/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
* SPDX-License-Identifier: Apache-2.0.
*/
#pragma once
#include Creates a new Authorizer resource to represent an authorizer.See
* Also:
AWS
* API Reference
The API identifier.
*/ inline const Aws::String& GetApiId() const{ return m_apiId; } /** *The API identifier.
*/ inline bool ApiIdHasBeenSet() const { return m_apiIdHasBeenSet; } /** *The API identifier.
*/ inline void SetApiId(const Aws::String& value) { m_apiIdHasBeenSet = true; m_apiId = value; } /** *The API identifier.
*/ inline void SetApiId(Aws::String&& value) { m_apiIdHasBeenSet = true; m_apiId = std::move(value); } /** *The API identifier.
*/ inline void SetApiId(const char* value) { m_apiIdHasBeenSet = true; m_apiId.assign(value); } /** *The API identifier.
*/ inline CreateAuthorizerRequest& WithApiId(const Aws::String& value) { SetApiId(value); return *this;} /** *The API identifier.
*/ inline CreateAuthorizerRequest& WithApiId(Aws::String&& value) { SetApiId(std::move(value)); return *this;} /** *The API identifier.
*/ inline CreateAuthorizerRequest& WithApiId(const char* value) { SetApiId(value); return *this;} /** *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, don't specify this parameter. Supported only for REQUEST * authorizers.
*/ inline const Aws::String& GetAuthorizerCredentialsArn() const{ return m_authorizerCredentialsArn; } /** *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, don't specify this parameter. Supported only for REQUEST * authorizers.
*/ inline bool AuthorizerCredentialsArnHasBeenSet() const { return m_authorizerCredentialsArnHasBeenSet; } /** *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, don't specify this parameter. Supported only for REQUEST * authorizers.
*/ inline void SetAuthorizerCredentialsArn(const Aws::String& value) { m_authorizerCredentialsArnHasBeenSet = true; m_authorizerCredentialsArn = value; } /** *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, don't specify this parameter. Supported only for REQUEST * authorizers.
*/ inline void SetAuthorizerCredentialsArn(Aws::String&& value) { m_authorizerCredentialsArnHasBeenSet = true; m_authorizerCredentialsArn = std::move(value); } /** *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, don't specify this parameter. Supported only for REQUEST * authorizers.
*/ inline void SetAuthorizerCredentialsArn(const char* value) { m_authorizerCredentialsArnHasBeenSet = true; m_authorizerCredentialsArn.assign(value); } /** *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, don't specify this parameter. Supported only for REQUEST * authorizers.
*/ inline CreateAuthorizerRequest& WithAuthorizerCredentialsArn(const Aws::String& value) { SetAuthorizerCredentialsArn(value); return *this;} /** *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, don't specify this parameter. Supported only for REQUEST * authorizers.
*/ inline CreateAuthorizerRequest& WithAuthorizerCredentialsArn(Aws::String&& value) { SetAuthorizerCredentialsArn(std::move(value)); return *this;} /** *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, don't specify this parameter. Supported only for REQUEST * authorizers.
*/ inline CreateAuthorizerRequest& WithAuthorizerCredentialsArn(const char* value) { SetAuthorizerCredentialsArn(value); return *this;} /** *Specifies the format of the payload sent to an HTTP API Lambda authorizer. * Required for HTTP API Lambda authorizers. Supported values are 1.0 and 2.0. To * learn more, see Working * with AWS Lambda authorizers for HTTP APIs.
*/ inline const Aws::String& GetAuthorizerPayloadFormatVersion() const{ return m_authorizerPayloadFormatVersion; } /** *Specifies the format of the payload sent to an HTTP API Lambda authorizer. * Required for HTTP API Lambda authorizers. Supported values are 1.0 and 2.0. To * learn more, see Working * with AWS Lambda authorizers for HTTP APIs.
*/ inline bool AuthorizerPayloadFormatVersionHasBeenSet() const { return m_authorizerPayloadFormatVersionHasBeenSet; } /** *Specifies the format of the payload sent to an HTTP API Lambda authorizer. * Required for HTTP API Lambda authorizers. Supported values are 1.0 and 2.0. To * learn more, see Working * with AWS Lambda authorizers for HTTP APIs.
*/ inline void SetAuthorizerPayloadFormatVersion(const Aws::String& value) { m_authorizerPayloadFormatVersionHasBeenSet = true; m_authorizerPayloadFormatVersion = value; } /** *Specifies the format of the payload sent to an HTTP API Lambda authorizer. * Required for HTTP API Lambda authorizers. Supported values are 1.0 and 2.0. To * learn more, see Working * with AWS Lambda authorizers for HTTP APIs.
*/ inline void SetAuthorizerPayloadFormatVersion(Aws::String&& value) { m_authorizerPayloadFormatVersionHasBeenSet = true; m_authorizerPayloadFormatVersion = std::move(value); } /** *Specifies the format of the payload sent to an HTTP API Lambda authorizer. * Required for HTTP API Lambda authorizers. Supported values are 1.0 and 2.0. To * learn more, see Working * with AWS Lambda authorizers for HTTP APIs.
*/ inline void SetAuthorizerPayloadFormatVersion(const char* value) { m_authorizerPayloadFormatVersionHasBeenSet = true; m_authorizerPayloadFormatVersion.assign(value); } /** *Specifies the format of the payload sent to an HTTP API Lambda authorizer. * Required for HTTP API Lambda authorizers. Supported values are 1.0 and 2.0. To * learn more, see Working * with AWS Lambda authorizers for HTTP APIs.
*/ inline CreateAuthorizerRequest& WithAuthorizerPayloadFormatVersion(const Aws::String& value) { SetAuthorizerPayloadFormatVersion(value); return *this;} /** *Specifies the format of the payload sent to an HTTP API Lambda authorizer. * Required for HTTP API Lambda authorizers. Supported values are 1.0 and 2.0. To * learn more, see Working * with AWS Lambda authorizers for HTTP APIs.
*/ inline CreateAuthorizerRequest& WithAuthorizerPayloadFormatVersion(Aws::String&& value) { SetAuthorizerPayloadFormatVersion(std::move(value)); return *this;} /** *Specifies the format of the payload sent to an HTTP API Lambda authorizer. * Required for HTTP API Lambda authorizers. Supported values are 1.0 and 2.0. To * learn more, see Working * with AWS Lambda authorizers for HTTP APIs.
*/ inline CreateAuthorizerRequest& WithAuthorizerPayloadFormatVersion(const char* value) { SetAuthorizerPayloadFormatVersion(value); return *this;} /** *The time to live (TTL) for cached authorizer results, in seconds. If it * equals 0, authorization caching is disabled. If it is greater than 0, API * Gateway caches authorizer responses. The maximum value is 3600, or 1 hour. * Supported only for HTTP API Lambda authorizers.
*/ inline int GetAuthorizerResultTtlInSeconds() const{ return m_authorizerResultTtlInSeconds; } /** *The time to live (TTL) for cached authorizer results, in seconds. If it * equals 0, authorization caching is disabled. If it is greater than 0, API * Gateway caches authorizer responses. The maximum value is 3600, or 1 hour. * Supported only for HTTP API Lambda authorizers.
*/ inline bool AuthorizerResultTtlInSecondsHasBeenSet() const { return m_authorizerResultTtlInSecondsHasBeenSet; } /** *The time to live (TTL) for cached authorizer results, in seconds. If it * equals 0, authorization caching is disabled. If it is greater than 0, API * Gateway caches authorizer responses. The maximum value is 3600, or 1 hour. * Supported only for HTTP API Lambda authorizers.
*/ inline void SetAuthorizerResultTtlInSeconds(int value) { m_authorizerResultTtlInSecondsHasBeenSet = true; m_authorizerResultTtlInSeconds = value; } /** *The time to live (TTL) for cached authorizer results, in seconds. If it * equals 0, authorization caching is disabled. If it is greater than 0, API * Gateway caches authorizer responses. The maximum value is 3600, or 1 hour. * Supported only for HTTP API Lambda authorizers.
*/ inline CreateAuthorizerRequest& WithAuthorizerResultTtlInSeconds(int value) { SetAuthorizerResultTtlInSeconds(value); return *this;} /** *The authorizer type. Specify REQUEST for a Lambda function using incoming * request parameters. Specify JWT to use JSON Web Tokens (supported only for HTTP * APIs).
*/ inline const AuthorizerType& GetAuthorizerType() const{ return m_authorizerType; } /** *The authorizer type. Specify REQUEST for a Lambda function using incoming * request parameters. Specify JWT to use JSON Web Tokens (supported only for HTTP * APIs).
*/ inline bool AuthorizerTypeHasBeenSet() const { return m_authorizerTypeHasBeenSet; } /** *The authorizer type. Specify REQUEST for a Lambda function using incoming * request parameters. Specify JWT to use JSON Web Tokens (supported only for HTTP * APIs).
*/ inline void SetAuthorizerType(const AuthorizerType& value) { m_authorizerTypeHasBeenSet = true; m_authorizerType = value; } /** *The authorizer type. Specify REQUEST for a Lambda function using incoming * request parameters. Specify JWT to use JSON Web Tokens (supported only for HTTP * APIs).
*/ inline void SetAuthorizerType(AuthorizerType&& value) { m_authorizerTypeHasBeenSet = true; m_authorizerType = std::move(value); } /** *The authorizer type. Specify REQUEST for a Lambda function using incoming * request parameters. Specify JWT to use JSON Web Tokens (supported only for HTTP * APIs).
*/ inline CreateAuthorizerRequest& WithAuthorizerType(const AuthorizerType& value) { SetAuthorizerType(value); return *this;} /** *The authorizer type. Specify REQUEST for a Lambda function using incoming * request parameters. Specify JWT to use JSON Web Tokens (supported only for HTTP * APIs).
*/ inline CreateAuthorizerRequest& WithAuthorizerType(AuthorizerType&& value) { SetAuthorizerType(std::move(value)); return *this;} /** *The authorizer's Uniform Resource Identifier (URI). For 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:
The authorizer's Uniform Resource Identifier (URI). For 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:
The authorizer's Uniform Resource Identifier (URI). For 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:
The authorizer's Uniform Resource Identifier (URI). For 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:
The authorizer's Uniform Resource Identifier (URI). For 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:
The authorizer's Uniform Resource Identifier (URI). For 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:
The authorizer's Uniform Resource Identifier (URI). For 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:
The authorizer's Uniform Resource Identifier (URI). For 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:
Specifies whether a Lambda authorizer returns a response in a simple format. * By default, a Lambda authorizer must return an IAM policy. If enabled, the * Lambda authorizer can return a boolean value instead of an IAM policy. Supported * only for HTTP APIs. To learn more, see Working * with AWS Lambda authorizers for HTTP APIs
*/ inline bool GetEnableSimpleResponses() const{ return m_enableSimpleResponses; } /** *Specifies whether a Lambda authorizer returns a response in a simple format. * By default, a Lambda authorizer must return an IAM policy. If enabled, the * Lambda authorizer can return a boolean value instead of an IAM policy. Supported * only for HTTP APIs. To learn more, see Working * with AWS Lambda authorizers for HTTP APIs
*/ inline bool EnableSimpleResponsesHasBeenSet() const { return m_enableSimpleResponsesHasBeenSet; } /** *Specifies whether a Lambda authorizer returns a response in a simple format. * By default, a Lambda authorizer must return an IAM policy. If enabled, the * Lambda authorizer can return a boolean value instead of an IAM policy. Supported * only for HTTP APIs. To learn more, see Working * with AWS Lambda authorizers for HTTP APIs
*/ inline void SetEnableSimpleResponses(bool value) { m_enableSimpleResponsesHasBeenSet = true; m_enableSimpleResponses = value; } /** *Specifies whether a Lambda authorizer returns a response in a simple format. * By default, a Lambda authorizer must return an IAM policy. If enabled, the * Lambda authorizer can return a boolean value instead of an IAM policy. Supported * only for HTTP APIs. To learn more, see Working * with AWS Lambda authorizers for HTTP APIs
*/ inline CreateAuthorizerRequest& WithEnableSimpleResponses(bool value) { SetEnableSimpleResponses(value); return *this;} /** *The identity source for which authorization is requested.
For a * REQUEST authorizer, this is optional. The value is a set of one or more mapping * expressions of the specified request parameters. The identity source can be * headers, query string parameters, stage variables, and context parameters. For * example, if an Auth header and a Name query string parameter are defined as * identity sources, this value is route.request.header.Auth, * route.request.querystring.Name for WebSocket APIs. For HTTP APIs, use selection * expressions prefixed with $, for example, $request.header.Auth, * $request.querystring.Name. These parameters are used to perform runtime * validation for Lambda-based authorizers by verifying all of the identity-related * request parameters are present in the request, 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. For HTTP APIs, identity sources are also used as the cache key when * caching is enabled. To learn more, see Working * with AWS Lambda authorizers for HTTP APIs.
For JWT, a single entry * that specifies where to extract the JSON Web Token (JWT) from inbound requests. * Currently only header-based and query parameter-based selections are supported, * for example $request.header.Authorization.
*/ inline const Aws::VectorThe identity source for which authorization is requested.
For a * REQUEST authorizer, this is optional. The value is a set of one or more mapping * expressions of the specified request parameters. The identity source can be * headers, query string parameters, stage variables, and context parameters. For * example, if an Auth header and a Name query string parameter are defined as * identity sources, this value is route.request.header.Auth, * route.request.querystring.Name for WebSocket APIs. For HTTP APIs, use selection * expressions prefixed with $, for example, $request.header.Auth, * $request.querystring.Name. These parameters are used to perform runtime * validation for Lambda-based authorizers by verifying all of the identity-related * request parameters are present in the request, 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. For HTTP APIs, identity sources are also used as the cache key when * caching is enabled. To learn more, see Working * with AWS Lambda authorizers for HTTP APIs.
For JWT, a single entry * that specifies where to extract the JSON Web Token (JWT) from inbound requests. * Currently only header-based and query parameter-based selections are supported, * for example $request.header.Authorization.
*/ inline bool IdentitySourceHasBeenSet() const { return m_identitySourceHasBeenSet; } /** *The identity source for which authorization is requested.
For a * REQUEST authorizer, this is optional. The value is a set of one or more mapping * expressions of the specified request parameters. The identity source can be * headers, query string parameters, stage variables, and context parameters. For * example, if an Auth header and a Name query string parameter are defined as * identity sources, this value is route.request.header.Auth, * route.request.querystring.Name for WebSocket APIs. For HTTP APIs, use selection * expressions prefixed with $, for example, $request.header.Auth, * $request.querystring.Name. These parameters are used to perform runtime * validation for Lambda-based authorizers by verifying all of the identity-related * request parameters are present in the request, 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. For HTTP APIs, identity sources are also used as the cache key when * caching is enabled. To learn more, see Working * with AWS Lambda authorizers for HTTP APIs.
For JWT, a single entry * that specifies where to extract the JSON Web Token (JWT) from inbound requests. * Currently only header-based and query parameter-based selections are supported, * for example $request.header.Authorization.
*/ inline void SetIdentitySource(const Aws::VectorThe identity source for which authorization is requested.
For a * REQUEST authorizer, this is optional. The value is a set of one or more mapping * expressions of the specified request parameters. The identity source can be * headers, query string parameters, stage variables, and context parameters. For * example, if an Auth header and a Name query string parameter are defined as * identity sources, this value is route.request.header.Auth, * route.request.querystring.Name for WebSocket APIs. For HTTP APIs, use selection * expressions prefixed with $, for example, $request.header.Auth, * $request.querystring.Name. These parameters are used to perform runtime * validation for Lambda-based authorizers by verifying all of the identity-related * request parameters are present in the request, 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. For HTTP APIs, identity sources are also used as the cache key when * caching is enabled. To learn more, see Working * with AWS Lambda authorizers for HTTP APIs.
For JWT, a single entry * that specifies where to extract the JSON Web Token (JWT) from inbound requests. * Currently only header-based and query parameter-based selections are supported, * for example $request.header.Authorization.
*/ inline void SetIdentitySource(Aws::VectorThe identity source for which authorization is requested.
For a * REQUEST authorizer, this is optional. The value is a set of one or more mapping * expressions of the specified request parameters. The identity source can be * headers, query string parameters, stage variables, and context parameters. For * example, if an Auth header and a Name query string parameter are defined as * identity sources, this value is route.request.header.Auth, * route.request.querystring.Name for WebSocket APIs. For HTTP APIs, use selection * expressions prefixed with $, for example, $request.header.Auth, * $request.querystring.Name. These parameters are used to perform runtime * validation for Lambda-based authorizers by verifying all of the identity-related * request parameters are present in the request, 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. For HTTP APIs, identity sources are also used as the cache key when * caching is enabled. To learn more, see Working * with AWS Lambda authorizers for HTTP APIs.
For JWT, a single entry * that specifies where to extract the JSON Web Token (JWT) from inbound requests. * Currently only header-based and query parameter-based selections are supported, * for example $request.header.Authorization.
*/ inline CreateAuthorizerRequest& WithIdentitySource(const Aws::VectorThe identity source for which authorization is requested.
For a * REQUEST authorizer, this is optional. The value is a set of one or more mapping * expressions of the specified request parameters. The identity source can be * headers, query string parameters, stage variables, and context parameters. For * example, if an Auth header and a Name query string parameter are defined as * identity sources, this value is route.request.header.Auth, * route.request.querystring.Name for WebSocket APIs. For HTTP APIs, use selection * expressions prefixed with $, for example, $request.header.Auth, * $request.querystring.Name. These parameters are used to perform runtime * validation for Lambda-based authorizers by verifying all of the identity-related * request parameters are present in the request, 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. For HTTP APIs, identity sources are also used as the cache key when * caching is enabled. To learn more, see Working * with AWS Lambda authorizers for HTTP APIs.
For JWT, a single entry * that specifies where to extract the JSON Web Token (JWT) from inbound requests. * Currently only header-based and query parameter-based selections are supported, * for example $request.header.Authorization.
*/ inline CreateAuthorizerRequest& WithIdentitySource(Aws::VectorThe identity source for which authorization is requested.
For a * REQUEST authorizer, this is optional. The value is a set of one or more mapping * expressions of the specified request parameters. The identity source can be * headers, query string parameters, stage variables, and context parameters. For * example, if an Auth header and a Name query string parameter are defined as * identity sources, this value is route.request.header.Auth, * route.request.querystring.Name for WebSocket APIs. For HTTP APIs, use selection * expressions prefixed with $, for example, $request.header.Auth, * $request.querystring.Name. These parameters are used to perform runtime * validation for Lambda-based authorizers by verifying all of the identity-related * request parameters are present in the request, 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. For HTTP APIs, identity sources are also used as the cache key when * caching is enabled. To learn more, see Working * with AWS Lambda authorizers for HTTP APIs.
For JWT, a single entry * that specifies where to extract the JSON Web Token (JWT) from inbound requests. * Currently only header-based and query parameter-based selections are supported, * for example $request.header.Authorization.
*/ inline CreateAuthorizerRequest& AddIdentitySource(const Aws::String& value) { m_identitySourceHasBeenSet = true; m_identitySource.push_back(value); return *this; } /** *The identity source for which authorization is requested.
For a * REQUEST authorizer, this is optional. The value is a set of one or more mapping * expressions of the specified request parameters. The identity source can be * headers, query string parameters, stage variables, and context parameters. For * example, if an Auth header and a Name query string parameter are defined as * identity sources, this value is route.request.header.Auth, * route.request.querystring.Name for WebSocket APIs. For HTTP APIs, use selection * expressions prefixed with $, for example, $request.header.Auth, * $request.querystring.Name. These parameters are used to perform runtime * validation for Lambda-based authorizers by verifying all of the identity-related * request parameters are present in the request, 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. For HTTP APIs, identity sources are also used as the cache key when * caching is enabled. To learn more, see Working * with AWS Lambda authorizers for HTTP APIs.
For JWT, a single entry * that specifies where to extract the JSON Web Token (JWT) from inbound requests. * Currently only header-based and query parameter-based selections are supported, * for example $request.header.Authorization.
*/ inline CreateAuthorizerRequest& AddIdentitySource(Aws::String&& value) { m_identitySourceHasBeenSet = true; m_identitySource.push_back(std::move(value)); return *this; } /** *The identity source for which authorization is requested.
For a * REQUEST authorizer, this is optional. The value is a set of one or more mapping * expressions of the specified request parameters. The identity source can be * headers, query string parameters, stage variables, and context parameters. For * example, if an Auth header and a Name query string parameter are defined as * identity sources, this value is route.request.header.Auth, * route.request.querystring.Name for WebSocket APIs. For HTTP APIs, use selection * expressions prefixed with $, for example, $request.header.Auth, * $request.querystring.Name. These parameters are used to perform runtime * validation for Lambda-based authorizers by verifying all of the identity-related * request parameters are present in the request, 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. For HTTP APIs, identity sources are also used as the cache key when * caching is enabled. To learn more, see Working * with AWS Lambda authorizers for HTTP APIs.
For JWT, a single entry * that specifies where to extract the JSON Web Token (JWT) from inbound requests. * Currently only header-based and query parameter-based selections are supported, * for example $request.header.Authorization.
*/ inline CreateAuthorizerRequest& AddIdentitySource(const char* value) { m_identitySourceHasBeenSet = true; m_identitySource.push_back(value); return *this; } /** *This parameter is not used.
*/ inline const Aws::String& GetIdentityValidationExpression() const{ return m_identityValidationExpression; } /** *This parameter is not used.
*/ inline bool IdentityValidationExpressionHasBeenSet() const { return m_identityValidationExpressionHasBeenSet; } /** *This parameter is not used.
*/ inline void SetIdentityValidationExpression(const Aws::String& value) { m_identityValidationExpressionHasBeenSet = true; m_identityValidationExpression = value; } /** *This parameter is not used.
*/ inline void SetIdentityValidationExpression(Aws::String&& value) { m_identityValidationExpressionHasBeenSet = true; m_identityValidationExpression = std::move(value); } /** *This parameter is not used.
*/ inline void SetIdentityValidationExpression(const char* value) { m_identityValidationExpressionHasBeenSet = true; m_identityValidationExpression.assign(value); } /** *This parameter is not used.
*/ inline CreateAuthorizerRequest& WithIdentityValidationExpression(const Aws::String& value) { SetIdentityValidationExpression(value); return *this;} /** *This parameter is not used.
*/ inline CreateAuthorizerRequest& WithIdentityValidationExpression(Aws::String&& value) { SetIdentityValidationExpression(std::move(value)); return *this;} /** *This parameter is not used.
*/ inline CreateAuthorizerRequest& WithIdentityValidationExpression(const char* value) { SetIdentityValidationExpression(value); return *this;} /** *Represents the configuration of a JWT authorizer. Required for the JWT * authorizer type. Supported only for HTTP APIs.
*/ inline const JWTConfiguration& GetJwtConfiguration() const{ return m_jwtConfiguration; } /** *Represents the configuration of a JWT authorizer. Required for the JWT * authorizer type. Supported only for HTTP APIs.
*/ inline bool JwtConfigurationHasBeenSet() const { return m_jwtConfigurationHasBeenSet; } /** *Represents the configuration of a JWT authorizer. Required for the JWT * authorizer type. Supported only for HTTP APIs.
*/ inline void SetJwtConfiguration(const JWTConfiguration& value) { m_jwtConfigurationHasBeenSet = true; m_jwtConfiguration = value; } /** *Represents the configuration of a JWT authorizer. Required for the JWT * authorizer type. Supported only for HTTP APIs.
*/ inline void SetJwtConfiguration(JWTConfiguration&& value) { m_jwtConfigurationHasBeenSet = true; m_jwtConfiguration = std::move(value); } /** *Represents the configuration of a JWT authorizer. Required for the JWT * authorizer type. Supported only for HTTP APIs.
*/ inline CreateAuthorizerRequest& WithJwtConfiguration(const JWTConfiguration& value) { SetJwtConfiguration(value); return *this;} /** *Represents the configuration of a JWT authorizer. Required for the JWT * authorizer type. Supported only for HTTP APIs.
*/ inline CreateAuthorizerRequest& WithJwtConfiguration(JWTConfiguration&& value) { SetJwtConfiguration(std::move(value)); return *this;} /** *The name of the authorizer.
*/ inline const Aws::String& GetName() const{ return m_name; } /** *The name of the authorizer.
*/ inline bool NameHasBeenSet() const { return m_nameHasBeenSet; } /** *The name of the authorizer.
*/ inline void SetName(const Aws::String& value) { m_nameHasBeenSet = true; m_name = value; } /** *The name of the authorizer.
*/ inline void SetName(Aws::String&& value) { m_nameHasBeenSet = true; m_name = std::move(value); } /** *The name of the authorizer.
*/ inline void SetName(const char* value) { m_nameHasBeenSet = true; m_name.assign(value); } /** *The name of the authorizer.
*/ inline CreateAuthorizerRequest& WithName(const Aws::String& value) { SetName(value); return *this;} /** *The name of the authorizer.
*/ inline CreateAuthorizerRequest& WithName(Aws::String&& value) { SetName(std::move(value)); return *this;} /** *The name of the authorizer.
*/ inline CreateAuthorizerRequest& WithName(const char* value) { SetName(value); return *this;} private: Aws::String m_apiId; bool m_apiIdHasBeenSet = false; Aws::String m_authorizerCredentialsArn; bool m_authorizerCredentialsArnHasBeenSet = false; Aws::String m_authorizerPayloadFormatVersion; bool m_authorizerPayloadFormatVersionHasBeenSet = false; int m_authorizerResultTtlInSeconds; bool m_authorizerResultTtlInSecondsHasBeenSet = false; AuthorizerType m_authorizerType; bool m_authorizerTypeHasBeenSet = false; Aws::String m_authorizerUri; bool m_authorizerUriHasBeenSet = false; bool m_enableSimpleResponses; bool m_enableSimpleResponsesHasBeenSet = false; Aws::Vector