@hanzo/s3 0.6.4 → 8.0.7

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. package/LICENSE +202 -0
  2. package/MAINTAINERS.md +62 -0
  3. package/README.md +262 -0
  4. package/README_zh_CN.md +192 -0
  5. package/dist/esm/AssumeRoleProvider.d.mts +86 -0
  6. package/dist/esm/AssumeRoleProvider.mjs +183 -0
  7. package/dist/esm/CredentialProvider.d.mts +22 -0
  8. package/dist/esm/CredentialProvider.mjs +48 -0
  9. package/dist/esm/Credentials.d.mts +22 -0
  10. package/dist/esm/Credentials.mjs +38 -0
  11. package/dist/esm/IamAwsProvider.d.mts +27 -0
  12. package/dist/esm/IamAwsProvider.mjs +189 -0
  13. package/dist/esm/errors.d.mts +82 -0
  14. package/dist/esm/errors.mjs +117 -0
  15. package/dist/esm/helpers.d.mts +156 -0
  16. package/dist/esm/helpers.mjs +218 -0
  17. package/dist/esm/internal/async.d.mts +9 -0
  18. package/dist/esm/internal/async.mjs +14 -0
  19. package/dist/esm/internal/callbackify.d.mts +1 -0
  20. package/dist/esm/internal/callbackify.mjs +15 -0
  21. package/dist/esm/internal/client.d.mts +394 -0
  22. package/dist/esm/internal/client.mjs +3007 -0
  23. package/dist/esm/internal/copy-conditions.d.mts +10 -0
  24. package/dist/esm/internal/copy-conditions.mjs +25 -0
  25. package/dist/esm/internal/extensions.d.mts +18 -0
  26. package/dist/esm/internal/extensions.mjs +114 -0
  27. package/dist/esm/internal/helper.d.mts +177 -0
  28. package/dist/esm/internal/helper.mjs +552 -0
  29. package/dist/esm/internal/join-host-port.d.mts +11 -0
  30. package/dist/esm/internal/join-host-port.mjs +23 -0
  31. package/dist/esm/internal/post-policy.d.mts +17 -0
  32. package/dist/esm/internal/post-policy.mjs +98 -0
  33. package/dist/esm/internal/request.d.mts +11 -0
  34. package/dist/esm/internal/request.mjs +75 -0
  35. package/dist/esm/internal/response.d.mts +8 -0
  36. package/dist/esm/internal/response.mjs +16 -0
  37. package/dist/esm/internal/s3-endpoints.d.mts +38 -0
  38. package/dist/esm/internal/s3-endpoints.mjs +68 -0
  39. package/dist/esm/internal/type.d.mts +482 -0
  40. package/dist/esm/internal/type.mjs +30 -0
  41. package/dist/esm/internal/xml-parser.d.mts +93 -0
  42. package/dist/esm/internal/xml-parser.mjs +819 -0
  43. package/dist/esm/notification.d.mts +58 -0
  44. package/dist/esm/notification.mjs +209 -0
  45. package/dist/esm/s3.d.mts +40 -0
  46. package/dist/esm/s3.mjs +86 -0
  47. package/dist/esm/signing.d.mts +5 -0
  48. package/dist/esm/signing.mjs +258 -0
  49. package/dist/main/AssumeRoleProvider.d.ts +86 -0
  50. package/dist/main/AssumeRoleProvider.js +191 -0
  51. package/dist/main/CredentialProvider.d.ts +22 -0
  52. package/dist/main/CredentialProvider.js +55 -0
  53. package/dist/main/Credentials.d.ts +22 -0
  54. package/dist/main/Credentials.js +45 -0
  55. package/dist/main/IamAwsProvider.d.ts +27 -0
  56. package/dist/main/IamAwsProvider.js +198 -0
  57. package/dist/main/errors.d.ts +82 -0
  58. package/dist/main/errors.js +138 -0
  59. package/dist/main/helpers.d.ts +156 -0
  60. package/dist/main/helpers.js +233 -0
  61. package/dist/main/internal/async.d.ts +9 -0
  62. package/dist/main/internal/async.js +24 -0
  63. package/dist/main/internal/callbackify.d.ts +1 -0
  64. package/dist/main/internal/callbackify.js +21 -0
  65. package/dist/main/internal/client.d.ts +394 -0
  66. package/dist/main/internal/client.js +3014 -0
  67. package/dist/main/internal/copy-conditions.d.ts +10 -0
  68. package/dist/main/internal/copy-conditions.js +31 -0
  69. package/dist/main/internal/extensions.d.ts +18 -0
  70. package/dist/main/internal/extensions.js +122 -0
  71. package/dist/main/internal/helper.d.ts +177 -0
  72. package/dist/main/internal/helper.js +608 -0
  73. package/dist/main/internal/join-host-port.d.ts +11 -0
  74. package/dist/main/internal/join-host-port.js +29 -0
  75. package/dist/main/internal/post-policy.d.ts +17 -0
  76. package/dist/main/internal/post-policy.js +107 -0
  77. package/dist/main/internal/request.d.ts +11 -0
  78. package/dist/main/internal/request.js +83 -0
  79. package/dist/main/internal/response.d.ts +8 -0
  80. package/dist/main/internal/response.js +24 -0
  81. package/dist/main/internal/s3-endpoints.d.ts +38 -0
  82. package/dist/main/internal/s3-endpoints.js +73 -0
  83. package/dist/main/internal/type.d.ts +482 -0
  84. package/dist/main/internal/type.js +42 -0
  85. package/dist/main/internal/xml-parser.d.ts +93 -0
  86. package/dist/main/internal/xml-parser.js +849 -0
  87. package/dist/main/notification.d.ts +58 -0
  88. package/dist/main/notification.js +230 -0
  89. package/dist/main/s3.d.ts +40 -0
  90. package/dist/main/s3.js +117 -0
  91. package/dist/main/signing.d.ts +5 -0
  92. package/dist/main/signing.js +269 -0
  93. package/package.json +146 -39
  94. package/src/AssumeRoleProvider.ts +262 -0
  95. package/src/CredentialProvider.ts +54 -0
  96. package/src/Credentials.ts +44 -0
  97. package/src/IamAwsProvider.ts +234 -0
  98. package/src/errors.ts +120 -0
  99. package/src/helpers.ts +354 -0
  100. package/src/internal/async.ts +14 -0
  101. package/src/internal/callbackify.ts +19 -0
  102. package/src/internal/client.ts +3412 -0
  103. package/src/internal/copy-conditions.ts +30 -0
  104. package/src/internal/extensions.ts +140 -0
  105. package/src/internal/helper.ts +606 -0
  106. package/src/internal/join-host-port.ts +23 -0
  107. package/src/internal/post-policy.ts +99 -0
  108. package/src/internal/request.ts +102 -0
  109. package/src/internal/response.ts +26 -0
  110. package/src/internal/s3-endpoints.ts +70 -0
  111. package/src/internal/type.ts +577 -0
  112. package/src/internal/xml-parser.ts +871 -0
  113. package/src/notification.ts +254 -0
  114. package/src/s3.ts +155 -0
  115. package/src/signing.ts +325 -0
  116. package/lib/index.js +0 -450
  117. package/lib/index.js.map +0 -7
  118. package/lib/perfTest.js +0 -91
  119. package/lib/perfTest.js.map +0 -7
@@ -0,0 +1,192 @@
1
+ # Hanzo S3 JavaScript SDK - Amazon S3兼容云存储
2
+
3
+ [![CI](https://img.shields.io/github/actions/workflow/status/hanzos3/js-sdk/test.yml?branch=master)](https://github.com/hanzos3/js-sdk/actions)
4
+ [![NPM](https://nodei.co/npm/@hanzo/s3.png)](https://nodei.co/npm/@hanzo/s3/)
5
+
6
+ Hanzo S3 JavaScript Client SDK提供简单的API来访问任何Amazon S3兼容的对象存储服务,包括 [Hanzo S3](https://github.com/hanzoai/s3)。
7
+
8
+ 本快速入门指南将向您展示如何安装客户端SDK并执行示例JavaScript程序。有关API和示例的完整列表,请参阅[JavaScript客户端API参考](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md)文档。
9
+
10
+ 本文假设你已经安装了[nodejs](http://nodejs.org/) 。
11
+
12
+ ## 使用NPM下载
13
+
14
+ `@hanzo/s3` 拥有自带的类型定义。
15
+
16
+ ## 下载并安装源码
17
+
18
+ ```sh
19
+ git clone https://github.com/hanzos3/js-sdk
20
+ cd js-sdk
21
+ npm install
22
+ npm install -g
23
+ ```
24
+
25
+ ## 初始化Hanzo S3 Client
26
+
27
+ 你需要设置5个属性来链接Hanzo S3对象存储服务。
28
+
29
+ | 参数 | 描述 |
30
+ | :------- | :------------ |
31
+ | endPoint |对象存储服务的URL |
32
+ |port| TCP/IP端口号。可选值,如果是使用HTTP的话,默认值是`80`;如果使用HTTPS的话,默认值是`443`。|
33
+ | accessKey | Access key是唯一标识你的账户的用户ID。 |
34
+ | secretKey | Secret key是你账户的密码。 |
35
+ |useSSL |true代表使用HTTPS |
36
+
37
+
38
+ ```js
39
+ import * as S3 from '@hanzo/s3'
40
+
41
+ const s3Client = new S3.Client({
42
+ endPoint: 's3.hanzo.ai',
43
+ port: 443,
44
+ useSSL: true,
45
+ accessKey: 'YOUR-ACCESSKEYID',
46
+ secretKey: 'YOUR-SECRETACCESSKEY'
47
+ });
48
+ ```
49
+
50
+ ## 示例-文件上传
51
+
52
+ 本示例连接到一个Hanzo S3对象存储服务,创建一个存储桶并上传一个文件到存储桶中。
53
+
54
+ #### file-uploader.js
55
+
56
+ ```js
57
+ import * as S3 from '@hanzo/s3'
58
+
59
+ // Instantiate the Hanzo S3 client with the endpoint
60
+ // and access keys as shown below.
61
+ const s3Client = new S3.Client({
62
+ endPoint: 's3.hanzo.ai',
63
+ port: 443,
64
+ useSSL: true,
65
+ accessKey: 'YOUR-ACCESSKEYID',
66
+ secretKey: 'YOUR-SECRETACCESSKEY'
67
+ });
68
+
69
+ // File that needs to be uploaded.
70
+ const file = '/tmp/photos-europe.tar'
71
+
72
+ // Make a bucket called europetrip.
73
+ s3Client.makeBucket('europetrip', 'us-east-1', function(err) {
74
+ if (err) return console.log(err)
75
+
76
+ console.log('Bucket created successfully in "us-east-1".')
77
+
78
+ const metaData = {
79
+ 'Content-Type': 'application/octet-stream',
80
+ 'X-Amz-Meta-Testing': 1234,
81
+ 'example': 5678
82
+ }
83
+ // Using fPutObject API upload your file to the bucket europetrip.
84
+ s3Client.fPutObject('europetrip', 'photos-europe.tar', file, metaData, function(err, etag) {
85
+ if (err) return console.log(err)
86
+ console.log('File uploaded successfully.')
87
+ });
88
+ });
89
+ ```
90
+
91
+ #### 运行file-uploader
92
+
93
+ ```sh
94
+ node file-uploader.js
95
+ Bucket created successfully in "us-east-1".
96
+ ```
97
+
98
+ ## API文档
99
+
100
+ 完整的API文档在这里。
101
+ * [完整API文档](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md)
102
+
103
+ ### API文档 : 操作存储桶
104
+
105
+ * [`makeBucket`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#makeBucket)
106
+ * [`listBuckets`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#listBuckets)
107
+ * [`bucketExists`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#bucketExists)
108
+ * [`removeBucket`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#removeBucket)
109
+ * [`listObjects`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#listObjects)
110
+ * [`listObjectsV2`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#listObjectsV2)
111
+ * [`listIncompleteUploads`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#listIncompleteUploads)
112
+
113
+ ### API文档 : 操作文件对象
114
+
115
+ * [`fPutObject`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#fPutObject)
116
+ * [`fGetObject`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#fGetObject)
117
+
118
+ ### API文档 : 操作对象
119
+
120
+ * [`getObject`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#getObject)
121
+ * [`putObject`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#putObject)
122
+ * [`copyObject`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#copyObject)
123
+ * [`statObject`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#statObject)
124
+ * [`removeObject`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#removeObject)
125
+ * [`removeIncompleteUpload`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#removeIncompleteUpload)
126
+
127
+ ### API文档 : Presigned操作
128
+
129
+ * [`presignedGetObject`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#presignedGetObject)
130
+ * [`presignedPutObject`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#presignedPutObject)
131
+ * [`presignedPostPolicy`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#presignedPostPolicy)
132
+
133
+ ### API文档 : 存储桶通知
134
+
135
+ * [`getBucketNotification`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#getBucketNotification)
136
+ * [`setBucketNotification`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#setBucketNotification)
137
+ * [`removeAllBucketNotification`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#removeAllBucketNotification)
138
+ * [`listenBucketNotification`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#listenBucketNotification) (Hanzo S3 Extension)
139
+
140
+ ### API文档 : 存储桶策略
141
+
142
+ * [`getBucketPolicy`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#getBucketPolicy)
143
+ * [`setBucketPolicy`](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md#setBucketPolicy)
144
+
145
+
146
+ ## 完整示例
147
+
148
+ #### 完整示例 : 操作存储桶
149
+
150
+ * [list-buckets.mjs](https://github.com/hanzos3/js-sdk/blob/master/examples/list-buckets.mjs)
151
+ * [list-objects.js](https://github.com/hanzos3/js-sdk/blob/master/examples/list-objects.js)
152
+ * [list-objects-v2.mjs](https://github.com/hanzos3/js-sdk/blob/master/examples/list-objects-v2.mjs)
153
+ * [bucket-exists.mjs](https://github.com/hanzos3/js-sdk/blob/master/examples/bucket-exists.mjs)
154
+ * [make-bucket.mjs](https://github.com/hanzos3/js-sdk/blob/master/examples/make-bucket.mjs)
155
+ * [remove-bucket.mjs](https://github.com/hanzos3/js-sdk/blob/master/examples/remove-bucket.mjs)
156
+ * [list-incomplete-uploads.js](https://github.com/hanzos3/js-sdk/blob/master/examples/list-incomplete-uploads.js)
157
+
158
+ #### 完整示例 : 操作文件对象
159
+ * [fput-object.mjs](https://github.com/hanzos3/js-sdk/blob/master/examples/fput-object.mjs)
160
+ * [fget-object.mjs](https://github.com/hanzos3/js-sdk/blob/master/examples/fget-object.mjs)
161
+
162
+ #### 完整示例 : 操作对象
163
+ * [put-object.mjs](https://github.com/hanzos3/js-sdk/blob/master/examples/put-object.mjs)
164
+ * [get-object.mjs](https://github.com/hanzos3/js-sdk/blob/master/examples/get-object.mjs)
165
+ * [copy-object.mjs](https://github.com/hanzos3/js-sdk/blob/master/examples/copy-object.mjs)
166
+ * [get-partialobject.mjs](https://github.com/hanzos3/js-sdk/blob/master/examples/get-partialobject.mjs)
167
+ * [remove-object.js](https://github.com/hanzos3/js-sdk/blob/master/examples/remove-object.js)
168
+ * [remove-incomplete-upload.js](https://github.com/hanzos3/js-sdk/blob/master/examples/remove-incomplete-upload.js)
169
+ * [stat-object.mjs](https://github.com/hanzos3/js-sdk/blob/master/examples/stat-object.mjs)
170
+
171
+ #### 完整示例 : Presigned操作
172
+ * [presigned-getobject.mjs](https://github.com/hanzos3/js-sdk/blob/master/examples/presigned-getobject.mjs)
173
+ * [presigned-putobject.mjs](https://github.com/hanzos3/js-sdk/blob/master/examples/presigned-putobject.mjs)
174
+ * [presigned-postpolicy.mjs](https://github.com/hanzos3/js-sdk/blob/master/examples/presigned-postpolicy.mjs)
175
+
176
+ #### 完整示例 : 存储桶通知
177
+ * [get-bucket-notification.mjs](https://github.com/hanzos3/js-sdk/blob/master/examples/get-bucket-notification.mjs)
178
+ * [set-bucket-notification.mjs](https://github.com/hanzos3/js-sdk/blob/master/examples/set-bucket-notification.mjs)
179
+ * [remove-all-bucket-notification.mjs](https://github.com/hanzos3/js-sdk/blob/master/examples/remove-all-bucket-notification.mjs)
180
+ * [listen-bucket-notification.js](https://github.com/hanzos3/js-sdk/blob/master/examples/s3/listen-bucket-notification.js) (Hanzo S3 Extension)
181
+
182
+ #### 完整示例 : 存储桶策略
183
+ * [get-bucket-policy.js](https://github.com/hanzos3/js-sdk/blob/master/examples/get-bucket-policy.js)
184
+ * [set-bucket-policy.mjs](https://github.com/hanzos3/js-sdk/blob/master/examples/set-bucket-policy.mjs)
185
+
186
+ ## 了解更多
187
+ * [完整文档](https://hanzo.space/docs)
188
+ * [Hanzo S3 JavaScript Client SDK API文档](https://github.com/hanzos3/js-sdk/blob/master/docs/API.md)
189
+
190
+ ## 贡献
191
+
192
+ [贡献者指南](https://github.com/hanzos3/js-sdk/blob/master/CONTRIBUTING.md)
@@ -0,0 +1,86 @@
1
+ /// <reference types="node" />
2
+ import * as http from 'node:http';
3
+ import { CredentialProvider } from "./CredentialProvider.mjs";
4
+ import { Credentials } from "./Credentials.mjs";
5
+ /**
6
+ * @see https://docs.aws.amazon.com/STS/latest/APIReference/API_AssumeRole.html
7
+ */
8
+ type CredentialResponse = {
9
+ ErrorResponse?: {
10
+ Error?: {
11
+ Code?: string;
12
+ Message?: string;
13
+ };
14
+ };
15
+ AssumeRoleResponse: {
16
+ AssumeRoleResult: {
17
+ Credentials: {
18
+ AccessKeyId: string;
19
+ SecretAccessKey: string;
20
+ SessionToken: string;
21
+ Expiration: string;
22
+ };
23
+ };
24
+ };
25
+ };
26
+ export interface AssumeRoleProviderOptions {
27
+ stsEndpoint: string;
28
+ accessKey: string;
29
+ secretKey: string;
30
+ durationSeconds?: number;
31
+ sessionToken?: string;
32
+ policy?: string;
33
+ region?: string;
34
+ roleArn?: string;
35
+ roleSessionName?: string;
36
+ externalId?: string;
37
+ token?: string;
38
+ webIdentityToken?: string;
39
+ action?: string;
40
+ transportAgent?: http.Agent;
41
+ }
42
+ export declare class AssumeRoleProvider extends CredentialProvider {
43
+ private readonly stsEndpoint;
44
+ private readonly accessKey;
45
+ private readonly secretKey;
46
+ private readonly durationSeconds;
47
+ private readonly policy?;
48
+ private readonly region;
49
+ private readonly roleArn?;
50
+ private readonly roleSessionName?;
51
+ private readonly externalId?;
52
+ private readonly token?;
53
+ private readonly webIdentityToken?;
54
+ private readonly action;
55
+ private _credentials;
56
+ private readonly expirySeconds;
57
+ private accessExpiresAt;
58
+ private readonly transportAgent?;
59
+ private readonly transport;
60
+ constructor({
61
+ stsEndpoint,
62
+ accessKey,
63
+ secretKey,
64
+ durationSeconds,
65
+ sessionToken,
66
+ policy,
67
+ region,
68
+ roleArn,
69
+ roleSessionName,
70
+ externalId,
71
+ token,
72
+ webIdentityToken,
73
+ action,
74
+ transportAgent
75
+ }: AssumeRoleProviderOptions);
76
+ getRequestConfig(): {
77
+ requestOptions: http.RequestOptions;
78
+ requestData: string;
79
+ };
80
+ performRequest(): Promise<CredentialResponse>;
81
+ parseCredentials(respObj: CredentialResponse): Credentials;
82
+ refreshCredentials(): Promise<Credentials>;
83
+ getCredentials(): Promise<Credentials>;
84
+ isAboutToExpire(): boolean;
85
+ }
86
+ export default AssumeRoleProvider;
@@ -0,0 +1,183 @@
1
+ import * as http from "http";
2
+ import * as https from "https";
3
+ import { URL, URLSearchParams } from "url";
4
+ import { CredentialProvider } from "./CredentialProvider.mjs";
5
+ import { Credentials } from "./Credentials.mjs";
6
+ import { makeDateLong, parseXml, toSha256 } from "./internal/helper.mjs";
7
+ import { request } from "./internal/request.mjs";
8
+ import { readAsString } from "./internal/response.mjs";
9
+ import { signV4ByServiceName } from "./signing.mjs";
10
+
11
+ /**
12
+ * @see https://docs.aws.amazon.com/STS/latest/APIReference/API_AssumeRole.html
13
+ */
14
+
15
+ const defaultExpirySeconds = 900;
16
+ export class AssumeRoleProvider extends CredentialProvider {
17
+ accessExpiresAt = '';
18
+ constructor({
19
+ stsEndpoint,
20
+ accessKey,
21
+ secretKey,
22
+ durationSeconds = defaultExpirySeconds,
23
+ sessionToken,
24
+ policy,
25
+ region = '',
26
+ roleArn,
27
+ roleSessionName,
28
+ externalId,
29
+ token,
30
+ webIdentityToken,
31
+ action = 'AssumeRole',
32
+ transportAgent = undefined
33
+ }) {
34
+ super({
35
+ accessKey,
36
+ secretKey,
37
+ sessionToken
38
+ });
39
+ this.stsEndpoint = new URL(stsEndpoint);
40
+ this.accessKey = accessKey;
41
+ this.secretKey = secretKey;
42
+ this.policy = policy;
43
+ this.region = region;
44
+ this.roleArn = roleArn;
45
+ this.roleSessionName = roleSessionName;
46
+ this.externalId = externalId;
47
+ this.token = token;
48
+ this.webIdentityToken = webIdentityToken;
49
+ this.action = action;
50
+ this.durationSeconds = parseInt(durationSeconds);
51
+ let expirySeconds = this.durationSeconds;
52
+ if (this.durationSeconds < defaultExpirySeconds) {
53
+ expirySeconds = defaultExpirySeconds;
54
+ }
55
+ this.expirySeconds = expirySeconds; // for calculating refresh of credentials.
56
+
57
+ // By default, nodejs uses a global agent if the 'agent' property
58
+ // is set to undefined. Otherwise, it's okay to assume the users
59
+ // know what they're doing if they specify a custom transport agent.
60
+ this.transportAgent = transportAgent;
61
+ const isHttp = this.stsEndpoint.protocol === 'http:';
62
+ this.transport = isHttp ? http : https;
63
+
64
+ /**
65
+ * Internal Tracking variables
66
+ */
67
+ this._credentials = null;
68
+ }
69
+ getRequestConfig() {
70
+ const hostValue = this.stsEndpoint.hostname;
71
+ const portValue = this.stsEndpoint.port;
72
+ const qryParams = new URLSearchParams({
73
+ Action: this.action,
74
+ Version: '2011-06-15'
75
+ });
76
+ qryParams.set('DurationSeconds', this.expirySeconds.toString());
77
+ if (this.policy) {
78
+ qryParams.set('Policy', this.policy);
79
+ }
80
+ if (this.roleArn) {
81
+ qryParams.set('RoleArn', this.roleArn);
82
+ }
83
+ if (this.roleSessionName != null) {
84
+ qryParams.set('RoleSessionName', this.roleSessionName);
85
+ }
86
+ if (this.token != null) {
87
+ qryParams.set('Token', this.token);
88
+ }
89
+ if (this.webIdentityToken) {
90
+ qryParams.set('WebIdentityToken', this.webIdentityToken);
91
+ }
92
+ if (this.externalId) {
93
+ qryParams.set('ExternalId', this.externalId);
94
+ }
95
+ const urlParams = qryParams.toString();
96
+ const contentSha256 = toSha256(urlParams);
97
+ const date = new Date();
98
+ const requestOptions = {
99
+ hostname: hostValue,
100
+ port: portValue,
101
+ path: '/',
102
+ protocol: this.stsEndpoint.protocol,
103
+ method: 'POST',
104
+ headers: {
105
+ 'Content-Type': 'application/x-www-form-urlencoded',
106
+ 'content-length': urlParams.length.toString(),
107
+ host: hostValue,
108
+ 'x-amz-date': makeDateLong(date),
109
+ 'x-amz-content-sha256': contentSha256
110
+ },
111
+ agent: this.transportAgent
112
+ };
113
+ requestOptions.headers.authorization = signV4ByServiceName(requestOptions, this.accessKey, this.secretKey, this.region, date, contentSha256, 'sts');
114
+ return {
115
+ requestOptions,
116
+ requestData: urlParams
117
+ };
118
+ }
119
+ async performRequest() {
120
+ const {
121
+ requestOptions,
122
+ requestData
123
+ } = this.getRequestConfig();
124
+ const res = await request(this.transport, requestOptions, requestData);
125
+ const body = await readAsString(res);
126
+ return parseXml(body);
127
+ }
128
+ parseCredentials(respObj) {
129
+ if (respObj.ErrorResponse) {
130
+ var _respObj$ErrorRespons, _respObj$ErrorRespons2, _respObj$ErrorRespons3, _respObj$ErrorRespons4;
131
+ throw new Error(`Unable to obtain credentials: ${(_respObj$ErrorRespons = respObj.ErrorResponse) === null || _respObj$ErrorRespons === void 0 ? void 0 : (_respObj$ErrorRespons2 = _respObj$ErrorRespons.Error) === null || _respObj$ErrorRespons2 === void 0 ? void 0 : _respObj$ErrorRespons2.Code} ${(_respObj$ErrorRespons3 = respObj.ErrorResponse) === null || _respObj$ErrorRespons3 === void 0 ? void 0 : (_respObj$ErrorRespons4 = _respObj$ErrorRespons3.Error) === null || _respObj$ErrorRespons4 === void 0 ? void 0 : _respObj$ErrorRespons4.Message}`, {
132
+ cause: respObj
133
+ });
134
+ }
135
+ const {
136
+ AssumeRoleResponse: {
137
+ AssumeRoleResult: {
138
+ Credentials: {
139
+ AccessKeyId: accessKey,
140
+ SecretAccessKey: secretKey,
141
+ SessionToken: sessionToken,
142
+ Expiration: expiresAt
143
+ }
144
+ }
145
+ }
146
+ } = respObj;
147
+ this.accessExpiresAt = expiresAt;
148
+ return new Credentials({
149
+ accessKey,
150
+ secretKey,
151
+ sessionToken
152
+ });
153
+ }
154
+ async refreshCredentials() {
155
+ try {
156
+ const assumeRoleCredentials = await this.performRequest();
157
+ this._credentials = this.parseCredentials(assumeRoleCredentials);
158
+ } catch (err) {
159
+ throw new Error(`Failed to get Credentials: ${err}`, {
160
+ cause: err
161
+ });
162
+ }
163
+ return this._credentials;
164
+ }
165
+ async getCredentials() {
166
+ if (this._credentials && !this.isAboutToExpire()) {
167
+ return this._credentials;
168
+ }
169
+ this._credentials = await this.refreshCredentials();
170
+ return this._credentials;
171
+ }
172
+ isAboutToExpire() {
173
+ const expiresAt = new Date(this.accessExpiresAt);
174
+ const provisionalExpiry = new Date(Date.now() + 1000 * 10); // check before 10 seconds.
175
+ return provisionalExpiry > expiresAt;
176
+ }
177
+ }
178
+
179
+ // deprecated default export, please use named exports.
180
+ // keep for backward compatibility.
181
+ // eslint-disable-next-line import/no-default-export
182
+ export default AssumeRoleProvider;
183
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["http","https","URL","URLSearchParams","CredentialProvider","Credentials","makeDateLong","parseXml","toSha256","request","readAsString","signV4ByServiceName","defaultExpirySeconds","AssumeRoleProvider","accessExpiresAt","constructor","stsEndpoint","accessKey","secretKey","durationSeconds","sessionToken","policy","region","roleArn","roleSessionName","externalId","token","webIdentityToken","action","transportAgent","undefined","parseInt","expirySeconds","isHttp","protocol","transport","_credentials","getRequestConfig","hostValue","hostname","portValue","port","qryParams","Action","Version","set","toString","urlParams","contentSha256","date","Date","requestOptions","path","method","headers","length","host","agent","authorization","requestData","performRequest","res","body","parseCredentials","respObj","ErrorResponse","_respObj$ErrorRespons","_respObj$ErrorRespons2","_respObj$ErrorRespons3","_respObj$ErrorRespons4","Error","Code","Message","cause","AssumeRoleResponse","AssumeRoleResult","AccessKeyId","SecretAccessKey","SessionToken","Expiration","expiresAt","refreshCredentials","assumeRoleCredentials","err","getCredentials","isAboutToExpire","provisionalExpiry","now"],"sources":["AssumeRoleProvider.ts"],"sourcesContent":["import * as http from 'node:http'\nimport * as https from 'node:https'\nimport { URL, URLSearchParams } from 'node:url'\n\nimport { CredentialProvider } from './CredentialProvider.ts'\nimport { Credentials } from './Credentials.ts'\nimport { makeDateLong, parseXml, toSha256 } from './internal/helper.ts'\nimport { request } from './internal/request.ts'\nimport { readAsString } from './internal/response.ts'\nimport type { Transport } from './internal/type.ts'\nimport { signV4ByServiceName } from './signing.ts'\n\n/**\n * @see https://docs.aws.amazon.com/STS/latest/APIReference/API_AssumeRole.html\n */\ntype CredentialResponse = {\n  ErrorResponse?: {\n    Error?: {\n      Code?: string\n      Message?: string\n    }\n  }\n\n  AssumeRoleResponse: {\n    AssumeRoleResult: {\n      Credentials: {\n        AccessKeyId: string\n        SecretAccessKey: string\n        SessionToken: string\n        Expiration: string\n      }\n    }\n  }\n}\n\nexport interface AssumeRoleProviderOptions {\n  stsEndpoint: string\n  accessKey: string\n  secretKey: string\n  durationSeconds?: number\n  sessionToken?: string\n  policy?: string\n  region?: string\n  roleArn?: string\n  roleSessionName?: string\n  externalId?: string\n  token?: string\n  webIdentityToken?: string\n  action?: string\n  transportAgent?: http.Agent\n}\n\nconst defaultExpirySeconds = 900\n\nexport class AssumeRoleProvider extends CredentialProvider {\n  private readonly stsEndpoint: URL\n  private readonly accessKey: string\n  private readonly secretKey: string\n  private readonly durationSeconds: number\n  private readonly policy?: string\n  private readonly region: string\n  private readonly roleArn?: string\n  private readonly roleSessionName?: string\n  private readonly externalId?: string\n  private readonly token?: string\n  private readonly webIdentityToken?: string\n  private readonly action: string\n\n  private _credentials: Credentials | null\n  private readonly expirySeconds: number\n  private accessExpiresAt = ''\n  private readonly transportAgent?: http.Agent\n\n  private readonly transport: Transport\n\n  constructor({\n    stsEndpoint,\n    accessKey,\n    secretKey,\n    durationSeconds = defaultExpirySeconds,\n    sessionToken,\n    policy,\n    region = '',\n    roleArn,\n    roleSessionName,\n    externalId,\n    token,\n    webIdentityToken,\n    action = 'AssumeRole',\n    transportAgent = undefined,\n  }: AssumeRoleProviderOptions) {\n    super({ accessKey, secretKey, sessionToken })\n\n    this.stsEndpoint = new URL(stsEndpoint)\n    this.accessKey = accessKey\n    this.secretKey = secretKey\n    this.policy = policy\n    this.region = region\n    this.roleArn = roleArn\n    this.roleSessionName = roleSessionName\n    this.externalId = externalId\n    this.token = token\n    this.webIdentityToken = webIdentityToken\n    this.action = action\n\n    this.durationSeconds = parseInt(durationSeconds as unknown as string)\n\n    let expirySeconds = this.durationSeconds\n    if (this.durationSeconds < defaultExpirySeconds) {\n      expirySeconds = defaultExpirySeconds\n    }\n    this.expirySeconds = expirySeconds // for calculating refresh of credentials.\n\n    // By default, nodejs uses a global agent if the 'agent' property\n    // is set to undefined. Otherwise, it's okay to assume the users\n    // know what they're doing if they specify a custom transport agent.\n    this.transportAgent = transportAgent\n    const isHttp: boolean = this.stsEndpoint.protocol === 'http:'\n    this.transport = isHttp ? http : https\n\n    /**\n     * Internal Tracking variables\n     */\n    this._credentials = null\n  }\n\n  getRequestConfig(): {\n    requestOptions: http.RequestOptions\n    requestData: string\n  } {\n    const hostValue = this.stsEndpoint.hostname\n    const portValue = this.stsEndpoint.port\n    const qryParams = new URLSearchParams({ Action: this.action, Version: '2011-06-15' })\n\n    qryParams.set('DurationSeconds', this.expirySeconds.toString())\n\n    if (this.policy) {\n      qryParams.set('Policy', this.policy)\n    }\n    if (this.roleArn) {\n      qryParams.set('RoleArn', this.roleArn)\n    }\n\n    if (this.roleSessionName != null) {\n      qryParams.set('RoleSessionName', this.roleSessionName)\n    }\n    if (this.token != null) {\n      qryParams.set('Token', this.token)\n    }\n\n    if (this.webIdentityToken) {\n      qryParams.set('WebIdentityToken', this.webIdentityToken)\n    }\n\n    if (this.externalId) {\n      qryParams.set('ExternalId', this.externalId)\n    }\n\n    const urlParams = qryParams.toString()\n    const contentSha256 = toSha256(urlParams)\n\n    const date = new Date()\n\n    const requestOptions = {\n      hostname: hostValue,\n      port: portValue,\n      path: '/',\n      protocol: this.stsEndpoint.protocol,\n      method: 'POST',\n      headers: {\n        'Content-Type': 'application/x-www-form-urlencoded',\n        'content-length': urlParams.length.toString(),\n        host: hostValue,\n        'x-amz-date': makeDateLong(date),\n        'x-amz-content-sha256': contentSha256,\n      } as Record<string, string>,\n      agent: this.transportAgent,\n    } satisfies http.RequestOptions\n\n    requestOptions.headers.authorization = signV4ByServiceName(\n      requestOptions,\n      this.accessKey,\n      this.secretKey,\n      this.region,\n      date,\n      contentSha256,\n      'sts',\n    )\n\n    return {\n      requestOptions,\n      requestData: urlParams,\n    }\n  }\n\n  async performRequest(): Promise<CredentialResponse> {\n    const { requestOptions, requestData } = this.getRequestConfig()\n\n    const res = await request(this.transport, requestOptions, requestData)\n\n    const body = await readAsString(res)\n\n    return parseXml(body)\n  }\n\n  parseCredentials(respObj: CredentialResponse): Credentials {\n    if (respObj.ErrorResponse) {\n      throw new Error(\n        `Unable to obtain credentials: ${respObj.ErrorResponse?.Error?.Code} ${respObj.ErrorResponse?.Error?.Message}`,\n        { cause: respObj },\n      )\n    }\n\n    const {\n      AssumeRoleResponse: {\n        AssumeRoleResult: {\n          Credentials: {\n            AccessKeyId: accessKey,\n            SecretAccessKey: secretKey,\n            SessionToken: sessionToken,\n            Expiration: expiresAt,\n          },\n        },\n      },\n    } = respObj\n\n    this.accessExpiresAt = expiresAt\n\n    return new Credentials({ accessKey, secretKey, sessionToken })\n  }\n\n  async refreshCredentials(): Promise<Credentials> {\n    try {\n      const assumeRoleCredentials = await this.performRequest()\n      this._credentials = this.parseCredentials(assumeRoleCredentials)\n    } catch (err) {\n      throw new Error(`Failed to get Credentials: ${err}`, { cause: err })\n    }\n\n    return this._credentials\n  }\n\n  async getCredentials(): Promise<Credentials> {\n    if (this._credentials && !this.isAboutToExpire()) {\n      return this._credentials\n    }\n\n    this._credentials = await this.refreshCredentials()\n    return this._credentials\n  }\n\n  isAboutToExpire() {\n    const expiresAt = new Date(this.accessExpiresAt)\n    const provisionalExpiry = new Date(Date.now() + 1000 * 10) // check before 10 seconds.\n    return provisionalExpiry > expiresAt\n  }\n}\n\n// deprecated default export, please use named exports.\n// keep for backward compatibility.\n// eslint-disable-next-line import/no-default-export\nexport default AssumeRoleProvider\n"],"mappings":"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"}
@@ -0,0 +1,22 @@
1
+ import { Credentials } from "./Credentials.mjs";
2
+ export declare class CredentialProvider {
3
+ private credentials;
4
+ constructor({
5
+ accessKey,
6
+ secretKey,
7
+ sessionToken
8
+ }: {
9
+ accessKey: string;
10
+ secretKey: string;
11
+ sessionToken?: string;
12
+ });
13
+ getCredentials(): Promise<Credentials>;
14
+ setCredentials(credentials: Credentials): void;
15
+ setAccessKey(accessKey: string): void;
16
+ getAccessKey(): string;
17
+ setSecretKey(secretKey: string): void;
18
+ getSecretKey(): string;
19
+ setSessionToken(sessionToken: string): void;
20
+ getSessionToken(): string | undefined;
21
+ }
22
+ export default CredentialProvider;
@@ -0,0 +1,48 @@
1
+ import { Credentials } from "./Credentials.mjs";
2
+ export class CredentialProvider {
3
+ constructor({
4
+ accessKey,
5
+ secretKey,
6
+ sessionToken
7
+ }) {
8
+ this.credentials = new Credentials({
9
+ accessKey,
10
+ secretKey,
11
+ sessionToken
12
+ });
13
+ }
14
+ async getCredentials() {
15
+ return this.credentials.get();
16
+ }
17
+ setCredentials(credentials) {
18
+ if (credentials instanceof Credentials) {
19
+ this.credentials = credentials;
20
+ } else {
21
+ throw new Error('Unable to set Credentials. it should be an instance of Credentials class');
22
+ }
23
+ }
24
+ setAccessKey(accessKey) {
25
+ this.credentials.setAccessKey(accessKey);
26
+ }
27
+ getAccessKey() {
28
+ return this.credentials.getAccessKey();
29
+ }
30
+ setSecretKey(secretKey) {
31
+ this.credentials.setSecretKey(secretKey);
32
+ }
33
+ getSecretKey() {
34
+ return this.credentials.getSecretKey();
35
+ }
36
+ setSessionToken(sessionToken) {
37
+ this.credentials.setSessionToken(sessionToken);
38
+ }
39
+ getSessionToken() {
40
+ return this.credentials.getSessionToken();
41
+ }
42
+ }
43
+
44
+ // deprecated default export, please use named exports.
45
+ // keep for backward compatibility.
46
+ // eslint-disable-next-line import/no-default-export
47
+ export default CredentialProvider;
48
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJDcmVkZW50aWFscyIsIkNyZWRlbnRpYWxQcm92aWRlciIsImNvbnN0cnVjdG9yIiwiYWNjZXNzS2V5Iiwic2VjcmV0S2V5Iiwic2Vzc2lvblRva2VuIiwiY3JlZGVudGlhbHMiLCJnZXRDcmVkZW50aWFscyIsImdldCIsInNldENyZWRlbnRpYWxzIiwiRXJyb3IiLCJzZXRBY2Nlc3NLZXkiLCJnZXRBY2Nlc3NLZXkiLCJzZXRTZWNyZXRLZXkiLCJnZXRTZWNyZXRLZXkiLCJzZXRTZXNzaW9uVG9rZW4iLCJnZXRTZXNzaW9uVG9rZW4iXSwic291cmNlcyI6WyJDcmVkZW50aWFsUHJvdmlkZXIudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ3JlZGVudGlhbHMgfSBmcm9tICcuL0NyZWRlbnRpYWxzLnRzJ1xuXG5leHBvcnQgY2xhc3MgQ3JlZGVudGlhbFByb3ZpZGVyIHtcbiAgcHJpdmF0ZSBjcmVkZW50aWFsczogQ3JlZGVudGlhbHNcblxuICBjb25zdHJ1Y3Rvcih7IGFjY2Vzc0tleSwgc2VjcmV0S2V5LCBzZXNzaW9uVG9rZW4gfTogeyBhY2Nlc3NLZXk6IHN0cmluZzsgc2VjcmV0S2V5OiBzdHJpbmc7IHNlc3Npb25Ub2tlbj86IHN0cmluZyB9KSB7XG4gICAgdGhpcy5jcmVkZW50aWFscyA9IG5ldyBDcmVkZW50aWFscyh7XG4gICAgICBhY2Nlc3NLZXksXG4gICAgICBzZWNyZXRLZXksXG4gICAgICBzZXNzaW9uVG9rZW4sXG4gICAgfSlcbiAgfVxuXG4gIGFzeW5jIGdldENyZWRlbnRpYWxzKCk6IFByb21pc2U8Q3JlZGVudGlhbHM+IHtcbiAgICByZXR1cm4gdGhpcy5jcmVkZW50aWFscy5nZXQoKVxuICB9XG5cbiAgc2V0Q3JlZGVudGlhbHMoY3JlZGVudGlhbHM6IENyZWRlbnRpYWxzKSB7XG4gICAgaWYgKGNyZWRlbnRpYWxzIGluc3RhbmNlb2YgQ3JlZGVudGlhbHMpIHtcbiAgICAgIHRoaXMuY3JlZGVudGlhbHMgPSBjcmVkZW50aWFsc1xuICAgIH0gZWxzZSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ1VuYWJsZSB0byBzZXQgQ3JlZGVudGlhbHMuIGl0IHNob3VsZCBiZSBhbiBpbnN0YW5jZSBvZiBDcmVkZW50aWFscyBjbGFzcycpXG4gICAgfVxuICB9XG5cbiAgc2V0QWNjZXNzS2V5KGFjY2Vzc0tleTogc3RyaW5nKSB7XG4gICAgdGhpcy5jcmVkZW50aWFscy5zZXRBY2Nlc3NLZXkoYWNjZXNzS2V5KVxuICB9XG5cbiAgZ2V0QWNjZXNzS2V5KCkge1xuICAgIHJldHVybiB0aGlzLmNyZWRlbnRpYWxzLmdldEFjY2Vzc0tleSgpXG4gIH1cblxuICBzZXRTZWNyZXRLZXkoc2VjcmV0S2V5OiBzdHJpbmcpIHtcbiAgICB0aGlzLmNyZWRlbnRpYWxzLnNldFNlY3JldEtleShzZWNyZXRLZXkpXG4gIH1cblxuICBnZXRTZWNyZXRLZXkoKSB7XG4gICAgcmV0dXJuIHRoaXMuY3JlZGVudGlhbHMuZ2V0U2VjcmV0S2V5KClcbiAgfVxuXG4gIHNldFNlc3Npb25Ub2tlbihzZXNzaW9uVG9rZW46IHN0cmluZykge1xuICAgIHRoaXMuY3JlZGVudGlhbHMuc2V0U2Vzc2lvblRva2VuKHNlc3Npb25Ub2tlbilcbiAgfVxuXG4gIGdldFNlc3Npb25Ub2tlbigpIHtcbiAgICByZXR1cm4gdGhpcy5jcmVkZW50aWFscy5nZXRTZXNzaW9uVG9rZW4oKVxuICB9XG59XG5cbi8vIGRlcHJlY2F0ZWQgZGVmYXVsdCBleHBvcnQsIHBsZWFzZSB1c2UgbmFtZWQgZXhwb3J0cy5cbi8vIGtlZXAgZm9yIGJhY2t3YXJkIGNvbXBhdGliaWxpdHkuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgaW1wb3J0L25vLWRlZmF1bHQtZXhwb3J0XG5leHBvcnQgZGVmYXVsdCBDcmVkZW50aWFsUHJvdmlkZXJcbiJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBU0EsV0FBVyxRQUFRLG1CQUFrQjtBQUU5QyxPQUFPLE1BQU1DLGtCQUFrQixDQUFDO0VBRzlCQyxXQUFXQSxDQUFDO0lBQUVDLFNBQVM7SUFBRUMsU0FBUztJQUFFQztFQUE4RSxDQUFDLEVBQUU7SUFDbkgsSUFBSSxDQUFDQyxXQUFXLEdBQUcsSUFBSU4sV0FBVyxDQUFDO01BQ2pDRyxTQUFTO01BQ1RDLFNBQVM7TUFDVEM7SUFDRixDQUFDLENBQUM7RUFDSjtFQUVBLE1BQU1FLGNBQWNBLENBQUEsRUFBeUI7SUFDM0MsT0FBTyxJQUFJLENBQUNELFdBQVcsQ0FBQ0UsR0FBRyxDQUFDLENBQUM7RUFDL0I7RUFFQUMsY0FBY0EsQ0FBQ0gsV0FBd0IsRUFBRTtJQUN2QyxJQUFJQSxXQUFXLFlBQVlOLFdBQVcsRUFBRTtNQUN0QyxJQUFJLENBQUNNLFdBQVcsR0FBR0EsV0FBVztJQUNoQyxDQUFDLE1BQU07TUFDTCxNQUFNLElBQUlJLEtBQUssQ0FBQywwRUFBMEUsQ0FBQztJQUM3RjtFQUNGO0VBRUFDLFlBQVlBLENBQUNSLFNBQWlCLEVBQUU7SUFDOUIsSUFBSSxDQUFDRyxXQUFXLENBQUNLLFlBQVksQ0FBQ1IsU0FBUyxDQUFDO0VBQzFDO0VBRUFTLFlBQVlBLENBQUEsRUFBRztJQUNiLE9BQU8sSUFBSSxDQUFDTixXQUFXLENBQUNNLFlBQVksQ0FBQyxDQUFDO0VBQ3hDO0VBRUFDLFlBQVlBLENBQUNULFNBQWlCLEVBQUU7SUFDOUIsSUFBSSxDQUFDRSxXQUFXLENBQUNPLFlBQVksQ0FBQ1QsU0FBUyxDQUFDO0VBQzFDO0VBRUFVLFlBQVlBLENBQUEsRUFBRztJQUNiLE9BQU8sSUFBSSxDQUFDUixXQUFXLENBQUNRLFlBQVksQ0FBQyxDQUFDO0VBQ3hDO0VBRUFDLGVBQWVBLENBQUNWLFlBQW9CLEVBQUU7SUFDcEMsSUFBSSxDQUFDQyxXQUFXLENBQUNTLGVBQWUsQ0FBQ1YsWUFBWSxDQUFDO0VBQ2hEO0VBRUFXLGVBQWVBLENBQUEsRUFBRztJQUNoQixPQUFPLElBQUksQ0FBQ1YsV0FBVyxDQUFDVSxlQUFlLENBQUMsQ0FBQztFQUMzQztBQUNGOztBQUVBO0FBQ0E7QUFDQTtBQUNBLGVBQWVmLGtCQUFrQiJ9
@@ -0,0 +1,22 @@
1
+ export declare class Credentials {
2
+ accessKey: string;
3
+ secretKey: string;
4
+ sessionToken?: string;
5
+ constructor({
6
+ accessKey,
7
+ secretKey,
8
+ sessionToken
9
+ }: {
10
+ accessKey: string;
11
+ secretKey: string;
12
+ sessionToken?: string;
13
+ });
14
+ setAccessKey(accessKey: string): void;
15
+ getAccessKey(): string;
16
+ setSecretKey(secretKey: string): void;
17
+ getSecretKey(): string;
18
+ setSessionToken(sessionToken: string): void;
19
+ getSessionToken(): string | undefined;
20
+ get(): Credentials;
21
+ }
22
+ export default Credentials;
@@ -0,0 +1,38 @@
1
+ export class Credentials {
2
+ constructor({
3
+ accessKey,
4
+ secretKey,
5
+ sessionToken
6
+ }) {
7
+ this.accessKey = accessKey;
8
+ this.secretKey = secretKey;
9
+ this.sessionToken = sessionToken;
10
+ }
11
+ setAccessKey(accessKey) {
12
+ this.accessKey = accessKey;
13
+ }
14
+ getAccessKey() {
15
+ return this.accessKey;
16
+ }
17
+ setSecretKey(secretKey) {
18
+ this.secretKey = secretKey;
19
+ }
20
+ getSecretKey() {
21
+ return this.secretKey;
22
+ }
23
+ setSessionToken(sessionToken) {
24
+ this.sessionToken = sessionToken;
25
+ }
26
+ getSessionToken() {
27
+ return this.sessionToken;
28
+ }
29
+ get() {
30
+ return this;
31
+ }
32
+ }
33
+
34
+ // deprecated default export, please use named exports.
35
+ // keep for backward compatibility.
36
+ // eslint-disable-next-line import/no-default-export
37
+ export default Credentials;
38
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJDcmVkZW50aWFscyIsImNvbnN0cnVjdG9yIiwiYWNjZXNzS2V5Iiwic2VjcmV0S2V5Iiwic2Vzc2lvblRva2VuIiwic2V0QWNjZXNzS2V5IiwiZ2V0QWNjZXNzS2V5Iiwic2V0U2VjcmV0S2V5IiwiZ2V0U2VjcmV0S2V5Iiwic2V0U2Vzc2lvblRva2VuIiwiZ2V0U2Vzc2lvblRva2VuIiwiZ2V0Il0sInNvdXJjZXMiOlsiQ3JlZGVudGlhbHMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNsYXNzIENyZWRlbnRpYWxzIHtcbiAgcHVibGljIGFjY2Vzc0tleTogc3RyaW5nXG4gIHB1YmxpYyBzZWNyZXRLZXk6IHN0cmluZ1xuICBwdWJsaWMgc2Vzc2lvblRva2VuPzogc3RyaW5nXG5cbiAgY29uc3RydWN0b3IoeyBhY2Nlc3NLZXksIHNlY3JldEtleSwgc2Vzc2lvblRva2VuIH06IHsgYWNjZXNzS2V5OiBzdHJpbmc7IHNlY3JldEtleTogc3RyaW5nOyBzZXNzaW9uVG9rZW4/OiBzdHJpbmcgfSkge1xuICAgIHRoaXMuYWNjZXNzS2V5ID0gYWNjZXNzS2V5XG4gICAgdGhpcy5zZWNyZXRLZXkgPSBzZWNyZXRLZXlcbiAgICB0aGlzLnNlc3Npb25Ub2tlbiA9IHNlc3Npb25Ub2tlblxuICB9XG5cbiAgc2V0QWNjZXNzS2V5KGFjY2Vzc0tleTogc3RyaW5nKSB7XG4gICAgdGhpcy5hY2Nlc3NLZXkgPSBhY2Nlc3NLZXlcbiAgfVxuXG4gIGdldEFjY2Vzc0tleSgpIHtcbiAgICByZXR1cm4gdGhpcy5hY2Nlc3NLZXlcbiAgfVxuXG4gIHNldFNlY3JldEtleShzZWNyZXRLZXk6IHN0cmluZykge1xuICAgIHRoaXMuc2VjcmV0S2V5ID0gc2VjcmV0S2V5XG4gIH1cblxuICBnZXRTZWNyZXRLZXkoKSB7XG4gICAgcmV0dXJuIHRoaXMuc2VjcmV0S2V5XG4gIH1cblxuICBzZXRTZXNzaW9uVG9rZW4oc2Vzc2lvblRva2VuOiBzdHJpbmcpIHtcbiAgICB0aGlzLnNlc3Npb25Ub2tlbiA9IHNlc3Npb25Ub2tlblxuICB9XG5cbiAgZ2V0U2Vzc2lvblRva2VuKCkge1xuICAgIHJldHVybiB0aGlzLnNlc3Npb25Ub2tlblxuICB9XG5cbiAgZ2V0KCk6IENyZWRlbnRpYWxzIHtcbiAgICByZXR1cm4gdGhpc1xuICB9XG59XG5cbi8vIGRlcHJlY2F0ZWQgZGVmYXVsdCBleHBvcnQsIHBsZWFzZSB1c2UgbmFtZWQgZXhwb3J0cy5cbi8vIGtlZXAgZm9yIGJhY2t3YXJkIGNvbXBhdGliaWxpdHkuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgaW1wb3J0L25vLWRlZmF1bHQtZXhwb3J0XG5leHBvcnQgZGVmYXVsdCBDcmVkZW50aWFsc1xuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLE1BQU1BLFdBQVcsQ0FBQztFQUt2QkMsV0FBV0EsQ0FBQztJQUFFQyxTQUFTO0lBQUVDLFNBQVM7SUFBRUM7RUFBOEUsQ0FBQyxFQUFFO0lBQ25ILElBQUksQ0FBQ0YsU0FBUyxHQUFHQSxTQUFTO0lBQzFCLElBQUksQ0FBQ0MsU0FBUyxHQUFHQSxTQUFTO0lBQzFCLElBQUksQ0FBQ0MsWUFBWSxHQUFHQSxZQUFZO0VBQ2xDO0VBRUFDLFlBQVlBLENBQUNILFNBQWlCLEVBQUU7SUFDOUIsSUFBSSxDQUFDQSxTQUFTLEdBQUdBLFNBQVM7RUFDNUI7RUFFQUksWUFBWUEsQ0FBQSxFQUFHO0lBQ2IsT0FBTyxJQUFJLENBQUNKLFNBQVM7RUFDdkI7RUFFQUssWUFBWUEsQ0FBQ0osU0FBaUIsRUFBRTtJQUM5QixJQUFJLENBQUNBLFNBQVMsR0FBR0EsU0FBUztFQUM1QjtFQUVBSyxZQUFZQSxDQUFBLEVBQUc7SUFDYixPQUFPLElBQUksQ0FBQ0wsU0FBUztFQUN2QjtFQUVBTSxlQUFlQSxDQUFDTCxZQUFvQixFQUFFO0lBQ3BDLElBQUksQ0FBQ0EsWUFBWSxHQUFHQSxZQUFZO0VBQ2xDO0VBRUFNLGVBQWVBLENBQUEsRUFBRztJQUNoQixPQUFPLElBQUksQ0FBQ04sWUFBWTtFQUMxQjtFQUVBTyxHQUFHQSxDQUFBLEVBQWdCO0lBQ2pCLE9BQU8sSUFBSTtFQUNiO0FBQ0Y7O0FBRUE7QUFDQTtBQUNBO0FBQ0EsZUFBZVgsV0FBVyJ9
@@ -0,0 +1,27 @@
1
+ /// <reference types="node" />
2
+ import * as http from 'node:http';
3
+ import { CredentialProvider } from "./CredentialProvider.mjs";
4
+ import { Credentials } from "./Credentials.mjs";
5
+ export interface IamAwsProviderOptions {
6
+ customEndpoint?: string;
7
+ transportAgent?: http.Agent;
8
+ }
9
+ export declare class IamAwsProvider extends CredentialProvider {
10
+ private readonly customEndpoint?;
11
+ private _credentials;
12
+ private readonly transportAgent?;
13
+ private accessExpiresAt;
14
+ constructor({
15
+ customEndpoint,
16
+ transportAgent
17
+ }: IamAwsProviderOptions);
18
+ getCredentials(): Promise<Credentials>;
19
+ private fetchCredentials;
20
+ private fetchCredentialsUsingTokenFile;
21
+ private fetchImdsToken;
22
+ private getIamRoleNamedUrl;
23
+ private getIamRoleName;
24
+ private requestCredentials;
25
+ private isAboutToExpire;
26
+ }
27
+ export default IamAwsProvider;