@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,10 @@
|
|
|
1
|
+
export declare class CopyConditions {
|
|
2
|
+
modified: string;
|
|
3
|
+
unmodified: string;
|
|
4
|
+
matchETag: string;
|
|
5
|
+
matchETagExcept: string;
|
|
6
|
+
setModified(date: Date): void;
|
|
7
|
+
setUnmodified(date: Date): void;
|
|
8
|
+
setMatchETag(etag: string): void;
|
|
9
|
+
setMatchETagExcept(etag: string): void;
|
|
10
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
class CopyConditions {
|
|
7
|
+
modified = '';
|
|
8
|
+
unmodified = '';
|
|
9
|
+
matchETag = '';
|
|
10
|
+
matchETagExcept = '';
|
|
11
|
+
setModified(date) {
|
|
12
|
+
if (!(date instanceof Date)) {
|
|
13
|
+
throw new TypeError('date must be of type Date');
|
|
14
|
+
}
|
|
15
|
+
this.modified = date.toUTCString();
|
|
16
|
+
}
|
|
17
|
+
setUnmodified(date) {
|
|
18
|
+
if (!(date instanceof Date)) {
|
|
19
|
+
throw new TypeError('date must be of type Date');
|
|
20
|
+
}
|
|
21
|
+
this.unmodified = date.toUTCString();
|
|
22
|
+
}
|
|
23
|
+
setMatchETag(etag) {
|
|
24
|
+
this.matchETag = etag;
|
|
25
|
+
}
|
|
26
|
+
setMatchETagExcept(etag) {
|
|
27
|
+
this.matchETagExcept = etag;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
exports.CopyConditions = CopyConditions;
|
|
31
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJDb3B5Q29uZGl0aW9ucyIsIm1vZGlmaWVkIiwidW5tb2RpZmllZCIsIm1hdGNoRVRhZyIsIm1hdGNoRVRhZ0V4Y2VwdCIsInNldE1vZGlmaWVkIiwiZGF0ZSIsIkRhdGUiLCJUeXBlRXJyb3IiLCJ0b1VUQ1N0cmluZyIsInNldFVubW9kaWZpZWQiLCJzZXRNYXRjaEVUYWciLCJldGFnIiwic2V0TWF0Y2hFVGFnRXhjZXB0IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbImNvcHktY29uZGl0aW9ucy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgQ29weUNvbmRpdGlvbnMge1xuICBwdWJsaWMgbW9kaWZpZWQgPSAnJ1xuICBwdWJsaWMgdW5tb2RpZmllZCA9ICcnXG4gIHB1YmxpYyBtYXRjaEVUYWcgPSAnJ1xuICBwdWJsaWMgbWF0Y2hFVGFnRXhjZXB0ID0gJydcblxuICBzZXRNb2RpZmllZChkYXRlOiBEYXRlKTogdm9pZCB7XG4gICAgaWYgKCEoZGF0ZSBpbnN0YW5jZW9mIERhdGUpKSB7XG4gICAgICB0aHJvdyBuZXcgVHlwZUVycm9yKCdkYXRlIG11c3QgYmUgb2YgdHlwZSBEYXRlJylcbiAgICB9XG5cbiAgICB0aGlzLm1vZGlmaWVkID0gZGF0ZS50b1VUQ1N0cmluZygpXG4gIH1cblxuICBzZXRVbm1vZGlmaWVkKGRhdGU6IERhdGUpOiB2b2lkIHtcbiAgICBpZiAoIShkYXRlIGluc3RhbmNlb2YgRGF0ZSkpIHtcbiAgICAgIHRocm93IG5ldyBUeXBlRXJyb3IoJ2RhdGUgbXVzdCBiZSBvZiB0eXBlIERhdGUnKVxuICAgIH1cblxuICAgIHRoaXMudW5tb2RpZmllZCA9IGRhdGUudG9VVENTdHJpbmcoKVxuICB9XG5cbiAgc2V0TWF0Y2hFVGFnKGV0YWc6IHN0cmluZyk6IHZvaWQge1xuICAgIHRoaXMubWF0Y2hFVGFnID0gZXRhZ1xuICB9XG5cbiAgc2V0TWF0Y2hFVGFnRXhjZXB0KGV0YWc6IHN0cmluZyk6IHZvaWQge1xuICAgIHRoaXMubWF0Y2hFVGFnRXhjZXB0ID0gZXRhZ1xuICB9XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7O0FBQU8sTUFBTUEsY0FBYyxDQUFDO0VBQ25CQyxRQUFRLEdBQUcsRUFBRTtFQUNiQyxVQUFVLEdBQUcsRUFBRTtFQUNmQyxTQUFTLEdBQUcsRUFBRTtFQUNkQyxlQUFlLEdBQUcsRUFBRTtFQUUzQkMsV0FBV0EsQ0FBQ0MsSUFBVSxFQUFRO0lBQzVCLElBQUksRUFBRUEsSUFBSSxZQUFZQyxJQUFJLENBQUMsRUFBRTtNQUMzQixNQUFNLElBQUlDLFNBQVMsQ0FBQywyQkFBMkIsQ0FBQztJQUNsRDtJQUVBLElBQUksQ0FBQ1AsUUFBUSxHQUFHSyxJQUFJLENBQUNHLFdBQVcsQ0FBQyxDQUFDO0VBQ3BDO0VBRUFDLGFBQWFBLENBQUNKLElBQVUsRUFBUTtJQUM5QixJQUFJLEVBQUVBLElBQUksWUFBWUMsSUFBSSxDQUFDLEVBQUU7TUFDM0IsTUFBTSxJQUFJQyxTQUFTLENBQUMsMkJBQTJCLENBQUM7SUFDbEQ7SUFFQSxJQUFJLENBQUNOLFVBQVUsR0FBR0ksSUFBSSxDQUFDRyxXQUFXLENBQUMsQ0FBQztFQUN0QztFQUVBRSxZQUFZQSxDQUFDQyxJQUFZLEVBQVE7SUFDL0IsSUFBSSxDQUFDVCxTQUFTLEdBQUdTLElBQUk7RUFDdkI7RUFFQUMsa0JBQWtCQSxDQUFDRCxJQUFZLEVBQVE7SUFDckMsSUFBSSxDQUFDUixlQUFlLEdBQUdRLElBQUk7RUFDN0I7QUFDRjtBQUFDRSxPQUFBLENBQUFkLGNBQUEsR0FBQUEsY0FBQSJ9
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import type { TypedClient } from "./client.js";
|
|
2
|
+
import type { BucketItemWithMetadata, BucketStream } from "./type.js";
|
|
3
|
+
export declare class Extensions {
|
|
4
|
+
private readonly client;
|
|
5
|
+
constructor(client: TypedClient);
|
|
6
|
+
/**
|
|
7
|
+
* List the objects in the bucket using S3 ListObjects V2 With Metadata
|
|
8
|
+
*
|
|
9
|
+
* @param bucketName - name of the bucket
|
|
10
|
+
* @param prefix - the prefix of the objects that should be listed (optional, default `''`)
|
|
11
|
+
* @param recursive - `true` indicates recursive style listing and `false` indicates directory style listing delimited by '/'. (optional, default `false`)
|
|
12
|
+
* @param startAfter - Specifies the key to start after when listing objects in a bucket. (optional, default `''`)
|
|
13
|
+
* @returns stream emitting the objects in the bucket, the object is of the format:
|
|
14
|
+
*/
|
|
15
|
+
listObjectsV2WithMetadata(bucketName: string, prefix?: string, recursive?: boolean, startAfter?: string): BucketStream<BucketItemWithMetadata>;
|
|
16
|
+
private listObjectsV2WithMetadataGen;
|
|
17
|
+
private listObjectsV2WithMetadataQuery;
|
|
18
|
+
}
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
var stream = _interopRequireWildcard(require("stream"), true);
|
|
7
|
+
var errors = _interopRequireWildcard(require("../errors.js"), true);
|
|
8
|
+
var _helper = require("./helper.js");
|
|
9
|
+
var _response = require("./response.js");
|
|
10
|
+
var _xmlParser = require("./xml-parser.js");
|
|
11
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
12
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
13
|
+
/*
|
|
14
|
+
* Hanzo S3 Javascript Library for Amazon S3 Compatible Cloud Storage, (C) 2020 Hanzo AI, Inc.
|
|
15
|
+
*
|
|
16
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
17
|
+
* you may not use this file except in compliance with the License.
|
|
18
|
+
* You may obtain a copy of the License at
|
|
19
|
+
*
|
|
20
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
21
|
+
*
|
|
22
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
23
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
24
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
25
|
+
* See the License for the specific language governing permissions and
|
|
26
|
+
* limitations under the License.
|
|
27
|
+
*/
|
|
28
|
+
|
|
29
|
+
class Extensions {
|
|
30
|
+
constructor(client) {
|
|
31
|
+
this.client = client;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
* List the objects in the bucket using S3 ListObjects V2 With Metadata
|
|
36
|
+
*
|
|
37
|
+
* @param bucketName - name of the bucket
|
|
38
|
+
* @param prefix - the prefix of the objects that should be listed (optional, default `''`)
|
|
39
|
+
* @param recursive - `true` indicates recursive style listing and `false` indicates directory style listing delimited by '/'. (optional, default `false`)
|
|
40
|
+
* @param startAfter - Specifies the key to start after when listing objects in a bucket. (optional, default `''`)
|
|
41
|
+
* @returns stream emitting the objects in the bucket, the object is of the format:
|
|
42
|
+
*/
|
|
43
|
+
listObjectsV2WithMetadata(bucketName, prefix, recursive, startAfter) {
|
|
44
|
+
if (prefix === undefined) {
|
|
45
|
+
prefix = '';
|
|
46
|
+
}
|
|
47
|
+
if (recursive === undefined) {
|
|
48
|
+
recursive = false;
|
|
49
|
+
}
|
|
50
|
+
if (startAfter === undefined) {
|
|
51
|
+
startAfter = '';
|
|
52
|
+
}
|
|
53
|
+
if (!(0, _helper.isValidBucketName)(bucketName)) {
|
|
54
|
+
throw new errors.InvalidBucketNameError('Invalid bucket name: ' + bucketName);
|
|
55
|
+
}
|
|
56
|
+
if (!(0, _helper.isValidPrefix)(prefix)) {
|
|
57
|
+
throw new errors.InvalidPrefixError(`Invalid prefix : ${prefix}`);
|
|
58
|
+
}
|
|
59
|
+
if (!(0, _helper.isString)(prefix)) {
|
|
60
|
+
throw new TypeError('prefix should be of type "string"');
|
|
61
|
+
}
|
|
62
|
+
if (!(0, _helper.isBoolean)(recursive)) {
|
|
63
|
+
throw new TypeError('recursive should be of type "boolean"');
|
|
64
|
+
}
|
|
65
|
+
if (!(0, _helper.isString)(startAfter)) {
|
|
66
|
+
throw new TypeError('startAfter should be of type "string"');
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
// if recursive is false set delimiter to '/'
|
|
70
|
+
const delimiter = recursive ? '' : '/';
|
|
71
|
+
return stream.Readable.from(this.listObjectsV2WithMetadataGen(bucketName, prefix, delimiter, startAfter), {
|
|
72
|
+
objectMode: true
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
async *listObjectsV2WithMetadataGen(bucketName, prefix, delimiter, startAfter) {
|
|
76
|
+
let ended = false;
|
|
77
|
+
let continuationToken = '';
|
|
78
|
+
do {
|
|
79
|
+
const result = await this.listObjectsV2WithMetadataQuery(bucketName, prefix, continuationToken, delimiter, startAfter);
|
|
80
|
+
ended = !result.isTruncated;
|
|
81
|
+
continuationToken = result.nextContinuationToken;
|
|
82
|
+
for (const obj of result.objects) {
|
|
83
|
+
yield obj;
|
|
84
|
+
}
|
|
85
|
+
} while (!ended);
|
|
86
|
+
}
|
|
87
|
+
async listObjectsV2WithMetadataQuery(bucketName, prefix, continuationToken, delimiter, startAfter) {
|
|
88
|
+
const queries = [];
|
|
89
|
+
|
|
90
|
+
// Call for listing objects v2 API
|
|
91
|
+
queries.push(`list-type=2`);
|
|
92
|
+
queries.push(`encoding-type=url`);
|
|
93
|
+
// escape every value in query string, except maxKeys
|
|
94
|
+
queries.push(`prefix=${(0, _helper.uriEscape)(prefix)}`);
|
|
95
|
+
queries.push(`delimiter=${(0, _helper.uriEscape)(delimiter)}`);
|
|
96
|
+
queries.push(`metadata=true`);
|
|
97
|
+
if (continuationToken) {
|
|
98
|
+
continuationToken = (0, _helper.uriEscape)(continuationToken);
|
|
99
|
+
queries.push(`continuation-token=${continuationToken}`);
|
|
100
|
+
}
|
|
101
|
+
// Set start-after
|
|
102
|
+
if (startAfter) {
|
|
103
|
+
startAfter = (0, _helper.uriEscape)(startAfter);
|
|
104
|
+
queries.push(`start-after=${startAfter}`);
|
|
105
|
+
}
|
|
106
|
+
queries.push(`max-keys=1000`);
|
|
107
|
+
queries.sort();
|
|
108
|
+
let query = '';
|
|
109
|
+
if (queries.length > 0) {
|
|
110
|
+
query = `${queries.join('&')}`;
|
|
111
|
+
}
|
|
112
|
+
const method = 'GET';
|
|
113
|
+
const res = await this.client.makeRequestAsync({
|
|
114
|
+
method,
|
|
115
|
+
bucketName,
|
|
116
|
+
query
|
|
117
|
+
});
|
|
118
|
+
return (0, _xmlParser.parseListObjectsV2WithMetadata)(await (0, _response.readAsString)(res));
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
exports.Extensions = Extensions;
|
|
122
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzdHJlYW0iLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInJlcXVpcmUiLCJlcnJvcnMiLCJfaGVscGVyIiwiX3Jlc3BvbnNlIiwiX3htbFBhcnNlciIsIl9nZXRSZXF1aXJlV2lsZGNhcmRDYWNoZSIsIm5vZGVJbnRlcm9wIiwiV2Vha01hcCIsImNhY2hlQmFiZWxJbnRlcm9wIiwiY2FjaGVOb2RlSW50ZXJvcCIsIm9iaiIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0IiwiY2FjaGUiLCJoYXMiLCJnZXQiLCJuZXdPYmoiLCJoYXNQcm9wZXJ0eURlc2NyaXB0b3IiLCJPYmplY3QiLCJkZWZpbmVQcm9wZXJ0eSIsImdldE93blByb3BlcnR5RGVzY3JpcHRvciIsImtleSIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsImRlc2MiLCJzZXQiLCJFeHRlbnNpb25zIiwiY29uc3RydWN0b3IiLCJjbGllbnQiLCJsaXN0T2JqZWN0c1YyV2l0aE1ldGFkYXRhIiwiYnVja2V0TmFtZSIsInByZWZpeCIsInJlY3Vyc2l2ZSIsInN0YXJ0QWZ0ZXIiLCJ1bmRlZmluZWQiLCJpc1ZhbGlkQnVja2V0TmFtZSIsIkludmFsaWRCdWNrZXROYW1lRXJyb3IiLCJpc1ZhbGlkUHJlZml4IiwiSW52YWxpZFByZWZpeEVycm9yIiwiaXNTdHJpbmciLCJUeXBlRXJyb3IiLCJpc0Jvb2xlYW4iLCJkZWxpbWl0ZXIiLCJSZWFkYWJsZSIsImZyb20iLCJsaXN0T2JqZWN0c1YyV2l0aE1ldGFkYXRhR2VuIiwib2JqZWN0TW9kZSIsImVuZGVkIiwiY29udGludWF0aW9uVG9rZW4iLCJyZXN1bHQiLCJsaXN0T2JqZWN0c1YyV2l0aE1ldGFkYXRhUXVlcnkiLCJpc1RydW5jYXRlZCIsIm5leHRDb250aW51YXRpb25Ub2tlbiIsIm9iamVjdHMiLCJxdWVyaWVzIiwicHVzaCIsInVyaUVzY2FwZSIsInNvcnQiLCJxdWVyeSIsImxlbmd0aCIsImpvaW4iLCJtZXRob2QiLCJyZXMiLCJtYWtlUmVxdWVzdEFzeW5jIiwicGFyc2VMaXN0T2JqZWN0c1YyV2l0aE1ldGFkYXRhIiwicmVhZEFzU3RyaW5nIiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbImV4dGVuc2lvbnMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIEhhbnpvIFMzIEphdmFzY3JpcHQgTGlicmFyeSBmb3IgQW1hem9uIFMzIENvbXBhdGlibGUgQ2xvdWQgU3RvcmFnZSwgKEMpIDIwMjAgSGFuem8gQUksIEluYy5cbiAqXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlXCIpO1xuICogeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuICogWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogICAgIGh0dHA6Ly93d3cuYXBhY2hlLm9yZy9saWNlbnNlcy9MSUNFTlNFLTIuMFxuICpcbiAqIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmVcbiAqIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuIFwiQVMgSVNcIiBCQVNJUyxcbiAqIFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICogU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZFxuICogbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG4gKi9cblxuaW1wb3J0ICogYXMgc3RyZWFtIGZyb20gJ25vZGU6c3RyZWFtJ1xuXG5pbXBvcnQgKiBhcyBlcnJvcnMgZnJvbSAnLi4vZXJyb3JzLnRzJ1xuaW1wb3J0IHR5cGUgeyBUeXBlZENsaWVudCB9IGZyb20gJy4vY2xpZW50LnRzJ1xuaW1wb3J0IHsgaXNCb29sZWFuLCBpc1N0cmluZywgaXNWYWxpZEJ1Y2tldE5hbWUsIGlzVmFsaWRQcmVmaXgsIHVyaUVzY2FwZSB9IGZyb20gJy4vaGVscGVyLnRzJ1xuaW1wb3J0IHsgcmVhZEFzU3RyaW5nIH0gZnJvbSAnLi9yZXNwb25zZS50cydcbmltcG9ydCB0eXBlIHsgQnVja2V0SXRlbVdpdGhNZXRhZGF0YSwgQnVja2V0U3RyZWFtIH0gZnJvbSAnLi90eXBlLnRzJ1xuaW1wb3J0IHsgcGFyc2VMaXN0T2JqZWN0c1YyV2l0aE1ldGFkYXRhIH0gZnJvbSAnLi94bWwtcGFyc2VyLnRzJ1xuXG5leHBvcnQgY2xhc3MgRXh0ZW5zaW9ucyB7XG4gIHByaXZhdGUgcmVhZG9ubHkgY2xpZW50OiBUeXBlZENsaWVudFxuXG4gIGNvbnN0cnVjdG9yKGNsaWVudDogVHlwZWRDbGllbnQpIHtcbiAgICB0aGlzLmNsaWVudCA9IGNsaWVudFxuICB9XG5cbiAgLyoqXG4gICAqIExpc3QgdGhlIG9iamVjdHMgaW4gdGhlIGJ1Y2tldCB1c2luZyBTMyBMaXN0T2JqZWN0cyBWMiBXaXRoIE1ldGFkYXRhXG4gICAqXG4gICAqIEBwYXJhbSBidWNrZXROYW1lIC0gbmFtZSBvZiB0aGUgYnVja2V0XG4gICAqIEBwYXJhbSBwcmVmaXggLSB0aGUgcHJlZml4IG9mIHRoZSBvYmplY3RzIHRoYXQgc2hvdWxkIGJlIGxpc3RlZCAob3B0aW9uYWwsIGRlZmF1bHQgYCcnYClcbiAgICogQHBhcmFtIHJlY3Vyc2l2ZSAtIGB0cnVlYCBpbmRpY2F0ZXMgcmVjdXJzaXZlIHN0eWxlIGxpc3RpbmcgYW5kIGBmYWxzZWAgaW5kaWNhdGVzIGRpcmVjdG9yeSBzdHlsZSBsaXN0aW5nIGRlbGltaXRlZCBieSAnLycuIChvcHRpb25hbCwgZGVmYXVsdCBgZmFsc2VgKVxuICAgKiBAcGFyYW0gc3RhcnRBZnRlciAtIFNwZWNpZmllcyB0aGUga2V5IHRvIHN0YXJ0IGFmdGVyIHdoZW4gbGlzdGluZyBvYmplY3RzIGluIGEgYnVja2V0LiAob3B0aW9uYWwsIGRlZmF1bHQgYCcnYClcbiAgICogQHJldHVybnMgc3RyZWFtIGVtaXR0aW5nIHRoZSBvYmplY3RzIGluIHRoZSBidWNrZXQsIHRoZSBvYmplY3QgaXMgb2YgdGhlIGZvcm1hdDpcbiAgICovXG4gIHB1YmxpYyBsaXN0T2JqZWN0c1YyV2l0aE1ldGFkYXRhKFxuICAgIGJ1Y2tldE5hbWU6IHN0cmluZyxcbiAgICBwcmVmaXg/OiBzdHJpbmcsXG4gICAgcmVjdXJzaXZlPzogYm9vbGVhbixcbiAgICBzdGFydEFmdGVyPzogc3RyaW5nLFxuICApOiBCdWNrZXRTdHJlYW08QnVja2V0SXRlbVdpdGhNZXRhZGF0YT4ge1xuICAgIGlmIChwcmVmaXggPT09IHVuZGVmaW5lZCkge1xuICAgICAgcHJlZml4ID0gJydcbiAgICB9XG4gICAgaWYgKHJlY3Vyc2l2ZSA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICByZWN1cnNpdmUgPSBmYWxzZVxuICAgIH1cbiAgICBpZiAoc3RhcnRBZnRlciA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICBzdGFydEFmdGVyID0gJydcbiAgICB9XG4gICAgaWYgKCFpc1ZhbGlkQnVja2V0TmFtZShidWNrZXROYW1lKSkge1xuICAgICAgdGhyb3cgbmV3IGVycm9ycy5JbnZhbGlkQnVja2V0TmFtZUVycm9yKCdJbnZhbGlkIGJ1Y2tldCBuYW1lOiAnICsgYnVja2V0TmFtZSlcbiAgICB9XG4gICAgaWYgKCFpc1ZhbGlkUHJlZml4KHByZWZpeCkpIHtcbiAgICAgIHRocm93IG5ldyBlcnJvcnMuSW52YWxpZFByZWZpeEVycm9yKGBJbnZhbGlkIHByZWZpeCA6ICR7cHJlZml4fWApXG4gICAgfVxuICAgIGlmICghaXNTdHJpbmcocHJlZml4KSkge1xuICAgICAgdGhyb3cgbmV3IFR5cGVFcnJvcigncHJlZml4IHNob3VsZCBiZSBvZiB0eXBlIFwic3RyaW5nXCInKVxuICAgIH1cbiAgICBpZiAoIWlzQm9vbGVhbihyZWN1cnNpdmUpKSB7XG4gICAgICB0aHJvdyBuZXcgVHlwZUVycm9yKCdyZWN1cnNpdmUgc2hvdWxkIGJlIG9mIHR5cGUgXCJib29sZWFuXCInKVxuICAgIH1cbiAgICBpZiAoIWlzU3RyaW5nKHN0YXJ0QWZ0ZXIpKSB7XG4gICAgICB0aHJvdyBuZXcgVHlwZUVycm9yKCdzdGFydEFmdGVyIHNob3VsZCBiZSBvZiB0eXBlIFwic3RyaW5nXCInKVxuICAgIH1cblxuICAgIC8vIGlmIHJlY3Vyc2l2ZSBpcyBmYWxzZSBzZXQgZGVsaW1pdGVyIHRvICcvJ1xuICAgIGNvbnN0IGRlbGltaXRlciA9IHJlY3Vyc2l2ZSA/ICcnIDogJy8nXG4gICAgcmV0dXJuIHN0cmVhbS5SZWFkYWJsZS5mcm9tKHRoaXMubGlzdE9iamVjdHNWMldpdGhNZXRhZGF0YUdlbihidWNrZXROYW1lLCBwcmVmaXgsIGRlbGltaXRlciwgc3RhcnRBZnRlciksIHtcbiAgICAgIG9iamVjdE1vZGU6IHRydWUsXG4gICAgfSlcbiAgfVxuXG4gIHByaXZhdGUgYXN5bmMgKmxpc3RPYmplY3RzVjJXaXRoTWV0YWRhdGFHZW4oXG4gICAgYnVja2V0TmFtZTogc3RyaW5nLFxuICAgIHByZWZpeDogc3RyaW5nLFxuICAgIGRlbGltaXRlcjogc3RyaW5nLFxuICAgIHN0YXJ0QWZ0ZXI6IHN0cmluZyxcbiAgKTogQXN5bmNJdGVyYWJsZTxCdWNrZXRJdGVtV2l0aE1ldGFkYXRhPiB7XG4gICAgbGV0IGVuZGVkID0gZmFsc2VcbiAgICBsZXQgY29udGludWF0aW9uVG9rZW4gPSAnJ1xuICAgIGRvIHtcbiAgICAgIGNvbnN0IHJlc3VsdCA9IGF3YWl0IHRoaXMubGlzdE9iamVjdHNWMldpdGhNZXRhZGF0YVF1ZXJ5KFxuICAgICAgICBidWNrZXROYW1lLFxuICAgICAgICBwcmVmaXgsXG4gICAgICAgIGNvbnRpbnVhdGlvblRva2VuLFxuICAgICAgICBkZWxpbWl0ZXIsXG4gICAgICAgIHN0YXJ0QWZ0ZXIsXG4gICAgICApXG4gICAgICBlbmRlZCA9ICFyZXN1bHQuaXNUcnVuY2F0ZWRcbiAgICAgIGNvbnRpbnVhdGlvblRva2VuID0gcmVzdWx0Lm5leHRDb250aW51YXRpb25Ub2tlblxuICAgICAgZm9yIChjb25zdCBvYmogb2YgcmVzdWx0Lm9iamVjdHMpIHtcbiAgICAgICAgeWllbGQgb2JqXG4gICAgICB9XG4gICAgfSB3aGlsZSAoIWVuZGVkKVxuICB9XG5cbiAgcHJpdmF0ZSBhc3luYyBsaXN0T2JqZWN0c1YyV2l0aE1ldGFkYXRhUXVlcnkoXG4gICAgYnVja2V0TmFtZTogc3RyaW5nLFxuICAgIHByZWZpeDogc3RyaW5nLFxuICAgIGNvbnRpbnVhdGlvblRva2VuOiBzdHJpbmcsXG4gICAgZGVsaW1pdGVyOiBzdHJpbmcsXG4gICAgc3RhcnRBZnRlcjogc3RyaW5nLFxuICApIHtcbiAgICBjb25zdCBxdWVyaWVzID0gW11cblxuICAgIC8vIENhbGwgZm9yIGxpc3Rpbmcgb2JqZWN0cyB2MiBBUElcbiAgICBxdWVyaWVzLnB1c2goYGxpc3QtdHlwZT0yYClcbiAgICBxdWVyaWVzLnB1c2goYGVuY29kaW5nLXR5cGU9dXJsYClcbiAgICAvLyBlc2NhcGUgZXZlcnkgdmFsdWUgaW4gcXVlcnkgc3RyaW5nLCBleGNlcHQgbWF4S2V5c1xuICAgIHF1ZXJpZXMucHVzaChgcHJlZml4PSR7dXJpRXNjYXBlKHByZWZpeCl9YClcbiAgICBxdWVyaWVzLnB1c2goYGRlbGltaXRlcj0ke3VyaUVzY2FwZShkZWxpbWl0ZXIpfWApXG4gICAgcXVlcmllcy5wdXNoKGBtZXRhZGF0YT10cnVlYClcblxuICAgIGlmIChjb250aW51YXRpb25Ub2tlbikge1xuICAgICAgY29udGludWF0aW9uVG9rZW4gPSB1cmlFc2NhcGUoY29udGludWF0aW9uVG9rZW4pXG4gICAgICBxdWVyaWVzLnB1c2goYGNvbnRpbnVhdGlvbi10b2tlbj0ke2NvbnRpbnVhdGlvblRva2VufWApXG4gICAgfVxuICAgIC8vIFNldCBzdGFydC1hZnRlclxuICAgIGlmIChzdGFydEFmdGVyKSB7XG4gICAgICBzdGFydEFmdGVyID0gdXJpRXNjYXBlKHN0YXJ0QWZ0ZXIpXG4gICAgICBxdWVyaWVzLnB1c2goYHN0YXJ0LWFmdGVyPSR7c3RhcnRBZnRlcn1gKVxuICAgIH1cbiAgICBxdWVyaWVzLnB1c2goYG1heC1rZXlzPTEwMDBgKVxuICAgIHF1ZXJpZXMuc29ydCgpXG4gICAgbGV0IHF1ZXJ5ID0gJydcbiAgICBpZiAocXVlcmllcy5sZW5ndGggPiAwKSB7XG4gICAgICBxdWVyeSA9IGAke3F1ZXJpZXMuam9pbignJicpfWBcbiAgICB9XG4gICAgY29uc3QgbWV0aG9kID0gJ0dFVCdcbiAgICBjb25zdCByZXMgPSBhd2FpdCB0aGlzLmNsaWVudC5tYWtlUmVxdWVzdEFzeW5jKHsgbWV0aG9kLCBidWNrZXROYW1lLCBxdWVyeSB9KVxuICAgIHJldHVybiBwYXJzZUxpc3RPYmplY3RzVjJXaXRoTWV0YWRhdGEoYXdhaXQgcmVhZEFzU3RyaW5nKHJlcykpXG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFnQkEsSUFBQUEsTUFBQSxHQUFBQyx1QkFBQSxDQUFBQyxPQUFBO0FBRUEsSUFBQUMsTUFBQSxHQUFBRix1QkFBQSxDQUFBQyxPQUFBO0FBRUEsSUFBQUUsT0FBQSxHQUFBRixPQUFBO0FBQ0EsSUFBQUcsU0FBQSxHQUFBSCxPQUFBO0FBRUEsSUFBQUksVUFBQSxHQUFBSixPQUFBO0FBQWdFLFNBQUFLLHlCQUFBQyxXQUFBLGVBQUFDLE9BQUEsa0NBQUFDLGlCQUFBLE9BQUFELE9BQUEsUUFBQUUsZ0JBQUEsT0FBQUYsT0FBQSxZQUFBRix3QkFBQSxZQUFBQSxDQUFBQyxXQUFBLFdBQUFBLFdBQUEsR0FBQUcsZ0JBQUEsR0FBQUQsaUJBQUEsS0FBQUYsV0FBQTtBQUFBLFNBQUFQLHdCQUFBVyxHQUFBLEVBQUFKLFdBQUEsU0FBQUEsV0FBQSxJQUFBSSxHQUFBLElBQUFBLEdBQUEsQ0FBQUMsVUFBQSxXQUFBRCxHQUFBLFFBQUFBLEdBQUEsb0JBQUFBLEdBQUEsd0JBQUFBLEdBQUEsNEJB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
|
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
/// <reference types="node" />
|
|
3
|
+
import * as stream from 'node:stream';
|
|
4
|
+
import _ from 'lodash';
|
|
5
|
+
import type { Binary, Encryption, ObjectMetaData, RequestHeaders, ResponseHeader } from "./type.js";
|
|
6
|
+
export declare function hashBinary(buf: Buffer, enableSHA256: boolean): {
|
|
7
|
+
md5sum: string;
|
|
8
|
+
sha256sum: string;
|
|
9
|
+
};
|
|
10
|
+
export declare function uriEscape(uriStr: string): string;
|
|
11
|
+
export declare function uriResourceEscape(string: string): string;
|
|
12
|
+
export declare function getScope(region: string, date: Date, serviceName?: string): string;
|
|
13
|
+
/**
|
|
14
|
+
* isAmazonEndpoint - true if endpoint is 's3.amazonaws.com' or 's3.cn-north-1.amazonaws.com.cn'
|
|
15
|
+
*/
|
|
16
|
+
export declare function isAmazonEndpoint(endpoint: string): boolean;
|
|
17
|
+
/**
|
|
18
|
+
* isVirtualHostStyle - verify if bucket name is support with virtual
|
|
19
|
+
* hosts. bucketNames with periods should be always treated as path
|
|
20
|
+
* style if the protocol is 'https:', this is due to SSL wildcard
|
|
21
|
+
* limitation. For all other buckets and Amazon S3 endpoint we will
|
|
22
|
+
* default to virtual host style.
|
|
23
|
+
*/
|
|
24
|
+
export declare function isVirtualHostStyle(endpoint: string, protocol: string, bucket: string, pathStyle: boolean): boolean;
|
|
25
|
+
export declare function isValidIP(ip: string): boolean;
|
|
26
|
+
/**
|
|
27
|
+
* @returns if endpoint is valid domain.
|
|
28
|
+
*/
|
|
29
|
+
export declare function isValidEndpoint(endpoint: string): boolean;
|
|
30
|
+
/**
|
|
31
|
+
* @returns if input host is a valid domain.
|
|
32
|
+
*/
|
|
33
|
+
export declare function isValidDomain(host: string): boolean;
|
|
34
|
+
/**
|
|
35
|
+
* Probes contentType using file extensions.
|
|
36
|
+
*
|
|
37
|
+
* @example
|
|
38
|
+
* ```
|
|
39
|
+
* // return 'image/png'
|
|
40
|
+
* probeContentType('file.png')
|
|
41
|
+
* ```
|
|
42
|
+
*/
|
|
43
|
+
export declare function probeContentType(path: string): string;
|
|
44
|
+
/**
|
|
45
|
+
* is input port valid.
|
|
46
|
+
*/
|
|
47
|
+
export declare function isValidPort(port: unknown): port is number;
|
|
48
|
+
export declare function isValidBucketName(bucket: unknown): boolean;
|
|
49
|
+
/**
|
|
50
|
+
* check if objectName is a valid object name
|
|
51
|
+
*/
|
|
52
|
+
export declare function isValidObjectName(objectName: unknown): boolean;
|
|
53
|
+
/**
|
|
54
|
+
* check if prefix is valid
|
|
55
|
+
*/
|
|
56
|
+
export declare function isValidPrefix(prefix: unknown): prefix is string;
|
|
57
|
+
/**
|
|
58
|
+
* check if typeof arg number
|
|
59
|
+
*/
|
|
60
|
+
export declare function isNumber(arg: unknown): arg is number;
|
|
61
|
+
export type AnyFunction = (...args: any[]) => any;
|
|
62
|
+
/**
|
|
63
|
+
* check if typeof arg function
|
|
64
|
+
*/
|
|
65
|
+
export declare function isFunction(arg: unknown): arg is AnyFunction;
|
|
66
|
+
/**
|
|
67
|
+
* check if typeof arg string
|
|
68
|
+
*/
|
|
69
|
+
export declare function isString(arg: unknown): arg is string;
|
|
70
|
+
/**
|
|
71
|
+
* check if typeof arg object
|
|
72
|
+
*/
|
|
73
|
+
export declare function isObject(arg: unknown): arg is object;
|
|
74
|
+
/**
|
|
75
|
+
* check if typeof arg is plain object
|
|
76
|
+
*/
|
|
77
|
+
export declare function isPlainObject(arg: unknown): arg is Record<string, unknown>;
|
|
78
|
+
/**
|
|
79
|
+
* check if object is readable stream
|
|
80
|
+
*/
|
|
81
|
+
export declare function isReadableStream(arg: unknown): arg is stream.Readable;
|
|
82
|
+
/**
|
|
83
|
+
* check if arg is boolean
|
|
84
|
+
*/
|
|
85
|
+
export declare function isBoolean(arg: unknown): arg is boolean;
|
|
86
|
+
export declare function isEmpty(o: unknown): o is null | undefined;
|
|
87
|
+
export declare function isEmptyObject(o: Record<string, unknown>): boolean;
|
|
88
|
+
export declare function isDefined<T>(o: T): o is Exclude<T, null | undefined>;
|
|
89
|
+
/**
|
|
90
|
+
* check if arg is a valid date
|
|
91
|
+
*/
|
|
92
|
+
export declare function isValidDate(arg: unknown): arg is Date;
|
|
93
|
+
/**
|
|
94
|
+
* Create a Date string with format: 'YYYYMMDDTHHmmss' + Z
|
|
95
|
+
*/
|
|
96
|
+
export declare function makeDateLong(date?: Date): string;
|
|
97
|
+
/**
|
|
98
|
+
* Create a Date string with format: 'YYYYMMDD'
|
|
99
|
+
*/
|
|
100
|
+
export declare function makeDateShort(date?: Date): string;
|
|
101
|
+
/**
|
|
102
|
+
* pipesetup sets up pipe() from left to right os streams array
|
|
103
|
+
* pipesetup will also make sure that error emitted at any of the upstream Stream
|
|
104
|
+
* will be emitted at the last stream. This makes error handling simple
|
|
105
|
+
*/
|
|
106
|
+
export declare function pipesetup(...streams: [stream.Readable, ...stream.Duplex[], stream.Writable]): stream.Readable | stream.Duplex | stream.Writable;
|
|
107
|
+
/**
|
|
108
|
+
* return a Readable stream that emits data
|
|
109
|
+
*/
|
|
110
|
+
export declare function readableStream(data: unknown): stream.Readable;
|
|
111
|
+
/**
|
|
112
|
+
* Process metadata to insert appropriate value to `content-type` attribute
|
|
113
|
+
*/
|
|
114
|
+
export declare function insertContentType(metaData: ObjectMetaData, filePath: string): ObjectMetaData;
|
|
115
|
+
/**
|
|
116
|
+
* Function prepends metadata with the appropriate prefix if it is not already on
|
|
117
|
+
*/
|
|
118
|
+
export declare function prependXAMZMeta(metaData?: ObjectMetaData): RequestHeaders;
|
|
119
|
+
/**
|
|
120
|
+
* Checks if it is a valid header according to the AmazonS3 API
|
|
121
|
+
*/
|
|
122
|
+
export declare function isAmzHeader(key: string): boolean;
|
|
123
|
+
/**
|
|
124
|
+
* Checks if it is a supported Header
|
|
125
|
+
*/
|
|
126
|
+
export declare function isSupportedHeader(key: string): boolean;
|
|
127
|
+
/**
|
|
128
|
+
* Checks if it is a storage header
|
|
129
|
+
*/
|
|
130
|
+
export declare function isStorageClassHeader(key: string): boolean;
|
|
131
|
+
export declare function extractMetadata(headers: ResponseHeader): _.Dictionary<string>;
|
|
132
|
+
export declare function getVersionId(headers?: ResponseHeader): string | null;
|
|
133
|
+
export declare function getSourceVersionId(headers?: ResponseHeader): string | null;
|
|
134
|
+
export declare function sanitizeETag(etag?: string): string;
|
|
135
|
+
export declare function toMd5(payload: Binary): string;
|
|
136
|
+
export declare function toSha256(payload: Binary): string;
|
|
137
|
+
/**
|
|
138
|
+
* toArray returns a single element array with param being the element,
|
|
139
|
+
* if param is just a string, and returns 'param' back if it is an array
|
|
140
|
+
* So, it makes sure param is always an array
|
|
141
|
+
*/
|
|
142
|
+
export declare function toArray<T = unknown>(param: T | T[]): Array<T>;
|
|
143
|
+
export declare function sanitizeObjectKey(objectName: string): string;
|
|
144
|
+
export declare function sanitizeSize(size?: string): number | undefined;
|
|
145
|
+
export declare const PART_CONSTRAINTS: {
|
|
146
|
+
ABS_MIN_PART_SIZE: number;
|
|
147
|
+
MIN_PART_SIZE: number;
|
|
148
|
+
MAX_PARTS_COUNT: number;
|
|
149
|
+
MAX_PART_SIZE: number;
|
|
150
|
+
MAX_SINGLE_PUT_OBJECT_SIZE: number;
|
|
151
|
+
MAX_MULTIPART_PUT_OBJECT_SIZE: number;
|
|
152
|
+
};
|
|
153
|
+
/**
|
|
154
|
+
* Return Encryption headers
|
|
155
|
+
* @param encConfig
|
|
156
|
+
* @returns an object with key value pairs that can be used in headers.
|
|
157
|
+
*/
|
|
158
|
+
export declare function getEncryptionHeaders(encConfig: Encryption): RequestHeaders;
|
|
159
|
+
export declare function partsRequired(size: number): number;
|
|
160
|
+
/**
|
|
161
|
+
* calculateEvenSplits - computes splits for a source and returns
|
|
162
|
+
* start and end index slices. Splits happen evenly to be sure that no
|
|
163
|
+
* part is less than 5MiB, as that could fail the multipart request if
|
|
164
|
+
* it is not the last part.
|
|
165
|
+
*/
|
|
166
|
+
export declare function calculateEvenSplits<T extends {
|
|
167
|
+
Start?: number;
|
|
168
|
+
}>(size: number, objInfo: T): {
|
|
169
|
+
startIndex: number[];
|
|
170
|
+
objInfo: T;
|
|
171
|
+
endIndex: number[];
|
|
172
|
+
} | null;
|
|
173
|
+
export declare function parseXml(xml: string): any;
|
|
174
|
+
/**
|
|
175
|
+
* get content size of object content to upload
|
|
176
|
+
*/
|
|
177
|
+
export declare function getContentLength(s: stream.Readable | Buffer | string): Promise<number | null>;
|