Class RequestAuthorizerProps.Builder
java.lang.Object
software.amazon.awscdk.services.apigateway.RequestAuthorizerProps.Builder
- All Implemented Interfaces:
software.amazon.jsii.Builder<RequestAuthorizerProps>
- Enclosing interface:
- RequestAuthorizerProps
@Stability(Stable)
public static final class RequestAuthorizerProps.Builder
extends Object
implements software.amazon.jsii.Builder<RequestAuthorizerProps>
A builder for
RequestAuthorizerProps
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionassumeRole
(IRole assumeRole) Sets the value ofLambdaAuthorizerProps.getAssumeRole()
authorizerName
(String authorizerName) Sets the value ofLambdaAuthorizerProps.getAuthorizerName()
build()
Builds the configured instance.Sets the value ofLambdaAuthorizerProps.getHandler()
identitySources
(List<String> identitySources) Sets the value ofRequestAuthorizerProps.getIdentitySources()
resultsCacheTtl
(Duration resultsCacheTtl) Sets the value ofLambdaAuthorizerProps.getResultsCacheTtl()
-
Constructor Details
-
Builder
public Builder()
-
-
Method Details
-
identitySources
@Stability(Stable) public RequestAuthorizerProps.Builder identitySources(List<String> identitySources) Sets the value ofRequestAuthorizerProps.getIdentitySources()
- Parameters:
identitySources
- An array of request header mapping expressions for identities. This parameter is required. Supported parameter types are Header, Query String, Stage Variable, and Context. For instance, extracting an authorization token from a header would use the identity sourceIdentitySource.header('Authorizer')
.Note: API Gateway uses the specified identity sources as the request authorizer caching key. When caching is enabled, API Gateway calls the authorizer's Lambda function only after successfully verifying that all the specified identity sources are present at runtime. If a specified identify source is missing, null, or empty, API Gateway returns a 401 Unauthorized response without calling the authorizer Lambda function.
- Returns:
this
-
handler
Sets the value ofLambdaAuthorizerProps.getHandler()
- Parameters:
handler
- The handler for the authorizer lambda function. This parameter is required. The handler must follow a very specific protocol on the input it receives and the output it needs to produce. API Gateway has documented the handler's input specification {@link https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-lambda-authorizer-input.html | here} and output specification {@link https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-lambda-authorizer-output.html | here}.- Returns:
this
-
assumeRole
Sets the value ofLambdaAuthorizerProps.getAssumeRole()
- Parameters:
assumeRole
- An optional IAM role for APIGateway to assume before calling the Lambda-based authorizer. The IAM role must be assumable by 'apigateway.amazonaws.com'.- Returns:
this
-
authorizerName
Sets the value ofLambdaAuthorizerProps.getAuthorizerName()
- Parameters:
authorizerName
- An optional human friendly name for the authorizer. Note that, this is not the primary identifier of the authorizer.- Returns:
this
-
resultsCacheTtl
Sets the value ofLambdaAuthorizerProps.getResultsCacheTtl()
- Parameters:
resultsCacheTtl
- How long APIGateway should cache the results. Max 1 hour. Disable caching by setting this to 0.- Returns:
this
-
build
Builds the configured instance.- Specified by:
build
in interfacesoftware.amazon.jsii.Builder<RequestAuthorizerProps>
- Returns:
- a new instance of
RequestAuthorizerProps
- Throws:
NullPointerException
- if any required attribute was not provided
-