aws-sdk-core 3.189.0 → 3.199.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (119) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +183 -0
  3. data/VERSION +1 -1
  4. data/lib/aws-sdk-core/binary/decode_handler.rb +3 -9
  5. data/lib/aws-sdk-core/binary/encode_handler.rb +1 -1
  6. data/lib/aws-sdk-core/binary/event_builder.rb +34 -37
  7. data/lib/aws-sdk-core/binary/event_stream_decoder.rb +1 -0
  8. data/lib/aws-sdk-core/binary/event_stream_encoder.rb +4 -3
  9. data/lib/aws-sdk-core/cbor/cbor_engine.rb +19 -0
  10. data/lib/aws-sdk-core/cbor/decoder.rb +310 -0
  11. data/lib/aws-sdk-core/cbor/encoder.rb +243 -0
  12. data/lib/aws-sdk-core/cbor.rb +106 -0
  13. data/lib/aws-sdk-core/client_stubs.rb +18 -14
  14. data/lib/aws-sdk-core/credential_provider.rb +1 -1
  15. data/lib/aws-sdk-core/ec2_metadata.rb +1 -1
  16. data/lib/aws-sdk-core/ecs_credentials.rb +2 -1
  17. data/lib/aws-sdk-core/endpoints/matchers.rb +5 -1
  18. data/lib/aws-sdk-core/error_handler.rb +41 -0
  19. data/lib/aws-sdk-core/errors.rb +2 -2
  20. data/lib/aws-sdk-core/event_emitter.rb +0 -16
  21. data/lib/aws-sdk-core/instance_profile_credentials.rb +3 -2
  22. data/lib/aws-sdk-core/json/builder.rb +8 -1
  23. data/lib/aws-sdk-core/json/error_handler.rb +15 -10
  24. data/lib/aws-sdk-core/json/handler.rb +5 -6
  25. data/lib/aws-sdk-core/json/json_engine.rb +3 -1
  26. data/lib/aws-sdk-core/json/oj_engine.rb +7 -1
  27. data/lib/aws-sdk-core/json/parser.rb +6 -1
  28. data/lib/aws-sdk-core/json.rb +43 -14
  29. data/lib/aws-sdk-core/lru_cache.rb +75 -0
  30. data/lib/aws-sdk-core/pageable_response.rb +1 -1
  31. data/lib/aws-sdk-core/param_validator.rb +7 -2
  32. data/lib/aws-sdk-core/plugins/client_metrics_plugin.rb +1 -0
  33. data/lib/aws-sdk-core/plugins/client_metrics_send_plugin.rb +14 -2
  34. data/lib/aws-sdk-core/plugins/credentials_configuration.rb +2 -0
  35. data/lib/aws-sdk-core/plugins/global_configuration.rb +8 -9
  36. data/lib/aws-sdk-core/plugins/invocation_id.rb +1 -11
  37. data/lib/aws-sdk-core/plugins/logging.rb +2 -0
  38. data/lib/aws-sdk-core/plugins/protocols/api_gateway.rb +3 -1
  39. data/lib/aws-sdk-core/plugins/protocols/ec2.rb +2 -24
  40. data/lib/aws-sdk-core/plugins/protocols/json_rpc.rb +6 -8
  41. data/lib/aws-sdk-core/plugins/protocols/query.rb +4 -2
  42. data/lib/aws-sdk-core/plugins/protocols/rest_json.rb +3 -15
  43. data/lib/aws-sdk-core/plugins/protocols/rest_xml.rb +3 -0
  44. data/lib/aws-sdk-core/plugins/protocols/rpc_v2.rb +17 -0
  45. data/lib/aws-sdk-core/plugins/request_compression.rb +11 -2
  46. data/lib/aws-sdk-core/plugins/retry_errors.rb +12 -3
  47. data/lib/aws-sdk-core/plugins/sign.rb +8 -3
  48. data/lib/aws-sdk-core/plugins/stub_responses.rb +1 -0
  49. data/lib/aws-sdk-core/plugins/user_agent.rb +61 -26
  50. data/lib/aws-sdk-core/process_credentials.rb +45 -27
  51. data/lib/aws-sdk-core/query/ec2_handler.rb +27 -0
  52. data/lib/aws-sdk-core/query/ec2_param_builder.rb +5 -7
  53. data/lib/aws-sdk-core/query/handler.rb +4 -4
  54. data/lib/aws-sdk-core/query/param_builder.rb +2 -2
  55. data/lib/aws-sdk-core/query.rb +2 -1
  56. data/lib/aws-sdk-core/rest/content_type_handler.rb +60 -0
  57. data/lib/aws-sdk-core/rest/handler.rb +3 -4
  58. data/lib/aws-sdk-core/rest/request/body.rb +32 -5
  59. data/lib/aws-sdk-core/rest/request/endpoint.rb +24 -4
  60. data/lib/aws-sdk-core/rest/request/headers.rb +15 -7
  61. data/lib/aws-sdk-core/rest/request/querystring_builder.rb +23 -11
  62. data/lib/aws-sdk-core/rest/response/body.rb +15 -1
  63. data/lib/aws-sdk-core/rest/response/header_list_parser.rb +79 -0
  64. data/lib/aws-sdk-core/rest/response/headers.rb +8 -3
  65. data/lib/aws-sdk-core/rest.rb +1 -0
  66. data/lib/aws-sdk-core/rpc_v2/builder.rb +62 -0
  67. data/lib/aws-sdk-core/rpc_v2/content_type_handler.rb +45 -0
  68. data/lib/aws-sdk-core/rpc_v2/error_handler.rb +84 -0
  69. data/lib/aws-sdk-core/rpc_v2/handler.rb +74 -0
  70. data/lib/aws-sdk-core/rpc_v2/parser.rb +90 -0
  71. data/lib/aws-sdk-core/rpc_v2.rb +6 -0
  72. data/lib/aws-sdk-core/stubbing/protocols/rpc_v2.rb +41 -0
  73. data/lib/aws-sdk-core/util.rb +39 -0
  74. data/lib/aws-sdk-core/waiters/poller.rb +2 -2
  75. data/lib/aws-sdk-core/xml/builder.rb +17 -9
  76. data/lib/aws-sdk-core/xml/error_handler.rb +32 -42
  77. data/lib/aws-sdk-core/xml/parser/frame.rb +4 -20
  78. data/lib/aws-sdk-core/xml/parser/stack.rb +2 -0
  79. data/lib/aws-sdk-core/xml/parser.rb +2 -6
  80. data/lib/aws-sdk-core.rb +7 -2
  81. data/lib/aws-sdk-sso/client.rb +77 -49
  82. data/lib/aws-sdk-sso/plugins/endpoints.rb +1 -0
  83. data/lib/aws-sdk-sso.rb +1 -1
  84. data/lib/aws-sdk-ssooidc/client.rb +127 -51
  85. data/lib/aws-sdk-ssooidc/client_api.rb +22 -0
  86. data/lib/aws-sdk-ssooidc/errors.rb +21 -0
  87. data/lib/aws-sdk-ssooidc/plugins/endpoints.rb +1 -0
  88. data/lib/aws-sdk-ssooidc/types.rb +77 -9
  89. data/lib/aws-sdk-ssooidc.rb +1 -1
  90. data/lib/aws-sdk-sts/client.rb +78 -50
  91. data/lib/aws-sdk-sts/client_api.rb +8 -8
  92. data/lib/aws-sdk-sts/plugins/endpoints.rb +1 -0
  93. data/lib/aws-sdk-sts/types.rb +1 -1
  94. data/lib/aws-sdk-sts.rb +1 -1
  95. data/lib/seahorse/client/async_base.rb +1 -1
  96. data/lib/seahorse/client/async_response.rb +19 -0
  97. data/lib/seahorse/client/base.rb +18 -7
  98. data/lib/seahorse/client/h2/handler.rb +1 -0
  99. data/lib/seahorse/client/handler.rb +1 -1
  100. data/lib/seahorse/client/net_http/connection_pool.rb +3 -9
  101. data/lib/seahorse/client/plugin.rb +9 -0
  102. data/lib/seahorse/client/plugins/endpoint.rb +0 -1
  103. data/lib/seahorse/client/plugins/net_http.rb +48 -16
  104. data/lib/seahorse/model/shapes.rb +2 -2
  105. data/sig/aws-sdk-core/client_stubs.rbs +10 -0
  106. data/sig/aws-sdk-core/errors.rbs +22 -0
  107. data/sig/aws-sdk-core/resources/collection.rbs +21 -0
  108. data/sig/aws-sdk-core/structure.rbs +4 -0
  109. data/sig/aws-sdk-core/waiters/errors.rbs +20 -0
  110. data/sig/aws-sdk-core.rbs +7 -0
  111. data/sig/seahorse/client/base.rbs +25 -0
  112. data/sig/seahorse/client/handler_builder.rbs +16 -0
  113. data/sig/seahorse/client/response.rbs +61 -0
  114. metadata +38 -12
  115. /data/lib/aws-sdk-core/xml/parser/{engines/libxml.rb → libxml_engine.rb} +0 -0
  116. /data/lib/aws-sdk-core/xml/parser/{engines/nokogiri.rb → nokogiri_engine.rb} +0 -0
  117. /data/lib/aws-sdk-core/xml/parser/{engines/oga.rb → oga_engine.rb} +0 -0
  118. /data/lib/aws-sdk-core/xml/parser/{engines/ox.rb → ox_engine.rb} +0 -0
  119. /data/lib/aws-sdk-core/xml/parser/{engines/rexml.rb → rexml_engine.rb} +0 -0
@@ -118,6 +118,13 @@ module Aws::SSOOIDC
118
118
  # that has registered to receive the authorization code.
119
119
  # @return [String]
120
120
  #
121
+ # @!attribute [rw] code_verifier
122
+ # Used only when calling this API for the Authorization Code grant
123
+ # type. This value is generated by the client and presented to
124
+ # validate the original code challenge value the client passed at
125
+ # authorization time.
126
+ # @return [String]
127
+ #
121
128
  # @see http://docs.aws.amazon.com/goto/WebAPI/sso-oidc-2019-06-10/CreateTokenRequest AWS API Documentation
122
129
  #
123
130
  class CreateTokenRequest < Struct.new(
@@ -128,14 +135,15 @@ module Aws::SSOOIDC
128
135
  :code,
129
136
  :refresh_token,
130
137
  :scope,
131
- :redirect_uri)
132
- SENSITIVE = [:client_secret, :refresh_token]
138
+ :redirect_uri,
139
+ :code_verifier)
140
+ SENSITIVE = [:client_secret, :refresh_token, :code_verifier]
133
141
  include Aws::Structure
134
142
  end
135
143
 
136
144
  # @!attribute [rw] access_token
137
- # A bearer token to access AWS accounts and applications assigned to a
138
- # user.
145
+ # A bearer token to access Amazon Web Services accounts and
146
+ # applications assigned to a user.
139
147
  # @return [String]
140
148
  #
141
149
  # @!attribute [rw] token_type
@@ -278,6 +286,13 @@ module Aws::SSOOIDC
278
286
  # * Refresh Token - `urn:ietf:params:oauth:token-type:refresh_token`
279
287
  # @return [String]
280
288
  #
289
+ # @!attribute [rw] code_verifier
290
+ # Used only when calling this API for the Authorization Code grant
291
+ # type. This value is generated by the client and presented to
292
+ # validate the original code challenge value the client passed at
293
+ # authorization time.
294
+ # @return [String]
295
+ #
281
296
  # @see http://docs.aws.amazon.com/goto/WebAPI/sso-oidc-2019-06-10/CreateTokenWithIAMRequest AWS API Documentation
282
297
  #
283
298
  class CreateTokenWithIAMRequest < Struct.new(
@@ -290,14 +305,15 @@ module Aws::SSOOIDC
290
305
  :redirect_uri,
291
306
  :subject_token,
292
307
  :subject_token_type,
293
- :requested_token_type)
294
- SENSITIVE = [:refresh_token, :assertion, :subject_token]
308
+ :requested_token_type,
309
+ :code_verifier)
310
+ SENSITIVE = [:refresh_token, :assertion, :subject_token, :code_verifier]
295
311
  include Aws::Structure
296
312
  end
297
313
 
298
314
  # @!attribute [rw] access_token
299
- # A bearer token to access AWS accounts and applications assigned to a
300
- # user.
315
+ # A bearer token to access Amazon Web Services accounts and
316
+ # applications assigned to a user.
301
317
  # @return [String]
302
318
  #
303
319
  # @!attribute [rw] token_type
@@ -467,6 +483,28 @@ module Aws::SSOOIDC
467
483
  include Aws::Structure
468
484
  end
469
485
 
486
+ # Indicates that one or more redirect URI in the request is not
487
+ # supported for this operation.
488
+ #
489
+ # @!attribute [rw] error
490
+ # Single error code. For this exception the value will be
491
+ # `invalid_redirect_uri`.
492
+ # @return [String]
493
+ #
494
+ # @!attribute [rw] error_description
495
+ # Human-readable text providing additional information, used to assist
496
+ # the client developer in understanding the error that occurred.
497
+ # @return [String]
498
+ #
499
+ # @see http://docs.aws.amazon.com/goto/WebAPI/sso-oidc-2019-06-10/InvalidRedirectUriException AWS API Documentation
500
+ #
501
+ class InvalidRedirectUriException < Struct.new(
502
+ :error,
503
+ :error_description)
504
+ SENSITIVE = []
505
+ include Aws::Structure
506
+ end
507
+
470
508
  # Indicates that something is wrong with the input to the request. For
471
509
  # example, a required parameter might be missing or out of range.
472
510
  #
@@ -559,12 +597,42 @@ module Aws::SSOOIDC
559
597
  # granting an access token.
560
598
  # @return [Array<String>]
561
599
  #
600
+ # @!attribute [rw] redirect_uris
601
+ # The list of redirect URI that are defined by the client. At
602
+ # completion of authorization, this list is used to restrict what
603
+ # locations the user agent can be redirected back to.
604
+ # @return [Array<String>]
605
+ #
606
+ # @!attribute [rw] grant_types
607
+ # The list of OAuth 2.0 grant types that are defined by the client.
608
+ # This list is used to restrict the token granting flows available to
609
+ # the client.
610
+ # @return [Array<String>]
611
+ #
612
+ # @!attribute [rw] issuer_url
613
+ # The IAM Identity Center Issuer URL associated with an instance of
614
+ # IAM Identity Center. This value is needed for user access to
615
+ # resources through the client.
616
+ # @return [String]
617
+ #
618
+ # @!attribute [rw] entitled_application_arn
619
+ # This IAM Identity Center application ARN is used to define
620
+ # administrator-managed configuration for public client access to
621
+ # resources. At authorization, the scopes, grants, and redirect URI
622
+ # available to this client will be restricted by this application
623
+ # resource.
624
+ # @return [String]
625
+ #
562
626
  # @see http://docs.aws.amazon.com/goto/WebAPI/sso-oidc-2019-06-10/RegisterClientRequest AWS API Documentation
563
627
  #
564
628
  class RegisterClientRequest < Struct.new(
565
629
  :client_name,
566
630
  :client_type,
567
- :scopes)
631
+ :scopes,
632
+ :redirect_uris,
633
+ :grant_types,
634
+ :issuer_url,
635
+ :entitled_application_arn)
568
636
  SENSITIVE = []
569
637
  include Aws::Structure
570
638
  end
@@ -54,6 +54,6 @@ require_relative 'aws-sdk-ssooidc/customizations'
54
54
  # @!group service
55
55
  module Aws::SSOOIDC
56
56
 
57
- GEM_VERSION = '3.189.0'
57
+ GEM_VERSION = '3.199.0'
58
58
 
59
59
  end
@@ -22,6 +22,7 @@ require 'aws-sdk-core/plugins/endpoint_pattern.rb'
22
22
  require 'aws-sdk-core/plugins/response_paging.rb'
23
23
  require 'aws-sdk-core/plugins/stub_responses.rb'
24
24
  require 'aws-sdk-core/plugins/idempotency_token.rb'
25
+ require 'aws-sdk-core/plugins/invocation_id.rb'
25
26
  require 'aws-sdk-core/plugins/jsonvalue_converter.rb'
26
27
  require 'aws-sdk-core/plugins/client_metrics_plugin.rb'
27
28
  require 'aws-sdk-core/plugins/client_metrics_send_plugin.rb'
@@ -73,6 +74,7 @@ module Aws::STS
73
74
  add_plugin(Aws::Plugins::ResponsePaging)
74
75
  add_plugin(Aws::Plugins::StubResponses)
75
76
  add_plugin(Aws::Plugins::IdempotencyToken)
77
+ add_plugin(Aws::Plugins::InvocationId)
76
78
  add_plugin(Aws::Plugins::JsonvalueConverter)
77
79
  add_plugin(Aws::Plugins::ClientMetricsPlugin)
78
80
  add_plugin(Aws::Plugins::ClientMetricsSendPlugin)
@@ -89,6 +91,11 @@ module Aws::STS
89
91
 
90
92
  # @overload initialize(options)
91
93
  # @param [Hash] options
94
+ #
95
+ # @option options [Array<Seahorse::Client::Plugin>] :plugins ([]])
96
+ # A list of plugins to apply to the client. Each plugin is either a
97
+ # class name or an instance of a plugin class.
98
+ #
92
99
  # @option options [required, Aws::CredentialProvider] :credentials
93
100
  # Your AWS credentials. This can be an instance of any one of the
94
101
  # following classes:
@@ -198,10 +205,16 @@ module Aws::STS
198
205
  # When set to 'true' the request body will not be compressed
199
206
  # for supported operations.
200
207
  #
201
- # @option options [String] :endpoint
202
- # The client endpoint is normally constructed from the `:region`
203
- # option. You should only configure an `:endpoint` when connecting
204
- # to test or custom endpoints. This should be a valid HTTP(S) URI.
208
+ # @option options [String, URI::HTTPS, URI::HTTP] :endpoint
209
+ # Normally you should not configure the `:endpoint` option
210
+ # directly. This is normally constructed from the `:region`
211
+ # option. Configuring `:endpoint` is normally reserved for
212
+ # connecting to test or custom endpoints. The endpoint should
213
+ # be a URI formatted like:
214
+ #
215
+ # 'http://example.com'
216
+ # 'https://example.com'
217
+ # 'http://example.com:123'
205
218
  #
206
219
  # @option options [Integer] :endpoint_cache_max_entries (1000)
207
220
  # Used for the maximum size limit of the LRU cache storing endpoints data
@@ -291,11 +304,11 @@ module Aws::STS
291
304
  # throttling. This is a provisional mode that may change behavior
292
305
  # in the future.
293
306
  #
294
- #
295
307
  # @option options [String] :sdk_ua_app_id
296
308
  # A unique and opaque application ID that is appended to the
297
- # User-Agent header as app/<sdk_ua_app_id>. It should have a
298
- # maximum length of 50.
309
+ # User-Agent header as app/sdk_ua_app_id. It should have a
310
+ # maximum length of 50. This variable is sourced from environment
311
+ # variable AWS_SDK_UA_APP_ID or the shared config profile attribute sdk_ua_app_id.
299
312
  #
300
313
  # @option options [String] :secret_access_key
301
314
  #
@@ -344,50 +357,65 @@ module Aws::STS
344
357
  # @option options [Aws::STS::EndpointProvider] :endpoint_provider
345
358
  # The endpoint provider used to resolve endpoints. Any object that responds to `#resolve_endpoint(parameters)` where `parameters` is a Struct similar to `Aws::STS::EndpointParameters`
346
359
  #
347
- # @option options [URI::HTTP,String] :http_proxy A proxy to send
348
- # requests through. Formatted like 'http://proxy.com:123'.
349
- #
350
- # @option options [Float] :http_open_timeout (15) The number of
351
- # seconds to wait when opening a HTTP session before raising a
352
- # `Timeout::Error`.
353
- #
354
- # @option options [Float] :http_read_timeout (60) The default
355
- # number of seconds to wait for response data. This value can
356
- # safely be set per-request on the session.
357
- #
358
- # @option options [Float] :http_idle_timeout (5) The number of
359
- # seconds a connection is allowed to sit idle before it is
360
- # considered stale. Stale connections are closed and removed
361
- # from the pool before making a request.
362
- #
363
- # @option options [Float] :http_continue_timeout (1) The number of
364
- # seconds to wait for a 100-continue response before sending the
365
- # request body. This option has no effect unless the request has
366
- # "Expect" header set to "100-continue". Defaults to `nil` which
367
- # disables this behaviour. This value can safely be set per
368
- # request on the session.
369
- #
370
- # @option options [Float] :ssl_timeout (nil) Sets the SSL timeout
371
- # in seconds.
372
- #
373
- # @option options [Boolean] :http_wire_trace (false) When `true`,
374
- # HTTP debug output will be sent to the `:logger`.
360
+ # @option options [Float] :http_continue_timeout (1)
361
+ # The number of seconds to wait for a 100-continue response before sending the
362
+ # request body. This option has no effect unless the request has "Expect"
363
+ # header set to "100-continue". Defaults to `nil` which disables this
364
+ # behaviour. This value can safely be set per request on the session.
365
+ #
366
+ # @option options [Float] :http_idle_timeout (5)
367
+ # The number of seconds a connection is allowed to sit idle before it
368
+ # is considered stale. Stale connections are closed and removed from the
369
+ # pool before making a request.
370
+ #
371
+ # @option options [Float] :http_open_timeout (15)
372
+ # The default number of seconds to wait for response data.
373
+ # This value can safely be set per-request on the session.
374
+ #
375
+ # @option options [URI::HTTP,String] :http_proxy
376
+ # A proxy to send requests through. Formatted like 'http://proxy.com:123'.
377
+ #
378
+ # @option options [Float] :http_read_timeout (60)
379
+ # The default number of seconds to wait for response data.
380
+ # This value can safely be set per-request on the session.
381
+ #
382
+ # @option options [Boolean] :http_wire_trace (false)
383
+ # When `true`, HTTP debug output will be sent to the `:logger`.
384
+ #
385
+ # @option options [Proc] :on_chunk_received
386
+ # When a Proc object is provided, it will be used as callback when each chunk
387
+ # of the response body is received. It provides three arguments: the chunk,
388
+ # the number of bytes received, and the total number of
389
+ # bytes in the response (or nil if the server did not send a `content-length`).
390
+ #
391
+ # @option options [Proc] :on_chunk_sent
392
+ # When a Proc object is provided, it will be used as callback when each chunk
393
+ # of the request body is sent. It provides three arguments: the chunk,
394
+ # the number of bytes read from the body, and the total number of
395
+ # bytes in the body.
396
+ #
397
+ # @option options [Boolean] :raise_response_errors (true)
398
+ # When `true`, response errors are raised.
399
+ #
400
+ # @option options [String] :ssl_ca_bundle
401
+ # Full path to the SSL certificate authority bundle file that should be used when
402
+ # verifying peer certificates. If you do not pass `:ssl_ca_bundle` or
403
+ # `:ssl_ca_directory` the the system default will be used if available.
404
+ #
405
+ # @option options [String] :ssl_ca_directory
406
+ # Full path of the directory that contains the unbundled SSL certificate
407
+ # authority files for verifying peer certificates. If you do
408
+ # not pass `:ssl_ca_bundle` or `:ssl_ca_directory` the the system
409
+ # default will be used if available.
375
410
  #
376
- # @option options [Boolean] :ssl_verify_peer (true) When `true`,
377
- # SSL peer certificates are verified when establishing a
378
- # connection.
411
+ # @option options [String] :ssl_ca_store
412
+ # Sets the X509::Store to verify peer certificate.
379
413
  #
380
- # @option options [String] :ssl_ca_bundle Full path to the SSL
381
- # certificate authority bundle file that should be used when
382
- # verifying peer certificates. If you do not pass
383
- # `:ssl_ca_bundle` or `:ssl_ca_directory` the the system default
384
- # will be used if available.
414
+ # @option options [Float] :ssl_timeout
415
+ # Sets the SSL timeout in seconds
385
416
  #
386
- # @option options [String] :ssl_ca_directory Full path of the
387
- # directory that contains the unbundled SSL certificate
388
- # authority files for verifying peer certificates. If you do
389
- # not pass `:ssl_ca_bundle` or `:ssl_ca_directory` the the
390
- # system default will be used if available.
417
+ # @option options [Boolean] :ssl_verify_peer (true)
418
+ # When `true`, SSL peer certificates are verified when establishing a connection.
391
419
  #
392
420
  def initialize(*args)
393
421
  super
@@ -775,7 +803,7 @@ module Aws::STS
775
803
  # a single trusted context assertion and the ARN of the context provider
776
804
  # from which the trusted context assertion was generated.
777
805
  #
778
- # `[\{"ProviderArn":"arn:aws:iam::aws:contextProvider/identitycenter","ContextAssertion":"trusted-context-assertion"\}]`
806
+ # `[\{"ProviderArn":"arn:aws:iam::aws:contextProvider/IdentityCenter","ContextAssertion":"trusted-context-assertion"\}]`
779
807
  #
780
808
  # @return [Types::AssumeRoleResponse] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
781
809
  #
@@ -2352,7 +2380,7 @@ module Aws::STS
2352
2380
  params: params,
2353
2381
  config: config)
2354
2382
  context[:gem_name] = 'aws-sdk-core'
2355
- context[:gem_version] = '3.189.0'
2383
+ context[:gem_version] = '3.199.0'
2356
2384
  Seahorse::Client::Request.new(handlers, context)
2357
2385
  end
2358
2386
 
@@ -24,7 +24,7 @@ module Aws::STS
24
24
  Credentials = Shapes::StructureShape.new(name: 'Credentials')
25
25
  DecodeAuthorizationMessageRequest = Shapes::StructureShape.new(name: 'DecodeAuthorizationMessageRequest')
26
26
  DecodeAuthorizationMessageResponse = Shapes::StructureShape.new(name: 'DecodeAuthorizationMessageResponse')
27
- ExpiredTokenException = Shapes::StructureShape.new(name: 'ExpiredTokenException')
27
+ ExpiredTokenException = Shapes::StructureShape.new(name: 'ExpiredTokenException', error: {"code"=>"ExpiredTokenException", "httpStatusCode"=>400, "senderFault"=>true})
28
28
  FederatedUser = Shapes::StructureShape.new(name: 'FederatedUser')
29
29
  GetAccessKeyInfoRequest = Shapes::StructureShape.new(name: 'GetAccessKeyInfoRequest')
30
30
  GetAccessKeyInfoResponse = Shapes::StructureShape.new(name: 'GetAccessKeyInfoResponse')
@@ -34,18 +34,18 @@ module Aws::STS
34
34
  GetFederationTokenResponse = Shapes::StructureShape.new(name: 'GetFederationTokenResponse')
35
35
  GetSessionTokenRequest = Shapes::StructureShape.new(name: 'GetSessionTokenRequest')
36
36
  GetSessionTokenResponse = Shapes::StructureShape.new(name: 'GetSessionTokenResponse')
37
- IDPCommunicationErrorException = Shapes::StructureShape.new(name: 'IDPCommunicationErrorException')
38
- IDPRejectedClaimException = Shapes::StructureShape.new(name: 'IDPRejectedClaimException')
39
- InvalidAuthorizationMessageException = Shapes::StructureShape.new(name: 'InvalidAuthorizationMessageException')
40
- InvalidIdentityTokenException = Shapes::StructureShape.new(name: 'InvalidIdentityTokenException')
37
+ IDPCommunicationErrorException = Shapes::StructureShape.new(name: 'IDPCommunicationErrorException', error: {"code"=>"IDPCommunicationError", "httpStatusCode"=>400, "senderFault"=>true})
38
+ IDPRejectedClaimException = Shapes::StructureShape.new(name: 'IDPRejectedClaimException', error: {"code"=>"IDPRejectedClaim", "httpStatusCode"=>403, "senderFault"=>true})
39
+ InvalidAuthorizationMessageException = Shapes::StructureShape.new(name: 'InvalidAuthorizationMessageException', error: {"code"=>"InvalidAuthorizationMessageException", "httpStatusCode"=>400, "senderFault"=>true})
40
+ InvalidIdentityTokenException = Shapes::StructureShape.new(name: 'InvalidIdentityTokenException', error: {"code"=>"InvalidIdentityToken", "httpStatusCode"=>400, "senderFault"=>true})
41
41
  Issuer = Shapes::StringShape.new(name: 'Issuer')
42
- MalformedPolicyDocumentException = Shapes::StructureShape.new(name: 'MalformedPolicyDocumentException')
42
+ MalformedPolicyDocumentException = Shapes::StructureShape.new(name: 'MalformedPolicyDocumentException', error: {"code"=>"MalformedPolicyDocument", "httpStatusCode"=>400, "senderFault"=>true})
43
43
  NameQualifier = Shapes::StringShape.new(name: 'NameQualifier')
44
- PackedPolicyTooLargeException = Shapes::StructureShape.new(name: 'PackedPolicyTooLargeException')
44
+ PackedPolicyTooLargeException = Shapes::StructureShape.new(name: 'PackedPolicyTooLargeException', error: {"code"=>"PackedPolicyTooLarge", "httpStatusCode"=>400, "senderFault"=>true})
45
45
  PolicyDescriptorType = Shapes::StructureShape.new(name: 'PolicyDescriptorType')
46
46
  ProvidedContext = Shapes::StructureShape.new(name: 'ProvidedContext')
47
47
  ProvidedContextsListType = Shapes::ListShape.new(name: 'ProvidedContextsListType')
48
- RegionDisabledException = Shapes::StructureShape.new(name: 'RegionDisabledException')
48
+ RegionDisabledException = Shapes::StructureShape.new(name: 'RegionDisabledException', error: {"code"=>"RegionDisabledException", "httpStatusCode"=>403, "senderFault"=>true})
49
49
  SAMLAssertionType = Shapes::StringShape.new(name: 'SAMLAssertionType')
50
50
  Subject = Shapes::StringShape.new(name: 'Subject')
51
51
  SubjectType = Shapes::StringShape.new(name: 'SubjectType')
@@ -14,6 +14,7 @@ module Aws::STS
14
14
  option(
15
15
  :endpoint_provider,
16
16
  doc_type: 'Aws::STS::EndpointProvider',
17
+ rbs_type: 'untyped',
17
18
  docstring: 'The endpoint provider used to resolve endpoints. Any '\
18
19
  'object that responds to `#resolve_endpoint(parameters)` '\
19
20
  'where `parameters` is a Struct similar to '\
@@ -297,7 +297,7 @@ module Aws::STS
297
297
  # context provider from which the trusted context assertion was
298
298
  # generated.
299
299
  #
300
- # `[\{"ProviderArn":"arn:aws:iam::aws:contextProvider/identitycenter","ContextAssertion":"trusted-context-assertion"\}]`
300
+ # `[\{"ProviderArn":"arn:aws:iam::aws:contextProvider/IdentityCenter","ContextAssertion":"trusted-context-assertion"\}]`
301
301
  # @return [Array<Types::ProvidedContext>]
302
302
  #
303
303
  # @see http://docs.aws.amazon.com/goto/WebAPI/sts-2011-06-15/AssumeRoleRequest AWS API Documentation
data/lib/aws-sdk-sts.rb CHANGED
@@ -54,6 +54,6 @@ require_relative 'aws-sdk-sts/customizations'
54
54
  # @!group service
55
55
  module Aws::STS
56
56
 
57
- GEM_VERSION = '3.189.0'
57
+ GEM_VERSION = '3.199.0'
58
58
 
59
59
  end
@@ -5,12 +5,12 @@ module Seahorse
5
5
  class AsyncBase < Seahorse::Client::Base
6
6
 
7
7
  # default H2 plugins
8
+ # @api private
8
9
  @plugins = PluginList.new([
9
10
  Plugins::Endpoint,
10
11
  Plugins::H2,
11
12
  Plugins::ResponseTarget
12
13
  ])
13
-
14
14
  def initialize(plugins, options)
15
15
  super
16
16
  @connection = H2::Connection.new(options)
@@ -12,24 +12,43 @@ module Seahorse
12
12
  @sync_queue = options[:sync_queue]
13
13
  end
14
14
 
15
+ # @return [RequestContext]
15
16
  def context
16
17
  @response.context
17
18
  end
18
19
 
20
+ # @return [StandardError, nil]
19
21
  def error
20
22
  @response.error
21
23
  end
22
24
 
25
+ # @overload on(status_code, &block)
26
+ # @param [Integer] status_code The block will be
27
+ # triggered only for responses with the given status code.
28
+ #
29
+ # @overload on(status_code_range, &block)
30
+ # @param [Range<Integer>] status_code_range The block will be
31
+ # triggered only for responses with a status code that falls
32
+ # witin the given range.
33
+ #
34
+ # @return [self]
23
35
  def on(range, &block)
24
36
  @response.on(range, &block)
25
37
  self
26
38
  end
27
39
 
40
+ # @api private
28
41
  def on_complete(&block)
29
42
  @response.on_complete(&block)
30
43
  self
31
44
  end
32
45
 
46
+ # @return [Boolean] Returns `true` if the response is complete with
47
+ # no error.
48
+ def successful?
49
+ @response.error.nil?
50
+ end
51
+
33
52
  def wait
34
53
  if error && context.config.raise_response_errors
35
54
  raise error
@@ -1,7 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'thread'
4
-
5
3
  module Seahorse
6
4
  module Client
7
5
  class Base
@@ -9,6 +7,7 @@ module Seahorse
9
7
  include HandlerBuilder
10
8
 
11
9
  # default plugins
10
+ # @api private
12
11
  @plugins = PluginList.new([
13
12
  Plugins::Endpoint,
14
13
  Plugins::NetHttp,
@@ -59,6 +58,7 @@ module Seahorse
59
58
  def build_config(plugins, options)
60
59
  config = Configuration.new
61
60
  config.add_option(:api)
61
+ config.add_option(:plugins)
62
62
  plugins.each do |plugin|
63
63
  plugin.add_options(config) if plugin.respond_to?(:add_options)
64
64
  end
@@ -95,9 +95,9 @@ module Seahorse
95
95
  class << self
96
96
 
97
97
  def new(options = {})
98
- plugins = build_plugins
99
98
  options = options.dup
100
- before_initialize(plugins, options)
99
+ plugins = build_plugins(self.plugins + options.fetch(:plugins, []))
100
+ plugins = before_initialize(plugins, options)
101
101
  client = allocate
102
102
  client.send(:initialize, plugins, options)
103
103
  client
@@ -208,17 +208,28 @@ module Seahorse
208
208
  include(operations_module)
209
209
  end
210
210
 
211
- def build_plugins
211
+ def build_plugins(plugins)
212
212
  plugins.map { |plugin| plugin.is_a?(Class) ? plugin.new : plugin }
213
213
  end
214
214
 
215
215
  def before_initialize(plugins, options)
216
- plugins.each do |plugin|
217
- plugin.before_initialize(self, options) if plugin.respond_to?(:before_initialize)
216
+ queue = Queue.new
217
+ plugins.each { |plugin| queue.push(plugin) }
218
+ until queue.empty?
219
+ plugin = queue.pop
220
+ next unless plugin.respond_to?(:before_initialize)
221
+
222
+ plugins_before = options.fetch(:plugins, [])
223
+ plugin.before_initialize(self, options)
224
+ plugins_after = build_plugins(options.fetch(:plugins, []) - plugins_before)
225
+ # Plugins with before_initialize can add other plugins
226
+ plugins_after.each { |p| queue.push(p); plugins << p }
218
227
  end
228
+ plugins
219
229
  end
220
230
 
221
231
  def inherited(subclass)
232
+ super
222
233
  subclass.instance_variable_set('@plugins', PluginList.new(@plugins))
223
234
  end
224
235
 
@@ -126,6 +126,7 @@ module Seahorse
126
126
  # https://http2.github.io/http2-spec/#rfc.section.8.1.2.3
127
127
  def _h2_headers(req)
128
128
  headers = {}
129
+ headers[':authority'] = req.endpoint.host
129
130
  headers[':method'] = req.http_method.upcase
130
131
  headers[':scheme'] = req.endpoint.scheme
131
132
  headers[':path'] = req.endpoint.path.empty? ? '/' : req.endpoint.path
@@ -15,7 +15,7 @@ module Seahorse
15
15
  attr_accessor :handler
16
16
 
17
17
  # @param [RequestContext] context
18
- # @return [Response]
18
+ # @return [Seahorse::Response]
19
19
  def call(context)
20
20
  @handler.call(context)
21
21
  end
@@ -119,11 +119,7 @@ module Seahorse
119
119
  # pool, not counting those currently in use.
120
120
  def size
121
121
  @pool_mutex.synchronize do
122
- size = 0
123
- @pool.each_pair do |endpoint,sessions|
124
- size += sessions.size
125
- end
126
- size
122
+ @pool.values.flatten.size
127
123
  end
128
124
  end
129
125
 
@@ -142,9 +138,7 @@ module Seahorse
142
138
  # @return [nil]
143
139
  def empty!
144
140
  @pool_mutex.synchronize do
145
- @pool.each_pair do |endpoint,sessions|
146
- sessions.each(&:finish)
147
- end
141
+ @pool.values.flatten.map(&:finish)
148
142
  @pool.clear
149
143
  end
150
144
  nil
@@ -312,7 +306,7 @@ module Seahorse
312
306
  # @note **Must** be called behind a `@pool_mutex` synchronize block.
313
307
  def _clean
314
308
  now = Aws::Util.monotonic_milliseconds
315
- @pool.each_pair do |endpoint,sessions|
309
+ @pool.values.each do |sessions|
316
310
  sessions.delete_if do |session|
317
311
  if session.last_used.nil? or now - session.last_used > http_idle_timeout * 1000
318
312
  session.finish
@@ -111,7 +111,15 @@ module Seahorse
111
111
 
112
112
  def initialize(name, options = {})
113
113
  @name = name
114
+ # prevent unstable object shapes by ensuring
115
+ # order and presence of instance variables
116
+ @default = nil
117
+ @default_block = nil
118
+ @required = nil
119
+ @doc_type = nil
114
120
  @doc_default = nil
121
+ @docstring = nil
122
+ @rbs_type = nil
115
123
  options.each_pair do |opt_name, opt_value|
116
124
  self.send("#{opt_name}=", opt_value)
117
125
  end
@@ -124,6 +132,7 @@ module Seahorse
124
132
  attr_accessor :doc_type
125
133
  attr_writer :doc_default
126
134
  attr_accessor :docstring
135
+ attr_accessor :rbs_type
127
136
 
128
137
  def doc_default(options)
129
138
  if @doc_default.nil? && !default.is_a?(Proc)
@@ -17,7 +17,6 @@ be a URI formatted like:
17
17
  'http://example.com'
18
18
  'https://example.com'
19
19
  'http://example.com:123'
20
-
21
20
  DOCS
22
21
 
23
22
  def add_handlers(handlers, config)