# frozen_string_literal: true # WARNING ABOUT GENERATED CODE # # This file is generated. See the contributing guide for more information: # https://github.com/aws/aws-sdk-ruby/blob/version-3/CONTRIBUTING.md # # WARNING ABOUT GENERATED CODE module Aws::APIGateway module Types # Access log settings, including the access log format and access log # destination ARN. # # @!attribute [rw] format # A single line format of the access logs of data, as specified by # selected [$context variables][1]. The format must include at least # `$context.requestId`. # # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-mapping-template-reference.html#context-variable-reference # @return [String] # # @!attribute [rw] destination_arn # The Amazon Resource Name (ARN) of the CloudWatch Logs log group or # Kinesis Data Firehose delivery stream to receive access logs. If you # specify a Kinesis Data Firehose delivery stream, the stream name # must begin with `amazon-apigateway-`. # @return [String] # class AccessLogSettings < Struct.new( :format, :destination_arn) SENSITIVE = [] include Aws::Structure end # Represents an AWS account that is associated with API Gateway. # #
# To view the account info, call `GET` on this resource. # # #### Error Codes # # The following exception may be thrown when the request fails. # # * UnauthorizedException # * NotFoundException # * TooManyRequestsException # # For detailed error code information, including the corresponding HTTP # Status Codes, see [API Gateway Error Codes][1] # # #### Example: Get the information about an account. # # ##### Request # # GET /account HTTP/1.1 Content-Type: application/json Host: apigateway.us-east-1.amazonaws.com X-Amz-Date: 20160531T184618Z Authorization: AWS4-HMAC-SHA256 Credential=\{access_key_ID\}/us-east-1/apigateway/aws4_request, SignedHeaders=content-type;host;x-amz-date, Signature=\{sig4_hash\} # # ##### Response # # The successful response returns a `200 OK` status code and a payload # similar to the following: # # \{ "_links": \{ "curies": \{ "href": "https://docs.aws.amazon.com/apigateway/latest/developerguide/account-apigateway-\{rel\}.html", "name": "account", "templated": true \}, "self": \{ "href": "/account" \}, "account:update": \{ "href": "/account" \} \}, "cloudwatchRoleArn": "arn:aws:iam::123456789012:role/apigAwsProxyRole", "throttleSettings": \{ "rateLimit": 500, "burstLimit": 1000 \} \} # # In addition to making the REST API call directly, you can use the AWS # CLI and an AWS SDK to access this resource. # #
# #
# [API Gateway Limits][2] [Developer Guide][3], [AWS CLI][4] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/api-reference/handling-errors/#api-error-codes # [2]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-limits.html # [3]: https://docs.aws.amazon.com/apigateway/latest/developerguide/welcome.html # [4]: https://docs.aws.amazon.com/cli/latest/reference/apigateway/get-account.html # # @!attribute [rw] cloudwatch_role_arn # The ARN of an Amazon CloudWatch role for the current Account. # @return [String] # # @!attribute [rw] throttle_settings # Specifies the API request limits configured for the current Account. # @return [Types::ThrottleSettings] # # @!attribute [rw] features # A list of features supported for the account. When usage plans are # enabled, the features list will include an entry of `"UsagePlans"`. # @return [Array] # # @!attribute [rw] api_key_version # The version of the API keys used for the account. # @return [String] # class Account < Struct.new( :cloudwatch_role_arn, :throttle_settings, :features, :api_key_version) SENSITIVE = [] include Aws::Structure end # A resource that can be distributed to callers for executing Method # resources that require an API key. API keys can be mapped to any Stage # on any RestApi, which indicates that the callers with the API key can # make requests to that stage. # #
# [Use API Keys][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/how-to-api-keys.html # # @!attribute [rw] id # The identifier of the API Key. # @return [String] # # @!attribute [rw] value # The value of the API Key. # @return [String] # # @!attribute [rw] name # The name of the API Key. # @return [String] # # @!attribute [rw] customer_id # An AWS Marketplace customer identifier , when integrating with the # AWS SaaS Marketplace. # @return [String] # # @!attribute [rw] description # The description of the API Key. # @return [String] # # @!attribute [rw] enabled # Specifies whether the API Key can be used by callers. # @return [Boolean] # # @!attribute [rw] created_date # The timestamp when the API Key was created. # @return [Time] # # @!attribute [rw] last_updated_date # The timestamp when the API Key was last updated. # @return [Time] # # @!attribute [rw] stage_keys # A list of Stage resources that are associated with the ApiKey # resource. # @return [Array] # # @!attribute [rw] tags # The collection of tags. Each tag element is associated with a given # resource. # @return [Hash] # class ApiKey < Struct.new( :id, :value, :name, :customer_id, :description, :enabled, :created_date, :last_updated_date, :stage_keys, :tags) SENSITIVE = [] include Aws::Structure end # The identifier of an ApiKey used in a UsagePlan. # # @!attribute [rw] ids # A list of all the ApiKey identifiers. # @return [Array] # # @!attribute [rw] warnings # A list of warning messages. # @return [Array] # class ApiKeyIds < Struct.new( :ids, :warnings) SENSITIVE = [] include Aws::Structure end # Represents a collection of API keys as represented by an ApiKeys # resource. # #
# [Use API Keys][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/how-to-api-keys.html # # @!attribute [rw] warnings # A list of warning messages logged during the import of API keys when # the `failOnWarnings` option is set to true. # @return [Array] # # @!attribute [rw] position # @return [String] # # @!attribute [rw] items # The current page of elements from this collection. # @return [Array] # class ApiKeys < Struct.new( :warnings, :position, :items) SENSITIVE = [] include Aws::Structure end # API stage name of the associated API stage in a usage plan. # # @note When making an API call, you may pass ApiStage # data as a hash: # # { # api_id: "String", # stage: "String", # throttle: { # "String" => { # burst_limit: 1, # rate_limit: 1.0, # }, # }, # } # # @!attribute [rw] api_id # API Id of the associated API stage in a usage plan. # @return [String] # # @!attribute [rw] stage # API stage name of the associated API stage in a usage plan. # @return [String] # # @!attribute [rw] throttle # Map containing method level throttling information for API stage in # a usage plan. # @return [Hash] # class ApiStage < Struct.new( :api_id, :stage, :throttle) SENSITIVE = [] include Aws::Structure end # Represents an authorization layer for methods. If enabled on a method, # API Gateway will activate the authorizer when a client calls the # method. # #
# [Use Lambda Function as Authorizer][1] [Use Cognito User Pool as # Authorizer][2] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-use-lambda-authorizer.html # [2]: https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-integrate-with-cognito.html # # @!attribute [rw] id # The identifier for the authorizer resource. # @return [String] # # @!attribute [rw] name # \[Required\] The name of the authorizer. # @return [String] # # @!attribute [rw] type # 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. # @return [String] # # @!attribute [rw] provider_arns # 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. # @return [Array] # # @!attribute [rw] auth_type # Optional customer-defined field, used in OpenAPI imports and exports # without functional impact. # @return [String] # # @!attribute [rw] authorizer_uri # 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`. # @return [String] # # @!attribute [rw] authorizer_credentials # 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. # @return [String] # # @!attribute [rw] identity_source # 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. # @return [String] # # @!attribute [rw] identity_validation_expression # 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. # @return [String] # # @!attribute [rw] authorizer_result_ttl_in_seconds # 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. # @return [Integer] # class Authorizer < Struct.new( :id, :name, :type, :provider_arns, :auth_type, :authorizer_uri, :authorizer_credentials, :identity_source, :identity_validation_expression, :authorizer_result_ttl_in_seconds) SENSITIVE = [] include Aws::Structure end # Represents a collection of Authorizer resources. # #
# [Use Lambda Function as Authorizer][1] [Use Cognito User Pool as # Authorizer][2] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-use-lambda-authorizer.html # [2]: https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-integrate-with-cognito.html # # @!attribute [rw] position # @return [String] # # @!attribute [rw] items # The current page of elements from this collection. # @return [Array] # class Authorizers < Struct.new( :position, :items) SENSITIVE = [] include Aws::Structure end # The submitted request is not valid, for example, the input is # incomplete or incorrect. See the accompanying error message for # details. # # @!attribute [rw] message # @return [String] # class BadRequestException < Struct.new( :message) SENSITIVE = [] include Aws::Structure end # Represents the base path that callers of the API must provide as part # of the URL after the domain name. # #
# A custom domain name plus a `BasePathMapping` specification identifies # a deployed RestApi in a given stage of the owner Account. #
# #
# [Use Custom Domain Names][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/how-to-custom-domains.html # # @!attribute [rw] base_path # The base path name that callers of the API must provide as part of # the URL after the domain name. # @return [String] # # @!attribute [rw] rest_api_id # The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] stage # The name of the associated stage. # @return [String] # class BasePathMapping < Struct.new( :base_path, :rest_api_id, :stage) SENSITIVE = [] include Aws::Structure end # Represents a collection of BasePathMapping resources. # #
# [Use Custom Domain Names][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/how-to-custom-domains.html # # @!attribute [rw] position # @return [String] # # @!attribute [rw] items # The current page of elements from this collection. # @return [Array] # class BasePathMappings < Struct.new( :position, :items) SENSITIVE = [] include Aws::Structure end # Configuration settings of a canary deployment. # # @note When making an API call, you may pass CanarySettings # data as a hash: # # { # percent_traffic: 1.0, # deployment_id: "String", # stage_variable_overrides: { # "String" => "String", # }, # use_stage_cache: false, # } # # @!attribute [rw] percent_traffic # The percent (0-100) of traffic diverted to a canary deployment. # @return [Float] # # @!attribute [rw] deployment_id # The ID of the canary deployment. # @return [String] # # @!attribute [rw] stage_variable_overrides # Stage variables overridden for a canary release deployment, # including new stage variables introduced in the canary. These stage # variables are represented as a string-to-string map between stage # variable names and their values. # @return [Hash] # # @!attribute [rw] use_stage_cache # A Boolean flag to indicate whether the canary deployment uses the # stage cache or not. # @return [Boolean] # class CanarySettings < Struct.new( :percent_traffic, :deployment_id, :stage_variable_overrides, :use_stage_cache) SENSITIVE = [] include Aws::Structure end # Represents a client certificate used to configure client-side SSL # authentication while sending requests to the integration endpoint. # #
# Client certificates are used to authenticate an API by the backend # server. To authenticate an API client (or user), use IAM roles and # policies, a custom Authorizer or an Amazon Cognito user pool. #
# #
# [Use Client-Side Certificate][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/getting-started-client-side-ssl-authentication.html # # @!attribute [rw] client_certificate_id # The identifier of the client certificate. # @return [String] # # @!attribute [rw] description # The description of the client certificate. # @return [String] # # @!attribute [rw] pem_encoded_certificate # The PEM-encoded public key of the client certificate, which can be # used to configure certificate authentication in the integration # endpoint . # @return [String] # # @!attribute [rw] created_date # The timestamp when the client certificate was created. # @return [Time] # # @!attribute [rw] expiration_date # The timestamp when the client certificate will expire. # @return [Time] # # @!attribute [rw] tags # The collection of tags. Each tag element is associated with a given # resource. # @return [Hash] # class ClientCertificate < Struct.new( :client_certificate_id, :description, :pem_encoded_certificate, :created_date, :expiration_date, :tags) SENSITIVE = [] include Aws::Structure end # Represents a collection of ClientCertificate resources. # #
# [Use Client-Side Certificate][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/getting-started-client-side-ssl-authentication.html # # @!attribute [rw] position # @return [String] # # @!attribute [rw] items # The current page of elements from this collection. # @return [Array] # class ClientCertificates < Struct.new( :position, :items) SENSITIVE = [] include Aws::Structure end # The request configuration has conflicts. For details, see the # accompanying error message. # # @!attribute [rw] message # @return [String] # class ConflictException < Struct.new( :message) SENSITIVE = [] include Aws::Structure end # Request to create an ApiKey resource. # # @note When making an API call, you may pass CreateApiKeyRequest # data as a hash: # # { # name: "String", # description: "String", # enabled: false, # generate_distinct_id: false, # value: "String", # stage_keys: [ # { # rest_api_id: "String", # stage_name: "String", # }, # ], # customer_id: "String", # tags: { # "String" => "String", # }, # } # # @!attribute [rw] name # The name of the ApiKey. # @return [String] # # @!attribute [rw] description # The description of the ApiKey. # @return [String] # # @!attribute [rw] enabled # Specifies whether the ApiKey can be used by callers. # @return [Boolean] # # @!attribute [rw] generate_distinct_id # Specifies whether (`true`) or not (`false`) the key identifier is # distinct from the created API key value. This parameter is # deprecated and should not be used. # @return [Boolean] # # @!attribute [rw] value # Specifies a value of the API key. # @return [String] # # @!attribute [rw] stage_keys # DEPRECATED FOR USAGE PLANS - Specifies stages associated with the # API key. # @return [Array] # # @!attribute [rw] customer_id # An AWS Marketplace customer identifier , when integrating with the # AWS SaaS Marketplace. # @return [String] # # @!attribute [rw] tags # The key-value map of strings. The valid character set is # \[a-zA-Z+-=.\_:/\]. The tag key can be up to 128 characters and must # not start with `aws:`. The tag value can be up to 256 characters. # @return [Hash] # class CreateApiKeyRequest < Struct.new( :name, :description, :enabled, :generate_distinct_id, :value, :stage_keys, :customer_id, :tags) SENSITIVE = [] include Aws::Structure end # Request to add a new Authorizer to an existing RestApi resource. # # @note When making an API call, you may pass CreateAuthorizerRequest # data as a hash: # # { # rest_api_id: "String", # required # name: "String", # required # type: "TOKEN", # required, accepts TOKEN, REQUEST, COGNITO_USER_POOLS # provider_arns: ["ProviderARN"], # auth_type: "String", # authorizer_uri: "String", # authorizer_credentials: "String", # identity_source: "String", # identity_validation_expression: "String", # authorizer_result_ttl_in_seconds: 1, # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] name # \[Required\] The name of the authorizer. # @return [String] # # @!attribute [rw] type # \[Required\] 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. # @return [String] # # @!attribute [rw] provider_arns # 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. # @return [Array] # # @!attribute [rw] auth_type # Optional customer-defined field, used in OpenAPI imports and exports # without functional impact. # @return [String] # # @!attribute [rw] authorizer_uri # 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`. # @return [String] # # @!attribute [rw] authorizer_credentials # 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. # @return [String] # # @!attribute [rw] identity_source # 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. # @return [String] # # @!attribute [rw] identity_validation_expression # 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. # @return [String] # # @!attribute [rw] authorizer_result_ttl_in_seconds # 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. # @return [Integer] # class CreateAuthorizerRequest < Struct.new( :rest_api_id, :name, :type, :provider_arns, :auth_type, :authorizer_uri, :authorizer_credentials, :identity_source, :identity_validation_expression, :authorizer_result_ttl_in_seconds) SENSITIVE = [] include Aws::Structure end # Requests API Gateway to create a new BasePathMapping resource. # # @note When making an API call, you may pass CreateBasePathMappingRequest # data as a hash: # # { # domain_name: "String", # required # base_path: "String", # rest_api_id: "String", # required # stage: "String", # } # # @!attribute [rw] domain_name # \[Required\] The domain name of the BasePathMapping resource to # create. # @return [String] # # @!attribute [rw] base_path # The base path name that callers of the API must provide as part of # the URL after the domain name. This value must be unique for all of # the mappings across a single API. Specify '(none)' if you do not # want callers to specify a base path name after the domain name. # @return [String] # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] stage # The name of the API's stage that you want to use for this mapping. # Specify '(none)' if you want callers to explicitly specify the # stage name after any base path name. # @return [String] # class CreateBasePathMappingRequest < Struct.new( :domain_name, :base_path, :rest_api_id, :stage) SENSITIVE = [] include Aws::Structure end # Requests API Gateway to create a Deployment resource. # # @note When making an API call, you may pass CreateDeploymentRequest # data as a hash: # # { # rest_api_id: "String", # required # stage_name: "String", # stage_description: "String", # description: "String", # cache_cluster_enabled: false, # cache_cluster_size: "0.5", # accepts 0.5, 1.6, 6.1, 13.5, 28.4, 58.2, 118, 237 # variables: { # "String" => "String", # }, # canary_settings: { # percent_traffic: 1.0, # stage_variable_overrides: { # "String" => "String", # }, # use_stage_cache: false, # }, # tracing_enabled: false, # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] stage_name # The name of the Stage resource for the Deployment resource to # create. # @return [String] # # @!attribute [rw] stage_description # The description of the Stage resource for the Deployment resource to # create. # @return [String] # # @!attribute [rw] description # The description for the Deployment resource to create. # @return [String] # # @!attribute [rw] cache_cluster_enabled # Enables a cache cluster for the Stage resource specified in the # input. # @return [Boolean] # # @!attribute [rw] cache_cluster_size # Specifies the cache cluster size for the Stage resource specified in # the input, if a cache cluster is enabled. # @return [String] # # @!attribute [rw] variables # A map that defines the stage variables for the Stage resource that # is associated with the new deployment. Variable names can have # alphanumeric and underscore characters, and the values must match # `[A-Za-z0-9-._~:/?#&=,]+`. # @return [Hash] # # @!attribute [rw] canary_settings # The input configuration for the canary deployment when the # deployment is a canary release deployment. # @return [Types::DeploymentCanarySettings] # # @!attribute [rw] tracing_enabled # Specifies whether active tracing with X-ray is enabled for the # Stage. # @return [Boolean] # class CreateDeploymentRequest < Struct.new( :rest_api_id, :stage_name, :stage_description, :description, :cache_cluster_enabled, :cache_cluster_size, :variables, :canary_settings, :tracing_enabled) SENSITIVE = [] include Aws::Structure end # Creates a new documentation part of a given API. # # @note When making an API call, you may pass CreateDocumentationPartRequest # data as a hash: # # { # rest_api_id: "String", # required # location: { # required # type: "API", # required, accepts API, AUTHORIZER, MODEL, RESOURCE, METHOD, PATH_PARAMETER, QUERY_PARAMETER, REQUEST_HEADER, REQUEST_BODY, RESPONSE, RESPONSE_HEADER, RESPONSE_BODY # path: "String", # method: "String", # status_code: "DocumentationPartLocationStatusCode", # name: "String", # }, # properties: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] location # \[Required\] The location of the targeted API entity of the # to-be-created documentation part. # @return [Types::DocumentationPartLocation] # # @!attribute [rw] properties # \[Required\] The new documentation content map of the targeted API # entity. Enclosed key-value pairs are API-specific, but only # OpenAPI-compliant key-value pairs can be exported and, hence, # published. # @return [String] # class CreateDocumentationPartRequest < Struct.new( :rest_api_id, :location, :properties) SENSITIVE = [] include Aws::Structure end # Creates a new documentation version of a given API. # # @note When making an API call, you may pass CreateDocumentationVersionRequest # data as a hash: # # { # rest_api_id: "String", # required # documentation_version: "String", # required # stage_name: "String", # description: "String", # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] documentation_version # \[Required\] The version identifier of the new snapshot. # @return [String] # # @!attribute [rw] stage_name # The stage name to be associated with the new documentation snapshot. # @return [String] # # @!attribute [rw] description # A description about the new documentation snapshot. # @return [String] # class CreateDocumentationVersionRequest < Struct.new( :rest_api_id, :documentation_version, :stage_name, :description) SENSITIVE = [] include Aws::Structure end # A request to create a new domain name. # # @note When making an API call, you may pass CreateDomainNameRequest # data as a hash: # # { # domain_name: "String", # required # certificate_name: "String", # certificate_body: "String", # certificate_private_key: "String", # certificate_chain: "String", # certificate_arn: "String", # regional_certificate_name: "String", # regional_certificate_arn: "String", # endpoint_configuration: { # types: ["REGIONAL"], # accepts REGIONAL, EDGE, PRIVATE # vpc_endpoint_ids: ["String"], # }, # tags: { # "String" => "String", # }, # security_policy: "TLS_1_0", # accepts TLS_1_0, TLS_1_2 # mutual_tls_authentication: { # truststore_uri: "String", # truststore_version: "String", # }, # } # # @!attribute [rw] domain_name # \[Required\] The name of the DomainName resource. # @return [String] # # @!attribute [rw] certificate_name # The user-friendly name of the certificate that will be used by # edge-optimized endpoint for this domain name. # @return [String] # # @!attribute [rw] certificate_body # \[Deprecated\] The body of the server certificate that will be used # by edge-optimized endpoint for this domain name provided by your # certificate authority. # @return [String] # # @!attribute [rw] certificate_private_key # \[Deprecated\] Your edge-optimized endpoint's domain name # certificate's private key. # @return [String] # # @!attribute [rw] certificate_chain # \[Deprecated\] The intermediate certificates and optionally the root # certificate, one after the other without any blank lines, used by an # edge-optimized endpoint for this domain name. If you include the # root certificate, your certificate chain must start with # intermediate certificates and end with the root certificate. Use the # intermediate certificates that were provided by your certificate # authority. Do not include any intermediaries that are not in the # chain of trust path. # @return [String] # # @!attribute [rw] certificate_arn # The reference to an AWS-managed certificate that will be used by # edge-optimized endpoint for this domain name. AWS Certificate # Manager is the only supported source. # @return [String] # # @!attribute [rw] regional_certificate_name # The user-friendly name of the certificate that will be used by # regional endpoint for this domain name. # @return [String] # # @!attribute [rw] regional_certificate_arn # The reference to an AWS-managed certificate that will be used by # regional endpoint for this domain name. AWS Certificate Manager is # the only supported source. # @return [String] # # @!attribute [rw] endpoint_configuration # The endpoint configuration of this DomainName showing the endpoint # types of the domain name. # @return [Types::EndpointConfiguration] # # @!attribute [rw] tags # The key-value map of strings. The valid character set is # \[a-zA-Z+-=.\_:/\]. The tag key can be up to 128 characters and must # not start with `aws:`. The tag value can be up to 256 characters. # @return [Hash] # # @!attribute [rw] security_policy # The Transport Layer Security (TLS) version + cipher suite for this # DomainName. The valid values are `TLS_1_0` and `TLS_1_2`. # @return [String] # # @!attribute [rw] mutual_tls_authentication # If specified, API Gateway performs two-way authentication between # the client and the server. Clients must present a trusted # certificate to access your custom domain name. # @return [Types::MutualTlsAuthenticationInput] # class CreateDomainNameRequest < Struct.new( :domain_name, :certificate_name, :certificate_body, :certificate_private_key, :certificate_chain, :certificate_arn, :regional_certificate_name, :regional_certificate_arn, :endpoint_configuration, :tags, :security_policy, :mutual_tls_authentication) SENSITIVE = [] include Aws::Structure end # Request to add a new Model to an existing RestApi resource. # # @note When making an API call, you may pass CreateModelRequest # data as a hash: # # { # rest_api_id: "String", # required # name: "String", # required # description: "String", # schema: "String", # content_type: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The RestApi identifier under which the Model will be # created. # @return [String] # # @!attribute [rw] name # \[Required\] The name of the model. Must be alphanumeric. # @return [String] # # @!attribute [rw] description # The description of the model. # @return [String] # # @!attribute [rw] schema # The schema for the model. For `application/json` models, this should # be [JSON schema draft 4][1] model. # # # # [1]: https://tools.ietf.org/html/draft-zyp-json-schema-04 # @return [String] # # @!attribute [rw] content_type # \[Required\] The content-type for the model. # @return [String] # class CreateModelRequest < Struct.new( :rest_api_id, :name, :description, :schema, :content_type) SENSITIVE = [] include Aws::Structure end # Creates a RequestValidator of a given RestApi. # # @note When making an API call, you may pass CreateRequestValidatorRequest # data as a hash: # # { # rest_api_id: "String", # required # name: "String", # validate_request_body: false, # validate_request_parameters: false, # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] name # The name of the to-be-created RequestValidator. # @return [String] # # @!attribute [rw] validate_request_body # A Boolean flag to indicate whether to validate request body # according to the configured model schema for the method (`true`) or # not (`false`). # @return [Boolean] # # @!attribute [rw] validate_request_parameters # A Boolean flag to indicate whether to validate request parameters, # `true`, or not `false`. # @return [Boolean] # class CreateRequestValidatorRequest < Struct.new( :rest_api_id, :name, :validate_request_body, :validate_request_parameters) SENSITIVE = [] include Aws::Structure end # Requests API Gateway to create a Resource resource. # # @note When making an API call, you may pass CreateResourceRequest # data as a hash: # # { # rest_api_id: "String", # required # parent_id: "String", # required # path_part: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] parent_id # \[Required\] The parent resource's identifier. # @return [String] # # @!attribute [rw] path_part # The last path segment for this resource. # @return [String] # class CreateResourceRequest < Struct.new( :rest_api_id, :parent_id, :path_part) SENSITIVE = [] include Aws::Structure end # The POST Request to add a new RestApi resource to your collection. # # @note When making an API call, you may pass CreateRestApiRequest # data as a hash: # # { # name: "String", # required # description: "String", # version: "String", # clone_from: "String", # binary_media_types: ["String"], # minimum_compression_size: 1, # api_key_source: "HEADER", # accepts HEADER, AUTHORIZER # endpoint_configuration: { # types: ["REGIONAL"], # accepts REGIONAL, EDGE, PRIVATE # vpc_endpoint_ids: ["String"], # }, # policy: "String", # tags: { # "String" => "String", # }, # disable_execute_api_endpoint: false, # } # # @!attribute [rw] name # \[Required\] The name of the RestApi. # @return [String] # # @!attribute [rw] description # The description of the RestApi. # @return [String] # # @!attribute [rw] version # A version identifier for the API. # @return [String] # # @!attribute [rw] clone_from # The ID of the RestApi that you want to clone from. # @return [String] # # @!attribute [rw] binary_media_types # The list of binary media types supported by the RestApi. By default, # the RestApi supports only UTF-8-encoded text payloads. # @return [Array] # # @!attribute [rw] minimum_compression_size # A nullable integer that is used to enable compression (with # non-negative between 0 and 10485760 (10M) bytes, inclusive) or # disable compression (with a null value) on an API. When compression # is enabled, compression or decompression is not applied on the # payload if the payload size is smaller than this value. Setting it # to zero allows compression for any payload size. # @return [Integer] # # @!attribute [rw] api_key_source # The source of the API key for metering requests according to a usage # plan. Valid values are: * `HEADER` to read the API key from the # `X-API-Key` header of a # request. # * `AUTHORIZER` to read the API key from the `UsageIdentifierKey` # from a custom authorizer. # @return [String] # # @!attribute [rw] endpoint_configuration # The endpoint configuration of this RestApi showing the endpoint # types of the API. # @return [Types::EndpointConfiguration] # # @!attribute [rw] policy # A stringified JSON policy document that applies to this RestApi regardless of the caller and Method configuration. # @return [String] # # @!attribute [rw] tags # The key-value map of strings. The valid character set is # \[a-zA-Z+-=.\_:/\]. The tag key can be up to 128 characters and must # not start with `aws:`. The tag value can be up to 256 characters. # @return [Hash] # # @!attribute [rw] disable_execute_api_endpoint # Specifies whether clients can invoke your API by using the default # `execute-api` endpoint. By default, clients can invoke your API with # the default # https://\\\{api\_id\\}.execute-api.\\\{region\\}.amazonaws.com # endpoint. To require that clients use a custom domain name to invoke # your API, disable the default endpoint. # @return [Boolean] # class CreateRestApiRequest < Struct.new( :name, :description, :version, :clone_from, :binary_media_types, :minimum_compression_size, :api_key_source, :endpoint_configuration, :policy, :tags, :disable_execute_api_endpoint) SENSITIVE = [] include Aws::Structure end # Requests API Gateway to create a Stage resource. # # @note When making an API call, you may pass CreateStageRequest # data as a hash: # # { # rest_api_id: "String", # required # stage_name: "String", # required # deployment_id: "String", # required # description: "String", # cache_cluster_enabled: false, # cache_cluster_size: "0.5", # accepts 0.5, 1.6, 6.1, 13.5, 28.4, 58.2, 118, 237 # variables: { # "String" => "String", # }, # documentation_version: "String", # canary_settings: { # percent_traffic: 1.0, # deployment_id: "String", # stage_variable_overrides: { # "String" => "String", # }, # use_stage_cache: false, # }, # tracing_enabled: false, # tags: { # "String" => "String", # }, # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] stage_name # \[Required\] The name for the Stage resource. Stage names can only # contain alphanumeric characters, hyphens, and underscores. Maximum # length is 128 characters. # @return [String] # # @!attribute [rw] deployment_id # \[Required\] The identifier of the Deployment resource for the Stage # resource. # @return [String] # # @!attribute [rw] description # The description of the Stage resource. # @return [String] # # @!attribute [rw] cache_cluster_enabled # Whether cache clustering is enabled for the stage. # @return [Boolean] # # @!attribute [rw] cache_cluster_size # The stage's cache cluster size. # @return [String] # # @!attribute [rw] variables # A map that defines the stage variables for the new Stage resource. # Variable names can have alphanumeric and underscore characters, and # the values must match `[A-Za-z0-9-._~:/?#&=,]+`. # @return [Hash] # # @!attribute [rw] documentation_version # The version of the associated API documentation. # @return [String] # # @!attribute [rw] canary_settings # The canary deployment settings of this stage. # @return [Types::CanarySettings] # # @!attribute [rw] tracing_enabled # Specifies whether active tracing with X-ray is enabled for the # Stage. # @return [Boolean] # # @!attribute [rw] tags # The key-value map of strings. The valid character set is # \[a-zA-Z+-=.\_:/\]. The tag key can be up to 128 characters and must # not start with `aws:`. The tag value can be up to 256 characters. # @return [Hash] # class CreateStageRequest < Struct.new( :rest_api_id, :stage_name, :deployment_id, :description, :cache_cluster_enabled, :cache_cluster_size, :variables, :documentation_version, :canary_settings, :tracing_enabled, :tags) SENSITIVE = [] include Aws::Structure end # The POST request to create a usage plan key for adding an existing API # key to a usage plan. # # @note When making an API call, you may pass CreateUsagePlanKeyRequest # data as a hash: # # { # usage_plan_id: "String", # required # key_id: "String", # required # key_type: "String", # required # } # # @!attribute [rw] usage_plan_id # \[Required\] The Id of the UsagePlan resource representing the usage # plan containing the to-be-created UsagePlanKey resource representing # a plan customer. # @return [String] # # @!attribute [rw] key_id # \[Required\] The identifier of a UsagePlanKey resource for a plan # customer. # @return [String] # # @!attribute [rw] key_type # \[Required\] The type of a UsagePlanKey resource for a plan # customer. # @return [String] # class CreateUsagePlanKeyRequest < Struct.new( :usage_plan_id, :key_id, :key_type) SENSITIVE = [] include Aws::Structure end # The POST request to create a usage plan with the name, description, # throttle limits and quota limits, as well as the associated API # stages, specified in the payload. # # @note When making an API call, you may pass CreateUsagePlanRequest # data as a hash: # # { # name: "String", # required # description: "String", # api_stages: [ # { # api_id: "String", # stage: "String", # throttle: { # "String" => { # burst_limit: 1, # rate_limit: 1.0, # }, # }, # }, # ], # throttle: { # burst_limit: 1, # rate_limit: 1.0, # }, # quota: { # limit: 1, # offset: 1, # period: "DAY", # accepts DAY, WEEK, MONTH # }, # tags: { # "String" => "String", # }, # } # # @!attribute [rw] name # \[Required\] The name of the usage plan. # @return [String] # # @!attribute [rw] description # The description of the usage plan. # @return [String] # # @!attribute [rw] api_stages # The associated API stages of the usage plan. # @return [Array] # # @!attribute [rw] throttle # The throttling limits of the usage plan. # @return [Types::ThrottleSettings] # # @!attribute [rw] quota # The quota of the usage plan. # @return [Types::QuotaSettings] # # @!attribute [rw] tags # The key-value map of strings. The valid character set is # \[a-zA-Z+-=.\_:/\]. The tag key can be up to 128 characters and must # not start with `aws:`. The tag value can be up to 256 characters. # @return [Hash] # class CreateUsagePlanRequest < Struct.new( :name, :description, :api_stages, :throttle, :quota, :tags) SENSITIVE = [] include Aws::Structure end # Creates a VPC link, under the caller's account in a selected region, # in an asynchronous operation that typically takes 2-4 minutes to # complete and become operational. The caller must have permissions to # create and update VPC Endpoint services. # # @note When making an API call, you may pass CreateVpcLinkRequest # data as a hash: # # { # name: "String", # required # description: "String", # target_arns: ["String"], # required # tags: { # "String" => "String", # }, # } # # @!attribute [rw] name # \[Required\] The name used to label and identify the VPC link. # @return [String] # # @!attribute [rw] description # The description of the VPC link. # @return [String] # # @!attribute [rw] target_arns # \[Required\] The ARN of the network load balancer of the VPC # targeted by the VPC link. The network load balancer must be owned by # the same AWS account of the API owner. # @return [Array] # # @!attribute [rw] tags # The key-value map of strings. The valid character set is # \[a-zA-Z+-=.\_:/\]. The tag key can be up to 128 characters and must # not start with `aws:`. The tag value can be up to 256 characters. # @return [Hash] # class CreateVpcLinkRequest < Struct.new( :name, :description, :target_arns, :tags) SENSITIVE = [] include Aws::Structure end # A request to delete the ApiKey resource. # # @note When making an API call, you may pass DeleteApiKeyRequest # data as a hash: # # { # api_key: "String", # required # } # # @!attribute [rw] api_key # \[Required\] The identifier of the ApiKey resource to be deleted. # @return [String] # class DeleteApiKeyRequest < Struct.new( :api_key) SENSITIVE = [] include Aws::Structure end # Request to delete an existing Authorizer resource. # # @note When making an API call, you may pass DeleteAuthorizerRequest # data as a hash: # # { # rest_api_id: "String", # required # authorizer_id: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] authorizer_id # \[Required\] The identifier of the Authorizer resource. # @return [String] # class DeleteAuthorizerRequest < Struct.new( :rest_api_id, :authorizer_id) SENSITIVE = [] include Aws::Structure end # A request to delete the BasePathMapping resource. # # @note When making an API call, you may pass DeleteBasePathMappingRequest # data as a hash: # # { # domain_name: "String", # required # base_path: "String", # required # } # # @!attribute [rw] domain_name # \[Required\] The domain name of the BasePathMapping resource to # delete. # @return [String] # # @!attribute [rw] base_path # \[Required\] The base path name of the BasePathMapping resource to # delete. # # To specify an empty base path, set this parameter to `'(none)'`. # @return [String] # class DeleteBasePathMappingRequest < Struct.new( :domain_name, :base_path) SENSITIVE = [] include Aws::Structure end # A request to delete the ClientCertificate resource. # # @note When making an API call, you may pass DeleteClientCertificateRequest # data as a hash: # # { # client_certificate_id: "String", # required # } # # @!attribute [rw] client_certificate_id # \[Required\] The identifier of the ClientCertificate resource to be # deleted. # @return [String] # class DeleteClientCertificateRequest < Struct.new( :client_certificate_id) SENSITIVE = [] include Aws::Structure end # Requests API Gateway to delete a Deployment resource. # # @note When making an API call, you may pass DeleteDeploymentRequest # data as a hash: # # { # rest_api_id: "String", # required # deployment_id: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] deployment_id # \[Required\] The identifier of the Deployment resource to delete. # @return [String] # class DeleteDeploymentRequest < Struct.new( :rest_api_id, :deployment_id) SENSITIVE = [] include Aws::Structure end # Deletes an existing documentation part of an API. # # @note When making an API call, you may pass DeleteDocumentationPartRequest # data as a hash: # # { # rest_api_id: "String", # required # documentation_part_id: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] documentation_part_id # \[Required\] The identifier of the to-be-deleted documentation part. # @return [String] # class DeleteDocumentationPartRequest < Struct.new( :rest_api_id, :documentation_part_id) SENSITIVE = [] include Aws::Structure end # Deletes an existing documentation version of an API. # # @note When making an API call, you may pass DeleteDocumentationVersionRequest # data as a hash: # # { # rest_api_id: "String", # required # documentation_version: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] documentation_version # \[Required\] The version identifier of a to-be-deleted documentation # snapshot. # @return [String] # class DeleteDocumentationVersionRequest < Struct.new( :rest_api_id, :documentation_version) SENSITIVE = [] include Aws::Structure end # A request to delete the DomainName resource. # # @note When making an API call, you may pass DeleteDomainNameRequest # data as a hash: # # { # domain_name: "String", # required # } # # @!attribute [rw] domain_name # \[Required\] The name of the DomainName resource to be deleted. # @return [String] # class DeleteDomainNameRequest < Struct.new( :domain_name) SENSITIVE = [] include Aws::Structure end # Clears any customization of a GatewayResponse of a specified response # type on the given RestApi and resets it with the default settings. # # @note When making an API call, you may pass DeleteGatewayResponseRequest # data as a hash: # # { # rest_api_id: "String", # required # response_type: "DEFAULT_4XX", # required, accepts DEFAULT_4XX, DEFAULT_5XX, RESOURCE_NOT_FOUND, UNAUTHORIZED, INVALID_API_KEY, ACCESS_DENIED, AUTHORIZER_FAILURE, AUTHORIZER_CONFIGURATION_ERROR, INVALID_SIGNATURE, EXPIRED_TOKEN, MISSING_AUTHENTICATION_TOKEN, INTEGRATION_FAILURE, INTEGRATION_TIMEOUT, API_CONFIGURATION_ERROR, UNSUPPORTED_MEDIA_TYPE, BAD_REQUEST_PARAMETERS, BAD_REQUEST_BODY, REQUEST_TOO_LARGE, THROTTLED, QUOTA_EXCEEDED # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] response_type # \[Required\] The response type of the associated GatewayResponse. # Valid values # are * ACCESS\_DENIED # * API\_CONFIGURATION\_ERROR # * AUTHORIZER\_FAILURE # * AUTHORIZER\_CONFIGURATION\_ERROR # * BAD\_REQUEST\_PARAMETERS # * BAD\_REQUEST\_BODY # * DEFAULT\_4XX # * DEFAULT\_5XX # * EXPIRED\_TOKEN # * INVALID\_SIGNATURE # * INTEGRATION\_FAILURE # * INTEGRATION\_TIMEOUT # * INVALID\_API\_KEY # * MISSING\_AUTHENTICATION\_TOKEN # * QUOTA\_EXCEEDED # * REQUEST\_TOO\_LARGE # * RESOURCE\_NOT\_FOUND # * THROTTLED # * UNAUTHORIZED # * UNSUPPORTED\_MEDIA\_TYPE # @return [String] # class DeleteGatewayResponseRequest < Struct.new( :rest_api_id, :response_type) SENSITIVE = [] include Aws::Structure end # Represents a delete integration request. # # @note When making an API call, you may pass DeleteIntegrationRequest # data as a hash: # # { # rest_api_id: "String", # required # resource_id: "String", # required # http_method: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] resource_id # \[Required\] Specifies a delete integration request's resource # identifier. # @return [String] # # @!attribute [rw] http_method # \[Required\] Specifies a delete integration request's HTTP method. # @return [String] # class DeleteIntegrationRequest < Struct.new( :rest_api_id, :resource_id, :http_method) SENSITIVE = [] include Aws::Structure end # Represents a delete integration response request. # # @note When making an API call, you may pass DeleteIntegrationResponseRequest # data as a hash: # # { # rest_api_id: "String", # required # resource_id: "String", # required # http_method: "String", # required # status_code: "StatusCode", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] resource_id # \[Required\] Specifies a delete integration response request's # resource identifier. # @return [String] # # @!attribute [rw] http_method # \[Required\] Specifies a delete integration response request's HTTP # method. # @return [String] # # @!attribute [rw] status_code # \[Required\] Specifies a delete integration response request's # status code. # @return [String] # class DeleteIntegrationResponseRequest < Struct.new( :rest_api_id, :resource_id, :http_method, :status_code) SENSITIVE = [] include Aws::Structure end # Request to delete an existing Method resource. # # @note When making an API call, you may pass DeleteMethodRequest # data as a hash: # # { # rest_api_id: "String", # required # resource_id: "String", # required # http_method: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] resource_id # \[Required\] The Resource identifier for the Method resource. # @return [String] # # @!attribute [rw] http_method # \[Required\] The HTTP verb of the Method resource. # @return [String] # class DeleteMethodRequest < Struct.new( :rest_api_id, :resource_id, :http_method) SENSITIVE = [] include Aws::Structure end # A request to delete an existing MethodResponse resource. # # @note When making an API call, you may pass DeleteMethodResponseRequest # data as a hash: # # { # rest_api_id: "String", # required # resource_id: "String", # required # http_method: "String", # required # status_code: "StatusCode", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] resource_id # \[Required\] The Resource identifier for the MethodResponse # resource. # @return [String] # # @!attribute [rw] http_method # \[Required\] The HTTP verb of the Method resource. # @return [String] # # @!attribute [rw] status_code # \[Required\] The status code identifier for the MethodResponse # resource. # @return [String] # class DeleteMethodResponseRequest < Struct.new( :rest_api_id, :resource_id, :http_method, :status_code) SENSITIVE = [] include Aws::Structure end # Request to delete an existing model in an existing RestApi resource. # # @note When making an API call, you may pass DeleteModelRequest # data as a hash: # # { # rest_api_id: "String", # required # model_name: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] model_name # \[Required\] The name of the model to delete. # @return [String] # class DeleteModelRequest < Struct.new( :rest_api_id, :model_name) SENSITIVE = [] include Aws::Structure end # Deletes a specified RequestValidator of a given RestApi. # # @note When making an API call, you may pass DeleteRequestValidatorRequest # data as a hash: # # { # rest_api_id: "String", # required # request_validator_id: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] request_validator_id # \[Required\] The identifier of the RequestValidator to be deleted. # @return [String] # class DeleteRequestValidatorRequest < Struct.new( :rest_api_id, :request_validator_id) SENSITIVE = [] include Aws::Structure end # Request to delete a Resource. # # @note When making an API call, you may pass DeleteResourceRequest # data as a hash: # # { # rest_api_id: "String", # required # resource_id: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] resource_id # \[Required\] The identifier of the Resource resource. # @return [String] # class DeleteResourceRequest < Struct.new( :rest_api_id, :resource_id) SENSITIVE = [] include Aws::Structure end # Request to delete the specified API from your collection. # # @note When making an API call, you may pass DeleteRestApiRequest # data as a hash: # # { # rest_api_id: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # class DeleteRestApiRequest < Struct.new( :rest_api_id) SENSITIVE = [] include Aws::Structure end # Requests API Gateway to delete a Stage resource. # # @note When making an API call, you may pass DeleteStageRequest # data as a hash: # # { # rest_api_id: "String", # required # stage_name: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] stage_name # \[Required\] The name of the Stage resource to delete. # @return [String] # class DeleteStageRequest < Struct.new( :rest_api_id, :stage_name) SENSITIVE = [] include Aws::Structure end # The DELETE request to delete a usage plan key and remove the # underlying API key from the associated usage plan. # # @note When making an API call, you may pass DeleteUsagePlanKeyRequest # data as a hash: # # { # usage_plan_id: "String", # required # key_id: "String", # required # } # # @!attribute [rw] usage_plan_id # \[Required\] The Id of the UsagePlan resource representing the usage # plan containing the to-be-deleted UsagePlanKey resource representing # a plan customer. # @return [String] # # @!attribute [rw] key_id # \[Required\] The Id of the UsagePlanKey resource to be deleted. # @return [String] # class DeleteUsagePlanKeyRequest < Struct.new( :usage_plan_id, :key_id) SENSITIVE = [] include Aws::Structure end # The DELETE request to delete a usage plan of a given plan Id. # # @note When making an API call, you may pass DeleteUsagePlanRequest # data as a hash: # # { # usage_plan_id: "String", # required # } # # @!attribute [rw] usage_plan_id # \[Required\] The Id of the to-be-deleted usage plan. # @return [String] # class DeleteUsagePlanRequest < Struct.new( :usage_plan_id) SENSITIVE = [] include Aws::Structure end # Deletes an existing VpcLink of a specified identifier. # # @note When making an API call, you may pass DeleteVpcLinkRequest # data as a hash: # # { # vpc_link_id: "String", # required # } # # @!attribute [rw] vpc_link_id # \[Required\] The identifier of the VpcLink. It is used in an # Integration to reference this VpcLink. # @return [String] # class DeleteVpcLinkRequest < Struct.new( :vpc_link_id) SENSITIVE = [] include Aws::Structure end # An immutable representation of a RestApi resource that can be called # by users using Stages. A deployment must be associated with a Stage # for it to be callable over the Internet. # #
# To create a deployment, call `POST` on the Deployments resource of a # RestApi. To view, update, or delete a deployment, call `GET`, `PATCH`, # or `DELETE` on the specified deployment resource # (`/restapis/\{restapi_id\}/deployments/\{deployment_id\}`). #
# #
# RestApi, Deployments, Stage, [AWS CLI][1], [AWS SDKs][2] #
# # # # [1]: https://docs.aws.amazon.com/cli/latest/reference/apigateway/get-deployment.html # [2]: https://aws.amazon.com/tools/ # # @!attribute [rw] id # The identifier for the deployment resource. # @return [String] # # @!attribute [rw] description # The description for the deployment resource. # @return [String] # # @!attribute [rw] created_date # The date and time that the deployment resource was created. # @return [Time] # # @!attribute [rw] api_summary # A summary of the RestApi at the date and time that the deployment # resource was created. # @return [Hash>] # class Deployment < Struct.new( :id, :description, :created_date, :api_summary) SENSITIVE = [] include Aws::Structure end # The input configuration for a canary deployment. # # @note When making an API call, you may pass DeploymentCanarySettings # data as a hash: # # { # percent_traffic: 1.0, # stage_variable_overrides: { # "String" => "String", # }, # use_stage_cache: false, # } # # @!attribute [rw] percent_traffic # The percentage (0.0-100.0) of traffic routed to the canary # deployment. # @return [Float] # # @!attribute [rw] stage_variable_overrides # A stage variable overrides used for the canary release deployment. # They can override existing stage variables or add new stage # variables for the canary release deployment. These stage variables # are represented as a string-to-string map between stage variable # names and their values. # @return [Hash] # # @!attribute [rw] use_stage_cache # A Boolean flag to indicate whether the canary release deployment # uses the stage cache or not. # @return [Boolean] # class DeploymentCanarySettings < Struct.new( :percent_traffic, :stage_variable_overrides, :use_stage_cache) SENSITIVE = [] include Aws::Structure end # Represents a collection resource that contains zero or more references # to your existing deployments, and links that guide you on how to # interact with your collection. The collection offers a paginated view # of the contained deployments. # #
# To create a new deployment of a RestApi, make a `POST` request against # this resource. To view, update, or delete an existing deployment, make # a `GET`, `PATCH`, or `DELETE` request, respectively, on a specified # Deployment resource. #
# #
# [Deploying an API][1], [AWS CLI][2], [AWS SDKs][3] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/how-to-deploy-api.html # [2]: https://docs.aws.amazon.com/cli/latest/reference/apigateway/get-deployment.html # [3]: https://aws.amazon.com/tools/ # # @!attribute [rw] position # @return [String] # # @!attribute [rw] items # The current page of elements from this collection. # @return [Array] # class Deployments < Struct.new( :position, :items) SENSITIVE = [] include Aws::Structure end # A documentation part for a targeted API entity. # #
# A documentation part consists of a content map (`properties`) and a # target (`location`). The target specifies an API entity to which the # documentation content applies. The supported API entity types are # `API`, `AUTHORIZER`, `MODEL`, `RESOURCE`, `METHOD`, `PATH_PARAMETER`, # `QUERY_PARAMETER`, `REQUEST_HEADER`, `REQUEST_BODY`, `RESPONSE`, # `RESPONSE_HEADER`, and `RESPONSE_BODY`. Valid `location` fields depend # on the API entity type. All valid fields are not required. # # The content map is a JSON string of API-specific key-value pairs. # Although an API can use any shape for the content map, only the # OpenAPI-compliant documentation fields will be injected into the # associated API entity definition in the exported OpenAPI definition # file. # #
# #
# [Documenting an API][1], DocumentationParts #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-documenting-api.html # # @!attribute [rw] id # The DocumentationPart identifier, generated by API Gateway when the # `DocumentationPart` is created. # @return [String] # # @!attribute [rw] location # The location of the API entity to which the documentation applies. # Valid fields depend on the targeted API entity type. All the valid # location fields are not required. If not explicitly specified, a # valid location field is treated as a wildcard and associated # documentation content may be inherited by matching entities, unless # overridden. # @return [Types::DocumentationPartLocation] # # @!attribute [rw] properties # A content map of API-specific key-value pairs describing the # targeted API entity. The map must be encoded as a JSON string, e.g., # `"\{ "description": "The API does ..." \}"`. Only # OpenAPI-compliant documentation-related fields from the # properties # # map are exported and, hence, published as part of the API entity # definitions, while the original documentation parts are exported in # a OpenAPI extension of `x-amazon-apigateway-documentation`. # @return [String] # class DocumentationPart < Struct.new( :id, :location, :properties) SENSITIVE = [] include Aws::Structure end # A collection of the imported DocumentationPart identifiers. # #
# This is used to return the result when documentation parts in an # external (e.g., OpenAPI) file are imported into API Gateway #
# #
# [Documenting an API][1], [documentationpart:import][2], # DocumentationPart #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-documenting-api.html # [2]: https://docs.aws.amazon.com/apigateway/api-reference/link-relation/documentationpart-import/ # # @!attribute [rw] ids # A list of the returned documentation part identifiers. # @return [Array] # # @!attribute [rw] warnings # A list of warning messages reported during import of documentation # parts. # @return [Array] # class DocumentationPartIds < Struct.new( :ids, :warnings) SENSITIVE = [] include Aws::Structure end # Specifies the target API entity to which the documentation applies. # # @note When making an API call, you may pass DocumentationPartLocation # data as a hash: # # { # type: "API", # required, accepts API, AUTHORIZER, MODEL, RESOURCE, METHOD, PATH_PARAMETER, QUERY_PARAMETER, REQUEST_HEADER, REQUEST_BODY, RESPONSE, RESPONSE_HEADER, RESPONSE_BODY # path: "String", # method: "String", # status_code: "DocumentationPartLocationStatusCode", # name: "String", # } # # @!attribute [rw] type # \[Required\] The type of API entity to which the documentation # content applies. Valid values are `API`, `AUTHORIZER`, `MODEL`, # `RESOURCE`, `METHOD`, `PATH_PARAMETER`, `QUERY_PARAMETER`, # `REQUEST_HEADER`, `REQUEST_BODY`, `RESPONSE`, `RESPONSE_HEADER`, and # `RESPONSE_BODY`. Content inheritance does not apply to any entity of # the `API`, `AUTHORIZER`, `METHOD`, `MODEL`, `REQUEST_BODY`, or # `RESOURCE` type. # @return [String] # # @!attribute [rw] path # The URL path of the target. It is a valid field for the API entity # types of `RESOURCE`, `METHOD`, `PATH_PARAMETER`, `QUERY_PARAMETER`, # `REQUEST_HEADER`, `REQUEST_BODY`, `RESPONSE`, `RESPONSE_HEADER`, and # `RESPONSE_BODY`. The default value is `/` for the root resource. # When an applicable child entity inherits the content of another # entity of the same type with more general specifications of the # other `location` attributes, the child entity's `path` attribute # must match that of the parent entity as a prefix. # @return [String] # # @!attribute [rw] method # The HTTP verb of a method. It is a valid field for the API entity # types of `METHOD`, `PATH_PARAMETER`, `QUERY_PARAMETER`, # `REQUEST_HEADER`, `REQUEST_BODY`, `RESPONSE`, `RESPONSE_HEADER`, and # `RESPONSE_BODY`. The default value is `*` for any method. When an # applicable child entity inherits the content of an entity of the # same type with more general specifications of the other `location` # attributes, the child entity's `method` attribute must match that # of the parent entity exactly. # @return [String] # # @!attribute [rw] status_code # The HTTP status code of a response. It is a valid field for the API # entity types of `RESPONSE`, `RESPONSE_HEADER`, and `RESPONSE_BODY`. # The default value is `*` for any status code. When an applicable # child entity inherits the content of an entity of the same type with # more general specifications of the other `location` attributes, the # child entity's `statusCode` attribute must match that of the parent # entity exactly. # @return [String] # # @!attribute [rw] name # The name of the targeted API entity. It is a valid and required # field for the API entity types of `AUTHORIZER`, `MODEL`, # `PATH_PARAMETER`, `QUERY_PARAMETER`, `REQUEST_HEADER`, # `REQUEST_BODY` and `RESPONSE_HEADER`. It is an invalid field for any # other entity type. # @return [String] # class DocumentationPartLocation < Struct.new( :type, :path, :method, :status_code, :name) SENSITIVE = [] include Aws::Structure end # The collection of documentation parts of an API. # #
# #
# [Documenting an API][1], DocumentationPart #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-documenting-api.html # # @!attribute [rw] position # @return [String] # # @!attribute [rw] items # The current page of elements from this collection. # @return [Array] # class DocumentationParts < Struct.new( :position, :items) SENSITIVE = [] include Aws::Structure end # A snapshot of the documentation of an API. # #
# Publishing API documentation involves creating a documentation version # associated with an API stage and exporting the versioned documentation # to an external (e.g., OpenAPI) file. # #
# #
# [Documenting an API][1], DocumentationPart, DocumentationVersions #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-documenting-api.html # # @!attribute [rw] version # The version identifier of the API documentation snapshot. # @return [String] # # @!attribute [rw] created_date # The date when the API documentation snapshot is created. # @return [Time] # # @!attribute [rw] description # The description of the API documentation snapshot. # @return [String] # class DocumentationVersion < Struct.new( :version, :created_date, :description) SENSITIVE = [] include Aws::Structure end # The collection of documentation snapshots of an API. # #
# Use the DocumentationVersions to manage documentation snapshots # associated with various API stages. # #
# #
# [Documenting an API][1], DocumentationPart, DocumentationVersion #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-documenting-api.html # # @!attribute [rw] position # @return [String] # # @!attribute [rw] items # The current page of elements from this collection. # @return [Array] # class DocumentationVersions < Struct.new( :position, :items) SENSITIVE = [] include Aws::Structure end # Represents a custom domain name as a user-friendly host name of an API # (RestApi). # #
# When you deploy an API, API Gateway creates a default host name for # the API. This default API host name is of the # `\{restapi-id\}.execute-api.\{region\}.amazonaws.com` format. With the # default host name, you can access the API's root resource with the # URL of # `https://\{restapi-id\}.execute-api.\{region\}.amazonaws.com/\{stage\}/`. # When you set up a custom domain name of `apis.example.com` for this # API, you can then access the same resource using the URL of the # `https://apis.examples.com/myApi`, where `myApi` is the base path # mapping (BasePathMapping) of your API under the custom domain name. # #
# #
# [Set a Custom Host Name for an API][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/how-to-custom-domains.html # # @!attribute [rw] domain_name # The custom domain name as an API host name, for example, # `my-api.example.com`. # @return [String] # # @!attribute [rw] certificate_name # The name of the certificate that will be used by edge-optimized # endpoint for this domain name. # @return [String] # # @!attribute [rw] certificate_arn # The reference to an AWS-managed certificate that will be used by # edge-optimized endpoint for this domain name. AWS Certificate # Manager is the only supported source. # @return [String] # # @!attribute [rw] certificate_upload_date # The timestamp when the certificate that was used by edge-optimized # endpoint for this domain name was uploaded. # @return [Time] # # @!attribute [rw] regional_domain_name # The domain name associated with the regional endpoint for this # custom domain name. You set up this association by adding a DNS # record that points the custom domain name to this regional domain # name. The regional domain name is returned by API Gateway when you # create a regional endpoint. # @return [String] # # @!attribute [rw] regional_hosted_zone_id # The region-specific Amazon Route 53 Hosted Zone ID of the regional # endpoint. For more information, see [Set up a Regional Custom Domain # Name][1] and [AWS Regions and Endpoints for API Gateway][2]. # # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-regional-api-custom-domain-create.html # [2]: https://docs.aws.amazon.com/general/latest/gr/rande.html#apigateway_region # @return [String] # # @!attribute [rw] regional_certificate_name # The name of the certificate that will be used for validating the # regional domain name. # @return [String] # # @!attribute [rw] regional_certificate_arn # The reference to an AWS-managed certificate that will be used for # validating the regional domain name. AWS Certificate Manager is the # only supported source. # @return [String] # # @!attribute [rw] distribution_domain_name # The domain name of the Amazon CloudFront distribution associated # with this custom domain name for an edge-optimized endpoint. You set # up this association when adding a DNS record pointing the custom # domain name to this distribution name. For more information about # CloudFront distributions, see the [Amazon CloudFront # documentation][1]. # # # # [1]: https://aws.amazon.com/documentation/cloudfront/ # @return [String] # # @!attribute [rw] distribution_hosted_zone_id # The region-agnostic Amazon Route 53 Hosted Zone ID of the # edge-optimized endpoint. The valid value is `Z2FDTNDATAQYW2` for all # the regions. For more information, see [Set up a Regional Custom # Domain Name][1] and [AWS Regions and Endpoints for API Gateway][2]. # # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/apigateway-regional-api-custom-domain-create.html # [2]: https://docs.aws.amazon.com/general/latest/gr/rande.html#apigateway_region # @return [String] # # @!attribute [rw] endpoint_configuration # The endpoint configuration of this DomainName showing the endpoint # types of the domain name. # @return [Types::EndpointConfiguration] # # @!attribute [rw] domain_name_status # The status of the DomainName migration. The valid values are # `AVAILABLE` and `UPDATING`. If the status is `UPDATING`, the domain # cannot be modified further until the existing operation is complete. # If it is `AVAILABLE`, the domain can be updated. # @return [String] # # @!attribute [rw] domain_name_status_message # An optional text message containing detailed information about # status of the DomainName migration. # @return [String] # # @!attribute [rw] security_policy # The Transport Layer Security (TLS) version + cipher suite for this # DomainName. The valid values are `TLS_1_0` and `TLS_1_2`. # @return [String] # # @!attribute [rw] tags # The collection of tags. Each tag element is associated with a given # resource. # @return [Hash] # # @!attribute [rw] mutual_tls_authentication # The mutual TLS authentication configuration for a custom domain # name. If specified, API Gateway performs two-way authentication # between the client and the server. Clients must present a trusted # certificate to access your API. # @return [Types::MutualTlsAuthentication] # class DomainName < Struct.new( :domain_name, :certificate_name, :certificate_arn, :certificate_upload_date, :regional_domain_name, :regional_hosted_zone_id, :regional_certificate_name, :regional_certificate_arn, :distribution_domain_name, :distribution_hosted_zone_id, :endpoint_configuration, :domain_name_status, :domain_name_status_message, :security_policy, :tags, :mutual_tls_authentication) SENSITIVE = [] include Aws::Structure end # Represents a collection of DomainName resources. # #
# [Use Client-Side Certificate][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/how-to-custom-domains.html # # @!attribute [rw] position # @return [String] # # @!attribute [rw] items # The current page of elements from this collection. # @return [Array] # class DomainNames < Struct.new( :position, :items) SENSITIVE = [] include Aws::Structure end # The endpoint configuration to indicate the types of endpoints an API # (RestApi) or its custom domain name (DomainName) has. # # @note When making an API call, you may pass EndpointConfiguration # data as a hash: # # { # types: ["REGIONAL"], # accepts REGIONAL, EDGE, PRIVATE # vpc_endpoint_ids: ["String"], # } # # @!attribute [rw] types # A list of endpoint types of an API (RestApi) or its custom domain # name (DomainName). For an edge-optimized API and its custom domain # name, the endpoint type is `"EDGE"`. For a regional API and its # custom domain name, the endpoint type is `REGIONAL`. For a private # API, the endpoint type is `PRIVATE`. # @return [Array] # # @!attribute [rw] vpc_endpoint_ids # A list of VpcEndpointIds of an API (RestApi) against which to create # Route53 ALIASes. It is only supported for `PRIVATE` endpoint type. # @return [Array] # class EndpointConfiguration < Struct.new( :types, :vpc_endpoint_ids) SENSITIVE = [] include Aws::Structure end # The binary blob response to GetExport, which contains the generated # SDK. # # @!attribute [rw] content_type # The content-type header value in the HTTP response. This will # correspond to a valid 'accept' type in the request. # @return [String] # # @!attribute [rw] content_disposition # The content-disposition header value in the HTTP response. # @return [String] # # @!attribute [rw] body # The binary blob response to GetExport, which contains the export. # @return [String] # class ExportResponse < Struct.new( :content_type, :content_disposition, :body) SENSITIVE = [] include Aws::Structure end # Request to flush authorizer cache entries on a specified stage. # # @note When making an API call, you may pass FlushStageAuthorizersCacheRequest # data as a hash: # # { # rest_api_id: "String", # required # stage_name: "String", # required # } # # @!attribute [rw] rest_api_id # The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] stage_name # The name of the stage to flush. # @return [String] # class FlushStageAuthorizersCacheRequest < Struct.new( :rest_api_id, :stage_name) SENSITIVE = [] include Aws::Structure end # Requests API Gateway to flush a stage's cache. # # @note When making an API call, you may pass FlushStageCacheRequest # data as a hash: # # { # rest_api_id: "String", # required # stage_name: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] stage_name # \[Required\] The name of the stage to flush its cache. # @return [String] # class FlushStageCacheRequest < Struct.new( :rest_api_id, :stage_name) SENSITIVE = [] include Aws::Structure end # A gateway response of a given response type and status code, with # optional response parameters and mapping templates. # #
# For more information about valid gateway response types, see [Gateway # Response Types Supported by API Gateway][1] #
# #### Example: Get a Gateway Response of a given response type # # ##### Request # # This example shows how to get a gateway response of the # `MISSING_AUTHENTICATION_TOKEN` type. # # GET /restapis/o81lxisefl/gatewayresponses/MISSING_AUTHENTICATION_TOKEN HTTP/1.1 Host: beta-apigateway.us-east-1.amazonaws.com Content-Type: application/json X-Amz-Date: 20170503T202516Z Authorization: AWS4-HMAC-SHA256 Credential=\{access-key-id\}/20170503/us-east-1/apigateway/aws4_request, SignedHeaders=content-type;host;x-amz-date, Signature=1b52460e3159c1a26cff29093855d50ea141c1c5b937528fecaf60f51129697a Cache-Control: no-cache Postman-Token: 3b2a1ce9-c848-2e26-2e2f-9c2caefbed45 # # The response type is specified as a URL path. # # ##### Response # # The successful operation returns the `200 OK` status code and a # payload similar to the following: # # \{ "_links": \{ "curies": \{ "href": "http://docs.aws.amazon.com/apigateway/latest/developerguide/restapi-gatewayresponse-\{rel\}.html", "name": "gatewayresponse", "templated": true \}, "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/MISSING_AUTHENTICATION_TOKEN" \}, "gatewayresponse:delete": \{ "href": "/restapis/o81lxisefl/gatewayresponses/MISSING_AUTHENTICATION_TOKEN" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/MISSING_AUTHENTICATION_TOKEN" \} \}, "defaultResponse": false, "responseParameters": \{ "gatewayresponse.header.x-request-path": "method.request.path.petId", "gatewayresponse.header.Access-Control-Allow-Origin": "'a.b.c'", "gatewayresponse.header.x-request-query": "method.request.querystring.q", "gatewayresponse.header.x-request-header": "method.request.header.Accept" \}, "responseTemplates": \{ "application/json": "\{\n "message": $context.error.messageString,\n "type": "$context.error.responseType",\n "stage": "$context.stage",\n "resourcePath": "$context.resourcePath",\n "stageVariables.a": "$stageVariables.a",\n "statusCode": "'404'"\n\}" \}, "responseType": "MISSING_AUTHENTICATION_TOKEN", "statusCode": "404" \} # # # #
#
# #
# [Customize Gateway Responses][2] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/supported-gateway-response-types.html # [2]: https://docs.aws.amazon.com/apigateway/latest/developerguide/customize-gateway-responses.html # # @!attribute [rw] response_type # The response type of the associated GatewayResponse. Valid values # are * ACCESS\_DENIED # * API\_CONFIGURATION\_ERROR # * AUTHORIZER\_FAILURE # * AUTHORIZER\_CONFIGURATION\_ERROR # * BAD\_REQUEST\_PARAMETERS # * BAD\_REQUEST\_BODY # * DEFAULT\_4XX # * DEFAULT\_5XX # * EXPIRED\_TOKEN # * INVALID\_SIGNATURE # * INTEGRATION\_FAILURE # * INTEGRATION\_TIMEOUT # * INVALID\_API\_KEY # * MISSING\_AUTHENTICATION\_TOKEN # * QUOTA\_EXCEEDED # * REQUEST\_TOO\_LARGE # * RESOURCE\_NOT\_FOUND # * THROTTLED # * UNAUTHORIZED # * UNSUPPORTED\_MEDIA\_TYPE # @return [String] # # @!attribute [rw] status_code # The HTTP status code for this GatewayResponse. # @return [String] # # @!attribute [rw] response_parameters # Response parameters (paths, query strings and headers) of the # GatewayResponse as a string-to-string map of key-value pairs. # @return [Hash] # # @!attribute [rw] response_templates # Response templates of the GatewayResponse as a string-to-string map # of key-value pairs. # @return [Hash] # # @!attribute [rw] default_response # A Boolean flag to indicate whether this GatewayResponse is the # default gateway response (`true`) or not (`false`). A default # gateway response is one generated by API Gateway without any # customization by an API developer. # @return [Boolean] # class GatewayResponse < Struct.new( :response_type, :status_code, :response_parameters, :response_templates, :default_response) SENSITIVE = [] include Aws::Structure end # The collection of the GatewayResponse instances of a RestApi as a # `responseType`-to-GatewayResponse object map of key-value pairs. As # such, pagination is not supported for querying this collection. # #
# For more information about valid gateway response types, see [Gateway # Response Types Supported by API Gateway][1] #
# #### Example: Get the collection of gateway responses of an API # # ##### Request # # This example request shows how to retrieve the GatewayResponses # collection from an API. # # GET /restapis/o81lxisefl/gatewayresponses HTTP/1.1 Host: beta-apigateway.us-east-1.amazonaws.com Content-Type: application/json X-Amz-Date: 20170503T220604Z Authorization: AWS4-HMAC-SHA256 Credential=\{access-key-id\}/20170503/us-east-1/apigateway/aws4_request, SignedHeaders=content-type;host;x-amz-date, Signature=59b42fe54a76a5de8adf2c67baa6d39206f8e9ad49a1d77ccc6a5da3103a398a Cache-Control: no-cache Postman-Token: 5637af27-dc29-fc5c-9dfe-0645d52cb515 # # # # ##### Response # # The successful operation returns the `200 OK` status code and a # payload similar to the following: # # \{ "_links": \{ "curies": \{ "href": "http://docs.aws.amazon.com/apigateway/latest/developerguide/restapi-gatewayresponse-\{rel\}.html", "name": "gatewayresponse", "templated": true \}, "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses" \}, "first": \{ "href": "/restapis/o81lxisefl/gatewayresponses" \}, "gatewayresponse:by-type": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "item": [ \{ "href": "/restapis/o81lxisefl/gatewayresponses/INTEGRATION_FAILURE" \}, \{ "href": "/restapis/o81lxisefl/gatewayresponses/RESOURCE_NOT_FOUND" \}, \{ "href": "/restapis/o81lxisefl/gatewayresponses/REQUEST_TOO_LARGE" \}, \{ "href": "/restapis/o81lxisefl/gatewayresponses/THROTTLED" \}, \{ "href": "/restapis/o81lxisefl/gatewayresponses/UNSUPPORTED_MEDIA_TYPE" \}, \{ "href": "/restapis/o81lxisefl/gatewayresponses/AUTHORIZER_CONFIGURATION_ERROR" \}, \{ "href": "/restapis/o81lxisefl/gatewayresponses/DEFAULT_5XX" \}, \{ "href": "/restapis/o81lxisefl/gatewayresponses/DEFAULT_4XX" \}, \{ "href": "/restapis/o81lxisefl/gatewayresponses/BAD_REQUEST_PARAMETERS" \}, \{ "href": "/restapis/o81lxisefl/gatewayresponses/BAD_REQUEST_BODY" \}, \{ "href": "/restapis/o81lxisefl/gatewayresponses/EXPIRED_TOKEN" \}, \{ "href": "/restapis/o81lxisefl/gatewayresponses/ACCESS_DENIED" \}, \{ "href": "/restapis/o81lxisefl/gatewayresponses/INVALID_API_KEY" \}, \{ "href": "/restapis/o81lxisefl/gatewayresponses/UNAUTHORIZED" \}, \{ "href": "/restapis/o81lxisefl/gatewayresponses/API_CONFIGURATION_ERROR" \}, \{ "href": "/restapis/o81lxisefl/gatewayresponses/QUOTA_EXCEEDED" \}, \{ "href": "/restapis/o81lxisefl/gatewayresponses/INTEGRATION_TIMEOUT" \}, \{ "href": "/restapis/o81lxisefl/gatewayresponses/MISSING_AUTHENTICATION_TOKEN" \}, \{ "href": "/restapis/o81lxisefl/gatewayresponses/INVALID_SIGNATURE" \}, \{ "href": "/restapis/o81lxisefl/gatewayresponses/AUTHORIZER_FAILURE" \} ] \}, "_embedded": \{ "item": [ \{ "_links": \{ "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/INTEGRATION_FAILURE" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/INTEGRATION_FAILURE" \} \}, "defaultResponse": true, "responseParameters": \{\}, "responseTemplates": \{ "application/json": "\{"message":$context.error.messageString\}" \}, "responseType": "INTEGRATION_FAILURE", "statusCode": "504" \}, \{ "_links": \{ "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/RESOURCE_NOT_FOUND" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/RESOURCE_NOT_FOUND" \} \}, "defaultResponse": true, "responseParameters": \{\}, "responseTemplates": \{ "application/json": "\{"message":$context.error.messageString\}" \}, "responseType": "RESOURCE_NOT_FOUND", "statusCode": "404" \}, \{ "_links": \{ "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/REQUEST_TOO_LARGE" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/REQUEST_TOO_LARGE" \} \}, "defaultResponse": true, "responseParameters": \{\}, "responseTemplates": \{ "application/json": "\{"message":$context.error.messageString\}" \}, "responseType": "REQUEST_TOO_LARGE", "statusCode": "413" \}, \{ "_links": \{ "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/THROTTLED" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/THROTTLED" \} \}, "defaultResponse": true, "responseParameters": \{\}, "responseTemplates": \{ "application/json": "\{"message":$context.error.messageString\}" \}, "responseType": "THROTTLED", "statusCode": "429" \}, \{ "_links": \{ "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/UNSUPPORTED_MEDIA_TYPE" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/UNSUPPORTED_MEDIA_TYPE" \} \}, "defaultResponse": true, "responseParameters": \{\}, "responseTemplates": \{ "application/json": "\{"message":$context.error.messageString\}" \}, "responseType": "UNSUPPORTED_MEDIA_TYPE", "statusCode": "415" \}, \{ "_links": \{ "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/AUTHORIZER_CONFIGURATION_ERROR" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/AUTHORIZER_CONFIGURATION_ERROR" \} \}, "defaultResponse": true, "responseParameters": \{\}, "responseTemplates": \{ "application/json": "\{"message":$context.error.messageString\}" \}, "responseType": "AUTHORIZER_CONFIGURATION_ERROR", "statusCode": "500" \}, \{ "_links": \{ "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/DEFAULT_5XX" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/DEFAULT_5XX" \} \}, "defaultResponse": true, "responseParameters": \{\}, "responseTemplates": \{ "application/json": "\{"message":$context.error.messageString\}" \}, "responseType": "DEFAULT_5XX" \}, \{ "_links": \{ "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/DEFAULT_4XX" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/DEFAULT_4XX" \} \}, "defaultResponse": true, "responseParameters": \{\}, "responseTemplates": \{ "application/json": "\{"message":$context.error.messageString\}" \}, "responseType": "DEFAULT_4XX" \}, \{ "_links": \{ "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/BAD_REQUEST_PARAMETERS" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/BAD_REQUEST_PARAMETERS" \} \}, "defaultResponse": true, "responseParameters": \{\}, "responseTemplates": \{ "application/json": "\{"message":$context.error.messageString\}" \}, "responseType": "BAD_REQUEST_PARAMETERS", "statusCode": "400" \}, \{ "_links": \{ "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/BAD_REQUEST_BODY" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/BAD_REQUEST_BODY" \} \}, "defaultResponse": true, "responseParameters": \{\}, "responseTemplates": \{ "application/json": "\{"message":$context.error.messageString\}" \}, "responseType": "BAD_REQUEST_BODY", "statusCode": "400" \}, \{ "_links": \{ "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/EXPIRED_TOKEN" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/EXPIRED_TOKEN" \} \}, "defaultResponse": true, "responseParameters": \{\}, "responseTemplates": \{ "application/json": "\{"message":$context.error.messageString\}" \}, "responseType": "EXPIRED_TOKEN", "statusCode": "403" \}, \{ "_links": \{ "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/ACCESS_DENIED" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/ACCESS_DENIED" \} \}, "defaultResponse": true, "responseParameters": \{\}, "responseTemplates": \{ "application/json": "\{"message":$context.error.messageString\}" \}, "responseType": "ACCESS_DENIED", "statusCode": "403" \}, \{ "_links": \{ "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/INVALID_API_KEY" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/INVALID_API_KEY" \} \}, "defaultResponse": true, "responseParameters": \{\}, "responseTemplates": \{ "application/json": "\{"message":$context.error.messageString\}" \}, "responseType": "INVALID_API_KEY", "statusCode": "403" \}, \{ "_links": \{ "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/UNAUTHORIZED" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/UNAUTHORIZED" \} \}, "defaultResponse": true, "responseParameters": \{\}, "responseTemplates": \{ "application/json": "\{"message":$context.error.messageString\}" \}, "responseType": "UNAUTHORIZED", "statusCode": "401" \}, \{ "_links": \{ "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/API_CONFIGURATION_ERROR" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/API_CONFIGURATION_ERROR" \} \}, "defaultResponse": true, "responseParameters": \{\}, "responseTemplates": \{ "application/json": "\{"message":$context.error.messageString\}" \}, "responseType": "API_CONFIGURATION_ERROR", "statusCode": "500" \}, \{ "_links": \{ "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/QUOTA_EXCEEDED" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/QUOTA_EXCEEDED" \} \}, "defaultResponse": true, "responseParameters": \{\}, "responseTemplates": \{ "application/json": "\{"message":$context.error.messageString\}" \}, "responseType": "QUOTA_EXCEEDED", "statusCode": "429" \}, \{ "_links": \{ "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/INTEGRATION_TIMEOUT" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/INTEGRATION_TIMEOUT" \} \}, "defaultResponse": true, "responseParameters": \{\}, "responseTemplates": \{ "application/json": "\{"message":$context.error.messageString\}" \}, "responseType": "INTEGRATION_TIMEOUT", "statusCode": "504" \}, \{ "_links": \{ "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/MISSING_AUTHENTICATION_TOKEN" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/MISSING_AUTHENTICATION_TOKEN" \} \}, "defaultResponse": true, "responseParameters": \{\}, "responseTemplates": \{ "application/json": "\{"message":$context.error.messageString\}" \}, "responseType": "MISSING_AUTHENTICATION_TOKEN", "statusCode": "403" \}, \{ "_links": \{ "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/INVALID_SIGNATURE" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/INVALID_SIGNATURE" \} \}, "defaultResponse": true, "responseParameters": \{\}, "responseTemplates": \{ "application/json": "\{"message":$context.error.messageString\}" \}, "responseType": "INVALID_SIGNATURE", "statusCode": "403" \}, \{ "_links": \{ "self": \{ "href": "/restapis/o81lxisefl/gatewayresponses/AUTHORIZER_FAILURE" \}, "gatewayresponse:put": \{ "href": "/restapis/o81lxisefl/gatewayresponses/\{response_type\}", "templated": true \}, "gatewayresponse:update": \{ "href": "/restapis/o81lxisefl/gatewayresponses/AUTHORIZER_FAILURE" \} \}, "defaultResponse": true, "responseParameters": \{\}, "responseTemplates": \{ "application/json": "\{"message":$context.error.messageString\}" \}, "responseType": "AUTHORIZER_FAILURE", "statusCode": "500" \} ] \} \} # # # #
#
# #
# [Customize Gateway Responses][2] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/supported-gateway-response-types.html # [2]: https://docs.aws.amazon.com/apigateway/latest/developerguide/customize-gateway-responses.html # # @!attribute [rw] position # @return [String] # # @!attribute [rw] items # Returns the entire collection, because of no pagination support. # @return [Array] # class GatewayResponses < Struct.new( :position, :items) SENSITIVE = [] include Aws::Structure end # A request to generate a ClientCertificate resource. # # @note When making an API call, you may pass GenerateClientCertificateRequest # data as a hash: # # { # description: "String", # tags: { # "String" => "String", # }, # } # # @!attribute [rw] description # The description of the ClientCertificate. # @return [String] # # @!attribute [rw] tags # The key-value map of strings. The valid character set is # \[a-zA-Z+-=.\_:/\]. The tag key can be up to 128 characters and must # not start with `aws:`. The tag value can be up to 256 characters. # @return [Hash] # class GenerateClientCertificateRequest < Struct.new( :description, :tags) SENSITIVE = [] include Aws::Structure end # Requests API Gateway to get information about the current Account # resource. # # @api private # class GetAccountRequest < Aws::EmptyStructure; end # A request to get information about the current ApiKey resource. # # @note When making an API call, you may pass GetApiKeyRequest # data as a hash: # # { # api_key: "String", # required # include_value: false, # } # # @!attribute [rw] api_key # \[Required\] The identifier of the ApiKey resource. # @return [String] # # @!attribute [rw] include_value # A boolean flag to specify whether (`true`) or not (`false`) the # result contains the key value. # @return [Boolean] # class GetApiKeyRequest < Struct.new( :api_key, :include_value) SENSITIVE = [] include Aws::Structure end # A request to get information about the current ApiKeys resource. # # @note When making an API call, you may pass GetApiKeysRequest # data as a hash: # # { # position: "String", # limit: 1, # name_query: "String", # customer_id: "String", # include_values: false, # } # # @!attribute [rw] position # The current pagination position in the paged result set. # @return [String] # # @!attribute [rw] limit # The maximum number of returned results per page. The default value # is 25 and the maximum value is 500. # @return [Integer] # # @!attribute [rw] name_query # The name of queried API keys. # @return [String] # # @!attribute [rw] customer_id # The identifier of a customer in AWS Marketplace or an external # system, such as a developer portal. # @return [String] # # @!attribute [rw] include_values # A boolean flag to specify whether (`true`) or not (`false`) the # result contains key values. # @return [Boolean] # class GetApiKeysRequest < Struct.new( :position, :limit, :name_query, :customer_id, :include_values) SENSITIVE = [] include Aws::Structure end # Request to describe an existing Authorizer resource. # # @note When making an API call, you may pass GetAuthorizerRequest # data as a hash: # # { # rest_api_id: "String", # required # authorizer_id: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] authorizer_id # \[Required\] The identifier of the Authorizer resource. # @return [String] # class GetAuthorizerRequest < Struct.new( :rest_api_id, :authorizer_id) SENSITIVE = [] include Aws::Structure end # Request to describe an existing Authorizers resource. # # @note When making an API call, you may pass GetAuthorizersRequest # data as a hash: # # { # rest_api_id: "String", # required # position: "String", # limit: 1, # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] position # The current pagination position in the paged result set. # @return [String] # # @!attribute [rw] limit # The maximum number of returned results per page. The default value # is 25 and the maximum value is 500. # @return [Integer] # class GetAuthorizersRequest < Struct.new( :rest_api_id, :position, :limit) SENSITIVE = [] include Aws::Structure end # Request to describe a BasePathMapping resource. # # @note When making an API call, you may pass GetBasePathMappingRequest # data as a hash: # # { # domain_name: "String", # required # base_path: "String", # required # } # # @!attribute [rw] domain_name # \[Required\] The domain name of the BasePathMapping resource to be # described. # @return [String] # # @!attribute [rw] base_path # \[Required\] The base path name that callers of the API must provide # as part of the URL after the domain name. This value must be unique # for all of the mappings across a single API. Specify '(none)' if # you do not want callers to specify any base path name after the # domain name. # @return [String] # class GetBasePathMappingRequest < Struct.new( :domain_name, :base_path) SENSITIVE = [] include Aws::Structure end # A request to get information about a collection of BasePathMapping # resources. # # @note When making an API call, you may pass GetBasePathMappingsRequest # data as a hash: # # { # domain_name: "String", # required # position: "String", # limit: 1, # } # # @!attribute [rw] domain_name # \[Required\] The domain name of a BasePathMapping resource. # @return [String] # # @!attribute [rw] position # The current pagination position in the paged result set. # @return [String] # # @!attribute [rw] limit # The maximum number of returned results per page. The default value # is 25 and the maximum value is 500. # @return [Integer] # class GetBasePathMappingsRequest < Struct.new( :domain_name, :position, :limit) SENSITIVE = [] include Aws::Structure end # A request to get information about the current ClientCertificate # resource. # # @note When making an API call, you may pass GetClientCertificateRequest # data as a hash: # # { # client_certificate_id: "String", # required # } # # @!attribute [rw] client_certificate_id # \[Required\] The identifier of the ClientCertificate resource to be # described. # @return [String] # class GetClientCertificateRequest < Struct.new( :client_certificate_id) SENSITIVE = [] include Aws::Structure end # A request to get information about a collection of ClientCertificate # resources. # # @note When making an API call, you may pass GetClientCertificatesRequest # data as a hash: # # { # position: "String", # limit: 1, # } # # @!attribute [rw] position # The current pagination position in the paged result set. # @return [String] # # @!attribute [rw] limit # The maximum number of returned results per page. The default value # is 25 and the maximum value is 500. # @return [Integer] # class GetClientCertificatesRequest < Struct.new( :position, :limit) SENSITIVE = [] include Aws::Structure end # Requests API Gateway to get information about a Deployment resource. # # @note When making an API call, you may pass GetDeploymentRequest # data as a hash: # # { # rest_api_id: "String", # required # deployment_id: "String", # required # embed: ["String"], # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] deployment_id # \[Required\] The identifier of the Deployment resource to get # information about. # @return [String] # # @!attribute [rw] embed # A query parameter to retrieve the specified embedded resources of # the returned Deployment resource in the response. In a REST API # call, this `embed` parameter value is a list of comma-separated # strings, as in `GET # /restapis/\{restapi_id\}/deployments/\{deployment_id\}?embed=var1,var2`. # The SDK and other platform-dependent libraries might use a different # format for the list. Currently, this request supports only retrieval # of the embedded API summary this way. Hence, the parameter value # must be a single-valued list containing only the `"apisummary"` # string. For example, `GET # /restapis/\{restapi_id\}/deployments/\{deployment_id\}?embed=apisummary`. # @return [Array] # class GetDeploymentRequest < Struct.new( :rest_api_id, :deployment_id, :embed) SENSITIVE = [] include Aws::Structure end # Requests API Gateway to get information about a Deployments # collection. # # @note When making an API call, you may pass GetDeploymentsRequest # data as a hash: # # { # rest_api_id: "String", # required # position: "String", # limit: 1, # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] position # The current pagination position in the paged result set. # @return [String] # # @!attribute [rw] limit # The maximum number of returned results per page. The default value # is 25 and the maximum value is 500. # @return [Integer] # class GetDeploymentsRequest < Struct.new( :rest_api_id, :position, :limit) SENSITIVE = [] include Aws::Structure end # Gets a specified documentation part of a given API. # # @note When making an API call, you may pass GetDocumentationPartRequest # data as a hash: # # { # rest_api_id: "String", # required # documentation_part_id: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] documentation_part_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # class GetDocumentationPartRequest < Struct.new( :rest_api_id, :documentation_part_id) SENSITIVE = [] include Aws::Structure end # Gets the documentation parts of an API. The result may be filtered by # the type, name, or path of API entities (targets). # # @note When making an API call, you may pass GetDocumentationPartsRequest # data as a hash: # # { # rest_api_id: "String", # required # type: "API", # accepts API, AUTHORIZER, MODEL, RESOURCE, METHOD, PATH_PARAMETER, QUERY_PARAMETER, REQUEST_HEADER, REQUEST_BODY, RESPONSE, RESPONSE_HEADER, RESPONSE_BODY # name_query: "String", # path: "String", # position: "String", # limit: 1, # location_status: "DOCUMENTED", # accepts DOCUMENTED, UNDOCUMENTED # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] type # The type of API entities of the to-be-retrieved documentation parts. # @return [String] # # @!attribute [rw] name_query # The name of API entities of the to-be-retrieved documentation parts. # @return [String] # # @!attribute [rw] path # The path of API entities of the to-be-retrieved documentation parts. # @return [String] # # @!attribute [rw] position # The current pagination position in the paged result set. # @return [String] # # @!attribute [rw] limit # The maximum number of returned results per page. The default value # is 25 and the maximum value is 500. # @return [Integer] # # @!attribute [rw] location_status # The status of the API documentation parts to retrieve. Valid values # are `DOCUMENTED` for retrieving DocumentationPart resources with # content and `UNDOCUMENTED` for DocumentationPart resources without # content. # @return [String] # class GetDocumentationPartsRequest < Struct.new( :rest_api_id, :type, :name_query, :path, :position, :limit, :location_status) SENSITIVE = [] include Aws::Structure end # Gets a documentation snapshot of an API. # # @note When making an API call, you may pass GetDocumentationVersionRequest # data as a hash: # # { # rest_api_id: "String", # required # documentation_version: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] documentation_version # \[Required\] The version identifier of the to-be-retrieved # documentation snapshot. # @return [String] # class GetDocumentationVersionRequest < Struct.new( :rest_api_id, :documentation_version) SENSITIVE = [] include Aws::Structure end # Gets the documentation versions of an API. # # @note When making an API call, you may pass GetDocumentationVersionsRequest # data as a hash: # # { # rest_api_id: "String", # required # position: "String", # limit: 1, # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] position # The current pagination position in the paged result set. # @return [String] # # @!attribute [rw] limit # The maximum number of returned results per page. The default value # is 25 and the maximum value is 500. # @return [Integer] # class GetDocumentationVersionsRequest < Struct.new( :rest_api_id, :position, :limit) SENSITIVE = [] include Aws::Structure end # Request to get the name of a DomainName resource. # # @note When making an API call, you may pass GetDomainNameRequest # data as a hash: # # { # domain_name: "String", # required # } # # @!attribute [rw] domain_name # \[Required\] The name of the DomainName resource. # @return [String] # class GetDomainNameRequest < Struct.new( :domain_name) SENSITIVE = [] include Aws::Structure end # Request to describe a collection of DomainName resources. # # @note When making an API call, you may pass GetDomainNamesRequest # data as a hash: # # { # position: "String", # limit: 1, # } # # @!attribute [rw] position # The current pagination position in the paged result set. # @return [String] # # @!attribute [rw] limit # The maximum number of returned results per page. The default value # is 25 and the maximum value is 500. # @return [Integer] # class GetDomainNamesRequest < Struct.new( :position, :limit) SENSITIVE = [] include Aws::Structure end # Request a new export of a RestApi for a particular Stage. # # @note When making an API call, you may pass GetExportRequest # data as a hash: # # { # rest_api_id: "String", # required # stage_name: "String", # required # export_type: "String", # required # parameters: { # "String" => "String", # }, # accepts: "String", # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] stage_name # \[Required\] The name of the Stage that will be exported. # @return [String] # # @!attribute [rw] export_type # \[Required\] The type of export. Acceptable values are 'oas30' for # OpenAPI 3.0.x and 'swagger' for Swagger/OpenAPI 2.0. # @return [String] # # @!attribute [rw] parameters # A key-value map of query string parameters that specify properties # of the export, depending on the requested `exportType`. For # `exportType` `oas30` and `swagger`, any combination of the following # parameters are supported: `extensions='integrations'` or # `extensions='apigateway'` will export the API with # x-amazon-apigateway-integration extensions. # `extensions='authorizers'` will export the API with # x-amazon-apigateway-authorizer extensions. `postman` will export the # API with Postman extensions, allowing for import to the Postman tool # @return [Hash] # # @!attribute [rw] accepts # The content-type of the export, for example `application/json`. # Currently `application/json` and `application/yaml` are supported # for `exportType` of`oas30` and `swagger`. This should be specified # in the `Accept` header for direct API requests. # @return [String] # class GetExportRequest < Struct.new( :rest_api_id, :stage_name, :export_type, :parameters, :accepts) SENSITIVE = [] include Aws::Structure end # Gets a GatewayResponse of a specified response type on the given # RestApi. # # @note When making an API call, you may pass GetGatewayResponseRequest # data as a hash: # # { # rest_api_id: "String", # required # response_type: "DEFAULT_4XX", # required, accepts DEFAULT_4XX, DEFAULT_5XX, RESOURCE_NOT_FOUND, UNAUTHORIZED, INVALID_API_KEY, ACCESS_DENIED, AUTHORIZER_FAILURE, AUTHORIZER_CONFIGURATION_ERROR, INVALID_SIGNATURE, EXPIRED_TOKEN, MISSING_AUTHENTICATION_TOKEN, INTEGRATION_FAILURE, INTEGRATION_TIMEOUT, API_CONFIGURATION_ERROR, UNSUPPORTED_MEDIA_TYPE, BAD_REQUEST_PARAMETERS, BAD_REQUEST_BODY, REQUEST_TOO_LARGE, THROTTLED, QUOTA_EXCEEDED # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] response_type # \[Required\] The response type of the associated GatewayResponse. # Valid values # are * ACCESS\_DENIED # * API\_CONFIGURATION\_ERROR # * AUTHORIZER\_FAILURE # * AUTHORIZER\_CONFIGURATION\_ERROR # * BAD\_REQUEST\_PARAMETERS # * BAD\_REQUEST\_BODY # * DEFAULT\_4XX # * DEFAULT\_5XX # * EXPIRED\_TOKEN # * INVALID\_SIGNATURE # * INTEGRATION\_FAILURE # * INTEGRATION\_TIMEOUT # * INVALID\_API\_KEY # * MISSING\_AUTHENTICATION\_TOKEN # * QUOTA\_EXCEEDED # * REQUEST\_TOO\_LARGE # * RESOURCE\_NOT\_FOUND # * THROTTLED # * UNAUTHORIZED # * UNSUPPORTED\_MEDIA\_TYPE # @return [String] # class GetGatewayResponseRequest < Struct.new( :rest_api_id, :response_type) SENSITIVE = [] include Aws::Structure end # Gets the GatewayResponses collection on the given RestApi. If an API # developer has not added any definitions for gateway responses, the # result will be the API Gateway-generated default GatewayResponses # collection for the supported response types. # # @note When making an API call, you may pass GetGatewayResponsesRequest # data as a hash: # # { # rest_api_id: "String", # required # position: "String", # limit: 1, # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] position # The current pagination position in the paged result set. The # GatewayResponse collection does not support pagination and the # position does not apply here. # @return [String] # # @!attribute [rw] limit # The maximum number of returned results per page. The default value # is 25 and the maximum value is 500. The GatewayResponses collection # does not support pagination and the limit does not apply here. # @return [Integer] # class GetGatewayResponsesRequest < Struct.new( :rest_api_id, :position, :limit) SENSITIVE = [] include Aws::Structure end # Represents a request to get the integration configuration. # # @note When making an API call, you may pass GetIntegrationRequest # data as a hash: # # { # rest_api_id: "String", # required # resource_id: "String", # required # http_method: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] resource_id # \[Required\] Specifies a get integration request's resource # identifier # @return [String] # # @!attribute [rw] http_method # \[Required\] Specifies a get integration request's HTTP method. # @return [String] # class GetIntegrationRequest < Struct.new( :rest_api_id, :resource_id, :http_method) SENSITIVE = [] include Aws::Structure end # Represents a get integration response request. # # @note When making an API call, you may pass GetIntegrationResponseRequest # data as a hash: # # { # rest_api_id: "String", # required # resource_id: "String", # required # http_method: "String", # required # status_code: "StatusCode", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] resource_id # \[Required\] Specifies a get integration response request's # resource identifier. # @return [String] # # @!attribute [rw] http_method # \[Required\] Specifies a get integration response request's HTTP # method. # @return [String] # # @!attribute [rw] status_code # \[Required\] Specifies a get integration response request's status # code. # @return [String] # class GetIntegrationResponseRequest < Struct.new( :rest_api_id, :resource_id, :http_method, :status_code) SENSITIVE = [] include Aws::Structure end # Request to describe an existing Method resource. # # @note When making an API call, you may pass GetMethodRequest # data as a hash: # # { # rest_api_id: "String", # required # resource_id: "String", # required # http_method: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] resource_id # \[Required\] The Resource identifier for the Method resource. # @return [String] # # @!attribute [rw] http_method # \[Required\] Specifies the method request's HTTP method type. # @return [String] # class GetMethodRequest < Struct.new( :rest_api_id, :resource_id, :http_method) SENSITIVE = [] include Aws::Structure end # Request to describe a MethodResponse resource. # # @note When making an API call, you may pass GetMethodResponseRequest # data as a hash: # # { # rest_api_id: "String", # required # resource_id: "String", # required # http_method: "String", # required # status_code: "StatusCode", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] resource_id # \[Required\] The Resource identifier for the MethodResponse # resource. # @return [String] # # @!attribute [rw] http_method # \[Required\] The HTTP verb of the Method resource. # @return [String] # # @!attribute [rw] status_code # \[Required\] The status code for the MethodResponse resource. # @return [String] # class GetMethodResponseRequest < Struct.new( :rest_api_id, :resource_id, :http_method, :status_code) SENSITIVE = [] include Aws::Structure end # Request to list information about a model in an existing RestApi # resource. # # @note When making an API call, you may pass GetModelRequest # data as a hash: # # { # rest_api_id: "String", # required # model_name: "String", # required # flatten: false, # } # # @!attribute [rw] rest_api_id # \[Required\] The RestApi identifier under which the Model exists. # @return [String] # # @!attribute [rw] model_name # \[Required\] The name of the model as an identifier. # @return [String] # # @!attribute [rw] flatten # A query parameter of a Boolean value to resolve (`true`) all # external model references and returns a flattened model schema or # not (`false`) The default is `false`. # @return [Boolean] # class GetModelRequest < Struct.new( :rest_api_id, :model_name, :flatten) SENSITIVE = [] include Aws::Structure end # Request to generate a sample mapping template used to transform the # payload. # # @note When making an API call, you may pass GetModelTemplateRequest # data as a hash: # # { # rest_api_id: "String", # required # model_name: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] model_name # \[Required\] The name of the model for which to generate a template. # @return [String] # class GetModelTemplateRequest < Struct.new( :rest_api_id, :model_name) SENSITIVE = [] include Aws::Structure end # Request to list existing Models defined for a RestApi resource. # # @note When making an API call, you may pass GetModelsRequest # data as a hash: # # { # rest_api_id: "String", # required # position: "String", # limit: 1, # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] position # The current pagination position in the paged result set. # @return [String] # # @!attribute [rw] limit # The maximum number of returned results per page. The default value # is 25 and the maximum value is 500. # @return [Integer] # class GetModelsRequest < Struct.new( :rest_api_id, :position, :limit) SENSITIVE = [] include Aws::Structure end # Gets a RequestValidator of a given RestApi. # # @note When making an API call, you may pass GetRequestValidatorRequest # data as a hash: # # { # rest_api_id: "String", # required # request_validator_id: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] request_validator_id # \[Required\] The identifier of the RequestValidator to be retrieved. # @return [String] # class GetRequestValidatorRequest < Struct.new( :rest_api_id, :request_validator_id) SENSITIVE = [] include Aws::Structure end # Gets the RequestValidators collection of a given RestApi. # # @note When making an API call, you may pass GetRequestValidatorsRequest # data as a hash: # # { # rest_api_id: "String", # required # position: "String", # limit: 1, # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] position # The current pagination position in the paged result set. # @return [String] # # @!attribute [rw] limit # The maximum number of returned results per page. The default value # is 25 and the maximum value is 500. # @return [Integer] # class GetRequestValidatorsRequest < Struct.new( :rest_api_id, :position, :limit) SENSITIVE = [] include Aws::Structure end # Request to list information about a resource. # # @note When making an API call, you may pass GetResourceRequest # data as a hash: # # { # rest_api_id: "String", # required # resource_id: "String", # required # embed: ["String"], # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] resource_id # \[Required\] The identifier for the Resource resource. # @return [String] # # @!attribute [rw] embed # A query parameter to retrieve the specified resources embedded in # the returned Resource representation in the response. This `embed` # parameter value is a list of comma-separated strings. Currently, the # request supports only retrieval of the embedded Method resources # this way. The query parameter value must be a single-valued list and # contain the `"methods"` string. For example, `GET # /restapis/\{restapi_id\}/resources/\{resource_id\}?embed=methods`. # @return [Array] # class GetResourceRequest < Struct.new( :rest_api_id, :resource_id, :embed) SENSITIVE = [] include Aws::Structure end # Request to list information about a collection of resources. # # @note When making an API call, you may pass GetResourcesRequest # data as a hash: # # { # rest_api_id: "String", # required # position: "String", # limit: 1, # embed: ["String"], # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] position # The current pagination position in the paged result set. # @return [String] # # @!attribute [rw] limit # The maximum number of returned results per page. The default value # is 25 and the maximum value is 500. # @return [Integer] # # @!attribute [rw] embed # A query parameter used to retrieve the specified resources embedded # in the returned Resources resource in the response. This `embed` # parameter value is a list of comma-separated strings. Currently, the # request supports only retrieval of the embedded Method resources # this way. The query parameter value must be a single-valued list and # contain the `"methods"` string. For example, `GET # /restapis/\{restapi_id\}/resources?embed=methods`. # @return [Array] # class GetResourcesRequest < Struct.new( :rest_api_id, :position, :limit, :embed) SENSITIVE = [] include Aws::Structure end # The GET request to list an existing RestApi defined for your # collection. # # @note When making an API call, you may pass GetRestApiRequest # data as a hash: # # { # rest_api_id: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # class GetRestApiRequest < Struct.new( :rest_api_id) SENSITIVE = [] include Aws::Structure end # The GET request to list existing RestApis defined for your collection. # # @note When making an API call, you may pass GetRestApisRequest # data as a hash: # # { # position: "String", # limit: 1, # } # # @!attribute [rw] position # The current pagination position in the paged result set. # @return [String] # # @!attribute [rw] limit # The maximum number of returned results per page. The default value # is 25 and the maximum value is 500. # @return [Integer] # class GetRestApisRequest < Struct.new( :position, :limit) SENSITIVE = [] include Aws::Structure end # Request a new generated client SDK for a RestApi and Stage. # # @note When making an API call, you may pass GetSdkRequest # data as a hash: # # { # rest_api_id: "String", # required # stage_name: "String", # required # sdk_type: "String", # required # parameters: { # "String" => "String", # }, # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] stage_name # \[Required\] The name of the Stage that the SDK will use. # @return [String] # # @!attribute [rw] sdk_type # \[Required\] The language for the generated SDK. Currently `java`, # `javascript`, `android`, `objectivec` (for iOS), `swift` (for iOS), # and `ruby` are supported. # @return [String] # # @!attribute [rw] parameters # A string-to-string key-value map of query parameters # `sdkType`-dependent properties of the SDK. For `sdkType` of # `objectivec` or `swift`, a parameter named `classPrefix` is # required. For `sdkType` of `android`, parameters named `groupId`, # `artifactId`, `artifactVersion`, and `invokerPackage` are required. # For `sdkType` of `java`, parameters named `serviceName` and # `javaPackageName` are required. # @return [Hash] # class GetSdkRequest < Struct.new( :rest_api_id, :stage_name, :sdk_type, :parameters) SENSITIVE = [] include Aws::Structure end # Get an SdkType instance. # # @note When making an API call, you may pass GetSdkTypeRequest # data as a hash: # # { # id: "String", # required # } # # @!attribute [rw] id # \[Required\] The identifier of the queried SdkType instance. # @return [String] # class GetSdkTypeRequest < Struct.new( :id) SENSITIVE = [] include Aws::Structure end # Get the SdkTypes collection. # # @note When making an API call, you may pass GetSdkTypesRequest # data as a hash: # # { # position: "String", # limit: 1, # } # # @!attribute [rw] position # The current pagination position in the paged result set. # @return [String] # # @!attribute [rw] limit # The maximum number of returned results per page. The default value # is 25 and the maximum value is 500. # @return [Integer] # class GetSdkTypesRequest < Struct.new( :position, :limit) SENSITIVE = [] include Aws::Structure end # Requests API Gateway to get information about a Stage resource. # # @note When making an API call, you may pass GetStageRequest # data as a hash: # # { # rest_api_id: "String", # required # stage_name: "String", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] stage_name # \[Required\] The name of the Stage resource to get information # about. # @return [String] # class GetStageRequest < Struct.new( :rest_api_id, :stage_name) SENSITIVE = [] include Aws::Structure end # Requests API Gateway to get information about one or more Stage # resources. # # @note When making an API call, you may pass GetStagesRequest # data as a hash: # # { # rest_api_id: "String", # required # deployment_id: "String", # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] deployment_id # The stages' deployment identifiers. # @return [String] # class GetStagesRequest < Struct.new( :rest_api_id, :deployment_id) SENSITIVE = [] include Aws::Structure end # Gets the Tags collection for a given resource. # # @note When making an API call, you may pass GetTagsRequest # data as a hash: # # { # resource_arn: "String", # required # position: "String", # limit: 1, # } # # @!attribute [rw] resource_arn # \[Required\] The ARN of a resource that can be tagged. # @return [String] # # @!attribute [rw] position # (Not currently supported) The current pagination position in the # paged result set. # @return [String] # # @!attribute [rw] limit # (Not currently supported) The maximum number of returned results per # page. The default value is 25 and the maximum value is 500. # @return [Integer] # class GetTagsRequest < Struct.new( :resource_arn, :position, :limit) SENSITIVE = [] include Aws::Structure end # The GET request to get a usage plan key of a given key identifier. # # @note When making an API call, you may pass GetUsagePlanKeyRequest # data as a hash: # # { # usage_plan_id: "String", # required # key_id: "String", # required # } # # @!attribute [rw] usage_plan_id # \[Required\] The Id of the UsagePlan resource representing the usage # plan containing the to-be-retrieved UsagePlanKey resource # representing a plan customer. # @return [String] # # @!attribute [rw] key_id # \[Required\] The key Id of the to-be-retrieved UsagePlanKey resource # representing a plan customer. # @return [String] # class GetUsagePlanKeyRequest < Struct.new( :usage_plan_id, :key_id) SENSITIVE = [] include Aws::Structure end # The GET request to get all the usage plan keys representing the API # keys added to a specified usage plan. # # @note When making an API call, you may pass GetUsagePlanKeysRequest # data as a hash: # # { # usage_plan_id: "String", # required # position: "String", # limit: 1, # name_query: "String", # } # # @!attribute [rw] usage_plan_id # \[Required\] The Id of the UsagePlan resource representing the usage # plan containing the to-be-retrieved UsagePlanKey resource # representing a plan customer. # @return [String] # # @!attribute [rw] position # The current pagination position in the paged result set. # @return [String] # # @!attribute [rw] limit # The maximum number of returned results per page. The default value # is 25 and the maximum value is 500. # @return [Integer] # # @!attribute [rw] name_query # A query parameter specifying the name of the to-be-returned usage # plan keys. # @return [String] # class GetUsagePlanKeysRequest < Struct.new( :usage_plan_id, :position, :limit, :name_query) SENSITIVE = [] include Aws::Structure end # The GET request to get a usage plan of a given plan identifier. # # @note When making an API call, you may pass GetUsagePlanRequest # data as a hash: # # { # usage_plan_id: "String", # required # } # # @!attribute [rw] usage_plan_id # \[Required\] The identifier of the UsagePlan resource to be # retrieved. # @return [String] # class GetUsagePlanRequest < Struct.new( :usage_plan_id) SENSITIVE = [] include Aws::Structure end # The GET request to get all the usage plans of the caller's account. # # @note When making an API call, you may pass GetUsagePlansRequest # data as a hash: # # { # position: "String", # key_id: "String", # limit: 1, # } # # @!attribute [rw] position # The current pagination position in the paged result set. # @return [String] # # @!attribute [rw] key_id # The identifier of the API key associated with the usage plans. # @return [String] # # @!attribute [rw] limit # The maximum number of returned results per page. The default value # is 25 and the maximum value is 500. # @return [Integer] # class GetUsagePlansRequest < Struct.new( :position, :key_id, :limit) SENSITIVE = [] include Aws::Structure end # The GET request to get the usage data of a usage plan in a specified # time interval. # # @note When making an API call, you may pass GetUsageRequest # data as a hash: # # { # usage_plan_id: "String", # required # key_id: "String", # start_date: "String", # required # end_date: "String", # required # position: "String", # limit: 1, # } # # @!attribute [rw] usage_plan_id # \[Required\] The Id of the usage plan associated with the usage # data. # @return [String] # # @!attribute [rw] key_id # The Id of the API key associated with the resultant usage data. # @return [String] # # @!attribute [rw] start_date # \[Required\] The starting date (e.g., 2016-01-01) of the usage data. # @return [String] # # @!attribute [rw] end_date # \[Required\] The ending date (e.g., 2016-12-31) of the usage data. # @return [String] # # @!attribute [rw] position # The current pagination position in the paged result set. # @return [String] # # @!attribute [rw] limit # The maximum number of returned results per page. The default value # is 25 and the maximum value is 500. # @return [Integer] # class GetUsageRequest < Struct.new( :usage_plan_id, :key_id, :start_date, :end_date, :position, :limit) SENSITIVE = [] include Aws::Structure end # Gets a specified VPC link under the caller's account in a region. # # @note When making an API call, you may pass GetVpcLinkRequest # data as a hash: # # { # vpc_link_id: "String", # required # } # # @!attribute [rw] vpc_link_id # \[Required\] The identifier of the VpcLink. It is used in an # Integration to reference this VpcLink. # @return [String] # class GetVpcLinkRequest < Struct.new( :vpc_link_id) SENSITIVE = [] include Aws::Structure end # Gets the VpcLinks collection under the caller's account in a selected # region. # # @note When making an API call, you may pass GetVpcLinksRequest # data as a hash: # # { # position: "String", # limit: 1, # } # # @!attribute [rw] position # The current pagination position in the paged result set. # @return [String] # # @!attribute [rw] limit # The maximum number of returned results per page. The default value # is 25 and the maximum value is 500. # @return [Integer] # class GetVpcLinksRequest < Struct.new( :position, :limit) SENSITIVE = [] include Aws::Structure end # The POST request to import API keys from an external source, such as a # CSV-formatted file. # # @note When making an API call, you may pass ImportApiKeysRequest # data as a hash: # # { # body: "data", # required # format: "csv", # required, accepts csv # fail_on_warnings: false, # } # # @!attribute [rw] body # The payload of the POST request to import API keys. For the payload # format, see [API Key File Format][1]. # # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-key-file-format.html # @return [String] # # @!attribute [rw] format # A query parameter to specify the input format to imported API keys. # Currently, only the `csv` format is supported. # @return [String] # # @!attribute [rw] fail_on_warnings # A query parameter to indicate whether to rollback ApiKey importation # (`true`) or not (`false`) when error is encountered. # @return [Boolean] # class ImportApiKeysRequest < Struct.new( :body, :format, :fail_on_warnings) SENSITIVE = [] include Aws::Structure end # Import documentation parts from an external (e.g., OpenAPI) definition # file. # # @note When making an API call, you may pass ImportDocumentationPartsRequest # data as a hash: # # { # rest_api_id: "String", # required # mode: "merge", # accepts merge, overwrite # fail_on_warnings: false, # body: "data", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] mode # A query parameter to indicate whether to overwrite (`OVERWRITE`) any # existing DocumentationParts definition or to merge (`MERGE`) the new # definition into the existing one. The default value is `MERGE`. # @return [String] # # @!attribute [rw] fail_on_warnings # A query parameter to specify whether to rollback the documentation # importation (`true`) or not (`false`) when a warning is encountered. # The default value is `false`. # @return [Boolean] # # @!attribute [rw] body # \[Required\] Raw byte array representing the to-be-imported # documentation parts. To import from an OpenAPI file, this is a JSON # object. # @return [String] # class ImportDocumentationPartsRequest < Struct.new( :rest_api_id, :mode, :fail_on_warnings, :body) SENSITIVE = [] include Aws::Structure end # A POST request to import an API to API Gateway using an input of an # API definition file. # # @note When making an API call, you may pass ImportRestApiRequest # data as a hash: # # { # fail_on_warnings: false, # parameters: { # "String" => "String", # }, # body: "data", # required # } # # @!attribute [rw] fail_on_warnings # A query parameter to indicate whether to rollback the API creation # (`true`) or not (`false`) when a warning is encountered. The default # value is `false`. # @return [Boolean] # # @!attribute [rw] parameters # A key-value map of context-specific query string parameters # specifying the behavior of different API importing operations. The # following shows operation-specific parameters and their supported # values. # # To exclude DocumentationParts from the import, set `parameters` as # `ignore=documentation`. # # To configure the endpoint type, set `parameters` as # `endpointConfigurationTypes=EDGE`, # `endpointConfigurationTypes=REGIONAL`, or # `endpointConfigurationTypes=PRIVATE`. The default endpoint type is # `EDGE`. # # To handle imported `basepath`, set `parameters` as # `basepath=ignore`, `basepath=prepend` or `basepath=split`. # # For example, the AWS CLI command to exclude documentation from the # imported API is: # # aws apigateway import-rest-api --parameters ignore=documentation --body 'file:///path/to/imported-api-body.json' # # The AWS CLI command to set the regional endpoint on the imported API # is: # # aws apigateway import-rest-api --parameters endpointConfigurationTypes=REGIONAL --body 'file:///path/to/imported-api-body.json' # @return [Hash] # # @!attribute [rw] body # \[Required\] The POST request body containing external API # definitions. Currently, only OpenAPI definition JSON/YAML files are # supported. The maximum size of the API definition file is 6MB. # @return [String] # class ImportRestApiRequest < Struct.new( :fail_on_warnings, :parameters, :body) SENSITIVE = [] include Aws::Structure end # Represents an HTTP, HTTP\_PROXY, AWS, AWS\_PROXY, or Mock integration. # #
# In the API Gateway console, the built-in Lambda integration is an AWS # integration. #
# #
# [Creating an API][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/how-to-create-api.html # # @!attribute [rw] type # Specifies an API method integration type. The valid value is one of # the following: # # * `AWS`\: for integrating the API method request with an AWS service # action, including the Lambda function-invoking action. With the # Lambda function-invoking action, this is referred to as the Lambda # custom integration. With any other AWS service action, this is # known as AWS integration. # * `AWS_PROXY`\: for integrating the API method request with the # Lambda function-invoking action with the client request passed # through as-is. This integration is also referred to as the Lambda # proxy integration. # * `HTTP`\: for integrating the API method request with an HTTP # endpoint, including a private HTTP endpoint within a VPC. This # integration is also referred to as the HTTP custom integration. # * `HTTP_PROXY`\: for integrating the API method request with an HTTP # endpoint, including a private HTTP endpoint within a VPC, with the # client request passed through as-is. This is also referred to as # the HTTP proxy integration. # * `MOCK`\: for integrating the API method request with API Gateway # as a "loop-back" endpoint without invoking any backend. # # For the HTTP and HTTP proxy integrations, each integration can # specify a protocol (`http/https`), port and path. Standard 80 and # 443 ports are supported as well as custom ports above 1024. An HTTP # or HTTP proxy integration with a `connectionType` of `VPC_LINK` is # referred to as a private integration and uses a VpcLink to connect # API Gateway to a network load balancer of a VPC. # @return [String] # # @!attribute [rw] http_method # Specifies the integration's HTTP method type. # @return [String] # # @!attribute [rw] uri # Specifies Uniform Resource Identifier (URI) of the integration # endpoint. # # * For `HTTP` or `HTTP_PROXY` integrations, the URI must be a fully # formed, encoded HTTP(S) URL according to the [RFC-3986 # specification][1], for either standard integration, where # `connectionType` is not `VPC_LINK`, or private integration, where # `connectionType` is `VPC_LINK`. For a private HTTP integration, # the URI is not used for routing. # # * For `AWS` or `AWS_PROXY` integrations, the URI is of the form # `arn:aws:apigateway:\{region\}:\{subdomain.service|service\}:path|action/\{service_api\}`. # Here, `\{Region\}` is the API Gateway region (e.g., `us-east-1`); # `\{service\}` is the name of the integrated AWS service (e.g., # `s3`); and `\{subdomain\}` is a designated subdomain supported by # certain AWS service for fast host-name lookup. `action` can be # used for an AWS service action-based API, using an # `Action=\{name\}&\{p1\}=\{v1\}&p2=\{v2\}...` query string. The # ensuing `\{service_api\}` refers to a supported action `\{name\}` # plus any required input parameters. Alternatively, `path` can be # used for an AWS service path-based API. The ensuing `service_api` # refers to the path to an AWS service resource, including the # region of the integrated AWS service, if applicable. For example, # for integration with the S3 API of `GetObject`, the `uri` can be # either # `arn:aws:apigateway:us-west-2:s3:action/GetObject&Bucket=\{bucket\}&Key=\{key\}` # or `arn:aws:apigateway:us-west-2:s3:path/\{bucket\}/\{key\}` # # # # [1]: https://en.wikipedia.org/wiki/Uniform_Resource_Identifier # @return [String] # # @!attribute [rw] connection_type # The type of the network connection to the integration endpoint. The # valid value is `INTERNET` for connections through the public # routable internet or `VPC_LINK` for private connections between API # Gateway and a network load balancer in a VPC. The default value is # `INTERNET`. # @return [String] # # @!attribute [rw] connection_id # The ([`id`][1]) of the VpcLink used for the integration when # `connectionType=VPC_LINK` and undefined, otherwise. # # # # [1]: https://docs.aws.amazon.com/apigateway/api-reference/resource/vpc-link/#id # @return [String] # # @!attribute [rw] credentials # Specifies the credentials required for the integration, if any. For # AWS integrations, three options are available. To specify an IAM # Role for API Gateway to assume, use the role's Amazon Resource Name # (ARN). To require that the caller's identity be passed through from # the request, specify the string `arn:aws:iam::*:user/*`. To use # resource-based permissions on supported AWS services, specify null. # @return [String] # # @!attribute [rw] request_parameters # A key-value map specifying request parameters that are passed from # the method request to the back end. The key is an integration # request parameter name and the associated value is a method request # parameter value or static value that must be enclosed within single # quotes and pre-encoded as required by the back end. The method # request parameter value must match the pattern of # `method.request.\{location\}.\{name\}`, where `location` is # `querystring`, `path`, or `header` and `name` must be a valid and # unique method request parameter name. # @return [Hash] # # @!attribute [rw] request_templates # Represents a map of Velocity templates that are applied on the # request payload based on the value of the Content-Type header sent # by the client. The content type value is the key in this map, and # the template (as a String) is the value. # @return [Hash] # # @!attribute [rw] passthrough_behavior #
# Specifies how the method request body of an unmapped content type # will be passed through the integration request to the back end # without transformation. A content type is unmapped if no mapping # template is defined in the integration or the content type does not # match any of the mapped content types, as specified in # `requestTemplates`. The valid value is one of the following: # # * `WHEN_NO_MATCH`\: passes the method request body through the # integration request to the back end without transformation when # the method request content type does not match any content type # associated with the mapping templates defined in the integration # request. # * `WHEN_NO_TEMPLATES`\: passes the method request body through the # integration request to the back end without transformation when no # mapping template is defined in the integration request. If a # template is defined when this option is selected, the method # request of an unmapped content-type will be rejected with an HTTP # `415 Unsupported Media Type` response. # * `NEVER`\: rejects the method request with an HTTP `415 Unsupported # Media Type` response when either the method request content type # does not match any content type associated with the mapping # templates defined in the integration request or no mapping # template is defined in the integration request. # #
# @return [String] # # @!attribute [rw] content_handling # Specifies how to handle request payload content type conversions. # Supported values are `CONVERT_TO_BINARY` and `CONVERT_TO_TEXT`, with # the following behaviors: # # * `CONVERT_TO_BINARY`\: Converts a request payload from a # Base64-encoded string to the corresponding binary blob. # # * `CONVERT_TO_TEXT`\: Converts a request payload from a binary blob # to a Base64-encoded string. # # If this property is not defined, the request payload will be passed # through from the method request to integration request without # modification, provided that the `passthroughBehavior` is configured # to support payload pass-through. # @return [String] # # @!attribute [rw] timeout_in_millis # Custom timeout between 50 and 29,000 milliseconds. The default value # is 29,000 milliseconds or 29 seconds. # @return [Integer] # # @!attribute [rw] cache_namespace # Specifies a group of related cached parameters. By default, API # Gateway uses the resource ID as the `cacheNamespace`. You can # specify the same `cacheNamespace` across resources to return the # same cached data for requests to different resources. # @return [String] # # @!attribute [rw] cache_key_parameters # A list of request parameters whose values API Gateway caches. To be # valid values for `cacheKeyParameters`, these parameters must also be # specified for Method `requestParameters`. # @return [Array] # # @!attribute [rw] integration_responses # Specifies the integration's responses. # #
# # # #### Example: Get integration responses of a method # # ##### Request # # # # GET /restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration/responses/200 HTTP/1.1 Content-Type: application/json Host: apigateway.us-east-1.amazonaws.com X-Amz-Date: 20160607T191449Z Authorization: AWS4-HMAC-SHA256 Credential=\{access_key_ID\}/20160607/us-east-1/apigateway/aws4_request, SignedHeaders=content-type;host;x-amz-date, Signature=\{sig4_hash\} # # ##### Response # # The successful response returns `200 OK` status and a payload as # follows: # # \{ "_links": \{ "curies": \{ "href": "https://docs.aws.amazon.com/apigateway/latest/developerguide/restapi-integration-response-\{rel\}.html", "name": "integrationresponse", "templated": true \}, "self": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration/responses/200", "title": "200" \}, "integrationresponse:delete": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration/responses/200" \}, "integrationresponse:update": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration/responses/200" \} \}, "responseParameters": \{ "method.response.header.Content-Type": "'application/xml'" \}, "responseTemplates": \{ "application/json": "$util.urlDecode("%3CkinesisStreams%3E#foreach($stream in $input.path('$.StreamNames'))%3Cstream%3E%3Cname%3E$stream%3C/name%3E%3C/stream%3E#end%3C/kinesisStreams%3E")\n" \}, "statusCode": "200" \} # # # #
# #
# [Creating an API][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/how-to-create-api.html # @return [Hash] # # @!attribute [rw] tls_config # Specifies the TLS configuration for an integration. # @return [Types::TlsConfig] # class Integration < Struct.new( :type, :http_method, :uri, :connection_type, :connection_id, :credentials, :request_parameters, :request_templates, :passthrough_behavior, :content_handling, :timeout_in_millis, :cache_namespace, :cache_key_parameters, :integration_responses, :tls_config) SENSITIVE = [] include Aws::Structure end # Represents an integration response. The status code must map to an # existing MethodResponse, and parameters and templates can be used to # transform the back-end response. # #
# [Creating an API][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/how-to-create-api.html # # @!attribute [rw] status_code # Specifies the status code that is used to map the integration # response to an existing MethodResponse. # @return [String] # # @!attribute [rw] selection_pattern # Specifies the regular expression (regex) pattern used to choose an # integration response based on the response from the back end. For # example, if the success response returns nothing and the error # response returns some string, you could use the `.+` regex to match # error response. However, make sure that the error response does not # contain any newline (`\n`) character in such cases. If the back end # is an AWS Lambda function, the AWS Lambda function error header is # matched. For all other HTTP and AWS back ends, the HTTP status code # is matched. # @return [String] # # @!attribute [rw] response_parameters # A key-value map specifying response parameters that are passed to # the method response from the back end. The key is a method response # header parameter name and the mapped value is an integration # response header value, a static value enclosed within a pair of # single quotes, or a JSON expression from the integration response # body. The mapping key must match the pattern of # `method.response.header.\{name\}`, where `name` is a valid and # unique header name. The mapped non-static value must match the # pattern of `integration.response.header.\{name\}` or # `integration.response.body.\{JSON-expression\}`, where `name` is a # valid and unique response header name and `JSON-expression` is a # valid JSON expression without the `$` prefix. # @return [Hash] # # @!attribute [rw] response_templates # Specifies the templates used to transform the integration response # body. Response templates are represented as a key/value map, with a # content-type as the key and a template as the value. # @return [Hash] # # @!attribute [rw] content_handling # Specifies how to handle response payload content type conversions. # Supported values are `CONVERT_TO_BINARY` and `CONVERT_TO_TEXT`, with # the following behaviors: # # * `CONVERT_TO_BINARY`\: Converts a response payload from a # Base64-encoded string to the corresponding binary blob. # # * `CONVERT_TO_TEXT`\: Converts a response payload from a binary blob # to a Base64-encoded string. # # If this property is not defined, the response payload will be passed # through from the integration response to the method response without # modification. # @return [String] # class IntegrationResponse < Struct.new( :status_code, :selection_pattern, :response_parameters, :response_templates, :content_handling) SENSITIVE = [] include Aws::Structure end # The request exceeded the rate limit. Retry after the specified time # period. # # @!attribute [rw] retry_after_seconds # @return [String] # # @!attribute [rw] message # @return [String] # class LimitExceededException < Struct.new( :retry_after_seconds, :message) SENSITIVE = [] include Aws::Structure end # Represents a client-facing interface by which the client calls the API # to access back-end resources. A **Method** resource is integrated with # an Integration resource. Both consist of a request and one or more # responses. The method request takes the client input that is passed to # the back end through the integration request. A method response # returns the output from the back end to the client through an # integration response. A method request is embodied in a **Method** # resource, whereas an integration request is embodied in an Integration # resource. On the other hand, a method response is represented by a # MethodResponse resource, whereas an integration response is # represented by an IntegrationResponse resource. # #
# # # #### Example: Retrive the GET method on a specified resource # # ##### Request # # The following example request retrieves the information about the GET # method on an API resource (`3kzxbg5sa2`) of an API (`fugvjdxtri`). # # GET /restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET HTTP/1.1 Content-Type: application/json Host: apigateway.us-east-1.amazonaws.com X-Amz-Date: 20160603T210259Z Authorization: AWS4-HMAC-SHA256 Credential=\{access_key_ID\}/20160603/us-east-1/apigateway/aws4_request, SignedHeaders=content-type;host;x-amz-date, Signature=\{sig4_hash\} # # ##### Response # # The successful response returns a `200 OK` status code and a payload # similar to the following: # # \{ "_links": \{ "curies": [ \{ "href": "https://docs.aws.amazon.com/apigateway/latest/developerguide/restapi-integration-\{rel\}.html", "name": "integration", "templated": true \}, \{ "href": "https://docs.aws.amazon.com/apigateway/latest/developerguide/restapi-integration-response-\{rel\}.html", "name": "integrationresponse", "templated": true \}, \{ "href": "https://docs.aws.amazon.com/apigateway/latest/developerguide/restapi-method-\{rel\}.html", "name": "method", "templated": true \}, \{ "href": "https://docs.aws.amazon.com/apigateway/latest/developerguide/restapi-method-response-\{rel\}.html", "name": "methodresponse", "templated": true \} ], "self": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET", "name": "GET", "title": "GET" \}, "integration:put": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration" \}, "method:delete": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET" \}, "method:integration": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration" \}, "method:responses": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/responses/200", "name": "200", "title": "200" \}, "method:update": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET" \}, "methodresponse:put": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/responses/\{status_code\}", "templated": true \} \}, "apiKeyRequired": true, "authorizationType": "NONE", "httpMethod": "GET", "_embedded": \{ "method:integration": \{ "_links": \{ "self": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration" \}, "integration:delete": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration" \}, "integration:responses": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration/responses/200", "name": "200", "title": "200" \}, "integration:update": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration" \}, "integrationresponse:put": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration/responses/\{status_code\}", "templated": true \} \}, "cacheKeyParameters": [], "cacheNamespace": "3kzxbg5sa2", "credentials": "arn:aws:iam::123456789012:role/apigAwsProxyRole", "httpMethod": "POST", "passthroughBehavior": "WHEN_NO_MATCH", "requestParameters": \{ "integration.request.header.Content-Type": "'application/x-amz-json-1.1'" \}, "requestTemplates": \{ "application/json": "\{\n\}" \}, "type": "AWS", "uri": "arn:aws:apigateway:us-east-1:kinesis:action/ListStreams", "_embedded": \{ "integration:responses": \{ "_links": \{ "self": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration/responses/200", "name": "200", "title": "200" \}, "integrationresponse:delete": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration/responses/200" \}, "integrationresponse:update": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration/responses/200" \} \}, "responseParameters": \{ "method.response.header.Content-Type": "'application/xml'" \}, "responseTemplates": \{ "application/json": "$util.urlDecode("%3CkinesisStreams%3E%23foreach(%24stream%20in%20%24input.path(%27%24.StreamNames%27))%3Cstream%3E%3Cname%3E%24stream%3C%2Fname%3E%3C%2Fstream%3E%23end%3C%2FkinesisStreams%3E")" \}, "statusCode": "200" \} \} \}, "method:responses": \{ "_links": \{ "self": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/responses/200", "name": "200", "title": "200" \}, "methodresponse:delete": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/responses/200" \}, "methodresponse:update": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/responses/200" \} \}, "responseModels": \{ "application/json": "Empty" \}, "responseParameters": \{ "method.response.header.Content-Type": false \}, "statusCode": "200" \} \} \} # # In the example above, the response template for the `200 OK` response # maps the JSON output from the `ListStreams` action in the back end to # an XML output. The mapping template is URL-encoded as # `%3CkinesisStreams%3E%23foreach(%24stream%20in%20%24input.path(%27%24.StreamNames%27))%3Cstream%3E%3Cname%3E%24stream%3C%2Fname%3E%3C%2Fstream%3E%23end%3C%2FkinesisStreams%3E` # and the output is decoded using the [$util.urlDecode()][1] helper # function. # #
# #
# MethodResponse, Integration, IntegrationResponse, Resource, [Set up an # API's method][2] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-mapping-template-reference.html#util-templat-reference # [2]: https://docs.aws.amazon.com/apigateway/latest/developerguide/how-to-method-settings.html # # @!attribute [rw] http_method # The method's HTTP verb. # @return [String] # # @!attribute [rw] authorization_type # The method's authorization type. Valid values are `NONE` for open # access, `AWS_IAM` for using AWS IAM permissions, `CUSTOM` for using # a custom authorizer, or `COGNITO_USER_POOLS` for using a Cognito # user pool. # @return [String] # # @!attribute [rw] authorizer_id # The identifier of an Authorizer to use on this method. The # `authorizationType` must be `CUSTOM`. # @return [String] # # @!attribute [rw] api_key_required # A boolean flag specifying whether a valid ApiKey is required to # invoke this method. # @return [Boolean] # # @!attribute [rw] request_validator_id # The identifier of a RequestValidator for request validation. # @return [String] # # @!attribute [rw] operation_name # A human-friendly operation identifier for the method. For example, # you can assign the `operationName` of `ListPets` for the `GET /pets` # method in the `PetStore` example. # @return [String] # # @!attribute [rw] request_parameters # A key-value map defining required or optional method request # parameters that can be accepted by API Gateway. A key is a method # request parameter name matching the pattern of # `method.request.\{location\}.\{name\}`, where `location` is # `querystring`, `path`, or `header` and `name` is a valid and unique # parameter name. The value associated with the key is a Boolean flag # indicating whether the parameter is required (`true`) or optional # (`false`). The method request parameter names defined here are # available in Integration to be mapped to integration request # parameters or templates. # @return [Hash] # # @!attribute [rw] request_models # A key-value map specifying data schemas, represented by Model # resources, (as the mapped value) of the request payloads of given # content types (as the mapping key). # @return [Hash] # # @!attribute [rw] method_responses # Gets a method response associated with a given HTTP status code. # #
# The collection of method responses are encapsulated in a key-value # map, where the key is a response's HTTP status code and the value # is a MethodResponse resource that specifies the response returned to # the caller from the back end through the integration response. # # #### Example: Get a 200 OK response of a GET method # # ##### Request # # # # GET /restapis/uojnr9hd57/resources/0cjtch/methods/GET/responses/200 HTTP/1.1 Content-Type: application/json Host: apigateway.us-east-1.amazonaws.com Content-Length: 117 X-Amz-Date: 20160613T215008Z Authorization: AWS4-HMAC-SHA256 Credential=\{access_key_ID\}/20160613/us-east-1/apigateway/aws4_request, SignedHeaders=content-type;host;x-amz-date, Signature=\{sig4_hash\} # # ##### Response # # The successful response returns a `200 OK` status code and a payload # similar to the following: # # \{ "_links": \{ "curies": \{ "href": "https://docs.aws.amazon.com/apigateway/latest/developerguide/restapi-method-response-\{rel\}.html", "name": "methodresponse", "templated": true \}, "self": \{ "href": "/restapis/uojnr9hd57/resources/0cjtch/methods/GET/responses/200", "title": "200" \}, "methodresponse:delete": \{ "href": "/restapis/uojnr9hd57/resources/0cjtch/methods/GET/responses/200" \}, "methodresponse:update": \{ "href": "/restapis/uojnr9hd57/resources/0cjtch/methods/GET/responses/200" \} \}, "responseModels": \{ "application/json": "Empty" \}, "responseParameters": \{ "method.response.header.operator": false, "method.response.header.operand_2": false, "method.response.header.operand_1": false \}, "statusCode": "200" \} # # # #
# #
# [AWS CLI][1] #
# # # # [1]: https://docs.aws.amazon.com/cli/latest/reference/apigateway/get-method-response.html # @return [Hash] # # @!attribute [rw] method_integration # Gets the method's integration responsible for passing the # client-submitted request to the back end and performing necessary # transformations to make the request compliant with the back end. # #
# # # #### Example: # # ##### Request # # # # GET /restapis/uojnr9hd57/resources/0cjtch/methods/GET/integration HTTP/1.1 Content-Type: application/json Host: apigateway.us-east-1.amazonaws.com Content-Length: 117 X-Amz-Date: 20160613T213210Z Authorization: AWS4-HMAC-SHA256 Credential=\{access_key_ID\}/20160613/us-east-1/apigateway/aws4_request, SignedHeaders=content-type;host;x-amz-date, Signature=\{sig4_hash\} # # ##### Response # # The successful response returns a `200 OK` status code and a payload # similar to the following: # # \{ "_links": \{ "curies": [ \{ "href": "https://docs.aws.amazon.com/apigateway/latest/developerguide/restapi-integration-\{rel\}.html", "name": "integration", "templated": true \}, \{ "href": "https://docs.aws.amazon.com/apigateway/latest/developerguide/restapi-integration-response-\{rel\}.html", "name": "integrationresponse", "templated": true \} ], "self": \{ "href": "/restapis/uojnr9hd57/resources/0cjtch/methods/GET/integration" \}, "integration:delete": \{ "href": "/restapis/uojnr9hd57/resources/0cjtch/methods/GET/integration" \}, "integration:responses": \{ "href": "/restapis/uojnr9hd57/resources/0cjtch/methods/GET/integration/responses/200", "name": "200", "title": "200" \}, "integration:update": \{ "href": "/restapis/uojnr9hd57/resources/0cjtch/methods/GET/integration" \}, "integrationresponse:put": \{ "href": "/restapis/uojnr9hd57/resources/0cjtch/methods/GET/integration/responses/\{status_code\}", "templated": true \} \}, "cacheKeyParameters": [], "cacheNamespace": "0cjtch", "credentials": "arn:aws:iam::123456789012:role/apigAwsProxyRole", "httpMethod": "POST", "passthroughBehavior": "WHEN_NO_MATCH", "requestTemplates": \{ "application/json": "\{\n "a": "$input.params('operand1')",\n "b": "$input.params('operand2')", \n "op": "$input.params('operator')" \n\}" \}, "type": "AWS", "uri": "arn:aws:apigateway:us-west-2:lambda:path//2015-03-31/functions/arn:aws:lambda:us-west-2:123456789012:function:Calc/invocations", "_embedded": \{ "integration:responses": \{ "_links": \{ "self": \{ "href": "/restapis/uojnr9hd57/resources/0cjtch/methods/GET/integration/responses/200", "name": "200", "title": "200" \}, "integrationresponse:delete": \{ "href": "/restapis/uojnr9hd57/resources/0cjtch/methods/GET/integration/responses/200" \}, "integrationresponse:update": \{ "href": "/restapis/uojnr9hd57/resources/0cjtch/methods/GET/integration/responses/200" \} \}, "responseParameters": \{ "method.response.header.operator": "integration.response.body.op", "method.response.header.operand_2": "integration.response.body.b", "method.response.header.operand_1": "integration.response.body.a" \}, "responseTemplates": \{ "application/json": "#set($res = $input.path('$'))\n\{\n "result": "$res.a, $res.b, $res.op => $res.c",\n "a" : "$res.a",\n "b" : "$res.b",\n "op" : "$res.op",\n "c" : "$res.c"\n\}" \}, "selectionPattern": "", "statusCode": "200" \} \} \} # # # #
# #
# [AWS CLI][1] #
# # # # [1]: https://docs.aws.amazon.com/cli/latest/reference/apigateway/get-integration.html # @return [Types::Integration] # # @!attribute [rw] authorization_scopes # A list of authorization scopes configured on the method. The scopes # are used with a `COGNITO_USER_POOLS` authorizer to authorize the # method invocation. The authorization works by matching the method # scopes against the scopes parsed from the access token in the # incoming request. The method invocation is authorized if any method # scopes matches a claimed scope in the access token. Otherwise, the # invocation is not authorized. When the method scope is configured, # the client must provide an access token instead of an identity token # for authorization purposes. # @return [Array] # class Method < Struct.new( :http_method, :authorization_type, :authorizer_id, :api_key_required, :request_validator_id, :operation_name, :request_parameters, :request_models, :method_responses, :method_integration, :authorization_scopes) SENSITIVE = [] include Aws::Structure end # Represents a method response of a given HTTP status code returned to # the client. The method response is passed from the back end through # the associated integration response that can be transformed using a # mapping template. # #
# # # #### Example: A **MethodResponse** instance of an API # # ##### Request # # The example request retrieves a **MethodResponse** of the 200 status # code. # # GET /restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/responses/200 HTTP/1.1 Content-Type: application/json Host: apigateway.us-east-1.amazonaws.com X-Amz-Date: 20160603T222952Z Authorization: AWS4-HMAC-SHA256 Credential=\{access_key_ID\}/20160603/us-east-1/apigateway/aws4_request, SignedHeaders=content-type;host;x-amz-date, Signature=\{sig4_hash\} # # ##### Response # # The successful response returns `200 OK` status and a payload as # follows: # # \{ "_links": \{ "curies": \{ "href": "https://docs.aws.amazon.com/apigateway/latest/developerguide/restapi-method-response-\{rel\}.html", "name": "methodresponse", "templated": true \}, "self": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/responses/200", "title": "200" \}, "methodresponse:delete": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/responses/200" \}, "methodresponse:update": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/responses/200" \} \}, "responseModels": \{ "application/json": "Empty" \}, "responseParameters": \{ "method.response.header.Content-Type": false \}, "statusCode": "200" \} # # # #
# #
# Method, IntegrationResponse, Integration [Creating an API][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/how-to-create-api.html # # @!attribute [rw] status_code # The method response's status code. # @return [String] # # @!attribute [rw] response_parameters # A key-value map specifying required or optional response parameters # that API Gateway can send back to the caller. A key defines a method # response header and the value specifies whether the associated # method response header is required or not. The expression of the key # must match the pattern `method.response.header.\{name\}`, where # `name` is a valid and unique header name. API Gateway passes certain # integration response data to the method response headers specified # here according to the mapping you prescribe in the API's # IntegrationResponse. The integration response data that can be # mapped include an integration response header expressed in # `integration.response.header.\{name\}`, a static value enclosed # within a pair of single quotes (e.g., `'application/json'`), or a # JSON expression from the back-end response payload in the form of # `integration.response.body.\{JSON-expression\}`, where # `JSON-expression` is a valid JSON expression without the `$` # prefix.) # @return [Hash] # # @!attribute [rw] response_models # Specifies the Model resources used for the response's content-type. # Response models are represented as a key/value map, with a # content-type as the key and a Model name as the value. # @return [Hash] # class MethodResponse < Struct.new( :status_code, :response_parameters, :response_models) SENSITIVE = [] include Aws::Structure end # Specifies the method setting properties. # # @!attribute [rw] metrics_enabled # Specifies whether Amazon CloudWatch metrics are enabled for this # method. The PATCH path for this setting is # `/\{method_setting_key\}/metrics/enabled`, and the value is a # Boolean. # @return [Boolean] # # @!attribute [rw] logging_level # Specifies the logging level for this method, which affects the log # entries pushed to Amazon CloudWatch Logs. The PATCH path for this # setting is `/\{method_setting_key\}/logging/loglevel`, and the # available levels are `OFF`, `ERROR`, and `INFO`. Choose `ERROR` to # write only error-level entries to CloudWatch Logs, or choose `INFO` # to include all `ERROR` events as well as extra informational events. # @return [String] # # @!attribute [rw] data_trace_enabled # Specifies whether data trace logging is enabled for this method, # which affects the log entries pushed to Amazon CloudWatch Logs. The # PATCH path for this setting is # `/\{method_setting_key\}/logging/dataTrace`, and the value is a # Boolean. # @return [Boolean] # # @!attribute [rw] throttling_burst_limit # Specifies the throttling burst limit. The PATCH path for this # setting is `/\{method_setting_key\}/throttling/burstLimit`, and the # value is an integer. # @return [Integer] # # @!attribute [rw] throttling_rate_limit # Specifies the throttling rate limit. The PATCH path for this setting # is `/\{method_setting_key\}/throttling/rateLimit`, and the value is # a double. # @return [Float] # # @!attribute [rw] caching_enabled # Specifies whether responses should be cached and returned for # requests. A cache cluster must be enabled on the stage for responses # to be cached. The PATCH path for this setting is # `/\{method_setting_key\}/caching/enabled`, and the value is a # Boolean. # @return [Boolean] # # @!attribute [rw] cache_ttl_in_seconds # Specifies the time to live (TTL), in seconds, for cached responses. # The higher the TTL, the longer the response will be cached. The # PATCH path for this setting is # `/\{method_setting_key\}/caching/ttlInSeconds`, and the value is an # integer. # @return [Integer] # # @!attribute [rw] cache_data_encrypted # Specifies whether the cached responses are encrypted. The PATCH path # for this setting is `/\{method_setting_key\}/caching/dataEncrypted`, # and the value is a Boolean. # @return [Boolean] # # @!attribute [rw] require_authorization_for_cache_control # Specifies whether authorization is required for a cache invalidation # request. The PATCH path for this setting is # `/\{method_setting_key\}/caching/requireAuthorizationForCacheControl`, # and the value is a Boolean. # @return [Boolean] # # @!attribute [rw] unauthorized_cache_control_header_strategy # Specifies how to handle unauthorized requests for cache # invalidation. The PATCH path for this setting is # `/\{method_setting_key\}/caching/unauthorizedCacheControlHeaderStrategy`, # and the available values are `FAIL_WITH_403`, # `SUCCEED_WITH_RESPONSE_HEADER`, `SUCCEED_WITHOUT_RESPONSE_HEADER`. # @return [String] # class MethodSetting < Struct.new( :metrics_enabled, :logging_level, :data_trace_enabled, :throttling_burst_limit, :throttling_rate_limit, :caching_enabled, :cache_ttl_in_seconds, :cache_data_encrypted, :require_authorization_for_cache_control, :unauthorized_cache_control_header_strategy) SENSITIVE = [] include Aws::Structure end # Represents a summary of a Method resource, given a particular date and # time. # # @!attribute [rw] authorization_type # The method's authorization type. Valid values are `NONE` for open # access, `AWS_IAM` for using AWS IAM permissions, `CUSTOM` for using # a custom authorizer, or `COGNITO_USER_POOLS` for using a Cognito # user pool. # @return [String] # # @!attribute [rw] api_key_required # Specifies whether the method requires a valid ApiKey. # @return [Boolean] # class MethodSnapshot < Struct.new( :authorization_type, :api_key_required) SENSITIVE = [] include Aws::Structure end # Represents the data structure of a method's request or response # payload. # #
# A request model defines the data structure of the client-supplied # request payload. A response model defines the data structure of the # response payload returned by the back end. Although not required, # models are useful for mapping payloads between the front end and back # end. # # A model is used for generating an API's SDK, validating the input # request body, and creating a skeletal mapping template. # #
# #
# Method, MethodResponse, [Models and Mappings][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/models-mappings.html # # @!attribute [rw] id # The identifier for the model resource. # @return [String] # # @!attribute [rw] name # The name of the model. Must be an alphanumeric string. # @return [String] # # @!attribute [rw] description # The description of the model. # @return [String] # # @!attribute [rw] schema # The schema for the model. For `application/json` models, this should # be [JSON schema draft 4][1] model. Do not include "\\*/" # characters in the description of any properties because such # "\\*/" characters may be interpreted as the closing marker for # comments in some languages, such as Java or JavaScript, causing the # installation of your API's SDK generated by API Gateway to fail. # # # # [1]: https://tools.ietf.org/html/draft-zyp-json-schema-04 # @return [String] # # @!attribute [rw] content_type # The content-type for the model. # @return [String] # class Model < Struct.new( :id, :name, :description, :schema, :content_type) SENSITIVE = [] include Aws::Structure end # Represents a collection of Model resources. # #
# Method, MethodResponse, [Models and Mappings][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/models-mappings.html # # @!attribute [rw] position # @return [String] # # @!attribute [rw] items # The current page of elements from this collection. # @return [Array] # class Models < Struct.new( :position, :items) SENSITIVE = [] include Aws::Structure end # If specified, API Gateway performs two-way authentication between the # client and the server. Clients must present a trusted certificate to # access your custom domain name. # # @!attribute [rw] truststore_uri # An Amazon S3 URL that specifies the truststore for mutual TLS # authentication, for example `s3://bucket-name/key-name`. The # truststore can contain certificates from public or private # certificate authorities. To update the truststore, upload a new # version to S3, and then update your custom domain name to use the # new version. To update the truststore, you must have permissions to # access the S3 object. # @return [String] # # @!attribute [rw] truststore_version # The version of the S3 object that contains your truststore. To # specify a version, you must have versioning enabled for the S3 # bucket. # @return [String] # # @!attribute [rw] truststore_warnings # A list of warnings that API Gateway returns while processing your # truststore. Invalid certificates produce warnings. Mutual TLS is # still enabled, but some clients might not be able to access your # API. To resolve warnings, upload a new truststore to S3, and then # update you domain name to use the new version. # @return [Array] # class MutualTlsAuthentication < Struct.new( :truststore_uri, :truststore_version, :truststore_warnings) SENSITIVE = [] include Aws::Structure end # If specified, API Gateway performs two-way authentication between the # client and the server. Clients must present a trusted certificate to # access your custom domain name. # # @note When making an API call, you may pass MutualTlsAuthenticationInput # data as a hash: # # { # truststore_uri: "String", # truststore_version: "String", # } # # @!attribute [rw] truststore_uri # An Amazon S3 resource ARN that specifies the truststore for mutual # TLS authentication, for example, `s3://bucket-name/key-name`. The # truststore can contain certificates from public or private # certificate authorities. To update the truststore, upload a new # version to S3, and then update your custom domain name to use the # new version. To update the truststore, you must have permissions to # access the S3 object. # @return [String] # # @!attribute [rw] truststore_version # The version of the S3 object that contains your truststore. To # specify a version, you must have versioning enabled for the S3 # bucket. # @return [String] # class MutualTlsAuthenticationInput < Struct.new( :truststore_uri, :truststore_version) SENSITIVE = [] include Aws::Structure end # The requested resource is not found. Make sure that the request URI is # correct. # # @!attribute [rw] message # @return [String] # class NotFoundException < Struct.new( :message) SENSITIVE = [] include Aws::Structure end # A single patch operation to apply to the specified resource. Please # refer to http://tools.ietf.org/html/rfc6902#section-4 for an # explanation of how each operation is used. # # @note When making an API call, you may pass PatchOperation # data as a hash: # # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # } # # @!attribute [rw] op # An update operation to be performed with this PATCH request. The # valid value can be `add`, `remove`, `replace` or `copy`. Not all # valid operations are supported for a given resource. Support of the # operations depends on specific operational contexts. Attempts to # apply an unsupported operation on a resource will return an error # message. # @return [String] # # @!attribute [rw] path # The `op` operation's target, as identified by a [JSON Pointer][1] # value that references a location within the targeted resource. For # example, if the target resource has an updateable property of # `\{"name":"value"\}`, the path for this property is `/name`. If the # `name` property value is a JSON object (e.g., `\{"name": # \{"child/name": "child-value"\}\}`), the path for the `child/name` # property will be `/name/child~1name`. Any slash ("/") character # appearing in path names must be escaped with "~1", as shown in the # example above. Each `op` operation can have only one `path` # associated with it. # # # # [1]: https://tools.ietf.org/html/draft-ietf-appsawg-json-pointer-08 # @return [String] # # @!attribute [rw] value # The new target value of the update operation. It is applicable for # the `add` or `replace` operation. When using AWS CLI to update a # property of a JSON value, enclose the JSON object with a pair of # single quotes in a Linux shell, e.g., '\\\{"a": ...\\}'. In a # Windows shell, see [Using JSON for Parameters][1]. # # # # [1]: https://docs.aws.amazon.com/cli/latest/userguide/cli-using-param.html#cli-using-param-json # @return [String] # # @!attribute [rw] from # The `copy` update operation's source as identified by a # `JSON-Pointer` value referencing the location within the targeted # resource to copy the value from. For example, to promote a canary # deployment, you copy the canary deployment ID to the affiliated # deployment ID by calling a PATCH request on a Stage resource with # `"op":"copy"`, `"from":"/canarySettings/deploymentId"` and # `"path":"/deploymentId"`. # @return [String] # class PatchOperation < Struct.new( :op, :path, :value, :from) SENSITIVE = [] include Aws::Structure end # Creates a customization of a GatewayResponse of a specified response # type and status code on the given RestApi. # # @note When making an API call, you may pass PutGatewayResponseRequest # data as a hash: # # { # rest_api_id: "String", # required # response_type: "DEFAULT_4XX", # required, accepts DEFAULT_4XX, DEFAULT_5XX, RESOURCE_NOT_FOUND, UNAUTHORIZED, INVALID_API_KEY, ACCESS_DENIED, AUTHORIZER_FAILURE, AUTHORIZER_CONFIGURATION_ERROR, INVALID_SIGNATURE, EXPIRED_TOKEN, MISSING_AUTHENTICATION_TOKEN, INTEGRATION_FAILURE, INTEGRATION_TIMEOUT, API_CONFIGURATION_ERROR, UNSUPPORTED_MEDIA_TYPE, BAD_REQUEST_PARAMETERS, BAD_REQUEST_BODY, REQUEST_TOO_LARGE, THROTTLED, QUOTA_EXCEEDED # status_code: "StatusCode", # response_parameters: { # "String" => "String", # }, # response_templates: { # "String" => "String", # }, # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] response_type # \[Required\] The response type of the associated GatewayResponse. # Valid values # are * ACCESS\_DENIED # * API\_CONFIGURATION\_ERROR # * AUTHORIZER\_FAILURE # * AUTHORIZER\_CONFIGURATION\_ERROR # * BAD\_REQUEST\_PARAMETERS # * BAD\_REQUEST\_BODY # * DEFAULT\_4XX # * DEFAULT\_5XX # * EXPIRED\_TOKEN # * INVALID\_SIGNATURE # * INTEGRATION\_FAILURE # * INTEGRATION\_TIMEOUT # * INVALID\_API\_KEY # * MISSING\_AUTHENTICATION\_TOKEN # * QUOTA\_EXCEEDED # * REQUEST\_TOO\_LARGE # * RESOURCE\_NOT\_FOUND # * THROTTLED # * UNAUTHORIZED # * UNSUPPORTED\_MEDIA\_TYPE # @return [String] # # @!attribute [rw] status_code # The HTTP status code of the GatewayResponse. # @return [String] # # @!attribute [rw] response_parameters # Response parameters (paths, query strings and headers) of the # GatewayResponse as a string-to-string map of key-value pairs. # @return [Hash] # # @!attribute [rw] response_templates # Response templates of the GatewayResponse as a string-to-string map # of key-value pairs. # @return [Hash] # class PutGatewayResponseRequest < Struct.new( :rest_api_id, :response_type, :status_code, :response_parameters, :response_templates) SENSITIVE = [] include Aws::Structure end # Sets up a method's integration. # # @note When making an API call, you may pass PutIntegrationRequest # data as a hash: # # { # rest_api_id: "String", # required # resource_id: "String", # required # http_method: "String", # required # type: "HTTP", # required, accepts HTTP, AWS, MOCK, HTTP_PROXY, AWS_PROXY # integration_http_method: "String", # uri: "String", # connection_type: "INTERNET", # accepts INTERNET, VPC_LINK # connection_id: "String", # credentials: "String", # request_parameters: { # "String" => "String", # }, # request_templates: { # "String" => "String", # }, # passthrough_behavior: "String", # cache_namespace: "String", # cache_key_parameters: ["String"], # content_handling: "CONVERT_TO_BINARY", # accepts CONVERT_TO_BINARY, CONVERT_TO_TEXT # timeout_in_millis: 1, # tls_config: { # insecure_skip_verification: false, # }, # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] resource_id # \[Required\] Specifies a put integration request's resource ID. # @return [String] # # @!attribute [rw] http_method # \[Required\] Specifies a put integration request's HTTP method. # @return [String] # # @!attribute [rw] type # \[Required\] Specifies a put integration input's type. # @return [String] # # @!attribute [rw] integration_http_method # Specifies a put integration HTTP method. When the integration type # is HTTP or AWS, this field is required. # @return [String] # # @!attribute [rw] uri # Specifies Uniform Resource Identifier (URI) of the integration # endpoint. # # * For `HTTP` or `HTTP_PROXY` integrations, the URI must be a fully # formed, encoded HTTP(S) URL according to the [RFC-3986 # specification][1], for either standard integration, where # `connectionType` is not `VPC_LINK`, or private integration, where # `connectionType` is `VPC_LINK`. For a private HTTP integration, # the URI is not used for routing. # # * For `AWS` or `AWS_PROXY` integrations, the URI is of the form # `arn:aws:apigateway:\{region\}:\{subdomain.service|service\}:path|action/\{service_api\}`. # Here, `\{Region\}` is the API Gateway region (e.g., `us-east-1`); # `\{service\}` is the name of the integrated AWS service (e.g., # `s3`); and `\{subdomain\}` is a designated subdomain supported by # certain AWS service for fast host-name lookup. `action` can be # used for an AWS service action-based API, using an # `Action=\{name\}&\{p1\}=\{v1\}&p2=\{v2\}...` query string. The # ensuing `\{service_api\}` refers to a supported action `\{name\}` # plus any required input parameters. Alternatively, `path` can be # used for an AWS service path-based API. The ensuing `service_api` # refers to the path to an AWS service resource, including the # region of the integrated AWS service, if applicable. For example, # for integration with the S3 API of `GetObject`, the `uri` can be # either # `arn:aws:apigateway:us-west-2:s3:action/GetObject&Bucket=\{bucket\}&Key=\{key\}` # or `arn:aws:apigateway:us-west-2:s3:path/\{bucket\}/\{key\}` # # # # [1]: https://en.wikipedia.org/wiki/Uniform_Resource_Identifier # @return [String] # # @!attribute [rw] connection_type # The type of the network connection to the integration endpoint. The # valid value is `INTERNET` for connections through the public # routable internet or `VPC_LINK` for private connections between API # Gateway and a network load balancer in a VPC. The default value is # `INTERNET`. # @return [String] # # @!attribute [rw] connection_id # The ([`id`][1]) of the VpcLink used for the integration when # `connectionType=VPC_LINK` and undefined, otherwise. # # # # [1]: https://docs.aws.amazon.com/apigateway/api-reference/resource/vpc-link/#id # @return [String] # # @!attribute [rw] credentials # Specifies whether credentials are required for a put integration. # @return [String] # # @!attribute [rw] request_parameters # A key-value map specifying request parameters that are passed from # the method request to the back end. The key is an integration # request parameter name and the associated value is a method request # parameter value or static value that must be enclosed within single # quotes and pre-encoded as required by the back end. The method # request parameter value must match the pattern of # `method.request.\{location\}.\{name\}`, where `location` is # `querystring`, `path`, or `header` and `name` must be a valid and # unique method request parameter name. # @return [Hash] # # @!attribute [rw] request_templates # Represents a map of Velocity templates that are applied on the # request payload based on the value of the Content-Type header sent # by the client. The content type value is the key in this map, and # the template (as a String) is the value. # @return [Hash] # # @!attribute [rw] passthrough_behavior # Specifies the pass-through behavior for incoming requests based on # the Content-Type header in the request, and the available mapping # templates specified as the `requestTemplates` property on the # Integration resource. There are three valid values: `WHEN_NO_MATCH`, # `WHEN_NO_TEMPLATES`, and `NEVER`. # # * `WHEN_NO_MATCH` passes the request body for unmapped content types # through to the integration back end without transformation. # # * `NEVER` rejects unmapped content types with an HTTP 415 # 'Unsupported Media Type' response. # # * `WHEN_NO_TEMPLATES` allows pass-through when the integration has # NO content types mapped to templates. However if there is at least # one content type defined, unmapped content types will be rejected # with the same 415 response. # @return [String] # # @!attribute [rw] cache_namespace # Specifies a group of related cached parameters. By default, API # Gateway uses the resource ID as the `cacheNamespace`. You can # specify the same `cacheNamespace` across resources to return the # same cached data for requests to different resources. # @return [String] # # @!attribute [rw] cache_key_parameters # A list of request parameters whose values API Gateway caches. To be # valid values for `cacheKeyParameters`, these parameters must also be # specified for Method `requestParameters`. # @return [Array] # # @!attribute [rw] content_handling # Specifies how to handle request payload content type conversions. # Supported values are `CONVERT_TO_BINARY` and `CONVERT_TO_TEXT`, with # the following behaviors: # # * `CONVERT_TO_BINARY`\: Converts a request payload from a # Base64-encoded string to the corresponding binary blob. # # * `CONVERT_TO_TEXT`\: Converts a request payload from a binary blob # to a Base64-encoded string. # # If this property is not defined, the request payload will be passed # through from the method request to integration request without # modification, provided that the `passthroughBehavior` is configured # to support payload pass-through. # @return [String] # # @!attribute [rw] timeout_in_millis # Custom timeout between 50 and 29,000 milliseconds. The default value # is 29,000 milliseconds or 29 seconds. # @return [Integer] # # @!attribute [rw] tls_config # @return [Types::TlsConfig] # class PutIntegrationRequest < Struct.new( :rest_api_id, :resource_id, :http_method, :type, :integration_http_method, :uri, :connection_type, :connection_id, :credentials, :request_parameters, :request_templates, :passthrough_behavior, :cache_namespace, :cache_key_parameters, :content_handling, :timeout_in_millis, :tls_config) SENSITIVE = [] include Aws::Structure end # Represents a put integration response request. # # @note When making an API call, you may pass PutIntegrationResponseRequest # data as a hash: # # { # rest_api_id: "String", # required # resource_id: "String", # required # http_method: "String", # required # status_code: "StatusCode", # required # selection_pattern: "String", # response_parameters: { # "String" => "String", # }, # response_templates: { # "String" => "String", # }, # content_handling: "CONVERT_TO_BINARY", # accepts CONVERT_TO_BINARY, CONVERT_TO_TEXT # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] resource_id # \[Required\] Specifies a put integration response request's # resource identifier. # @return [String] # # @!attribute [rw] http_method # \[Required\] Specifies a put integration response request's HTTP # method. # @return [String] # # @!attribute [rw] status_code # \[Required\] Specifies the status code that is used to map the # integration response to an existing MethodResponse. # @return [String] # # @!attribute [rw] selection_pattern # Specifies the selection pattern of a put integration response. # @return [String] # # @!attribute [rw] response_parameters # A key-value map specifying response parameters that are passed to # the method response from the back end. The key is a method response # header parameter name and the mapped value is an integration # response header value, a static value enclosed within a pair of # single quotes, or a JSON expression from the integration response # body. The mapping key must match the pattern of # `method.response.header.\{name\}`, where `name` is a valid and # unique header name. The mapped non-static value must match the # pattern of `integration.response.header.\{name\}` or # `integration.response.body.\{JSON-expression\}`, where `name` must # be a valid and unique response header name and `JSON-expression` a # valid JSON expression without the `$` prefix. # @return [Hash] # # @!attribute [rw] response_templates # Specifies a put integration response's templates. # @return [Hash] # # @!attribute [rw] content_handling # Specifies how to handle response payload content type conversions. # Supported values are `CONVERT_TO_BINARY` and `CONVERT_TO_TEXT`, with # the following behaviors: # # * `CONVERT_TO_BINARY`\: Converts a response payload from a # Base64-encoded string to the corresponding binary blob. # # * `CONVERT_TO_TEXT`\: Converts a response payload from a binary blob # to a Base64-encoded string. # # If this property is not defined, the response payload will be passed # through from the integration response to the method response without # modification. # @return [String] # class PutIntegrationResponseRequest < Struct.new( :rest_api_id, :resource_id, :http_method, :status_code, :selection_pattern, :response_parameters, :response_templates, :content_handling) SENSITIVE = [] include Aws::Structure end # Request to add a method to an existing Resource resource. # # @note When making an API call, you may pass PutMethodRequest # data as a hash: # # { # rest_api_id: "String", # required # resource_id: "String", # required # http_method: "String", # required # authorization_type: "String", # required # authorizer_id: "String", # api_key_required: false, # operation_name: "String", # request_parameters: { # "String" => false, # }, # request_models: { # "String" => "String", # }, # request_validator_id: "String", # authorization_scopes: ["String"], # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] resource_id # \[Required\] The Resource identifier for the new Method resource. # @return [String] # # @!attribute [rw] http_method # \[Required\] Specifies the method request's HTTP method type. # @return [String] # # @!attribute [rw] authorization_type # \[Required\] The method's authorization type. Valid values are # `NONE` for open access, `AWS_IAM` for using AWS IAM permissions, # `CUSTOM` for using a custom authorizer, or `COGNITO_USER_POOLS` for # using a Cognito user pool. # @return [String] # # @!attribute [rw] authorizer_id # Specifies the identifier of an Authorizer to use on this Method, if # the type is CUSTOM or COGNITO\_USER\_POOLS. The authorizer # identifier is generated by API Gateway when you created the # authorizer. # @return [String] # # @!attribute [rw] api_key_required # Specifies whether the method required a valid ApiKey. # @return [Boolean] # # @!attribute [rw] operation_name # A human-friendly operation identifier for the method. For example, # you can assign the `operationName` of `ListPets` for the `GET /pets` # method in the `PetStore` example. # @return [String] # # @!attribute [rw] request_parameters # A key-value map defining required or optional method request # parameters that can be accepted by API Gateway. A key defines a # method request parameter name matching the pattern of # `method.request.\{location\}.\{name\}`, where `location` is # `querystring`, `path`, or `header` and `name` is a valid and unique # parameter name. The value associated with the key is a Boolean flag # indicating whether the parameter is required (`true`) or optional # (`false`). The method request parameter names defined here are # available in Integration to be mapped to integration request # parameters or body-mapping templates. # @return [Hash] # # @!attribute [rw] request_models # Specifies the Model resources used for the request's content type. # Request models are represented as a key/value map, with a content # type as the key and a Model name as the value. # @return [Hash] # # @!attribute [rw] request_validator_id # The identifier of a RequestValidator for validating the method # request. # @return [String] # # @!attribute [rw] authorization_scopes # A list of authorization scopes configured on the method. The scopes # are used with a `COGNITO_USER_POOLS` authorizer to authorize the # method invocation. The authorization works by matching the method # scopes against the scopes parsed from the access token in the # incoming request. The method invocation is authorized if any method # scopes matches a claimed scope in the access token. Otherwise, the # invocation is not authorized. When the method scope is configured, # the client must provide an access token instead of an identity token # for authorization purposes. # @return [Array] # class PutMethodRequest < Struct.new( :rest_api_id, :resource_id, :http_method, :authorization_type, :authorizer_id, :api_key_required, :operation_name, :request_parameters, :request_models, :request_validator_id, :authorization_scopes) SENSITIVE = [] include Aws::Structure end # Request to add a MethodResponse to an existing Method resource. # # @note When making an API call, you may pass PutMethodResponseRequest # data as a hash: # # { # rest_api_id: "String", # required # resource_id: "String", # required # http_method: "String", # required # status_code: "StatusCode", # required # response_parameters: { # "String" => false, # }, # response_models: { # "String" => "String", # }, # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] resource_id # \[Required\] The Resource identifier for the Method resource. # @return [String] # # @!attribute [rw] http_method # \[Required\] The HTTP verb of the Method resource. # @return [String] # # @!attribute [rw] status_code # \[Required\] The method response's status code. # @return [String] # # @!attribute [rw] response_parameters # A key-value map specifying required or optional response parameters # that API Gateway can send back to the caller. A key defines a method # response header name and the associated value is a Boolean flag # indicating whether the method response parameter is required or not. # The method response header names must match the pattern of # `method.response.header.\{name\}`, where `name` is a valid and # unique header name. The response parameter names defined here are # available in the integration response to be mapped from an # integration response header expressed in # `integration.response.header.\{name\}`, a static value enclosed # within a pair of single quotes (e.g., `'application/json'`), or a # JSON expression from the back-end response payload in the form of # `integration.response.body.\{JSON-expression\}`, where # `JSON-expression` is a valid JSON expression without the `$` # prefix.) # @return [Hash] # # @!attribute [rw] response_models # Specifies the Model resources used for the response's content type. # Response models are represented as a key/value map, with a content # type as the key and a Model name as the value. # @return [Hash] # class PutMethodResponseRequest < Struct.new( :rest_api_id, :resource_id, :http_method, :status_code, :response_parameters, :response_models) SENSITIVE = [] include Aws::Structure end # A PUT request to update an existing API, with external API definitions # specified as the request body. # # @note When making an API call, you may pass PutRestApiRequest # data as a hash: # # { # rest_api_id: "String", # required # mode: "merge", # accepts merge, overwrite # fail_on_warnings: false, # parameters: { # "String" => "String", # }, # body: "data", # required # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] mode # The `mode` query parameter to specify the update mode. Valid values # are "merge" and "overwrite". By default, the update mode is # "merge". # @return [String] # # @!attribute [rw] fail_on_warnings # A query parameter to indicate whether to rollback the API update # (`true`) or not (`false`) when a warning is encountered. The default # value is `false`. # @return [Boolean] # # @!attribute [rw] parameters # Custom header parameters as part of the request. For example, to # exclude DocumentationParts from an imported API, set # `ignore=documentation` as a `parameters` value, as in the AWS CLI # command of `aws apigateway import-rest-api --parameters # ignore=documentation --body # 'file:///path/to/imported-api-body.json'`. # @return [Hash] # # @!attribute [rw] body # \[Required\] The PUT request body containing external API # definitions. Currently, only OpenAPI definition JSON/YAML files are # supported. The maximum size of the API definition file is 6MB. # @return [String] # class PutRestApiRequest < Struct.new( :rest_api_id, :mode, :fail_on_warnings, :parameters, :body) SENSITIVE = [] include Aws::Structure end # Quotas configured for a usage plan. # # @note When making an API call, you may pass QuotaSettings # data as a hash: # # { # limit: 1, # offset: 1, # period: "DAY", # accepts DAY, WEEK, MONTH # } # # @!attribute [rw] limit # The maximum number of requests that can be made in a given time # period. # @return [Integer] # # @!attribute [rw] offset # The day that a time period starts. For example, with a time period # of `WEEK`, an offset of `0` starts on Sunday, and an offset of `1` # starts on Monday. # @return [Integer] # # @!attribute [rw] period # The time period in which the limit applies. Valid values are # "DAY", "WEEK" or "MONTH". # @return [String] # class QuotaSettings < Struct.new( :limit, :offset, :period) SENSITIVE = [] include Aws::Structure end # A set of validation rules for incoming Method requests. # #
# In OpenAPI, a RequestValidator of an API is defined by the # [x-amazon-apigateway-request-validators.requestValidator][1] object. # It the referenced using the [x-amazon-apigateway-request-validator][2] # property. # #
# #
# [Enable Basic Request Validation in API Gateway][3] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-swagger-extensions.html#api-gateway-swagger-extensions-request-validators.requestValidator.html # [2]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-swagger-extensions.html#api-gateway-swagger-extensions-request-validator # [3]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-method-request-validation.html # # @!attribute [rw] id # The identifier of this RequestValidator. # @return [String] # # @!attribute [rw] name # The name of this RequestValidator # @return [String] # # @!attribute [rw] validate_request_body # A Boolean flag to indicate whether to validate a request body # according to the configured Model schema. # @return [Boolean] # # @!attribute [rw] validate_request_parameters # A Boolean flag to indicate whether to validate request parameters # (`true`) or not (`false`). # @return [Boolean] # class RequestValidator < Struct.new( :id, :name, :validate_request_body, :validate_request_parameters) SENSITIVE = [] include Aws::Structure end # A collection of RequestValidator resources of a given RestApi. # #
# In OpenAPI, the RequestValidators of an API is defined by the # [x-amazon-apigateway-request-validators][1] extension. # #
# #
# [Enable Basic Request Validation in API Gateway][2] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-swagger-extensions.html#api-gateway-swagger-extensions-request-validators.html # [2]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-method-request-validation.html # # @!attribute [rw] position # @return [String] # # @!attribute [rw] items # The current page of elements from this collection. # @return [Array] # class RequestValidators < Struct.new( :position, :items) SENSITIVE = [] include Aws::Structure end # Represents an API resource. # #
# [Create an API][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/how-to-create-api.html # # @!attribute [rw] id # The resource's identifier. # @return [String] # # @!attribute [rw] parent_id # The parent resource's identifier. # @return [String] # # @!attribute [rw] path_part # The last path segment for this resource. # @return [String] # # @!attribute [rw] path # The full path for this resource. # @return [String] # # @!attribute [rw] resource_methods # Gets an API resource's method of a given HTTP verb. # #
# The resource methods are a map of methods indexed by methods' HTTP # verbs enabled on the resource. This method map is included in the # `200 OK` response of the `GET # /restapis/\{restapi_id\}/resources/\{resource_id\}` or `GET # /restapis/\{restapi_id\}/resources/\{resource_id\}?embed=methods` # request. # # #### Example: Get the GET method of an API resource # # ##### Request # # GET /restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET HTTP/1.1 Content-Type: application/json Host: apigateway.us-east-1.amazonaws.com X-Amz-Date: 20170223T031827Z Authorization: AWS4-HMAC-SHA256 Credential=\{access_key_ID\}/20170223/us-east-1/apigateway/aws4_request, SignedHeaders=content-type;host;x-amz-date, Signature=\{sig4_hash\} # # ##### Response # # \{ "_links": \{ "curies": [ \{ "href": "https://docs.aws.amazon.com/apigateway/latest/developerguide/restapi-integration-\{rel\}.html", "name": "integration", "templated": true \}, \{ "href": "https://docs.aws.amazon.com/apigateway/latest/developerguide/restapi-integration-response-\{rel\}.html", "name": "integrationresponse", "templated": true \}, \{ "href": "https://docs.aws.amazon.com/apigateway/latest/developerguide/restapi-method-\{rel\}.html", "name": "method", "templated": true \}, \{ "href": "https://docs.aws.amazon.com/apigateway/latest/developerguide/restapi-method-response-\{rel\}.html", "name": "methodresponse", "templated": true \} ], "self": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET", "name": "GET", "title": "GET" \}, "integration:put": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration" \}, "method:delete": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET" \}, "method:integration": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration" \}, "method:responses": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/responses/200", "name": "200", "title": "200" \}, "method:update": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET" \}, "methodresponse:put": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/responses/\{status_code\}", "templated": true \} \}, "apiKeyRequired": false, "authorizationType": "NONE", "httpMethod": "GET", "_embedded": \{ "method:integration": \{ "_links": \{ "self": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration" \}, "integration:delete": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration" \}, "integration:responses": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration/responses/200", "name": "200", "title": "200" \}, "integration:update": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration" \}, "integrationresponse:put": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration/responses/\{status_code\}", "templated": true \} \}, "cacheKeyParameters": [], "cacheNamespace": "3kzxbg5sa2", "credentials": "arn:aws:iam::123456789012:role/apigAwsProxyRole", "httpMethod": "POST", "passthroughBehavior": "WHEN_NO_MATCH", "requestParameters": \{ "integration.request.header.Content-Type": "'application/x-amz-json-1.1'" \}, "requestTemplates": \{ "application/json": "\{\n\}" \}, "type": "AWS", "uri": "arn:aws:apigateway:us-east-1:kinesis:action/ListStreams", "_embedded": \{ "integration:responses": \{ "_links": \{ "self": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration/responses/200", "name": "200", "title": "200" \}, "integrationresponse:delete": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration/responses/200" \}, "integrationresponse:update": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/integration/responses/200" \} \}, "responseParameters": \{ "method.response.header.Content-Type": "'application/xml'" \}, "responseTemplates": \{ "application/json": "$util.urlDecode("%3CkinesisStreams%3E#foreach($stream in $input.path('$.StreamNames'))%3Cstream%3E%3Cname%3E$stream%3C/name%3E%3C/stream%3E#end%3C/kinesisStreams%3E")\n" \}, "statusCode": "200" \} \} \}, "method:responses": \{ "_links": \{ "self": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/responses/200", "name": "200", "title": "200" \}, "methodresponse:delete": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/responses/200" \}, "methodresponse:update": \{ "href": "/restapis/fugvjdxtri/resources/3kzxbg5sa2/methods/GET/responses/200" \} \}, "responseModels": \{ "application/json": "Empty" \}, "responseParameters": \{ "method.response.header.Content-Type": false \}, "statusCode": "200" \} \} \} # # If the `OPTIONS` is enabled on the resource, you can follow the # example here to get that method. Just replace the `GET` of the last # path segment in the request URL with `OPTIONS`. # #
# #
# @return [Hash] # class Resource < Struct.new( :id, :parent_id, :path_part, :path, :resource_methods) SENSITIVE = [] include Aws::Structure end # Represents a collection of Resource resources. # #
# [Create an API][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/how-to-create-api.html # # @!attribute [rw] position # @return [String] # # @!attribute [rw] items # The current page of elements from this collection. # @return [Array] # class Resources < Struct.new( :position, :items) SENSITIVE = [] include Aws::Structure end # Represents a REST API. # #
# [Create an API][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/how-to-create-api.html # # @!attribute [rw] id # The API's identifier. This identifier is unique across all of your # APIs in API Gateway. # @return [String] # # @!attribute [rw] name # The API's name. # @return [String] # # @!attribute [rw] description # The API's description. # @return [String] # # @!attribute [rw] created_date # The timestamp when the API was created. # @return [Time] # # @!attribute [rw] version # A version identifier for the API. # @return [String] # # @!attribute [rw] warnings # The warning messages reported when `failonwarnings` is turned on # during API import. # @return [Array] # # @!attribute [rw] binary_media_types # The list of binary media types supported by the RestApi. By default, # the RestApi supports only UTF-8-encoded text payloads. # @return [Array] # # @!attribute [rw] minimum_compression_size # A nullable integer that is used to enable compression (with # non-negative between 0 and 10485760 (10M) bytes, inclusive) or # disable compression (with a null value) on an API. When compression # is enabled, compression or decompression is not applied on the # payload if the payload size is smaller than this value. Setting it # to zero allows compression for any payload size. # @return [Integer] # # @!attribute [rw] api_key_source # The source of the API key for metering requests according to a usage # plan. Valid values are: * `HEADER` to read the API key from the # `X-API-Key` header of a # request. # * `AUTHORIZER` to read the API key from the `UsageIdentifierKey` # from a custom authorizer. # @return [String] # # @!attribute [rw] endpoint_configuration # The endpoint configuration of this RestApi showing the endpoint # types of the API. # @return [Types::EndpointConfiguration] # # @!attribute [rw] policy # A stringified JSON policy document that applies to this RestApi # regardless of the caller and Method configuration. # @return [String] # # @!attribute [rw] tags # The collection of tags. Each tag element is associated with a given # resource. # @return [Hash] # # @!attribute [rw] disable_execute_api_endpoint # Specifies whether clients can invoke your API by using the default # `execute-api` endpoint. By default, clients can invoke your API with # the default # https://\\\{api\_id\\}.execute-api.\\\{region\\}.amazonaws.com # endpoint. To require that clients use a custom domain name to invoke # your API, disable the default endpoint. # @return [Boolean] # class RestApi < Struct.new( :id, :name, :description, :created_date, :version, :warnings, :binary_media_types, :minimum_compression_size, :api_key_source, :endpoint_configuration, :policy, :tags, :disable_execute_api_endpoint) SENSITIVE = [] include Aws::Structure end # Contains references to your APIs and links that guide you in how to # interact with your collection. A collection offers a paginated view of # your APIs. # #
# [Create an API][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/how-to-create-api.html # # @!attribute [rw] position # @return [String] # # @!attribute [rw] items # The current page of elements from this collection. # @return [Array] # class RestApis < Struct.new( :position, :items) SENSITIVE = [] include Aws::Structure end # A configuration property of an SDK type. # # @!attribute [rw] name # The name of a an SdkType configuration property. # @return [String] # # @!attribute [rw] friendly_name # The user-friendly name of an SdkType configuration property. # @return [String] # # @!attribute [rw] description # The description of an SdkType configuration property. # @return [String] # # @!attribute [rw] required # A boolean flag of an SdkType configuration property to indicate if # the associated SDK configuration property is required (`true`) or # not (`false`). # @return [Boolean] # # @!attribute [rw] default_value # The default value of an SdkType configuration property. # @return [String] # class SdkConfigurationProperty < Struct.new( :name, :friendly_name, :description, :required, :default_value) SENSITIVE = [] include Aws::Structure end # The binary blob response to GetSdk, which contains the generated SDK. # # @!attribute [rw] content_type # The content-type header value in the HTTP response. # @return [String] # # @!attribute [rw] content_disposition # The content-disposition header value in the HTTP response. # @return [String] # # @!attribute [rw] body # The binary blob response to GetSdk, which contains the generated # SDK. # @return [String] # class SdkResponse < Struct.new( :content_type, :content_disposition, :body) SENSITIVE = [] include Aws::Structure end # A type of SDK that API Gateway can generate. # # @!attribute [rw] id # The identifier of an SdkType instance. # @return [String] # # @!attribute [rw] friendly_name # The user-friendly name of an SdkType instance. # @return [String] # # @!attribute [rw] description # The description of an SdkType. # @return [String] # # @!attribute [rw] configuration_properties # A list of configuration properties of an SdkType. # @return [Array] # class SdkType < Struct.new( :id, :friendly_name, :description, :configuration_properties) SENSITIVE = [] include Aws::Structure end # The collection of SdkType instances. # # @!attribute [rw] position # @return [String] # # @!attribute [rw] items # The current page of elements from this collection. # @return [Array] # class SdkTypes < Struct.new( :position, :items) SENSITIVE = [] include Aws::Structure end # The requested service is not available. For details see the # accompanying error message. Retry after the specified time period. # # @!attribute [rw] retry_after_seconds # @return [String] # # @!attribute [rw] message # @return [String] # class ServiceUnavailableException < Struct.new( :retry_after_seconds, :message) SENSITIVE = [] include Aws::Structure end # Represents a unique identifier for a version of a deployed RestApi # that is callable by users. # #
# [Deploy an API][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/how-to-deploy-api.html # # @!attribute [rw] deployment_id # The identifier of the Deployment that the stage points to. # @return [String] # # @!attribute [rw] client_certificate_id # The identifier of a client certificate for an API stage. # @return [String] # # @!attribute [rw] stage_name # The name of the stage is the first path segment in the Uniform # Resource Identifier (URI) of a call to API Gateway. Stage names can # only contain alphanumeric characters, hyphens, and underscores. # Maximum length is 128 characters. # @return [String] # # @!attribute [rw] description # The stage's description. # @return [String] # # @!attribute [rw] cache_cluster_enabled # Specifies whether a cache cluster is enabled for the stage. # @return [Boolean] # # @!attribute [rw] cache_cluster_size # The size of the cache cluster for the stage, if enabled. # @return [String] # # @!attribute [rw] cache_cluster_status # The status of the cache cluster for the stage, if enabled. # @return [String] # # @!attribute [rw] method_settings # A map that defines the method settings for a Stage resource. Keys # (designated as `/\{method_setting_key` below) are method paths # defined as `\{resource_path\}/\{http_method\}` for an individual # method override, or `/*/*` for overriding all methods in the # stage. # @return [Hash] # # @!attribute [rw] variables # A map that defines the stage variables for a Stage resource. # Variable names can have alphanumeric and underscore characters, and # the values must match `[A-Za-z0-9-._~:/?#&=,]+`. # @return [Hash] # # @!attribute [rw] documentation_version # The version of the associated API documentation. # @return [String] # # @!attribute [rw] access_log_settings # Settings for logging access in this stage. # @return [Types::AccessLogSettings] # # @!attribute [rw] canary_settings # Settings for the canary deployment in this stage. # @return [Types::CanarySettings] # # @!attribute [rw] tracing_enabled # Specifies whether active tracing with X-ray is enabled for the # Stage. # @return [Boolean] # # @!attribute [rw] web_acl_arn # The ARN of the WebAcl associated with the Stage. # @return [String] # # @!attribute [rw] tags # The collection of tags. Each tag element is associated with a given # resource. # @return [Hash] # # @!attribute [rw] created_date # The timestamp when the stage was created. # @return [Time] # # @!attribute [rw] last_updated_date # The timestamp when the stage last updated. # @return [Time] # class Stage < Struct.new( :deployment_id, :client_certificate_id, :stage_name, :description, :cache_cluster_enabled, :cache_cluster_size, :cache_cluster_status, :method_settings, :variables, :documentation_version, :access_log_settings, :canary_settings, :tracing_enabled, :web_acl_arn, :tags, :created_date, :last_updated_date) SENSITIVE = [] include Aws::Structure end # A reference to a unique stage identified in the format # `\{restApiId\}/\{stage\}`. # # @note When making an API call, you may pass StageKey # data as a hash: # # { # rest_api_id: "String", # stage_name: "String", # } # # @!attribute [rw] rest_api_id # The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] stage_name # The stage name associated with the stage key. # @return [String] # class StageKey < Struct.new( :rest_api_id, :stage_name) SENSITIVE = [] include Aws::Structure end # A list of Stage resources that are associated with the ApiKey # resource. # #
# [Deploying API in Stages][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/stages.html # # @!attribute [rw] item # The current page of elements from this collection. # @return [Array] # class Stages < Struct.new( :item) SENSITIVE = [] include Aws::Structure end # Adds or updates a tag on a given resource. # # @note When making an API call, you may pass TagResourceRequest # data as a hash: # # { # resource_arn: "String", # required # tags: { # required # "String" => "String", # }, # } # # @!attribute [rw] resource_arn # \[Required\] The ARN of a resource that can be tagged. # @return [String] # # @!attribute [rw] tags # \[Required\] The key-value map of strings. The valid character set # is \[a-zA-Z+-=.\_:/\]. The tag key can be up to 128 characters and # must not start with `aws:`. The tag value can be up to 256 # characters. # @return [Hash] # class TagResourceRequest < Struct.new( :resource_arn, :tags) SENSITIVE = [] include Aws::Structure end # The collection of tags. Each tag element is associated with a given # resource. # # @!attribute [rw] tags # The collection of tags. Each tag element is associated with a given # resource. # @return [Hash] # class Tags < Struct.new( :tags) SENSITIVE = [] include Aws::Structure end # Represents a mapping template used to transform a payload. # #
# [Mapping Templates][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/models-mappings.html#models-mappings-mappings # # @!attribute [rw] value # The Apache [Velocity Template Language (VTL)][1] template content # used for the template resource. # # # # [1]: https://velocity.apache.org/engine/devel/vtl-reference.html # @return [String] # class Template < Struct.new( :value) SENSITIVE = [] include Aws::Structure end # Make a request to simulate the execution of an Authorizer. # # @note When making an API call, you may pass TestInvokeAuthorizerRequest # data as a hash: # # { # rest_api_id: "String", # required # authorizer_id: "String", # required # headers: { # "String" => "String", # }, # multi_value_headers: { # "String" => ["String"], # }, # path_with_query_string: "String", # body: "String", # stage_variables: { # "String" => "String", # }, # additional_context: { # "String" => "String", # }, # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] authorizer_id # \[Required\] Specifies a test invoke authorizer request's # Authorizer ID. # @return [String] # # @!attribute [rw] headers # \[Required\] A key-value map of headers to simulate an incoming # invocation request. This is where the incoming authorization token, # or identity source, should be specified. # @return [Hash] # # @!attribute [rw] multi_value_headers # \[Optional\] The headers as a map from string to list of values to # simulate an incoming invocation request. This is where the incoming # authorization token, or identity source, may be specified. # @return [Hash>] # # @!attribute [rw] path_with_query_string # \[Optional\] The URI path, including query string, of the simulated # invocation request. Use this to specify path parameters and query # string parameters. # @return [String] # # @!attribute [rw] body # \[Optional\] The simulated request body of an incoming invocation # request. # @return [String] # # @!attribute [rw] stage_variables # A key-value map of stage variables to simulate an invocation on a # deployed Stage. # @return [Hash] # # @!attribute [rw] additional_context # \[Optional\] A key-value map of additional context variables. # @return [Hash] # class TestInvokeAuthorizerRequest < Struct.new( :rest_api_id, :authorizer_id, :headers, :multi_value_headers, :path_with_query_string, :body, :stage_variables, :additional_context) SENSITIVE = [] include Aws::Structure end # Represents the response of the test invoke request for a custom # Authorizer # # @!attribute [rw] client_status # The HTTP status code that the client would have received. Value is 0 # if the authorizer succeeded. # @return [Integer] # # @!attribute [rw] log # The API Gateway execution log for the test authorizer request. # @return [String] # # @!attribute [rw] latency # The execution latency of the test authorizer request. # @return [Integer] # # @!attribute [rw] principal_id # The principal identity returned by the Authorizer # @return [String] # # @!attribute [rw] policy # The JSON policy document returned by the Authorizer # @return [String] # # @!attribute [rw] authorization # @return [Hash>] # # @!attribute [rw] claims # The [open identity claims][1], with any supported custom attributes, # returned from the Cognito Your User Pool configured for the API. # # # # [1]: https://openid.net/specs/openid-connect-core-1_0.html#StandardClaims # @return [Hash] # class TestInvokeAuthorizerResponse < Struct.new( :client_status, :log, :latency, :principal_id, :policy, :authorization, :claims) SENSITIVE = [] include Aws::Structure end # Make a request to simulate the execution of a Method. # # @note When making an API call, you may pass TestInvokeMethodRequest # data as a hash: # # { # rest_api_id: "String", # required # resource_id: "String", # required # http_method: "String", # required # path_with_query_string: "String", # body: "String", # headers: { # "String" => "String", # }, # multi_value_headers: { # "String" => ["String"], # }, # client_certificate_id: "String", # stage_variables: { # "String" => "String", # }, # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] resource_id # \[Required\] Specifies a test invoke method request's resource ID. # @return [String] # # @!attribute [rw] http_method # \[Required\] Specifies a test invoke method request's HTTP method. # @return [String] # # @!attribute [rw] path_with_query_string # The URI path, including query string, of the simulated invocation # request. Use this to specify path parameters and query string # parameters. # @return [String] # # @!attribute [rw] body # The simulated request body of an incoming invocation request. # @return [String] # # @!attribute [rw] headers # A key-value map of headers to simulate an incoming invocation # request. # @return [Hash] # # @!attribute [rw] multi_value_headers # The headers as a map from string to list of values to simulate an # incoming invocation request. # @return [Hash>] # # @!attribute [rw] client_certificate_id # A ClientCertificate identifier to use in the test invocation. API # Gateway will use the certificate when making the HTTPS request to # the defined back-end endpoint. # @return [String] # # @!attribute [rw] stage_variables # A key-value map of stage variables to simulate an invocation on a # deployed Stage. # @return [Hash] # class TestInvokeMethodRequest < Struct.new( :rest_api_id, :resource_id, :http_method, :path_with_query_string, :body, :headers, :multi_value_headers, :client_certificate_id, :stage_variables) SENSITIVE = [] include Aws::Structure end # Represents the response of the test invoke request in the HTTP method. # #
# [Test API using the API Gateway console][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/how-to-test-method.html#how-to-test-method-console # # @!attribute [rw] status # The HTTP status code. # @return [Integer] # # @!attribute [rw] body # The body of the HTTP response. # @return [String] # # @!attribute [rw] headers # The headers of the HTTP response. # @return [Hash] # # @!attribute [rw] multi_value_headers # The headers of the HTTP response as a map from string to list of # values. # @return [Hash>] # # @!attribute [rw] log # The API Gateway execution log for the test invoke request. # @return [String] # # @!attribute [rw] latency # The execution latency of the test invoke request. # @return [Integer] # class TestInvokeMethodResponse < Struct.new( :status, :body, :headers, :multi_value_headers, :log, :latency) SENSITIVE = [] include Aws::Structure end # The API request rate limits. # # @note When making an API call, you may pass ThrottleSettings # data as a hash: # # { # burst_limit: 1, # rate_limit: 1.0, # } # # @!attribute [rw] burst_limit # The API request burst limit, the maximum rate limit over a time # ranging from one to a few seconds, depending upon whether the # underlying token bucket is at its full capacity. # @return [Integer] # # @!attribute [rw] rate_limit # The API request steady-state rate limit. # @return [Float] # class ThrottleSettings < Struct.new( :burst_limit, :rate_limit) SENSITIVE = [] include Aws::Structure end # @note When making an API call, you may pass TlsConfig # data as a hash: # # { # insecure_skip_verification: false, # } # # @!attribute [rw] insecure_skip_verification # Specifies whether or not API Gateway skips verification that the # certificate for an integration endpoint is issued by a [supported # certificate authority][1]. This isn’t recommended, but it enables # you to use certificates that are signed by private certificate # authorities, or certificates that are self-signed. If enabled, API # Gateway still performs basic certificate validation, which includes # checking the certificate's expiration date, hostname, and presence # of a root certificate authority. Supported only for `HTTP` and # `HTTP_PROXY` integrations. # # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-supported-certificate-authorities-for-http-endpoints.html # @return [Boolean] # class TlsConfig < Struct.new( :insecure_skip_verification) SENSITIVE = [] include Aws::Structure end # The request has reached its throttling limit. Retry after the # specified time period. # # @!attribute [rw] retry_after_seconds # @return [String] # # @!attribute [rw] message # @return [String] # class TooManyRequestsException < Struct.new( :retry_after_seconds, :message) SENSITIVE = [] include Aws::Structure end # The request is denied because the caller has insufficient permissions. # # @!attribute [rw] message # @return [String] # class UnauthorizedException < Struct.new( :message) SENSITIVE = [] include Aws::Structure end # Removes a tag from a given resource. # # @note When making an API call, you may pass UntagResourceRequest # data as a hash: # # { # resource_arn: "String", # required # tag_keys: ["String"], # required # } # # @!attribute [rw] resource_arn # \[Required\] The ARN of a resource that can be tagged. # @return [String] # # @!attribute [rw] tag_keys # \[Required\] The Tag keys to delete. # @return [Array] # class UntagResourceRequest < Struct.new( :resource_arn, :tag_keys) SENSITIVE = [] include Aws::Structure end # Requests API Gateway to change information about the current Account # resource. # # @note When making an API call, you may pass UpdateAccountRequest # data as a hash: # # { # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateAccountRequest < Struct.new( :patch_operations) SENSITIVE = [] include Aws::Structure end # A request to change information about an ApiKey resource. # # @note When making an API call, you may pass UpdateApiKeyRequest # data as a hash: # # { # api_key: "String", # required # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] api_key # \[Required\] The identifier of the ApiKey resource to be updated. # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateApiKeyRequest < Struct.new( :api_key, :patch_operations) SENSITIVE = [] include Aws::Structure end # Request to update an existing Authorizer resource. # # @note When making an API call, you may pass UpdateAuthorizerRequest # data as a hash: # # { # rest_api_id: "String", # required # authorizer_id: "String", # required # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] authorizer_id # \[Required\] The identifier of the Authorizer resource. # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateAuthorizerRequest < Struct.new( :rest_api_id, :authorizer_id, :patch_operations) SENSITIVE = [] include Aws::Structure end # A request to change information about the BasePathMapping resource. # # @note When making an API call, you may pass UpdateBasePathMappingRequest # data as a hash: # # { # domain_name: "String", # required # base_path: "String", # required # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] domain_name # \[Required\] The domain name of the BasePathMapping resource to # change. # @return [String] # # @!attribute [rw] base_path # \[Required\] The base path of the BasePathMapping resource to # change. # # To specify an empty base path, set this parameter to `'(none)'`. # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateBasePathMappingRequest < Struct.new( :domain_name, :base_path, :patch_operations) SENSITIVE = [] include Aws::Structure end # A request to change information about an ClientCertificate resource. # # @note When making an API call, you may pass UpdateClientCertificateRequest # data as a hash: # # { # client_certificate_id: "String", # required # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] client_certificate_id # \[Required\] The identifier of the ClientCertificate resource to be # updated. # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateClientCertificateRequest < Struct.new( :client_certificate_id, :patch_operations) SENSITIVE = [] include Aws::Structure end # Requests API Gateway to change information about a Deployment # resource. # # @note When making an API call, you may pass UpdateDeploymentRequest # data as a hash: # # { # rest_api_id: "String", # required # deployment_id: "String", # required # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] deployment_id # The replacement identifier for the Deployment resource to change # information about. # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateDeploymentRequest < Struct.new( :rest_api_id, :deployment_id, :patch_operations) SENSITIVE = [] include Aws::Structure end # Updates an existing documentation part of a given API. # # @note When making an API call, you may pass UpdateDocumentationPartRequest # data as a hash: # # { # rest_api_id: "String", # required # documentation_part_id: "String", # required # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] documentation_part_id # \[Required\] The identifier of the to-be-updated documentation part. # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateDocumentationPartRequest < Struct.new( :rest_api_id, :documentation_part_id, :patch_operations) SENSITIVE = [] include Aws::Structure end # Updates an existing documentation version of an API. # # @note When making an API call, you may pass UpdateDocumentationVersionRequest # data as a hash: # # { # rest_api_id: "String", # required # documentation_version: "String", # required # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi.. # @return [String] # # @!attribute [rw] documentation_version # \[Required\] The version identifier of the to-be-updated # documentation version. # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateDocumentationVersionRequest < Struct.new( :rest_api_id, :documentation_version, :patch_operations) SENSITIVE = [] include Aws::Structure end # A request to change information about the DomainName resource. # # @note When making an API call, you may pass UpdateDomainNameRequest # data as a hash: # # { # domain_name: "String", # required # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] domain_name # \[Required\] The name of the DomainName resource to be changed. # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateDomainNameRequest < Struct.new( :domain_name, :patch_operations) SENSITIVE = [] include Aws::Structure end # Updates a GatewayResponse of a specified response type on the given # RestApi. # # @note When making an API call, you may pass UpdateGatewayResponseRequest # data as a hash: # # { # rest_api_id: "String", # required # response_type: "DEFAULT_4XX", # required, accepts DEFAULT_4XX, DEFAULT_5XX, RESOURCE_NOT_FOUND, UNAUTHORIZED, INVALID_API_KEY, ACCESS_DENIED, AUTHORIZER_FAILURE, AUTHORIZER_CONFIGURATION_ERROR, INVALID_SIGNATURE, EXPIRED_TOKEN, MISSING_AUTHENTICATION_TOKEN, INTEGRATION_FAILURE, INTEGRATION_TIMEOUT, API_CONFIGURATION_ERROR, UNSUPPORTED_MEDIA_TYPE, BAD_REQUEST_PARAMETERS, BAD_REQUEST_BODY, REQUEST_TOO_LARGE, THROTTLED, QUOTA_EXCEEDED # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] response_type # \[Required\] The response type of the associated GatewayResponse. # Valid values # are * ACCESS\_DENIED # * API\_CONFIGURATION\_ERROR # * AUTHORIZER\_FAILURE # * AUTHORIZER\_CONFIGURATION\_ERROR # * BAD\_REQUEST\_PARAMETERS # * BAD\_REQUEST\_BODY # * DEFAULT\_4XX # * DEFAULT\_5XX # * EXPIRED\_TOKEN # * INVALID\_SIGNATURE # * INTEGRATION\_FAILURE # * INTEGRATION\_TIMEOUT # * INVALID\_API\_KEY # * MISSING\_AUTHENTICATION\_TOKEN # * QUOTA\_EXCEEDED # * REQUEST\_TOO\_LARGE # * RESOURCE\_NOT\_FOUND # * THROTTLED # * UNAUTHORIZED # * UNSUPPORTED\_MEDIA\_TYPE # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateGatewayResponseRequest < Struct.new( :rest_api_id, :response_type, :patch_operations) SENSITIVE = [] include Aws::Structure end # Represents an update integration request. # # @note When making an API call, you may pass UpdateIntegrationRequest # data as a hash: # # { # rest_api_id: "String", # required # resource_id: "String", # required # http_method: "String", # required # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] resource_id # \[Required\] Represents an update integration request's resource # identifier. # @return [String] # # @!attribute [rw] http_method # \[Required\] Represents an update integration request's HTTP # method. # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateIntegrationRequest < Struct.new( :rest_api_id, :resource_id, :http_method, :patch_operations) SENSITIVE = [] include Aws::Structure end # Represents an update integration response request. # # @note When making an API call, you may pass UpdateIntegrationResponseRequest # data as a hash: # # { # rest_api_id: "String", # required # resource_id: "String", # required # http_method: "String", # required # status_code: "StatusCode", # required # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] resource_id # \[Required\] Specifies an update integration response request's # resource identifier. # @return [String] # # @!attribute [rw] http_method # \[Required\] Specifies an update integration response request's # HTTP method. # @return [String] # # @!attribute [rw] status_code # \[Required\] Specifies an update integration response request's # status code. # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateIntegrationResponseRequest < Struct.new( :rest_api_id, :resource_id, :http_method, :status_code, :patch_operations) SENSITIVE = [] include Aws::Structure end # Request to update an existing Method resource. # # @note When making an API call, you may pass UpdateMethodRequest # data as a hash: # # { # rest_api_id: "String", # required # resource_id: "String", # required # http_method: "String", # required # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] resource_id # \[Required\] The Resource identifier for the Method resource. # @return [String] # # @!attribute [rw] http_method # \[Required\] The HTTP verb of the Method resource. # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateMethodRequest < Struct.new( :rest_api_id, :resource_id, :http_method, :patch_operations) SENSITIVE = [] include Aws::Structure end # A request to update an existing MethodResponse resource. # # @note When making an API call, you may pass UpdateMethodResponseRequest # data as a hash: # # { # rest_api_id: "String", # required # resource_id: "String", # required # http_method: "String", # required # status_code: "StatusCode", # required # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] resource_id # \[Required\] The Resource identifier for the MethodResponse # resource. # @return [String] # # @!attribute [rw] http_method # \[Required\] The HTTP verb of the Method resource. # @return [String] # # @!attribute [rw] status_code # \[Required\] The status code for the MethodResponse resource. # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateMethodResponseRequest < Struct.new( :rest_api_id, :resource_id, :http_method, :status_code, :patch_operations) SENSITIVE = [] include Aws::Structure end # Request to update an existing model in an existing RestApi resource. # # @note When making an API call, you may pass UpdateModelRequest # data as a hash: # # { # rest_api_id: "String", # required # model_name: "String", # required # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] model_name # \[Required\] The name of the model to update. # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateModelRequest < Struct.new( :rest_api_id, :model_name, :patch_operations) SENSITIVE = [] include Aws::Structure end # Updates a RequestValidator of a given RestApi. # # @note When making an API call, you may pass UpdateRequestValidatorRequest # data as a hash: # # { # rest_api_id: "String", # required # request_validator_id: "String", # required # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] request_validator_id # \[Required\] The identifier of RequestValidator to be updated. # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateRequestValidatorRequest < Struct.new( :rest_api_id, :request_validator_id, :patch_operations) SENSITIVE = [] include Aws::Structure end # Request to change information about a Resource resource. # # @note When making an API call, you may pass UpdateResourceRequest # data as a hash: # # { # rest_api_id: "String", # required # resource_id: "String", # required # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] resource_id # \[Required\] The identifier of the Resource resource. # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateResourceRequest < Struct.new( :rest_api_id, :resource_id, :patch_operations) SENSITIVE = [] include Aws::Structure end # Request to update an existing RestApi resource in your collection. # # @note When making an API call, you may pass UpdateRestApiRequest # data as a hash: # # { # rest_api_id: "String", # required # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateRestApiRequest < Struct.new( :rest_api_id, :patch_operations) SENSITIVE = [] include Aws::Structure end # Requests API Gateway to change information about a Stage resource. # # @note When making an API call, you may pass UpdateStageRequest # data as a hash: # # { # rest_api_id: "String", # required # stage_name: "String", # required # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] rest_api_id # \[Required\] The string identifier of the associated RestApi. # @return [String] # # @!attribute [rw] stage_name # \[Required\] The name of the Stage resource to change information # about. # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateStageRequest < Struct.new( :rest_api_id, :stage_name, :patch_operations) SENSITIVE = [] include Aws::Structure end # The PATCH request to update a usage plan of a given plan Id. # # @note When making an API call, you may pass UpdateUsagePlanRequest # data as a hash: # # { # usage_plan_id: "String", # required # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] usage_plan_id # \[Required\] The Id of the to-be-updated usage plan. # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateUsagePlanRequest < Struct.new( :usage_plan_id, :patch_operations) SENSITIVE = [] include Aws::Structure end # The PATCH request to grant a temporary extension to the remaining # quota of a usage plan associated with a specified API key. # # @note When making an API call, you may pass UpdateUsageRequest # data as a hash: # # { # usage_plan_id: "String", # required # key_id: "String", # required # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] usage_plan_id # \[Required\] The Id of the usage plan associated with the usage # data. # @return [String] # # @!attribute [rw] key_id # \[Required\] The identifier of the API key associated with the usage # plan in which a temporary extension is granted to the remaining # quota. # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateUsageRequest < Struct.new( :usage_plan_id, :key_id, :patch_operations) SENSITIVE = [] include Aws::Structure end # Updates an existing VpcLink of a specified identifier. # # @note When making an API call, you may pass UpdateVpcLinkRequest # data as a hash: # # { # vpc_link_id: "String", # required # patch_operations: [ # { # op: "add", # accepts add, remove, replace, move, copy, test # path: "String", # value: "String", # from: "String", # }, # ], # } # # @!attribute [rw] vpc_link_id # \[Required\] The identifier of the VpcLink. It is used in an # Integration to reference this VpcLink. # @return [String] # # @!attribute [rw] patch_operations # A list of update operations to be applied to the specified resource # and in the order specified in this list. # @return [Array] # class UpdateVpcLinkRequest < Struct.new( :vpc_link_id, :patch_operations) SENSITIVE = [] include Aws::Structure end # Represents the usage data of a usage plan. # #
# #
# [Create and Use Usage Plans][1], [Manage Usage in a Usage Plan][2] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-api-usage-plans.html # [2]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-create-usage-plans-with-console.html#api-gateway-usage-plan-manage-usage # # @!attribute [rw] usage_plan_id # The plan Id associated with this usage data. # @return [String] # # @!attribute [rw] start_date # The starting date of the usage data. # @return [String] # # @!attribute [rw] end_date # The ending date of the usage data. # @return [String] # # @!attribute [rw] position # @return [String] # # @!attribute [rw] items # The usage data, as daily logs of used and remaining quotas, over the # specified time interval indexed over the API keys in a usage plan. # For example, `\{..., "values" : \{ "\{api_key\}" : [ [0, 100], [10, # 90], [100, 10]]\}`, where `\{api_key\}` stands for an API key value # and the daily log entry is of the format `[used quota, remaining # quota]`. # @return [Hash>>] # class Usage < Struct.new( :usage_plan_id, :start_date, :end_date, :position, :items) SENSITIVE = [] include Aws::Structure end # Represents a usage plan than can specify who can assess associated API # stages with specified request limits and quotas. # #
# In a usage plan, you associate an API by specifying the API's Id and # a stage name of the specified API. You add plan customers by adding # API keys to the plan. # #
# #
# [Create and Use Usage Plans][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-api-usage-plans.html # # @!attribute [rw] id # The identifier of a UsagePlan resource. # @return [String] # # @!attribute [rw] name # The name of a usage plan. # @return [String] # # @!attribute [rw] description # The description of a usage plan. # @return [String] # # @!attribute [rw] api_stages # The associated API stages of a usage plan. # @return [Array] # # @!attribute [rw] throttle # The request throttle limits of a usage plan. # @return [Types::ThrottleSettings] # # @!attribute [rw] quota # The maximum number of permitted requests per a given unit time # interval. # @return [Types::QuotaSettings] # # @!attribute [rw] product_code # The AWS Markeplace product identifier to associate with the usage # plan as a SaaS product on AWS Marketplace. # @return [String] # # @!attribute [rw] tags # The collection of tags. Each tag element is associated with a given # resource. # @return [Hash] # class UsagePlan < Struct.new( :id, :name, :description, :api_stages, :throttle, :quota, :product_code, :tags) SENSITIVE = [] include Aws::Structure end # Represents a usage plan key to identify a plan customer. # #
# To associate an API stage with a selected API key in a usage plan, you # must create a UsagePlanKey resource to represent the selected ApiKey. # #
# # "
# [Create and Use Usage Plans][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-api-usage-plans.html # # @!attribute [rw] id # The Id of a usage plan key. # @return [String] # # @!attribute [rw] type # The type of a usage plan key. Currently, the valid key type is # `API_KEY`. # @return [String] # # @!attribute [rw] value # The value of a usage plan key. # @return [String] # # @!attribute [rw] name # The name of a usage plan key. # @return [String] # class UsagePlanKey < Struct.new( :id, :type, :value, :name) SENSITIVE = [] include Aws::Structure end # Represents the collection of usage plan keys added to usage plans for # the associated API keys and, possibly, other types of keys. # #
# [Create and Use Usage Plans][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-api-usage-plans.html # # @!attribute [rw] position # @return [String] # # @!attribute [rw] items # The current page of elements from this collection. # @return [Array] # class UsagePlanKeys < Struct.new( :position, :items) SENSITIVE = [] include Aws::Structure end # Represents a collection of usage plans for an AWS account. # #
# [Create and Use Usage Plans][1] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/api-gateway-api-usage-plans.html # # @!attribute [rw] position # @return [String] # # @!attribute [rw] items # The current page of elements from this collection. # @return [Array] # class UsagePlans < Struct.new( :position, :items) SENSITIVE = [] include Aws::Structure end # An API Gateway VPC link for a RestApi to access resources in an Amazon # Virtual Private Cloud (VPC). # #
# To enable access to a resource in an Amazon Virtual Private Cloud # through Amazon API Gateway, you, as an API developer, create a VpcLink # resource targeted for one or more network load balancers of the VPC # and then integrate an API method with a private integration that uses # the VpcLink. The private integration has an integration type of `HTTP` # or `HTTP_PROXY` and has a connection type of `VPC_LINK`. The # integration uses the `connectionId` property to identify the VpcLink # used. # #
# # @!attribute [rw] id # The identifier of the VpcLink. It is used in an Integration to # reference this VpcLink. # @return [String] # # @!attribute [rw] name # The name used to label and identify the VPC link. # @return [String] # # @!attribute [rw] description # The description of the VPC link. # @return [String] # # @!attribute [rw] target_arns # The ARN of the network load balancer of the VPC targeted by the VPC # link. The network load balancer must be owned by the same AWS # account of the API owner. # @return [Array] # # @!attribute [rw] status # The status of the VPC link. The valid values are `AVAILABLE`, # `PENDING`, `DELETING`, or `FAILED`. Deploying an API will wait if # the status is `PENDING` and will fail if the status is `DELETING`. # @return [String] # # @!attribute [rw] status_message # A description about the VPC link status. # @return [String] # # @!attribute [rw] tags # The collection of tags. Each tag element is associated with a given # resource. # @return [Hash] # class VpcLink < Struct.new( :id, :name, :description, :target_arns, :status, :status_message, :tags) SENSITIVE = [] include Aws::Structure end # The collection of VPC links under the caller's account in a region. # #
# [Getting Started with Private Integrations][1], [Set up Private # Integrations][2] #
# # # # [1]: https://docs.aws.amazon.com/apigateway/latest/developerguide/getting-started-with-private-integration.html # [2]: https://docs.aws.amazon.com/apigateway/latest/developerguide/set-up-private-integration.html # # @!attribute [rw] position # @return [String] # # @!attribute [rw] items # The current page of elements from this collection. # @return [Array] # class VpcLinks < Struct.new( :position, :items) SENSITIVE = [] include Aws::Structure end end end