Authorizer

apigateway.services.k8s.aws/v1alpha1

TypeLink
GoDocapigateway-controller/apis/v1alpha1#Authorizer

Metadata

PropertyValue
ScopeNamespaced
KindAuthorizer
ListKindAuthorizerList
Pluralauthorizers
Singularauthorizer

Represents an authorization layer for methods. If enabled on a method, API Gateway will activate the authorizer when a client calls the method.

Spec

authType: string
authorizerCredentials: string
authorizerResultTTLInSeconds: integer
authorizerURI: string
identitySource: string
identityValidationExpression: string
name: string
providerARNs:
- string
restAPIID: string
restAPIRef: 
  from: 
    name: string
    namespace: string
type: string
FieldDescription
authType
Optional
string
Optional customer-defined field, used in OpenAPI imports and exports without
functional impact.
authorizerCredentials
Optional
string
Specifies the required credentials as an IAM role for API Gateway to invoke
the authorizer. To specify an IAM role for API Gateway to assume, use the
role’s Amazon Resource Name (ARN). To use resource-based permissions on the
Lambda function, specify null.
authorizerResultTTLInSeconds
Optional
integer
The TTL in seconds of cached authorizer results. If it equals 0, authorization
caching is disabled. If it is greater than 0, API Gateway will cache authorizer
responses. If this field is not set, the default value is 300. The maximum
value is 3600, or 1 hour.
authorizerURI
Optional
string
Specifies the authorizer’s Uniform Resource Identifier (URI). For TOKEN or
REQUEST authorizers, this must be a well-formed Lambda function URI, for
example, arn:aws:apigateway:us-west-2:lambda:path/2015-03-31/functions/arn:aws:lambda:us-west-2:{account_id}:function:{lambda_function_name}/invocations.
In general, the URI has this form arn:aws:apigateway:{region}:lambda:path/{service_api},
where {region} is the same as the region hosting the Lambda function, path
indicates that the remaining substring in the URI should be treated as the
path to the resource, including the initial /. For Lambda functions, this
is usually of the form /2015-03-31/functions/[FunctionARN]/invocations.
identitySource
Optional
string
The identity source for which authorization is requested. For a TOKEN or
COGNITO_USER_POOLS authorizer, this is required and specifies the request
header mapping expression for the custom header holding the authorization
token submitted by the client. For example, if the token header name is Auth,
the header mapping expression is method.request.header.Auth. For the REQUEST
authorizer, this is required when authorization caching is enabled. The value
is a comma-separated string of one or more mapping expressions of the specified
request parameters. For example, if an Auth header, a Name query string parameter
are defined as identity sources, this value is method.request.header.Auth,
method.request.querystring.Name. These parameters will be used to derive
the authorization caching key and to perform runtime validation of the REQUEST
authorizer by verifying all of the identity-related request parameters are
present, not null and non-empty. Only when this is true does the authorizer
invoke the authorizer Lambda function, otherwise, it returns a 401 Unauthorized
response without calling the Lambda function. The valid value is a string
of comma-separated mapping expressions of the specified request parameters.
When the authorization caching is not enabled, this property is optional.
identityValidationExpression
Optional
string
A validation expression for the incoming identity token. For TOKEN authorizers,
this value is a regular expression. For COGNITO_USER_POOLS authorizers, API
Gateway will match the aud field of the incoming token from the client against
the specified regular expression. It will invoke the authorizer’s Lambda
function when there is a match. Otherwise, it will return a 401 Unauthorized
response without calling the Lambda function. The validation expression does
not apply to the REQUEST authorizer.
name
Required
string
The name of the authorizer.
providerARNs
Optional
array
A list of the Amazon Cognito user pool ARNs for the COGNITO_USER_POOLS authorizer.
Each element is of this format: arn:aws:cognito-idp:{region}:{account_id}:userpool/{user_pool_id}.
For a TOKEN or REQUEST authorizer, this is not defined.
providerARNs.[]
Required
string
restAPIRef
Optional
object
AWSResourceReferenceWrapper provides a wrapper around *AWSResourceReference
type to provide more user friendly syntax for references using ‘from’ field
Ex:
APIIDRef:

from:
name: my-api
restAPIRef.from
Optional
object
AWSResourceReference provides all the values necessary to reference another
k8s resource for finding the identifier(Id/ARN/Name)
restAPIRef.from.name
Optional
string
restAPIRef.from.namespace
Optional
string
type
Required
string
The authorizer type. Valid values are TOKEN for a Lambda function using a
single authorization token submitted in a custom header, REQUEST for a Lambda
function using incoming request parameters, and COGNITO_USER_POOLS for using
an Amazon Cognito user pool.

Status

ackResourceMetadata: 
  arn: string
  ownerAccountID: string
  region: string
conditions:
- lastTransitionTime: string
  message: string
  reason: string
  status: string
  type: string
id: string
FieldDescription
ackResourceMetadata
Optional
object
All CRs managed by ACK have a common Status.ACKResourceMetadata member
that is used to contain resource sync state, account ownership,
constructed ARN for the resource
ackResourceMetadata.arn
Optional
string
ARN is the Amazon Resource Name for the resource. This is a
globally-unique identifier and is set only by the ACK service controller
once the controller has orchestrated the creation of the resource OR
when it has verified that an “adopted” resource (a resource where the
ARN annotation was set by the Kubernetes user on the CR) exists and
matches the supplied CR’s Spec field values.
https://github.com/aws/aws-controllers-k8s/issues/270
ackResourceMetadata.ownerAccountID
Required
string
OwnerAccountID is the AWS Account ID of the account that owns the
backend AWS service API resource.
ackResourceMetadata.region
Required
string
Region is the AWS region in which the resource exists or will exist.
conditions
Optional
array
All CRs managed by ACK have a common Status.Conditions member that
contains a collection of ackv1alpha1.Condition objects that describe
the various terminal states of the CR and its backend AWS service API
resource
conditions.[]
Required
object
Condition is the common struct used by all CRDs managed by ACK service
controllers to indicate terminal states of the CR and its backend AWS
service API resource
conditions.[].message
Optional
string
A human readable message indicating details about the transition.
conditions.[].reason
Optional
string
The reason for the condition’s last transition.
conditions.[].status
Optional
string
Status of the condition, one of True, False, Unknown.
conditions.[].type
Optional
string
Type is the type of the Condition
id
Optional
string
The identifier for the authorizer resource.