@aws-sdk/client-sts 3.33.0 → 3.36.1

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 (189) hide show
  1. package/CHANGELOG.md +47 -0
  2. package/{dist/cjs → dist-cjs}/STS.js +1 -9
  3. package/dist-cjs/STSClient.js +34 -0
  4. package/dist-cjs/commands/AssumeRoleCommand.js +38 -0
  5. package/dist-cjs/commands/AssumeRoleWithSAMLCommand.js +36 -0
  6. package/dist-cjs/commands/AssumeRoleWithWebIdentityCommand.js +36 -0
  7. package/dist-cjs/commands/DecodeAuthorizationMessageCommand.js +38 -0
  8. package/dist-cjs/commands/GetAccessKeyInfoCommand.js +38 -0
  9. package/dist-cjs/commands/GetCallerIdentityCommand.js +38 -0
  10. package/dist-cjs/commands/GetFederationTokenCommand.js +38 -0
  11. package/dist-cjs/commands/GetSessionTokenCommand.js +38 -0
  12. package/{dist/cjs → dist-cjs}/defaultRoleAssumers.js +0 -17
  13. package/{dist/cjs → dist-cjs}/defaultStsRoleAssumers.js +0 -21
  14. package/{dist/cjs → dist-cjs}/endpoints.js +0 -1
  15. package/{dist/cjs → dist-cjs}/index.js +0 -1
  16. package/{dist/cjs → dist-cjs}/models/index.js +0 -1
  17. package/{dist/cjs → dist-cjs}/models/models_0.js +0 -88
  18. package/{dist/cjs → dist-cjs}/protocols/Aws_query.js +22 -25
  19. package/{dist/cjs → dist-cjs}/runtimeConfig.browser.js +1 -5
  20. package/{dist/cjs → dist-cjs}/runtimeConfig.js +1 -5
  21. package/{dist/cjs → dist-cjs}/runtimeConfig.native.js +0 -4
  22. package/{dist/cjs → dist-cjs}/runtimeConfig.shared.js +1 -5
  23. package/{dist/es → dist-es}/STS.js +2 -10
  24. package/{dist/es → dist-es}/STSClient.js +2 -15
  25. package/dist-es/commands/AssumeRoleCommand.js +41 -0
  26. package/dist-es/commands/AssumeRoleWithSAMLCommand.js +39 -0
  27. package/dist-es/commands/AssumeRoleWithWebIdentityCommand.js +39 -0
  28. package/dist-es/commands/DecodeAuthorizationMessageCommand.js +41 -0
  29. package/dist-es/commands/GetAccessKeyInfoCommand.js +41 -0
  30. package/{dist/es → dist-es}/commands/GetCallerIdentityCommand.js +4 -39
  31. package/dist-es/commands/GetFederationTokenCommand.js +41 -0
  32. package/dist-es/commands/GetSessionTokenCommand.js +41 -0
  33. package/dist-es/defaultRoleAssumers.js +16 -0
  34. package/{dist/es → dist-es}/defaultStsRoleAssumers.js +10 -32
  35. package/{dist/es → dist-es}/endpoints.js +1 -2
  36. package/{dist/types/index.d.ts → dist-es/index.js} +0 -0
  37. package/{dist/types/models/index.d.ts → dist-es/models/index.js} +0 -0
  38. package/{dist/es → dist-es}/models/models_0.js +0 -88
  39. package/{dist/es → dist-es}/protocols/Aws_query.js +152 -155
  40. package/{dist/es → dist-es}/runtimeConfig.browser.js +1 -5
  41. package/{dist/es → dist-es}/runtimeConfig.js +1 -5
  42. package/{dist/es → dist-es}/runtimeConfig.native.js +0 -4
  43. package/{dist/es → dist-es}/runtimeConfig.shared.js +1 -5
  44. package/{dist/types → dist-types}/STS.d.ts +2 -2
  45. package/{dist/types → dist-types}/STSClient.d.ts +8 -8
  46. package/{dist/types → dist-types}/commands/AssumeRoleCommand.d.ts +3 -3
  47. package/{dist/types → dist-types}/commands/AssumeRoleWithSAMLCommand.d.ts +3 -3
  48. package/{dist/types → dist-types}/commands/AssumeRoleWithWebIdentityCommand.d.ts +3 -3
  49. package/{dist/types → dist-types}/commands/DecodeAuthorizationMessageCommand.d.ts +3 -3
  50. package/{dist/types → dist-types}/commands/GetAccessKeyInfoCommand.d.ts +3 -3
  51. package/{dist/types → dist-types}/commands/GetCallerIdentityCommand.d.ts +3 -3
  52. package/{dist/types → dist-types}/commands/GetFederationTokenCommand.d.ts +3 -3
  53. package/{dist/types → dist-types}/commands/GetSessionTokenCommand.d.ts +3 -3
  54. package/{dist/types → dist-types}/defaultRoleAssumers.d.ts +0 -0
  55. package/{dist/types → dist-types}/defaultStsRoleAssumers.d.ts +0 -0
  56. package/{dist/types → dist-types}/endpoints.d.ts +0 -0
  57. package/{index.ts → dist-types/index.d.ts} +0 -0
  58. package/{models/index.ts → dist-types/models/index.d.ts} +0 -0
  59. package/{dist/types → dist-types}/models/models_0.d.ts +0 -0
  60. package/{dist/types → dist-types}/protocols/Aws_query.d.ts +2 -2
  61. package/{dist/types → dist-types}/runtimeConfig.browser.d.ts +0 -0
  62. package/{dist/types → dist-types}/runtimeConfig.d.ts +0 -0
  63. package/{dist/types → dist-types}/runtimeConfig.native.d.ts +0 -0
  64. package/{dist/types → dist-types}/runtimeConfig.shared.d.ts +0 -0
  65. package/dist-types/ts3.4/STS.d.ts +45 -0
  66. package/{dist/types → dist-types}/ts3.4/STSClient.d.ts +32 -101
  67. package/dist-types/ts3.4/commands/AssumeRoleCommand.d.ts +17 -0
  68. package/dist-types/ts3.4/commands/AssumeRoleWithSAMLCommand.d.ts +17 -0
  69. package/dist-types/ts3.4/commands/AssumeRoleWithWebIdentityCommand.d.ts +17 -0
  70. package/dist-types/ts3.4/commands/DecodeAuthorizationMessageCommand.d.ts +17 -0
  71. package/dist-types/ts3.4/commands/GetAccessKeyInfoCommand.d.ts +17 -0
  72. package/dist-types/ts3.4/commands/GetCallerIdentityCommand.d.ts +17 -0
  73. package/dist-types/ts3.4/commands/GetFederationTokenCommand.d.ts +17 -0
  74. package/dist-types/ts3.4/commands/GetSessionTokenCommand.d.ts +17 -0
  75. package/dist-types/ts3.4/defaultRoleAssumers.d.ts +8 -0
  76. package/{dist/types → dist-types}/ts3.4/defaultStsRoleAssumers.d.ts +6 -25
  77. package/{dist/types → dist-types}/ts3.4/endpoints.d.ts +0 -0
  78. package/{dist/types → dist-types}/ts3.4/index.d.ts +0 -0
  79. package/{dist/types → dist-types}/ts3.4/models/index.d.ts +0 -0
  80. package/dist-types/ts3.4/models/models_0.d.ts +367 -0
  81. package/{dist/types → dist-types}/ts3.4/protocols/Aws_query.d.ts +2 -2
  82. package/{dist/types → dist-types}/ts3.4/runtimeConfig.browser.d.ts +1 -3
  83. package/{dist/types → dist-types}/ts3.4/runtimeConfig.d.ts +1 -3
  84. package/{dist/types → dist-types}/ts3.4/runtimeConfig.native.d.ts +1 -3
  85. package/{dist/types → dist-types}/ts3.4/runtimeConfig.shared.d.ts +1 -3
  86. package/package.json +52 -49
  87. package/STS.ts +0 -896
  88. package/STSClient.ts +0 -263
  89. package/commands/AssumeRoleCommand.ts +0 -176
  90. package/commands/AssumeRoleWithSAMLCommand.ts +0 -225
  91. package/commands/AssumeRoleWithWebIdentityCommand.ts +0 -232
  92. package/commands/DecodeAuthorizationMessageCommand.ts +0 -134
  93. package/commands/GetAccessKeyInfoCommand.ts +0 -113
  94. package/commands/GetCallerIdentityCommand.ts +0 -105
  95. package/commands/GetFederationTokenCommand.ts +0 -234
  96. package/commands/GetSessionTokenCommand.ts +0 -147
  97. package/defaultRoleAssumers.spec.ts +0 -148
  98. package/defaultRoleAssumers.ts +0 -41
  99. package/defaultStsRoleAssumers.ts +0 -126
  100. package/dist/cjs/STS.js.map +0 -1
  101. package/dist/cjs/STSClient.js +0 -47
  102. package/dist/cjs/STSClient.js.map +0 -1
  103. package/dist/cjs/commands/AssumeRoleCommand.js +0 -146
  104. package/dist/cjs/commands/AssumeRoleCommand.js.map +0 -1
  105. package/dist/cjs/commands/AssumeRoleWithSAMLCommand.js +0 -192
  106. package/dist/cjs/commands/AssumeRoleWithSAMLCommand.js.map +0 -1
  107. package/dist/cjs/commands/AssumeRoleWithWebIdentityCommand.js +0 -196
  108. package/dist/cjs/commands/AssumeRoleWithWebIdentityCommand.js.map +0 -1
  109. package/dist/cjs/commands/DecodeAuthorizationMessageCommand.js +0 -98
  110. package/dist/cjs/commands/DecodeAuthorizationMessageCommand.js.map +0 -1
  111. package/dist/cjs/commands/GetAccessKeyInfoCommand.js +0 -80
  112. package/dist/cjs/commands/GetAccessKeyInfoCommand.js.map +0 -1
  113. package/dist/cjs/commands/GetCallerIdentityCommand.js +0 -72
  114. package/dist/cjs/commands/GetCallerIdentityCommand.js.map +0 -1
  115. package/dist/cjs/commands/GetFederationTokenCommand.js +0 -201
  116. package/dist/cjs/commands/GetFederationTokenCommand.js.map +0 -1
  117. package/dist/cjs/commands/GetSessionTokenCommand.js +0 -114
  118. package/dist/cjs/commands/GetSessionTokenCommand.js.map +0 -1
  119. package/dist/cjs/defaultRoleAssumers.js.map +0 -1
  120. package/dist/cjs/defaultRoleAssumers.spec.js +0 -135
  121. package/dist/cjs/defaultRoleAssumers.spec.js.map +0 -1
  122. package/dist/cjs/defaultStsRoleAssumers.js.map +0 -1
  123. package/dist/cjs/endpoints.js.map +0 -1
  124. package/dist/cjs/index.js.map +0 -1
  125. package/dist/cjs/models/index.js.map +0 -1
  126. package/dist/cjs/models/models_0.js.map +0 -1
  127. package/dist/cjs/package.json +0 -93
  128. package/dist/cjs/protocols/Aws_query.js.map +0 -1
  129. package/dist/cjs/runtimeConfig.browser.js.map +0 -1
  130. package/dist/cjs/runtimeConfig.js.map +0 -1
  131. package/dist/cjs/runtimeConfig.native.js.map +0 -1
  132. package/dist/cjs/runtimeConfig.shared.js.map +0 -1
  133. package/dist/es/STS.js.map +0 -1
  134. package/dist/es/STSClient.js.map +0 -1
  135. package/dist/es/commands/AssumeRoleCommand.js +0 -150
  136. package/dist/es/commands/AssumeRoleCommand.js.map +0 -1
  137. package/dist/es/commands/AssumeRoleWithSAMLCommand.js +0 -196
  138. package/dist/es/commands/AssumeRoleWithSAMLCommand.js.map +0 -1
  139. package/dist/es/commands/AssumeRoleWithWebIdentityCommand.js +0 -200
  140. package/dist/es/commands/AssumeRoleWithWebIdentityCommand.js.map +0 -1
  141. package/dist/es/commands/DecodeAuthorizationMessageCommand.js +0 -102
  142. package/dist/es/commands/DecodeAuthorizationMessageCommand.js.map +0 -1
  143. package/dist/es/commands/GetAccessKeyInfoCommand.js +0 -84
  144. package/dist/es/commands/GetAccessKeyInfoCommand.js.map +0 -1
  145. package/dist/es/commands/GetCallerIdentityCommand.js.map +0 -1
  146. package/dist/es/commands/GetFederationTokenCommand.js +0 -205
  147. package/dist/es/commands/GetFederationTokenCommand.js.map +0 -1
  148. package/dist/es/commands/GetSessionTokenCommand.js +0 -118
  149. package/dist/es/commands/GetSessionTokenCommand.js.map +0 -1
  150. package/dist/es/defaultRoleAssumers.js +0 -33
  151. package/dist/es/defaultRoleAssumers.js.map +0 -1
  152. package/dist/es/defaultRoleAssumers.spec.js +0 -142
  153. package/dist/es/defaultRoleAssumers.spec.js.map +0 -1
  154. package/dist/es/defaultStsRoleAssumers.js.map +0 -1
  155. package/dist/es/endpoints.js.map +0 -1
  156. package/dist/es/index.js +0 -13
  157. package/dist/es/index.js.map +0 -1
  158. package/dist/es/models/index.js +0 -2
  159. package/dist/es/models/index.js.map +0 -1
  160. package/dist/es/models/models_0.js.map +0 -1
  161. package/dist/es/package.json +0 -93
  162. package/dist/es/protocols/Aws_query.js.map +0 -1
  163. package/dist/es/runtimeConfig.browser.js.map +0 -1
  164. package/dist/es/runtimeConfig.js.map +0 -1
  165. package/dist/es/runtimeConfig.native.js.map +0 -1
  166. package/dist/es/runtimeConfig.shared.js.map +0 -1
  167. package/dist/types/defaultRoleAssumers.spec.d.ts +0 -1
  168. package/dist/types/ts3.4/STS.d.ts +0 -666
  169. package/dist/types/ts3.4/commands/AssumeRoleCommand.d.ts +0 -118
  170. package/dist/types/ts3.4/commands/AssumeRoleWithSAMLCommand.d.ts +0 -166
  171. package/dist/types/ts3.4/commands/AssumeRoleWithWebIdentityCommand.d.ts +0 -170
  172. package/dist/types/ts3.4/commands/DecodeAuthorizationMessageCommand.d.ts +0 -70
  173. package/dist/types/ts3.4/commands/GetAccessKeyInfoCommand.d.ts +0 -52
  174. package/dist/types/ts3.4/commands/GetCallerIdentityCommand.d.ts +0 -44
  175. package/dist/types/ts3.4/commands/GetFederationTokenCommand.d.ts +0 -173
  176. package/dist/types/ts3.4/commands/GetSessionTokenCommand.d.ts +0 -86
  177. package/dist/types/ts3.4/defaultRoleAssumers.d.ts +0 -19
  178. package/dist/types/ts3.4/defaultRoleAssumers.spec.d.ts +0 -1
  179. package/dist/types/ts3.4/models/models_0.d.ts +0 -1192
  180. package/endpoints.ts +0 -91
  181. package/jest.config.js +0 -4
  182. package/models/models_0.ts +0 -1361
  183. package/protocols/Aws_query.ts +0 -1513
  184. package/runtimeConfig.browser.ts +0 -40
  185. package/runtimeConfig.native.ts +0 -16
  186. package/runtimeConfig.shared.ts +0 -16
  187. package/runtimeConfig.ts +0 -45
  188. package/tsconfig.es.json +0 -12
  189. package/tsconfig.json +0 -32
@@ -1,232 +0,0 @@
1
- import { STSClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../STSClient";
2
- import { AssumeRoleWithWebIdentityRequest, AssumeRoleWithWebIdentityResponse } from "../models/models_0";
3
- import {
4
- deserializeAws_queryAssumeRoleWithWebIdentityCommand,
5
- serializeAws_queryAssumeRoleWithWebIdentityCommand,
6
- } from "../protocols/Aws_query";
7
- import { getSerdePlugin } from "@aws-sdk/middleware-serde";
8
- import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http";
9
- import { Command as $Command } from "@aws-sdk/smithy-client";
10
- import {
11
- FinalizeHandlerArguments,
12
- Handler,
13
- HandlerExecutionContext,
14
- MiddlewareStack,
15
- HttpHandlerOptions as __HttpHandlerOptions,
16
- MetadataBearer as __MetadataBearer,
17
- SerdeContext as __SerdeContext,
18
- } from "@aws-sdk/types";
19
-
20
- export interface AssumeRoleWithWebIdentityCommandInput extends AssumeRoleWithWebIdentityRequest {}
21
- export interface AssumeRoleWithWebIdentityCommandOutput extends AssumeRoleWithWebIdentityResponse, __MetadataBearer {}
22
-
23
- /**
24
- * <p>Returns a set of temporary security credentials for users who have been authenticated in
25
- * a mobile or web application with a web identity provider. Example providers include Amazon Cognito,
26
- * Login with Amazon, Facebook, Google, or any OpenID Connect-compatible identity
27
- * provider.</p>
28
- * <note>
29
- * <p>For mobile applications, we recommend that you use Amazon Cognito. You can use Amazon Cognito with the
30
- * <a href="http://aws.amazon.com/sdkforios/">Amazon Web Services SDK for iOS Developer Guide</a> and the <a href="http://aws.amazon.com/sdkforandroid/">Amazon Web Services SDK for Android Developer Guide</a> to uniquely
31
- * identify a user. You can also supply the user with a consistent identity throughout the
32
- * lifetime of an application.</p>
33
- * <p>To learn more about Amazon Cognito, see <a href="https://docs.aws.amazon.com/mobile/sdkforandroid/developerguide/cognito-auth.html#d0e840">Amazon Cognito Overview</a> in
34
- * <i>Amazon Web Services SDK for Android Developer Guide</i> and <a href="https://docs.aws.amazon.com/mobile/sdkforios/developerguide/cognito-auth.html#d0e664">Amazon Cognito Overview</a> in the
35
- * <i>Amazon Web Services SDK for iOS Developer Guide</i>.</p>
36
- * </note>
37
- * <p>Calling <code>AssumeRoleWithWebIdentity</code> does not require the use of Amazon Web Services
38
- * security credentials. Therefore, you can distribute an application (for example, on mobile
39
- * devices) that requests temporary security credentials without including long-term Amazon Web Services
40
- * credentials in the application. You also don't need to deploy server-based proxy services
41
- * that use long-term Amazon Web Services credentials. Instead, the identity of the caller is validated by
42
- * using a token from the web identity provider. For a comparison of
43
- * <code>AssumeRoleWithWebIdentity</code> with the other API operations that produce
44
- * temporary credentials, see <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_request.html">Requesting Temporary Security
45
- * Credentials</a> and <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_request.html#stsapi_comparison">Comparing the
46
- * STS API operations</a> in the <i>IAM User Guide</i>.</p>
47
- * <p>The temporary security credentials returned by this API consist of an access key ID, a
48
- * secret access key, and a security token. Applications can use these temporary security
49
- * credentials to sign calls to Amazon Web Services service API operations.</p>
50
- * <p>
51
- * <b>Session Duration</b>
52
- * </p>
53
- * <p>By default, the temporary security credentials created by
54
- * <code>AssumeRoleWithWebIdentity</code> last for one hour. However, you can use the
55
- * optional <code>DurationSeconds</code> parameter to specify the duration of your session.
56
- * You can provide a value from 900 seconds (15 minutes) up to the maximum session duration
57
- * setting for the role. This setting can have a value from 1 hour to 12 hours. To learn how
58
- * to view the maximum value for your role, see <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_use.html#id_roles_use_view-role-max-session">View the
59
- * Maximum Session Duration Setting for a Role</a> in the
60
- * <i>IAM User Guide</i>. The maximum session duration limit applies when
61
- * you use the <code>AssumeRole*</code> API operations or the <code>assume-role*</code> CLI
62
- * commands. However the limit does not apply when you use those operations to create a
63
- * console URL. For more information, see <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_use.html">Using IAM Roles</a> in the
64
- * <i>IAM User Guide</i>. </p>
65
- * <p>
66
- * <b>Permissions</b>
67
- * </p>
68
- * <p>The temporary security credentials created by <code>AssumeRoleWithWebIdentity</code> can
69
- * be used to make API calls to any Amazon Web Services service with the following exception: you cannot
70
- * call the STS <code>GetFederationToken</code> or <code>GetSessionToken</code> API
71
- * operations.</p>
72
- * <p>(Optional) You can pass inline or managed <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies.html#policies_session">session policies</a> to
73
- * this operation. You can pass a single JSON policy document to use as an inline session
74
- * policy. You can also specify up to 10 managed policies to use as managed session policies.
75
- * The plaintext that you use for both inline and managed session policies can't exceed 2,048
76
- * characters. Passing policies to this operation returns new
77
- * temporary credentials. The resulting session's permissions are the intersection of the
78
- * role's identity-based policy and the session policies. You can use the role's temporary
79
- * credentials in subsequent Amazon Web Services API calls to access resources in the account that owns
80
- * the role. You cannot use session policies to grant more permissions than those allowed
81
- * by the identity-based policy of the role that is being assumed. For more information, see
82
- * <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies.html#policies_session">Session
83
- * Policies</a> in the <i>IAM User Guide</i>.</p>
84
- * <p>
85
- * <b>Tags</b>
86
- * </p>
87
- * <p>(Optional) You can configure your IdP to pass attributes into your web identity token as
88
- * session tags. Each session tag consists of a key name and an associated value. For more
89
- * information about session tags, see <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/id_session-tags.html">Passing Session Tags in STS</a> in the
90
- * <i>IAM User Guide</i>.</p>
91
- * <p>You can pass up to 50 session tags. The plaintext session tag keys can’t exceed 128
92
- * characters and the values can’t exceed 256 characters. For these and additional limits, see
93
- * <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_iam-limits.html#reference_iam-limits-entity-length">IAM
94
- * and STS Character Limits</a> in the <i>IAM User Guide</i>.</p>
95
- *
96
- * <note>
97
- * <p>An Amazon Web Services conversion compresses the passed session policies and session tags into a
98
- * packed binary format that has a separate limit. Your request can fail for this limit
99
- * even if your plaintext meets the other requirements. The <code>PackedPolicySize</code>
100
- * response element indicates by percentage how close the policies and tags for your
101
- * request are to the upper size limit.
102
- * </p>
103
- * </note>
104
- * <p>You can pass a session tag with the same key as a tag that is
105
- * attached to the role. When you do, the session tag overrides the role tag with the same
106
- * key.</p>
107
- * <p>An administrator must grant you the permissions necessary to pass session tags. The
108
- * administrator can also create granular permissions to allow you to pass only specific
109
- * session tags. For more information, see <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/tutorial_attribute-based-access-control.html">Tutorial: Using Tags
110
- * for Attribute-Based Access Control</a> in the
111
- * <i>IAM User Guide</i>.</p>
112
- * <p>You can set the session tags as transitive. Transitive tags persist during role
113
- * chaining. For more information, see <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/id_session-tags.html#id_session-tags_role-chaining">Chaining Roles
114
- * with Session Tags</a> in the <i>IAM User Guide</i>.</p>
115
- * <p>
116
- * <b>Identities</b>
117
- * </p>
118
- * <p>Before your application can call <code>AssumeRoleWithWebIdentity</code>, you must have
119
- * an identity token from a supported identity provider and create a role that the application
120
- * can assume. The role that your application assumes must trust the identity provider that is
121
- * associated with the identity token. In other words, the identity provider must be specified
122
- * in the role's trust policy. </p>
123
- * <important>
124
- * <p>Calling <code>AssumeRoleWithWebIdentity</code> can result in an entry in your
125
- * CloudTrail logs. The entry includes the <a href="http://openid.net/specs/openid-connect-core-1_0.html#Claims">Subject</a> of
126
- * the provided web identity token. We recommend that you avoid using any personally
127
- * identifiable information (PII) in this field. For example, you could instead use a GUID
128
- * or a pairwise identifier, as <a href="http://openid.net/specs/openid-connect-core-1_0.html#SubjectIDTypes">suggested
129
- * in the OIDC specification</a>.</p>
130
- * </important>
131
- * <p>For more information about how to use web identity federation and the
132
- * <code>AssumeRoleWithWebIdentity</code> API, see the following resources: </p>
133
- * <ul>
134
- * <li>
135
- * <p>
136
- * <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/id_roles_providers_oidc_manual.html">Using Web Identity Federation API Operations for Mobile Apps</a> and <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_request.html#api_assumerolewithwebidentity">Federation Through a Web-based Identity Provider</a>. </p>
137
- * </li>
138
- * <li>
139
- * <p>
140
- * <a href="https://aws.amazon.com/blogs/aws/the-aws-web-identity-federation-playground/"> Web Identity Federation Playground</a>. Walk through the process of
141
- * authenticating through Login with Amazon, Facebook, or Google, getting temporary
142
- * security credentials, and then using those credentials to make a request to Amazon Web Services.
143
- * </p>
144
- * </li>
145
- * <li>
146
- * <p>
147
- * <a href="http://aws.amazon.com/sdkforios/">Amazon Web Services SDK for iOS Developer Guide</a> and <a href="http://aws.amazon.com/sdkforandroid/">Amazon Web Services SDK for Android Developer Guide</a>. These toolkits
148
- * contain sample apps that show how to invoke the identity providers. The toolkits then
149
- * show how to use the information from these providers to get and use temporary
150
- * security credentials. </p>
151
- * </li>
152
- * <li>
153
- * <p>
154
- * <a href="http://aws.amazon.com/articles/web-identity-federation-with-mobile-applications">Web Identity
155
- * Federation with Mobile Applications</a>. This article discusses web identity
156
- * federation and shows an example of how to use web identity federation to get access
157
- * to content in Amazon S3. </p>
158
- * </li>
159
- * </ul>
160
- * @example
161
- * Use a bare-bones client and the command you need to make an API call.
162
- * ```javascript
163
- * import { STSClient, AssumeRoleWithWebIdentityCommand } from "@aws-sdk/client-sts"; // ES Modules import
164
- * // const { STSClient, AssumeRoleWithWebIdentityCommand } = require("@aws-sdk/client-sts"); // CommonJS import
165
- * const client = new STSClient(config);
166
- * const command = new AssumeRoleWithWebIdentityCommand(input);
167
- * const response = await client.send(command);
168
- * ```
169
- *
170
- * @see {@link AssumeRoleWithWebIdentityCommandInput} for command's `input` shape.
171
- * @see {@link AssumeRoleWithWebIdentityCommandOutput} for command's `response` shape.
172
- * @see {@link STSClientResolvedConfig | config} for command's `input` shape.
173
- *
174
- */
175
- export class AssumeRoleWithWebIdentityCommand extends $Command<
176
- AssumeRoleWithWebIdentityCommandInput,
177
- AssumeRoleWithWebIdentityCommandOutput,
178
- STSClientResolvedConfig
179
- > {
180
- // Start section: command_properties
181
- // End section: command_properties
182
-
183
- constructor(readonly input: AssumeRoleWithWebIdentityCommandInput) {
184
- // Start section: command_constructor
185
- super();
186
- // End section: command_constructor
187
- }
188
-
189
- /**
190
- * @internal
191
- */
192
- resolveMiddleware(
193
- clientStack: MiddlewareStack<ServiceInputTypes, ServiceOutputTypes>,
194
- configuration: STSClientResolvedConfig,
195
- options?: __HttpHandlerOptions
196
- ): Handler<AssumeRoleWithWebIdentityCommandInput, AssumeRoleWithWebIdentityCommandOutput> {
197
- this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize));
198
-
199
- const stack = clientStack.concat(this.middlewareStack);
200
-
201
- const { logger } = configuration;
202
- const clientName = "STSClient";
203
- const commandName = "AssumeRoleWithWebIdentityCommand";
204
- const handlerExecutionContext: HandlerExecutionContext = {
205
- logger,
206
- clientName,
207
- commandName,
208
- inputFilterSensitiveLog: AssumeRoleWithWebIdentityRequest.filterSensitiveLog,
209
- outputFilterSensitiveLog: AssumeRoleWithWebIdentityResponse.filterSensitiveLog,
210
- };
211
- const { requestHandler } = configuration;
212
- return stack.resolve(
213
- (request: FinalizeHandlerArguments<any>) =>
214
- requestHandler.handle(request.request as __HttpRequest, options || {}),
215
- handlerExecutionContext
216
- );
217
- }
218
-
219
- private serialize(input: AssumeRoleWithWebIdentityCommandInput, context: __SerdeContext): Promise<__HttpRequest> {
220
- return serializeAws_queryAssumeRoleWithWebIdentityCommand(input, context);
221
- }
222
-
223
- private deserialize(
224
- output: __HttpResponse,
225
- context: __SerdeContext
226
- ): Promise<AssumeRoleWithWebIdentityCommandOutput> {
227
- return deserializeAws_queryAssumeRoleWithWebIdentityCommand(output, context);
228
- }
229
-
230
- // Start section: command_body_extra
231
- // End section: command_body_extra
232
- }
@@ -1,134 +0,0 @@
1
- import { STSClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../STSClient";
2
- import { DecodeAuthorizationMessageRequest, DecodeAuthorizationMessageResponse } from "../models/models_0";
3
- import {
4
- deserializeAws_queryDecodeAuthorizationMessageCommand,
5
- serializeAws_queryDecodeAuthorizationMessageCommand,
6
- } from "../protocols/Aws_query";
7
- import { getSerdePlugin } from "@aws-sdk/middleware-serde";
8
- import { getAwsAuthPlugin } from "@aws-sdk/middleware-signing";
9
- import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http";
10
- import { Command as $Command } from "@aws-sdk/smithy-client";
11
- import {
12
- FinalizeHandlerArguments,
13
- Handler,
14
- HandlerExecutionContext,
15
- MiddlewareStack,
16
- HttpHandlerOptions as __HttpHandlerOptions,
17
- MetadataBearer as __MetadataBearer,
18
- SerdeContext as __SerdeContext,
19
- } from "@aws-sdk/types";
20
-
21
- export interface DecodeAuthorizationMessageCommandInput extends DecodeAuthorizationMessageRequest {}
22
- export interface DecodeAuthorizationMessageCommandOutput extends DecodeAuthorizationMessageResponse, __MetadataBearer {}
23
-
24
- /**
25
- * <p>Decodes additional information about the authorization status of a request from an
26
- * encoded message returned in response to an Amazon Web Services request.</p>
27
- * <p>For example, if a user is not authorized to perform an operation that he or she has
28
- * requested, the request returns a <code>Client.UnauthorizedOperation</code> response (an
29
- * HTTP 403 response). Some Amazon Web Services operations additionally return an encoded message that can
30
- * provide details about this authorization failure. </p>
31
- * <note>
32
- * <p>Only certain Amazon Web Services operations return an encoded authorization message. The
33
- * documentation for an individual operation indicates whether that operation returns an
34
- * encoded message in addition to returning an HTTP code.</p>
35
- * </note>
36
- * <p>The message is encoded because the details of the authorization status can constitute
37
- * privileged information that the user who requested the operation should not see. To decode
38
- * an authorization status message, a user must be granted permissions via an IAM policy to
39
- * request the <code>DecodeAuthorizationMessage</code>
40
- * (<code>sts:DecodeAuthorizationMessage</code>) action. </p>
41
- * <p>The decoded message includes the following type of information:</p>
42
- * <ul>
43
- * <li>
44
- * <p>Whether the request was denied due to an explicit deny or due to the absence of an
45
- * explicit allow. For more information, see <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_policies_evaluation-logic.html#policy-eval-denyallow">Determining Whether a Request is Allowed or Denied</a> in the
46
- * <i>IAM User Guide</i>. </p>
47
- * </li>
48
- * <li>
49
- * <p>The principal who made the request.</p>
50
- * </li>
51
- * <li>
52
- * <p>The requested action.</p>
53
- * </li>
54
- * <li>
55
- * <p>The requested resource.</p>
56
- * </li>
57
- * <li>
58
- * <p>The values of condition keys in the context of the user's request.</p>
59
- * </li>
60
- * </ul>
61
- * @example
62
- * Use a bare-bones client and the command you need to make an API call.
63
- * ```javascript
64
- * import { STSClient, DecodeAuthorizationMessageCommand } from "@aws-sdk/client-sts"; // ES Modules import
65
- * // const { STSClient, DecodeAuthorizationMessageCommand } = require("@aws-sdk/client-sts"); // CommonJS import
66
- * const client = new STSClient(config);
67
- * const command = new DecodeAuthorizationMessageCommand(input);
68
- * const response = await client.send(command);
69
- * ```
70
- *
71
- * @see {@link DecodeAuthorizationMessageCommandInput} for command's `input` shape.
72
- * @see {@link DecodeAuthorizationMessageCommandOutput} for command's `response` shape.
73
- * @see {@link STSClientResolvedConfig | config} for command's `input` shape.
74
- *
75
- */
76
- export class DecodeAuthorizationMessageCommand extends $Command<
77
- DecodeAuthorizationMessageCommandInput,
78
- DecodeAuthorizationMessageCommandOutput,
79
- STSClientResolvedConfig
80
- > {
81
- // Start section: command_properties
82
- // End section: command_properties
83
-
84
- constructor(readonly input: DecodeAuthorizationMessageCommandInput) {
85
- // Start section: command_constructor
86
- super();
87
- // End section: command_constructor
88
- }
89
-
90
- /**
91
- * @internal
92
- */
93
- resolveMiddleware(
94
- clientStack: MiddlewareStack<ServiceInputTypes, ServiceOutputTypes>,
95
- configuration: STSClientResolvedConfig,
96
- options?: __HttpHandlerOptions
97
- ): Handler<DecodeAuthorizationMessageCommandInput, DecodeAuthorizationMessageCommandOutput> {
98
- this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize));
99
- this.middlewareStack.use(getAwsAuthPlugin(configuration));
100
-
101
- const stack = clientStack.concat(this.middlewareStack);
102
-
103
- const { logger } = configuration;
104
- const clientName = "STSClient";
105
- const commandName = "DecodeAuthorizationMessageCommand";
106
- const handlerExecutionContext: HandlerExecutionContext = {
107
- logger,
108
- clientName,
109
- commandName,
110
- inputFilterSensitiveLog: DecodeAuthorizationMessageRequest.filterSensitiveLog,
111
- outputFilterSensitiveLog: DecodeAuthorizationMessageResponse.filterSensitiveLog,
112
- };
113
- const { requestHandler } = configuration;
114
- return stack.resolve(
115
- (request: FinalizeHandlerArguments<any>) =>
116
- requestHandler.handle(request.request as __HttpRequest, options || {}),
117
- handlerExecutionContext
118
- );
119
- }
120
-
121
- private serialize(input: DecodeAuthorizationMessageCommandInput, context: __SerdeContext): Promise<__HttpRequest> {
122
- return serializeAws_queryDecodeAuthorizationMessageCommand(input, context);
123
- }
124
-
125
- private deserialize(
126
- output: __HttpResponse,
127
- context: __SerdeContext
128
- ): Promise<DecodeAuthorizationMessageCommandOutput> {
129
- return deserializeAws_queryDecodeAuthorizationMessageCommand(output, context);
130
- }
131
-
132
- // Start section: command_body_extra
133
- // End section: command_body_extra
134
- }
@@ -1,113 +0,0 @@
1
- import { STSClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../STSClient";
2
- import { GetAccessKeyInfoRequest, GetAccessKeyInfoResponse } from "../models/models_0";
3
- import {
4
- deserializeAws_queryGetAccessKeyInfoCommand,
5
- serializeAws_queryGetAccessKeyInfoCommand,
6
- } from "../protocols/Aws_query";
7
- import { getSerdePlugin } from "@aws-sdk/middleware-serde";
8
- import { getAwsAuthPlugin } from "@aws-sdk/middleware-signing";
9
- import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http";
10
- import { Command as $Command } from "@aws-sdk/smithy-client";
11
- import {
12
- FinalizeHandlerArguments,
13
- Handler,
14
- HandlerExecutionContext,
15
- MiddlewareStack,
16
- HttpHandlerOptions as __HttpHandlerOptions,
17
- MetadataBearer as __MetadataBearer,
18
- SerdeContext as __SerdeContext,
19
- } from "@aws-sdk/types";
20
-
21
- export interface GetAccessKeyInfoCommandInput extends GetAccessKeyInfoRequest {}
22
- export interface GetAccessKeyInfoCommandOutput extends GetAccessKeyInfoResponse, __MetadataBearer {}
23
-
24
- /**
25
- * <p>Returns the account identifier for the specified access key ID.</p>
26
- * <p>Access keys consist of two parts: an access key ID (for example,
27
- * <code>AKIAIOSFODNN7EXAMPLE</code>) and a secret access key (for example,
28
- * <code>wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY</code>). For more information about
29
- * access keys, see <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_access-keys.html">Managing Access Keys for IAM
30
- * Users</a> in the <i>IAM User Guide</i>.</p>
31
- * <p>When you pass an access key ID to this operation, it returns the ID of the Amazon Web Services
32
- * account to which the keys belong. Access key IDs beginning with <code>AKIA</code> are
33
- * long-term credentials for an IAM user or the Amazon Web Services account root user. Access key IDs
34
- * beginning with <code>ASIA</code> are temporary credentials that are created using STS
35
- * operations. If the account in the response belongs to you, you can sign in as the root
36
- * user and review your root user access keys. Then, you can pull a <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_getting-report.html">credentials report</a> to learn which IAM user owns the keys. To learn who
37
- * requested the temporary credentials for an <code>ASIA</code> access key, view the STS
38
- * events in your <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/cloudtrail-integration.html">CloudTrail logs</a> in the
39
- * <i>IAM User Guide</i>.</p>
40
- * <p>This operation does not indicate the state of the access key. The key might be active,
41
- * inactive, or deleted. Active keys might not have permissions to perform an operation.
42
- * Providing a deleted access key might return an error that the key doesn't exist.</p>
43
- * @example
44
- * Use a bare-bones client and the command you need to make an API call.
45
- * ```javascript
46
- * import { STSClient, GetAccessKeyInfoCommand } from "@aws-sdk/client-sts"; // ES Modules import
47
- * // const { STSClient, GetAccessKeyInfoCommand } = require("@aws-sdk/client-sts"); // CommonJS import
48
- * const client = new STSClient(config);
49
- * const command = new GetAccessKeyInfoCommand(input);
50
- * const response = await client.send(command);
51
- * ```
52
- *
53
- * @see {@link GetAccessKeyInfoCommandInput} for command's `input` shape.
54
- * @see {@link GetAccessKeyInfoCommandOutput} for command's `response` shape.
55
- * @see {@link STSClientResolvedConfig | config} for command's `input` shape.
56
- *
57
- */
58
- export class GetAccessKeyInfoCommand extends $Command<
59
- GetAccessKeyInfoCommandInput,
60
- GetAccessKeyInfoCommandOutput,
61
- STSClientResolvedConfig
62
- > {
63
- // Start section: command_properties
64
- // End section: command_properties
65
-
66
- constructor(readonly input: GetAccessKeyInfoCommandInput) {
67
- // Start section: command_constructor
68
- super();
69
- // End section: command_constructor
70
- }
71
-
72
- /**
73
- * @internal
74
- */
75
- resolveMiddleware(
76
- clientStack: MiddlewareStack<ServiceInputTypes, ServiceOutputTypes>,
77
- configuration: STSClientResolvedConfig,
78
- options?: __HttpHandlerOptions
79
- ): Handler<GetAccessKeyInfoCommandInput, GetAccessKeyInfoCommandOutput> {
80
- this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize));
81
- this.middlewareStack.use(getAwsAuthPlugin(configuration));
82
-
83
- const stack = clientStack.concat(this.middlewareStack);
84
-
85
- const { logger } = configuration;
86
- const clientName = "STSClient";
87
- const commandName = "GetAccessKeyInfoCommand";
88
- const handlerExecutionContext: HandlerExecutionContext = {
89
- logger,
90
- clientName,
91
- commandName,
92
- inputFilterSensitiveLog: GetAccessKeyInfoRequest.filterSensitiveLog,
93
- outputFilterSensitiveLog: GetAccessKeyInfoResponse.filterSensitiveLog,
94
- };
95
- const { requestHandler } = configuration;
96
- return stack.resolve(
97
- (request: FinalizeHandlerArguments<any>) =>
98
- requestHandler.handle(request.request as __HttpRequest, options || {}),
99
- handlerExecutionContext
100
- );
101
- }
102
-
103
- private serialize(input: GetAccessKeyInfoCommandInput, context: __SerdeContext): Promise<__HttpRequest> {
104
- return serializeAws_queryGetAccessKeyInfoCommand(input, context);
105
- }
106
-
107
- private deserialize(output: __HttpResponse, context: __SerdeContext): Promise<GetAccessKeyInfoCommandOutput> {
108
- return deserializeAws_queryGetAccessKeyInfoCommand(output, context);
109
- }
110
-
111
- // Start section: command_body_extra
112
- // End section: command_body_extra
113
- }
@@ -1,105 +0,0 @@
1
- import { STSClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../STSClient";
2
- import { GetCallerIdentityRequest, GetCallerIdentityResponse } from "../models/models_0";
3
- import {
4
- deserializeAws_queryGetCallerIdentityCommand,
5
- serializeAws_queryGetCallerIdentityCommand,
6
- } from "../protocols/Aws_query";
7
- import { getSerdePlugin } from "@aws-sdk/middleware-serde";
8
- import { getAwsAuthPlugin } from "@aws-sdk/middleware-signing";
9
- import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http";
10
- import { Command as $Command } from "@aws-sdk/smithy-client";
11
- import {
12
- FinalizeHandlerArguments,
13
- Handler,
14
- HandlerExecutionContext,
15
- MiddlewareStack,
16
- HttpHandlerOptions as __HttpHandlerOptions,
17
- MetadataBearer as __MetadataBearer,
18
- SerdeContext as __SerdeContext,
19
- } from "@aws-sdk/types";
20
-
21
- export interface GetCallerIdentityCommandInput extends GetCallerIdentityRequest {}
22
- export interface GetCallerIdentityCommandOutput extends GetCallerIdentityResponse, __MetadataBearer {}
23
-
24
- /**
25
- * <p>Returns details about the IAM user or role whose credentials are used to call the
26
- * operation.</p>
27
- * <note>
28
- * <p>No permissions are required to perform this operation. If an administrator adds a
29
- * policy to your IAM user or role that explicitly denies access to the
30
- * <code>sts:GetCallerIdentity</code> action, you can still perform this operation.
31
- * Permissions are not required because the same information is returned when an IAM
32
- * user or role is denied access. To view an example response, see <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/troubleshoot_general.html#troubleshoot_general_access-denied-delete-mfa">I Am Not Authorized to Perform: iam:DeleteVirtualMFADevice</a> in the
33
- * <i>IAM User Guide</i>.</p>
34
- * </note>
35
- * @example
36
- * Use a bare-bones client and the command you need to make an API call.
37
- * ```javascript
38
- * import { STSClient, GetCallerIdentityCommand } from "@aws-sdk/client-sts"; // ES Modules import
39
- * // const { STSClient, GetCallerIdentityCommand } = require("@aws-sdk/client-sts"); // CommonJS import
40
- * const client = new STSClient(config);
41
- * const command = new GetCallerIdentityCommand(input);
42
- * const response = await client.send(command);
43
- * ```
44
- *
45
- * @see {@link GetCallerIdentityCommandInput} for command's `input` shape.
46
- * @see {@link GetCallerIdentityCommandOutput} for command's `response` shape.
47
- * @see {@link STSClientResolvedConfig | config} for command's `input` shape.
48
- *
49
- */
50
- export class GetCallerIdentityCommand extends $Command<
51
- GetCallerIdentityCommandInput,
52
- GetCallerIdentityCommandOutput,
53
- STSClientResolvedConfig
54
- > {
55
- // Start section: command_properties
56
- // End section: command_properties
57
-
58
- constructor(readonly input: GetCallerIdentityCommandInput) {
59
- // Start section: command_constructor
60
- super();
61
- // End section: command_constructor
62
- }
63
-
64
- /**
65
- * @internal
66
- */
67
- resolveMiddleware(
68
- clientStack: MiddlewareStack<ServiceInputTypes, ServiceOutputTypes>,
69
- configuration: STSClientResolvedConfig,
70
- options?: __HttpHandlerOptions
71
- ): Handler<GetCallerIdentityCommandInput, GetCallerIdentityCommandOutput> {
72
- this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize));
73
- this.middlewareStack.use(getAwsAuthPlugin(configuration));
74
-
75
- const stack = clientStack.concat(this.middlewareStack);
76
-
77
- const { logger } = configuration;
78
- const clientName = "STSClient";
79
- const commandName = "GetCallerIdentityCommand";
80
- const handlerExecutionContext: HandlerExecutionContext = {
81
- logger,
82
- clientName,
83
- commandName,
84
- inputFilterSensitiveLog: GetCallerIdentityRequest.filterSensitiveLog,
85
- outputFilterSensitiveLog: GetCallerIdentityResponse.filterSensitiveLog,
86
- };
87
- const { requestHandler } = configuration;
88
- return stack.resolve(
89
- (request: FinalizeHandlerArguments<any>) =>
90
- requestHandler.handle(request.request as __HttpRequest, options || {}),
91
- handlerExecutionContext
92
- );
93
- }
94
-
95
- private serialize(input: GetCallerIdentityCommandInput, context: __SerdeContext): Promise<__HttpRequest> {
96
- return serializeAws_queryGetCallerIdentityCommand(input, context);
97
- }
98
-
99
- private deserialize(output: __HttpResponse, context: __SerdeContext): Promise<GetCallerIdentityCommandOutput> {
100
- return deserializeAws_queryGetCallerIdentityCommand(output, context);
101
- }
102
-
103
- // Start section: command_body_extra
104
- // End section: command_body_extra
105
- }