curtain-web-api 1.0.42 → 1.0.44
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.
|
@@ -25,7 +25,7 @@ export declare class CurtainWebAPI {
|
|
|
25
25
|
postSettings(id: string, token: string, onDownloadProgress?: any): Promise<import("axios").AxiosResponse<any, any>>;
|
|
26
26
|
getPrideData(accession: string): Promise<import("axios").AxiosResponse<any, any>>;
|
|
27
27
|
generateTemporarySession(linkId: string, lifetime: number): Promise<import("axios").AxiosResponse<any, any>>;
|
|
28
|
-
updateSession(sessionData: any, linkId: string): Promise<import("axios").AxiosResponse<any, any>>;
|
|
28
|
+
updateSession(sessionData: any, linkId: string, encryption?: CurtainEncryption): Promise<import("axios").AxiosResponse<any, any>>;
|
|
29
29
|
getSessionSettings(linkId: string): Promise<import("axios").AxiosResponse<any, any>>;
|
|
30
30
|
getOwnership(linkId: string): Promise<import("axios").AxiosResponse<any, any>>;
|
|
31
31
|
getOwners(linkId: string): Promise<import("axios").AxiosResponse<any, any>>;
|
|
@@ -312,25 +312,56 @@ class CurtainWebAPI {
|
|
|
312
312
|
return response;
|
|
313
313
|
});
|
|
314
314
|
}
|
|
315
|
-
updateSession(sessionData, linkId
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
315
|
+
updateSession(sessionData, linkId, encryption = {
|
|
316
|
+
encrypted: false,
|
|
317
|
+
e2e: false,
|
|
318
|
+
}) {
|
|
319
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
320
|
+
let form = new FormData();
|
|
321
|
+
if ("file" in sessionData) {
|
|
322
|
+
let data = JSON.stringify(sessionData["file"], exports.replacer);
|
|
323
|
+
if (encryption.encrypted && encryption.e2e && encryption.publicKey !== undefined) {
|
|
324
|
+
const aesKey = yield (0, curtain_encryption_1.generateAESKey)();
|
|
325
|
+
const encryptedData = yield (0, curtain_encryption_1.encryptAESData)(aesKey, data);
|
|
326
|
+
const encryptedKey = yield (0, curtain_encryption_1.encryptAESKey)(encryption.publicKey, yield (0, curtain_encryption_1.exportAESKey)(aesKey));
|
|
327
|
+
const encryptedIV = yield (0, curtain_encryption_1.encryptAESKey)(encryption.publicKey, (0, curtain_encryption_1.base64ToArrayBuffer)(encryptedData.iv));
|
|
328
|
+
const payload = {
|
|
329
|
+
encryptedData: encryptedData.encrypted,
|
|
330
|
+
encryptedKey: (0, curtain_encryption_1.arrayBufferToBase64String)(encryptedKey),
|
|
331
|
+
encryptedIV: (0, curtain_encryption_1.arrayBufferToBase64String)(encryptedIV)
|
|
332
|
+
};
|
|
333
|
+
form.append("encryptedKey", payload.encryptedKey);
|
|
334
|
+
form.append("encryptedIV", payload.encryptedIV);
|
|
335
|
+
form.append("file", new Blob([payload.encryptedData], { type: 'text/json' }), "curtain-settings.json");
|
|
336
|
+
}
|
|
337
|
+
else {
|
|
338
|
+
form.append("file", new Blob([data], { type: 'text/json' }), "curtain-settings.json");
|
|
339
|
+
}
|
|
340
|
+
}
|
|
341
|
+
if ("enable" in sessionData) {
|
|
342
|
+
if (sessionData["enable"]) {
|
|
343
|
+
form.append("enable", "True");
|
|
344
|
+
}
|
|
345
|
+
else {
|
|
346
|
+
form.append("enable", "False");
|
|
347
|
+
}
|
|
348
|
+
}
|
|
349
|
+
if (encryption.encrypted) {
|
|
350
|
+
form.append("encrypted", "True");
|
|
324
351
|
}
|
|
325
352
|
else {
|
|
326
|
-
|
|
353
|
+
form.append("encrypted", "False");
|
|
327
354
|
}
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
355
|
+
if (encryption.e2e) {
|
|
356
|
+
form.append("e2e", "True");
|
|
357
|
+
}
|
|
358
|
+
else {
|
|
359
|
+
form.append("e2e", "False");
|
|
360
|
+
}
|
|
361
|
+
let headers = new axios_1.AxiosHeaders();
|
|
362
|
+
headers["Accept"] = "application/json";
|
|
363
|
+
headers["Content-Type"] = "multipart/form-data";
|
|
364
|
+
return this.axiosInstance.patch(this.baseURL + "curtain/" + linkId + "/", form, { responseType: "json" });
|
|
334
365
|
});
|
|
335
366
|
}
|
|
336
367
|
getSessionSettings(linkId) {
|
|
@@ -483,10 +514,12 @@ class CurtainWebAPI {
|
|
|
483
514
|
return this.axiosInstance.post(this.baseURL + "curtain/" + linkId + "/set_encryption_factors/", { encryption_key: encryptedAESKey, encryption_iv: encryptedIV }, { headers: headers, responseType: "json" }).then((response) => { return response; });
|
|
484
515
|
}
|
|
485
516
|
getEncryptionFactors(linkId) {
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
|
|
489
|
-
|
|
517
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
518
|
+
let headers = new axios_1.AxiosHeaders();
|
|
519
|
+
headers["Accept"] = "application/json";
|
|
520
|
+
headers["Content-Type"] = "application/json";
|
|
521
|
+
return yield this.axiosInstance.get(this.baseURL + "curtain/" + linkId + "/get_encryption_factors/", { headers: headers, responseType: "json" });
|
|
522
|
+
});
|
|
490
523
|
}
|
|
491
524
|
}
|
|
492
525
|
exports.CurtainWebAPI = CurtainWebAPI;
|
package/package.json
CHANGED
|
@@ -299,27 +299,55 @@ export class CurtainWebAPI {
|
|
|
299
299
|
});
|
|
300
300
|
}
|
|
301
301
|
|
|
302
|
-
updateSession(sessionData: any, linkId: string
|
|
303
|
-
|
|
302
|
+
async updateSession(sessionData: any, linkId: string, encryption: CurtainEncryption = {
|
|
303
|
+
encrypted: false,
|
|
304
|
+
e2e: false,
|
|
305
|
+
}) {
|
|
306
|
+
let form: FormData = new FormData();
|
|
304
307
|
if ("file" in sessionData) {
|
|
305
|
-
|
|
306
|
-
|
|
308
|
+
let data = JSON.stringify(sessionData["file"], replacer)
|
|
309
|
+
if (encryption.encrypted && encryption.e2e && encryption.publicKey !== undefined) {
|
|
310
|
+
const aesKey = await generateAESKey()
|
|
311
|
+
const encryptedData = await encryptAESData(aesKey, data)
|
|
312
|
+
const encryptedKey = await encryptAESKey(encryption.publicKey, await exportAESKey(aesKey))
|
|
313
|
+
const encryptedIV = await encryptAESKey(encryption.publicKey, base64ToArrayBuffer(encryptedData.iv))
|
|
314
|
+
const payload = {
|
|
315
|
+
encryptedData: encryptedData.encrypted,
|
|
316
|
+
encryptedKey: arrayBufferToBase64String(encryptedKey),
|
|
317
|
+
encryptedIV: arrayBufferToBase64String(encryptedIV)
|
|
318
|
+
}
|
|
319
|
+
|
|
320
|
+
form.append("encryptedKey", payload.encryptedKey)
|
|
321
|
+
form.append("encryptedIV", payload.encryptedIV)
|
|
322
|
+
form.append("file", new Blob([payload.encryptedData], {type: 'text/json'}), "curtain-settings.json")
|
|
323
|
+
} else {
|
|
324
|
+
form.append("file", new Blob([data], {type: 'text/json'}), "curtain-settings.json")
|
|
325
|
+
}
|
|
307
326
|
}
|
|
308
327
|
if ("enable" in sessionData) {
|
|
309
328
|
if (sessionData["enable"]) {
|
|
310
|
-
|
|
329
|
+
form.append("enable", "True")
|
|
311
330
|
} else {
|
|
312
|
-
|
|
331
|
+
form.append("enable", "False")
|
|
313
332
|
}
|
|
314
333
|
}
|
|
315
334
|
|
|
335
|
+
if (encryption.encrypted) {
|
|
336
|
+
form.append("encrypted", "True")
|
|
337
|
+
} else {
|
|
338
|
+
form.append("encrypted", "False")
|
|
339
|
+
}
|
|
340
|
+
if (encryption.e2e) {
|
|
341
|
+
form.append("e2e", "True")
|
|
342
|
+
} else {
|
|
343
|
+
form.append("e2e", "False")
|
|
344
|
+
}
|
|
345
|
+
|
|
316
346
|
let headers = new AxiosHeaders();
|
|
317
347
|
headers["Accept"] = "application/json";
|
|
318
348
|
headers["Content-Type"] = "multipart/form-data";
|
|
319
349
|
|
|
320
|
-
return this.axiosInstance.patch(this.baseURL + "curtain/" + linkId + "/",
|
|
321
|
-
return response;
|
|
322
|
-
});
|
|
350
|
+
return this.axiosInstance.patch(this.baseURL + "curtain/" + linkId + "/", form, {responseType:"json"})
|
|
323
351
|
}
|
|
324
352
|
|
|
325
353
|
getSessionSettings(linkId: string) {
|
|
@@ -497,11 +525,11 @@ export class CurtainWebAPI {
|
|
|
497
525
|
return this.axiosInstance.post(this.baseURL + "curtain/" + linkId + "/set_encryption_factors/", {encryption_key: encryptedAESKey, encryption_iv: encryptedIV}, {headers: headers, responseType: "json"}).then((response) => {return response;});
|
|
498
526
|
}
|
|
499
527
|
|
|
500
|
-
getEncryptionFactors(linkId: string) {
|
|
528
|
+
async getEncryptionFactors(linkId: string) {
|
|
501
529
|
let headers = new AxiosHeaders();
|
|
502
530
|
headers["Accept"] = "application/json";
|
|
503
531
|
headers["Content-Type"] = "application/json";
|
|
504
|
-
return this.axiosInstance.get(this.baseURL + "curtain/" + linkId + "/get_encryption_factors/", {headers: headers, responseType: "json"})
|
|
532
|
+
return await this.axiosInstance.get(this.baseURL + "curtain/" + linkId + "/get_encryption_factors/", {headers: headers, responseType: "json"})
|
|
505
533
|
}
|
|
506
534
|
}
|
|
507
535
|
|