@protontech/drive-sdk 0.0.10 → 0.0.11
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/crypto/driveCrypto.d.ts +11 -0
- package/dist/crypto/driveCrypto.js +16 -0
- package/dist/crypto/driveCrypto.js.map +1 -1
- package/dist/crypto/interface.d.ts +2 -0
- package/dist/crypto/openPGPCrypto.d.ts +2 -0
- package/dist/crypto/openPGPCrypto.js +8 -0
- package/dist/crypto/openPGPCrypto.js.map +1 -1
- package/dist/interface/index.d.ts +3 -3
- package/dist/interface/index.js +2 -2
- package/dist/interface/index.js.map +1 -1
- package/dist/interface/nodes.d.ts +9 -0
- package/dist/interface/nodes.js.map +1 -1
- package/dist/interface/sharing.d.ts +22 -2
- package/dist/interface/telemetry.d.ts +10 -8
- package/dist/interface/telemetry.js +7 -7
- package/dist/interface/telemetry.js.map +1 -1
- package/dist/internal/apiService/errors.js +1 -1
- package/dist/internal/apiService/errors.js.map +1 -1
- package/dist/internal/apiService/errors.test.js +7 -0
- package/dist/internal/apiService/errors.test.js.map +1 -1
- package/dist/internal/download/interface.d.ts +2 -2
- package/dist/internal/download/telemetry.js +7 -5
- package/dist/internal/download/telemetry.js.map +1 -1
- package/dist/internal/download/telemetry.test.js +10 -6
- package/dist/internal/download/telemetry.test.js.map +1 -1
- package/dist/internal/nodes/cache.js +25 -1
- package/dist/internal/nodes/cache.js.map +1 -1
- package/dist/internal/nodes/cache.test.js +33 -0
- package/dist/internal/nodes/cache.test.js.map +1 -1
- package/dist/internal/nodes/cryptoService.d.ts +8 -3
- package/dist/internal/nodes/cryptoService.js +11 -11
- package/dist/internal/nodes/cryptoService.js.map +1 -1
- package/dist/internal/nodes/cryptoService.test.js +2 -2
- package/dist/internal/nodes/cryptoService.test.js.map +1 -1
- package/dist/internal/nodes/index.d.ts +1 -1
- package/dist/internal/nodes/interface.d.ts +2 -2
- package/dist/internal/nodes/nodesManagement.js +1 -1
- package/dist/internal/nodes/nodesManagement.js.map +1 -1
- package/dist/internal/nodes/nodesManagement.test.js +1 -1
- package/dist/internal/nodes/nodesManagement.test.js.map +1 -1
- package/dist/internal/shares/cryptoService.js +4 -4
- package/dist/internal/shares/cryptoService.js.map +1 -1
- package/dist/internal/shares/cryptoService.test.js +2 -2
- package/dist/internal/shares/cryptoService.test.js.map +1 -1
- package/dist/internal/shares/manager.d.ts +2 -2
- package/dist/internal/shares/manager.js +2 -2
- package/dist/internal/shares/manager.js.map +1 -1
- package/dist/internal/sharing/apiService.d.ts +2 -2
- package/dist/internal/sharing/apiService.js +1 -1
- package/dist/internal/sharing/apiService.js.map +1 -1
- package/dist/internal/sharing/cryptoService.d.ts +12 -3
- package/dist/internal/sharing/cryptoService.js +110 -1
- package/dist/internal/sharing/cryptoService.js.map +1 -1
- package/dist/internal/sharing/cryptoService.test.js +132 -0
- package/dist/internal/sharing/cryptoService.test.js.map +1 -0
- package/dist/internal/sharing/index.js +1 -1
- package/dist/internal/sharing/index.js.map +1 -1
- package/dist/internal/sharing/interface.d.ts +4 -0
- package/dist/internal/sharing/sharingAccess.d.ts +3 -3
- package/dist/internal/sharing/sharingAccess.js +29 -4
- package/dist/internal/sharing/sharingAccess.js.map +1 -1
- package/dist/internal/sharing/sharingAccess.test.js +65 -0
- package/dist/internal/sharing/sharingAccess.test.js.map +1 -1
- package/dist/internal/sharing/sharingManagement.js +2 -2
- package/dist/internal/sharing/sharingManagement.js.map +1 -1
- package/dist/internal/sharing/sharingManagement.test.js +3 -3
- package/dist/internal/sharing/sharingManagement.test.js.map +1 -1
- package/dist/internal/upload/interface.d.ts +2 -2
- package/dist/internal/upload/telemetry.js +7 -5
- package/dist/internal/upload/telemetry.js.map +1 -1
- package/dist/internal/upload/telemetry.test.js +10 -6
- package/dist/internal/upload/telemetry.test.js.map +1 -1
- package/dist/protonDriveClient.d.ts +16 -1
- package/dist/protonDriveClient.js +23 -2
- package/dist/protonDriveClient.js.map +1 -1
- package/dist/transformers.d.ts +1 -1
- package/dist/transformers.js +16 -2
- package/dist/transformers.js.map +1 -1
- package/package.json +1 -1
- package/src/crypto/driveCrypto.ts +30 -0
- package/src/crypto/interface.ts +6 -0
- package/src/crypto/openPGPCrypto.ts +13 -0
- package/src/interface/index.ts +3 -3
- package/src/interface/nodes.ts +9 -0
- package/src/interface/sharing.ts +24 -2
- package/src/interface/telemetry.ts +8 -7
- package/src/internal/apiService/errors.test.ts +8 -0
- package/src/internal/apiService/errors.ts +1 -1
- package/src/internal/download/interface.ts +2 -2
- package/src/internal/download/telemetry.test.ts +18 -14
- package/src/internal/download/telemetry.ts +8 -5
- package/src/internal/nodes/cache.test.ts +41 -2
- package/src/internal/nodes/cache.ts +31 -3
- package/src/internal/nodes/cryptoService.test.ts +3 -3
- package/src/internal/nodes/cryptoService.ts +14 -13
- package/src/internal/nodes/index.ts +1 -1
- package/src/internal/nodes/interface.ts +2 -2
- package/src/internal/nodes/nodesManagement.test.ts +6 -6
- package/src/internal/nodes/nodesManagement.ts +2 -2
- package/src/internal/shares/cryptoService.test.ts +2 -2
- package/src/internal/shares/cryptoService.ts +7 -7
- package/src/internal/shares/manager.ts +4 -4
- package/src/internal/sharing/apiService.ts +10 -10
- package/src/internal/sharing/cryptoService.test.ts +148 -0
- package/src/internal/sharing/cryptoService.ts +137 -3
- package/src/internal/sharing/index.ts +1 -1
- package/src/internal/sharing/interface.ts +4 -0
- package/src/internal/sharing/sharingAccess.test.ts +74 -0
- package/src/internal/sharing/sharingAccess.ts +29 -5
- package/src/internal/sharing/sharingManagement.test.ts +3 -3
- package/src/internal/sharing/sharingManagement.ts +2 -2
- package/src/internal/upload/interface.ts +2 -2
- package/src/internal/upload/telemetry.test.ts +10 -6
- package/src/internal/upload/telemetry.ts +8 -5
- package/src/protonDriveClient.ts +27 -2
- package/src/transformers.ts +31 -5
- package/dist/cache/index.d.ts +0 -2
- package/dist/cache/index.js +0 -6
- package/dist/cache/index.js.map +0 -1
- package/dist/cache/interface.d.ts +0 -105
- package/dist/cache/interface.js +0 -3
- package/dist/cache/interface.js.map +0 -1
- package/dist/cache/memoryCache.d.ts +0 -18
- package/dist/cache/memoryCache.js +0 -78
- package/dist/cache/memoryCache.js.map +0 -1
- package/dist/cache/memoryCache.test.js +0 -121
- package/dist/cache/memoryCache.test.js.map +0 -1
- package/dist/crypto/hmac.d.ts +0 -22
- package/dist/crypto/hmac.js +0 -44
- package/dist/crypto/hmac.js.map +0 -1
- package/dist/crypto/utils.d.ts +0 -2
- package/dist/crypto/utils.js +0 -35
- package/dist/crypto/utils.js.map +0 -1
- package/dist/errors.d.ts +0 -138
- package/dist/errors.js +0 -163
- package/dist/errors.js.map +0 -1
- package/dist/interface/account.js +0 -3
- package/dist/interface/account.js.map +0 -1
- package/dist/interface/author.d.ts +0 -26
- package/dist/interface/author.js +0 -3
- package/dist/interface/author.js.map +0 -1
- package/dist/interface/download.d.ts +0 -29
- package/dist/interface/download.js +0 -3
- package/dist/interface/download.js.map +0 -1
- package/dist/interface/httpClient.d.ts +0 -38
- package/dist/interface/httpClient.js +0 -3
- package/dist/interface/httpClient.js.map +0 -1
- package/dist/interface/result.d.ts +0 -9
- package/dist/interface/result.js +0 -11
- package/dist/interface/result.js.map +0 -1
- package/dist/interface/thumbnail.d.ts +0 -17
- package/dist/interface/thumbnail.js +0 -9
- package/dist/interface/thumbnail.js.map +0 -1
- package/dist/interface/upload.d.ts +0 -16
- package/dist/interface/upload.js +0 -3
- package/dist/interface/upload.js.map +0 -1
- package/dist/internal/apiService/errorCodes.d.ts +0 -30
- package/dist/internal/apiService/errorCodes.js +0 -11
- package/dist/internal/apiService/errorCodes.js.map +0 -1
- package/dist/internal/apiService/observerStream.d.ts +0 -3
- package/dist/internal/apiService/observerStream.js +0 -15
- package/dist/internal/apiService/observerStream.js.map +0 -1
- package/dist/internal/batchLoading.d.ts +0 -34
- package/dist/internal/batchLoading.js +0 -68
- package/dist/internal/batchLoading.js.map +0 -1
- package/dist/internal/batchLoading.test.d.ts +0 -1
- package/dist/internal/batchLoading.test.js +0 -50
- package/dist/internal/batchLoading.test.js.map +0 -1
- package/dist/internal/download/controller.d.ts +0 -8
- package/dist/internal/download/controller.js +0 -22
- package/dist/internal/download/controller.js.map +0 -1
- package/dist/internal/download/queue.d.ts +0 -5
- package/dist/internal/download/queue.js +0 -31
- package/dist/internal/download/queue.js.map +0 -1
- package/dist/internal/errors.js +0 -28
- package/dist/internal/errors.js.map +0 -1
- package/dist/internal/errors.test.js +0 -22
- package/dist/internal/errors.test.js.map +0 -1
- package/dist/internal/events/interface.d.ts +0 -47
- package/dist/internal/events/interface.js +0 -12
- package/dist/internal/events/interface.js.map +0 -1
- package/dist/internal/nodes/mediaTypes.d.ts +0 -2
- package/dist/internal/nodes/mediaTypes.js +0 -13
- package/dist/internal/nodes/mediaTypes.js.map +0 -1
- package/dist/internal/nodes/validations.d.ts +0 -4
- package/dist/internal/nodes/validations.js +0 -21
- package/dist/internal/nodes/validations.js.map +0 -1
- package/dist/internal/uids.d.ts +0 -38
- package/dist/internal/uids.js +0 -85
- package/dist/internal/uids.js.map +0 -1
- package/dist/internal/upload/chunkStreamReader.d.ts +0 -13
- package/dist/internal/upload/chunkStreamReader.js +0 -46
- package/dist/internal/upload/chunkStreamReader.js.map +0 -1
- package/dist/internal/upload/chunkStreamReader.test.d.ts +0 -1
- package/dist/internal/upload/chunkStreamReader.test.js +0 -75
- package/dist/internal/upload/chunkStreamReader.test.js.map +0 -1
- package/dist/internal/upload/controller.d.ts +0 -8
- package/dist/internal/upload/controller.js +0 -25
- package/dist/internal/upload/controller.js.map +0 -1
- package/dist/internal/upload/digests.d.ts +0 -8
- package/dist/internal/upload/digests.js +0 -22
- package/dist/internal/upload/digests.js.map +0 -1
- package/dist/internal/upload/queue.d.ts +0 -5
- package/dist/internal/upload/queue.js +0 -32
- package/dist/internal/upload/queue.js.map +0 -1
- package/dist/internal/utils.d.ts +0 -1
- package/dist/internal/utils.js +0 -13
- package/dist/internal/utils.js.map +0 -1
- package/dist/internal/wait.d.ts +0 -3
- package/dist/internal/wait.js +0 -28
- package/dist/internal/wait.js.map +0 -1
- package/dist/internal/wait.test.d.ts +0 -1
- package/dist/internal/wait.test.js +0 -21
- package/dist/internal/wait.test.js.map +0 -1
- /package/dist/{cache/memoryCache.test.d.ts → internal/sharing/cryptoService.test.d.ts} +0 -0
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.UploadQueue = void 0;
|
|
4
|
-
const wait_1 = require("../wait");
|
|
5
|
-
/**
|
|
6
|
-
* A queue that limits the number of concurrent uploads.
|
|
7
|
-
*
|
|
8
|
-
* This is used to limit the number of concurrent uploads to avoid
|
|
9
|
-
* overloading the server, or get rate limited.
|
|
10
|
-
*
|
|
11
|
-
* Each file upload consumes memory and is limited by the number of
|
|
12
|
-
* concurrent block uploads for each file.
|
|
13
|
-
*
|
|
14
|
-
* This queue is straitforward and does not have any priority mechanism
|
|
15
|
-
* or other features, such as limiting total number of blocks being
|
|
16
|
-
* uploaded. That is something we want to add in the future to be
|
|
17
|
-
* more performant for many small file uploads.
|
|
18
|
-
*/
|
|
19
|
-
const MAX_CONCURRENT_UPLOADS = 5;
|
|
20
|
-
class UploadQueue {
|
|
21
|
-
capacity = 0;
|
|
22
|
-
// TODO: use expected size to control the size of the queue
|
|
23
|
-
async waitForCapacity(signal) {
|
|
24
|
-
await (0, wait_1.waitForCondition)(() => this.capacity < MAX_CONCURRENT_UPLOADS, signal);
|
|
25
|
-
this.capacity++;
|
|
26
|
-
}
|
|
27
|
-
releaseCapacity() {
|
|
28
|
-
this.capacity--;
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
exports.UploadQueue = UploadQueue;
|
|
32
|
-
//# sourceMappingURL=queue.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"queue.js","sourceRoot":"","sources":["../../../src/internal/upload/queue.ts"],"names":[],"mappings":";;;AAAA,kCAA2C;AAE3C;;;;;;;;;;;;;GAaG;AACH,MAAM,sBAAsB,GAAG,CAAC,CAAC;AAEjC,MAAa,WAAW;IACZ,QAAQ,GAAG,CAAC,CAAC;IAErB,2DAA2D;IAC3D,KAAK,CAAC,eAAe,CAAC,MAAoB;QACtC,MAAM,IAAA,uBAAgB,EAAC,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,GAAG,sBAAsB,EAAE,MAAM,CAAC,CAAC;QAC7E,IAAI,CAAC,QAAQ,EAAE,CAAC;IACpB,CAAC;IAED,eAAe;QACX,IAAI,CAAC,QAAQ,EAAE,CAAC;IACpB,CAAC;CACJ;AAZD,kCAYC"}
|
package/dist/internal/utils.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export declare function mergeUint8Arrays(arrays: Uint8Array[]): Uint8Array;
|
package/dist/internal/utils.js
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.mergeUint8Arrays = mergeUint8Arrays;
|
|
4
|
-
function mergeUint8Arrays(arrays) {
|
|
5
|
-
const length = arrays.reduce((sum, arr) => sum + arr.length, 0);
|
|
6
|
-
const chunksAll = new Uint8Array(length);
|
|
7
|
-
arrays.reduce((position, arr) => {
|
|
8
|
-
chunksAll.set(arr, position);
|
|
9
|
-
return position + arr.length;
|
|
10
|
-
}, 0);
|
|
11
|
-
return chunksAll;
|
|
12
|
-
}
|
|
13
|
-
//# sourceMappingURL=utils.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/internal/utils.ts"],"names":[],"mappings":";;AAAA,4CAQC;AARD,SAAgB,gBAAgB,CAAC,MAAoB;IACjD,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,GAAG,GAAG,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;IAChE,MAAM,SAAS,GAAG,IAAI,UAAU,CAAC,MAAM,CAAC,CAAC;IACzC,MAAM,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,GAAG,EAAE,EAAE;QAC5B,SAAS,CAAC,GAAG,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAC7B,OAAO,QAAQ,GAAG,GAAG,CAAC,MAAM,CAAC;IACjC,CAAC,EAAE,CAAC,CAAC,CAAC;IACN,OAAO,SAAS,CAAC;AACrB,CAAC"}
|
package/dist/internal/wait.d.ts
DELETED
package/dist/internal/wait.js
DELETED
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.waitForCondition = waitForCondition;
|
|
4
|
-
exports.waitSeconds = waitSeconds;
|
|
5
|
-
exports.wait = wait;
|
|
6
|
-
const errors_1 = require("../errors");
|
|
7
|
-
const WAIT_TIME = 50;
|
|
8
|
-
function waitForCondition(callback, signal) {
|
|
9
|
-
return new Promise((resolve, reject) => {
|
|
10
|
-
const waitForCondition = () => {
|
|
11
|
-
if (signal?.aborted) {
|
|
12
|
-
return reject(new errors_1.AbortError());
|
|
13
|
-
}
|
|
14
|
-
if (callback()) {
|
|
15
|
-
return resolve();
|
|
16
|
-
}
|
|
17
|
-
setTimeout(waitForCondition, WAIT_TIME);
|
|
18
|
-
};
|
|
19
|
-
waitForCondition();
|
|
20
|
-
});
|
|
21
|
-
}
|
|
22
|
-
async function waitSeconds(seconds) {
|
|
23
|
-
return wait(seconds * 1000);
|
|
24
|
-
}
|
|
25
|
-
async function wait(miliseconds) {
|
|
26
|
-
return new Promise((resolve) => setTimeout(resolve, miliseconds));
|
|
27
|
-
}
|
|
28
|
-
//# sourceMappingURL=wait.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"wait.js","sourceRoot":"","sources":["../../src/internal/wait.ts"],"names":[],"mappings":";;AAIA,4CAaC;AAED,kCAEC;AAED,oBAEC;AAzBD,sCAAuC;AAEvC,MAAM,SAAS,GAAG,EAAE,CAAC;AAErB,SAAgB,gBAAgB,CAAC,QAAuB,EAAE,MAAoB;IAC1E,OAAO,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACzC,MAAM,gBAAgB,GAAG,GAAG,EAAE;YAC1B,IAAI,MAAM,EAAE,OAAO,EAAE,CAAC;gBAClB,OAAO,MAAM,CAAC,IAAI,mBAAU,EAAE,CAAC,CAAC;YACpC,CAAC;YACD,IAAI,QAAQ,EAAE,EAAE,CAAC;gBACb,OAAO,OAAO,EAAE,CAAC;YACrB,CAAC;YACD,UAAU,CAAC,gBAAgB,EAAE,SAAS,CAAC,CAAC;QAC5C,CAAC,CAAC;QACF,gBAAgB,EAAE,CAAC;IACvB,CAAC,CAAC,CAAC;AACP,CAAC;AAEM,KAAK,UAAU,WAAW,CAAC,OAAe;IAC7C,OAAO,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,CAAC;AAChC,CAAC;AAEM,KAAK,UAAU,IAAI,CAAC,WAAmB;IAC1C,OAAO,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC,CAAC;AAC5E,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const wait_1 = require("./wait");
|
|
4
|
-
describe('waitForCondition', () => {
|
|
5
|
-
it('should resolve immediately if condition is met', async () => {
|
|
6
|
-
const callback = jest.fn().mockReturnValue(true);
|
|
7
|
-
await (0, wait_1.waitForCondition)(callback);
|
|
8
|
-
expect(callback).toHaveBeenCalled();
|
|
9
|
-
});
|
|
10
|
-
it('should resolve after condition is met', async () => {
|
|
11
|
-
const callback = jest.fn().mockReturnValueOnce(false).mockReturnValueOnce(true);
|
|
12
|
-
await (0, wait_1.waitForCondition)(callback);
|
|
13
|
-
expect(callback).toHaveBeenCalledTimes(2);
|
|
14
|
-
});
|
|
15
|
-
it('should reject if signal is aborted', async () => {
|
|
16
|
-
const signal = { aborted: true };
|
|
17
|
-
const callback = jest.fn().mockReturnValue(false);
|
|
18
|
-
await expect((0, wait_1.waitForCondition)(callback, signal)).rejects.toThrow('aborted');
|
|
19
|
-
});
|
|
20
|
-
});
|
|
21
|
-
//# sourceMappingURL=wait.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"wait.test.js","sourceRoot":"","sources":["../../src/internal/wait.test.ts"],"names":[],"mappings":";;AAAA,iCAA0C;AAE1C,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAC9B,EAAE,CAAC,gDAAgD,EAAE,KAAK,IAAI,EAAE;QAC5D,MAAM,QAAQ,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QACjD,MAAM,IAAA,uBAAgB,EAAC,QAAQ,CAAC,CAAC;QACjC,MAAM,CAAC,QAAQ,CAAC,CAAC,gBAAgB,EAAE,CAAC;IACxC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uCAAuC,EAAE,KAAK,IAAI,EAAE;QACnD,MAAM,QAAQ,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;QAChF,MAAM,IAAA,uBAAgB,EAAC,QAAQ,CAAC,CAAC;QACjC,MAAM,CAAC,QAAQ,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oCAAoC,EAAE,KAAK,IAAI,EAAE;QAChD,MAAM,MAAM,GAAG,EAAE,OAAO,EAAE,IAAI,EAAwB,CAAC;QACvD,MAAM,QAAQ,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;QAClD,MAAM,MAAM,CAAC,IAAA,uBAAgB,EAAC,QAAQ,EAAE,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IAChF,CAAC,CAAC,CAAC;AACP,CAAC,CAAC,CAAC"}
|
|
File without changes
|