@eluvio/elv-client-js 3.2.1 → 3.2.5
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/dist/ElvClient-min.js +15 -11
- package/dist/ElvClient-node-min.js +17 -13
- package/dist/ElvFrameClient-min.js +12 -8
- package/dist/ElvPermissionsClient-min.js +13 -9
- package/dist/ElvWalletClient-min.js +58 -0
- package/dist/ElvWalletClient-node-min.js +78 -0
- package/dist/src/AuthorizationClient.js +2248 -1990
- package/dist/src/ContentObjectVerification.js +164 -173
- package/dist/src/Crypto.js +376 -324
- package/dist/src/ElvClient.js +1182 -1019
- package/dist/src/ElvWallet.js +119 -95
- package/dist/src/EthClient.js +1040 -896
- package/dist/src/FrameClient.js +331 -300
- package/dist/src/HttpClient.js +153 -147
- package/dist/src/Id.js +1 -3
- package/dist/src/PermissionsClient.js +1294 -1168
- package/dist/src/RemoteSigner.js +263 -211
- package/dist/src/UserProfileClient.js +1164 -1023
- package/dist/src/Utils.js +209 -181
- package/dist/src/client/ABRPublishing.js +895 -858
- package/dist/src/client/AccessGroups.js +1102 -959
- package/dist/src/client/ContentAccess.js +3724 -3431
- package/dist/src/client/ContentManagement.js +2252 -2068
- package/dist/src/client/Contracts.js +647 -563
- package/dist/src/client/Files.js +1886 -1757
- package/dist/src/client/NFT.js +126 -112
- package/dist/src/client/NTP.js +478 -422
- package/dist/src/walletClient/ClientMethods.js +1029 -879
- package/dist/src/walletClient/Utils.js +84 -70
- package/dist/src/walletClient/index.js +1200 -1088
- package/package.json +4 -2
- package/src/Utils.js +0 -1
- package/src/walletClient/ClientMethods.js +37 -5
- package/utilities/ProductionMasterCreate.js +2 -2
package/dist/src/client/Files.js
CHANGED
|
@@ -2,9 +2,11 @@ var _defineProperty = require("@babel/runtime/helpers/defineProperty");
|
|
|
2
2
|
|
|
3
3
|
var _regeneratorRuntime = require("@babel/runtime/regenerator");
|
|
4
4
|
|
|
5
|
-
|
|
5
|
+
var _asyncToGenerator = require("@babel/runtime/helpers/asyncToGenerator");
|
|
6
6
|
|
|
7
|
-
function
|
|
7
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
8
|
+
|
|
9
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
8
10
|
|
|
9
11
|
/**
|
|
10
12
|
* Methods for accessing and managing access groups
|
|
@@ -43,51 +45,57 @@ var _require = require("../Validation"),
|
|
|
43
45
|
*/
|
|
44
46
|
|
|
45
47
|
|
|
46
|
-
exports.ListFiles = function
|
|
47
|
-
var
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
if (versionHash) {
|
|
60
|
-
objectId = this.utils.DecodeVersionHash(versionHash).objectId;
|
|
61
|
-
}
|
|
48
|
+
exports.ListFiles = /*#__PURE__*/function () {
|
|
49
|
+
var _ref2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(_ref) {
|
|
50
|
+
var libraryId, objectId, versionHash, path;
|
|
51
|
+
return _regeneratorRuntime.wrap(function _callee$(_context) {
|
|
52
|
+
while (1) {
|
|
53
|
+
switch (_context.prev = _context.next) {
|
|
54
|
+
case 0:
|
|
55
|
+
libraryId = _ref.libraryId, objectId = _ref.objectId, versionHash = _ref.versionHash;
|
|
56
|
+
ValidateParameters({
|
|
57
|
+
libraryId: libraryId,
|
|
58
|
+
objectId: objectId,
|
|
59
|
+
versionHash: versionHash
|
|
60
|
+
});
|
|
62
61
|
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
62
|
+
if (versionHash) {
|
|
63
|
+
objectId = this.utils.DecodeVersionHash(versionHash).objectId;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
path = UrlJoin("q", versionHash || objectId, "meta", "files");
|
|
67
|
+
_context.t0 = this.utils;
|
|
68
|
+
_context.t1 = this.HttpClient;
|
|
69
|
+
_context.next = 8;
|
|
70
|
+
return this.authClient.AuthorizationHeader({
|
|
71
|
+
libraryId: libraryId,
|
|
72
|
+
objectId: objectId,
|
|
73
|
+
versionHash: versionHash
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
case 8:
|
|
77
|
+
_context.t2 = _context.sent;
|
|
78
|
+
_context.t3 = path;
|
|
79
|
+
_context.t4 = {
|
|
80
|
+
headers: _context.t2,
|
|
81
|
+
method: "GET",
|
|
82
|
+
path: _context.t3
|
|
83
|
+
};
|
|
84
|
+
_context.t5 = _context.t1.Request.call(_context.t1, _context.t4);
|
|
85
|
+
return _context.abrupt("return", _context.t0.ResponseToJson.call(_context.t0, _context.t5));
|
|
86
|
+
|
|
87
|
+
case 13:
|
|
88
|
+
case "end":
|
|
89
|
+
return _context.stop();
|
|
90
|
+
}
|
|
87
91
|
}
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
|
|
92
|
+
}, _callee, this);
|
|
93
|
+
}));
|
|
94
|
+
|
|
95
|
+
return function (_x) {
|
|
96
|
+
return _ref2.apply(this, arguments);
|
|
97
|
+
};
|
|
98
|
+
}();
|
|
91
99
|
/**
|
|
92
100
|
* Copy/reference files from S3 to a content object.
|
|
93
101
|
*
|
|
@@ -124,235 +132,241 @@ exports.ListFiles = function _callee(_ref) {
|
|
|
124
132
|
*/
|
|
125
133
|
|
|
126
134
|
|
|
127
|
-
exports.UploadFilesFromS3 = function
|
|
128
|
-
var
|
|
135
|
+
exports.UploadFilesFromS3 = /*#__PURE__*/function () {
|
|
136
|
+
var _ref4 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2(_ref3) {
|
|
137
|
+
var libraryId, objectId, writeToken, region, bucket, fileInfo, accessKey, secret, signedUrl, _ref3$encryption, encryption, _ref3$copy, copy, callback, s3prefixRegex, i, fileSourcePath, s3prefixMatch, bucketName, encryption_key, conk, cloudCredentials, defaults, ops, _yield$this$CreateFil, id, status, done, progress, _progress;
|
|
129
138
|
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
139
|
+
return _regeneratorRuntime.wrap(function _callee2$(_context2) {
|
|
140
|
+
while (1) {
|
|
141
|
+
switch (_context2.prev = _context2.next) {
|
|
142
|
+
case 0:
|
|
143
|
+
libraryId = _ref3.libraryId, objectId = _ref3.objectId, writeToken = _ref3.writeToken, region = _ref3.region, bucket = _ref3.bucket, fileInfo = _ref3.fileInfo, accessKey = _ref3.accessKey, secret = _ref3.secret, signedUrl = _ref3.signedUrl, _ref3$encryption = _ref3.encryption, encryption = _ref3$encryption === void 0 ? "none" : _ref3$encryption, _ref3$copy = _ref3.copy, copy = _ref3$copy === void 0 ? false : _ref3$copy, callback = _ref3.callback;
|
|
144
|
+
ValidateParameters({
|
|
145
|
+
libraryId: libraryId,
|
|
146
|
+
objectId: objectId
|
|
147
|
+
});
|
|
148
|
+
ValidateWriteToken(writeToken);
|
|
149
|
+
s3prefixRegex = /^s3:\/\/([^/]+)\//i; // for matching and extracting bucket name when full s3:// path is specified
|
|
150
|
+
// if fileInfo source paths start with s3://bucketName/, check against bucket arg passed in, and strip
|
|
142
151
|
|
|
143
|
-
|
|
152
|
+
i = 0;
|
|
144
153
|
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
154
|
+
case 5:
|
|
155
|
+
if (!(i < fileInfo.length)) {
|
|
156
|
+
_context2.next = 18;
|
|
157
|
+
break;
|
|
158
|
+
}
|
|
150
159
|
|
|
151
|
-
|
|
152
|
-
|
|
160
|
+
fileSourcePath = fileInfo[i].source;
|
|
161
|
+
s3prefixMatch = s3prefixRegex.exec(fileSourcePath);
|
|
153
162
|
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
163
|
+
if (!s3prefixMatch) {
|
|
164
|
+
_context2.next = 15;
|
|
165
|
+
break;
|
|
166
|
+
}
|
|
158
167
|
|
|
159
|
-
|
|
168
|
+
bucketName = s3prefixMatch[1];
|
|
160
169
|
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
170
|
+
if (!(bucketName !== bucket)) {
|
|
171
|
+
_context2.next = 14;
|
|
172
|
+
break;
|
|
173
|
+
}
|
|
165
174
|
|
|
166
|
-
|
|
175
|
+
throw Error("Full S3 file path \"" + fileSourcePath + "\" specified, but does not match provided bucket name '" + bucket + "'");
|
|
167
176
|
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
177
|
+
case 14:
|
|
178
|
+
// strip prefix
|
|
179
|
+
fileInfo[i].source = fileSourcePath.replace(s3prefixRegex, "");
|
|
171
180
|
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
181
|
+
case 15:
|
|
182
|
+
i++;
|
|
183
|
+
_context2.next = 5;
|
|
184
|
+
break;
|
|
176
185
|
|
|
177
|
-
|
|
178
|
-
|
|
186
|
+
case 18:
|
|
187
|
+
this.Log("Uploading files from S3: ".concat(libraryId, " ").concat(objectId, " ").concat(writeToken));
|
|
179
188
|
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
189
|
+
if (!(encryption === "cgck")) {
|
|
190
|
+
_context2.next = 25;
|
|
191
|
+
break;
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
_context2.next = 22;
|
|
195
|
+
return this.EncryptionConk({
|
|
196
|
+
libraryId: libraryId,
|
|
197
|
+
objectId: objectId,
|
|
198
|
+
writeToken: writeToken
|
|
199
|
+
});
|
|
200
|
+
|
|
201
|
+
case 22:
|
|
202
|
+
conk = _context2.sent;
|
|
203
|
+
conk = _objectSpread(_objectSpread({}, conk), {}, {
|
|
204
|
+
secret_key: ""
|
|
205
|
+
});
|
|
206
|
+
encryption_key = "kp__".concat(this.utils.B58(Buffer.from(JSON.stringify(conk))));
|
|
184
207
|
|
|
185
|
-
|
|
186
|
-
return _regeneratorRuntime.awrap(this.EncryptionConk({
|
|
187
|
-
libraryId: libraryId,
|
|
188
|
-
objectId: objectId,
|
|
189
|
-
writeToken: writeToken
|
|
190
|
-
}));
|
|
191
|
-
|
|
192
|
-
case 22:
|
|
193
|
-
conk = _context2.sent;
|
|
194
|
-
conk = _objectSpread({}, conk, {
|
|
195
|
-
secret_key: ""
|
|
196
|
-
});
|
|
197
|
-
encryption_key = "kp__".concat(this.utils.B58(Buffer.from(JSON.stringify(conk))));
|
|
198
|
-
|
|
199
|
-
case 25:
|
|
200
|
-
cloudCredentials = {
|
|
201
|
-
access_key_id: accessKey,
|
|
202
|
-
secret_access_key: secret
|
|
203
|
-
};
|
|
204
|
-
|
|
205
|
-
if (signedUrl) {
|
|
208
|
+
case 25:
|
|
206
209
|
cloudCredentials = {
|
|
207
|
-
|
|
210
|
+
access_key_id: accessKey,
|
|
211
|
+
secret_access_key: secret
|
|
208
212
|
};
|
|
209
|
-
}
|
|
210
213
|
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
protocol: "s3",
|
|
215
|
-
platform: "aws",
|
|
216
|
-
path: bucket,
|
|
217
|
-
storage_endpoint: {
|
|
218
|
-
region: region
|
|
219
|
-
},
|
|
220
|
-
cloud_credentials: cloudCredentials
|
|
221
|
-
}
|
|
222
|
-
};
|
|
223
|
-
ops = fileInfo.map(function (info) {
|
|
224
|
-
if (copy) {
|
|
225
|
-
return {
|
|
226
|
-
op: "ingest-copy",
|
|
227
|
-
path: info.path,
|
|
228
|
-
encryption: {
|
|
229
|
-
scheme: encryption === "cgck" ? "cgck" : "none"
|
|
230
|
-
},
|
|
231
|
-
ingest: {
|
|
232
|
-
type: "key",
|
|
233
|
-
path: info.source
|
|
234
|
-
}
|
|
235
|
-
};
|
|
236
|
-
} else {
|
|
237
|
-
return {
|
|
238
|
-
op: "add-reference",
|
|
239
|
-
path: info.path,
|
|
240
|
-
reference: {
|
|
241
|
-
type: "key",
|
|
242
|
-
path: info.source
|
|
243
|
-
}
|
|
214
|
+
if (signedUrl) {
|
|
215
|
+
cloudCredentials = {
|
|
216
|
+
signed_url: signedUrl
|
|
244
217
|
};
|
|
245
218
|
}
|
|
246
|
-
}); // eslint-disable-next-line no-unused-vars
|
|
247
|
-
|
|
248
|
-
_context2.next = 31;
|
|
249
|
-
return _regeneratorRuntime.awrap(this.CreateFileUploadJob({
|
|
250
|
-
libraryId: libraryId,
|
|
251
|
-
objectId: objectId,
|
|
252
|
-
writeToken: writeToken,
|
|
253
|
-
ops: ops,
|
|
254
|
-
defaults: defaults
|
|
255
|
-
}));
|
|
256
|
-
|
|
257
|
-
case 31:
|
|
258
|
-
_ref3 = _context2.sent;
|
|
259
|
-
id = _ref3.id;
|
|
260
|
-
|
|
261
|
-
case 33:
|
|
262
|
-
if (!true) {
|
|
263
|
-
_context2.next = 56;
|
|
264
|
-
break;
|
|
265
|
-
}
|
|
266
219
|
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
220
|
+
defaults = {
|
|
221
|
+
encryption_key: encryption_key,
|
|
222
|
+
access: {
|
|
223
|
+
protocol: "s3",
|
|
224
|
+
platform: "aws",
|
|
225
|
+
path: bucket,
|
|
226
|
+
storage_endpoint: {
|
|
227
|
+
region: region
|
|
228
|
+
},
|
|
229
|
+
cloud_credentials: cloudCredentials
|
|
230
|
+
}
|
|
231
|
+
};
|
|
232
|
+
ops = fileInfo.map(function (info) {
|
|
233
|
+
if (copy) {
|
|
234
|
+
return {
|
|
235
|
+
op: "ingest-copy",
|
|
236
|
+
path: info.path,
|
|
237
|
+
encryption: {
|
|
238
|
+
scheme: encryption === "cgck" ? "cgck" : "none"
|
|
239
|
+
},
|
|
240
|
+
ingest: {
|
|
241
|
+
type: "key",
|
|
242
|
+
path: info.source
|
|
243
|
+
}
|
|
244
|
+
};
|
|
245
|
+
} else {
|
|
246
|
+
return {
|
|
247
|
+
op: "add-reference",
|
|
248
|
+
path: info.path,
|
|
249
|
+
reference: {
|
|
250
|
+
type: "key",
|
|
251
|
+
path: info.source
|
|
252
|
+
}
|
|
253
|
+
};
|
|
254
|
+
}
|
|
255
|
+
}); // eslint-disable-next-line no-unused-vars
|
|
256
|
+
|
|
257
|
+
_context2.next = 31;
|
|
258
|
+
return this.CreateFileUploadJob({
|
|
259
|
+
libraryId: libraryId,
|
|
260
|
+
objectId: objectId,
|
|
261
|
+
writeToken: writeToken,
|
|
262
|
+
ops: ops,
|
|
263
|
+
defaults: defaults
|
|
264
|
+
});
|
|
288
265
|
|
|
289
|
-
|
|
266
|
+
case 31:
|
|
267
|
+
_yield$this$CreateFil = _context2.sent;
|
|
268
|
+
id = _yield$this$CreateFil.id;
|
|
290
269
|
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
270
|
+
case 33:
|
|
271
|
+
if (!true) {
|
|
272
|
+
_context2.next = 56;
|
|
273
|
+
break;
|
|
274
|
+
}
|
|
296
275
|
|
|
297
|
-
|
|
298
|
-
|
|
276
|
+
_context2.next = 36;
|
|
277
|
+
return new Promise(function (resolve) {
|
|
278
|
+
return setTimeout(resolve, 1000);
|
|
279
|
+
});
|
|
299
280
|
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
281
|
+
case 36:
|
|
282
|
+
_context2.next = 38;
|
|
283
|
+
return this.UploadStatus({
|
|
284
|
+
libraryId: libraryId,
|
|
285
|
+
objectId: objectId,
|
|
286
|
+
writeToken: writeToken,
|
|
287
|
+
uploadId: id
|
|
288
|
+
});
|
|
305
289
|
|
|
306
|
-
|
|
290
|
+
case 38:
|
|
291
|
+
status = _context2.sent;
|
|
307
292
|
|
|
308
|
-
|
|
309
|
-
|
|
293
|
+
if (!(status.errors && status.errors.length > 1)) {
|
|
294
|
+
_context2.next = 43;
|
|
295
|
+
break;
|
|
296
|
+
}
|
|
310
297
|
|
|
311
|
-
|
|
312
|
-
done = status.ingest_copy.done;
|
|
298
|
+
throw status.errors.join("\n");
|
|
313
299
|
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
uploaded: progress.bytes.completed,
|
|
319
|
-
total: progress.bytes.total,
|
|
320
|
-
uploadedFiles: progress.files.completed,
|
|
321
|
-
totalFiles: progress.files.total,
|
|
322
|
-
fileStatus: progress.files.details
|
|
323
|
-
});
|
|
300
|
+
case 43:
|
|
301
|
+
if (!status.error) {
|
|
302
|
+
_context2.next = 48;
|
|
303
|
+
break;
|
|
324
304
|
}
|
|
325
|
-
} else {
|
|
326
|
-
done = status.add_reference.done;
|
|
327
305
|
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
306
|
+
this.Log("S3 file upload failed:\n".concat(JSON.stringify(status, null, 2)));
|
|
307
|
+
throw status.error;
|
|
308
|
+
|
|
309
|
+
case 48:
|
|
310
|
+
if (!(status.status.toLowerCase() === "failed")) {
|
|
311
|
+
_context2.next = 50;
|
|
312
|
+
break;
|
|
335
313
|
}
|
|
336
|
-
}
|
|
337
314
|
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
315
|
+
throw "File upload failed";
|
|
316
|
+
|
|
317
|
+
case 50:
|
|
318
|
+
done = false;
|
|
342
319
|
|
|
343
|
-
|
|
320
|
+
if (copy) {
|
|
321
|
+
done = status.ingest_copy.done;
|
|
322
|
+
|
|
323
|
+
if (callback) {
|
|
324
|
+
progress = status.ingest_copy.progress;
|
|
325
|
+
callback({
|
|
326
|
+
done: done,
|
|
327
|
+
uploaded: progress.bytes.completed,
|
|
328
|
+
total: progress.bytes.total,
|
|
329
|
+
uploadedFiles: progress.files.completed,
|
|
330
|
+
totalFiles: progress.files.total,
|
|
331
|
+
fileStatus: progress.files.details
|
|
332
|
+
});
|
|
333
|
+
}
|
|
334
|
+
} else {
|
|
335
|
+
done = status.add_reference.done;
|
|
336
|
+
|
|
337
|
+
if (callback) {
|
|
338
|
+
_progress = status.add_reference.progress;
|
|
339
|
+
callback({
|
|
340
|
+
done: done,
|
|
341
|
+
uploadedFiles: _progress.completed,
|
|
342
|
+
totalFiles: _progress.total
|
|
343
|
+
});
|
|
344
|
+
}
|
|
345
|
+
}
|
|
344
346
|
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
347
|
+
if (!done) {
|
|
348
|
+
_context2.next = 54;
|
|
349
|
+
break;
|
|
350
|
+
}
|
|
348
351
|
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
+
return _context2.abrupt("break", 56);
|
|
353
|
+
|
|
354
|
+
case 54:
|
|
355
|
+
_context2.next = 33;
|
|
356
|
+
break;
|
|
357
|
+
|
|
358
|
+
case 56:
|
|
359
|
+
case "end":
|
|
360
|
+
return _context2.stop();
|
|
361
|
+
}
|
|
352
362
|
}
|
|
353
|
-
}
|
|
354
|
-
}
|
|
355
|
-
|
|
363
|
+
}, _callee2, this);
|
|
364
|
+
}));
|
|
365
|
+
|
|
366
|
+
return function (_x2) {
|
|
367
|
+
return _ref4.apply(this, arguments);
|
|
368
|
+
};
|
|
369
|
+
}();
|
|
356
370
|
/**
|
|
357
371
|
* Upload files to a content object.
|
|
358
372
|
*
|
|
@@ -381,577 +395,627 @@ exports.UploadFilesFromS3 = function _callee2(_ref2) {
|
|
|
381
395
|
*/
|
|
382
396
|
|
|
383
397
|
|
|
384
|
-
exports.UploadFiles = function
|
|
385
|
-
var
|
|
386
|
-
|
|
387
|
-
var libraryId, objectId, writeToken, fileInfo, _ref4$encryption, encryption, callback, conk, progress, fileDataMap, i, entry, _ref5, id, jobs, bufferSize, jobSpecs, prepared, uploaded, PrepareJobs, UploadJob, rateTestJobs, rates, j, start, elapsed, size, averageRate, concurrentUploads;
|
|
398
|
+
exports.UploadFiles = /*#__PURE__*/function () {
|
|
399
|
+
var _ref6 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee6(_ref5) {
|
|
400
|
+
var _this = this;
|
|
388
401
|
|
|
389
|
-
|
|
390
|
-
while (1) {
|
|
391
|
-
switch (_context6.prev = _context6.next) {
|
|
392
|
-
case 0:
|
|
393
|
-
libraryId = _ref4.libraryId, objectId = _ref4.objectId, writeToken = _ref4.writeToken, fileInfo = _ref4.fileInfo, _ref4$encryption = _ref4.encryption, encryption = _ref4$encryption === void 0 ? "none" : _ref4$encryption, callback = _ref4.callback;
|
|
394
|
-
ValidateParameters({
|
|
395
|
-
libraryId: libraryId,
|
|
396
|
-
objectId: objectId
|
|
397
|
-
});
|
|
398
|
-
ValidateWriteToken(writeToken);
|
|
399
|
-
this.Log("Uploading files: ".concat(libraryId, " ").concat(objectId, " ").concat(writeToken));
|
|
402
|
+
var libraryId, objectId, writeToken, fileInfo, _ref5$encryption, encryption, callback, conk, progress, fileDataMap, i, entry, _yield$this$CreateFil2, id, jobs, bufferSize, jobSpecs, prepared, uploaded, PrepareJobs, UploadJob, rateTestJobs, rates, j, start, elapsed, size, averageRate, concurrentUploads;
|
|
400
403
|
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
writeToken
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
case 7:
|
|
414
|
-
conk = _context6.sent;
|
|
404
|
+
return _regeneratorRuntime.wrap(function _callee6$(_context6) {
|
|
405
|
+
while (1) {
|
|
406
|
+
switch (_context6.prev = _context6.next) {
|
|
407
|
+
case 0:
|
|
408
|
+
libraryId = _ref5.libraryId, objectId = _ref5.objectId, writeToken = _ref5.writeToken, fileInfo = _ref5.fileInfo, _ref5$encryption = _ref5.encryption, encryption = _ref5$encryption === void 0 ? "none" : _ref5$encryption, callback = _ref5.callback;
|
|
409
|
+
ValidateParameters({
|
|
410
|
+
libraryId: libraryId,
|
|
411
|
+
objectId: objectId
|
|
412
|
+
});
|
|
413
|
+
ValidateWriteToken(writeToken);
|
|
414
|
+
this.Log("Uploading files: ".concat(libraryId, " ").concat(objectId, " ").concat(writeToken));
|
|
415
415
|
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
416
|
+
if (!(encryption === "cgck")) {
|
|
417
|
+
_context6.next = 8;
|
|
418
|
+
break;
|
|
419
|
+
}
|
|
420
420
|
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
421
|
+
_context6.next = 7;
|
|
422
|
+
return this.EncryptionConk({
|
|
423
|
+
libraryId: libraryId,
|
|
424
|
+
objectId: objectId,
|
|
425
|
+
writeToken: writeToken
|
|
424
426
|
});
|
|
425
|
-
entry.path = entry.path.replace(/^\/+/, "");
|
|
426
427
|
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
scheme: "cgck"
|
|
430
|
-
};
|
|
431
|
-
}
|
|
428
|
+
case 7:
|
|
429
|
+
conk = _context6.sent;
|
|
432
430
|
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
uploaded: 0,
|
|
438
|
-
total: entry.size
|
|
439
|
-
};
|
|
440
|
-
fileInfo[i] = entry;
|
|
441
|
-
}
|
|
431
|
+
case 8:
|
|
432
|
+
// Extract file data into easily accessible hash while removing the data from the fileinfo for upload job creation
|
|
433
|
+
progress = {};
|
|
434
|
+
fileDataMap = {};
|
|
442
435
|
|
|
443
|
-
|
|
436
|
+
for (i = 0; i < fileInfo.length; i++) {
|
|
437
|
+
entry = _objectSpread(_objectSpread({}, fileInfo[i]), {}, {
|
|
438
|
+
data: undefined
|
|
439
|
+
});
|
|
440
|
+
entry.path = entry.path.replace(/^\/+/, "");
|
|
444
441
|
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
442
|
+
if (encryption === "cgck") {
|
|
443
|
+
entry.encryption = {
|
|
444
|
+
scheme: "cgck"
|
|
445
|
+
};
|
|
446
|
+
}
|
|
448
447
|
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
case 15:
|
|
459
|
-
_ref5 = _context6.sent;
|
|
460
|
-
id = _ref5.id;
|
|
461
|
-
jobs = _ref5.jobs;
|
|
462
|
-
this.Log("Upload ID: ".concat(id));
|
|
463
|
-
this.Log(jobs); // How far encryption can get ahead of upload
|
|
464
|
-
|
|
465
|
-
bufferSize = 100 * 1024 * 1024;
|
|
466
|
-
jobSpecs = [];
|
|
467
|
-
prepared = 0;
|
|
468
|
-
uploaded = 0; // Insert the data to upload into the job spec, encrypting if necessary
|
|
469
|
-
|
|
470
|
-
PrepareJobs = function PrepareJobs() {
|
|
471
|
-
var j, jobId, job, f, _fileInfo, data;
|
|
472
|
-
|
|
473
|
-
return _regeneratorRuntime.async(function PrepareJobs$(_context3) {
|
|
474
|
-
while (1) {
|
|
475
|
-
switch (_context3.prev = _context3.next) {
|
|
476
|
-
case 0:
|
|
477
|
-
j = 0;
|
|
478
|
-
|
|
479
|
-
case 1:
|
|
480
|
-
if (!(j < jobs.length)) {
|
|
481
|
-
_context3.next = 31;
|
|
482
|
-
break;
|
|
483
|
-
}
|
|
448
|
+
fileDataMap[entry.path] = fileInfo[i].data;
|
|
449
|
+
delete entry.data;
|
|
450
|
+
entry.type = "file";
|
|
451
|
+
progress[entry.path] = {
|
|
452
|
+
uploaded: 0,
|
|
453
|
+
total: entry.size
|
|
454
|
+
};
|
|
455
|
+
fileInfo[i] = entry;
|
|
456
|
+
}
|
|
484
457
|
|
|
485
|
-
|
|
486
|
-
if (!(prepared - uploaded > bufferSize)) {
|
|
487
|
-
_context3.next = 7;
|
|
488
|
-
break;
|
|
489
|
-
}
|
|
458
|
+
this.Log(fileInfo);
|
|
490
459
|
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
}));
|
|
495
|
-
|
|
496
|
-
case 5:
|
|
497
|
-
_context3.next = 2;
|
|
498
|
-
break;
|
|
499
|
-
|
|
500
|
-
case 7:
|
|
501
|
-
// Retrieve job info
|
|
502
|
-
jobId = jobs[j];
|
|
503
|
-
_context3.next = 10;
|
|
504
|
-
return _regeneratorRuntime.awrap(_this.UploadJobStatus({
|
|
505
|
-
libraryId: libraryId,
|
|
506
|
-
objectId: objectId,
|
|
507
|
-
writeToken: writeToken,
|
|
508
|
-
uploadId: id,
|
|
509
|
-
jobId: jobId
|
|
510
|
-
}));
|
|
511
|
-
|
|
512
|
-
case 10:
|
|
513
|
-
job = _context3.sent;
|
|
514
|
-
f = 0;
|
|
515
|
-
|
|
516
|
-
case 12:
|
|
517
|
-
if (!(f < job.files.length)) {
|
|
518
|
-
_context3.next = 25;
|
|
519
|
-
break;
|
|
520
|
-
}
|
|
460
|
+
if (callback) {
|
|
461
|
+
callback(progress);
|
|
462
|
+
}
|
|
521
463
|
|
|
522
|
-
|
|
523
|
-
|
|
464
|
+
_context6.next = 15;
|
|
465
|
+
return this.CreateFileUploadJob({
|
|
466
|
+
libraryId: libraryId,
|
|
467
|
+
objectId: objectId,
|
|
468
|
+
writeToken: writeToken,
|
|
469
|
+
ops: fileInfo,
|
|
470
|
+
encryption: encryption
|
|
471
|
+
});
|
|
524
472
|
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
|
|
473
|
+
case 15:
|
|
474
|
+
_yield$this$CreateFil2 = _context6.sent;
|
|
475
|
+
id = _yield$this$CreateFil2.id;
|
|
476
|
+
jobs = _yield$this$CreateFil2.jobs;
|
|
477
|
+
this.Log("Upload ID: ".concat(id));
|
|
478
|
+
this.Log(jobs); // How far encryption can get ahead of upload
|
|
479
|
+
|
|
480
|
+
bufferSize = 100 * 1024 * 1024;
|
|
481
|
+
jobSpecs = [];
|
|
482
|
+
prepared = 0;
|
|
483
|
+
uploaded = 0; // Insert the data to upload into the job spec, encrypting if necessary
|
|
484
|
+
|
|
485
|
+
PrepareJobs = /*#__PURE__*/function () {
|
|
486
|
+
var _ref7 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee3() {
|
|
487
|
+
var j, jobId, job, f, _fileInfo, data;
|
|
488
|
+
|
|
489
|
+
return _regeneratorRuntime.wrap(function _callee3$(_context3) {
|
|
490
|
+
while (1) {
|
|
491
|
+
switch (_context3.prev = _context3.next) {
|
|
492
|
+
case 0:
|
|
493
|
+
j = 0;
|
|
494
|
+
|
|
495
|
+
case 1:
|
|
496
|
+
if (!(j < jobs.length)) {
|
|
497
|
+
_context3.next = 31;
|
|
498
|
+
break;
|
|
499
|
+
}
|
|
500
|
+
|
|
501
|
+
case 2:
|
|
502
|
+
if (!(prepared - uploaded > bufferSize)) {
|
|
503
|
+
_context3.next = 7;
|
|
504
|
+
break;
|
|
505
|
+
}
|
|
506
|
+
|
|
507
|
+
_context3.next = 5;
|
|
508
|
+
return new Promise(function (resolve) {
|
|
509
|
+
return setTimeout(resolve, 500);
|
|
510
|
+
});
|
|
511
|
+
|
|
512
|
+
case 5:
|
|
513
|
+
_context3.next = 2;
|
|
514
|
+
break;
|
|
515
|
+
|
|
516
|
+
case 7:
|
|
517
|
+
// Retrieve job info
|
|
518
|
+
jobId = jobs[j];
|
|
519
|
+
_context3.next = 10;
|
|
520
|
+
return _this.UploadJobStatus({
|
|
521
|
+
libraryId: libraryId,
|
|
522
|
+
objectId: objectId,
|
|
523
|
+
writeToken: writeToken,
|
|
524
|
+
uploadId: id,
|
|
525
|
+
jobId: jobId
|
|
526
|
+
});
|
|
527
|
+
|
|
528
|
+
case 10:
|
|
529
|
+
job = _context3.sent;
|
|
530
|
+
f = 0;
|
|
531
|
+
|
|
532
|
+
case 12:
|
|
533
|
+
if (!(f < job.files.length)) {
|
|
534
|
+
_context3.next = 25;
|
|
535
|
+
break;
|
|
536
|
+
}
|
|
537
|
+
|
|
538
|
+
_fileInfo = job.files[f];
|
|
539
|
+
data = void 0;
|
|
540
|
+
|
|
541
|
+
if (typeof fileDataMap[_fileInfo.path] === "number") {
|
|
542
|
+
// File descriptor - Read data from file
|
|
543
|
+
data = Buffer.alloc(_fileInfo.len);
|
|
544
|
+
fs.readSync(fileDataMap[_fileInfo.path], data, 0, _fileInfo.len, _fileInfo.off);
|
|
545
|
+
} else {
|
|
546
|
+
// Full data - Slice requested chunk
|
|
547
|
+
data = fileDataMap[_fileInfo.path].slice(_fileInfo.off, _fileInfo.off + _fileInfo.len);
|
|
548
|
+
}
|
|
549
|
+
|
|
550
|
+
if (!(encryption === "cgck")) {
|
|
551
|
+
_context3.next = 20;
|
|
552
|
+
break;
|
|
553
|
+
}
|
|
554
|
+
|
|
555
|
+
_context3.next = 19;
|
|
556
|
+
return _this.Crypto.Encrypt(conk, data);
|
|
557
|
+
|
|
558
|
+
case 19:
|
|
559
|
+
data = _context3.sent;
|
|
560
|
+
|
|
561
|
+
case 20:
|
|
562
|
+
job.files[f].data = data;
|
|
563
|
+
prepared += _fileInfo.len;
|
|
564
|
+
|
|
565
|
+
case 22:
|
|
566
|
+
f++;
|
|
567
|
+
_context3.next = 12;
|
|
568
|
+
break;
|
|
569
|
+
|
|
570
|
+
case 25:
|
|
571
|
+
jobSpecs[j] = job; // Wait for a bit to let upload start
|
|
572
|
+
|
|
573
|
+
_context3.next = 28;
|
|
574
|
+
return new Promise(function (resolve) {
|
|
575
|
+
return setTimeout(resolve, 50);
|
|
576
|
+
});
|
|
577
|
+
|
|
578
|
+
case 28:
|
|
579
|
+
j++;
|
|
580
|
+
_context3.next = 1;
|
|
581
|
+
break;
|
|
582
|
+
|
|
583
|
+
case 31:
|
|
584
|
+
case "end":
|
|
585
|
+
return _context3.stop();
|
|
532
586
|
}
|
|
587
|
+
}
|
|
588
|
+
}, _callee3);
|
|
589
|
+
}));
|
|
533
590
|
|
|
534
|
-
|
|
535
|
-
|
|
536
|
-
|
|
591
|
+
return function PrepareJobs() {
|
|
592
|
+
return _ref7.apply(this, arguments);
|
|
593
|
+
};
|
|
594
|
+
}();
|
|
595
|
+
|
|
596
|
+
UploadJob = /*#__PURE__*/function () {
|
|
597
|
+
var _ref8 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee4(jobId, j) {
|
|
598
|
+
var jobSpec, files, f, _fileInfo2;
|
|
599
|
+
|
|
600
|
+
return _regeneratorRuntime.wrap(function _callee4$(_context4) {
|
|
601
|
+
while (1) {
|
|
602
|
+
switch (_context4.prev = _context4.next) {
|
|
603
|
+
case 0:
|
|
604
|
+
if (jobSpecs[j]) {
|
|
605
|
+
_context4.next = 5;
|
|
606
|
+
break;
|
|
607
|
+
}
|
|
608
|
+
|
|
609
|
+
_context4.next = 3;
|
|
610
|
+
return new Promise(function (resolve) {
|
|
611
|
+
return setTimeout(resolve, 500);
|
|
612
|
+
});
|
|
613
|
+
|
|
614
|
+
case 3:
|
|
615
|
+
_context4.next = 0;
|
|
616
|
+
break;
|
|
617
|
+
|
|
618
|
+
case 5:
|
|
619
|
+
jobSpec = jobSpecs[j];
|
|
620
|
+
files = jobSpec.files; // Upload each item
|
|
621
|
+
|
|
622
|
+
f = 0;
|
|
623
|
+
|
|
624
|
+
case 8:
|
|
625
|
+
if (!(f < files.length)) {
|
|
626
|
+
_context4.next = 18;
|
|
627
|
+
break;
|
|
628
|
+
}
|
|
629
|
+
|
|
630
|
+
_fileInfo2 = files[f];
|
|
631
|
+
_context4.next = 12;
|
|
632
|
+
return _this.UploadFileData({
|
|
633
|
+
libraryId: libraryId,
|
|
634
|
+
objectId: objectId,
|
|
635
|
+
writeToken: writeToken,
|
|
636
|
+
uploadId: id,
|
|
637
|
+
jobId: jobId,
|
|
638
|
+
fileData: _fileInfo2.data
|
|
639
|
+
});
|
|
640
|
+
|
|
641
|
+
case 12:
|
|
642
|
+
delete jobSpecs[j].files[f].data;
|
|
643
|
+
uploaded += _fileInfo2.len;
|
|
644
|
+
|
|
645
|
+
if (callback) {
|
|
646
|
+
progress[_fileInfo2.path] = _objectSpread(_objectSpread({}, progress[_fileInfo2.path]), {}, {
|
|
647
|
+
uploaded: progress[_fileInfo2.path].uploaded + _fileInfo2.len
|
|
648
|
+
});
|
|
649
|
+
callback(progress);
|
|
650
|
+
}
|
|
651
|
+
|
|
652
|
+
case 15:
|
|
653
|
+
f++;
|
|
654
|
+
_context4.next = 8;
|
|
655
|
+
break;
|
|
656
|
+
|
|
657
|
+
case 18:
|
|
658
|
+
case "end":
|
|
659
|
+
return _context4.stop();
|
|
537
660
|
}
|
|
661
|
+
}
|
|
662
|
+
}, _callee4);
|
|
663
|
+
}));
|
|
538
664
|
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
data = _context3.sent;
|
|
544
|
-
|
|
545
|
-
case 20:
|
|
546
|
-
job.files[f].data = data;
|
|
547
|
-
prepared += _fileInfo.len;
|
|
548
|
-
|
|
549
|
-
case 22:
|
|
550
|
-
f++;
|
|
551
|
-
_context3.next = 12;
|
|
552
|
-
break;
|
|
553
|
-
|
|
554
|
-
case 25:
|
|
555
|
-
jobSpecs[j] = job; // Wait for a bit to let upload start
|
|
556
|
-
|
|
557
|
-
_context3.next = 28;
|
|
558
|
-
return _regeneratorRuntime.awrap(new Promise(function (resolve) {
|
|
559
|
-
return setTimeout(resolve, 50);
|
|
560
|
-
}));
|
|
561
|
-
|
|
562
|
-
case 28:
|
|
563
|
-
j++;
|
|
564
|
-
_context3.next = 1;
|
|
565
|
-
break;
|
|
566
|
-
|
|
567
|
-
case 31:
|
|
568
|
-
case "end":
|
|
569
|
-
return _context3.stop();
|
|
570
|
-
}
|
|
571
|
-
}
|
|
572
|
-
});
|
|
573
|
-
};
|
|
574
|
-
|
|
575
|
-
UploadJob = function UploadJob(jobId, j) {
|
|
576
|
-
var jobSpec, files, f, _fileInfo2;
|
|
577
|
-
|
|
578
|
-
return _regeneratorRuntime.async(function UploadJob$(_context4) {
|
|
579
|
-
while (1) {
|
|
580
|
-
switch (_context4.prev = _context4.next) {
|
|
581
|
-
case 0:
|
|
582
|
-
if (jobSpecs[j]) {
|
|
583
|
-
_context4.next = 5;
|
|
584
|
-
break;
|
|
585
|
-
}
|
|
665
|
+
return function UploadJob(_x4, _x5) {
|
|
666
|
+
return _ref8.apply(this, arguments);
|
|
667
|
+
};
|
|
668
|
+
}(); // Preparing jobs is done asyncronously
|
|
586
669
|
|
|
587
|
-
_context4.next = 3;
|
|
588
|
-
return _regeneratorRuntime.awrap(new Promise(function (resolve) {
|
|
589
|
-
return setTimeout(resolve, 500);
|
|
590
|
-
}));
|
|
591
670
|
|
|
592
|
-
|
|
593
|
-
_context4.next = 0;
|
|
594
|
-
break;
|
|
671
|
+
PrepareJobs(); // Upload the first several chunks in sequence, to determine average upload rate
|
|
595
672
|
|
|
596
|
-
|
|
597
|
-
|
|
598
|
-
|
|
673
|
+
rateTestJobs = Math.min(3, jobs.length);
|
|
674
|
+
rates = [];
|
|
675
|
+
j = 0;
|
|
599
676
|
|
|
600
|
-
|
|
677
|
+
case 30:
|
|
678
|
+
if (!(j < rateTestJobs)) {
|
|
679
|
+
_context6.next = 40;
|
|
680
|
+
break;
|
|
681
|
+
}
|
|
601
682
|
|
|
602
|
-
|
|
603
|
-
|
|
604
|
-
|
|
605
|
-
|
|
606
|
-
|
|
683
|
+
start = new Date().getTime();
|
|
684
|
+
_context6.next = 34;
|
|
685
|
+
return UploadJob(jobs[j], j);
|
|
686
|
+
|
|
687
|
+
case 34:
|
|
688
|
+
elapsed = (new Date().getTime() - start) / 1000;
|
|
689
|
+
size = jobSpecs[j].files.map(function (file) {
|
|
690
|
+
return file.len;
|
|
691
|
+
}).reduce(function (length, total) {
|
|
692
|
+
return length + total;
|
|
693
|
+
}, 0);
|
|
694
|
+
rates.push(size / elapsed / (1024 * 1024));
|
|
695
|
+
|
|
696
|
+
case 37:
|
|
697
|
+
j++;
|
|
698
|
+
_context6.next = 30;
|
|
699
|
+
break;
|
|
607
700
|
|
|
608
|
-
|
|
609
|
-
|
|
610
|
-
|
|
611
|
-
|
|
612
|
-
|
|
613
|
-
|
|
614
|
-
|
|
615
|
-
|
|
616
|
-
|
|
617
|
-
|
|
618
|
-
|
|
619
|
-
|
|
620
|
-
|
|
621
|
-
|
|
622
|
-
|
|
623
|
-
|
|
624
|
-
|
|
625
|
-
|
|
626
|
-
|
|
627
|
-
|
|
701
|
+
case 40:
|
|
702
|
+
averageRate = rates.reduce(function (mbps, total) {
|
|
703
|
+
return mbps + total;
|
|
704
|
+
}, 0) / rateTestJobs; // Upload remaining jobs in parallel
|
|
705
|
+
|
|
706
|
+
concurrentUploads = Math.min(5, Math.ceil(averageRate / 2));
|
|
707
|
+
_context6.next = 44;
|
|
708
|
+
return this.utils.LimitedMap(concurrentUploads, jobs, /*#__PURE__*/function () {
|
|
709
|
+
var _ref9 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee5(jobId, j) {
|
|
710
|
+
return _regeneratorRuntime.wrap(function _callee5$(_context5) {
|
|
711
|
+
while (1) {
|
|
712
|
+
switch (_context5.prev = _context5.next) {
|
|
713
|
+
case 0:
|
|
714
|
+
if (!(j < rateTestJobs)) {
|
|
715
|
+
_context5.next = 2;
|
|
716
|
+
break;
|
|
717
|
+
}
|
|
718
|
+
|
|
719
|
+
return _context5.abrupt("return");
|
|
720
|
+
|
|
721
|
+
case 2:
|
|
722
|
+
_context5.next = 4;
|
|
723
|
+
return UploadJob(jobId, j);
|
|
724
|
+
|
|
725
|
+
case 4:
|
|
726
|
+
case "end":
|
|
727
|
+
return _context5.stop();
|
|
628
728
|
}
|
|
729
|
+
}
|
|
730
|
+
}, _callee5);
|
|
731
|
+
}));
|
|
629
732
|
|
|
630
|
-
|
|
631
|
-
|
|
632
|
-
|
|
633
|
-
|
|
733
|
+
return function (_x6, _x7) {
|
|
734
|
+
return _ref9.apply(this, arguments);
|
|
735
|
+
};
|
|
736
|
+
}());
|
|
634
737
|
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
738
|
+
case 44:
|
|
739
|
+
case "end":
|
|
740
|
+
return _context6.stop();
|
|
741
|
+
}
|
|
742
|
+
}
|
|
743
|
+
}, _callee6, this);
|
|
744
|
+
}));
|
|
745
|
+
|
|
746
|
+
return function (_x3) {
|
|
747
|
+
return _ref6.apply(this, arguments);
|
|
748
|
+
};
|
|
749
|
+
}();
|
|
750
|
+
|
|
751
|
+
exports.CreateFileUploadJob = /*#__PURE__*/function () {
|
|
752
|
+
var _ref11 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee7(_ref10) {
|
|
753
|
+
var libraryId, objectId, writeToken, ops, _ref10$defaults, defaults, _ref10$encryption, encryption, body, path;
|
|
754
|
+
|
|
755
|
+
return _regeneratorRuntime.wrap(function _callee7$(_context7) {
|
|
756
|
+
while (1) {
|
|
757
|
+
switch (_context7.prev = _context7.next) {
|
|
758
|
+
case 0:
|
|
759
|
+
libraryId = _ref10.libraryId, objectId = _ref10.objectId, writeToken = _ref10.writeToken, ops = _ref10.ops, _ref10$defaults = _ref10.defaults, defaults = _ref10$defaults === void 0 ? {} : _ref10$defaults, _ref10$encryption = _ref10.encryption, encryption = _ref10$encryption === void 0 ? "none" : _ref10$encryption;
|
|
760
|
+
ValidateParameters({
|
|
761
|
+
libraryId: libraryId,
|
|
762
|
+
objectId: objectId
|
|
640
763
|
});
|
|
641
|
-
|
|
764
|
+
ValidateWriteToken(writeToken);
|
|
765
|
+
this.Log("Creating file upload job: ".concat(libraryId, " ").concat(objectId, " ").concat(writeToken));
|
|
766
|
+
this.Log(ops);
|
|
642
767
|
|
|
768
|
+
if (encryption === "cgck") {
|
|
769
|
+
defaults.encryption = {
|
|
770
|
+
scheme: "cgck"
|
|
771
|
+
};
|
|
772
|
+
}
|
|
643
773
|
|
|
644
|
-
|
|
774
|
+
body = {
|
|
775
|
+
seq: 0,
|
|
776
|
+
seq_complete: true,
|
|
777
|
+
defaults: defaults,
|
|
778
|
+
ops: ops
|
|
779
|
+
};
|
|
780
|
+
path = UrlJoin("q", writeToken, "file_jobs");
|
|
781
|
+
_context7.t0 = this.utils;
|
|
782
|
+
_context7.t1 = this.HttpClient;
|
|
783
|
+
_context7.next = 12;
|
|
784
|
+
return this.authClient.AuthorizationHeader({
|
|
785
|
+
libraryId: libraryId,
|
|
786
|
+
objectId: objectId,
|
|
787
|
+
update: true,
|
|
788
|
+
encryption: encryption
|
|
789
|
+
});
|
|
645
790
|
|
|
646
|
-
|
|
647
|
-
|
|
648
|
-
|
|
791
|
+
case 12:
|
|
792
|
+
_context7.t2 = _context7.sent;
|
|
793
|
+
_context7.t3 = path;
|
|
794
|
+
_context7.t4 = body;
|
|
795
|
+
_context7.t5 = {
|
|
796
|
+
headers: _context7.t2,
|
|
797
|
+
method: "POST",
|
|
798
|
+
path: _context7.t3,
|
|
799
|
+
body: _context7.t4,
|
|
800
|
+
failover: false
|
|
801
|
+
};
|
|
802
|
+
_context7.t6 = _context7.t1.Request.call(_context7.t1, _context7.t5);
|
|
803
|
+
return _context7.abrupt("return", _context7.t0.ResponseToJson.call(_context7.t0, _context7.t6));
|
|
649
804
|
|
|
650
|
-
|
|
651
|
-
|
|
652
|
-
|
|
653
|
-
|
|
654
|
-
|
|
805
|
+
case 18:
|
|
806
|
+
case "end":
|
|
807
|
+
return _context7.stop();
|
|
808
|
+
}
|
|
809
|
+
}
|
|
810
|
+
}, _callee7, this);
|
|
811
|
+
}));
|
|
812
|
+
|
|
813
|
+
return function (_x8) {
|
|
814
|
+
return _ref11.apply(this, arguments);
|
|
815
|
+
};
|
|
816
|
+
}();
|
|
817
|
+
|
|
818
|
+
exports.UploadStatus = /*#__PURE__*/function () {
|
|
819
|
+
var _ref13 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee8(_ref12) {
|
|
820
|
+
var libraryId, objectId, writeToken, uploadId, path;
|
|
821
|
+
return _regeneratorRuntime.wrap(function _callee8$(_context8) {
|
|
822
|
+
while (1) {
|
|
823
|
+
switch (_context8.prev = _context8.next) {
|
|
824
|
+
case 0:
|
|
825
|
+
libraryId = _ref12.libraryId, objectId = _ref12.objectId, writeToken = _ref12.writeToken, uploadId = _ref12.uploadId;
|
|
826
|
+
ValidateParameters({
|
|
827
|
+
libraryId: libraryId,
|
|
828
|
+
objectId: objectId
|
|
829
|
+
});
|
|
830
|
+
ValidateWriteToken(writeToken);
|
|
831
|
+
path = UrlJoin("q", writeToken, "file_jobs", uploadId);
|
|
832
|
+
_context8.t0 = this.utils;
|
|
833
|
+
_context8.t1 = this.HttpClient;
|
|
834
|
+
_context8.next = 8;
|
|
835
|
+
return this.authClient.AuthorizationHeader({
|
|
836
|
+
libraryId: libraryId,
|
|
837
|
+
objectId: objectId,
|
|
838
|
+
update: true
|
|
839
|
+
});
|
|
655
840
|
|
|
656
|
-
|
|
657
|
-
|
|
658
|
-
|
|
659
|
-
|
|
660
|
-
|
|
661
|
-
|
|
662
|
-
|
|
663
|
-
|
|
664
|
-
|
|
665
|
-
|
|
666
|
-
|
|
667
|
-
rates.push(size / elapsed / (1024 * 1024));
|
|
668
|
-
|
|
669
|
-
case 37:
|
|
670
|
-
j++;
|
|
671
|
-
_context6.next = 30;
|
|
672
|
-
break;
|
|
673
|
-
|
|
674
|
-
case 40:
|
|
675
|
-
averageRate = rates.reduce(function (mbps, total) {
|
|
676
|
-
return mbps + total;
|
|
677
|
-
}, 0) / rateTestJobs; // Upload remaining jobs in parallel
|
|
678
|
-
|
|
679
|
-
concurrentUploads = Math.min(5, Math.ceil(averageRate / 2));
|
|
680
|
-
_context6.next = 44;
|
|
681
|
-
return _regeneratorRuntime.awrap(this.utils.LimitedMap(concurrentUploads, jobs, function _callee3(jobId, j) {
|
|
682
|
-
return _regeneratorRuntime.async(function _callee3$(_context5) {
|
|
683
|
-
while (1) {
|
|
684
|
-
switch (_context5.prev = _context5.next) {
|
|
685
|
-
case 0:
|
|
686
|
-
if (!(j < rateTestJobs)) {
|
|
687
|
-
_context5.next = 2;
|
|
688
|
-
break;
|
|
689
|
-
}
|
|
841
|
+
case 8:
|
|
842
|
+
_context8.t2 = _context8.sent;
|
|
843
|
+
_context8.t3 = path;
|
|
844
|
+
_context8.t4 = {
|
|
845
|
+
headers: _context8.t2,
|
|
846
|
+
method: "GET",
|
|
847
|
+
path: _context8.t3,
|
|
848
|
+
failover: false
|
|
849
|
+
};
|
|
850
|
+
_context8.t5 = _context8.t1.Request.call(_context8.t1, _context8.t4);
|
|
851
|
+
return _context8.abrupt("return", _context8.t0.ResponseToJson.call(_context8.t0, _context8.t5));
|
|
690
852
|
|
|
691
|
-
|
|
853
|
+
case 13:
|
|
854
|
+
case "end":
|
|
855
|
+
return _context8.stop();
|
|
856
|
+
}
|
|
857
|
+
}
|
|
858
|
+
}, _callee8, this);
|
|
859
|
+
}));
|
|
860
|
+
|
|
861
|
+
return function (_x9) {
|
|
862
|
+
return _ref13.apply(this, arguments);
|
|
863
|
+
};
|
|
864
|
+
}();
|
|
865
|
+
|
|
866
|
+
exports.UploadJobStatus = /*#__PURE__*/function () {
|
|
867
|
+
var _ref15 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee9(_ref14) {
|
|
868
|
+
var libraryId, objectId, writeToken, uploadId, jobId, path;
|
|
869
|
+
return _regeneratorRuntime.wrap(function _callee9$(_context9) {
|
|
870
|
+
while (1) {
|
|
871
|
+
switch (_context9.prev = _context9.next) {
|
|
872
|
+
case 0:
|
|
873
|
+
libraryId = _ref14.libraryId, objectId = _ref14.objectId, writeToken = _ref14.writeToken, uploadId = _ref14.uploadId, jobId = _ref14.jobId;
|
|
874
|
+
ValidateParameters({
|
|
875
|
+
libraryId: libraryId,
|
|
876
|
+
objectId: objectId
|
|
877
|
+
});
|
|
878
|
+
ValidateWriteToken(writeToken);
|
|
879
|
+
path = UrlJoin("q", writeToken, "file_jobs", uploadId, "uploads", jobId);
|
|
880
|
+
_context9.t0 = this.utils;
|
|
881
|
+
_context9.t1 = this.HttpClient;
|
|
882
|
+
_context9.next = 8;
|
|
883
|
+
return this.authClient.AuthorizationHeader({
|
|
884
|
+
libraryId: libraryId,
|
|
885
|
+
objectId: objectId,
|
|
886
|
+
update: true
|
|
887
|
+
});
|
|
692
888
|
|
|
693
|
-
|
|
694
|
-
|
|
695
|
-
|
|
889
|
+
case 8:
|
|
890
|
+
_context9.t2 = _context9.sent;
|
|
891
|
+
_context9.t3 = path;
|
|
892
|
+
_context9.t4 = {
|
|
893
|
+
headers: _context9.t2,
|
|
894
|
+
method: "GET",
|
|
895
|
+
path: _context9.t3,
|
|
896
|
+
failover: false
|
|
897
|
+
};
|
|
898
|
+
_context9.t5 = _context9.t1.Request.call(_context9.t1, _context9.t4);
|
|
899
|
+
return _context9.abrupt("return", _context9.t0.ResponseToJson.call(_context9.t0, _context9.t5));
|
|
696
900
|
|
|
697
|
-
|
|
698
|
-
|
|
699
|
-
|
|
700
|
-
|
|
701
|
-
|
|
901
|
+
case 13:
|
|
902
|
+
case "end":
|
|
903
|
+
return _context9.stop();
|
|
904
|
+
}
|
|
905
|
+
}
|
|
906
|
+
}, _callee9, this);
|
|
907
|
+
}));
|
|
908
|
+
|
|
909
|
+
return function (_x10) {
|
|
910
|
+
return _ref15.apply(this, arguments);
|
|
911
|
+
};
|
|
912
|
+
}();
|
|
913
|
+
|
|
914
|
+
exports.UploadFileData = /*#__PURE__*/function () {
|
|
915
|
+
var _ref17 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee10(_ref16) {
|
|
916
|
+
var libraryId, objectId, writeToken, uploadId, jobId, fileData, path;
|
|
917
|
+
return _regeneratorRuntime.wrap(function _callee10$(_context10) {
|
|
918
|
+
while (1) {
|
|
919
|
+
switch (_context10.prev = _context10.next) {
|
|
920
|
+
case 0:
|
|
921
|
+
libraryId = _ref16.libraryId, objectId = _ref16.objectId, writeToken = _ref16.writeToken, uploadId = _ref16.uploadId, jobId = _ref16.jobId, fileData = _ref16.fileData;
|
|
922
|
+
ValidateParameters({
|
|
923
|
+
libraryId: libraryId,
|
|
924
|
+
objectId: objectId
|
|
925
|
+
});
|
|
926
|
+
ValidateWriteToken(writeToken);
|
|
927
|
+
path = UrlJoin("q", writeToken, "file_jobs", uploadId, jobId);
|
|
928
|
+
_context10.t0 = this.utils;
|
|
929
|
+
_context10.t1 = this.HttpClient;
|
|
930
|
+
_context10.t2 = path;
|
|
931
|
+
_context10.t3 = fileData;
|
|
932
|
+
_context10.t4 = _objectSpread;
|
|
933
|
+
_context10.t5 = {
|
|
934
|
+
"Content-type": "application/octet-stream"
|
|
935
|
+
};
|
|
936
|
+
_context10.next = 12;
|
|
937
|
+
return this.authClient.AuthorizationHeader({
|
|
938
|
+
libraryId: libraryId,
|
|
939
|
+
objectId: objectId,
|
|
940
|
+
update: true
|
|
702
941
|
});
|
|
703
|
-
}));
|
|
704
942
|
|
|
705
|
-
|
|
706
|
-
|
|
707
|
-
|
|
943
|
+
case 12:
|
|
944
|
+
_context10.t6 = _context10.sent;
|
|
945
|
+
_context10.t7 = (0, _context10.t4)(_context10.t5, _context10.t6);
|
|
946
|
+
_context10.t8 = {
|
|
947
|
+
method: "POST",
|
|
948
|
+
path: _context10.t2,
|
|
949
|
+
body: _context10.t3,
|
|
950
|
+
bodyType: "BINARY",
|
|
951
|
+
headers: _context10.t7,
|
|
952
|
+
failover: false
|
|
953
|
+
};
|
|
954
|
+
_context10.t9 = _context10.t1.Request.call(_context10.t1, _context10.t8);
|
|
955
|
+
_context10.next = 18;
|
|
956
|
+
return _context10.t0.ResponseToJson.call(_context10.t0, _context10.t9);
|
|
957
|
+
|
|
958
|
+
case 18:
|
|
959
|
+
case "end":
|
|
960
|
+
return _context10.stop();
|
|
961
|
+
}
|
|
708
962
|
}
|
|
709
|
-
}
|
|
710
|
-
}
|
|
711
|
-
|
|
712
|
-
|
|
713
|
-
|
|
714
|
-
|
|
715
|
-
|
|
716
|
-
|
|
717
|
-
|
|
718
|
-
|
|
719
|
-
|
|
720
|
-
|
|
721
|
-
|
|
722
|
-
|
|
723
|
-
|
|
724
|
-
|
|
725
|
-
|
|
726
|
-
|
|
727
|
-
|
|
728
|
-
|
|
729
|
-
|
|
730
|
-
|
|
731
|
-
|
|
963
|
+
}, _callee10, this);
|
|
964
|
+
}));
|
|
965
|
+
|
|
966
|
+
return function (_x11) {
|
|
967
|
+
return _ref17.apply(this, arguments);
|
|
968
|
+
};
|
|
969
|
+
}();
|
|
970
|
+
|
|
971
|
+
exports.FinalizeUploadJob = /*#__PURE__*/function () {
|
|
972
|
+
var _ref19 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee11(_ref18) {
|
|
973
|
+
var libraryId, objectId, writeToken, path;
|
|
974
|
+
return _regeneratorRuntime.wrap(function _callee11$(_context11) {
|
|
975
|
+
while (1) {
|
|
976
|
+
switch (_context11.prev = _context11.next) {
|
|
977
|
+
case 0:
|
|
978
|
+
libraryId = _ref18.libraryId, objectId = _ref18.objectId, writeToken = _ref18.writeToken;
|
|
979
|
+
ValidateParameters({
|
|
980
|
+
libraryId: libraryId,
|
|
981
|
+
objectId: objectId
|
|
982
|
+
});
|
|
983
|
+
ValidateWriteToken(writeToken);
|
|
984
|
+
this.Log("Finalizing upload job: ".concat(libraryId, " ").concat(objectId, " ").concat(writeToken));
|
|
985
|
+
path = UrlJoin("q", writeToken, "files");
|
|
986
|
+
_context11.t0 = this.HttpClient;
|
|
987
|
+
_context11.t1 = path;
|
|
988
|
+
_context11.next = 9;
|
|
989
|
+
return this.authClient.AuthorizationHeader({
|
|
990
|
+
libraryId: libraryId,
|
|
991
|
+
objectId: objectId,
|
|
992
|
+
update: true
|
|
993
|
+
});
|
|
994
|
+
|
|
995
|
+
case 9:
|
|
996
|
+
_context11.t2 = _context11.sent;
|
|
997
|
+
_context11.t3 = {
|
|
998
|
+
method: "POST",
|
|
999
|
+
path: _context11.t1,
|
|
1000
|
+
bodyType: "BINARY",
|
|
1001
|
+
headers: _context11.t2,
|
|
1002
|
+
failover: false
|
|
732
1003
|
};
|
|
733
|
-
|
|
1004
|
+
_context11.next = 13;
|
|
1005
|
+
return _context11.t0.Request.call(_context11.t0, _context11.t3);
|
|
734
1006
|
|
|
735
|
-
|
|
736
|
-
|
|
737
|
-
|
|
738
|
-
|
|
739
|
-
ops: ops
|
|
740
|
-
};
|
|
741
|
-
path = UrlJoin("q", writeToken, "file_jobs");
|
|
742
|
-
_context7.t0 = this.utils;
|
|
743
|
-
_context7.t1 = this.HttpClient;
|
|
744
|
-
_context7.next = 12;
|
|
745
|
-
return _regeneratorRuntime.awrap(this.authClient.AuthorizationHeader({
|
|
746
|
-
libraryId: libraryId,
|
|
747
|
-
objectId: objectId,
|
|
748
|
-
update: true,
|
|
749
|
-
encryption: encryption
|
|
750
|
-
}));
|
|
751
|
-
|
|
752
|
-
case 12:
|
|
753
|
-
_context7.t2 = _context7.sent;
|
|
754
|
-
_context7.t3 = path;
|
|
755
|
-
_context7.t4 = body;
|
|
756
|
-
_context7.t5 = {
|
|
757
|
-
headers: _context7.t2,
|
|
758
|
-
method: "POST",
|
|
759
|
-
path: _context7.t3,
|
|
760
|
-
body: _context7.t4,
|
|
761
|
-
failover: false
|
|
762
|
-
};
|
|
763
|
-
_context7.t6 = _context7.t1.Request.call(_context7.t1, _context7.t5);
|
|
764
|
-
return _context7.abrupt("return", _context7.t0.ResponseToJson.call(_context7.t0, _context7.t6));
|
|
765
|
-
|
|
766
|
-
case 18:
|
|
767
|
-
case "end":
|
|
768
|
-
return _context7.stop();
|
|
1007
|
+
case 13:
|
|
1008
|
+
case "end":
|
|
1009
|
+
return _context11.stop();
|
|
1010
|
+
}
|
|
769
1011
|
}
|
|
770
|
-
}
|
|
771
|
-
}
|
|
772
|
-
|
|
773
|
-
|
|
774
|
-
|
|
775
|
-
|
|
776
|
-
|
|
777
|
-
while (1) {
|
|
778
|
-
switch (_context8.prev = _context8.next) {
|
|
779
|
-
case 0:
|
|
780
|
-
libraryId = _ref7.libraryId, objectId = _ref7.objectId, writeToken = _ref7.writeToken, uploadId = _ref7.uploadId;
|
|
781
|
-
ValidateParameters({
|
|
782
|
-
libraryId: libraryId,
|
|
783
|
-
objectId: objectId
|
|
784
|
-
});
|
|
785
|
-
ValidateWriteToken(writeToken);
|
|
786
|
-
path = UrlJoin("q", writeToken, "file_jobs", uploadId);
|
|
787
|
-
_context8.t0 = this.utils;
|
|
788
|
-
_context8.t1 = this.HttpClient;
|
|
789
|
-
_context8.next = 8;
|
|
790
|
-
return _regeneratorRuntime.awrap(this.authClient.AuthorizationHeader({
|
|
791
|
-
libraryId: libraryId,
|
|
792
|
-
objectId: objectId,
|
|
793
|
-
update: true
|
|
794
|
-
}));
|
|
795
|
-
|
|
796
|
-
case 8:
|
|
797
|
-
_context8.t2 = _context8.sent;
|
|
798
|
-
_context8.t3 = path;
|
|
799
|
-
_context8.t4 = {
|
|
800
|
-
headers: _context8.t2,
|
|
801
|
-
method: "GET",
|
|
802
|
-
path: _context8.t3,
|
|
803
|
-
failover: false
|
|
804
|
-
};
|
|
805
|
-
_context8.t5 = _context8.t1.Request.call(_context8.t1, _context8.t4);
|
|
806
|
-
return _context8.abrupt("return", _context8.t0.ResponseToJson.call(_context8.t0, _context8.t5));
|
|
807
|
-
|
|
808
|
-
case 13:
|
|
809
|
-
case "end":
|
|
810
|
-
return _context8.stop();
|
|
811
|
-
}
|
|
812
|
-
}
|
|
813
|
-
}, null, this);
|
|
814
|
-
};
|
|
815
|
-
|
|
816
|
-
exports.UploadJobStatus = function _callee7(_ref8) {
|
|
817
|
-
var libraryId, objectId, writeToken, uploadId, jobId, path;
|
|
818
|
-
return _regeneratorRuntime.async(function _callee7$(_context9) {
|
|
819
|
-
while (1) {
|
|
820
|
-
switch (_context9.prev = _context9.next) {
|
|
821
|
-
case 0:
|
|
822
|
-
libraryId = _ref8.libraryId, objectId = _ref8.objectId, writeToken = _ref8.writeToken, uploadId = _ref8.uploadId, jobId = _ref8.jobId;
|
|
823
|
-
ValidateParameters({
|
|
824
|
-
libraryId: libraryId,
|
|
825
|
-
objectId: objectId
|
|
826
|
-
});
|
|
827
|
-
ValidateWriteToken(writeToken);
|
|
828
|
-
path = UrlJoin("q", writeToken, "file_jobs", uploadId, "uploads", jobId);
|
|
829
|
-
_context9.t0 = this.utils;
|
|
830
|
-
_context9.t1 = this.HttpClient;
|
|
831
|
-
_context9.next = 8;
|
|
832
|
-
return _regeneratorRuntime.awrap(this.authClient.AuthorizationHeader({
|
|
833
|
-
libraryId: libraryId,
|
|
834
|
-
objectId: objectId,
|
|
835
|
-
update: true
|
|
836
|
-
}));
|
|
837
|
-
|
|
838
|
-
case 8:
|
|
839
|
-
_context9.t2 = _context9.sent;
|
|
840
|
-
_context9.t3 = path;
|
|
841
|
-
_context9.t4 = {
|
|
842
|
-
headers: _context9.t2,
|
|
843
|
-
method: "GET",
|
|
844
|
-
path: _context9.t3,
|
|
845
|
-
failover: false
|
|
846
|
-
};
|
|
847
|
-
_context9.t5 = _context9.t1.Request.call(_context9.t1, _context9.t4);
|
|
848
|
-
return _context9.abrupt("return", _context9.t0.ResponseToJson.call(_context9.t0, _context9.t5));
|
|
849
|
-
|
|
850
|
-
case 13:
|
|
851
|
-
case "end":
|
|
852
|
-
return _context9.stop();
|
|
853
|
-
}
|
|
854
|
-
}
|
|
855
|
-
}, null, this);
|
|
856
|
-
};
|
|
857
|
-
|
|
858
|
-
exports.UploadFileData = function _callee8(_ref9) {
|
|
859
|
-
var libraryId, objectId, writeToken, uploadId, jobId, fileData, path;
|
|
860
|
-
return _regeneratorRuntime.async(function _callee8$(_context10) {
|
|
861
|
-
while (1) {
|
|
862
|
-
switch (_context10.prev = _context10.next) {
|
|
863
|
-
case 0:
|
|
864
|
-
libraryId = _ref9.libraryId, objectId = _ref9.objectId, writeToken = _ref9.writeToken, uploadId = _ref9.uploadId, jobId = _ref9.jobId, fileData = _ref9.fileData;
|
|
865
|
-
ValidateParameters({
|
|
866
|
-
libraryId: libraryId,
|
|
867
|
-
objectId: objectId
|
|
868
|
-
});
|
|
869
|
-
ValidateWriteToken(writeToken);
|
|
870
|
-
path = UrlJoin("q", writeToken, "file_jobs", uploadId, jobId);
|
|
871
|
-
_context10.t0 = _regeneratorRuntime;
|
|
872
|
-
_context10.t1 = this.utils;
|
|
873
|
-
_context10.t2 = this.HttpClient;
|
|
874
|
-
_context10.t3 = path;
|
|
875
|
-
_context10.t4 = fileData;
|
|
876
|
-
_context10.t5 = _objectSpread;
|
|
877
|
-
_context10.t6 = {
|
|
878
|
-
"Content-type": "application/octet-stream"
|
|
879
|
-
};
|
|
880
|
-
_context10.next = 13;
|
|
881
|
-
return _regeneratorRuntime.awrap(this.authClient.AuthorizationHeader({
|
|
882
|
-
libraryId: libraryId,
|
|
883
|
-
objectId: objectId,
|
|
884
|
-
update: true
|
|
885
|
-
}));
|
|
886
|
-
|
|
887
|
-
case 13:
|
|
888
|
-
_context10.t7 = _context10.sent;
|
|
889
|
-
_context10.t8 = (0, _context10.t5)(_context10.t6, _context10.t7);
|
|
890
|
-
_context10.t9 = {
|
|
891
|
-
method: "POST",
|
|
892
|
-
path: _context10.t3,
|
|
893
|
-
body: _context10.t4,
|
|
894
|
-
bodyType: "BINARY",
|
|
895
|
-
headers: _context10.t8,
|
|
896
|
-
failover: false
|
|
897
|
-
};
|
|
898
|
-
_context10.t10 = _context10.t2.Request.call(_context10.t2, _context10.t9);
|
|
899
|
-
_context10.t11 = _context10.t1.ResponseToJson.call(_context10.t1, _context10.t10);
|
|
900
|
-
_context10.next = 20;
|
|
901
|
-
return _context10.t0.awrap.call(_context10.t0, _context10.t11);
|
|
902
|
-
|
|
903
|
-
case 20:
|
|
904
|
-
case "end":
|
|
905
|
-
return _context10.stop();
|
|
906
|
-
}
|
|
907
|
-
}
|
|
908
|
-
}, null, this);
|
|
909
|
-
};
|
|
910
|
-
|
|
911
|
-
exports.FinalizeUploadJob = function _callee9(_ref10) {
|
|
912
|
-
var libraryId, objectId, writeToken, path;
|
|
913
|
-
return _regeneratorRuntime.async(function _callee9$(_context11) {
|
|
914
|
-
while (1) {
|
|
915
|
-
switch (_context11.prev = _context11.next) {
|
|
916
|
-
case 0:
|
|
917
|
-
libraryId = _ref10.libraryId, objectId = _ref10.objectId, writeToken = _ref10.writeToken;
|
|
918
|
-
ValidateParameters({
|
|
919
|
-
libraryId: libraryId,
|
|
920
|
-
objectId: objectId
|
|
921
|
-
});
|
|
922
|
-
ValidateWriteToken(writeToken);
|
|
923
|
-
this.Log("Finalizing upload job: ".concat(libraryId, " ").concat(objectId, " ").concat(writeToken));
|
|
924
|
-
path = UrlJoin("q", writeToken, "files");
|
|
925
|
-
_context11.t0 = _regeneratorRuntime;
|
|
926
|
-
_context11.t1 = this.HttpClient;
|
|
927
|
-
_context11.t2 = path;
|
|
928
|
-
_context11.next = 10;
|
|
929
|
-
return _regeneratorRuntime.awrap(this.authClient.AuthorizationHeader({
|
|
930
|
-
libraryId: libraryId,
|
|
931
|
-
objectId: objectId,
|
|
932
|
-
update: true
|
|
933
|
-
}));
|
|
934
|
-
|
|
935
|
-
case 10:
|
|
936
|
-
_context11.t3 = _context11.sent;
|
|
937
|
-
_context11.t4 = {
|
|
938
|
-
method: "POST",
|
|
939
|
-
path: _context11.t2,
|
|
940
|
-
bodyType: "BINARY",
|
|
941
|
-
headers: _context11.t3,
|
|
942
|
-
failover: false
|
|
943
|
-
};
|
|
944
|
-
_context11.t5 = _context11.t1.Request.call(_context11.t1, _context11.t4);
|
|
945
|
-
_context11.next = 15;
|
|
946
|
-
return _context11.t0.awrap.call(_context11.t0, _context11.t5);
|
|
947
|
-
|
|
948
|
-
case 15:
|
|
949
|
-
case "end":
|
|
950
|
-
return _context11.stop();
|
|
951
|
-
}
|
|
952
|
-
}
|
|
953
|
-
}, null, this);
|
|
954
|
-
};
|
|
1012
|
+
}, _callee11, this);
|
|
1013
|
+
}));
|
|
1014
|
+
|
|
1015
|
+
return function (_x12) {
|
|
1016
|
+
return _ref19.apply(this, arguments);
|
|
1017
|
+
};
|
|
1018
|
+
}();
|
|
955
1019
|
/**
|
|
956
1020
|
* Create the specified directories on the specified object
|
|
957
1021
|
*
|
|
@@ -965,42 +1029,48 @@ exports.FinalizeUploadJob = function _callee9(_ref10) {
|
|
|
965
1029
|
*/
|
|
966
1030
|
|
|
967
1031
|
|
|
968
|
-
exports.CreateFileDirectories = function
|
|
969
|
-
var
|
|
970
|
-
|
|
971
|
-
|
|
972
|
-
|
|
973
|
-
|
|
974
|
-
|
|
975
|
-
|
|
976
|
-
|
|
977
|
-
|
|
978
|
-
|
|
979
|
-
|
|
980
|
-
|
|
981
|
-
|
|
982
|
-
|
|
983
|
-
|
|
984
|
-
|
|
985
|
-
|
|
986
|
-
|
|
987
|
-
|
|
988
|
-
|
|
989
|
-
|
|
990
|
-
|
|
991
|
-
|
|
992
|
-
|
|
993
|
-
|
|
994
|
-
|
|
995
|
-
|
|
996
|
-
|
|
997
|
-
|
|
998
|
-
|
|
999
|
-
|
|
1032
|
+
exports.CreateFileDirectories = /*#__PURE__*/function () {
|
|
1033
|
+
var _ref21 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee12(_ref20) {
|
|
1034
|
+
var libraryId, objectId, writeToken, filePaths, ops;
|
|
1035
|
+
return _regeneratorRuntime.wrap(function _callee12$(_context12) {
|
|
1036
|
+
while (1) {
|
|
1037
|
+
switch (_context12.prev = _context12.next) {
|
|
1038
|
+
case 0:
|
|
1039
|
+
libraryId = _ref20.libraryId, objectId = _ref20.objectId, writeToken = _ref20.writeToken, filePaths = _ref20.filePaths;
|
|
1040
|
+
ValidateParameters({
|
|
1041
|
+
libraryId: libraryId,
|
|
1042
|
+
objectId: objectId
|
|
1043
|
+
});
|
|
1044
|
+
ValidateWriteToken(writeToken);
|
|
1045
|
+
this.Log("Creating Directories: ".concat(libraryId, " ").concat(objectId, " ").concat(writeToken));
|
|
1046
|
+
this.Log(filePaths);
|
|
1047
|
+
ops = filePaths.map(function (path) {
|
|
1048
|
+
return {
|
|
1049
|
+
op: "add",
|
|
1050
|
+
type: "directory",
|
|
1051
|
+
path: path
|
|
1052
|
+
};
|
|
1053
|
+
});
|
|
1054
|
+
_context12.next = 8;
|
|
1055
|
+
return this.CreateFileUploadJob({
|
|
1056
|
+
libraryId: libraryId,
|
|
1057
|
+
objectId: objectId,
|
|
1058
|
+
writeToken: writeToken,
|
|
1059
|
+
ops: ops
|
|
1060
|
+
});
|
|
1061
|
+
|
|
1062
|
+
case 8:
|
|
1063
|
+
case "end":
|
|
1064
|
+
return _context12.stop();
|
|
1065
|
+
}
|
|
1000
1066
|
}
|
|
1001
|
-
}
|
|
1002
|
-
}
|
|
1003
|
-
|
|
1067
|
+
}, _callee12, this);
|
|
1068
|
+
}));
|
|
1069
|
+
|
|
1070
|
+
return function (_x13) {
|
|
1071
|
+
return _ref21.apply(this, arguments);
|
|
1072
|
+
};
|
|
1073
|
+
}();
|
|
1004
1074
|
/**
|
|
1005
1075
|
* Delete the specified list of files/directories
|
|
1006
1076
|
*
|
|
@@ -1014,41 +1084,47 @@ exports.CreateFileDirectories = function _callee10(_ref11) {
|
|
|
1014
1084
|
*/
|
|
1015
1085
|
|
|
1016
1086
|
|
|
1017
|
-
exports.DeleteFiles = function
|
|
1018
|
-
var
|
|
1019
|
-
|
|
1020
|
-
|
|
1021
|
-
|
|
1022
|
-
|
|
1023
|
-
|
|
1024
|
-
|
|
1025
|
-
|
|
1026
|
-
|
|
1027
|
-
|
|
1028
|
-
|
|
1029
|
-
|
|
1030
|
-
|
|
1031
|
-
|
|
1032
|
-
|
|
1033
|
-
|
|
1034
|
-
|
|
1035
|
-
|
|
1036
|
-
|
|
1037
|
-
|
|
1038
|
-
|
|
1039
|
-
|
|
1040
|
-
|
|
1041
|
-
|
|
1042
|
-
|
|
1043
|
-
|
|
1044
|
-
|
|
1045
|
-
|
|
1046
|
-
|
|
1047
|
-
|
|
1087
|
+
exports.DeleteFiles = /*#__PURE__*/function () {
|
|
1088
|
+
var _ref23 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee13(_ref22) {
|
|
1089
|
+
var libraryId, objectId, writeToken, filePaths, ops;
|
|
1090
|
+
return _regeneratorRuntime.wrap(function _callee13$(_context13) {
|
|
1091
|
+
while (1) {
|
|
1092
|
+
switch (_context13.prev = _context13.next) {
|
|
1093
|
+
case 0:
|
|
1094
|
+
libraryId = _ref22.libraryId, objectId = _ref22.objectId, writeToken = _ref22.writeToken, filePaths = _ref22.filePaths;
|
|
1095
|
+
ValidateParameters({
|
|
1096
|
+
libraryId: libraryId,
|
|
1097
|
+
objectId: objectId
|
|
1098
|
+
});
|
|
1099
|
+
ValidateWriteToken(writeToken);
|
|
1100
|
+
this.Log("Deleting Files: ".concat(libraryId, " ").concat(objectId, " ").concat(writeToken));
|
|
1101
|
+
this.Log(filePaths);
|
|
1102
|
+
ops = filePaths.map(function (path) {
|
|
1103
|
+
return {
|
|
1104
|
+
op: "del",
|
|
1105
|
+
path: path
|
|
1106
|
+
};
|
|
1107
|
+
});
|
|
1108
|
+
_context13.next = 8;
|
|
1109
|
+
return this.CreateFileUploadJob({
|
|
1110
|
+
libraryId: libraryId,
|
|
1111
|
+
objectId: objectId,
|
|
1112
|
+
writeToken: writeToken,
|
|
1113
|
+
ops: ops
|
|
1114
|
+
});
|
|
1115
|
+
|
|
1116
|
+
case 8:
|
|
1117
|
+
case "end":
|
|
1118
|
+
return _context13.stop();
|
|
1119
|
+
}
|
|
1048
1120
|
}
|
|
1049
|
-
}
|
|
1050
|
-
}
|
|
1051
|
-
|
|
1121
|
+
}, _callee13, this);
|
|
1122
|
+
}));
|
|
1123
|
+
|
|
1124
|
+
return function (_x14) {
|
|
1125
|
+
return _ref23.apply(this, arguments);
|
|
1126
|
+
};
|
|
1127
|
+
}();
|
|
1052
1128
|
/**
|
|
1053
1129
|
* Download a file from a content object
|
|
1054
1130
|
*
|
|
@@ -1075,212 +1151,216 @@ exports.DeleteFiles = function _callee11(_ref12) {
|
|
|
1075
1151
|
*/
|
|
1076
1152
|
|
|
1077
1153
|
|
|
1078
|
-
exports.DownloadFile = function
|
|
1079
|
-
var
|
|
1080
|
-
|
|
1081
|
-
|
|
1082
|
-
|
|
1083
|
-
|
|
1084
|
-
|
|
1085
|
-
|
|
1086
|
-
|
|
1087
|
-
|
|
1088
|
-
|
|
1089
|
-
|
|
1090
|
-
|
|
1091
|
-
|
|
1092
|
-
|
|
1093
|
-
|
|
1094
|
-
|
|
1095
|
-
|
|
1096
|
-
|
|
1097
|
-
|
|
1098
|
-
|
|
1099
|
-
|
|
1100
|
-
|
|
1101
|
-
|
|
1102
|
-
|
|
1103
|
-
|
|
1104
|
-
|
|
1105
|
-
|
|
1106
|
-
|
|
1107
|
-
|
|
1108
|
-
|
|
1109
|
-
|
|
1110
|
-
|
|
1111
|
-
|
|
1112
|
-
|
|
1113
|
-
|
|
1114
|
-
if (versionHash) {
|
|
1115
|
-
objectId = this.utils.DecodeVersionHash(versionHash).objectId;
|
|
1116
|
-
}
|
|
1154
|
+
exports.DownloadFile = /*#__PURE__*/function () {
|
|
1155
|
+
var _ref25 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee14(_ref24) {
|
|
1156
|
+
var libraryId,
|
|
1157
|
+
objectId,
|
|
1158
|
+
versionHash,
|
|
1159
|
+
writeToken,
|
|
1160
|
+
filePath,
|
|
1161
|
+
_ref24$format,
|
|
1162
|
+
format,
|
|
1163
|
+
_ref24$chunked,
|
|
1164
|
+
chunked,
|
|
1165
|
+
chunkSize,
|
|
1166
|
+
_ref24$clientSideDecr,
|
|
1167
|
+
clientSideDecryption,
|
|
1168
|
+
callback,
|
|
1169
|
+
fileInfo,
|
|
1170
|
+
encrypted,
|
|
1171
|
+
encryption,
|
|
1172
|
+
path,
|
|
1173
|
+
headers,
|
|
1174
|
+
ownerCapKey,
|
|
1175
|
+
ownerCap,
|
|
1176
|
+
bytesTotal,
|
|
1177
|
+
_args14 = arguments;
|
|
1178
|
+
|
|
1179
|
+
return _regeneratorRuntime.wrap(function _callee14$(_context14) {
|
|
1180
|
+
while (1) {
|
|
1181
|
+
switch (_context14.prev = _context14.next) {
|
|
1182
|
+
case 0:
|
|
1183
|
+
libraryId = _ref24.libraryId, objectId = _ref24.objectId, versionHash = _ref24.versionHash, writeToken = _ref24.writeToken, filePath = _ref24.filePath, _ref24$format = _ref24.format, format = _ref24$format === void 0 ? "arrayBuffer" : _ref24$format, _ref24$chunked = _ref24.chunked, chunked = _ref24$chunked === void 0 ? false : _ref24$chunked, chunkSize = _ref24.chunkSize, _ref24$clientSideDecr = _ref24.clientSideDecryption, clientSideDecryption = _ref24$clientSideDecr === void 0 ? false : _ref24$clientSideDecr, callback = _ref24.callback;
|
|
1184
|
+
ValidateParameters({
|
|
1185
|
+
libraryId: libraryId,
|
|
1186
|
+
objectId: objectId,
|
|
1187
|
+
versionHash: versionHash
|
|
1188
|
+
});
|
|
1189
|
+
ValidatePresence("filePath", filePath);
|
|
1117
1190
|
|
|
1118
|
-
|
|
1119
|
-
|
|
1120
|
-
|
|
1121
|
-
objectId: objectId,
|
|
1122
|
-
versionHash: versionHash,
|
|
1123
|
-
writeToken: writeToken,
|
|
1124
|
-
metadataSubtree: UrlJoin("files", filePath)
|
|
1125
|
-
}));
|
|
1126
|
-
|
|
1127
|
-
case 6:
|
|
1128
|
-
fileInfo = _context14.sent;
|
|
1129
|
-
encrypted = fileInfo && fileInfo["."].encryption && fileInfo["."].encryption.scheme === "cgck";
|
|
1130
|
-
encryption = encrypted ? "cgck" : undefined;
|
|
1131
|
-
path = encrypted && !clientSideDecryption ? UrlJoin("q", writeToken || versionHash || objectId, "rep", "files_download", filePath) : UrlJoin("q", writeToken || versionHash || objectId, "files", filePath);
|
|
1132
|
-
_context14.next = 12;
|
|
1133
|
-
return _regeneratorRuntime.awrap(this.authClient.AuthorizationHeader({
|
|
1134
|
-
libraryId: libraryId,
|
|
1135
|
-
objectId: objectId,
|
|
1136
|
-
versionHash: versionHash,
|
|
1137
|
-
encryption: encryption
|
|
1138
|
-
}));
|
|
1139
|
-
|
|
1140
|
-
case 12:
|
|
1141
|
-
headers = _context14.sent;
|
|
1142
|
-
headers.Accept = "*/*"; // If not owner, indicate re-encryption
|
|
1143
|
-
|
|
1144
|
-
ownerCapKey = "eluv.caps.iusr".concat(this.utils.AddressToHash(this.signer.address));
|
|
1145
|
-
_context14.next = 17;
|
|
1146
|
-
return _regeneratorRuntime.awrap(this.ContentObjectMetadata({
|
|
1147
|
-
libraryId: libraryId,
|
|
1148
|
-
objectId: objectId,
|
|
1149
|
-
metadataSubtree: ownerCapKey
|
|
1150
|
-
}));
|
|
1151
|
-
|
|
1152
|
-
case 17:
|
|
1153
|
-
ownerCap = _context14.sent;
|
|
1154
|
-
_context14.t1 = encrypted;
|
|
1155
|
-
|
|
1156
|
-
if (!_context14.t1) {
|
|
1157
|
-
_context14.next = 26;
|
|
1158
|
-
break;
|
|
1159
|
-
}
|
|
1191
|
+
if (versionHash) {
|
|
1192
|
+
objectId = this.utils.DecodeVersionHash(versionHash).objectId;
|
|
1193
|
+
}
|
|
1160
1194
|
|
|
1161
|
-
|
|
1162
|
-
|
|
1163
|
-
|
|
1164
|
-
|
|
1165
|
-
|
|
1166
|
-
|
|
1195
|
+
_context14.next = 6;
|
|
1196
|
+
return this.ContentObjectMetadata({
|
|
1197
|
+
libraryId: libraryId,
|
|
1198
|
+
objectId: objectId,
|
|
1199
|
+
versionHash: versionHash,
|
|
1200
|
+
writeToken: writeToken,
|
|
1201
|
+
metadataSubtree: UrlJoin("files", filePath)
|
|
1202
|
+
});
|
|
1167
1203
|
|
|
1168
|
-
|
|
1169
|
-
|
|
1170
|
-
|
|
1204
|
+
case 6:
|
|
1205
|
+
fileInfo = _context14.sent;
|
|
1206
|
+
encrypted = fileInfo && fileInfo["."].encryption && fileInfo["."].encryption.scheme === "cgck";
|
|
1207
|
+
encryption = encrypted ? "cgck" : undefined;
|
|
1208
|
+
path = encrypted && !clientSideDecryption ? UrlJoin("q", writeToken || versionHash || objectId, "rep", "files_download", filePath) : UrlJoin("q", writeToken || versionHash || objectId, "files", filePath);
|
|
1209
|
+
_context14.next = 12;
|
|
1210
|
+
return this.authClient.AuthorizationHeader({
|
|
1211
|
+
libraryId: libraryId,
|
|
1212
|
+
objectId: objectId,
|
|
1213
|
+
versionHash: versionHash,
|
|
1214
|
+
encryption: encryption
|
|
1215
|
+
});
|
|
1171
1216
|
|
|
1172
|
-
|
|
1173
|
-
|
|
1217
|
+
case 12:
|
|
1218
|
+
headers = _context14.sent;
|
|
1219
|
+
headers.Accept = "*/*"; // If not owner, indicate re-encryption
|
|
1174
1220
|
|
|
1175
|
-
|
|
1176
|
-
_context14.next =
|
|
1177
|
-
|
|
1178
|
-
|
|
1221
|
+
ownerCapKey = "eluv.caps.iusr".concat(this.utils.AddressToHash(this.signer.address));
|
|
1222
|
+
_context14.next = 17;
|
|
1223
|
+
return this.ContentObjectMetadata({
|
|
1224
|
+
libraryId: libraryId,
|
|
1225
|
+
objectId: objectId,
|
|
1226
|
+
metadataSubtree: ownerCapKey
|
|
1227
|
+
});
|
|
1179
1228
|
|
|
1180
|
-
|
|
1229
|
+
case 17:
|
|
1230
|
+
ownerCap = _context14.sent;
|
|
1231
|
+
_context14.t1 = encrypted;
|
|
1181
1232
|
|
|
1182
|
-
|
|
1183
|
-
|
|
1184
|
-
|
|
1185
|
-
|
|
1186
|
-
}
|
|
1233
|
+
if (!_context14.t1) {
|
|
1234
|
+
_context14.next = 26;
|
|
1235
|
+
break;
|
|
1236
|
+
}
|
|
1187
1237
|
|
|
1188
|
-
|
|
1238
|
+
_context14.t2 = this.utils;
|
|
1239
|
+
_context14.t3 = this.signer.address;
|
|
1240
|
+
_context14.next = 24;
|
|
1241
|
+
return this.ContentObjectOwner({
|
|
1242
|
+
objectId: objectId
|
|
1243
|
+
});
|
|
1189
1244
|
|
|
1190
|
-
|
|
1191
|
-
|
|
1192
|
-
|
|
1193
|
-
headers["X-Content-Fabric-Decryption-Mode"] = "decrypt"; // rep/files_download endpoint doesn't currently support Range header
|
|
1245
|
+
case 24:
|
|
1246
|
+
_context14.t4 = _context14.sent;
|
|
1247
|
+
_context14.t1 = !_context14.t2.EqualAddress.call(_context14.t2, _context14.t3, _context14.t4);
|
|
1194
1248
|
|
|
1195
|
-
|
|
1196
|
-
|
|
1249
|
+
case 26:
|
|
1250
|
+
_context14.t0 = _context14.t1;
|
|
1251
|
+
|
|
1252
|
+
if (!_context14.t0) {
|
|
1253
|
+
_context14.next = 29;
|
|
1254
|
+
break;
|
|
1255
|
+
}
|
|
1197
1256
|
|
|
1198
|
-
|
|
1257
|
+
_context14.t0 = !ownerCap;
|
|
1199
1258
|
|
|
1200
|
-
|
|
1201
|
-
_context14.
|
|
1202
|
-
|
|
1203
|
-
|
|
1259
|
+
case 29:
|
|
1260
|
+
if (!_context14.t0) {
|
|
1261
|
+
_context14.next = 31;
|
|
1262
|
+
break;
|
|
1263
|
+
}
|
|
1204
1264
|
|
|
1205
|
-
|
|
1206
|
-
_context14.t6 = this;
|
|
1207
|
-
_context14.next = 38;
|
|
1208
|
-
return _regeneratorRuntime.awrap(this.EncryptionConk({
|
|
1209
|
-
libraryId: libraryId,
|
|
1210
|
-
objectId: objectId,
|
|
1211
|
-
versionHash: versionHash,
|
|
1212
|
-
download: true
|
|
1213
|
-
}));
|
|
1214
|
-
|
|
1215
|
-
case 38:
|
|
1216
|
-
_context14.t7 = _context14.sent;
|
|
1217
|
-
_context14.t8 = path;
|
|
1218
|
-
_context14.t9 = bytesTotal;
|
|
1219
|
-
_context14.t10 = headers;
|
|
1220
|
-
_context14.t11 = callback;
|
|
1221
|
-
_context14.t12 = format;
|
|
1222
|
-
_context14.t13 = clientSideDecryption;
|
|
1223
|
-
_context14.t14 = chunked;
|
|
1224
|
-
_context14.t15 = {
|
|
1225
|
-
conk: _context14.t7,
|
|
1226
|
-
downloadPath: _context14.t8,
|
|
1227
|
-
bytesTotal: _context14.t9,
|
|
1228
|
-
headers: _context14.t10,
|
|
1229
|
-
callback: _context14.t11,
|
|
1230
|
-
format: _context14.t12,
|
|
1231
|
-
clientSideDecryption: _context14.t13,
|
|
1232
|
-
chunked: _context14.t14
|
|
1233
|
-
};
|
|
1234
|
-
_context14.t16 = _context14.t6.DownloadEncrypted.call(_context14.t6, _context14.t15);
|
|
1235
|
-
_context14.next = 50;
|
|
1236
|
-
return _context14.t5.awrap.call(_context14.t5, _context14.t16);
|
|
1237
|
-
|
|
1238
|
-
case 50:
|
|
1239
|
-
return _context14.abrupt("return", _context14.sent);
|
|
1240
|
-
|
|
1241
|
-
case 53:
|
|
1242
|
-
if (!chunkSize) {
|
|
1243
|
-
chunkSize = 10000000;
|
|
1244
|
-
}
|
|
1265
|
+
headers["X-Content-Fabric-Decryption-Mode"] = "reencrypt";
|
|
1245
1266
|
|
|
1246
|
-
|
|
1247
|
-
|
|
1248
|
-
|
|
1249
|
-
|
|
1250
|
-
bytesTotal: bytesTotal,
|
|
1251
|
-
headers: headers,
|
|
1252
|
-
callback: callback,
|
|
1253
|
-
format: format,
|
|
1254
|
-
chunked: chunked,
|
|
1255
|
-
chunkSize: chunkSize
|
|
1256
|
-
}));
|
|
1257
|
-
|
|
1258
|
-
case 57:
|
|
1259
|
-
return _context14.abrupt("return", _context14.sent);
|
|
1260
|
-
|
|
1261
|
-
case 60:
|
|
1262
|
-
_context14.prev = 60;
|
|
1263
|
-
_context14.t17 = _context14["catch"](54);
|
|
1264
|
-
|
|
1265
|
-
if (!(encrypted && !clientSideDecryption)) {
|
|
1266
|
-
_context14.next = 64;
|
|
1267
|
-
break;
|
|
1268
|
-
}
|
|
1267
|
+
case 31:
|
|
1268
|
+
// If using server side decryption, specify in header
|
|
1269
|
+
if (encrypted && !clientSideDecryption) {
|
|
1270
|
+
headers["X-Content-Fabric-Decryption-Mode"] = "decrypt"; // rep/files_download endpoint doesn't currently support Range header
|
|
1269
1271
|
|
|
1270
|
-
|
|
1271
|
-
|
|
1272
|
-
})));
|
|
1272
|
+
chunkSize = Number.MAX_SAFE_INTEGER;
|
|
1273
|
+
}
|
|
1273
1274
|
|
|
1274
|
-
|
|
1275
|
-
throw _context14.t17;
|
|
1275
|
+
bytesTotal = fileInfo["."].size;
|
|
1276
1276
|
|
|
1277
|
-
|
|
1278
|
-
|
|
1279
|
-
|
|
1277
|
+
if (!(encrypted && clientSideDecryption)) {
|
|
1278
|
+
_context14.next = 51;
|
|
1279
|
+
break;
|
|
1280
|
+
}
|
|
1281
|
+
|
|
1282
|
+
_context14.t5 = this;
|
|
1283
|
+
_context14.next = 37;
|
|
1284
|
+
return this.EncryptionConk({
|
|
1285
|
+
libraryId: libraryId,
|
|
1286
|
+
objectId: objectId,
|
|
1287
|
+
versionHash: versionHash,
|
|
1288
|
+
download: true
|
|
1289
|
+
});
|
|
1290
|
+
|
|
1291
|
+
case 37:
|
|
1292
|
+
_context14.t6 = _context14.sent;
|
|
1293
|
+
_context14.t7 = path;
|
|
1294
|
+
_context14.t8 = bytesTotal;
|
|
1295
|
+
_context14.t9 = headers;
|
|
1296
|
+
_context14.t10 = callback;
|
|
1297
|
+
_context14.t11 = format;
|
|
1298
|
+
_context14.t12 = clientSideDecryption;
|
|
1299
|
+
_context14.t13 = chunked;
|
|
1300
|
+
_context14.t14 = {
|
|
1301
|
+
conk: _context14.t6,
|
|
1302
|
+
downloadPath: _context14.t7,
|
|
1303
|
+
bytesTotal: _context14.t8,
|
|
1304
|
+
headers: _context14.t9,
|
|
1305
|
+
callback: _context14.t10,
|
|
1306
|
+
format: _context14.t11,
|
|
1307
|
+
clientSideDecryption: _context14.t12,
|
|
1308
|
+
chunked: _context14.t13
|
|
1309
|
+
};
|
|
1310
|
+
_context14.next = 48;
|
|
1311
|
+
return _context14.t5.DownloadEncrypted.call(_context14.t5, _context14.t14);
|
|
1312
|
+
|
|
1313
|
+
case 48:
|
|
1314
|
+
return _context14.abrupt("return", _context14.sent);
|
|
1315
|
+
|
|
1316
|
+
case 51:
|
|
1317
|
+
if (!chunkSize) {
|
|
1318
|
+
chunkSize = 10000000;
|
|
1319
|
+
}
|
|
1320
|
+
|
|
1321
|
+
_context14.prev = 52;
|
|
1322
|
+
_context14.next = 55;
|
|
1323
|
+
return this.Download({
|
|
1324
|
+
downloadPath: path,
|
|
1325
|
+
bytesTotal: bytesTotal,
|
|
1326
|
+
headers: headers,
|
|
1327
|
+
callback: callback,
|
|
1328
|
+
format: format,
|
|
1329
|
+
chunked: chunked,
|
|
1330
|
+
chunkSize: chunkSize
|
|
1331
|
+
});
|
|
1332
|
+
|
|
1333
|
+
case 55:
|
|
1334
|
+
return _context14.abrupt("return", _context14.sent);
|
|
1335
|
+
|
|
1336
|
+
case 58:
|
|
1337
|
+
_context14.prev = 58;
|
|
1338
|
+
_context14.t15 = _context14["catch"](52);
|
|
1339
|
+
|
|
1340
|
+
if (!(encrypted && !clientSideDecryption)) {
|
|
1341
|
+
_context14.next = 62;
|
|
1342
|
+
break;
|
|
1343
|
+
}
|
|
1344
|
+
|
|
1345
|
+
return _context14.abrupt("return", this.DownloadFile(_objectSpread(_objectSpread({}, _args14[0]), {}, {
|
|
1346
|
+
clientSideDecryption: true
|
|
1347
|
+
})));
|
|
1348
|
+
|
|
1349
|
+
case 62:
|
|
1350
|
+
throw _context14.t15;
|
|
1351
|
+
|
|
1352
|
+
case 63:
|
|
1353
|
+
case "end":
|
|
1354
|
+
return _context14.stop();
|
|
1355
|
+
}
|
|
1280
1356
|
}
|
|
1281
|
-
}
|
|
1282
|
-
}
|
|
1283
|
-
|
|
1357
|
+
}, _callee14, this, [[52, 58]]);
|
|
1358
|
+
}));
|
|
1359
|
+
|
|
1360
|
+
return function (_x15) {
|
|
1361
|
+
return _ref25.apply(this, arguments);
|
|
1362
|
+
};
|
|
1363
|
+
}();
|
|
1284
1364
|
/* Parts */
|
|
1285
1365
|
|
|
1286
1366
|
/**
|
|
@@ -1297,59 +1377,63 @@ exports.DownloadFile = function _callee12(_ref13) {
|
|
|
1297
1377
|
*/
|
|
1298
1378
|
|
|
1299
1379
|
|
|
1300
|
-
exports.ContentParts = function
|
|
1301
|
-
var
|
|
1302
|
-
|
|
1303
|
-
|
|
1304
|
-
|
|
1305
|
-
|
|
1306
|
-
|
|
1307
|
-
|
|
1308
|
-
|
|
1309
|
-
|
|
1310
|
-
|
|
1311
|
-
|
|
1312
|
-
|
|
1313
|
-
|
|
1314
|
-
|
|
1315
|
-
|
|
1316
|
-
|
|
1380
|
+
exports.ContentParts = /*#__PURE__*/function () {
|
|
1381
|
+
var _ref27 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee15(_ref26) {
|
|
1382
|
+
var libraryId, objectId, versionHash, path, response;
|
|
1383
|
+
return _regeneratorRuntime.wrap(function _callee15$(_context15) {
|
|
1384
|
+
while (1) {
|
|
1385
|
+
switch (_context15.prev = _context15.next) {
|
|
1386
|
+
case 0:
|
|
1387
|
+
libraryId = _ref26.libraryId, objectId = _ref26.objectId, versionHash = _ref26.versionHash;
|
|
1388
|
+
ValidateParameters({
|
|
1389
|
+
libraryId: libraryId,
|
|
1390
|
+
objectId: objectId,
|
|
1391
|
+
versionHash: versionHash
|
|
1392
|
+
});
|
|
1393
|
+
this.Log("Retrieving parts: ".concat(libraryId, " ").concat(objectId || versionHash));
|
|
1394
|
+
|
|
1395
|
+
if (versionHash) {
|
|
1396
|
+
objectId = this.utils.DecodeVersionHash(versionHash).objectId;
|
|
1397
|
+
}
|
|
1398
|
+
|
|
1399
|
+
path = UrlJoin("q", versionHash || objectId, "parts");
|
|
1400
|
+
_context15.t0 = this.utils;
|
|
1401
|
+
_context15.t1 = this.HttpClient;
|
|
1402
|
+
_context15.next = 9;
|
|
1403
|
+
return this.authClient.AuthorizationHeader({
|
|
1404
|
+
libraryId: libraryId,
|
|
1405
|
+
objectId: objectId,
|
|
1406
|
+
versionHash: versionHash
|
|
1407
|
+
});
|
|
1317
1408
|
|
|
1318
|
-
|
|
1319
|
-
|
|
1320
|
-
|
|
1321
|
-
|
|
1322
|
-
|
|
1323
|
-
|
|
1324
|
-
|
|
1325
|
-
|
|
1326
|
-
|
|
1327
|
-
|
|
1328
|
-
|
|
1329
|
-
|
|
1330
|
-
|
|
1331
|
-
|
|
1332
|
-
|
|
1333
|
-
|
|
1334
|
-
|
|
1335
|
-
|
|
1336
|
-
|
|
1337
|
-
|
|
1338
|
-
_context15.t7 = _context15.t1.ResponseToJson.call(_context15.t1, _context15.t6);
|
|
1339
|
-
_context15.next = 17;
|
|
1340
|
-
return _context15.t0.awrap.call(_context15.t0, _context15.t7);
|
|
1341
|
-
|
|
1342
|
-
case 17:
|
|
1343
|
-
response = _context15.sent;
|
|
1344
|
-
return _context15.abrupt("return", response.parts);
|
|
1345
|
-
|
|
1346
|
-
case 19:
|
|
1347
|
-
case "end":
|
|
1348
|
-
return _context15.stop();
|
|
1409
|
+
case 9:
|
|
1410
|
+
_context15.t2 = _context15.sent;
|
|
1411
|
+
_context15.t3 = path;
|
|
1412
|
+
_context15.t4 = {
|
|
1413
|
+
headers: _context15.t2,
|
|
1414
|
+
method: "GET",
|
|
1415
|
+
path: _context15.t3
|
|
1416
|
+
};
|
|
1417
|
+
_context15.t5 = _context15.t1.Request.call(_context15.t1, _context15.t4);
|
|
1418
|
+
_context15.next = 15;
|
|
1419
|
+
return _context15.t0.ResponseToJson.call(_context15.t0, _context15.t5);
|
|
1420
|
+
|
|
1421
|
+
case 15:
|
|
1422
|
+
response = _context15.sent;
|
|
1423
|
+
return _context15.abrupt("return", response.parts);
|
|
1424
|
+
|
|
1425
|
+
case 17:
|
|
1426
|
+
case "end":
|
|
1427
|
+
return _context15.stop();
|
|
1428
|
+
}
|
|
1349
1429
|
}
|
|
1350
|
-
}
|
|
1351
|
-
}
|
|
1352
|
-
|
|
1430
|
+
}, _callee15, this);
|
|
1431
|
+
}));
|
|
1432
|
+
|
|
1433
|
+
return function (_x16) {
|
|
1434
|
+
return _ref27.apply(this, arguments);
|
|
1435
|
+
};
|
|
1436
|
+
}();
|
|
1353
1437
|
/**
|
|
1354
1438
|
* Get information on a specific part
|
|
1355
1439
|
*
|
|
@@ -1365,59 +1449,63 @@ exports.ContentParts = function _callee13(_ref14) {
|
|
|
1365
1449
|
*/
|
|
1366
1450
|
|
|
1367
1451
|
|
|
1368
|
-
exports.ContentPart = function
|
|
1369
|
-
var
|
|
1370
|
-
|
|
1371
|
-
|
|
1372
|
-
|
|
1373
|
-
|
|
1374
|
-
|
|
1375
|
-
|
|
1376
|
-
|
|
1377
|
-
|
|
1378
|
-
|
|
1379
|
-
|
|
1380
|
-
|
|
1381
|
-
|
|
1382
|
-
|
|
1383
|
-
|
|
1384
|
-
|
|
1385
|
-
|
|
1452
|
+
exports.ContentPart = /*#__PURE__*/function () {
|
|
1453
|
+
var _ref29 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee16(_ref28) {
|
|
1454
|
+
var libraryId, objectId, versionHash, partHash, path;
|
|
1455
|
+
return _regeneratorRuntime.wrap(function _callee16$(_context16) {
|
|
1456
|
+
while (1) {
|
|
1457
|
+
switch (_context16.prev = _context16.next) {
|
|
1458
|
+
case 0:
|
|
1459
|
+
libraryId = _ref28.libraryId, objectId = _ref28.objectId, versionHash = _ref28.versionHash, partHash = _ref28.partHash;
|
|
1460
|
+
ValidateParameters({
|
|
1461
|
+
libraryId: libraryId,
|
|
1462
|
+
objectId: objectId,
|
|
1463
|
+
versionHash: versionHash
|
|
1464
|
+
});
|
|
1465
|
+
ValidatePartHash(partHash);
|
|
1466
|
+
this.Log("Retrieving part: ".concat(libraryId, " ").concat(objectId || versionHash, " ").concat(partHash));
|
|
1467
|
+
|
|
1468
|
+
if (versionHash) {
|
|
1469
|
+
objectId = this.utils.DecodeVersionHash(versionHash).objectId;
|
|
1470
|
+
}
|
|
1471
|
+
|
|
1472
|
+
path = UrlJoin("q", versionHash || objectId, "parts", partHash);
|
|
1473
|
+
_context16.t0 = this.utils;
|
|
1474
|
+
_context16.t1 = this.HttpClient;
|
|
1475
|
+
_context16.next = 10;
|
|
1476
|
+
return this.authClient.AuthorizationHeader({
|
|
1477
|
+
libraryId: libraryId,
|
|
1478
|
+
objectId: objectId,
|
|
1479
|
+
versionHash: versionHash
|
|
1480
|
+
});
|
|
1481
|
+
|
|
1482
|
+
case 10:
|
|
1483
|
+
_context16.t2 = _context16.sent;
|
|
1484
|
+
_context16.t3 = path;
|
|
1485
|
+
_context16.t4 = {
|
|
1486
|
+
headers: _context16.t2,
|
|
1487
|
+
method: "GET",
|
|
1488
|
+
path: _context16.t3
|
|
1489
|
+
};
|
|
1490
|
+
_context16.t5 = _context16.t1.Request.call(_context16.t1, _context16.t4);
|
|
1491
|
+
_context16.next = 16;
|
|
1492
|
+
return _context16.t0.ResponseToJson.call(_context16.t0, _context16.t5);
|
|
1493
|
+
|
|
1494
|
+
case 16:
|
|
1495
|
+
return _context16.abrupt("return", _context16.sent);
|
|
1386
1496
|
|
|
1387
|
-
|
|
1388
|
-
|
|
1389
|
-
|
|
1390
|
-
|
|
1391
|
-
_context16.next = 11;
|
|
1392
|
-
return _regeneratorRuntime.awrap(this.authClient.AuthorizationHeader({
|
|
1393
|
-
libraryId: libraryId,
|
|
1394
|
-
objectId: objectId,
|
|
1395
|
-
versionHash: versionHash
|
|
1396
|
-
}));
|
|
1397
|
-
|
|
1398
|
-
case 11:
|
|
1399
|
-
_context16.t3 = _context16.sent;
|
|
1400
|
-
_context16.t4 = path;
|
|
1401
|
-
_context16.t5 = {
|
|
1402
|
-
headers: _context16.t3,
|
|
1403
|
-
method: "GET",
|
|
1404
|
-
path: _context16.t4
|
|
1405
|
-
};
|
|
1406
|
-
_context16.t6 = _context16.t2.Request.call(_context16.t2, _context16.t5);
|
|
1407
|
-
_context16.t7 = _context16.t1.ResponseToJson.call(_context16.t1, _context16.t6);
|
|
1408
|
-
_context16.next = 18;
|
|
1409
|
-
return _context16.t0.awrap.call(_context16.t0, _context16.t7);
|
|
1410
|
-
|
|
1411
|
-
case 18:
|
|
1412
|
-
return _context16.abrupt("return", _context16.sent);
|
|
1413
|
-
|
|
1414
|
-
case 19:
|
|
1415
|
-
case "end":
|
|
1416
|
-
return _context16.stop();
|
|
1497
|
+
case 17:
|
|
1498
|
+
case "end":
|
|
1499
|
+
return _context16.stop();
|
|
1500
|
+
}
|
|
1417
1501
|
}
|
|
1418
|
-
}
|
|
1419
|
-
}
|
|
1420
|
-
|
|
1502
|
+
}, _callee16, this);
|
|
1503
|
+
}));
|
|
1504
|
+
|
|
1505
|
+
return function (_x17) {
|
|
1506
|
+
return _ref29.apply(this, arguments);
|
|
1507
|
+
};
|
|
1508
|
+
}();
|
|
1421
1509
|
/**
|
|
1422
1510
|
* Download a part from a content object. The fromByte and range parameters can be used to specify a
|
|
1423
1511
|
* specific section of the part to download.
|
|
@@ -1444,394 +1532,416 @@ exports.ContentPart = function _callee14(_ref15) {
|
|
|
1444
1532
|
*/
|
|
1445
1533
|
|
|
1446
1534
|
|
|
1447
|
-
exports.DownloadPart = function
|
|
1448
|
-
var
|
|
1535
|
+
exports.DownloadPart = /*#__PURE__*/function () {
|
|
1536
|
+
var _ref31 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee17(_ref30) {
|
|
1537
|
+
var libraryId, objectId, versionHash, writeToken, partHash, _ref30$format, format, _ref30$chunked, chunked, _ref30$chunkSize, chunkSize, callback, encrypted, encryption, path, headers, bytesTotal;
|
|
1449
1538
|
|
|
1450
|
-
|
|
1451
|
-
|
|
1452
|
-
|
|
1453
|
-
|
|
1454
|
-
|
|
1455
|
-
|
|
1456
|
-
|
|
1457
|
-
|
|
1458
|
-
|
|
1459
|
-
|
|
1460
|
-
|
|
1539
|
+
return _regeneratorRuntime.wrap(function _callee17$(_context17) {
|
|
1540
|
+
while (1) {
|
|
1541
|
+
switch (_context17.prev = _context17.next) {
|
|
1542
|
+
case 0:
|
|
1543
|
+
libraryId = _ref30.libraryId, objectId = _ref30.objectId, versionHash = _ref30.versionHash, writeToken = _ref30.writeToken, partHash = _ref30.partHash, _ref30$format = _ref30.format, format = _ref30$format === void 0 ? "arrayBuffer" : _ref30$format, _ref30$chunked = _ref30.chunked, chunked = _ref30$chunked === void 0 ? false : _ref30$chunked, _ref30$chunkSize = _ref30.chunkSize, chunkSize = _ref30$chunkSize === void 0 ? 10000000 : _ref30$chunkSize, callback = _ref30.callback;
|
|
1544
|
+
ValidateParameters({
|
|
1545
|
+
libraryId: libraryId,
|
|
1546
|
+
objectId: objectId,
|
|
1547
|
+
versionHash: versionHash
|
|
1548
|
+
});
|
|
1549
|
+
ValidatePartHash(partHash);
|
|
1461
1550
|
|
|
1462
|
-
|
|
1463
|
-
|
|
1464
|
-
|
|
1551
|
+
if (versionHash) {
|
|
1552
|
+
objectId = this.utils.DecodeVersionHash(versionHash).objectId;
|
|
1553
|
+
}
|
|
1465
1554
|
|
|
1466
|
-
|
|
1467
|
-
|
|
1468
|
-
|
|
1469
|
-
|
|
1470
|
-
|
|
1471
|
-
|
|
1472
|
-
|
|
1473
|
-
|
|
1474
|
-
|
|
1475
|
-
|
|
1476
|
-
|
|
1477
|
-
case 9:
|
|
1478
|
-
headers = _context17.sent;
|
|
1479
|
-
_context17.next = 12;
|
|
1480
|
-
return _regeneratorRuntime.awrap(this.ContentPart({
|
|
1481
|
-
libraryId: libraryId,
|
|
1482
|
-
objectId: objectId,
|
|
1483
|
-
versionHash: versionHash,
|
|
1484
|
-
partHash: partHash
|
|
1485
|
-
}));
|
|
1486
|
-
|
|
1487
|
-
case 12:
|
|
1488
|
-
bytesTotal = _context17.sent.part.size;
|
|
1489
|
-
|
|
1490
|
-
if (!encrypted) {
|
|
1491
|
-
_context17.next = 39;
|
|
1492
|
-
break;
|
|
1493
|
-
}
|
|
1555
|
+
encrypted = partHash.startsWith("hqpe");
|
|
1556
|
+
encryption = encrypted ? "cgck" : undefined;
|
|
1557
|
+
path = UrlJoin("q", writeToken || versionHash || objectId, "data", partHash);
|
|
1558
|
+
_context17.next = 9;
|
|
1559
|
+
return this.authClient.AuthorizationHeader({
|
|
1560
|
+
libraryId: libraryId,
|
|
1561
|
+
objectId: objectId,
|
|
1562
|
+
versionHash: versionHash,
|
|
1563
|
+
encryption: encryption
|
|
1564
|
+
});
|
|
1494
1565
|
|
|
1495
|
-
|
|
1496
|
-
|
|
1497
|
-
|
|
1498
|
-
|
|
1499
|
-
|
|
1500
|
-
|
|
1566
|
+
case 9:
|
|
1567
|
+
headers = _context17.sent;
|
|
1568
|
+
_context17.next = 12;
|
|
1569
|
+
return this.ContentPart({
|
|
1570
|
+
libraryId: libraryId,
|
|
1571
|
+
objectId: objectId,
|
|
1572
|
+
versionHash: versionHash,
|
|
1573
|
+
partHash: partHash
|
|
1574
|
+
});
|
|
1501
1575
|
|
|
1502
|
-
|
|
1503
|
-
|
|
1576
|
+
case 12:
|
|
1577
|
+
bytesTotal = _context17.sent.part.size;
|
|
1504
1578
|
|
|
1505
|
-
|
|
1506
|
-
|
|
1507
|
-
|
|
1508
|
-
|
|
1579
|
+
if (!encrypted) {
|
|
1580
|
+
_context17.next = 37;
|
|
1581
|
+
break;
|
|
1582
|
+
}
|
|
1509
1583
|
|
|
1510
|
-
|
|
1511
|
-
|
|
1512
|
-
|
|
1513
|
-
|
|
1514
|
-
|
|
1515
|
-
|
|
1516
|
-
return _regeneratorRuntime.awrap(this.EncryptionConk({
|
|
1517
|
-
libraryId: libraryId,
|
|
1518
|
-
objectId: objectId,
|
|
1519
|
-
download: true
|
|
1520
|
-
}));
|
|
1521
|
-
|
|
1522
|
-
case 25:
|
|
1523
|
-
_context17.t5 = _context17.sent;
|
|
1524
|
-
_context17.t6 = path;
|
|
1525
|
-
_context17.t7 = bytesTotal;
|
|
1526
|
-
_context17.t8 = headers;
|
|
1527
|
-
_context17.t9 = callback;
|
|
1528
|
-
_context17.t10 = format;
|
|
1529
|
-
_context17.t11 = chunked;
|
|
1530
|
-
_context17.t12 = {
|
|
1531
|
-
conk: _context17.t5,
|
|
1532
|
-
downloadPath: _context17.t6,
|
|
1533
|
-
bytesTotal: _context17.t7,
|
|
1534
|
-
headers: _context17.t8,
|
|
1535
|
-
callback: _context17.t9,
|
|
1536
|
-
format: _context17.t10,
|
|
1537
|
-
chunked: _context17.t11
|
|
1538
|
-
};
|
|
1539
|
-
_context17.t13 = _context17.t4.DownloadEncrypted.call(_context17.t4, _context17.t12);
|
|
1540
|
-
_context17.next = 36;
|
|
1541
|
-
return _context17.t3.awrap.call(_context17.t3, _context17.t13);
|
|
1542
|
-
|
|
1543
|
-
case 36:
|
|
1544
|
-
return _context17.abrupt("return", _context17.sent);
|
|
1545
|
-
|
|
1546
|
-
case 39:
|
|
1547
|
-
_context17.next = 41;
|
|
1548
|
-
return _regeneratorRuntime.awrap(this.Download({
|
|
1549
|
-
downloadPath: path,
|
|
1550
|
-
bytesTotal: bytesTotal,
|
|
1551
|
-
headers: headers,
|
|
1552
|
-
callback: callback,
|
|
1553
|
-
format: format,
|
|
1554
|
-
chunked: chunked,
|
|
1555
|
-
chunkSize: chunkSize
|
|
1556
|
-
}));
|
|
1557
|
-
|
|
1558
|
-
case 41:
|
|
1559
|
-
return _context17.abrupt("return", _context17.sent);
|
|
1560
|
-
|
|
1561
|
-
case 42:
|
|
1562
|
-
case "end":
|
|
1563
|
-
return _context17.stop();
|
|
1564
|
-
}
|
|
1565
|
-
}
|
|
1566
|
-
}, null, this);
|
|
1567
|
-
};
|
|
1584
|
+
_context17.t0 = this.utils;
|
|
1585
|
+
_context17.t1 = this.signer.address;
|
|
1586
|
+
_context17.next = 18;
|
|
1587
|
+
return this.ContentObjectOwner({
|
|
1588
|
+
objectId: objectId
|
|
1589
|
+
});
|
|
1568
1590
|
|
|
1569
|
-
|
|
1570
|
-
|
|
1591
|
+
case 18:
|
|
1592
|
+
_context17.t2 = _context17.sent;
|
|
1571
1593
|
|
|
1572
|
-
|
|
1573
|
-
|
|
1574
|
-
|
|
1575
|
-
|
|
1576
|
-
downloadPath = _ref17.downloadPath, headers = _ref17.headers, bytesTotal = _ref17.bytesTotal, _ref17$chunked = _ref17.chunked, chunked = _ref17$chunked === void 0 ? false : _ref17$chunked, _ref17$chunkSize = _ref17.chunkSize, chunkSize = _ref17$chunkSize === void 0 ? 2000000 : _ref17$chunkSize, callback = _ref17.callback, _ref17$format = _ref17.format, format = _ref17$format === void 0 ? "arrayBuffer" : _ref17$format;
|
|
1594
|
+
if (_context17.t0.EqualAddress.call(_context17.t0, _context17.t1, _context17.t2)) {
|
|
1595
|
+
_context17.next = 21;
|
|
1596
|
+
break;
|
|
1597
|
+
}
|
|
1577
1598
|
|
|
1578
|
-
|
|
1579
|
-
_context18.next = 3;
|
|
1580
|
-
break;
|
|
1581
|
-
}
|
|
1599
|
+
headers["X-Content-Fabric-Decryption-Mode"] = "reencrypt";
|
|
1582
1600
|
|
|
1583
|
-
|
|
1601
|
+
case 21:
|
|
1602
|
+
_context17.t3 = this;
|
|
1603
|
+
_context17.next = 24;
|
|
1604
|
+
return this.EncryptionConk({
|
|
1605
|
+
libraryId: libraryId,
|
|
1606
|
+
objectId: objectId,
|
|
1607
|
+
download: true
|
|
1608
|
+
});
|
|
1584
1609
|
|
|
1585
|
-
|
|
1586
|
-
|
|
1587
|
-
|
|
1588
|
-
|
|
1610
|
+
case 24:
|
|
1611
|
+
_context17.t4 = _context17.sent;
|
|
1612
|
+
_context17.t5 = path;
|
|
1613
|
+
_context17.t6 = bytesTotal;
|
|
1614
|
+
_context17.t7 = headers;
|
|
1615
|
+
_context17.t8 = callback;
|
|
1616
|
+
_context17.t9 = format;
|
|
1617
|
+
_context17.t10 = chunked;
|
|
1618
|
+
_context17.t11 = {
|
|
1619
|
+
conk: _context17.t4,
|
|
1620
|
+
downloadPath: _context17.t5,
|
|
1621
|
+
bytesTotal: _context17.t6,
|
|
1622
|
+
headers: _context17.t7,
|
|
1623
|
+
callback: _context17.t8,
|
|
1624
|
+
format: _context17.t9,
|
|
1625
|
+
chunked: _context17.t10
|
|
1626
|
+
};
|
|
1627
|
+
_context17.next = 34;
|
|
1628
|
+
return _context17.t3.DownloadEncrypted.call(_context17.t3, _context17.t11);
|
|
1589
1629
|
|
|
1630
|
+
case 34:
|
|
1631
|
+
return _context17.abrupt("return", _context17.sent);
|
|
1590
1632
|
|
|
1591
|
-
|
|
1592
|
-
|
|
1593
|
-
|
|
1633
|
+
case 37:
|
|
1634
|
+
_context17.next = 39;
|
|
1635
|
+
return this.Download({
|
|
1636
|
+
downloadPath: path,
|
|
1637
|
+
bytesTotal: bytesTotal,
|
|
1638
|
+
headers: headers,
|
|
1639
|
+
callback: callback,
|
|
1640
|
+
format: format,
|
|
1641
|
+
chunked: chunked,
|
|
1642
|
+
chunkSize: chunkSize
|
|
1643
|
+
});
|
|
1594
1644
|
|
|
1595
|
-
|
|
1596
|
-
|
|
1597
|
-
_context18.next = 35;
|
|
1598
|
-
break;
|
|
1599
|
-
}
|
|
1645
|
+
case 39:
|
|
1646
|
+
return _context17.abrupt("return", _context17.sent);
|
|
1600
1647
|
|
|
1601
|
-
|
|
1602
|
-
|
|
1603
|
-
|
|
1604
|
-
|
|
1605
|
-
|
|
1606
|
-
|
|
1607
|
-
|
|
1648
|
+
case 40:
|
|
1649
|
+
case "end":
|
|
1650
|
+
return _context17.stop();
|
|
1651
|
+
}
|
|
1652
|
+
}
|
|
1653
|
+
}, _callee17, this);
|
|
1654
|
+
}));
|
|
1655
|
+
|
|
1656
|
+
return function (_x18) {
|
|
1657
|
+
return _ref31.apply(this, arguments);
|
|
1658
|
+
};
|
|
1659
|
+
}();
|
|
1660
|
+
|
|
1661
|
+
exports.Download = /*#__PURE__*/function () {
|
|
1662
|
+
var _ref33 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee18(_ref32) {
|
|
1663
|
+
var downloadPath, headers, bytesTotal, _ref32$chunked, chunked, _ref32$chunkSize, chunkSize, callback, _ref32$format, format, outputChunks, bytesFinished, totalChunks, i, response;
|
|
1664
|
+
|
|
1665
|
+
return _regeneratorRuntime.wrap(function _callee18$(_context18) {
|
|
1666
|
+
while (1) {
|
|
1667
|
+
switch (_context18.prev = _context18.next) {
|
|
1668
|
+
case 0:
|
|
1669
|
+
downloadPath = _ref32.downloadPath, headers = _ref32.headers, bytesTotal = _ref32.bytesTotal, _ref32$chunked = _ref32.chunked, chunked = _ref32$chunked === void 0 ? false : _ref32$chunked, _ref32$chunkSize = _ref32.chunkSize, chunkSize = _ref32$chunkSize === void 0 ? 2000000 : _ref32$chunkSize, callback = _ref32.callback, _ref32$format = _ref32.format, format = _ref32$format === void 0 ? "arrayBuffer" : _ref32$format;
|
|
1670
|
+
|
|
1671
|
+
if (!(chunked && !callback)) {
|
|
1672
|
+
_context18.next = 3;
|
|
1673
|
+
break;
|
|
1674
|
+
}
|
|
1608
1675
|
|
|
1609
|
-
|
|
1610
|
-
response = _context18.sent;
|
|
1611
|
-
bytesFinished = Math.min(bytesFinished + chunkSize, bytesTotal);
|
|
1676
|
+
throw Error("No callback specified for chunked download");
|
|
1612
1677
|
|
|
1613
|
-
|
|
1614
|
-
|
|
1615
|
-
|
|
1616
|
-
|
|
1678
|
+
case 3:
|
|
1679
|
+
if (!chunked) {
|
|
1680
|
+
outputChunks = [];
|
|
1681
|
+
} // Download file in chunks
|
|
1682
|
+
|
|
1683
|
+
|
|
1684
|
+
bytesFinished = 0;
|
|
1685
|
+
totalChunks = Math.ceil(bytesTotal / chunkSize);
|
|
1686
|
+
i = 0;
|
|
1687
|
+
|
|
1688
|
+
case 7:
|
|
1689
|
+
if (!(i < totalChunks)) {
|
|
1690
|
+
_context18.next = 35;
|
|
1691
|
+
break;
|
|
1692
|
+
}
|
|
1617
1693
|
|
|
1618
|
-
|
|
1619
|
-
|
|
1620
|
-
|
|
1621
|
-
|
|
1622
|
-
|
|
1623
|
-
|
|
1624
|
-
case 19:
|
|
1625
|
-
_context18.t3 = _context18.sent;
|
|
1626
|
-
_context18.t4 = {
|
|
1627
|
-
bytesFinished: _context18.t1,
|
|
1628
|
-
bytesTotal: _context18.t2,
|
|
1629
|
-
chunk: _context18.t3
|
|
1630
|
-
};
|
|
1631
|
-
(0, _context18.t0)(_context18.t4);
|
|
1632
|
-
_context18.next = 32;
|
|
1633
|
-
break;
|
|
1634
|
-
|
|
1635
|
-
case 24:
|
|
1636
|
-
_context18.t5 = outputChunks;
|
|
1637
|
-
_context18.t6 = Buffer;
|
|
1638
|
-
_context18.next = 28;
|
|
1639
|
-
return _regeneratorRuntime.awrap(response.arrayBuffer());
|
|
1640
|
-
|
|
1641
|
-
case 28:
|
|
1642
|
-
_context18.t7 = _context18.sent;
|
|
1643
|
-
_context18.t8 = _context18.t6.from.call(_context18.t6, _context18.t7);
|
|
1644
|
-
|
|
1645
|
-
_context18.t5.push.call(_context18.t5, _context18.t8);
|
|
1646
|
-
|
|
1647
|
-
if (callback) {
|
|
1648
|
-
callback({
|
|
1649
|
-
bytesFinished: bytesFinished,
|
|
1650
|
-
bytesTotal: bytesTotal
|
|
1694
|
+
headers["Range"] = "bytes=".concat(bytesFinished, "-").concat(bytesFinished + chunkSize - 1);
|
|
1695
|
+
_context18.next = 11;
|
|
1696
|
+
return this.HttpClient.Request({
|
|
1697
|
+
path: downloadPath,
|
|
1698
|
+
headers: headers,
|
|
1699
|
+
method: "GET"
|
|
1651
1700
|
});
|
|
1652
|
-
}
|
|
1653
1701
|
|
|
1654
|
-
|
|
1655
|
-
|
|
1656
|
-
|
|
1657
|
-
|
|
1702
|
+
case 11:
|
|
1703
|
+
response = _context18.sent;
|
|
1704
|
+
bytesFinished = Math.min(bytesFinished + chunkSize, bytesTotal);
|
|
1705
|
+
|
|
1706
|
+
if (!chunked) {
|
|
1707
|
+
_context18.next = 24;
|
|
1708
|
+
break;
|
|
1709
|
+
}
|
|
1658
1710
|
|
|
1659
|
-
|
|
1660
|
-
|
|
1661
|
-
_context18.
|
|
1711
|
+
_context18.t0 = callback;
|
|
1712
|
+
_context18.t1 = bytesFinished;
|
|
1713
|
+
_context18.t2 = bytesTotal;
|
|
1714
|
+
_context18.next = 19;
|
|
1715
|
+
return this.utils.ResponseToFormat(format, response);
|
|
1716
|
+
|
|
1717
|
+
case 19:
|
|
1718
|
+
_context18.t3 = _context18.sent;
|
|
1719
|
+
_context18.t4 = {
|
|
1720
|
+
bytesFinished: _context18.t1,
|
|
1721
|
+
bytesTotal: _context18.t2,
|
|
1722
|
+
chunk: _context18.t3
|
|
1723
|
+
};
|
|
1724
|
+
(0, _context18.t0)(_context18.t4);
|
|
1725
|
+
_context18.next = 32;
|
|
1662
1726
|
break;
|
|
1663
|
-
}
|
|
1664
1727
|
|
|
1665
|
-
|
|
1666
|
-
|
|
1728
|
+
case 24:
|
|
1729
|
+
_context18.t5 = outputChunks;
|
|
1730
|
+
_context18.t6 = Buffer;
|
|
1731
|
+
_context18.next = 28;
|
|
1732
|
+
return response.arrayBuffer();
|
|
1667
1733
|
|
|
1668
|
-
|
|
1669
|
-
|
|
1734
|
+
case 28:
|
|
1735
|
+
_context18.t7 = _context18.sent;
|
|
1736
|
+
_context18.t8 = _context18.t6.from.call(_context18.t6, _context18.t7);
|
|
1670
1737
|
|
|
1671
|
-
|
|
1672
|
-
case "end":
|
|
1673
|
-
return _context18.stop();
|
|
1674
|
-
}
|
|
1675
|
-
}
|
|
1676
|
-
}, null, this);
|
|
1677
|
-
};
|
|
1738
|
+
_context18.t5.push.call(_context18.t5, _context18.t8);
|
|
1678
1739
|
|
|
1679
|
-
|
|
1680
|
-
|
|
1740
|
+
if (callback) {
|
|
1741
|
+
callback({
|
|
1742
|
+
bytesFinished: bytesFinished,
|
|
1743
|
+
bytesTotal: bytesTotal
|
|
1744
|
+
});
|
|
1745
|
+
}
|
|
1681
1746
|
|
|
1682
|
-
|
|
1747
|
+
case 32:
|
|
1748
|
+
i++;
|
|
1749
|
+
_context18.next = 7;
|
|
1750
|
+
break;
|
|
1683
1751
|
|
|
1684
|
-
|
|
1685
|
-
|
|
1686
|
-
|
|
1687
|
-
|
|
1688
|
-
|
|
1752
|
+
case 35:
|
|
1753
|
+
if (chunked) {
|
|
1754
|
+
_context18.next = 39;
|
|
1755
|
+
break;
|
|
1756
|
+
}
|
|
1689
1757
|
|
|
1690
|
-
|
|
1691
|
-
|
|
1692
|
-
break;
|
|
1693
|
-
}
|
|
1758
|
+
_context18.next = 38;
|
|
1759
|
+
return this.utils.ResponseToFormat(format, new Response(Buffer.concat(outputChunks)));
|
|
1694
1760
|
|
|
1695
|
-
|
|
1696
|
-
|
|
1697
|
-
case 3:
|
|
1698
|
-
// Must align chunk size with encryption block size
|
|
1699
|
-
isReencryption = conk.public_key.startsWith("ktpk");
|
|
1700
|
-
chunkSize = this.Crypto.EncryptedBlockSize(1000000, isReencryption);
|
|
1701
|
-
bytesFinished = 0;
|
|
1702
|
-
format = format.toLowerCase();
|
|
1703
|
-
outputChunks = []; // Set up decryption stream
|
|
1704
|
-
|
|
1705
|
-
_context20.next = 10;
|
|
1706
|
-
return _regeneratorRuntime.awrap(this.Crypto.OpenDecryptionStream(conk));
|
|
1707
|
-
|
|
1708
|
-
case 10:
|
|
1709
|
-
stream = _context20.sent;
|
|
1710
|
-
stream.on("data", function _callee17(chunk) {
|
|
1711
|
-
var arrayBuffer;
|
|
1712
|
-
return _regeneratorRuntime.async(function _callee17$(_context19) {
|
|
1713
|
-
while (1) {
|
|
1714
|
-
switch (_context19.prev = _context19.next) {
|
|
1715
|
-
case 0:
|
|
1716
|
-
if (!chunked) {
|
|
1717
|
-
_context19.next = 13;
|
|
1718
|
-
break;
|
|
1719
|
-
}
|
|
1761
|
+
case 38:
|
|
1762
|
+
return _context18.abrupt("return", _context18.sent);
|
|
1720
1763
|
|
|
1721
|
-
|
|
1722
|
-
|
|
1723
|
-
|
|
1724
|
-
|
|
1764
|
+
case 39:
|
|
1765
|
+
case "end":
|
|
1766
|
+
return _context18.stop();
|
|
1767
|
+
}
|
|
1768
|
+
}
|
|
1769
|
+
}, _callee18, this);
|
|
1770
|
+
}));
|
|
1725
1771
|
|
|
1726
|
-
|
|
1772
|
+
return function (_x19) {
|
|
1773
|
+
return _ref33.apply(this, arguments);
|
|
1774
|
+
};
|
|
1775
|
+
}();
|
|
1727
1776
|
|
|
1728
|
-
|
|
1729
|
-
|
|
1730
|
-
|
|
1731
|
-
|
|
1777
|
+
exports.DownloadEncrypted = /*#__PURE__*/function () {
|
|
1778
|
+
var _ref35 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee20(_ref34) {
|
|
1779
|
+
var _this2 = this;
|
|
1780
|
+
|
|
1781
|
+
var conk, downloadPath, bytesTotal, headers, callback, _ref34$format, format, _ref34$chunked, chunked, isReencryption, chunkSize, bytesFinished, outputChunks, stream, totalChunks, i, response;
|
|
1782
|
+
|
|
1783
|
+
return _regeneratorRuntime.wrap(function _callee20$(_context20) {
|
|
1784
|
+
while (1) {
|
|
1785
|
+
switch (_context20.prev = _context20.next) {
|
|
1786
|
+
case 0:
|
|
1787
|
+
conk = _ref34.conk, downloadPath = _ref34.downloadPath, bytesTotal = _ref34.bytesTotal, headers = _ref34.headers, callback = _ref34.callback, _ref34$format = _ref34.format, format = _ref34$format === void 0 ? "arrayBuffer" : _ref34$format, _ref34$chunked = _ref34.chunked, chunked = _ref34$chunked === void 0 ? false : _ref34$chunked;
|
|
1788
|
+
|
|
1789
|
+
if (!(chunked && !callback)) {
|
|
1790
|
+
_context20.next = 3;
|
|
1791
|
+
break;
|
|
1792
|
+
}
|
|
1732
1793
|
|
|
1733
|
-
|
|
1734
|
-
|
|
1735
|
-
|
|
1736
|
-
|
|
1737
|
-
|
|
1738
|
-
|
|
1739
|
-
|
|
1740
|
-
|
|
1741
|
-
|
|
1742
|
-
|
|
1743
|
-
|
|
1744
|
-
|
|
1745
|
-
|
|
1746
|
-
|
|
1747
|
-
|
|
1748
|
-
|
|
1749
|
-
|
|
1750
|
-
|
|
1751
|
-
|
|
1752
|
-
|
|
1753
|
-
|
|
1754
|
-
|
|
1755
|
-
|
|
1756
|
-
|
|
1757
|
-
|
|
1758
|
-
|
|
1794
|
+
throw Error("No callback specified for chunked download");
|
|
1795
|
+
|
|
1796
|
+
case 3:
|
|
1797
|
+
// Must align chunk size with encryption block size
|
|
1798
|
+
isReencryption = conk.public_key.startsWith("ktpk");
|
|
1799
|
+
chunkSize = this.Crypto.EncryptedBlockSize(1000000, isReencryption);
|
|
1800
|
+
bytesFinished = 0;
|
|
1801
|
+
format = format.toLowerCase();
|
|
1802
|
+
outputChunks = []; // Set up decryption stream
|
|
1803
|
+
|
|
1804
|
+
_context20.next = 10;
|
|
1805
|
+
return this.Crypto.OpenDecryptionStream(conk);
|
|
1806
|
+
|
|
1807
|
+
case 10:
|
|
1808
|
+
stream = _context20.sent;
|
|
1809
|
+
stream.on("data", /*#__PURE__*/function () {
|
|
1810
|
+
var _ref36 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee19(chunk) {
|
|
1811
|
+
var arrayBuffer;
|
|
1812
|
+
return _regeneratorRuntime.wrap(function _callee19$(_context19) {
|
|
1813
|
+
while (1) {
|
|
1814
|
+
switch (_context19.prev = _context19.next) {
|
|
1815
|
+
case 0:
|
|
1816
|
+
if (!chunked) {
|
|
1817
|
+
_context19.next = 13;
|
|
1818
|
+
break;
|
|
1819
|
+
}
|
|
1820
|
+
|
|
1821
|
+
if (!(format !== "buffer")) {
|
|
1822
|
+
_context19.next = 10;
|
|
1823
|
+
break;
|
|
1824
|
+
}
|
|
1825
|
+
|
|
1826
|
+
arrayBuffer = chunk.buffer.slice(chunk.byteOffset, chunk.byteOffset + chunk.byteLength);
|
|
1827
|
+
|
|
1828
|
+
if (!(format === "arraybuffer")) {
|
|
1829
|
+
_context19.next = 7;
|
|
1830
|
+
break;
|
|
1831
|
+
}
|
|
1832
|
+
|
|
1833
|
+
chunk = arrayBuffer;
|
|
1834
|
+
_context19.next = 10;
|
|
1835
|
+
break;
|
|
1836
|
+
|
|
1837
|
+
case 7:
|
|
1838
|
+
_context19.next = 9;
|
|
1839
|
+
return _this2.utils.ResponseToFormat(format, new Response(arrayBuffer));
|
|
1840
|
+
|
|
1841
|
+
case 9:
|
|
1842
|
+
chunk = _context19.sent;
|
|
1843
|
+
|
|
1844
|
+
case 10:
|
|
1845
|
+
callback({
|
|
1846
|
+
bytesFinished: bytesFinished,
|
|
1847
|
+
bytesTotal: bytesTotal,
|
|
1848
|
+
chunk: chunk
|
|
1849
|
+
});
|
|
1850
|
+
_context19.next = 15;
|
|
1851
|
+
break;
|
|
1852
|
+
|
|
1853
|
+
case 13:
|
|
1854
|
+
if (callback) {
|
|
1855
|
+
callback({
|
|
1856
|
+
bytesFinished: bytesFinished,
|
|
1857
|
+
bytesTotal: bytesTotal
|
|
1858
|
+
});
|
|
1859
|
+
}
|
|
1860
|
+
|
|
1861
|
+
outputChunks.push(chunk);
|
|
1862
|
+
|
|
1863
|
+
case 15:
|
|
1864
|
+
case "end":
|
|
1865
|
+
return _context19.stop();
|
|
1759
1866
|
}
|
|
1867
|
+
}
|
|
1868
|
+
}, _callee19);
|
|
1869
|
+
}));
|
|
1760
1870
|
|
|
1761
|
-
|
|
1871
|
+
return function (_x21) {
|
|
1872
|
+
return _ref36.apply(this, arguments);
|
|
1873
|
+
};
|
|
1874
|
+
}());
|
|
1875
|
+
totalChunks = Math.ceil(bytesTotal / chunkSize);
|
|
1876
|
+
i = 0;
|
|
1877
|
+
|
|
1878
|
+
case 14:
|
|
1879
|
+
if (!(i < totalChunks)) {
|
|
1880
|
+
_context20.next = 30;
|
|
1881
|
+
break;
|
|
1882
|
+
}
|
|
1762
1883
|
|
|
1763
|
-
|
|
1764
|
-
|
|
1765
|
-
|
|
1766
|
-
|
|
1767
|
-
|
|
1884
|
+
headers["Range"] = "bytes=".concat(bytesFinished, "-").concat(bytesFinished + chunkSize - 1);
|
|
1885
|
+
_context20.next = 18;
|
|
1886
|
+
return this.HttpClient.Request({
|
|
1887
|
+
headers: headers,
|
|
1888
|
+
method: "GET",
|
|
1889
|
+
path: downloadPath
|
|
1768
1890
|
});
|
|
1769
|
-
});
|
|
1770
|
-
totalChunks = Math.ceil(bytesTotal / chunkSize);
|
|
1771
|
-
i = 0;
|
|
1772
1891
|
|
|
1773
|
-
|
|
1774
|
-
|
|
1775
|
-
|
|
1892
|
+
case 18:
|
|
1893
|
+
response = _context20.sent;
|
|
1894
|
+
bytesFinished = Math.min(bytesFinished + chunkSize, bytesTotal);
|
|
1895
|
+
_context20.t0 = stream;
|
|
1896
|
+
_context20.t1 = Uint8Array;
|
|
1897
|
+
_context20.next = 24;
|
|
1898
|
+
return response.arrayBuffer();
|
|
1899
|
+
|
|
1900
|
+
case 24:
|
|
1901
|
+
_context20.t2 = _context20.sent;
|
|
1902
|
+
_context20.t3 = new _context20.t1(_context20.t2);
|
|
1903
|
+
|
|
1904
|
+
_context20.t0.write.call(_context20.t0, _context20.t3);
|
|
1905
|
+
|
|
1906
|
+
case 27:
|
|
1907
|
+
i++;
|
|
1908
|
+
_context20.next = 14;
|
|
1776
1909
|
break;
|
|
1777
|
-
}
|
|
1778
1910
|
|
|
1779
|
-
|
|
1780
|
-
|
|
1781
|
-
|
|
1782
|
-
|
|
1783
|
-
|
|
1784
|
-
|
|
1785
|
-
|
|
1786
|
-
|
|
1787
|
-
case 18:
|
|
1788
|
-
response = _context20.sent;
|
|
1789
|
-
bytesFinished = Math.min(bytesFinished + chunkSize, bytesTotal);
|
|
1790
|
-
_context20.t0 = stream;
|
|
1791
|
-
_context20.t1 = Uint8Array;
|
|
1792
|
-
_context20.next = 24;
|
|
1793
|
-
return _regeneratorRuntime.awrap(response.arrayBuffer());
|
|
1794
|
-
|
|
1795
|
-
case 24:
|
|
1796
|
-
_context20.t2 = _context20.sent;
|
|
1797
|
-
_context20.t3 = new _context20.t1(_context20.t2);
|
|
1798
|
-
|
|
1799
|
-
_context20.t0.write.call(_context20.t0, _context20.t3);
|
|
1800
|
-
|
|
1801
|
-
case 27:
|
|
1802
|
-
i++;
|
|
1803
|
-
_context20.next = 14;
|
|
1804
|
-
break;
|
|
1805
|
-
|
|
1806
|
-
case 30:
|
|
1807
|
-
// Wait for decryption to complete
|
|
1808
|
-
stream.end();
|
|
1809
|
-
_context20.next = 33;
|
|
1810
|
-
return _regeneratorRuntime.awrap(new Promise(function (resolve) {
|
|
1811
|
-
return stream.on("finish", function () {
|
|
1812
|
-
resolve();
|
|
1911
|
+
case 30:
|
|
1912
|
+
// Wait for decryption to complete
|
|
1913
|
+
stream.end();
|
|
1914
|
+
_context20.next = 33;
|
|
1915
|
+
return new Promise(function (resolve) {
|
|
1916
|
+
return stream.on("finish", function () {
|
|
1917
|
+
resolve();
|
|
1918
|
+
});
|
|
1813
1919
|
});
|
|
1814
|
-
}));
|
|
1815
1920
|
|
|
1816
|
-
|
|
1817
|
-
|
|
1818
|
-
|
|
1819
|
-
|
|
1820
|
-
|
|
1921
|
+
case 33:
|
|
1922
|
+
if (chunked) {
|
|
1923
|
+
_context20.next = 37;
|
|
1924
|
+
break;
|
|
1925
|
+
}
|
|
1821
1926
|
|
|
1822
|
-
|
|
1823
|
-
|
|
1927
|
+
_context20.next = 36;
|
|
1928
|
+
return this.utils.ResponseToFormat(format, new Response(Buffer.concat(outputChunks)));
|
|
1824
1929
|
|
|
1825
|
-
|
|
1826
|
-
|
|
1930
|
+
case 36:
|
|
1931
|
+
return _context20.abrupt("return", _context20.sent);
|
|
1827
1932
|
|
|
1828
|
-
|
|
1829
|
-
|
|
1830
|
-
|
|
1933
|
+
case 37:
|
|
1934
|
+
case "end":
|
|
1935
|
+
return _context20.stop();
|
|
1936
|
+
}
|
|
1831
1937
|
}
|
|
1832
|
-
}
|
|
1833
|
-
}
|
|
1834
|
-
|
|
1938
|
+
}, _callee20, this);
|
|
1939
|
+
}));
|
|
1940
|
+
|
|
1941
|
+
return function (_x20) {
|
|
1942
|
+
return _ref35.apply(this, arguments);
|
|
1943
|
+
};
|
|
1944
|
+
}();
|
|
1835
1945
|
/**
|
|
1836
1946
|
* Create a part upload draft
|
|
1837
1947
|
*
|
|
@@ -1847,57 +1957,61 @@ exports.DownloadEncrypted = function _callee18(_ref18) {
|
|
|
1847
1957
|
*/
|
|
1848
1958
|
|
|
1849
1959
|
|
|
1850
|
-
exports.CreatePart = function
|
|
1851
|
-
var
|
|
1852
|
-
|
|
1853
|
-
|
|
1854
|
-
|
|
1855
|
-
|
|
1856
|
-
|
|
1857
|
-
|
|
1858
|
-
|
|
1859
|
-
|
|
1860
|
-
|
|
1861
|
-
|
|
1862
|
-
|
|
1863
|
-
|
|
1864
|
-
|
|
1865
|
-
|
|
1866
|
-
|
|
1867
|
-
|
|
1868
|
-
|
|
1869
|
-
|
|
1870
|
-
|
|
1871
|
-
|
|
1872
|
-
|
|
1873
|
-
|
|
1874
|
-
|
|
1875
|
-
|
|
1876
|
-
|
|
1877
|
-
|
|
1878
|
-
|
|
1879
|
-
|
|
1880
|
-
|
|
1881
|
-
|
|
1882
|
-
|
|
1883
|
-
|
|
1884
|
-
|
|
1885
|
-
|
|
1886
|
-
|
|
1887
|
-
|
|
1888
|
-
|
|
1889
|
-
|
|
1890
|
-
|
|
1891
|
-
|
|
1892
|
-
|
|
1893
|
-
|
|
1894
|
-
|
|
1895
|
-
|
|
1896
|
-
|
|
1960
|
+
exports.CreatePart = /*#__PURE__*/function () {
|
|
1961
|
+
var _ref38 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee21(_ref37) {
|
|
1962
|
+
var libraryId, objectId, writeToken, encryption, path, openResponse;
|
|
1963
|
+
return _regeneratorRuntime.wrap(function _callee21$(_context21) {
|
|
1964
|
+
while (1) {
|
|
1965
|
+
switch (_context21.prev = _context21.next) {
|
|
1966
|
+
case 0:
|
|
1967
|
+
libraryId = _ref37.libraryId, objectId = _ref37.objectId, writeToken = _ref37.writeToken, encryption = _ref37.encryption;
|
|
1968
|
+
ValidateParameters({
|
|
1969
|
+
libraryId: libraryId,
|
|
1970
|
+
objectId: objectId
|
|
1971
|
+
});
|
|
1972
|
+
ValidateWriteToken(writeToken);
|
|
1973
|
+
path = UrlJoin("q", writeToken, "parts");
|
|
1974
|
+
_context21.t0 = this.utils;
|
|
1975
|
+
_context21.t1 = this.HttpClient;
|
|
1976
|
+
_context21.next = 8;
|
|
1977
|
+
return this.authClient.AuthorizationHeader({
|
|
1978
|
+
libraryId: libraryId,
|
|
1979
|
+
objectId: objectId,
|
|
1980
|
+
update: true,
|
|
1981
|
+
encryption: encryption
|
|
1982
|
+
});
|
|
1983
|
+
|
|
1984
|
+
case 8:
|
|
1985
|
+
_context21.t2 = _context21.sent;
|
|
1986
|
+
_context21.t3 = path;
|
|
1987
|
+
_context21.t4 = {
|
|
1988
|
+
headers: _context21.t2,
|
|
1989
|
+
method: "POST",
|
|
1990
|
+
path: _context21.t3,
|
|
1991
|
+
bodyType: "BINARY",
|
|
1992
|
+
body: "",
|
|
1993
|
+
failover: false
|
|
1994
|
+
};
|
|
1995
|
+
_context21.t5 = _context21.t1.Request.call(_context21.t1, _context21.t4);
|
|
1996
|
+
_context21.next = 14;
|
|
1997
|
+
return _context21.t0.ResponseToJson.call(_context21.t0, _context21.t5);
|
|
1998
|
+
|
|
1999
|
+
case 14:
|
|
2000
|
+
openResponse = _context21.sent;
|
|
2001
|
+
return _context21.abrupt("return", openResponse.part.write_token);
|
|
2002
|
+
|
|
2003
|
+
case 16:
|
|
2004
|
+
case "end":
|
|
2005
|
+
return _context21.stop();
|
|
2006
|
+
}
|
|
1897
2007
|
}
|
|
1898
|
-
}
|
|
1899
|
-
}
|
|
1900
|
-
|
|
2008
|
+
}, _callee21, this);
|
|
2009
|
+
}));
|
|
2010
|
+
|
|
2011
|
+
return function (_x22) {
|
|
2012
|
+
return _ref38.apply(this, arguments);
|
|
2013
|
+
};
|
|
2014
|
+
}();
|
|
1901
2015
|
/**
|
|
1902
2016
|
* Upload data to an open part draft
|
|
1903
2017
|
*
|
|
@@ -1915,77 +2029,80 @@ exports.CreatePart = function _callee19(_ref19) {
|
|
|
1915
2029
|
*/
|
|
1916
2030
|
|
|
1917
2031
|
|
|
1918
|
-
exports.UploadPartChunk = function
|
|
1919
|
-
var
|
|
2032
|
+
exports.UploadPartChunk = /*#__PURE__*/function () {
|
|
2033
|
+
var _ref40 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee22(_ref39) {
|
|
2034
|
+
var libraryId, objectId, writeToken, partWriteToken, chunk, encryption, conk, path;
|
|
2035
|
+
return _regeneratorRuntime.wrap(function _callee22$(_context22) {
|
|
2036
|
+
while (1) {
|
|
2037
|
+
switch (_context22.prev = _context22.next) {
|
|
2038
|
+
case 0:
|
|
2039
|
+
libraryId = _ref39.libraryId, objectId = _ref39.objectId, writeToken = _ref39.writeToken, partWriteToken = _ref39.partWriteToken, chunk = _ref39.chunk, encryption = _ref39.encryption;
|
|
2040
|
+
ValidateParameters({
|
|
2041
|
+
libraryId: libraryId,
|
|
2042
|
+
objectId: objectId
|
|
2043
|
+
});
|
|
2044
|
+
ValidateWriteToken(writeToken);
|
|
1920
2045
|
|
|
1921
|
-
|
|
1922
|
-
|
|
1923
|
-
|
|
1924
|
-
|
|
1925
|
-
libraryId = _ref20.libraryId, objectId = _ref20.objectId, writeToken = _ref20.writeToken, partWriteToken = _ref20.partWriteToken, chunk = _ref20.chunk, encryption = _ref20.encryption;
|
|
1926
|
-
ValidateParameters({
|
|
1927
|
-
libraryId: libraryId,
|
|
1928
|
-
objectId: objectId
|
|
1929
|
-
});
|
|
1930
|
-
ValidateWriteToken(writeToken);
|
|
2046
|
+
if (!(encryption && encryption !== "none")) {
|
|
2047
|
+
_context22.next = 10;
|
|
2048
|
+
break;
|
|
2049
|
+
}
|
|
1931
2050
|
|
|
1932
|
-
|
|
1933
|
-
|
|
1934
|
-
|
|
1935
|
-
|
|
2051
|
+
_context22.next = 6;
|
|
2052
|
+
return this.EncryptionConk({
|
|
2053
|
+
libraryId: libraryId,
|
|
2054
|
+
objectId: objectId,
|
|
2055
|
+
writeToken: writeToken
|
|
2056
|
+
});
|
|
2057
|
+
|
|
2058
|
+
case 6:
|
|
2059
|
+
conk = _context22.sent;
|
|
2060
|
+
_context22.next = 9;
|
|
2061
|
+
return this.Crypto.Encrypt(conk, chunk);
|
|
2062
|
+
|
|
2063
|
+
case 9:
|
|
2064
|
+
chunk = _context22.sent;
|
|
2065
|
+
|
|
2066
|
+
case 10:
|
|
2067
|
+
path = UrlJoin("q", writeToken, "parts");
|
|
2068
|
+
_context22.t0 = this.utils;
|
|
2069
|
+
_context22.t1 = this.HttpClient;
|
|
2070
|
+
_context22.next = 15;
|
|
2071
|
+
return this.authClient.AuthorizationHeader({
|
|
2072
|
+
libraryId: libraryId,
|
|
2073
|
+
objectId: objectId,
|
|
2074
|
+
update: true,
|
|
2075
|
+
encryption: encryption
|
|
2076
|
+
});
|
|
1936
2077
|
|
|
1937
|
-
|
|
1938
|
-
|
|
1939
|
-
|
|
1940
|
-
|
|
1941
|
-
|
|
1942
|
-
|
|
1943
|
-
|
|
1944
|
-
|
|
1945
|
-
|
|
1946
|
-
|
|
1947
|
-
|
|
1948
|
-
|
|
1949
|
-
|
|
1950
|
-
|
|
1951
|
-
|
|
1952
|
-
|
|
1953
|
-
|
|
1954
|
-
|
|
1955
|
-
|
|
1956
|
-
|
|
1957
|
-
_context22.next = 16;
|
|
1958
|
-
return _regeneratorRuntime.awrap(this.authClient.AuthorizationHeader({
|
|
1959
|
-
libraryId: libraryId,
|
|
1960
|
-
objectId: objectId,
|
|
1961
|
-
update: true,
|
|
1962
|
-
encryption: encryption
|
|
1963
|
-
}));
|
|
1964
|
-
|
|
1965
|
-
case 16:
|
|
1966
|
-
_context22.t3 = _context22.sent;
|
|
1967
|
-
_context22.t4 = UrlJoin(path, partWriteToken);
|
|
1968
|
-
_context22.t5 = chunk;
|
|
1969
|
-
_context22.t6 = {
|
|
1970
|
-
headers: _context22.t3,
|
|
1971
|
-
method: "POST",
|
|
1972
|
-
path: _context22.t4,
|
|
1973
|
-
body: _context22.t5,
|
|
1974
|
-
bodyType: "BINARY",
|
|
1975
|
-
failover: false
|
|
1976
|
-
};
|
|
1977
|
-
_context22.t7 = _context22.t2.Request.call(_context22.t2, _context22.t6);
|
|
1978
|
-
_context22.t8 = _context22.t1.ResponseToJson.call(_context22.t1, _context22.t7);
|
|
1979
|
-
_context22.next = 24;
|
|
1980
|
-
return _context22.t0.awrap.call(_context22.t0, _context22.t8);
|
|
1981
|
-
|
|
1982
|
-
case 24:
|
|
1983
|
-
case "end":
|
|
1984
|
-
return _context22.stop();
|
|
2078
|
+
case 15:
|
|
2079
|
+
_context22.t2 = _context22.sent;
|
|
2080
|
+
_context22.t3 = UrlJoin(path, partWriteToken);
|
|
2081
|
+
_context22.t4 = chunk;
|
|
2082
|
+
_context22.t5 = {
|
|
2083
|
+
headers: _context22.t2,
|
|
2084
|
+
method: "POST",
|
|
2085
|
+
path: _context22.t3,
|
|
2086
|
+
body: _context22.t4,
|
|
2087
|
+
bodyType: "BINARY",
|
|
2088
|
+
failover: false
|
|
2089
|
+
};
|
|
2090
|
+
_context22.t6 = _context22.t1.Request.call(_context22.t1, _context22.t5);
|
|
2091
|
+
_context22.next = 22;
|
|
2092
|
+
return _context22.t0.ResponseToJson.call(_context22.t0, _context22.t6);
|
|
2093
|
+
|
|
2094
|
+
case 22:
|
|
2095
|
+
case "end":
|
|
2096
|
+
return _context22.stop();
|
|
2097
|
+
}
|
|
1985
2098
|
}
|
|
1986
|
-
}
|
|
1987
|
-
}
|
|
1988
|
-
|
|
2099
|
+
}, _callee22, this);
|
|
2100
|
+
}));
|
|
2101
|
+
|
|
2102
|
+
return function (_x23) {
|
|
2103
|
+
return _ref40.apply(this, arguments);
|
|
2104
|
+
};
|
|
2105
|
+
}();
|
|
1989
2106
|
/**
|
|
1990
2107
|
* Finalize an open part draft
|
|
1991
2108
|
*
|
|
@@ -2002,62 +2119,64 @@ exports.UploadPartChunk = function _callee20(_ref20) {
|
|
|
2002
2119
|
*/
|
|
2003
2120
|
|
|
2004
2121
|
|
|
2005
|
-
exports.FinalizePart = function
|
|
2006
|
-
var
|
|
2007
|
-
|
|
2008
|
-
|
|
2009
|
-
|
|
2010
|
-
|
|
2011
|
-
|
|
2012
|
-
|
|
2013
|
-
|
|
2014
|
-
|
|
2015
|
-
|
|
2016
|
-
|
|
2017
|
-
|
|
2018
|
-
|
|
2019
|
-
|
|
2020
|
-
|
|
2021
|
-
|
|
2022
|
-
|
|
2023
|
-
|
|
2024
|
-
|
|
2025
|
-
|
|
2026
|
-
|
|
2027
|
-
|
|
2028
|
-
|
|
2029
|
-
|
|
2030
|
-
|
|
2031
|
-
|
|
2032
|
-
|
|
2033
|
-
|
|
2034
|
-
|
|
2035
|
-
|
|
2036
|
-
|
|
2037
|
-
|
|
2038
|
-
|
|
2039
|
-
|
|
2040
|
-
|
|
2041
|
-
|
|
2042
|
-
|
|
2043
|
-
|
|
2044
|
-
|
|
2045
|
-
|
|
2046
|
-
|
|
2047
|
-
|
|
2048
|
-
|
|
2049
|
-
|
|
2050
|
-
|
|
2051
|
-
|
|
2052
|
-
|
|
2053
|
-
|
|
2054
|
-
|
|
2055
|
-
case "end":
|
|
2056
|
-
return _context23.stop();
|
|
2122
|
+
exports.FinalizePart = /*#__PURE__*/function () {
|
|
2123
|
+
var _ref42 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee23(_ref41) {
|
|
2124
|
+
var libraryId, objectId, writeToken, partWriteToken, encryption, path;
|
|
2125
|
+
return _regeneratorRuntime.wrap(function _callee23$(_context23) {
|
|
2126
|
+
while (1) {
|
|
2127
|
+
switch (_context23.prev = _context23.next) {
|
|
2128
|
+
case 0:
|
|
2129
|
+
libraryId = _ref41.libraryId, objectId = _ref41.objectId, writeToken = _ref41.writeToken, partWriteToken = _ref41.partWriteToken, encryption = _ref41.encryption;
|
|
2130
|
+
ValidateParameters({
|
|
2131
|
+
libraryId: libraryId,
|
|
2132
|
+
objectId: objectId
|
|
2133
|
+
});
|
|
2134
|
+
ValidateWriteToken(writeToken);
|
|
2135
|
+
path = UrlJoin("q", writeToken, "parts");
|
|
2136
|
+
_context23.t0 = this.utils;
|
|
2137
|
+
_context23.t1 = this.HttpClient;
|
|
2138
|
+
_context23.next = 8;
|
|
2139
|
+
return this.authClient.AuthorizationHeader({
|
|
2140
|
+
libraryId: libraryId,
|
|
2141
|
+
objectId: objectId,
|
|
2142
|
+
update: true,
|
|
2143
|
+
encryption: encryption
|
|
2144
|
+
});
|
|
2145
|
+
|
|
2146
|
+
case 8:
|
|
2147
|
+
_context23.t2 = _context23.sent;
|
|
2148
|
+
_context23.t3 = UrlJoin(path, partWriteToken);
|
|
2149
|
+
_context23.t4 = {
|
|
2150
|
+
headers: _context23.t2,
|
|
2151
|
+
method: "POST",
|
|
2152
|
+
path: _context23.t3,
|
|
2153
|
+
bodyType: "BINARY",
|
|
2154
|
+
body: "",
|
|
2155
|
+
failover: false
|
|
2156
|
+
};
|
|
2157
|
+
_context23.next = 13;
|
|
2158
|
+
return _context23.t1.Request.call(_context23.t1, _context23.t4);
|
|
2159
|
+
|
|
2160
|
+
case 13:
|
|
2161
|
+
_context23.t5 = _context23.sent;
|
|
2162
|
+
_context23.next = 16;
|
|
2163
|
+
return _context23.t0.ResponseToJson.call(_context23.t0, _context23.t5);
|
|
2164
|
+
|
|
2165
|
+
case 16:
|
|
2166
|
+
return _context23.abrupt("return", _context23.sent);
|
|
2167
|
+
|
|
2168
|
+
case 17:
|
|
2169
|
+
case "end":
|
|
2170
|
+
return _context23.stop();
|
|
2171
|
+
}
|
|
2057
2172
|
}
|
|
2058
|
-
}
|
|
2059
|
-
}
|
|
2060
|
-
|
|
2173
|
+
}, _callee23, this);
|
|
2174
|
+
}));
|
|
2175
|
+
|
|
2176
|
+
return function (_x24) {
|
|
2177
|
+
return _ref42.apply(this, arguments);
|
|
2178
|
+
};
|
|
2179
|
+
}();
|
|
2061
2180
|
/**
|
|
2062
2181
|
* Upload part to an object draft
|
|
2063
2182
|
*
|
|
@@ -2081,90 +2200,96 @@ exports.FinalizePart = function _callee21(_ref21) {
|
|
|
2081
2200
|
*/
|
|
2082
2201
|
|
|
2083
2202
|
|
|
2084
|
-
exports.UploadPart = function
|
|
2085
|
-
var
|
|
2086
|
-
|
|
2087
|
-
|
|
2088
|
-
|
|
2089
|
-
|
|
2090
|
-
|
|
2091
|
-
|
|
2092
|
-
|
|
2093
|
-
|
|
2094
|
-
|
|
2095
|
-
|
|
2096
|
-
ValidateWriteToken(writeToken);
|
|
2097
|
-
_context24.next = 5;
|
|
2098
|
-
return _regeneratorRuntime.awrap(this.CreatePart({
|
|
2099
|
-
libraryId: libraryId,
|
|
2100
|
-
objectId: objectId,
|
|
2101
|
-
writeToken: writeToken,
|
|
2102
|
-
encryption: encryption
|
|
2103
|
-
}));
|
|
2104
|
-
|
|
2105
|
-
case 5:
|
|
2106
|
-
partWriteToken = _context24.sent;
|
|
2107
|
-
size = data.length || data.byteLength || data.size;
|
|
2108
|
-
|
|
2109
|
-
if (callback) {
|
|
2110
|
-
callback({
|
|
2111
|
-
bytesFinished: 0,
|
|
2112
|
-
bytesTotal: size
|
|
2203
|
+
exports.UploadPart = /*#__PURE__*/function () {
|
|
2204
|
+
var _ref44 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee24(_ref43) {
|
|
2205
|
+
var libraryId, objectId, writeToken, data, _ref43$encryption, encryption, _ref43$chunkSize, chunkSize, callback, partWriteToken, size, i, chunk;
|
|
2206
|
+
|
|
2207
|
+
return _regeneratorRuntime.wrap(function _callee24$(_context24) {
|
|
2208
|
+
while (1) {
|
|
2209
|
+
switch (_context24.prev = _context24.next) {
|
|
2210
|
+
case 0:
|
|
2211
|
+
libraryId = _ref43.libraryId, objectId = _ref43.objectId, writeToken = _ref43.writeToken, data = _ref43.data, _ref43$encryption = _ref43.encryption, encryption = _ref43$encryption === void 0 ? "none" : _ref43$encryption, _ref43$chunkSize = _ref43.chunkSize, chunkSize = _ref43$chunkSize === void 0 ? 10000000 : _ref43$chunkSize, callback = _ref43.callback;
|
|
2212
|
+
ValidateParameters({
|
|
2213
|
+
libraryId: libraryId,
|
|
2214
|
+
objectId: objectId
|
|
2113
2215
|
});
|
|
2114
|
-
|
|
2216
|
+
ValidateWriteToken(writeToken);
|
|
2217
|
+
_context24.next = 5;
|
|
2218
|
+
return this.CreatePart({
|
|
2219
|
+
libraryId: libraryId,
|
|
2220
|
+
objectId: objectId,
|
|
2221
|
+
writeToken: writeToken,
|
|
2222
|
+
encryption: encryption
|
|
2223
|
+
});
|
|
2224
|
+
|
|
2225
|
+
case 5:
|
|
2226
|
+
partWriteToken = _context24.sent;
|
|
2227
|
+
size = data.length || data.byteLength || data.size;
|
|
2228
|
+
|
|
2229
|
+
if (callback) {
|
|
2230
|
+
callback({
|
|
2231
|
+
bytesFinished: 0,
|
|
2232
|
+
bytesTotal: size
|
|
2233
|
+
});
|
|
2234
|
+
}
|
|
2235
|
+
|
|
2236
|
+
i = 0;
|
|
2115
2237
|
|
|
2116
|
-
|
|
2238
|
+
case 9:
|
|
2239
|
+
if (!(i < size)) {
|
|
2240
|
+
_context24.next = 17;
|
|
2241
|
+
break;
|
|
2242
|
+
}
|
|
2243
|
+
|
|
2244
|
+
chunk = data.slice(i, i + chunkSize);
|
|
2245
|
+
_context24.next = 13;
|
|
2246
|
+
return this.UploadPartChunk({
|
|
2247
|
+
libraryId: libraryId,
|
|
2248
|
+
objectId: objectId,
|
|
2249
|
+
writeToken: writeToken,
|
|
2250
|
+
partWriteToken: partWriteToken,
|
|
2251
|
+
chunk: chunk,
|
|
2252
|
+
encryption: encryption
|
|
2253
|
+
});
|
|
2254
|
+
|
|
2255
|
+
case 13:
|
|
2256
|
+
if (callback) {
|
|
2257
|
+
callback({
|
|
2258
|
+
bytesFinished: Math.min(i + chunkSize, size),
|
|
2259
|
+
bytesTotal: size
|
|
2260
|
+
});
|
|
2261
|
+
}
|
|
2117
2262
|
|
|
2118
|
-
|
|
2119
|
-
|
|
2120
|
-
_context24.next =
|
|
2263
|
+
case 14:
|
|
2264
|
+
i += chunkSize;
|
|
2265
|
+
_context24.next = 9;
|
|
2121
2266
|
break;
|
|
2122
|
-
}
|
|
2123
2267
|
|
|
2124
|
-
|
|
2125
|
-
|
|
2126
|
-
|
|
2127
|
-
|
|
2128
|
-
|
|
2129
|
-
|
|
2130
|
-
|
|
2131
|
-
|
|
2132
|
-
encryption: encryption
|
|
2133
|
-
}));
|
|
2134
|
-
|
|
2135
|
-
case 13:
|
|
2136
|
-
if (callback) {
|
|
2137
|
-
callback({
|
|
2138
|
-
bytesFinished: Math.min(i + chunkSize, size),
|
|
2139
|
-
bytesTotal: size
|
|
2268
|
+
case 17:
|
|
2269
|
+
_context24.next = 19;
|
|
2270
|
+
return this.FinalizePart({
|
|
2271
|
+
libraryId: libraryId,
|
|
2272
|
+
objectId: objectId,
|
|
2273
|
+
writeToken: writeToken,
|
|
2274
|
+
partWriteToken: partWriteToken,
|
|
2275
|
+
encryption: encryption
|
|
2140
2276
|
});
|
|
2141
|
-
}
|
|
2142
2277
|
|
|
2143
|
-
|
|
2144
|
-
|
|
2145
|
-
|
|
2146
|
-
|
|
2147
|
-
|
|
2148
|
-
|
|
2149
|
-
|
|
2150
|
-
return _regeneratorRuntime.awrap(this.FinalizePart({
|
|
2151
|
-
libraryId: libraryId,
|
|
2152
|
-
objectId: objectId,
|
|
2153
|
-
writeToken: writeToken,
|
|
2154
|
-
partWriteToken: partWriteToken,
|
|
2155
|
-
encryption: encryption
|
|
2156
|
-
}));
|
|
2157
|
-
|
|
2158
|
-
case 19:
|
|
2159
|
-
return _context24.abrupt("return", _context24.sent);
|
|
2160
|
-
|
|
2161
|
-
case 20:
|
|
2162
|
-
case "end":
|
|
2163
|
-
return _context24.stop();
|
|
2278
|
+
case 19:
|
|
2279
|
+
return _context24.abrupt("return", _context24.sent);
|
|
2280
|
+
|
|
2281
|
+
case 20:
|
|
2282
|
+
case "end":
|
|
2283
|
+
return _context24.stop();
|
|
2284
|
+
}
|
|
2164
2285
|
}
|
|
2165
|
-
}
|
|
2166
|
-
}
|
|
2167
|
-
|
|
2286
|
+
}, _callee24, this);
|
|
2287
|
+
}));
|
|
2288
|
+
|
|
2289
|
+
return function (_x25) {
|
|
2290
|
+
return _ref44.apply(this, arguments);
|
|
2291
|
+
};
|
|
2292
|
+
}();
|
|
2168
2293
|
/**
|
|
2169
2294
|
* Delete the specified part from a content draft
|
|
2170
2295
|
*
|
|
@@ -2178,46 +2303,50 @@ exports.UploadPart = function _callee22(_ref22) {
|
|
|
2178
2303
|
*/
|
|
2179
2304
|
|
|
2180
2305
|
|
|
2181
|
-
exports.DeletePart = function
|
|
2182
|
-
var
|
|
2183
|
-
|
|
2184
|
-
|
|
2185
|
-
|
|
2186
|
-
|
|
2187
|
-
|
|
2188
|
-
|
|
2189
|
-
|
|
2190
|
-
|
|
2191
|
-
|
|
2192
|
-
|
|
2193
|
-
|
|
2194
|
-
|
|
2195
|
-
|
|
2196
|
-
|
|
2197
|
-
|
|
2198
|
-
|
|
2199
|
-
|
|
2200
|
-
|
|
2201
|
-
|
|
2202
|
-
|
|
2203
|
-
|
|
2204
|
-
|
|
2205
|
-
|
|
2206
|
-
|
|
2207
|
-
|
|
2208
|
-
|
|
2209
|
-
|
|
2210
|
-
|
|
2211
|
-
|
|
2212
|
-
|
|
2213
|
-
|
|
2214
|
-
|
|
2215
|
-
|
|
2216
|
-
|
|
2217
|
-
|
|
2218
|
-
|
|
2219
|
-
|
|
2306
|
+
exports.DeletePart = /*#__PURE__*/function () {
|
|
2307
|
+
var _ref46 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee25(_ref45) {
|
|
2308
|
+
var libraryId, objectId, writeToken, partHash, path;
|
|
2309
|
+
return _regeneratorRuntime.wrap(function _callee25$(_context25) {
|
|
2310
|
+
while (1) {
|
|
2311
|
+
switch (_context25.prev = _context25.next) {
|
|
2312
|
+
case 0:
|
|
2313
|
+
libraryId = _ref45.libraryId, objectId = _ref45.objectId, writeToken = _ref45.writeToken, partHash = _ref45.partHash;
|
|
2314
|
+
ValidateParameters({
|
|
2315
|
+
libraryId: libraryId,
|
|
2316
|
+
objectId: objectId
|
|
2317
|
+
});
|
|
2318
|
+
ValidateWriteToken(writeToken);
|
|
2319
|
+
ValidatePartHash(partHash);
|
|
2320
|
+
path = UrlJoin("q", writeToken, "parts", partHash);
|
|
2321
|
+
_context25.t0 = this.HttpClient;
|
|
2322
|
+
_context25.next = 8;
|
|
2323
|
+
return this.authClient.AuthorizationHeader({
|
|
2324
|
+
libraryId: libraryId,
|
|
2325
|
+
objectId: objectId,
|
|
2326
|
+
update: true
|
|
2327
|
+
});
|
|
2328
|
+
|
|
2329
|
+
case 8:
|
|
2330
|
+
_context25.t1 = _context25.sent;
|
|
2331
|
+
_context25.t2 = path;
|
|
2332
|
+
_context25.t3 = {
|
|
2333
|
+
headers: _context25.t1,
|
|
2334
|
+
method: "DELETE",
|
|
2335
|
+
path: _context25.t2,
|
|
2336
|
+
failover: false
|
|
2337
|
+
};
|
|
2338
|
+
_context25.next = 13;
|
|
2339
|
+
return _context25.t0.Request.call(_context25.t0, _context25.t3);
|
|
2340
|
+
|
|
2341
|
+
case 13:
|
|
2342
|
+
case "end":
|
|
2343
|
+
return _context25.stop();
|
|
2344
|
+
}
|
|
2220
2345
|
}
|
|
2221
|
-
}
|
|
2222
|
-
}
|
|
2223
|
-
|
|
2346
|
+
}, _callee25, this);
|
|
2347
|
+
}));
|
|
2348
|
+
|
|
2349
|
+
return function (_x26) {
|
|
2350
|
+
return _ref46.apply(this, arguments);
|
|
2351
|
+
};
|
|
2352
|
+
}();
|