@hanzo/s3 0.6.4 → 8.0.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (119) hide show
  1. package/LICENSE +202 -0
  2. package/MAINTAINERS.md +62 -0
  3. package/README.md +262 -0
  4. package/README_zh_CN.md +192 -0
  5. package/dist/esm/AssumeRoleProvider.d.mts +86 -0
  6. package/dist/esm/AssumeRoleProvider.mjs +183 -0
  7. package/dist/esm/CredentialProvider.d.mts +22 -0
  8. package/dist/esm/CredentialProvider.mjs +48 -0
  9. package/dist/esm/Credentials.d.mts +22 -0
  10. package/dist/esm/Credentials.mjs +38 -0
  11. package/dist/esm/IamAwsProvider.d.mts +27 -0
  12. package/dist/esm/IamAwsProvider.mjs +189 -0
  13. package/dist/esm/errors.d.mts +82 -0
  14. package/dist/esm/errors.mjs +117 -0
  15. package/dist/esm/helpers.d.mts +156 -0
  16. package/dist/esm/helpers.mjs +218 -0
  17. package/dist/esm/internal/async.d.mts +9 -0
  18. package/dist/esm/internal/async.mjs +14 -0
  19. package/dist/esm/internal/callbackify.d.mts +1 -0
  20. package/dist/esm/internal/callbackify.mjs +15 -0
  21. package/dist/esm/internal/client.d.mts +394 -0
  22. package/dist/esm/internal/client.mjs +3007 -0
  23. package/dist/esm/internal/copy-conditions.d.mts +10 -0
  24. package/dist/esm/internal/copy-conditions.mjs +25 -0
  25. package/dist/esm/internal/extensions.d.mts +18 -0
  26. package/dist/esm/internal/extensions.mjs +114 -0
  27. package/dist/esm/internal/helper.d.mts +177 -0
  28. package/dist/esm/internal/helper.mjs +552 -0
  29. package/dist/esm/internal/join-host-port.d.mts +11 -0
  30. package/dist/esm/internal/join-host-port.mjs +23 -0
  31. package/dist/esm/internal/post-policy.d.mts +17 -0
  32. package/dist/esm/internal/post-policy.mjs +98 -0
  33. package/dist/esm/internal/request.d.mts +11 -0
  34. package/dist/esm/internal/request.mjs +75 -0
  35. package/dist/esm/internal/response.d.mts +8 -0
  36. package/dist/esm/internal/response.mjs +16 -0
  37. package/dist/esm/internal/s3-endpoints.d.mts +38 -0
  38. package/dist/esm/internal/s3-endpoints.mjs +68 -0
  39. package/dist/esm/internal/type.d.mts +482 -0
  40. package/dist/esm/internal/type.mjs +30 -0
  41. package/dist/esm/internal/xml-parser.d.mts +93 -0
  42. package/dist/esm/internal/xml-parser.mjs +819 -0
  43. package/dist/esm/notification.d.mts +58 -0
  44. package/dist/esm/notification.mjs +209 -0
  45. package/dist/esm/s3.d.mts +40 -0
  46. package/dist/esm/s3.mjs +86 -0
  47. package/dist/esm/signing.d.mts +5 -0
  48. package/dist/esm/signing.mjs +258 -0
  49. package/dist/main/AssumeRoleProvider.d.ts +86 -0
  50. package/dist/main/AssumeRoleProvider.js +191 -0
  51. package/dist/main/CredentialProvider.d.ts +22 -0
  52. package/dist/main/CredentialProvider.js +55 -0
  53. package/dist/main/Credentials.d.ts +22 -0
  54. package/dist/main/Credentials.js +45 -0
  55. package/dist/main/IamAwsProvider.d.ts +27 -0
  56. package/dist/main/IamAwsProvider.js +198 -0
  57. package/dist/main/errors.d.ts +82 -0
  58. package/dist/main/errors.js +138 -0
  59. package/dist/main/helpers.d.ts +156 -0
  60. package/dist/main/helpers.js +233 -0
  61. package/dist/main/internal/async.d.ts +9 -0
  62. package/dist/main/internal/async.js +24 -0
  63. package/dist/main/internal/callbackify.d.ts +1 -0
  64. package/dist/main/internal/callbackify.js +21 -0
  65. package/dist/main/internal/client.d.ts +394 -0
  66. package/dist/main/internal/client.js +3014 -0
  67. package/dist/main/internal/copy-conditions.d.ts +10 -0
  68. package/dist/main/internal/copy-conditions.js +31 -0
  69. package/dist/main/internal/extensions.d.ts +18 -0
  70. package/dist/main/internal/extensions.js +122 -0
  71. package/dist/main/internal/helper.d.ts +177 -0
  72. package/dist/main/internal/helper.js +608 -0
  73. package/dist/main/internal/join-host-port.d.ts +11 -0
  74. package/dist/main/internal/join-host-port.js +29 -0
  75. package/dist/main/internal/post-policy.d.ts +17 -0
  76. package/dist/main/internal/post-policy.js +107 -0
  77. package/dist/main/internal/request.d.ts +11 -0
  78. package/dist/main/internal/request.js +83 -0
  79. package/dist/main/internal/response.d.ts +8 -0
  80. package/dist/main/internal/response.js +24 -0
  81. package/dist/main/internal/s3-endpoints.d.ts +38 -0
  82. package/dist/main/internal/s3-endpoints.js +73 -0
  83. package/dist/main/internal/type.d.ts +482 -0
  84. package/dist/main/internal/type.js +42 -0
  85. package/dist/main/internal/xml-parser.d.ts +93 -0
  86. package/dist/main/internal/xml-parser.js +849 -0
  87. package/dist/main/notification.d.ts +58 -0
  88. package/dist/main/notification.js +230 -0
  89. package/dist/main/s3.d.ts +40 -0
  90. package/dist/main/s3.js +117 -0
  91. package/dist/main/signing.d.ts +5 -0
  92. package/dist/main/signing.js +269 -0
  93. package/package.json +146 -39
  94. package/src/AssumeRoleProvider.ts +262 -0
  95. package/src/CredentialProvider.ts +54 -0
  96. package/src/Credentials.ts +44 -0
  97. package/src/IamAwsProvider.ts +234 -0
  98. package/src/errors.ts +120 -0
  99. package/src/helpers.ts +354 -0
  100. package/src/internal/async.ts +14 -0
  101. package/src/internal/callbackify.ts +19 -0
  102. package/src/internal/client.ts +3412 -0
  103. package/src/internal/copy-conditions.ts +30 -0
  104. package/src/internal/extensions.ts +140 -0
  105. package/src/internal/helper.ts +606 -0
  106. package/src/internal/join-host-port.ts +23 -0
  107. package/src/internal/post-policy.ts +99 -0
  108. package/src/internal/request.ts +102 -0
  109. package/src/internal/response.ts +26 -0
  110. package/src/internal/s3-endpoints.ts +70 -0
  111. package/src/internal/type.ts +577 -0
  112. package/src/internal/xml-parser.ts +871 -0
  113. package/src/notification.ts +254 -0
  114. package/src/s3.ts +155 -0
  115. package/src/signing.ts +325 -0
  116. package/lib/index.js +0 -450
  117. package/lib/index.js.map +0 -7
  118. package/lib/perfTest.js +0 -91
  119. package/lib/perfTest.js.map +0 -7
@@ -0,0 +1,218 @@
1
+ import * as fs from "fs";
2
+ import * as path from "path";
3
+ import * as querystring from 'query-string';
4
+ import * as errors from "./errors.mjs";
5
+ import { getEncryptionHeaders, isEmpty, isEmptyObject, isNumber, isObject, isString, isValidBucketName, isValidObjectName } from "./internal/helper.mjs";
6
+ import { RETENTION_MODES } from "./internal/type.mjs";
7
+ export { ENCRYPTION_TYPES, LEGAL_HOLD_STATUS, RETENTION_MODES, RETENTION_VALIDITY_UNITS } from "./internal/type.mjs";
8
+ export const DEFAULT_REGION = 'us-east-1';
9
+ export const PRESIGN_EXPIRY_DAYS_MAX = 24 * 60 * 60 * 7; // 7 days in seconds
10
+
11
+ export class CopySourceOptions {
12
+ constructor({
13
+ Bucket,
14
+ Object,
15
+ VersionID = '',
16
+ MatchETag = '',
17
+ NoMatchETag = '',
18
+ MatchModifiedSince = null,
19
+ MatchUnmodifiedSince = null,
20
+ MatchRange = false,
21
+ Start = 0,
22
+ End = 0,
23
+ Encryption = undefined
24
+ }) {
25
+ this.Bucket = Bucket;
26
+ this.Object = Object;
27
+ this.VersionID = VersionID;
28
+ this.MatchETag = MatchETag;
29
+ this.NoMatchETag = NoMatchETag;
30
+ this.MatchModifiedSince = MatchModifiedSince;
31
+ this.MatchUnmodifiedSince = MatchUnmodifiedSince;
32
+ this.MatchRange = MatchRange;
33
+ this.Start = Start;
34
+ this.End = End;
35
+ this.Encryption = Encryption;
36
+ }
37
+ validate() {
38
+ if (!isValidBucketName(this.Bucket)) {
39
+ throw new errors.InvalidBucketNameError('Invalid Source bucket name: ' + this.Bucket);
40
+ }
41
+ if (!isValidObjectName(this.Object)) {
42
+ throw new errors.InvalidObjectNameError(`Invalid Source object name: ${this.Object}`);
43
+ }
44
+ if (this.MatchRange && this.Start !== -1 && this.End !== -1 && this.Start > this.End || this.Start < 0) {
45
+ throw new errors.InvalidObjectNameError('Source start must be non-negative, and start must be at most end.');
46
+ } else if (this.MatchRange && !isNumber(this.Start) || !isNumber(this.End)) {
47
+ throw new errors.InvalidObjectNameError('MatchRange is specified. But Invalid Start and End values are specified.');
48
+ }
49
+ return true;
50
+ }
51
+ getHeaders() {
52
+ const headerOptions = {};
53
+ headerOptions['x-amz-copy-source'] = encodeURI(this.Bucket + '/' + this.Object);
54
+ if (!isEmpty(this.VersionID)) {
55
+ headerOptions['x-amz-copy-source'] = `${encodeURI(this.Bucket + '/' + this.Object)}?versionId=${this.VersionID}`;
56
+ }
57
+ if (!isEmpty(this.MatchETag)) {
58
+ headerOptions['x-amz-copy-source-if-match'] = this.MatchETag;
59
+ }
60
+ if (!isEmpty(this.NoMatchETag)) {
61
+ headerOptions['x-amz-copy-source-if-none-match'] = this.NoMatchETag;
62
+ }
63
+ if (!isEmpty(this.MatchModifiedSince)) {
64
+ headerOptions['x-amz-copy-source-if-modified-since'] = this.MatchModifiedSince;
65
+ }
66
+ if (!isEmpty(this.MatchUnmodifiedSince)) {
67
+ headerOptions['x-amz-copy-source-if-unmodified-since'] = this.MatchUnmodifiedSince;
68
+ }
69
+ return headerOptions;
70
+ }
71
+ }
72
+
73
+ /**
74
+ * @deprecated use nodejs fs module
75
+ */
76
+ export function removeDirAndFiles(dirPath, removeSelf = true) {
77
+ if (removeSelf) {
78
+ return fs.rmSync(dirPath, {
79
+ recursive: true,
80
+ force: true
81
+ });
82
+ }
83
+ fs.readdirSync(dirPath).forEach(item => {
84
+ fs.rmSync(path.join(dirPath, item), {
85
+ recursive: true,
86
+ force: true
87
+ });
88
+ });
89
+ }
90
+ export class CopyDestinationOptions {
91
+ constructor({
92
+ Bucket,
93
+ Object,
94
+ Encryption,
95
+ UserMetadata,
96
+ UserTags,
97
+ LegalHold,
98
+ RetainUntilDate,
99
+ Mode,
100
+ MetadataDirective,
101
+ Headers
102
+ }) {
103
+ this.Bucket = Bucket;
104
+ this.Object = Object;
105
+ this.Encryption = Encryption ?? undefined; // null input will become undefined, easy for runtime assert
106
+ this.UserMetadata = UserMetadata;
107
+ this.UserTags = UserTags;
108
+ this.LegalHold = LegalHold;
109
+ this.Mode = Mode; // retention mode
110
+ this.RetainUntilDate = RetainUntilDate;
111
+ this.MetadataDirective = MetadataDirective;
112
+ this.Headers = Headers;
113
+ }
114
+ getHeaders() {
115
+ const replaceDirective = 'REPLACE';
116
+ const headerOptions = {};
117
+ const userTags = this.UserTags;
118
+ if (!isEmpty(userTags)) {
119
+ headerOptions['X-Amz-Tagging-Directive'] = replaceDirective;
120
+ headerOptions['X-Amz-Tagging'] = isObject(userTags) ? querystring.stringify(userTags) : isString(userTags) ? userTags : '';
121
+ }
122
+ if (this.Mode) {
123
+ headerOptions['X-Amz-Object-Lock-Mode'] = this.Mode; // GOVERNANCE or COMPLIANCE
124
+ }
125
+
126
+ if (this.RetainUntilDate) {
127
+ headerOptions['X-Amz-Object-Lock-Retain-Until-Date'] = this.RetainUntilDate; // needs to be UTC.
128
+ }
129
+
130
+ if (this.LegalHold) {
131
+ headerOptions['X-Amz-Object-Lock-Legal-Hold'] = this.LegalHold; // ON or OFF
132
+ }
133
+
134
+ if (this.UserMetadata) {
135
+ for (const [key, value] of Object.entries(this.UserMetadata)) {
136
+ headerOptions[`X-Amz-Meta-${key}`] = value.toString();
137
+ }
138
+ }
139
+ if (this.MetadataDirective) {
140
+ headerOptions[`X-Amz-Metadata-Directive`] = this.MetadataDirective;
141
+ }
142
+ if (this.Encryption) {
143
+ const encryptionHeaders = getEncryptionHeaders(this.Encryption);
144
+ for (const [key, value] of Object.entries(encryptionHeaders)) {
145
+ headerOptions[key] = value;
146
+ }
147
+ }
148
+ if (this.Headers) {
149
+ for (const [key, value] of Object.entries(this.Headers)) {
150
+ headerOptions[key] = value;
151
+ }
152
+ }
153
+ return headerOptions;
154
+ }
155
+ validate() {
156
+ if (!isValidBucketName(this.Bucket)) {
157
+ throw new errors.InvalidBucketNameError('Invalid Destination bucket name: ' + this.Bucket);
158
+ }
159
+ if (!isValidObjectName(this.Object)) {
160
+ throw new errors.InvalidObjectNameError(`Invalid Destination object name: ${this.Object}`);
161
+ }
162
+ if (!isEmpty(this.UserMetadata) && !isObject(this.UserMetadata)) {
163
+ throw new errors.InvalidObjectNameError(`Destination UserMetadata should be an object with key value pairs`);
164
+ }
165
+ if (!isEmpty(this.Mode) && ![RETENTION_MODES.GOVERNANCE, RETENTION_MODES.COMPLIANCE].includes(this.Mode)) {
166
+ throw new errors.InvalidObjectNameError(`Invalid Mode specified for destination object it should be one of [GOVERNANCE,COMPLIANCE]`);
167
+ }
168
+ if (this.Encryption !== undefined && isEmptyObject(this.Encryption)) {
169
+ throw new errors.InvalidObjectNameError(`Invalid Encryption configuration for destination object `);
170
+ }
171
+ return true;
172
+ }
173
+ }
174
+
175
+ /**
176
+ * maybe this should be a generic type for Records, leave it for later refactor
177
+ */
178
+ export class SelectResults {
179
+ constructor({
180
+ records,
181
+ // parsed data as stream
182
+ response,
183
+ // original response stream
184
+ stats,
185
+ // stats as xml
186
+ progress // stats as xml
187
+ }) {
188
+ this.records = records;
189
+ this.response = response;
190
+ this.stats = stats;
191
+ this.progress = progress;
192
+ }
193
+ setStats(stats) {
194
+ this.stats = stats;
195
+ }
196
+ getStats() {
197
+ return this.stats;
198
+ }
199
+ setProgress(progress) {
200
+ this.progress = progress;
201
+ }
202
+ getProgress() {
203
+ return this.progress;
204
+ }
205
+ setResponse(response) {
206
+ this.response = response;
207
+ }
208
+ getResponse() {
209
+ return this.response;
210
+ }
211
+ setRecords(records) {
212
+ this.records = records;
213
+ }
214
+ getRecords() {
215
+ return this.records;
216
+ }
217
+ }
218
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["fs","path","querystring","errors","getEncryptionHeaders","isEmpty","isEmptyObject","isNumber","isObject","isString","isValidBucketName","isValidObjectName","RETENTION_MODES","ENCRYPTION_TYPES","LEGAL_HOLD_STATUS","RETENTION_VALIDITY_UNITS","DEFAULT_REGION","PRESIGN_EXPIRY_DAYS_MAX","CopySourceOptions","constructor","Bucket","Object","VersionID","MatchETag","NoMatchETag","MatchModifiedSince","MatchUnmodifiedSince","MatchRange","Start","End","Encryption","undefined","validate","InvalidBucketNameError","InvalidObjectNameError","getHeaders","headerOptions","encodeURI","removeDirAndFiles","dirPath","removeSelf","rmSync","recursive","force","readdirSync","forEach","item","join","CopyDestinationOptions","UserMetadata","UserTags","LegalHold","RetainUntilDate","Mode","MetadataDirective","Headers","replaceDirective","userTags","stringify","key","value","entries","toString","encryptionHeaders","GOVERNANCE","COMPLIANCE","includes","SelectResults","records","response","stats","progress","setStats","getStats","setProgress","getProgress","setResponse","getResponse","setRecords","getRecords"],"sources":["helpers.ts"],"sourcesContent":["import * as fs from 'node:fs'\nimport * as path from 'node:path'\n\nimport * as querystring from 'query-string'\n\nimport * as errors from './errors.ts'\nimport {\n  getEncryptionHeaders,\n  isEmpty,\n  isEmptyObject,\n  isNumber,\n  isObject,\n  isString,\n  isValidBucketName,\n  isValidObjectName,\n} from './internal/helper.ts'\nimport type { Encryption, ObjectMetaData, RequestHeaders } from './internal/type.ts'\nimport { RETENTION_MODES } from './internal/type.ts'\n\nexport { ENCRYPTION_TYPES, LEGAL_HOLD_STATUS, RETENTION_MODES, RETENTION_VALIDITY_UNITS } from './internal/type.ts'\n\nexport const DEFAULT_REGION = 'us-east-1'\n\nexport const PRESIGN_EXPIRY_DAYS_MAX = 24 * 60 * 60 * 7 // 7 days in seconds\n\nexport interface ICopySourceOptions {\n  Bucket: string\n  Object: string\n  /**\n   * Valid versionId\n   */\n  VersionID?: string\n  /**\n   * Etag to match\n   */\n  MatchETag?: string\n  /**\n   * Etag to exclude\n   */\n  NoMatchETag?: string\n  /**\n   * Modified Date of the object/part.  UTC Date in string format\n   */\n  MatchModifiedSince?: string | null\n  /**\n   * Modified Date of the object/part to exclude UTC Date in string format\n   */\n  MatchUnmodifiedSince?: string | null\n  /**\n   * true or false Object range to match\n   */\n  MatchRange?: boolean\n  Start?: number\n  End?: number\n  Encryption?: Encryption\n}\n\nexport class CopySourceOptions {\n  public readonly Bucket: string\n  public readonly Object: string\n  public readonly VersionID: string\n  public MatchETag: string\n  private readonly NoMatchETag: string\n  private readonly MatchModifiedSince: string | null\n  private readonly MatchUnmodifiedSince: string | null\n  public readonly MatchRange: boolean\n  public readonly Start: number\n  public readonly End: number\n  private readonly Encryption?: Encryption\n\n  constructor({\n    Bucket,\n    Object,\n    VersionID = '',\n    MatchETag = '',\n    NoMatchETag = '',\n    MatchModifiedSince = null,\n    MatchUnmodifiedSince = null,\n    MatchRange = false,\n    Start = 0,\n    End = 0,\n    Encryption = undefined,\n  }: ICopySourceOptions) {\n    this.Bucket = Bucket\n    this.Object = Object\n    this.VersionID = VersionID\n    this.MatchETag = MatchETag\n    this.NoMatchETag = NoMatchETag\n    this.MatchModifiedSince = MatchModifiedSince\n    this.MatchUnmodifiedSince = MatchUnmodifiedSince\n    this.MatchRange = MatchRange\n    this.Start = Start\n    this.End = End\n    this.Encryption = Encryption\n  }\n\n  validate() {\n    if (!isValidBucketName(this.Bucket)) {\n      throw new errors.InvalidBucketNameError('Invalid Source bucket name: ' + this.Bucket)\n    }\n    if (!isValidObjectName(this.Object)) {\n      throw new errors.InvalidObjectNameError(`Invalid Source object name: ${this.Object}`)\n    }\n    if ((this.MatchRange && this.Start !== -1 && this.End !== -1 && this.Start > this.End) || this.Start < 0) {\n      throw new errors.InvalidObjectNameError('Source start must be non-negative, and start must be at most end.')\n    } else if ((this.MatchRange && !isNumber(this.Start)) || !isNumber(this.End)) {\n      throw new errors.InvalidObjectNameError(\n        'MatchRange is specified. But Invalid Start and End values are specified.',\n      )\n    }\n\n    return true\n  }\n\n  getHeaders(): RequestHeaders {\n    const headerOptions: RequestHeaders = {}\n    headerOptions['x-amz-copy-source'] = encodeURI(this.Bucket + '/' + this.Object)\n\n    if (!isEmpty(this.VersionID)) {\n      headerOptions['x-amz-copy-source'] = `${encodeURI(this.Bucket + '/' + this.Object)}?versionId=${this.VersionID}`\n    }\n\n    if (!isEmpty(this.MatchETag)) {\n      headerOptions['x-amz-copy-source-if-match'] = this.MatchETag\n    }\n    if (!isEmpty(this.NoMatchETag)) {\n      headerOptions['x-amz-copy-source-if-none-match'] = this.NoMatchETag\n    }\n\n    if (!isEmpty(this.MatchModifiedSince)) {\n      headerOptions['x-amz-copy-source-if-modified-since'] = this.MatchModifiedSince\n    }\n    if (!isEmpty(this.MatchUnmodifiedSince)) {\n      headerOptions['x-amz-copy-source-if-unmodified-since'] = this.MatchUnmodifiedSince\n    }\n\n    return headerOptions\n  }\n}\n\n/**\n * @deprecated use nodejs fs module\n */\nexport function removeDirAndFiles(dirPath: string, removeSelf = true) {\n  if (removeSelf) {\n    return fs.rmSync(dirPath, { recursive: true, force: true })\n  }\n\n  fs.readdirSync(dirPath).forEach((item) => {\n    fs.rmSync(path.join(dirPath, item), { recursive: true, force: true })\n  })\n}\n\nexport interface ICopyDestinationOptions {\n  /**\n   * Bucket name\n   */\n  Bucket: string\n  /**\n   * Object Name for the destination (composed/copied) object defaults\n   */\n  Object: string\n  /**\n   * Encryption configuration defaults to {}\n   * @default {}\n   */\n  Encryption?: Encryption\n  UserMetadata?: ObjectMetaData\n  /**\n   * query-string encoded string or Record<string, string> Object\n   */\n  UserTags?: Record<string, string> | string\n  LegalHold?: 'on' | 'off'\n  /**\n   * UTC Date String\n   */\n  RetainUntilDate?: string\n  Mode?: RETENTION_MODES\n  MetadataDirective?: 'COPY' | 'REPLACE'\n  /**\n   * Extra headers for the target object\n   */\n  Headers?: Record<string, string>\n}\n\nexport class CopyDestinationOptions {\n  public readonly Bucket: string\n  public readonly Object: string\n  private readonly Encryption?: Encryption\n  private readonly UserMetadata?: ObjectMetaData\n  private readonly UserTags?: Record<string, string> | string\n  private readonly LegalHold?: 'on' | 'off'\n  private readonly RetainUntilDate?: string\n  private readonly Mode?: RETENTION_MODES\n  private readonly MetadataDirective?: string\n  private readonly Headers?: Record<string, string>\n\n  constructor({\n    Bucket,\n    Object,\n    Encryption,\n    UserMetadata,\n    UserTags,\n    LegalHold,\n    RetainUntilDate,\n    Mode,\n    MetadataDirective,\n    Headers,\n  }: ICopyDestinationOptions) {\n    this.Bucket = Bucket\n    this.Object = Object\n    this.Encryption = Encryption ?? undefined // null input will become undefined, easy for runtime assert\n    this.UserMetadata = UserMetadata\n    this.UserTags = UserTags\n    this.LegalHold = LegalHold\n    this.Mode = Mode // retention mode\n    this.RetainUntilDate = RetainUntilDate\n    this.MetadataDirective = MetadataDirective\n    this.Headers = Headers\n  }\n\n  getHeaders(): RequestHeaders {\n    const replaceDirective = 'REPLACE'\n    const headerOptions: RequestHeaders = {}\n\n    const userTags = this.UserTags\n    if (!isEmpty(userTags)) {\n      headerOptions['X-Amz-Tagging-Directive'] = replaceDirective\n      headerOptions['X-Amz-Tagging'] = isObject(userTags)\n        ? querystring.stringify(userTags)\n        : isString(userTags)\n        ? userTags\n        : ''\n    }\n\n    if (this.Mode) {\n      headerOptions['X-Amz-Object-Lock-Mode'] = this.Mode // GOVERNANCE or COMPLIANCE\n    }\n\n    if (this.RetainUntilDate) {\n      headerOptions['X-Amz-Object-Lock-Retain-Until-Date'] = this.RetainUntilDate // needs to be UTC.\n    }\n\n    if (this.LegalHold) {\n      headerOptions['X-Amz-Object-Lock-Legal-Hold'] = this.LegalHold // ON or OFF\n    }\n\n    if (this.UserMetadata) {\n      for (const [key, value] of Object.entries(this.UserMetadata)) {\n        headerOptions[`X-Amz-Meta-${key}`] = value.toString()\n      }\n    }\n\n    if (this.MetadataDirective) {\n      headerOptions[`X-Amz-Metadata-Directive`] = this.MetadataDirective\n    }\n\n    if (this.Encryption) {\n      const encryptionHeaders = getEncryptionHeaders(this.Encryption)\n      for (const [key, value] of Object.entries(encryptionHeaders)) {\n        headerOptions[key] = value\n      }\n    }\n    if (this.Headers) {\n      for (const [key, value] of Object.entries(this.Headers)) {\n        headerOptions[key] = value\n      }\n    }\n\n    return headerOptions\n  }\n\n  validate() {\n    if (!isValidBucketName(this.Bucket)) {\n      throw new errors.InvalidBucketNameError('Invalid Destination bucket name: ' + this.Bucket)\n    }\n    if (!isValidObjectName(this.Object)) {\n      throw new errors.InvalidObjectNameError(`Invalid Destination object name: ${this.Object}`)\n    }\n    if (!isEmpty(this.UserMetadata) && !isObject(this.UserMetadata)) {\n      throw new errors.InvalidObjectNameError(`Destination UserMetadata should be an object with key value pairs`)\n    }\n\n    if (!isEmpty(this.Mode) && ![RETENTION_MODES.GOVERNANCE, RETENTION_MODES.COMPLIANCE].includes(this.Mode)) {\n      throw new errors.InvalidObjectNameError(\n        `Invalid Mode specified for destination object it should be one of [GOVERNANCE,COMPLIANCE]`,\n      )\n    }\n\n    if (this.Encryption !== undefined && isEmptyObject(this.Encryption)) {\n      throw new errors.InvalidObjectNameError(`Invalid Encryption configuration for destination object `)\n    }\n    return true\n  }\n}\n\n/**\n * maybe this should be a generic type for Records, leave it for later refactor\n */\nexport class SelectResults {\n  private records?: unknown\n  private response?: unknown\n  private stats?: string\n  private progress?: unknown\n\n  constructor({\n    records, // parsed data as stream\n    response, // original response stream\n    stats, // stats as xml\n    progress, // stats as xml\n  }: {\n    records?: unknown\n    response?: unknown\n    stats?: string\n    progress?: unknown\n  }) {\n    this.records = records\n    this.response = response\n    this.stats = stats\n    this.progress = progress\n  }\n\n  setStats(stats: string) {\n    this.stats = stats\n  }\n\n  getStats() {\n    return this.stats\n  }\n\n  setProgress(progress: unknown) {\n    this.progress = progress\n  }\n\n  getProgress() {\n    return this.progress\n  }\n\n  setResponse(response: unknown) {\n    this.response = response\n  }\n\n  getResponse() {\n    return this.response\n  }\n\n  setRecords(records: unknown) {\n    this.records = records\n  }\n\n  getRecords(): unknown {\n    return this.records\n  }\n}\n"],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ /// <reference types="node" />
2
+ /// <reference types="node" />
3
+ import * as fs from 'node:fs';
4
+ import * as stream from 'node:stream';
5
+ export { promises as fsp } from 'node:fs';
6
+ export declare const streamPromise: {
7
+ pipeline: typeof stream.pipeline.__promisify__;
8
+ };
9
+ export declare const fstat: typeof fs.fstat.__promisify__;
@@ -0,0 +1,14 @@
1
+ // promise helper for stdlib
2
+
3
+ import * as fs from "fs";
4
+ import * as stream from "stream";
5
+ import { promisify } from "util";
6
+
7
+ // TODO: use "node:fs/promise" directly after we stop testing on nodejs 12
8
+ export { promises as fsp } from 'node:fs';
9
+ export const streamPromise = {
10
+ // node:stream/promises Added in: v15.0.0
11
+ pipeline: promisify(stream.pipeline)
12
+ };
13
+ export const fstat = promisify(fs.fstat);
14
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJmcyIsInN0cmVhbSIsInByb21pc2lmeSIsInByb21pc2VzIiwiZnNwIiwic3RyZWFtUHJvbWlzZSIsInBpcGVsaW5lIiwiZnN0YXQiXSwic291cmNlcyI6WyJhc3luYy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvLyBwcm9taXNlIGhlbHBlciBmb3Igc3RkbGliXG5cbmltcG9ydCAqIGFzIGZzIGZyb20gJ25vZGU6ZnMnXG5pbXBvcnQgKiBhcyBzdHJlYW0gZnJvbSAnbm9kZTpzdHJlYW0nXG5pbXBvcnQgeyBwcm9taXNpZnkgfSBmcm9tICdub2RlOnV0aWwnXG5cbi8vIFRPRE86IHVzZSBcIm5vZGU6ZnMvcHJvbWlzZVwiIGRpcmVjdGx5IGFmdGVyIHdlIHN0b3AgdGVzdGluZyBvbiBub2RlanMgMTJcbmV4cG9ydCB7IHByb21pc2VzIGFzIGZzcCB9IGZyb20gJ25vZGU6ZnMnXG5leHBvcnQgY29uc3Qgc3RyZWFtUHJvbWlzZSA9IHtcbiAgLy8gbm9kZTpzdHJlYW0vcHJvbWlzZXMgQWRkZWQgaW46IHYxNS4wLjBcbiAgcGlwZWxpbmU6IHByb21pc2lmeShzdHJlYW0ucGlwZWxpbmUpLFxufVxuXG5leHBvcnQgY29uc3QgZnN0YXQgPSBwcm9taXNpZnkoZnMuZnN0YXQpXG4iXSwibWFwcGluZ3MiOiJBQUFBOztBQUVBLE9BQU8sS0FBS0EsRUFBRTtBQUNkLE9BQU8sS0FBS0MsTUFBTTtBQUNsQixTQUFTQyxTQUFTOztBQUVsQjtBQUNBLFNBQVNDLFFBQVEsSUFBSUMsR0FBRyxRQUFRLFNBQVM7QUFDekMsT0FBTyxNQUFNQyxhQUFhLEdBQUc7RUFDM0I7RUFDQUMsUUFBUSxFQUFFSixTQUFTLENBQUNELE1BQU0sQ0FBQ0ssUUFBUTtBQUNyQyxDQUFDO0FBRUQsT0FBTyxNQUFNQyxLQUFLLEdBQUdMLFNBQVMsQ0FBQ0YsRUFBRSxDQUFDTyxLQUFLLENBQUMifQ==
@@ -0,0 +1 @@
1
+ export declare function callbackify(fn: (...args: any[]) => any): (this: any, ...args: any[]) => any;
@@ -0,0 +1,15 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+
3
+ // Wrapper for an async function that supports callback style API.
4
+ // It will preserve 'this'.
5
+ export function callbackify(fn) {
6
+ return function (...args) {
7
+ const lastArg = args[args.length - 1];
8
+ if (typeof lastArg === 'function') {
9
+ const callback = args.pop();
10
+ return fn.apply(this, args).then(result => callback(null, result), err => callback(err));
11
+ }
12
+ return fn.apply(this, args);
13
+ };
14
+ }
15
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjYWxsYmFja2lmeSIsImZuIiwiYXJncyIsImxhc3RBcmciLCJsZW5ndGgiLCJjYWxsYmFjayIsInBvcCIsImFwcGx5IiwidGhlbiIsInJlc3VsdCIsImVyciJdLCJzb3VyY2VzIjpbImNhbGxiYWNraWZ5LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnkgKi9cblxuLy8gV3JhcHBlciBmb3IgYW4gYXN5bmMgZnVuY3Rpb24gdGhhdCBzdXBwb3J0cyBjYWxsYmFjayBzdHlsZSBBUEkuXG4vLyBJdCB3aWxsIHByZXNlcnZlICd0aGlzJy5cbmV4cG9ydCBmdW5jdGlvbiBjYWxsYmFja2lmeShmbjogKC4uLmFyZ3M6IGFueVtdKSA9PiBhbnkpIHtcbiAgcmV0dXJuIGZ1bmN0aW9uICh0aGlzOiBhbnksIC4uLmFyZ3M6IGFueVtdKSB7XG4gICAgY29uc3QgbGFzdEFyZyA9IGFyZ3NbYXJncy5sZW5ndGggLSAxXVxuXG4gICAgaWYgKHR5cGVvZiBsYXN0QXJnID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICBjb25zdCBjYWxsYmFjayA9IGFyZ3MucG9wKClcbiAgICAgIHJldHVybiBmbi5hcHBseSh0aGlzLCBhcmdzKS50aGVuKFxuICAgICAgICAocmVzdWx0OiBhbnkpID0+IGNhbGxiYWNrKG51bGwsIHJlc3VsdCksXG4gICAgICAgIChlcnI6IGFueSkgPT4gY2FsbGJhY2soZXJyKSxcbiAgICAgIClcbiAgICB9XG5cbiAgICByZXR1cm4gZm4uYXBwbHkodGhpcywgYXJncylcbiAgfVxufVxuIl0sIm1hcHBpbmdzIjoiQUFBQTs7QUFFQTtBQUNBO0FBQ0EsT0FBTyxTQUFTQSxXQUFXQSxDQUFDQyxFQUEyQixFQUFFO0VBQ3ZELE9BQU8sVUFBcUIsR0FBR0MsSUFBVyxFQUFFO0lBQzFDLE1BQU1DLE9BQU8sR0FBR0QsSUFBSSxDQUFDQSxJQUFJLENBQUNFLE1BQU0sR0FBRyxDQUFDLENBQUM7SUFFckMsSUFBSSxPQUFPRCxPQUFPLEtBQUssVUFBVSxFQUFFO01BQ2pDLE1BQU1FLFFBQVEsR0FBR0gsSUFBSSxDQUFDSSxHQUFHLENBQUMsQ0FBQztNQUMzQixPQUFPTCxFQUFFLENBQUNNLEtBQUssQ0FBQyxJQUFJLEVBQUVMLElBQUksQ0FBQyxDQUFDTSxJQUFJLENBQzdCQyxNQUFXLElBQUtKLFFBQVEsQ0FBQyxJQUFJLEVBQUVJLE1BQU0sQ0FBQyxFQUN0Q0MsR0FBUSxJQUFLTCxRQUFRLENBQUNLLEdBQUcsQ0FDNUIsQ0FBQztJQUNIO0lBRUEsT0FBT1QsRUFBRSxDQUFDTSxLQUFLLENBQUMsSUFBSSxFQUFFTCxJQUFJLENBQUM7RUFDN0IsQ0FBQztBQUNIIn0=