@hanzo/s3 0.6.3 → 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,189 @@
1
+ import * as fs from "fs/promises";
2
+ import * as http from "http";
3
+ import * as https from "https";
4
+ import { URL, URLSearchParams } from "url";
5
+ import { CredentialProvider } from "./CredentialProvider.mjs";
6
+ import { Credentials } from "./Credentials.mjs";
7
+ import { parseXml } from "./internal/helper.mjs";
8
+ import { request } from "./internal/request.mjs";
9
+ import { readAsString } from "./internal/response.mjs";
10
+ export class IamAwsProvider extends CredentialProvider {
11
+ accessExpiresAt = '';
12
+ constructor({
13
+ customEndpoint = undefined,
14
+ transportAgent = undefined
15
+ }) {
16
+ super({
17
+ accessKey: '',
18
+ secretKey: ''
19
+ });
20
+ this.customEndpoint = customEndpoint;
21
+ this.transportAgent = transportAgent;
22
+
23
+ /**
24
+ * Internal Tracking variables
25
+ */
26
+ this._credentials = null;
27
+ }
28
+ async getCredentials() {
29
+ if (!this._credentials || this.isAboutToExpire()) {
30
+ this._credentials = await this.fetchCredentials();
31
+ }
32
+ return this._credentials;
33
+ }
34
+ async fetchCredentials() {
35
+ try {
36
+ // check for IRSA (https://docs.aws.amazon.com/eks/latest/userguide/iam-roles-for-service-accounts.html)
37
+ const tokenFile = process.env.AWS_WEB_IDENTITY_TOKEN_FILE;
38
+ if (tokenFile) {
39
+ return await this.fetchCredentialsUsingTokenFile(tokenFile);
40
+ }
41
+
42
+ // try with IAM role for EC2 instances (https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/iam-roles-for-amazon-ec2.html)
43
+ let tokenHeader = 'Authorization';
44
+ let token = process.env.AWS_CONTAINER_AUTHORIZATION_TOKEN;
45
+ const relativeUri = process.env.AWS_CONTAINER_CREDENTIALS_RELATIVE_URI;
46
+ const fullUri = process.env.AWS_CONTAINER_CREDENTIALS_FULL_URI;
47
+ let url;
48
+ if (relativeUri) {
49
+ url = new URL(relativeUri, 'http://169.254.170.2');
50
+ } else if (fullUri) {
51
+ url = new URL(fullUri);
52
+ } else {
53
+ token = await this.fetchImdsToken();
54
+ tokenHeader = 'X-aws-ec2-metadata-token';
55
+ url = await this.getIamRoleNamedUrl(token);
56
+ }
57
+ return this.requestCredentials(url, tokenHeader, token);
58
+ } catch (err) {
59
+ throw new Error(`Failed to get Credentials: ${err}`, {
60
+ cause: err
61
+ });
62
+ }
63
+ }
64
+ async fetchCredentialsUsingTokenFile(tokenFile) {
65
+ const token = await fs.readFile(tokenFile, {
66
+ encoding: 'utf8'
67
+ });
68
+ const region = process.env.AWS_REGION;
69
+ const stsEndpoint = new URL(region ? `https://sts.${region}.amazonaws.com` : 'https://sts.amazonaws.com');
70
+ const hostValue = stsEndpoint.hostname;
71
+ const portValue = stsEndpoint.port;
72
+ const qryParams = new URLSearchParams({
73
+ Action: 'AssumeRoleWithWebIdentity',
74
+ Version: '2011-06-15'
75
+ });
76
+ const roleArn = process.env.AWS_ROLE_ARN;
77
+ if (roleArn) {
78
+ qryParams.set('RoleArn', roleArn);
79
+ const roleSessionName = process.env.AWS_ROLE_SESSION_NAME;
80
+ qryParams.set('RoleSessionName', roleSessionName ? roleSessionName : Date.now().toString());
81
+ }
82
+ qryParams.set('WebIdentityToken', token);
83
+ qryParams.sort();
84
+ const requestOptions = {
85
+ hostname: hostValue,
86
+ port: portValue,
87
+ path: `${stsEndpoint.pathname}?${qryParams.toString()}`,
88
+ protocol: stsEndpoint.protocol,
89
+ method: 'POST',
90
+ headers: {},
91
+ agent: this.transportAgent
92
+ };
93
+ const transport = stsEndpoint.protocol === 'http:' ? http : https;
94
+ const res = await request(transport, requestOptions, null);
95
+ const body = await readAsString(res);
96
+ const assumeRoleResponse = parseXml(body);
97
+ const creds = assumeRoleResponse.AssumeRoleWithWebIdentityResponse.AssumeRoleWithWebIdentityResult.Credentials;
98
+ this.accessExpiresAt = creds.Expiration;
99
+ return new Credentials({
100
+ accessKey: creds.AccessKeyId,
101
+ secretKey: creds.SecretAccessKey,
102
+ sessionToken: creds.SessionToken
103
+ });
104
+ }
105
+ async fetchImdsToken() {
106
+ const endpoint = this.customEndpoint ? this.customEndpoint : 'http://169.254.169.254';
107
+ const url = new URL('/latest/api/token', endpoint);
108
+ const requestOptions = {
109
+ hostname: url.hostname,
110
+ port: url.port,
111
+ path: `${url.pathname}${url.search}`,
112
+ protocol: url.protocol,
113
+ method: 'PUT',
114
+ headers: {
115
+ 'X-aws-ec2-metadata-token-ttl-seconds': '21600'
116
+ },
117
+ agent: this.transportAgent
118
+ };
119
+ const transport = url.protocol === 'http:' ? http : https;
120
+ const res = await request(transport, requestOptions, null);
121
+ return await readAsString(res);
122
+ }
123
+ async getIamRoleNamedUrl(token) {
124
+ const endpoint = this.customEndpoint ? this.customEndpoint : 'http://169.254.169.254';
125
+ const url = new URL('latest/meta-data/iam/security-credentials/', endpoint);
126
+ const roleName = await this.getIamRoleName(url, token);
127
+ return new URL(`${url.pathname}/${encodeURIComponent(roleName)}`, url.origin);
128
+ }
129
+ async getIamRoleName(url, token) {
130
+ const requestOptions = {
131
+ hostname: url.hostname,
132
+ port: url.port,
133
+ path: `${url.pathname}${url.search}`,
134
+ protocol: url.protocol,
135
+ method: 'GET',
136
+ headers: {
137
+ 'X-aws-ec2-metadata-token': token
138
+ },
139
+ agent: this.transportAgent
140
+ };
141
+ const transport = url.protocol === 'http:' ? http : https;
142
+ const res = await request(transport, requestOptions, null);
143
+ const body = await readAsString(res);
144
+ const roleNames = body.split(/\r\n|[\n\r\u2028\u2029]/);
145
+ if (roleNames.length === 0) {
146
+ throw new Error(`No IAM roles attached to EC2 service ${url}`);
147
+ }
148
+ return roleNames[0];
149
+ }
150
+ async requestCredentials(url, tokenHeader, token) {
151
+ const headers = {};
152
+ if (token) {
153
+ headers[tokenHeader] = token;
154
+ }
155
+ const requestOptions = {
156
+ hostname: url.hostname,
157
+ port: url.port,
158
+ path: `${url.pathname}${url.search}`,
159
+ protocol: url.protocol,
160
+ method: 'GET',
161
+ headers: headers,
162
+ agent: this.transportAgent
163
+ };
164
+ const transport = url.protocol === 'http:' ? http : https;
165
+ const res = await request(transport, requestOptions, null);
166
+ const body = await readAsString(res);
167
+ const ecsCredentials = JSON.parse(body);
168
+ if (!ecsCredentials.Code || ecsCredentials.Code != 'Success') {
169
+ throw new Error(`${url} failed with code ${ecsCredentials.Code} and message ${ecsCredentials.Message}`);
170
+ }
171
+ this.accessExpiresAt = ecsCredentials.Expiration;
172
+ return new Credentials({
173
+ accessKey: ecsCredentials.AccessKeyID,
174
+ secretKey: ecsCredentials.SecretAccessKey,
175
+ sessionToken: ecsCredentials.Token
176
+ });
177
+ }
178
+ isAboutToExpire() {
179
+ const expiresAt = new Date(this.accessExpiresAt);
180
+ const provisionalExpiry = new Date(Date.now() + 1000 * 10); // 10 seconds leeway
181
+ return provisionalExpiry > expiresAt;
182
+ }
183
+ }
184
+
185
+ // deprecated default export, please use named exports.
186
+ // keep for backward compatibility.
187
+ // eslint-disable-next-line import/no-default-export
188
+ export default IamAwsProvider;
189
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["fs","http","https","URL","URLSearchParams","CredentialProvider","Credentials","parseXml","request","readAsString","IamAwsProvider","accessExpiresAt","constructor","customEndpoint","undefined","transportAgent","accessKey","secretKey","_credentials","getCredentials","isAboutToExpire","fetchCredentials","tokenFile","process","env","AWS_WEB_IDENTITY_TOKEN_FILE","fetchCredentialsUsingTokenFile","tokenHeader","token","AWS_CONTAINER_AUTHORIZATION_TOKEN","relativeUri","AWS_CONTAINER_CREDENTIALS_RELATIVE_URI","fullUri","AWS_CONTAINER_CREDENTIALS_FULL_URI","url","fetchImdsToken","getIamRoleNamedUrl","requestCredentials","err","Error","cause","readFile","encoding","region","AWS_REGION","stsEndpoint","hostValue","hostname","portValue","port","qryParams","Action","Version","roleArn","AWS_ROLE_ARN","set","roleSessionName","AWS_ROLE_SESSION_NAME","Date","now","toString","sort","requestOptions","path","pathname","protocol","method","headers","agent","transport","res","body","assumeRoleResponse","creds","AssumeRoleWithWebIdentityResponse","AssumeRoleWithWebIdentityResult","Expiration","AccessKeyId","SecretAccessKey","sessionToken","SessionToken","endpoint","search","roleName","getIamRoleName","encodeURIComponent","origin","roleNames","split","length","ecsCredentials","JSON","parse","Code","Message","AccessKeyID","Token","expiresAt","provisionalExpiry"],"sources":["IamAwsProvider.ts"],"sourcesContent":["import * as fs from 'node:fs/promises'\nimport * 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 { parseXml } from './internal/helper.ts'\nimport { request } from './internal/request.ts'\nimport { readAsString } from './internal/response.ts'\n\ninterface AssumeRoleResponse {\n  AssumeRoleWithWebIdentityResponse: {\n    AssumeRoleWithWebIdentityResult: {\n      Credentials: {\n        AccessKeyId: string\n        SecretAccessKey: string\n        SessionToken: string\n        Expiration: string\n      }\n    }\n  }\n}\n\ninterface EcsCredentials {\n  AccessKeyID: string\n  SecretAccessKey: string\n  Token: string\n  Expiration: string\n  Code: string\n  Message: string\n}\n\nexport interface IamAwsProviderOptions {\n  customEndpoint?: string\n  transportAgent?: http.Agent\n}\n\nexport class IamAwsProvider extends CredentialProvider {\n  private readonly customEndpoint?: string\n\n  private _credentials: Credentials | null\n  private readonly transportAgent?: http.Agent\n  private accessExpiresAt = ''\n\n  constructor({ customEndpoint = undefined, transportAgent = undefined }: IamAwsProviderOptions) {\n    super({ accessKey: '', secretKey: '' })\n\n    this.customEndpoint = customEndpoint\n    this.transportAgent = transportAgent\n\n    /**\n     * Internal Tracking variables\n     */\n    this._credentials = null\n  }\n\n  async getCredentials(): Promise<Credentials> {\n    if (!this._credentials || this.isAboutToExpire()) {\n      this._credentials = await this.fetchCredentials()\n    }\n    return this._credentials\n  }\n\n  private async fetchCredentials(): Promise<Credentials> {\n    try {\n      // check for IRSA (https://docs.aws.amazon.com/eks/latest/userguide/iam-roles-for-service-accounts.html)\n      const tokenFile = process.env.AWS_WEB_IDENTITY_TOKEN_FILE\n      if (tokenFile) {\n        return await this.fetchCredentialsUsingTokenFile(tokenFile)\n      }\n\n      // try with IAM role for EC2 instances (https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/iam-roles-for-amazon-ec2.html)\n      let tokenHeader = 'Authorization'\n      let token = process.env.AWS_CONTAINER_AUTHORIZATION_TOKEN\n      const relativeUri = process.env.AWS_CONTAINER_CREDENTIALS_RELATIVE_URI\n      const fullUri = process.env.AWS_CONTAINER_CREDENTIALS_FULL_URI\n      let url: URL\n      if (relativeUri) {\n        url = new URL(relativeUri, 'http://169.254.170.2')\n      } else if (fullUri) {\n        url = new URL(fullUri)\n      } else {\n        token = await this.fetchImdsToken()\n        tokenHeader = 'X-aws-ec2-metadata-token'\n        url = await this.getIamRoleNamedUrl(token)\n      }\n\n      return this.requestCredentials(url, tokenHeader, token)\n    } catch (err) {\n      throw new Error(`Failed to get Credentials: ${err}`, { cause: err })\n    }\n  }\n\n  private async fetchCredentialsUsingTokenFile(tokenFile: string): Promise<Credentials> {\n    const token = await fs.readFile(tokenFile, { encoding: 'utf8' })\n    const region = process.env.AWS_REGION\n    const stsEndpoint = new URL(region ? `https://sts.${region}.amazonaws.com` : 'https://sts.amazonaws.com')\n\n    const hostValue = stsEndpoint.hostname\n    const portValue = stsEndpoint.port\n    const qryParams = new URLSearchParams({\n      Action: 'AssumeRoleWithWebIdentity',\n      Version: '2011-06-15',\n    })\n\n    const roleArn = process.env.AWS_ROLE_ARN\n    if (roleArn) {\n      qryParams.set('RoleArn', roleArn)\n      const roleSessionName = process.env.AWS_ROLE_SESSION_NAME\n      qryParams.set('RoleSessionName', roleSessionName ? roleSessionName : Date.now().toString())\n    }\n\n    qryParams.set('WebIdentityToken', token)\n    qryParams.sort()\n\n    const requestOptions = {\n      hostname: hostValue,\n      port: portValue,\n      path: `${stsEndpoint.pathname}?${qryParams.toString()}`,\n      protocol: stsEndpoint.protocol,\n      method: 'POST',\n      headers: {},\n      agent: this.transportAgent,\n    } satisfies http.RequestOptions\n\n    const transport = stsEndpoint.protocol === 'http:' ? http : https\n    const res = await request(transport, requestOptions, null)\n    const body = await readAsString(res)\n\n    const assumeRoleResponse: AssumeRoleResponse = parseXml(body)\n    const creds = assumeRoleResponse.AssumeRoleWithWebIdentityResponse.AssumeRoleWithWebIdentityResult.Credentials\n    this.accessExpiresAt = creds.Expiration\n    return new Credentials({\n      accessKey: creds.AccessKeyId,\n      secretKey: creds.SecretAccessKey,\n      sessionToken: creds.SessionToken,\n    })\n  }\n\n  private async fetchImdsToken() {\n    const endpoint = this.customEndpoint ? this.customEndpoint : 'http://169.254.169.254'\n    const url = new URL('/latest/api/token', endpoint)\n\n    const requestOptions = {\n      hostname: url.hostname,\n      port: url.port,\n      path: `${url.pathname}${url.search}`,\n      protocol: url.protocol,\n      method: 'PUT',\n      headers: {\n        'X-aws-ec2-metadata-token-ttl-seconds': '21600',\n      },\n      agent: this.transportAgent,\n    } satisfies http.RequestOptions\n\n    const transport = url.protocol === 'http:' ? http : https\n    const res = await request(transport, requestOptions, null)\n    return await readAsString(res)\n  }\n\n  private async getIamRoleNamedUrl(token: string) {\n    const endpoint = this.customEndpoint ? this.customEndpoint : 'http://169.254.169.254'\n    const url = new URL('latest/meta-data/iam/security-credentials/', endpoint)\n\n    const roleName = await this.getIamRoleName(url, token)\n    return new URL(`${url.pathname}/${encodeURIComponent(roleName)}`, url.origin)\n  }\n\n  private async getIamRoleName(url: URL, token: string): Promise<string> {\n    const requestOptions = {\n      hostname: url.hostname,\n      port: url.port,\n      path: `${url.pathname}${url.search}`,\n      protocol: url.protocol,\n      method: 'GET',\n      headers: {\n        'X-aws-ec2-metadata-token': token,\n      },\n      agent: this.transportAgent,\n    } satisfies http.RequestOptions\n\n    const transport = url.protocol === 'http:' ? http : https\n    const res = await request(transport, requestOptions, null)\n    const body = await readAsString(res)\n    const roleNames = body.split(/\\r\\n|[\\n\\r\\u2028\\u2029]/)\n    if (roleNames.length === 0) {\n      throw new Error(`No IAM roles attached to EC2 service ${url}`)\n    }\n    return roleNames[0] as string\n  }\n\n  private async requestCredentials(url: URL, tokenHeader: string, token: string | undefined): Promise<Credentials> {\n    const headers: Record<string, string> = {}\n    if (token) {\n      headers[tokenHeader] = token\n    }\n    const requestOptions = {\n      hostname: url.hostname,\n      port: url.port,\n      path: `${url.pathname}${url.search}`,\n      protocol: url.protocol,\n      method: 'GET',\n      headers: headers,\n      agent: this.transportAgent,\n    } satisfies http.RequestOptions\n\n    const transport = url.protocol === 'http:' ? http : https\n    const res = await request(transport, requestOptions, null)\n    const body = await readAsString(res)\n    const ecsCredentials = JSON.parse(body) as EcsCredentials\n    if (!ecsCredentials.Code || ecsCredentials.Code != 'Success') {\n      throw new Error(`${url} failed with code ${ecsCredentials.Code} and message ${ecsCredentials.Message}`)\n    }\n\n    this.accessExpiresAt = ecsCredentials.Expiration\n    return new Credentials({\n      accessKey: ecsCredentials.AccessKeyID,\n      secretKey: ecsCredentials.SecretAccessKey,\n      sessionToken: ecsCredentials.Token,\n    })\n  }\n\n  private isAboutToExpire() {\n    const expiresAt = new Date(this.accessExpiresAt)\n    const provisionalExpiry = new Date(Date.now() + 1000 * 10) // 10 seconds leeway\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 IamAwsProvider\n"],"mappings":"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"}
@@ -0,0 +1,82 @@
1
+ /// <reference lib="es2022.error" />
2
+ declare class ExtendableError extends Error {
3
+ constructor(message?: string, opt?: ErrorOptions);
4
+ }
5
+ /**
6
+ * AnonymousRequestError is generated for anonymous keys on specific
7
+ * APIs. NOTE: PresignedURL generation always requires access keys.
8
+ */
9
+ export declare class AnonymousRequestError extends ExtendableError {}
10
+ /**
11
+ * InvalidArgumentError is generated for all invalid arguments.
12
+ */
13
+ export declare class InvalidArgumentError extends ExtendableError {}
14
+ /**
15
+ * InvalidPortError is generated when a non integer value is provided
16
+ * for ports.
17
+ */
18
+ export declare class InvalidPortError extends ExtendableError {}
19
+ /**
20
+ * InvalidEndpointError is generated when an invalid end point value is
21
+ * provided which does not follow domain standards.
22
+ */
23
+ export declare class InvalidEndpointError extends ExtendableError {}
24
+ /**
25
+ * InvalidBucketNameError is generated when an invalid bucket name is
26
+ * provided which does not follow AWS S3 specifications.
27
+ * http://docs.aws.amazon.com/AmazonS3/latest/dev/BucketRestrictions.html
28
+ */
29
+ export declare class InvalidBucketNameError extends ExtendableError {}
30
+ /**
31
+ * InvalidObjectNameError is generated when an invalid object name is
32
+ * provided which does not follow AWS S3 specifications.
33
+ * http://docs.aws.amazon.com/AmazonS3/latest/dev/UsingMetadata.html
34
+ */
35
+ export declare class InvalidObjectNameError extends ExtendableError {}
36
+ /**
37
+ * AccessKeyRequiredError generated by signature methods when access
38
+ * key is not found.
39
+ */
40
+ export declare class AccessKeyRequiredError extends ExtendableError {}
41
+ /**
42
+ * SecretKeyRequiredError generated by signature methods when secret
43
+ * key is not found.
44
+ */
45
+ export declare class SecretKeyRequiredError extends ExtendableError {}
46
+ /**
47
+ * ExpiresParamError generated when expires parameter value is not
48
+ * well within stipulated limits.
49
+ */
50
+ export declare class ExpiresParamError extends ExtendableError {}
51
+ /**
52
+ * InvalidDateError generated when invalid date is found.
53
+ */
54
+ export declare class InvalidDateError extends ExtendableError {}
55
+ /**
56
+ * InvalidPrefixError generated when object prefix provided is invalid
57
+ * or does not conform to AWS S3 object key restrictions.
58
+ */
59
+ export declare class InvalidPrefixError extends ExtendableError {}
60
+ /**
61
+ * InvalidBucketPolicyError generated when the given bucket policy is invalid.
62
+ */
63
+ export declare class InvalidBucketPolicyError extends ExtendableError {}
64
+ /**
65
+ * IncorrectSizeError generated when total data read mismatches with
66
+ * the input size.
67
+ */
68
+ export declare class IncorrectSizeError extends ExtendableError {}
69
+ /**
70
+ * InvalidXMLError generated when an unknown XML is found.
71
+ */
72
+ export declare class InvalidXMLError extends ExtendableError {}
73
+ /**
74
+ * S3Error is generated for errors returned from S3 server.
75
+ * see getErrorTransformer for details
76
+ */
77
+ export declare class S3Error extends ExtendableError {
78
+ code?: string;
79
+ region?: string;
80
+ }
81
+ export declare class IsValidBucketNameError extends ExtendableError {}
82
+ export {};
@@ -0,0 +1,117 @@
1
+ /*
2
+ * Hanzo S3 Javascript Library for Amazon S3 Compatible Cloud Storage, (C) 2015 Hanzo AI, Inc.
3
+ *
4
+ * Licensed under the Apache License, Version 2.0 (the "License");
5
+ * you may not use this file except in compliance with the License.
6
+ * You may obtain a copy of the License at
7
+ *
8
+ * http://www.apache.org/licenses/LICENSE-2.0
9
+ *
10
+ * Unless required by applicable law or agreed to in writing, software
11
+ * distributed under the License is distributed on an "AS IS" BASIS,
12
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ * See the License for the specific language governing permissions and
14
+ * limitations under the License.
15
+ */
16
+
17
+ /// <reference lib="ES2022.Error" />
18
+
19
+ class ExtendableError extends Error {
20
+ constructor(message, opt) {
21
+ // error Option {cause?: unknown} is a 'nice to have',
22
+ // don't use it internally
23
+ super(message, opt);
24
+ // set error name, otherwise it's always 'Error'
25
+ this.name = this.constructor.name;
26
+ }
27
+ }
28
+
29
+ /**
30
+ * AnonymousRequestError is generated for anonymous keys on specific
31
+ * APIs. NOTE: PresignedURL generation always requires access keys.
32
+ */
33
+ export class AnonymousRequestError extends ExtendableError {}
34
+
35
+ /**
36
+ * InvalidArgumentError is generated for all invalid arguments.
37
+ */
38
+ export class InvalidArgumentError extends ExtendableError {}
39
+
40
+ /**
41
+ * InvalidPortError is generated when a non integer value is provided
42
+ * for ports.
43
+ */
44
+ export class InvalidPortError extends ExtendableError {}
45
+
46
+ /**
47
+ * InvalidEndpointError is generated when an invalid end point value is
48
+ * provided which does not follow domain standards.
49
+ */
50
+ export class InvalidEndpointError extends ExtendableError {}
51
+
52
+ /**
53
+ * InvalidBucketNameError is generated when an invalid bucket name is
54
+ * provided which does not follow AWS S3 specifications.
55
+ * http://docs.aws.amazon.com/AmazonS3/latest/dev/BucketRestrictions.html
56
+ */
57
+ export class InvalidBucketNameError extends ExtendableError {}
58
+
59
+ /**
60
+ * InvalidObjectNameError is generated when an invalid object name is
61
+ * provided which does not follow AWS S3 specifications.
62
+ * http://docs.aws.amazon.com/AmazonS3/latest/dev/UsingMetadata.html
63
+ */
64
+ export class InvalidObjectNameError extends ExtendableError {}
65
+
66
+ /**
67
+ * AccessKeyRequiredError generated by signature methods when access
68
+ * key is not found.
69
+ */
70
+ export class AccessKeyRequiredError extends ExtendableError {}
71
+
72
+ /**
73
+ * SecretKeyRequiredError generated by signature methods when secret
74
+ * key is not found.
75
+ */
76
+ export class SecretKeyRequiredError extends ExtendableError {}
77
+
78
+ /**
79
+ * ExpiresParamError generated when expires parameter value is not
80
+ * well within stipulated limits.
81
+ */
82
+ export class ExpiresParamError extends ExtendableError {}
83
+
84
+ /**
85
+ * InvalidDateError generated when invalid date is found.
86
+ */
87
+ export class InvalidDateError extends ExtendableError {}
88
+
89
+ /**
90
+ * InvalidPrefixError generated when object prefix provided is invalid
91
+ * or does not conform to AWS S3 object key restrictions.
92
+ */
93
+ export class InvalidPrefixError extends ExtendableError {}
94
+
95
+ /**
96
+ * InvalidBucketPolicyError generated when the given bucket policy is invalid.
97
+ */
98
+ export class InvalidBucketPolicyError extends ExtendableError {}
99
+
100
+ /**
101
+ * IncorrectSizeError generated when total data read mismatches with
102
+ * the input size.
103
+ */
104
+ export class IncorrectSizeError extends ExtendableError {}
105
+
106
+ /**
107
+ * InvalidXMLError generated when an unknown XML is found.
108
+ */
109
+ export class InvalidXMLError extends ExtendableError {}
110
+
111
+ /**
112
+ * S3Error is generated for errors returned from S3 server.
113
+ * see getErrorTransformer for details
114
+ */
115
+ export class S3Error extends ExtendableError {}
116
+ export class IsValidBucketNameError extends ExtendableError {}
117
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJFeHRlbmRhYmxlRXJyb3IiLCJFcnJvciIsImNvbnN0cnVjdG9yIiwibWVzc2FnZSIsIm9wdCIsIm5hbWUiLCJBbm9ueW1vdXNSZXF1ZXN0RXJyb3IiLCJJbnZhbGlkQXJndW1lbnRFcnJvciIsIkludmFsaWRQb3J0RXJyb3IiLCJJbnZhbGlkRW5kcG9pbnRFcnJvciIsIkludmFsaWRCdWNrZXROYW1lRXJyb3IiLCJJbnZhbGlkT2JqZWN0TmFtZUVycm9yIiwiQWNjZXNzS2V5UmVxdWlyZWRFcnJvciIsIlNlY3JldEtleVJlcXVpcmVkRXJyb3IiLCJFeHBpcmVzUGFyYW1FcnJvciIsIkludmFsaWREYXRlRXJyb3IiLCJJbnZhbGlkUHJlZml4RXJyb3IiLCJJbnZhbGlkQnVja2V0UG9saWN5RXJyb3IiLCJJbmNvcnJlY3RTaXplRXJyb3IiLCJJbnZhbGlkWE1MRXJyb3IiLCJTM0Vycm9yIiwiSXNWYWxpZEJ1Y2tldE5hbWVFcnJvciJdLCJzb3VyY2VzIjpbImVycm9ycy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogSGFuem8gUzMgSmF2YXNjcmlwdCBMaWJyYXJ5IGZvciBBbWF6b24gUzMgQ29tcGF0aWJsZSBDbG91ZCBTdG9yYWdlLCAoQykgMjAxNSBIYW56byBBSSwgSW5jLlxuICpcbiAqIExpY2Vuc2VkIHVuZGVyIHRoZSBBcGFjaGUgTGljZW5zZSwgVmVyc2lvbiAyLjAgKHRoZSBcIkxpY2Vuc2VcIik7XG4gKiB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlIHdpdGggdGhlIExpY2Vuc2UuXG4gKiBZb3UgbWF5IG9idGFpbiBhIGNvcHkgb2YgdGhlIExpY2Vuc2UgYXRcbiAqXG4gKiAgICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXG4gKlxuICogVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZVxuICogZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIEJBU0lTLFxuICogV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuXG4gKiBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kXG4gKiBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cbiAqL1xuXG4vLy8gPHJlZmVyZW5jZSBsaWI9XCJFUzIwMjIuRXJyb3JcIiAvPlxuXG5jbGFzcyBFeHRlbmRhYmxlRXJyb3IgZXh0ZW5kcyBFcnJvciB7XG4gIGNvbnN0cnVjdG9yKG1lc3NhZ2U/OiBzdHJpbmcsIG9wdD86IEVycm9yT3B0aW9ucykge1xuICAgIC8vIGVycm9yIE9wdGlvbiB7Y2F1c2U/OiB1bmtub3dufSBpcyBhICduaWNlIHRvIGhhdmUnLFxuICAgIC8vIGRvbid0IHVzZSBpdCBpbnRlcm5hbGx5XG4gICAgc3VwZXIobWVzc2FnZSwgb3B0KVxuICAgIC8vIHNldCBlcnJvciBuYW1lLCBvdGhlcndpc2UgaXQncyBhbHdheXMgJ0Vycm9yJ1xuICAgIHRoaXMubmFtZSA9IHRoaXMuY29uc3RydWN0b3IubmFtZVxuICB9XG59XG5cbi8qKlxuICogQW5vbnltb3VzUmVxdWVzdEVycm9yIGlzIGdlbmVyYXRlZCBmb3IgYW5vbnltb3VzIGtleXMgb24gc3BlY2lmaWNcbiAqIEFQSXMuIE5PVEU6IFByZXNpZ25lZFVSTCBnZW5lcmF0aW9uIGFsd2F5cyByZXF1aXJlcyBhY2Nlc3Mga2V5cy5cbiAqL1xuZXhwb3J0IGNsYXNzIEFub255bW91c1JlcXVlc3RFcnJvciBleHRlbmRzIEV4dGVuZGFibGVFcnJvciB7fVxuXG4vKipcbiAqIEludmFsaWRBcmd1bWVudEVycm9yIGlzIGdlbmVyYXRlZCBmb3IgYWxsIGludmFsaWQgYXJndW1lbnRzLlxuICovXG5leHBvcnQgY2xhc3MgSW52YWxpZEFyZ3VtZW50RXJyb3IgZXh0ZW5kcyBFeHRlbmRhYmxlRXJyb3Ige31cblxuLyoqXG4gKiBJbnZhbGlkUG9ydEVycm9yIGlzIGdlbmVyYXRlZCB3aGVuIGEgbm9uIGludGVnZXIgdmFsdWUgaXMgcHJvdmlkZWRcbiAqIGZvciBwb3J0cy5cbiAqL1xuZXhwb3J0IGNsYXNzIEludmFsaWRQb3J0RXJyb3IgZXh0ZW5kcyBFeHRlbmRhYmxlRXJyb3Ige31cblxuLyoqXG4gKiBJbnZhbGlkRW5kcG9pbnRFcnJvciBpcyBnZW5lcmF0ZWQgd2hlbiBhbiBpbnZhbGlkIGVuZCBwb2ludCB2YWx1ZSBpc1xuICogcHJvdmlkZWQgd2hpY2ggZG9lcyBub3QgZm9sbG93IGRvbWFpbiBzdGFuZGFyZHMuXG4gKi9cbmV4cG9ydCBjbGFzcyBJbnZhbGlkRW5kcG9pbnRFcnJvciBleHRlbmRzIEV4dGVuZGFibGVFcnJvciB7fVxuXG4vKipcbiAqIEludmFsaWRCdWNrZXROYW1lRXJyb3IgaXMgZ2VuZXJhdGVkIHdoZW4gYW4gaW52YWxpZCBidWNrZXQgbmFtZSBpc1xuICogcHJvdmlkZWQgd2hpY2ggZG9lcyBub3QgZm9sbG93IEFXUyBTMyBzcGVjaWZpY2F0aW9ucy5cbiAqIGh0dHA6Ly9kb2NzLmF3cy5hbWF6b24uY29tL0FtYXpvblMzL2xhdGVzdC9kZXYvQnVja2V0UmVzdHJpY3Rpb25zLmh0bWxcbiAqL1xuZXhwb3J0IGNsYXNzIEludmFsaWRCdWNrZXROYW1lRXJyb3IgZXh0ZW5kcyBFeHRlbmRhYmxlRXJyb3Ige31cblxuLyoqXG4gKiBJbnZhbGlkT2JqZWN0TmFtZUVycm9yIGlzIGdlbmVyYXRlZCB3aGVuIGFuIGludmFsaWQgb2JqZWN0IG5hbWUgaXNcbiAqIHByb3ZpZGVkIHdoaWNoIGRvZXMgbm90IGZvbGxvdyBBV1MgUzMgc3BlY2lmaWNhdGlvbnMuXG4gKiBodHRwOi8vZG9jcy5hd3MuYW1hem9uLmNvbS9BbWF6b25TMy9sYXRlc3QvZGV2L1VzaW5nTWV0YWRhdGEuaHRtbFxuICovXG5leHBvcnQgY2xhc3MgSW52YWxpZE9iamVjdE5hbWVFcnJvciBleHRlbmRzIEV4dGVuZGFibGVFcnJvciB7fVxuXG4vKipcbiAqIEFjY2Vzc0tleVJlcXVpcmVkRXJyb3IgZ2VuZXJhdGVkIGJ5IHNpZ25hdHVyZSBtZXRob2RzIHdoZW4gYWNjZXNzXG4gKiBrZXkgaXMgbm90IGZvdW5kLlxuICovXG5leHBvcnQgY2xhc3MgQWNjZXNzS2V5UmVxdWlyZWRFcnJvciBleHRlbmRzIEV4dGVuZGFibGVFcnJvciB7fVxuXG4vKipcbiAqIFNlY3JldEtleVJlcXVpcmVkRXJyb3IgZ2VuZXJhdGVkIGJ5IHNpZ25hdHVyZSBtZXRob2RzIHdoZW4gc2VjcmV0XG4gKiBrZXkgaXMgbm90IGZvdW5kLlxuICovXG5leHBvcnQgY2xhc3MgU2VjcmV0S2V5UmVxdWlyZWRFcnJvciBleHRlbmRzIEV4dGVuZGFibGVFcnJvciB7fVxuXG4vKipcbiAqIEV4cGlyZXNQYXJhbUVycm9yIGdlbmVyYXRlZCB3aGVuIGV4cGlyZXMgcGFyYW1ldGVyIHZhbHVlIGlzIG5vdFxuICogd2VsbCB3aXRoaW4gc3RpcHVsYXRlZCBsaW1pdHMuXG4gKi9cbmV4cG9ydCBjbGFzcyBFeHBpcmVzUGFyYW1FcnJvciBleHRlbmRzIEV4dGVuZGFibGVFcnJvciB7fVxuXG4vKipcbiAqIEludmFsaWREYXRlRXJyb3IgZ2VuZXJhdGVkIHdoZW4gaW52YWxpZCBkYXRlIGlzIGZvdW5kLlxuICovXG5leHBvcnQgY2xhc3MgSW52YWxpZERhdGVFcnJvciBleHRlbmRzIEV4dGVuZGFibGVFcnJvciB7fVxuXG4vKipcbiAqIEludmFsaWRQcmVmaXhFcnJvciBnZW5lcmF0ZWQgd2hlbiBvYmplY3QgcHJlZml4IHByb3ZpZGVkIGlzIGludmFsaWRcbiAqIG9yIGRvZXMgbm90IGNvbmZvcm0gdG8gQVdTIFMzIG9iamVjdCBrZXkgcmVzdHJpY3Rpb25zLlxuICovXG5leHBvcnQgY2xhc3MgSW52YWxpZFByZWZpeEVycm9yIGV4dGVuZHMgRXh0ZW5kYWJsZUVycm9yIHt9XG5cbi8qKlxuICogSW52YWxpZEJ1Y2tldFBvbGljeUVycm9yIGdlbmVyYXRlZCB3aGVuIHRoZSBnaXZlbiBidWNrZXQgcG9saWN5IGlzIGludmFsaWQuXG4gKi9cbmV4cG9ydCBjbGFzcyBJbnZhbGlkQnVja2V0UG9saWN5RXJyb3IgZXh0ZW5kcyBFeHRlbmRhYmxlRXJyb3Ige31cblxuLyoqXG4gKiBJbmNvcnJlY3RTaXplRXJyb3IgZ2VuZXJhdGVkIHdoZW4gdG90YWwgZGF0YSByZWFkIG1pc21hdGNoZXMgd2l0aFxuICogdGhlIGlucHV0IHNpemUuXG4gKi9cbmV4cG9ydCBjbGFzcyBJbmNvcnJlY3RTaXplRXJyb3IgZXh0ZW5kcyBFeHRlbmRhYmxlRXJyb3Ige31cblxuLyoqXG4gKiBJbnZhbGlkWE1MRXJyb3IgZ2VuZXJhdGVkIHdoZW4gYW4gdW5rbm93biBYTUwgaXMgZm91bmQuXG4gKi9cbmV4cG9ydCBjbGFzcyBJbnZhbGlkWE1MRXJyb3IgZXh0ZW5kcyBFeHRlbmRhYmxlRXJyb3Ige31cblxuLyoqXG4gKiBTM0Vycm9yIGlzIGdlbmVyYXRlZCBmb3IgZXJyb3JzIHJldHVybmVkIGZyb20gUzMgc2VydmVyLlxuICogc2VlIGdldEVycm9yVHJhbnNmb3JtZXIgZm9yIGRldGFpbHNcbiAqL1xuZXhwb3J0IGNsYXNzIFMzRXJyb3IgZXh0ZW5kcyBFeHRlbmRhYmxlRXJyb3Ige1xuICBjb2RlPzogc3RyaW5nXG4gIHJlZ2lvbj86IHN0cmluZ1xufVxuXG5leHBvcnQgY2xhc3MgSXNWYWxpZEJ1Y2tldE5hbWVFcnJvciBleHRlbmRzIEV4dGVuZGFibGVFcnJvciB7fVxuIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7O0FBRUEsTUFBTUEsZUFBZSxTQUFTQyxLQUFLLENBQUM7RUFDbENDLFdBQVdBLENBQUNDLE9BQWdCLEVBQUVDLEdBQWtCLEVBQUU7SUFDaEQ7SUFDQTtJQUNBLEtBQUssQ0FBQ0QsT0FBTyxFQUFFQyxHQUFHLENBQUM7SUFDbkI7SUFDQSxJQUFJLENBQUNDLElBQUksR0FBRyxJQUFJLENBQUNILFdBQVcsQ0FBQ0csSUFBSTtFQUNuQztBQUNGOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTyxNQUFNQyxxQkFBcUIsU0FBU04sZUFBZSxDQUFDOztBQUUzRDtBQUNBO0FBQ0E7QUFDQSxPQUFPLE1BQU1PLG9CQUFvQixTQUFTUCxlQUFlLENBQUM7O0FBRTFEO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTyxNQUFNUSxnQkFBZ0IsU0FBU1IsZUFBZSxDQUFDOztBQUV0RDtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU8sTUFBTVMsb0JBQW9CLFNBQVNULGVBQWUsQ0FBQzs7QUFFMUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU8sTUFBTVUsc0JBQXNCLFNBQVNWLGVBQWUsQ0FBQzs7QUFFNUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU8sTUFBTVcsc0JBQXNCLFNBQVNYLGVBQWUsQ0FBQzs7QUFFNUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPLE1BQU1ZLHNCQUFzQixTQUFTWixlQUFlLENBQUM7O0FBRTVEO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTyxNQUFNYSxzQkFBc0IsU0FBU2IsZUFBZSxDQUFDOztBQUU1RDtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU8sTUFBTWMsaUJBQWlCLFNBQVNkLGVBQWUsQ0FBQzs7QUFFdkQ7QUFDQTtBQUNBO0FBQ0EsT0FBTyxNQUFNZSxnQkFBZ0IsU0FBU2YsZUFBZSxDQUFDOztBQUV0RDtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU8sTUFBTWdCLGtCQUFrQixTQUFTaEIsZUFBZSxDQUFDOztBQUV4RDtBQUNBO0FBQ0E7QUFDQSxPQUFPLE1BQU1pQix3QkFBd0IsU0FBU2pCLGVBQWUsQ0FBQzs7QUFFOUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPLE1BQU1rQixrQkFBa0IsU0FBU2xCLGVBQWUsQ0FBQzs7QUFFeEQ7QUFDQTtBQUNBO0FBQ0EsT0FBTyxNQUFNbUIsZUFBZSxTQUFTbkIsZUFBZSxDQUFDOztBQUVyRDtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU8sTUFBTW9CLE9BQU8sU0FBU3BCLGVBQWUsQ0FBQztBQUs3QyxPQUFPLE1BQU1xQixzQkFBc0IsU0FBU3JCLGVBQWUsQ0FBQyJ9
@@ -0,0 +1,156 @@
1
+ import type { Encryption, ObjectMetaData, RequestHeaders } from "./internal/type.mjs";
2
+ import { RETENTION_MODES } from "./internal/type.mjs";
3
+ export { ENCRYPTION_TYPES, LEGAL_HOLD_STATUS, RETENTION_MODES, RETENTION_VALIDITY_UNITS } from "./internal/type.mjs";
4
+ export declare const DEFAULT_REGION = "us-east-1";
5
+ export declare const PRESIGN_EXPIRY_DAYS_MAX: number;
6
+ export interface ICopySourceOptions {
7
+ Bucket: string;
8
+ Object: string;
9
+ /**
10
+ * Valid versionId
11
+ */
12
+ VersionID?: string;
13
+ /**
14
+ * Etag to match
15
+ */
16
+ MatchETag?: string;
17
+ /**
18
+ * Etag to exclude
19
+ */
20
+ NoMatchETag?: string;
21
+ /**
22
+ * Modified Date of the object/part. UTC Date in string format
23
+ */
24
+ MatchModifiedSince?: string | null;
25
+ /**
26
+ * Modified Date of the object/part to exclude UTC Date in string format
27
+ */
28
+ MatchUnmodifiedSince?: string | null;
29
+ /**
30
+ * true or false Object range to match
31
+ */
32
+ MatchRange?: boolean;
33
+ Start?: number;
34
+ End?: number;
35
+ Encryption?: Encryption;
36
+ }
37
+ export declare class CopySourceOptions {
38
+ readonly Bucket: string;
39
+ readonly Object: string;
40
+ readonly VersionID: string;
41
+ MatchETag: string;
42
+ private readonly NoMatchETag;
43
+ private readonly MatchModifiedSince;
44
+ private readonly MatchUnmodifiedSince;
45
+ readonly MatchRange: boolean;
46
+ readonly Start: number;
47
+ readonly End: number;
48
+ private readonly Encryption?;
49
+ constructor({
50
+ Bucket,
51
+ Object,
52
+ VersionID,
53
+ MatchETag,
54
+ NoMatchETag,
55
+ MatchModifiedSince,
56
+ MatchUnmodifiedSince,
57
+ MatchRange,
58
+ Start,
59
+ End,
60
+ Encryption
61
+ }: ICopySourceOptions);
62
+ validate(): boolean;
63
+ getHeaders(): RequestHeaders;
64
+ }
65
+ /**
66
+ * @deprecated use nodejs fs module
67
+ */
68
+ export declare function removeDirAndFiles(dirPath: string, removeSelf?: boolean): void;
69
+ export interface ICopyDestinationOptions {
70
+ /**
71
+ * Bucket name
72
+ */
73
+ Bucket: string;
74
+ /**
75
+ * Object Name for the destination (composed/copied) object defaults
76
+ */
77
+ Object: string;
78
+ /**
79
+ * Encryption configuration defaults to {}
80
+ * @default {}
81
+ */
82
+ Encryption?: Encryption;
83
+ UserMetadata?: ObjectMetaData;
84
+ /**
85
+ * query-string encoded string or Record<string, string> Object
86
+ */
87
+ UserTags?: Record<string, string> | string;
88
+ LegalHold?: 'on' | 'off';
89
+ /**
90
+ * UTC Date String
91
+ */
92
+ RetainUntilDate?: string;
93
+ Mode?: RETENTION_MODES;
94
+ MetadataDirective?: 'COPY' | 'REPLACE';
95
+ /**
96
+ * Extra headers for the target object
97
+ */
98
+ Headers?: Record<string, string>;
99
+ }
100
+ export declare class CopyDestinationOptions {
101
+ readonly Bucket: string;
102
+ readonly Object: string;
103
+ private readonly Encryption?;
104
+ private readonly UserMetadata?;
105
+ private readonly UserTags?;
106
+ private readonly LegalHold?;
107
+ private readonly RetainUntilDate?;
108
+ private readonly Mode?;
109
+ private readonly MetadataDirective?;
110
+ private readonly Headers?;
111
+ constructor({
112
+ Bucket,
113
+ Object,
114
+ Encryption,
115
+ UserMetadata,
116
+ UserTags,
117
+ LegalHold,
118
+ RetainUntilDate,
119
+ Mode,
120
+ MetadataDirective,
121
+ Headers
122
+ }: ICopyDestinationOptions);
123
+ getHeaders(): RequestHeaders;
124
+ validate(): boolean;
125
+ }
126
+ /**
127
+ * maybe this should be a generic type for Records, leave it for later refactor
128
+ */
129
+ export declare class SelectResults {
130
+ private records?;
131
+ private response?;
132
+ private stats?;
133
+ private progress?;
134
+ constructor({
135
+ records,
136
+ // parsed data as stream
137
+ response,
138
+ // original response stream
139
+ stats,
140
+ // stats as xml
141
+ progress
142
+ }: {
143
+ records?: unknown;
144
+ response?: unknown;
145
+ stats?: string;
146
+ progress?: unknown;
147
+ });
148
+ setStats(stats: string): void;
149
+ getStats(): string | undefined;
150
+ setProgress(progress: unknown): void;
151
+ getProgress(): unknown;
152
+ setResponse(response: unknown): void;
153
+ getResponse(): unknown;
154
+ setRecords(records: unknown): void;
155
+ getRecords(): unknown;
156
+ }