@aws-sdk/lib-storage 3.34.0 → 3.35.0

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 (82) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/dist-cjs/Upload.js +180 -0
  3. package/dist-cjs/bytelength.js +30 -0
  4. package/dist-cjs/chunker.js +31 -0
  5. package/dist-cjs/chunks/getChunkBuffer.js +24 -0
  6. package/dist-cjs/chunks/getChunkStream.js +29 -0
  7. package/dist-cjs/chunks/getDataReadable.js +11 -0
  8. package/dist-cjs/chunks/getDataReadableStream.js +23 -0
  9. package/{dist/cjs → dist-cjs}/index.js +1 -1
  10. package/dist-cjs/runtimeConfig.browser.js +9 -0
  11. package/dist-cjs/runtimeConfig.js +11 -0
  12. package/dist-cjs/runtimeConfig.native.js +9 -0
  13. package/dist-cjs/runtimeConfig.shared.js +7 -0
  14. package/dist-cjs/types.js +3 -0
  15. package/dist-es/Upload.js +262 -0
  16. package/dist-es/bytelength.js +26 -0
  17. package/dist-es/chunker.js +27 -0
  18. package/dist-es/chunks/getChunkBuffer.js +38 -0
  19. package/dist-es/chunks/getChunkStream.js +69 -0
  20. package/dist-es/chunks/getDataReadable.js +45 -0
  21. package/dist-es/chunks/getDataReadableStream.js +39 -0
  22. package/dist-es/index.js +3 -0
  23. package/dist-es/runtimeConfig.browser.js +4 -0
  24. package/dist-es/runtimeConfig.js +5 -0
  25. package/dist-es/runtimeConfig.native.js +4 -0
  26. package/dist-es/runtimeConfig.shared.js +4 -0
  27. package/dist-es/types.js +2 -0
  28. package/{dist/types → dist-types}/Upload.d.ts +0 -0
  29. package/{dist/types → dist-types}/bytelength.d.ts +0 -0
  30. package/{dist/types → dist-types}/chunker.d.ts +0 -0
  31. package/{dist/types → dist-types}/chunks/getChunkBuffer.d.ts +0 -0
  32. package/{dist/types → dist-types}/chunks/getChunkStream.d.ts +0 -0
  33. package/{dist/types → dist-types}/chunks/getDataReadable.d.ts +0 -0
  34. package/{dist/types → dist-types}/chunks/getDataReadableStream.d.ts +0 -0
  35. package/{dist/types → dist-types}/index.d.ts +0 -0
  36. package/{dist/types → dist-types}/runtimeConfig.browser.d.ts +0 -0
  37. package/{dist/types → dist-types}/runtimeConfig.d.ts +0 -0
  38. package/{dist/types → dist-types}/runtimeConfig.native.d.ts +0 -0
  39. package/{dist/types → dist-types}/runtimeConfig.shared.d.ts +0 -0
  40. package/{dist/types → dist-types}/ts3.4/Upload.d.ts +0 -0
  41. package/{dist/types → dist-types}/ts3.4/bytelength.d.ts +0 -0
  42. package/{dist/types → dist-types}/ts3.4/chunker.d.ts +0 -0
  43. package/{dist/types → dist-types}/ts3.4/chunks/getChunkBuffer.d.ts +0 -0
  44. package/{dist/types → dist-types}/ts3.4/chunks/getChunkStream.d.ts +0 -0
  45. package/{dist/types → dist-types}/ts3.4/chunks/getDataReadable.d.ts +0 -0
  46. package/{dist/types → dist-types}/ts3.4/chunks/getDataReadableStream.d.ts +0 -0
  47. package/{dist/types → dist-types}/ts3.4/index.d.ts +0 -0
  48. package/{dist/types → dist-types}/ts3.4/runtimeConfig.browser.d.ts +0 -0
  49. package/{dist/types → dist-types}/ts3.4/runtimeConfig.d.ts +0 -0
  50. package/{dist/types → dist-types}/ts3.4/runtimeConfig.native.d.ts +0 -0
  51. package/{dist/types → dist-types}/ts3.4/runtimeConfig.shared.d.ts +0 -0
  52. package/{dist/types → dist-types}/ts3.4/types.d.ts +0 -0
  53. package/{dist/types → dist-types}/types.d.ts +0 -0
  54. package/package.json +9 -9
  55. package/tsconfig.cjs.json +1 -1
  56. package/tsconfig.es.json +1 -1
  57. package/tsconfig.types.json +1 -1
  58. package/dist/cjs/Upload.js +0 -180
  59. package/dist/cjs/bytelength.js +0 -30
  60. package/dist/cjs/chunker.js +0 -31
  61. package/dist/cjs/chunks/getChunkBuffer.js +0 -24
  62. package/dist/cjs/chunks/getChunkStream.js +0 -29
  63. package/dist/cjs/chunks/getDataReadable.js +0 -11
  64. package/dist/cjs/chunks/getDataReadableStream.js +0 -23
  65. package/dist/cjs/runtimeConfig.browser.js +0 -9
  66. package/dist/cjs/runtimeConfig.js +0 -11
  67. package/dist/cjs/runtimeConfig.native.js +0 -9
  68. package/dist/cjs/runtimeConfig.shared.js +0 -7
  69. package/dist/cjs/types.js +0 -3
  70. package/dist/es/Upload.js +0 -278
  71. package/dist/es/bytelength.js +0 -26
  72. package/dist/es/chunker.js +0 -29
  73. package/dist/es/chunks/getChunkBuffer.js +0 -38
  74. package/dist/es/chunks/getChunkStream.js +0 -70
  75. package/dist/es/chunks/getDataReadable.js +0 -45
  76. package/dist/es/chunks/getDataReadableStream.js +0 -43
  77. package/dist/es/index.js +0 -3
  78. package/dist/es/runtimeConfig.browser.js +0 -7
  79. package/dist/es/runtimeConfig.js +0 -8
  80. package/dist/es/runtimeConfig.native.js +0 -7
  81. package/dist/es/runtimeConfig.shared.js +0 -7
  82. package/dist/es/types.js +0 -2
@@ -0,0 +1,262 @@
1
+ import { __assign, __asyncValues, __awaiter, __extends, __generator } from "tslib";
2
+ import { CompleteMultipartUploadCommand, CreateMultipartUploadCommand, PutObjectCommand, PutObjectTaggingCommand, UploadPartCommand, } from "@aws-sdk/client-s3";
3
+ import { EventEmitter } from "events";
4
+ import { getChunk } from "./chunker";
5
+ import { byteLength } from "./bytelength";
6
+ import { AbortController } from "@aws-sdk/abort-controller";
7
+ var MIN_PART_SIZE = 1024 * 1024 * 5;
8
+ var Upload = (function (_super) {
9
+ __extends(Upload, _super);
10
+ function Upload(options) {
11
+ var _this = _super.call(this) || this;
12
+ _this.MAX_PARTS = 10000;
13
+ _this.queueSize = 4;
14
+ _this.partSize = MIN_PART_SIZE;
15
+ _this.leavePartsOnError = false;
16
+ _this.tags = [];
17
+ _this.concurrentUploaders = [];
18
+ _this.uploadedParts = [];
19
+ _this.isMultiPart = true;
20
+ _this.queueSize = options.queueSize || _this.queueSize;
21
+ _this.partSize = options.partSize || _this.partSize;
22
+ _this.leavePartsOnError = options.leavePartsOnError || _this.leavePartsOnError;
23
+ _this.tags = options.tags || _this.tags;
24
+ _this.client = options.client;
25
+ _this.params = options.params;
26
+ _this.__validateInput();
27
+ _this.totalBytes = byteLength(_this.params.Body);
28
+ _this.bytesUploadedSoFar = 0;
29
+ _this.abortController = new AbortController();
30
+ return _this;
31
+ }
32
+ Upload.prototype.abort = function () {
33
+ return __awaiter(this, void 0, void 0, function () {
34
+ return __generator(this, function (_a) {
35
+ this.abortController.abort();
36
+ return [2];
37
+ });
38
+ });
39
+ };
40
+ Upload.prototype.done = function () {
41
+ return __awaiter(this, void 0, void 0, function () {
42
+ return __generator(this, function (_a) {
43
+ switch (_a.label) {
44
+ case 0: return [4, Promise.race([this.__doMultipartUpload(), this.__abortTimeout(this.abortController.signal)])];
45
+ case 1: return [2, _a.sent()];
46
+ }
47
+ });
48
+ });
49
+ };
50
+ Upload.prototype.on = function (event, listener) {
51
+ this.uploadEvent = event;
52
+ _super.prototype.on.call(this, event, listener);
53
+ };
54
+ Upload.prototype.__uploadUsingPut = function (dataPart) {
55
+ return __awaiter(this, void 0, void 0, function () {
56
+ var params, putResult, totalSize;
57
+ return __generator(this, function (_a) {
58
+ switch (_a.label) {
59
+ case 0:
60
+ this.isMultiPart = false;
61
+ params = __assign(__assign({}, this.params), { Body: dataPart.data });
62
+ return [4, this.client.send(new PutObjectCommand(params))];
63
+ case 1:
64
+ putResult = _a.sent();
65
+ this.putResponse = putResult;
66
+ totalSize = byteLength(dataPart.data);
67
+ this.__notifyProgress({
68
+ loaded: totalSize,
69
+ total: totalSize,
70
+ part: 1,
71
+ Key: this.params.Key,
72
+ Bucket: this.params.Bucket,
73
+ });
74
+ return [2];
75
+ }
76
+ });
77
+ });
78
+ };
79
+ Upload.prototype.__createMultipartUpload = function () {
80
+ return __awaiter(this, void 0, void 0, function () {
81
+ var createCommandParams, createMultipartUploadResult;
82
+ return __generator(this, function (_a) {
83
+ switch (_a.label) {
84
+ case 0:
85
+ if (!this.createMultiPartPromise) {
86
+ createCommandParams = __assign(__assign({}, this.params), { Body: undefined });
87
+ this.createMultiPartPromise = this.client.send(new CreateMultipartUploadCommand(createCommandParams));
88
+ }
89
+ return [4, this.createMultiPartPromise];
90
+ case 1:
91
+ createMultipartUploadResult = _a.sent();
92
+ this.uploadId = createMultipartUploadResult.UploadId;
93
+ return [2];
94
+ }
95
+ });
96
+ });
97
+ };
98
+ Upload.prototype.__doConcurrentUpload = function (dataFeeder) {
99
+ var dataFeeder_1, dataFeeder_1_1;
100
+ var e_1, _a;
101
+ return __awaiter(this, void 0, void 0, function () {
102
+ var dataPart, partResult, e_2, e_1_1;
103
+ return __generator(this, function (_b) {
104
+ switch (_b.label) {
105
+ case 0:
106
+ _b.trys.push([0, 12, 13, 18]);
107
+ dataFeeder_1 = __asyncValues(dataFeeder);
108
+ _b.label = 1;
109
+ case 1: return [4, dataFeeder_1.next()];
110
+ case 2:
111
+ if (!(dataFeeder_1_1 = _b.sent(), !dataFeeder_1_1.done)) return [3, 11];
112
+ dataPart = dataFeeder_1_1.value;
113
+ if (this.uploadedParts.length > this.MAX_PARTS) {
114
+ throw new Error("Exceeded " + this.MAX_PARTS + " as part of the upload to " + this.params.Key + " and " + this.params.Bucket + ".");
115
+ }
116
+ _b.label = 3;
117
+ case 3:
118
+ _b.trys.push([3, 9, , 10]);
119
+ if (this.abortController.signal.aborted) {
120
+ return [2];
121
+ }
122
+ if (!(dataPart.partNumber === 1 && dataPart.lastPart)) return [3, 5];
123
+ return [4, this.__uploadUsingPut(dataPart)];
124
+ case 4: return [2, _b.sent()];
125
+ case 5:
126
+ if (!!this.uploadId) return [3, 7];
127
+ return [4, this.__createMultipartUpload()];
128
+ case 6:
129
+ _b.sent();
130
+ if (this.abortController.signal.aborted) {
131
+ return [2];
132
+ }
133
+ _b.label = 7;
134
+ case 7: return [4, this.client.send(new UploadPartCommand(__assign(__assign({}, this.params), { UploadId: this.uploadId, Body: dataPart.data, PartNumber: dataPart.partNumber })))];
135
+ case 8:
136
+ partResult = _b.sent();
137
+ if (this.abortController.signal.aborted) {
138
+ return [2];
139
+ }
140
+ this.uploadedParts.push({
141
+ PartNumber: dataPart.partNumber,
142
+ ETag: partResult.ETag,
143
+ });
144
+ this.bytesUploadedSoFar += byteLength(dataPart.data);
145
+ this.__notifyProgress({
146
+ loaded: this.bytesUploadedSoFar,
147
+ total: this.totalBytes,
148
+ part: dataPart.partNumber,
149
+ Key: this.params.Key,
150
+ Bucket: this.params.Bucket,
151
+ });
152
+ return [3, 10];
153
+ case 9:
154
+ e_2 = _b.sent();
155
+ if (!this.uploadId) {
156
+ throw e_2;
157
+ }
158
+ if (this.leavePartsOnError) {
159
+ throw e_2;
160
+ }
161
+ return [3, 10];
162
+ case 10: return [3, 1];
163
+ case 11: return [3, 18];
164
+ case 12:
165
+ e_1_1 = _b.sent();
166
+ e_1 = { error: e_1_1 };
167
+ return [3, 18];
168
+ case 13:
169
+ _b.trys.push([13, , 16, 17]);
170
+ if (!(dataFeeder_1_1 && !dataFeeder_1_1.done && (_a = dataFeeder_1.return))) return [3, 15];
171
+ return [4, _a.call(dataFeeder_1)];
172
+ case 14:
173
+ _b.sent();
174
+ _b.label = 15;
175
+ case 15: return [3, 17];
176
+ case 16:
177
+ if (e_1) throw e_1.error;
178
+ return [7];
179
+ case 17: return [7];
180
+ case 18: return [2];
181
+ }
182
+ });
183
+ });
184
+ };
185
+ Upload.prototype.__doMultipartUpload = function () {
186
+ return __awaiter(this, void 0, void 0, function () {
187
+ var dataFeeder, index, currentUpload, result, uploadCompleteParams;
188
+ return __generator(this, function (_a) {
189
+ switch (_a.label) {
190
+ case 0:
191
+ dataFeeder = getChunk(this.params.Body, this.partSize);
192
+ for (index = 0; index < this.queueSize; index++) {
193
+ currentUpload = this.__doConcurrentUpload(dataFeeder);
194
+ this.concurrentUploaders.push(currentUpload);
195
+ }
196
+ return [4, Promise.all(this.concurrentUploaders)];
197
+ case 1:
198
+ _a.sent();
199
+ if (this.abortController.signal.aborted) {
200
+ throw Object.assign(new Error("Upload aborted."), { name: "AbortError" });
201
+ }
202
+ if (!this.isMultiPart) return [3, 3];
203
+ this.uploadedParts.sort(function (a, b) { return a.PartNumber - b.PartNumber; });
204
+ uploadCompleteParams = __assign(__assign({}, this.params), { Body: undefined, UploadId: this.uploadId, MultipartUpload: {
205
+ Parts: this.uploadedParts,
206
+ } });
207
+ return [4, this.client.send(new CompleteMultipartUploadCommand(uploadCompleteParams))];
208
+ case 2:
209
+ result = _a.sent();
210
+ return [3, 4];
211
+ case 3:
212
+ result = this.putResponse;
213
+ _a.label = 4;
214
+ case 4:
215
+ if (!this.tags.length) return [3, 6];
216
+ return [4, this.client.send(new PutObjectTaggingCommand(__assign(__assign({}, this.params), { Tagging: {
217
+ TagSet: this.tags,
218
+ } })))];
219
+ case 5:
220
+ _a.sent();
221
+ _a.label = 6;
222
+ case 6: return [2, result];
223
+ }
224
+ });
225
+ });
226
+ };
227
+ Upload.prototype.__notifyProgress = function (progress) {
228
+ if (this.uploadEvent) {
229
+ this.emit(this.uploadEvent, progress);
230
+ }
231
+ };
232
+ Upload.prototype.__abortTimeout = function (abortSignal) {
233
+ return __awaiter(this, void 0, void 0, function () {
234
+ return __generator(this, function (_a) {
235
+ return [2, new Promise(function (resolve, reject) {
236
+ abortSignal.onabort = function () {
237
+ var abortError = new Error("Upload aborted.");
238
+ abortError.name = "AbortError";
239
+ reject(abortError);
240
+ };
241
+ })];
242
+ });
243
+ });
244
+ };
245
+ Upload.prototype.__validateInput = function () {
246
+ if (!this.params) {
247
+ throw new Error("InputError: Upload requires params to be passed to upload.");
248
+ }
249
+ if (!this.client) {
250
+ throw new Error("InputError: Upload requires a AWS client to do uploads with.");
251
+ }
252
+ if (this.partSize < MIN_PART_SIZE) {
253
+ throw new Error("EntityTooSmall: Your proposed upload partsize [" + this.partSize + "] is smaller than the minimum allowed size [" + MIN_PART_SIZE + "] (5MB)");
254
+ }
255
+ if (this.queueSize < 1) {
256
+ throw new Error("Queue size: Must have at least one uploading queue.");
257
+ }
258
+ };
259
+ return Upload;
260
+ }(EventEmitter));
261
+ export { Upload };
262
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Upload.js","sourceRoot":"","sources":["../src/Upload.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  CompletedPart,\n  CompleteMultipartUploadCommand,\n  CreateMultipartUploadCommand,\n  CreateMultipartUploadCommandOutput,\n  PutObjectCommand,\n  PutObjectCommandInput,\n  PutObjectCommandOutput,\n  PutObjectTaggingCommand,\n  ServiceOutputTypes,\n  Tag,\n  UploadPartCommand,\n} from \"@aws-sdk/client-s3\";\nimport { EventEmitter } from \"events\";\nimport { BodyDataTypes, Options, Progress, ServiceClients } from \"./types\";\nimport { getChunk } from \"./chunker\";\nimport { byteLength } from \"./bytelength\";\nimport { AbortController, AbortSignal } from \"@aws-sdk/abort-controller\";\n\nexport interface RawDataPart {\n  partNumber: number;\n  data: BodyDataTypes;\n  lastPart?: boolean;\n}\n\nconst MIN_PART_SIZE = 1024 * 1024 * 5;\n\nexport class Upload extends EventEmitter {\n  /**\n   * S3 multipart upload does not allow more than 10000 parts.\n   */\n  private MAX_PARTS = 10000;\n\n  // Defaults.\n  private queueSize = 4;\n  private partSize = MIN_PART_SIZE;\n  private leavePartsOnError = false;\n  private tags: Tag[] = [];\n\n  private client: ServiceClients;\n  private params: PutObjectCommandInput;\n\n  // used for reporting progress.\n  private totalBytes?: number;\n  private bytesUploadedSoFar: number;\n\n  // used in the upload.\n  private abortController: AbortController;\n  private concurrentUploaders: Promise<void>[] = [];\n  private createMultiPartPromise?: Promise<CreateMultipartUploadCommandOutput>;\n\n  private uploadedParts: CompletedPart[] = [];\n  private uploadId?: string;\n  uploadEvent?: string;\n\n  private isMultiPart: boolean = true;\n  private putResponse?: PutObjectCommandOutput;\n\n  constructor(options: Options) {\n    super();\n\n    // set defaults from options.\n    this.queueSize = options.queueSize || this.queueSize;\n    this.partSize = options.partSize || this.partSize;\n    this.leavePartsOnError = options.leavePartsOnError || this.leavePartsOnError;\n    this.tags = options.tags || this.tags;\n\n    this.client = options.client;\n    this.params = options.params;\n\n    this.__validateInput();\n\n    // set progress defaults\n    this.totalBytes = byteLength(this.params.Body);\n    this.bytesUploadedSoFar = 0;\n    this.abortController = new AbortController();\n  }\n\n  async abort(): Promise<void> {\n    /**\n     * Abort stops all new uploads and immediately exists the top level promise on this.done()\n     * Concurrent threads in flight clean up eventually.\n     */\n    this.abortController.abort();\n  }\n\n  async done(): Promise<ServiceOutputTypes> {\n    return await Promise.race([this.__doMultipartUpload(), this.__abortTimeout(this.abortController.signal)]);\n  }\n\n  on(event: \"httpUploadProgress\", listener: (progress: Progress) => void): any {\n    this.uploadEvent = event;\n    super.on(event, listener);\n  }\n\n  async __uploadUsingPut(dataPart: RawDataPart) {\n    this.isMultiPart = false;\n    const params = { ...this.params, Body: dataPart.data };\n    const putResult = await this.client.send(new PutObjectCommand(params));\n    this.putResponse = putResult;\n    const totalSize = byteLength(dataPart.data);\n    this.__notifyProgress({\n      loaded: totalSize,\n      total: totalSize,\n      part: 1,\n      Key: this.params.Key,\n      Bucket: this.params.Bucket,\n    });\n  }\n\n  async __createMultipartUpload() {\n    if (!this.createMultiPartPromise) {\n      const createCommandParams = { ...this.params, Body: undefined };\n      this.createMultiPartPromise = this.client.send(new CreateMultipartUploadCommand(createCommandParams));\n    }\n    const createMultipartUploadResult = await this.createMultiPartPromise;\n    this.uploadId = createMultipartUploadResult.UploadId;\n  }\n\n  async __doConcurrentUpload(dataFeeder: AsyncGenerator<RawDataPart, void, undefined>): Promise<void> {\n    for await (const dataPart of dataFeeder) {\n      if (this.uploadedParts.length > this.MAX_PARTS) {\n        throw new Error(\n          `Exceeded ${this.MAX_PARTS} as part of the upload to ${this.params.Key} and ${this.params.Bucket}.`\n        );\n      }\n\n      try {\n        if (this.abortController.signal.aborted) {\n          return;\n        }\n\n        // Use put instead of multi-part for one chunk uploads.\n        if (dataPart.partNumber === 1 && dataPart.lastPart) {\n          return await this.__uploadUsingPut(dataPart);\n        }\n\n        if (!this.uploadId) {\n          await this.__createMultipartUpload();\n          if (this.abortController.signal.aborted) {\n            return;\n          }\n        }\n\n        const partResult = await this.client.send(\n          new UploadPartCommand({\n            ...this.params,\n            UploadId: this.uploadId,\n            Body: dataPart.data,\n            PartNumber: dataPart.partNumber,\n          })\n        );\n\n        if (this.abortController.signal.aborted) {\n          return;\n        }\n\n        this.uploadedParts.push({\n          PartNumber: dataPart.partNumber,\n          ETag: partResult.ETag,\n        });\n\n        this.bytesUploadedSoFar += byteLength(dataPart.data);\n        this.__notifyProgress({\n          loaded: this.bytesUploadedSoFar,\n          total: this.totalBytes,\n          part: dataPart.partNumber,\n          Key: this.params.Key,\n          Bucket: this.params.Bucket,\n        });\n      } catch (e) {\n        // Failed to create multi-part or put\n        if (!this.uploadId) {\n          throw e;\n        }\n        // on leavePartsOnError throw an error so users can deal with it themselves,\n        // otherwise swallow the error.\n        if (this.leavePartsOnError) {\n          throw e;\n        }\n      }\n    }\n  }\n\n  async __doMultipartUpload(): Promise<ServiceOutputTypes> {\n    // Set up data input chunks.\n    const dataFeeder = getChunk(this.params.Body, this.partSize);\n\n    // Create and start concurrent uploads.\n    for (let index = 0; index < this.queueSize; index++) {\n      const currentUpload = this.__doConcurrentUpload(dataFeeder);\n      this.concurrentUploaders.push(currentUpload);\n    }\n\n    // Create and start concurrent uploads.\n    await Promise.all(this.concurrentUploaders);\n    if (this.abortController.signal.aborted) {\n      throw Object.assign(new Error(\"Upload aborted.\"), { name: \"AbortError\" });\n    }\n\n    let result;\n    if (this.isMultiPart) {\n      this.uploadedParts.sort((a, b) => a.PartNumber! - b.PartNumber!);\n\n      const uploadCompleteParams = {\n        ...this.params,\n        Body: undefined,\n        UploadId: this.uploadId,\n        MultipartUpload: {\n          Parts: this.uploadedParts,\n        },\n      };\n      result = await this.client.send(new CompleteMultipartUploadCommand(uploadCompleteParams));\n    } else {\n      result = this.putResponse!;\n    }\n\n    // Add tags to the object after it's completed the upload.\n    if (this.tags.length) {\n      await this.client.send(\n        new PutObjectTaggingCommand({\n          ...this.params,\n          Tagging: {\n            TagSet: this.tags,\n          },\n        })\n      );\n    }\n\n    return result;\n  }\n\n  __notifyProgress(progress: Progress) {\n    if (this.uploadEvent) {\n      this.emit(this.uploadEvent, progress);\n    }\n  }\n\n  async __abortTimeout(abortSignal: AbortSignal): Promise<ServiceOutputTypes> {\n    return new Promise((resolve, reject) => {\n      abortSignal.onabort = () => {\n        const abortError = new Error(\"Upload aborted.\");\n        abortError.name = \"AbortError\";\n        reject(abortError);\n      };\n    });\n  }\n\n  __validateInput() {\n    if (!this.params) {\n      throw new Error(`InputError: Upload requires params to be passed to upload.`);\n    }\n\n    if (!this.client) {\n      throw new Error(`InputError: Upload requires a AWS client to do uploads with.`);\n    }\n\n    if (this.partSize < MIN_PART_SIZE) {\n      throw new Error(\n        `EntityTooSmall: Your proposed upload partsize [${this.partSize}] is smaller than the minimum allowed size [${MIN_PART_SIZE}] (5MB)`\n      );\n    }\n\n    if (this.queueSize < 1) {\n      throw new Error(`Queue size: Must have at least one uploading queue.`);\n    }\n  }\n}\n"]}
@@ -0,0 +1,26 @@
1
+ import { ClientDefaultValues } from "./runtimeConfig";
2
+ export var byteLength = function (input) {
3
+ if (input === null || input === undefined)
4
+ return 0;
5
+ if (typeof input === "string")
6
+ input = Buffer.from(input);
7
+ if (typeof input.byteLength === "number") {
8
+ return input.byteLength;
9
+ }
10
+ else if (typeof input.length === "number") {
11
+ return input.length;
12
+ }
13
+ else if (typeof input.size === "number") {
14
+ return input.size;
15
+ }
16
+ else if (typeof input.path === "string") {
17
+ try {
18
+ return ClientDefaultValues.lstatSync(input.path).size;
19
+ }
20
+ catch (error) {
21
+ return undefined;
22
+ }
23
+ }
24
+ return undefined;
25
+ };
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnl0ZWxlbmd0aC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9ieXRlbGVuZ3RoLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRXRELE1BQU0sQ0FBQyxJQUFNLFVBQVUsR0FBRyxVQUFDLEtBQVU7SUFDbkMsSUFBSSxLQUFLLEtBQUssSUFBSSxJQUFJLEtBQUssS0FBSyxTQUFTO1FBQUUsT0FBTyxDQUFDLENBQUM7SUFDcEQsSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRO1FBQUUsS0FBSyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDMUQsSUFBSSxPQUFPLEtBQUssQ0FBQyxVQUFVLEtBQUssUUFBUSxFQUFFO1FBQ3hDLE9BQU8sS0FBSyxDQUFDLFVBQVUsQ0FBQztLQUN6QjtTQUFNLElBQUksT0FBTyxLQUFLLENBQUMsTUFBTSxLQUFLLFFBQVEsRUFBRTtRQUMzQyxPQUFPLEtBQUssQ0FBQyxNQUFNLENBQUM7S0FDckI7U0FBTSxJQUFJLE9BQU8sS0FBSyxDQUFDLElBQUksS0FBSyxRQUFRLEVBQUU7UUFDekMsT0FBTyxLQUFLLENBQUMsSUFBSSxDQUFDO0tBQ25CO1NBQU0sSUFBSSxPQUFPLEtBQUssQ0FBQyxJQUFJLEtBQUssUUFBUSxFQUFFO1FBQ3pDLElBQUk7WUFDRixPQUFPLG1CQUFtQixDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDO1NBQ3ZEO1FBQUMsT0FBTyxLQUFLLEVBQUU7WUFDZCxPQUFPLFNBQVMsQ0FBQztTQUNsQjtLQUNGO0lBQ0QsT0FBTyxTQUFTLENBQUM7QUFDbkIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2xpZW50RGVmYXVsdFZhbHVlcyB9IGZyb20gXCIuL3J1bnRpbWVDb25maWdcIjtcblxuZXhwb3J0IGNvbnN0IGJ5dGVMZW5ndGggPSAoaW5wdXQ6IGFueSkgPT4ge1xuICBpZiAoaW5wdXQgPT09IG51bGwgfHwgaW5wdXQgPT09IHVuZGVmaW5lZCkgcmV0dXJuIDA7XG4gIGlmICh0eXBlb2YgaW5wdXQgPT09IFwic3RyaW5nXCIpIGlucHV0ID0gQnVmZmVyLmZyb20oaW5wdXQpO1xuICBpZiAodHlwZW9mIGlucHV0LmJ5dGVMZW5ndGggPT09IFwibnVtYmVyXCIpIHtcbiAgICByZXR1cm4gaW5wdXQuYnl0ZUxlbmd0aDtcbiAgfSBlbHNlIGlmICh0eXBlb2YgaW5wdXQubGVuZ3RoID09PSBcIm51bWJlclwiKSB7XG4gICAgcmV0dXJuIGlucHV0Lmxlbmd0aDtcbiAgfSBlbHNlIGlmICh0eXBlb2YgaW5wdXQuc2l6ZSA9PT0gXCJudW1iZXJcIikge1xuICAgIHJldHVybiBpbnB1dC5zaXplO1xuICB9IGVsc2UgaWYgKHR5cGVvZiBpbnB1dC5wYXRoID09PSBcInN0cmluZ1wiKSB7XG4gICAgdHJ5IHtcbiAgICAgIHJldHVybiBDbGllbnREZWZhdWx0VmFsdWVzLmxzdGF0U3luYyhpbnB1dC5wYXRoKS5zaXplO1xuICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIH1cbiAgfVxuICByZXR1cm4gdW5kZWZpbmVkO1xufTtcbiJdfQ==
@@ -0,0 +1,27 @@
1
+ import { Readable } from "stream";
2
+ import { Buffer } from "buffer";
3
+ import { getChunkBuffer } from "./chunks/getChunkBuffer";
4
+ import { getChunkStream } from "./chunks/getChunkStream";
5
+ import { getDataReadableStream } from "./chunks/getDataReadableStream";
6
+ import { getDataReadable } from "./chunks/getDataReadable";
7
+ export var getChunk = function (data, partSize) {
8
+ if (data instanceof Buffer) {
9
+ return getChunkBuffer(data, partSize);
10
+ }
11
+ else if (data instanceof Readable) {
12
+ return getChunkStream(data, partSize, getDataReadable);
13
+ }
14
+ else if (data instanceof String || typeof data === "string" || data instanceof Uint8Array) {
15
+ return getChunkBuffer(Buffer.from(data), partSize);
16
+ }
17
+ if (typeof data.stream === "function") {
18
+ return getChunkStream(data.stream(), partSize, getDataReadableStream);
19
+ }
20
+ else if (data instanceof ReadableStream) {
21
+ return getChunkStream(data, partSize, getDataReadableStream);
22
+ }
23
+ else {
24
+ throw new Error("Body Data is unsupported format, expected data to be one of: string | Uint8Array | Buffer | Readable | ReadableStream | Blob;.");
25
+ }
26
+ };
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2h1bmtlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9jaHVua2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFDbEMsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLFFBQVEsQ0FBQztBQUdoQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUUzRCxNQUFNLENBQUMsSUFBTSxRQUFRLEdBQUcsVUFBQyxJQUFtQixFQUFFLFFBQWdCO0lBQzVELElBQUksSUFBSSxZQUFZLE1BQU0sRUFBRTtRQUMxQixPQUFPLGNBQWMsQ0FBQyxJQUFJLEVBQUUsUUFBUSxDQUFDLENBQUM7S0FDdkM7U0FBTSxJQUFJLElBQUksWUFBWSxRQUFRLEVBQUU7UUFDbkMsT0FBTyxjQUFjLENBQVcsSUFBSSxFQUFFLFFBQVEsRUFBRSxlQUFlLENBQUMsQ0FBQztLQUNsRTtTQUFNLElBQUksSUFBSSxZQUFZLE1BQU0sSUFBSSxPQUFPLElBQUksS0FBSyxRQUFRLElBQUksSUFBSSxZQUFZLFVBQVUsRUFBRTtRQUUzRixPQUFPLGNBQWMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLFFBQVEsQ0FBQyxDQUFDO0tBQ3BEO0lBQ0QsSUFBSSxPQUFRLElBQVksQ0FBQyxNQUFNLEtBQUssVUFBVSxFQUFFO1FBRTlDLE9BQU8sY0FBYyxDQUFrQixJQUFZLENBQUMsTUFBTSxFQUFFLEVBQUUsUUFBUSxFQUFFLHFCQUFxQixDQUFDLENBQUM7S0FDaEc7U0FBTSxJQUFJLElBQUksWUFBWSxjQUFjLEVBQUU7UUFDekMsT0FBTyxjQUFjLENBQWlCLElBQUksRUFBRSxRQUFRLEVBQUUscUJBQXFCLENBQUMsQ0FBQztLQUM5RTtTQUFNO1FBQ0wsTUFBTSxJQUFJLEtBQUssQ0FDYixnSUFBZ0ksQ0FDakksQ0FBQztLQUNIO0FBQ0gsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUmVhZGFibGUgfSBmcm9tIFwic3RyZWFtXCI7XG5pbXBvcnQgeyBCdWZmZXIgfSBmcm9tIFwiYnVmZmVyXCI7XG5cbmltcG9ydCB7IEJvZHlEYXRhVHlwZXMgfSBmcm9tIFwiLi90eXBlc1wiO1xuaW1wb3J0IHsgZ2V0Q2h1bmtCdWZmZXIgfSBmcm9tIFwiLi9jaHVua3MvZ2V0Q2h1bmtCdWZmZXJcIjtcbmltcG9ydCB7IGdldENodW5rU3RyZWFtIH0gZnJvbSBcIi4vY2h1bmtzL2dldENodW5rU3RyZWFtXCI7XG5pbXBvcnQgeyBnZXREYXRhUmVhZGFibGVTdHJlYW0gfSBmcm9tIFwiLi9jaHVua3MvZ2V0RGF0YVJlYWRhYmxlU3RyZWFtXCI7XG5pbXBvcnQgeyBnZXREYXRhUmVhZGFibGUgfSBmcm9tIFwiLi9jaHVua3MvZ2V0RGF0YVJlYWRhYmxlXCI7XG5cbmV4cG9ydCBjb25zdCBnZXRDaHVuayA9IChkYXRhOiBCb2R5RGF0YVR5cGVzLCBwYXJ0U2l6ZTogbnVtYmVyKSA9PiB7XG4gIGlmIChkYXRhIGluc3RhbmNlb2YgQnVmZmVyKSB7XG4gICAgcmV0dXJuIGdldENodW5rQnVmZmVyKGRhdGEsIHBhcnRTaXplKTtcbiAgfSBlbHNlIGlmIChkYXRhIGluc3RhbmNlb2YgUmVhZGFibGUpIHtcbiAgICByZXR1cm4gZ2V0Q2h1bmtTdHJlYW08UmVhZGFibGU+KGRhdGEsIHBhcnRTaXplLCBnZXREYXRhUmVhZGFibGUpO1xuICB9IGVsc2UgaWYgKGRhdGEgaW5zdGFuY2VvZiBTdHJpbmcgfHwgdHlwZW9mIGRhdGEgPT09IFwic3RyaW5nXCIgfHwgZGF0YSBpbnN0YW5jZW9mIFVpbnQ4QXJyYXkpIHtcbiAgICAvLyBjaHVuayBTdHJpbmdzLCBVaW50OEFycmF5LlxuICAgIHJldHVybiBnZXRDaHVua0J1ZmZlcihCdWZmZXIuZnJvbShkYXRhKSwgcGFydFNpemUpO1xuICB9XG4gIGlmICh0eXBlb2YgKGRhdGEgYXMgYW55KS5zdHJlYW0gPT09IFwiZnVuY3Rpb25cIikge1xuICAgIC8vIGFwcHJveGltYXRlIHN1cHBvcnQgZm9yIEJsb2JzLlxuICAgIHJldHVybiBnZXRDaHVua1N0cmVhbTxSZWFkYWJsZVN0cmVhbT4oKGRhdGEgYXMgYW55KS5zdHJlYW0oKSwgcGFydFNpemUsIGdldERhdGFSZWFkYWJsZVN0cmVhbSk7XG4gIH0gZWxzZSBpZiAoZGF0YSBpbnN0YW5jZW9mIFJlYWRhYmxlU3RyZWFtKSB7XG4gICAgcmV0dXJuIGdldENodW5rU3RyZWFtPFJlYWRhYmxlU3RyZWFtPihkYXRhLCBwYXJ0U2l6ZSwgZ2V0RGF0YVJlYWRhYmxlU3RyZWFtKTtcbiAgfSBlbHNlIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBcIkJvZHkgRGF0YSBpcyB1bnN1cHBvcnRlZCBmb3JtYXQsIGV4cGVjdGVkIGRhdGEgdG8gYmUgb25lIG9mOiBzdHJpbmcgfCBVaW50OEFycmF5IHwgQnVmZmVyIHwgUmVhZGFibGUgfCBSZWFkYWJsZVN0cmVhbSB8IEJsb2I7LlwiXG4gICAgKTtcbiAgfVxufTtcbiJdfQ==
@@ -0,0 +1,38 @@
1
+ import { __asyncGenerator, __await, __generator } from "tslib";
2
+ export function getChunkBuffer(data, partSize) {
3
+ return __asyncGenerator(this, arguments, function getChunkBuffer_1() {
4
+ var partNumber, startByte, endByte;
5
+ return __generator(this, function (_a) {
6
+ switch (_a.label) {
7
+ case 0:
8
+ partNumber = 1;
9
+ startByte = 0;
10
+ endByte = partSize;
11
+ _a.label = 1;
12
+ case 1:
13
+ if (!(endByte < data.byteLength)) return [3, 4];
14
+ return [4, __await({
15
+ partNumber: partNumber,
16
+ data: data.slice(startByte, endByte),
17
+ })];
18
+ case 2: return [4, _a.sent()];
19
+ case 3:
20
+ _a.sent();
21
+ partNumber += 1;
22
+ startByte = endByte;
23
+ endByte = startByte + partSize;
24
+ return [3, 1];
25
+ case 4: return [4, __await({
26
+ partNumber: partNumber,
27
+ data: data.slice(startByte),
28
+ lastPart: true,
29
+ })];
30
+ case 5: return [4, _a.sent()];
31
+ case 6:
32
+ _a.sent();
33
+ return [2];
34
+ }
35
+ });
36
+ });
37
+ }
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0Q2h1bmtCdWZmZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY2h1bmtzL2dldENodW5rQnVmZmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFFQSxNQUFNLFVBQWlCLGNBQWMsQ0FBQyxJQUFZLEVBQUUsUUFBZ0I7Ozs7OztvQkFDOUQsVUFBVSxHQUFHLENBQUMsQ0FBQztvQkFDZixTQUFTLEdBQUcsQ0FBQyxDQUFDO29CQUNkLE9BQU8sR0FBRyxRQUFRLENBQUM7Ozt5QkFFaEIsQ0FBQSxPQUFPLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQTt1Q0FDeEI7NEJBQ0osVUFBVSxZQUFBOzRCQUNWLElBQUksRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsRUFBRSxPQUFPLENBQUM7eUJBQ3JDO3dCQUhELHNCQUdDOztvQkFIRCxTQUdDLENBQUM7b0JBQ0YsVUFBVSxJQUFJLENBQUMsQ0FBQztvQkFDaEIsU0FBUyxHQUFHLE9BQU8sQ0FBQztvQkFDcEIsT0FBTyxHQUFHLFNBQVMsR0FBRyxRQUFRLENBQUM7OzJDQUczQjt3QkFDSixVQUFVLFlBQUE7d0JBQ1YsSUFBSSxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDO3dCQUMzQixRQUFRLEVBQUUsSUFBSTtxQkFDZjt3QkFKRCxzQkFJQzs7b0JBSkQsU0FJQyxDQUFDOzs7OztDQUNIIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUmF3RGF0YVBhcnQgfSBmcm9tIFwiLi4vVXBsb2FkXCI7XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiogZ2V0Q2h1bmtCdWZmZXIoZGF0YTogQnVmZmVyLCBwYXJ0U2l6ZTogbnVtYmVyKTogQXN5bmNHZW5lcmF0b3I8UmF3RGF0YVBhcnQsIHZvaWQsIHVuZGVmaW5lZD4ge1xuICBsZXQgcGFydE51bWJlciA9IDE7XG4gIGxldCBzdGFydEJ5dGUgPSAwO1xuICBsZXQgZW5kQnl0ZSA9IHBhcnRTaXplO1xuXG4gIHdoaWxlIChlbmRCeXRlIDwgZGF0YS5ieXRlTGVuZ3RoKSB7XG4gICAgeWllbGQge1xuICAgICAgcGFydE51bWJlcixcbiAgICAgIGRhdGE6IGRhdGEuc2xpY2Uoc3RhcnRCeXRlLCBlbmRCeXRlKSxcbiAgICB9O1xuICAgIHBhcnROdW1iZXIgKz0gMTtcbiAgICBzdGFydEJ5dGUgPSBlbmRCeXRlO1xuICAgIGVuZEJ5dGUgPSBzdGFydEJ5dGUgKyBwYXJ0U2l6ZTtcbiAgfVxuXG4gIHlpZWxkIHtcbiAgICBwYXJ0TnVtYmVyLFxuICAgIGRhdGE6IGRhdGEuc2xpY2Uoc3RhcnRCeXRlKSxcbiAgICBsYXN0UGFydDogdHJ1ZSxcbiAgfTtcbn1cbiJdfQ==
@@ -0,0 +1,69 @@
1
+ import { __asyncGenerator, __asyncValues, __await, __generator } from "tslib";
2
+ import { Buffer } from "buffer";
3
+ export function getChunkStream(data, partSize, getNextData) {
4
+ return __asyncGenerator(this, arguments, function getChunkStream_1() {
5
+ var partNumber, currentBuffer, _a, _b, datum, dataChunk, e_1_1;
6
+ var e_1, _c;
7
+ return __generator(this, function (_d) {
8
+ switch (_d.label) {
9
+ case 0:
10
+ partNumber = 1;
11
+ currentBuffer = { chunks: [], length: 0 };
12
+ _d.label = 1;
13
+ case 1:
14
+ _d.trys.push([1, 9, 10, 15]);
15
+ _a = __asyncValues(getNextData(data));
16
+ _d.label = 2;
17
+ case 2: return [4, __await(_a.next())];
18
+ case 3:
19
+ if (!(_b = _d.sent(), !_b.done)) return [3, 8];
20
+ datum = _b.value;
21
+ currentBuffer.chunks.push(datum);
22
+ currentBuffer.length += datum.length;
23
+ _d.label = 4;
24
+ case 4:
25
+ if (!(currentBuffer.length >= partSize)) return [3, 7];
26
+ dataChunk = currentBuffer.chunks.length > 1 ? Buffer.concat(currentBuffer.chunks) : currentBuffer.chunks[0];
27
+ return [4, __await({
28
+ partNumber: partNumber,
29
+ data: dataChunk.slice(0, partSize),
30
+ })];
31
+ case 5: return [4, _d.sent()];
32
+ case 6:
33
+ _d.sent();
34
+ currentBuffer.chunks = [dataChunk.slice(partSize)];
35
+ currentBuffer.length = currentBuffer.chunks[0].length;
36
+ partNumber += 1;
37
+ return [3, 4];
38
+ case 7: return [3, 2];
39
+ case 8: return [3, 15];
40
+ case 9:
41
+ e_1_1 = _d.sent();
42
+ e_1 = { error: e_1_1 };
43
+ return [3, 15];
44
+ case 10:
45
+ _d.trys.push([10, , 13, 14]);
46
+ if (!(_b && !_b.done && (_c = _a.return))) return [3, 12];
47
+ return [4, __await(_c.call(_a))];
48
+ case 11:
49
+ _d.sent();
50
+ _d.label = 12;
51
+ case 12: return [3, 14];
52
+ case 13:
53
+ if (e_1) throw e_1.error;
54
+ return [7];
55
+ case 14: return [7];
56
+ case 15: return [4, __await({
57
+ partNumber: partNumber,
58
+ data: Buffer.concat(currentBuffer.chunks),
59
+ lastPart: true,
60
+ })];
61
+ case 16: return [4, _d.sent()];
62
+ case 17:
63
+ _d.sent();
64
+ return [2];
65
+ }
66
+ });
67
+ });
68
+ }
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0Q2h1bmtTdHJlYW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY2h1bmtzL2dldENodW5rU3RyZWFtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFDQSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBT2hDLE1BQU0sVUFBaUIsY0FBYyxDQUNuQyxJQUFPLEVBQ1AsUUFBZ0IsRUFDaEIsV0FBZ0Q7Ozs7Ozs7b0JBRTVDLFVBQVUsR0FBRyxDQUFDLENBQUM7b0JBQ2IsYUFBYSxHQUFZLEVBQUUsTUFBTSxFQUFFLEVBQUUsRUFBRSxNQUFNLEVBQUUsQ0FBQyxFQUFFLENBQUM7Ozs7b0JBRS9CLEtBQUEsY0FBQSxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUE7Ozs7O29CQUExQixLQUFLLFdBQUEsQ0FBQTtvQkFDcEIsYUFBYSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7b0JBQ2pDLGFBQWEsQ0FBQyxNQUFNLElBQUksS0FBSyxDQUFDLE1BQU0sQ0FBQzs7O3lCQUU5QixDQUFBLGFBQWEsQ0FBQyxNQUFNLElBQUksUUFBUSxDQUFBO29CQUsvQixTQUFTLEdBQUcsYUFBYSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQzt1Q0FFNUc7NEJBQ0osVUFBVSxZQUFBOzRCQUNWLElBQUksRUFBRSxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxRQUFRLENBQUM7eUJBQ25DO3dCQUhELHNCQUdDOztvQkFIRCxTQUdDLENBQUM7b0JBR0YsYUFBYSxDQUFDLE1BQU0sR0FBRyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztvQkFDbkQsYUFBYSxDQUFDLE1BQU0sR0FBRyxhQUFhLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQztvQkFDdEQsVUFBVSxJQUFJLENBQUMsQ0FBQzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7NENBR2Q7d0JBQ0osVUFBVSxZQUFBO3dCQUNWLElBQUksRUFBRSxNQUFNLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUM7d0JBQ3pDLFFBQVEsRUFBRSxJQUFJO3FCQUNmO3lCQUpELHNCQUlDOztvQkFKRCxTQUlDLENBQUM7Ozs7O0NBQ0giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSYXdEYXRhUGFydCB9IGZyb20gXCIuLi9VcGxvYWRcIjtcbmltcG9ydCB7IEJ1ZmZlciB9IGZyb20gXCJidWZmZXJcIjtcblxuaW50ZXJmYWNlIEJ1ZmZlcnMge1xuICBjaHVua3M6IEJ1ZmZlcltdO1xuICBsZW5ndGg6IG51bWJlcjtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uKiBnZXRDaHVua1N0cmVhbTxUPihcbiAgZGF0YTogVCxcbiAgcGFydFNpemU6IG51bWJlcixcbiAgZ2V0TmV4dERhdGE6IChkYXRhOiBUKSA9PiBBc3luY0dlbmVyYXRvcjxCdWZmZXI+XG4pOiBBc3luY0dlbmVyYXRvcjxSYXdEYXRhUGFydCwgdm9pZCwgdW5kZWZpbmVkPiB7XG4gIGxldCBwYXJ0TnVtYmVyID0gMTtcbiAgY29uc3QgY3VycmVudEJ1ZmZlcjogQnVmZmVycyA9IHsgY2h1bmtzOiBbXSwgbGVuZ3RoOiAwIH07XG5cbiAgZm9yIGF3YWl0IChjb25zdCBkYXR1bSBvZiBnZXROZXh0RGF0YShkYXRhKSkge1xuICAgIGN1cnJlbnRCdWZmZXIuY2h1bmtzLnB1c2goZGF0dW0pO1xuICAgIGN1cnJlbnRCdWZmZXIubGVuZ3RoICs9IGRhdHVtLmxlbmd0aDtcblxuICAgIHdoaWxlIChjdXJyZW50QnVmZmVyLmxlbmd0aCA+PSBwYXJ0U2l6ZSkge1xuICAgICAgLyoqXG4gICAgICAgKiBDb25jYXQgYWxsIHRoZSBidWZmZXJzIHRvZ2V0aGVyIG9uY2UgaWYgdGhlcmUgaXMgbW9yZSB0aGFuIG9uZSB0byBjb25jYXQuIEF0dGVtcHRcbiAgICAgICAqIHRvIG1pbmltaXplIGNvbmNhdHMgYXMgQnVmZmVyLkNvbmNhdCBpcyBhbiBleHRyZW1lbHkgZXhwZW5zaXZlIG9wZXJhdGlvbi5cbiAgICAgICAqL1xuICAgICAgY29uc3QgZGF0YUNodW5rID0gY3VycmVudEJ1ZmZlci5jaHVua3MubGVuZ3RoID4gMSA/IEJ1ZmZlci5jb25jYXQoY3VycmVudEJ1ZmZlci5jaHVua3MpIDogY3VycmVudEJ1ZmZlci5jaHVua3NbMF07XG5cbiAgICAgIHlpZWxkIHtcbiAgICAgICAgcGFydE51bWJlcixcbiAgICAgICAgZGF0YTogZGF0YUNodW5rLnNsaWNlKDAsIHBhcnRTaXplKSxcbiAgICAgIH07XG5cbiAgICAgIC8vIFJlc2V0IHRoZSBidWZmZXIuXG4gICAgICBjdXJyZW50QnVmZmVyLmNodW5rcyA9IFtkYXRhQ2h1bmsuc2xpY2UocGFydFNpemUpXTtcbiAgICAgIGN1cnJlbnRCdWZmZXIubGVuZ3RoID0gY3VycmVudEJ1ZmZlci5jaHVua3NbMF0ubGVuZ3RoO1xuICAgICAgcGFydE51bWJlciArPSAxO1xuICAgIH1cbiAgfVxuICB5aWVsZCB7XG4gICAgcGFydE51bWJlcixcbiAgICBkYXRhOiBCdWZmZXIuY29uY2F0KGN1cnJlbnRCdWZmZXIuY2h1bmtzKSxcbiAgICBsYXN0UGFydDogdHJ1ZSxcbiAgfTtcbn1cbiJdfQ==
@@ -0,0 +1,45 @@
1
+ import { __asyncGenerator, __asyncValues, __await, __generator } from "tslib";
2
+ import { Buffer } from "buffer";
3
+ export function getDataReadable(data) {
4
+ return __asyncGenerator(this, arguments, function getDataReadable_1() {
5
+ var data_1, data_1_1, chunk, e_1_1;
6
+ var e_1, _a;
7
+ return __generator(this, function (_b) {
8
+ switch (_b.label) {
9
+ case 0:
10
+ _b.trys.push([0, 7, 8, 13]);
11
+ data_1 = __asyncValues(data);
12
+ _b.label = 1;
13
+ case 1: return [4, __await(data_1.next())];
14
+ case 2:
15
+ if (!(data_1_1 = _b.sent(), !data_1_1.done)) return [3, 6];
16
+ chunk = data_1_1.value;
17
+ return [4, __await(Buffer.from(chunk))];
18
+ case 3: return [4, _b.sent()];
19
+ case 4:
20
+ _b.sent();
21
+ _b.label = 5;
22
+ case 5: return [3, 1];
23
+ case 6: return [3, 13];
24
+ case 7:
25
+ e_1_1 = _b.sent();
26
+ e_1 = { error: e_1_1 };
27
+ return [3, 13];
28
+ case 8:
29
+ _b.trys.push([8, , 11, 12]);
30
+ if (!(data_1_1 && !data_1_1.done && (_a = data_1.return))) return [3, 10];
31
+ return [4, __await(_a.call(data_1))];
32
+ case 9:
33
+ _b.sent();
34
+ _b.label = 10;
35
+ case 10: return [3, 12];
36
+ case 11:
37
+ if (e_1) throw e_1.error;
38
+ return [7];
39
+ case 12: return [7];
40
+ case 13: return [2];
41
+ }
42
+ });
43
+ });
44
+ }
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0RGF0YVJlYWRhYmxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NodW5rcy9nZXREYXRhUmVhZGFibGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUNBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFFaEMsTUFBTSxVQUFpQixlQUFlLENBQUMsSUFBYzs7Ozs7Ozs7b0JBQ3pCLFNBQUEsY0FBQSxJQUFJLENBQUE7Ozs7O29CQUFiLEtBQUssaUJBQUEsQ0FBQTt1Q0FDZCxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQzt3QkFBeEIsc0JBQXdCOztvQkFBeEIsU0FBd0IsQ0FBQzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0NBRTVCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUmVhZGFibGUgfSBmcm9tIFwic3RyZWFtXCI7XG5pbXBvcnQgeyBCdWZmZXIgfSBmcm9tIFwiYnVmZmVyXCI7XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiogZ2V0RGF0YVJlYWRhYmxlKGRhdGE6IFJlYWRhYmxlKTogQXN5bmNHZW5lcmF0b3I8QnVmZmVyPiB7XG4gIGZvciBhd2FpdCAoY29uc3QgY2h1bmsgb2YgZGF0YSkge1xuICAgIHlpZWxkIEJ1ZmZlci5mcm9tKGNodW5rKTtcbiAgfVxufVxuIl19
@@ -0,0 +1,39 @@
1
+ import { __asyncGenerator, __await, __generator } from "tslib";
2
+ import { Buffer } from "buffer";
3
+ export function getDataReadableStream(data) {
4
+ return __asyncGenerator(this, arguments, function getDataReadableStream_1() {
5
+ var reader, _a, done, value, e_1;
6
+ return __generator(this, function (_b) {
7
+ switch (_b.label) {
8
+ case 0:
9
+ reader = data.getReader();
10
+ _b.label = 1;
11
+ case 1:
12
+ _b.trys.push([1, 9, 10, 11]);
13
+ _b.label = 2;
14
+ case 2:
15
+ if (!true) return [3, 8];
16
+ return [4, __await(reader.read())];
17
+ case 3:
18
+ _a = _b.sent(), done = _a.done, value = _a.value;
19
+ if (!done) return [3, 5];
20
+ return [4, __await(void 0)];
21
+ case 4: return [2, _b.sent()];
22
+ case 5: return [4, __await(Buffer.from(value))];
23
+ case 6: return [4, _b.sent()];
24
+ case 7:
25
+ _b.sent();
26
+ return [3, 2];
27
+ case 8: return [3, 11];
28
+ case 9:
29
+ e_1 = _b.sent();
30
+ throw e_1;
31
+ case 10:
32
+ reader.releaseLock();
33
+ return [7];
34
+ case 11: return [2];
35
+ }
36
+ });
37
+ });
38
+ }
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0RGF0YVJlYWRhYmxlU3RyZWFtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NodW5rcy9nZXREYXRhUmVhZGFibGVTdHJlYW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFFaEMsTUFBTSxVQUFpQixxQkFBcUIsQ0FBQyxJQUFvQjs7Ozs7O29CQUV6RCxNQUFNLEdBQUcsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDOzs7Ozs7eUJBR3ZCLElBQUk7b0JBRWUsbUJBQU0sTUFBTSxDQUFDLElBQUksRUFBRSxHQUFBOztvQkFBckMsS0FBa0IsU0FBbUIsRUFBbkMsSUFBSSxVQUFBLEVBQUUsS0FBSyxXQUFBO3lCQUVmLElBQUksRUFBSixjQUFJOzt3QkFBRSxzQkFBTzsyQ0FFWCxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQzt3QkFBeEIsc0JBQXdCOztvQkFBeEIsU0FBd0IsQ0FBQzs7Ozs7b0JBRzNCLE1BQU0sR0FBQyxDQUFDOztvQkFHUixNQUFNLENBQUMsV0FBVyxFQUFFLENBQUM7Ozs7OztDQUV4QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJ1ZmZlciB9IGZyb20gXCJidWZmZXJcIjtcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uKiBnZXREYXRhUmVhZGFibGVTdHJlYW0oZGF0YTogUmVhZGFibGVTdHJlYW0pOiBBc3luY0dlbmVyYXRvcjxCdWZmZXI+IHtcbiAgLy8gR2V0IGEgbG9jayBvbiB0aGUgc3RyZWFtLlxuICBjb25zdCByZWFkZXIgPSBkYXRhLmdldFJlYWRlcigpO1xuXG4gIHRyeSB7XG4gICAgd2hpbGUgKHRydWUpIHtcbiAgICAgIC8vIFJlYWQgZnJvbSB0aGUgc3RyZWFtLlxuICAgICAgY29uc3QgeyBkb25lLCB2YWx1ZSB9ID0gYXdhaXQgcmVhZGVyLnJlYWQoKTtcbiAgICAgIC8vIEV4aXQgaWYgd2UncmUgZG9uZS5cbiAgICAgIGlmIChkb25lKSByZXR1cm47XG4gICAgICAvLyBFbHNlIHlpZWxkIHRoZSBjaHVuay5cbiAgICAgIHlpZWxkIEJ1ZmZlci5mcm9tKHZhbHVlKTtcbiAgICB9XG4gIH0gY2F0Y2ggKGUpIHtcbiAgICB0aHJvdyBlO1xuICB9IGZpbmFsbHkge1xuICAgIC8vIHJlbGVhc2UgdGhlIGxvY2sgZm9yIHJlYWRpbmcgZnJvbSB0aGlzIHN0cmVhbS5cbiAgICByZWFkZXIucmVsZWFzZUxvY2soKTtcbiAgfVxufVxuIl19
@@ -0,0 +1,3 @@
1
+ export * from "./Upload";
2
+ export * from "./types";
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9VcGxvYWRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3R5cGVzXCI7XG4iXX0=
@@ -0,0 +1,4 @@
1
+ import { __assign } from "tslib";
2
+ import { ClientSharedValues } from "./runtimeConfig.shared";
3
+ export var ClientDefaultValues = __assign(__assign({}, ClientSharedValues), { runtime: "browser" });
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVudGltZUNvbmZpZy5icm93c2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3J1bnRpbWVDb25maWcuYnJvd3Nlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFLNUQsTUFBTSxDQUFDLElBQU0sbUJBQW1CLHlCQUMzQixrQkFBa0IsS0FDckIsT0FBTyxFQUFFLFNBQVMsR0FDbkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENsaWVudFNoYXJlZFZhbHVlcyB9IGZyb20gXCIuL3J1bnRpbWVDb25maWcuc2hhcmVkXCI7XG5cbi8qKlxuICogQGludGVybmFsXG4gKi9cbmV4cG9ydCBjb25zdCBDbGllbnREZWZhdWx0VmFsdWVzID0ge1xuICAuLi5DbGllbnRTaGFyZWRWYWx1ZXMsXG4gIHJ1bnRpbWU6IFwiYnJvd3NlclwiLFxufTtcbiJdfQ==
@@ -0,0 +1,5 @@
1
+ import { __assign } from "tslib";
2
+ import { ClientSharedValues } from "./runtimeConfig.shared";
3
+ import { lstatSync } from "fs";
4
+ export var ClientDefaultValues = __assign(__assign({}, ClientSharedValues), { runtime: "node", lstatSync: lstatSync });
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVudGltZUNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9ydW50aW1lQ29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUM1RCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sSUFBSSxDQUFDO0FBSy9CLE1BQU0sQ0FBQyxJQUFNLG1CQUFtQix5QkFDM0Isa0JBQWtCLEtBQ3JCLE9BQU8sRUFBRSxNQUFNLEVBQ2YsU0FBUyxXQUFBLEdBQ1YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENsaWVudFNoYXJlZFZhbHVlcyB9IGZyb20gXCIuL3J1bnRpbWVDb25maWcuc2hhcmVkXCI7XG5pbXBvcnQgeyBsc3RhdFN5bmMgfSBmcm9tIFwiZnNcIjtcblxuLyoqXG4gKiBAaW50ZXJuYWxcbiAqL1xuZXhwb3J0IGNvbnN0IENsaWVudERlZmF1bHRWYWx1ZXMgPSB7XG4gIC4uLkNsaWVudFNoYXJlZFZhbHVlcyxcbiAgcnVudGltZTogXCJub2RlXCIsXG4gIGxzdGF0U3luYyxcbn07XG4iXX0=
@@ -0,0 +1,4 @@
1
+ import { __assign } from "tslib";
2
+ import { ClientDefaultValues as BrowserDefaults } from "./runtimeConfig.browser";
3
+ export var ClientDefaultValues = __assign(__assign({}, BrowserDefaults), { runtime: "react-native" });
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVudGltZUNvbmZpZy5uYXRpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvcnVudGltZUNvbmZpZy5uYXRpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxtQkFBbUIsSUFBSSxlQUFlLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUtqRixNQUFNLENBQUMsSUFBTSxtQkFBbUIseUJBQzNCLGVBQWUsS0FDbEIsT0FBTyxFQUFFLGNBQWMsR0FDeEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENsaWVudERlZmF1bHRWYWx1ZXMgYXMgQnJvd3NlckRlZmF1bHRzIH0gZnJvbSBcIi4vcnVudGltZUNvbmZpZy5icm93c2VyXCI7XG5cbi8qKlxuICogQGludGVybmFsXG4gKi9cbmV4cG9ydCBjb25zdCBDbGllbnREZWZhdWx0VmFsdWVzID0ge1xuICAuLi5Ccm93c2VyRGVmYXVsdHMsXG4gIHJ1bnRpbWU6IFwicmVhY3QtbmF0aXZlXCIsXG59O1xuIl19
@@ -0,0 +1,4 @@
1
+ export var ClientSharedValues = {
2
+ lstatSync: function () { },
3
+ };
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVudGltZUNvbmZpZy5zaGFyZWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvcnVudGltZUNvbmZpZy5zaGFyZWQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsTUFBTSxDQUFDLElBQU0sa0JBQWtCLEdBQUc7SUFDaEMsU0FBUyxFQUFFLGNBQU8sQ0FBQztDQUNwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAaW50ZXJuYWxcbiAqL1xuZXhwb3J0IGNvbnN0IENsaWVudFNoYXJlZFZhbHVlcyA9IHtcbiAgbHN0YXRTeW5jOiAoKSA9PiB7fSxcbn07XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFB1dE9iamVjdENvbW1hbmRJbnB1dCwgUzNDbGllbnQsIFRhZyB9IGZyb20gXCJAYXdzLXNkay9jbGllbnQtczNcIjtcblxuZXhwb3J0IGludGVyZmFjZSBQcm9ncmVzcyB7XG4gIGxvYWRlZD86IG51bWJlcjtcbiAgdG90YWw/OiBudW1iZXI7XG4gIHBhcnQ/OiBudW1iZXI7XG4gIEtleT86IHN0cmluZztcbiAgQnVja2V0Pzogc3RyaW5nO1xufVxuXG4vLyBzdHJpbmcgfCBVaW50OEFycmF5IHwgQnVmZmVyIHwgUmVhZGFibGUgfCBSZWFkYWJsZVN0cmVhbSB8IEJsb2IuXG5leHBvcnQgdHlwZSBCb2R5RGF0YVR5cGVzID0gUHV0T2JqZWN0Q29tbWFuZElucHV0W1wiQm9keVwiXTtcblxuZXhwb3J0IHR5cGUgU2VydmljZUNsaWVudHMgPSBTM0NsaWVudDtcblxuZXhwb3J0IGludGVyZmFjZSBDb25maWd1cmF0aW9uIHtcbiAgLyoqXG4gICAqIFRoZSBzaXplIG9mIHRoZSBjb25jdXJyZW50IHF1ZXVlIG1hbmFnZXIgdG8gdXBsb2FkIHBhcnRzIGluIHBhcmFsbGVsLiBTZXQgdG8gMSBmb3Igc3luY2hyb25vdXMgdXBsb2FkaW5nIG9mIHBhcnRzLiBOb3RlIHRoYXQgdGhlIHVwbG9hZGVyIHdpbGwgYnVmZmVyIGF0IG1vc3QgcXVldWVTaXplICogcGFydFNpemUgYnl0ZXMgaW50byBtZW1vcnkgYXQgYW55IGdpdmVuIHRpbWUuXG4gICAqIGRlZmF1bHQ6IDRcbiAgICovXG4gIHF1ZXVlU2l6ZTogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBEZWZhdWx0OiA1IG1iXG4gICAqIFRoZSBzaXplIGluIGJ5dGVzIGZvciBlYWNoIGluZGl2aWR1YWwgcGFydCB0byBiZSB1cGxvYWRlZC4gQWRqdXN0IHRoZSBwYXJ0IHNpemUgdG8gZW5zdXJlIHRoZSBudW1iZXIgb2YgcGFydHMgZG9lcyBub3QgZXhjZWVkIG1heFRvdGFsUGFydHMuIFNlZSA1bWIgaXMgdGhlIG1pbmltdW0gYWxsb3dlZCBwYXJ0IHNpemUuXG4gICAqL1xuICBwYXJ0U2l6ZTogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBEZWZhdWx0OiBmYWxzZVxuICAgKiBXaGV0aGVyIHRvIGFib3J0IHRoZSBtdWx0aXBhcnQgdXBsb2FkIGlmIGFuIGVycm9yIG9jY3Vycy4gU2V0IHRvIHRydWUgaWYgeW91IHdhbnQgdG8gaGFuZGxlIGZhaWx1cmVzIG1hbnVhbGx5LiBJZiBzZXQgdG8gZmFsc2UgKGRlZmF1bHQpXG4gICAqIHRoZSB1cGxvYWQgd2lsbCBkcm9wIHBhcnRzIHRoYXQgaGF2ZSBmYWlsZWQuXG4gICAqL1xuICBsZWF2ZVBhcnRzT25FcnJvcjogYm9vbGVhbjtcblxuICAvKipcbiAgICogVGhlIHRhZ3MgdG8gYXBwbHkgdG8gdGhlIG9iamVjdC5cbiAgICovXG4gIHRhZ3M6IFRhZ1tdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE9wdGlvbnMgZXh0ZW5kcyBQYXJ0aWFsPENvbmZpZ3VyYXRpb24+IHtcbiAgLyoqXG4gICAqIFRoaXMgaXMgdGhlIGRhdGEgdGhhdCBpcyB1cGxvYWRlZC5cbiAgICovXG4gIHBhcmFtczogUHV0T2JqZWN0Q29tbWFuZElucHV0O1xuXG4gIC8qKlxuICAgKiBBIHNlcnZpY2UgY2xpZW50LlxuICAgKiBUaGlzIHRoZSB0YXJnZXQgd2hlcmUgd2UgdXBsb2FkIGRhdGEuXG4gICAqL1xuICBjbGllbnQ6IFNlcnZpY2VDbGllbnRzO1xufVxuIl19
File without changes
File without changes
File without changes
File without changes
File without changes