@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.
- package/LICENSE +202 -0
- package/MAINTAINERS.md +62 -0
- package/README.md +262 -0
- package/README_zh_CN.md +192 -0
- package/dist/esm/AssumeRoleProvider.d.mts +86 -0
- package/dist/esm/AssumeRoleProvider.mjs +183 -0
- package/dist/esm/CredentialProvider.d.mts +22 -0
- package/dist/esm/CredentialProvider.mjs +48 -0
- package/dist/esm/Credentials.d.mts +22 -0
- package/dist/esm/Credentials.mjs +38 -0
- package/dist/esm/IamAwsProvider.d.mts +27 -0
- package/dist/esm/IamAwsProvider.mjs +189 -0
- package/dist/esm/errors.d.mts +82 -0
- package/dist/esm/errors.mjs +117 -0
- package/dist/esm/helpers.d.mts +156 -0
- package/dist/esm/helpers.mjs +218 -0
- package/dist/esm/internal/async.d.mts +9 -0
- package/dist/esm/internal/async.mjs +14 -0
- package/dist/esm/internal/callbackify.d.mts +1 -0
- package/dist/esm/internal/callbackify.mjs +15 -0
- package/dist/esm/internal/client.d.mts +394 -0
- package/dist/esm/internal/client.mjs +3007 -0
- package/dist/esm/internal/copy-conditions.d.mts +10 -0
- package/dist/esm/internal/copy-conditions.mjs +25 -0
- package/dist/esm/internal/extensions.d.mts +18 -0
- package/dist/esm/internal/extensions.mjs +114 -0
- package/dist/esm/internal/helper.d.mts +177 -0
- package/dist/esm/internal/helper.mjs +552 -0
- package/dist/esm/internal/join-host-port.d.mts +11 -0
- package/dist/esm/internal/join-host-port.mjs +23 -0
- package/dist/esm/internal/post-policy.d.mts +17 -0
- package/dist/esm/internal/post-policy.mjs +98 -0
- package/dist/esm/internal/request.d.mts +11 -0
- package/dist/esm/internal/request.mjs +75 -0
- package/dist/esm/internal/response.d.mts +8 -0
- package/dist/esm/internal/response.mjs +16 -0
- package/dist/esm/internal/s3-endpoints.d.mts +38 -0
- package/dist/esm/internal/s3-endpoints.mjs +68 -0
- package/dist/esm/internal/type.d.mts +482 -0
- package/dist/esm/internal/type.mjs +30 -0
- package/dist/esm/internal/xml-parser.d.mts +93 -0
- package/dist/esm/internal/xml-parser.mjs +819 -0
- package/dist/esm/notification.d.mts +58 -0
- package/dist/esm/notification.mjs +209 -0
- package/dist/esm/s3.d.mts +40 -0
- package/dist/esm/s3.mjs +86 -0
- package/dist/esm/signing.d.mts +5 -0
- package/dist/esm/signing.mjs +258 -0
- package/dist/main/AssumeRoleProvider.d.ts +86 -0
- package/dist/main/AssumeRoleProvider.js +191 -0
- package/dist/main/CredentialProvider.d.ts +22 -0
- package/dist/main/CredentialProvider.js +55 -0
- package/dist/main/Credentials.d.ts +22 -0
- package/dist/main/Credentials.js +45 -0
- package/dist/main/IamAwsProvider.d.ts +27 -0
- package/dist/main/IamAwsProvider.js +198 -0
- package/dist/main/errors.d.ts +82 -0
- package/dist/main/errors.js +138 -0
- package/dist/main/helpers.d.ts +156 -0
- package/dist/main/helpers.js +233 -0
- package/dist/main/internal/async.d.ts +9 -0
- package/dist/main/internal/async.js +24 -0
- package/dist/main/internal/callbackify.d.ts +1 -0
- package/dist/main/internal/callbackify.js +21 -0
- package/dist/main/internal/client.d.ts +394 -0
- package/dist/main/internal/client.js +3014 -0
- package/dist/main/internal/copy-conditions.d.ts +10 -0
- package/dist/main/internal/copy-conditions.js +31 -0
- package/dist/main/internal/extensions.d.ts +18 -0
- package/dist/main/internal/extensions.js +122 -0
- package/dist/main/internal/helper.d.ts +177 -0
- package/dist/main/internal/helper.js +608 -0
- package/dist/main/internal/join-host-port.d.ts +11 -0
- package/dist/main/internal/join-host-port.js +29 -0
- package/dist/main/internal/post-policy.d.ts +17 -0
- package/dist/main/internal/post-policy.js +107 -0
- package/dist/main/internal/request.d.ts +11 -0
- package/dist/main/internal/request.js +83 -0
- package/dist/main/internal/response.d.ts +8 -0
- package/dist/main/internal/response.js +24 -0
- package/dist/main/internal/s3-endpoints.d.ts +38 -0
- package/dist/main/internal/s3-endpoints.js +73 -0
- package/dist/main/internal/type.d.ts +482 -0
- package/dist/main/internal/type.js +42 -0
- package/dist/main/internal/xml-parser.d.ts +93 -0
- package/dist/main/internal/xml-parser.js +849 -0
- package/dist/main/notification.d.ts +58 -0
- package/dist/main/notification.js +230 -0
- package/dist/main/s3.d.ts +40 -0
- package/dist/main/s3.js +117 -0
- package/dist/main/signing.d.ts +5 -0
- package/dist/main/signing.js +269 -0
- package/package.json +146 -39
- package/src/AssumeRoleProvider.ts +262 -0
- package/src/CredentialProvider.ts +54 -0
- package/src/Credentials.ts +44 -0
- package/src/IamAwsProvider.ts +234 -0
- package/src/errors.ts +120 -0
- package/src/helpers.ts +354 -0
- package/src/internal/async.ts +14 -0
- package/src/internal/callbackify.ts +19 -0
- package/src/internal/client.ts +3412 -0
- package/src/internal/copy-conditions.ts +30 -0
- package/src/internal/extensions.ts +140 -0
- package/src/internal/helper.ts +606 -0
- package/src/internal/join-host-port.ts +23 -0
- package/src/internal/post-policy.ts +99 -0
- package/src/internal/request.ts +102 -0
- package/src/internal/response.ts +26 -0
- package/src/internal/s3-endpoints.ts +70 -0
- package/src/internal/type.ts +577 -0
- package/src/internal/xml-parser.ts +871 -0
- package/src/notification.ts +254 -0
- package/src/s3.ts +155 -0
- package/src/signing.ts +325 -0
- package/lib/index.js +0 -450
- package/lib/index.js.map +0 -7
- package/lib/perfTest.js +0 -91
- 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
|
+
}
|