@lifeready/core 1.0.21 → 1.0.22
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/bundles/lifeready-core.umd.js +9745 -9700
- package/bundles/lifeready-core.umd.js.map +1 -1
- package/bundles/lifeready-core.umd.min.js +2 -2
- package/bundles/lifeready-core.umd.min.js.map +1 -1
- package/esm2015/lib/_common/run-outside-angular.js +2 -2
- package/esm2015/lib/_common/types.js +1 -1
- package/esm2015/lib/api/lr-apollo.service.js +3 -3
- package/esm2015/lib/api/lr-graphql/lr-graphql.service.js +3 -3
- package/esm2015/lib/api/query-processor/common-processors.service.js +3 -3
- package/esm2015/lib/api/query-processor/query-processor.service.js +4 -4
- package/esm2015/lib/api/query-processor/tp-password-reset-processor.service.js +6 -5
- package/esm2015/lib/api/types/lr-graphql.types.js +1 -1
- package/esm2015/lib/auth/auth.gql.js +1 -28
- package/esm2015/lib/auth/auth.types.js +1 -1
- package/esm2015/lib/auth/life-ready-auth.service.js +32 -31
- package/esm2015/lib/category/category.gql.js +1 -1
- package/esm2015/lib/category/category.service.js +6 -6
- package/esm2015/lib/contact-card/contact-card.gql.js +79 -0
- package/esm2015/lib/contact-card/contact-card.service.js +154 -0
- package/esm2015/lib/contact-card/contact-card2.gql.js +29 -0
- package/esm2015/lib/contact-card/contact-card2.service.js +103 -0
- package/esm2015/lib/encryption/encryption.service.js +189 -0
- package/esm2015/lib/file-upload/file-upload.service.js +74 -0
- package/esm2015/lib/file-upload/file-upload.types.js +1 -0
- package/esm2015/lib/{auth → idle}/idle.service.js +7 -7
- package/esm2015/lib/{auth → idle}/idle.types.js +1 -1
- package/esm2015/lib/items2/item2.service.js +20 -20
- package/esm2015/lib/key/key-factory.service.js +237 -0
- package/esm2015/lib/{cryptography → key}/key-graph.service.js +10 -10
- package/esm2015/lib/key/key-meta.service.js +200 -0
- package/esm2015/lib/key/key.service.js +124 -0
- package/esm2015/lib/key/key.types.js +11 -0
- package/esm2015/lib/key-exchange/key-exchange.gql.js +188 -0
- package/esm2015/lib/key-exchange/key-exchange.service.js +443 -0
- package/esm2015/lib/key-exchange/key-exchange.types.js +7 -0
- package/esm2015/lib/key-exchange/key-exchange2.gql.js +171 -0
- package/esm2015/lib/key-exchange/key-exchange2.service.js +500 -0
- package/esm2015/lib/lbop/lbop.service.js +355 -0
- package/esm2015/lib/life-ready.module.js +2 -27
- package/esm2015/lib/lock/lock.gql.js +40 -0
- package/esm2015/lib/lock/lock.service.js +64 -0
- package/esm2015/lib/message/message.gql.js +32 -0
- package/esm2015/lib/message/message.service.js +116 -0
- package/esm2015/lib/message/message.types.js +1 -0
- package/esm2015/lib/password/password.gql.js +28 -0
- package/esm2015/lib/password/password.service.js +315 -0
- package/esm2015/lib/persist/persist.service.js +180 -0
- package/esm2015/lib/profile/profile-details.service.js +214 -0
- package/esm2015/lib/profile/profile.gql.js +97 -0
- package/esm2015/lib/profile/profile.service.js +169 -0
- package/esm2015/lib/profile/profile.types.js +34 -0
- package/esm2015/lib/record/record-attachment.service.js +15 -15
- package/esm2015/lib/record/record.service.js +3 -3
- package/esm2015/lib/register/register.service.js +172 -0
- package/esm2015/lib/scenario/scenario.controller.js +2 -2
- package/esm2015/lib/scenario/{scenario.gql.private.js → scenario.private.gql.js} +1 -1
- package/esm2015/lib/scenario/scenario.service.js +9 -9
- package/esm2015/lib/scenario/scenario.types.js +1 -1
- package/esm2015/lib/shared-contact-card/shared-contact-card.service.js +119 -0
- package/esm2015/lib/shared-contact-card/shared-contact-card2.gql.js +41 -0
- package/esm2015/lib/shared-contact-card/shared-contact-card2.service.js +117 -0
- package/esm2015/lib/slip39/slip39.service.js +169 -0
- package/esm2015/lib/time/time.service.js +146 -0
- package/esm2015/lib/tp-assembly/tp-assembly.js +365 -0
- package/esm2015/lib/tp-assembly/tp-assembly.private.gql.js +22 -0
- package/esm2015/lib/tp-assembly/tp-assembly.types.js +1 -0
- package/esm2015/lib/tp-password-reset/tp-password-reset-request.service.js +100 -0
- package/esm2015/lib/tp-password-reset/tp-password-reset-user.service.js +117 -0
- package/esm2015/lib/tp-password-reset/tp-password-reset.constants.js +4 -0
- package/esm2015/lib/tp-password-reset/tp-password-reset.controller.js +34 -0
- package/esm2015/lib/tp-password-reset/tp-password-reset.gql.js +74 -0
- package/esm2015/lib/tp-password-reset/tp-password-reset.private.gql.js +165 -0
- package/esm2015/lib/tp-password-reset/tp-password-reset.private.service.js +54 -0
- package/esm2015/lib/tp-password-reset/tp-password-reset.service.js +92 -0
- package/esm2015/lib/tp-password-reset/tp-password-reset.types.js +1 -0
- package/esm2015/lib/trusted-party/trusted-party.gql.js +148 -0
- package/esm2015/lib/trusted-party/trusted-party.service.js +326 -0
- package/esm2015/lib/trusted-party/trusted-party.types.js +41 -0
- package/esm2015/lib/trusted-party/trusted-party2.gql.js +64 -0
- package/esm2015/lib/trusted-party/trusted-party2.gql.private.js +25 -0
- package/esm2015/lib/trusted-party/trusted-party2.service.js +224 -0
- package/esm2015/lib/trusted-party/trusted-party2.types.js +1 -0
- package/esm2015/lib/two-factor/two-factor.service.js +74 -0
- package/esm2015/lib/user/user.gql.js +60 -0
- package/esm2015/lib/user/user.service.js +79 -0
- package/esm2015/lib/user/user.types.js +1 -0
- package/esm2015/lib/web-crypto/web-crypto.service.js +29 -0
- package/esm2015/lifeready-core.js +15 -13
- package/esm2015/public-api.js +49 -51
- package/fesm2015/lifeready-core.js +9232 -9214
- package/fesm2015/lifeready-core.js.map +1 -1
- package/lib/_common/types.d.ts +3 -1
- package/lib/api/lr-apollo.service.d.ts +1 -1
- package/lib/api/lr-graphql/lr-graphql.service.d.ts +1 -1
- package/lib/api/query-processor/common-processors.service.d.ts +1 -1
- package/lib/api/query-processor/query-processor.service.d.ts +1 -1
- package/lib/api/query-processor/tp-password-reset-processor.service.d.ts +1 -1
- package/lib/api/types/lr-graphql.types.d.ts +11 -0
- package/lib/auth/auth.gql.d.ts +0 -3
- package/lib/auth/auth.types.d.ts +2 -2
- package/lib/auth/life-ready-auth.service.d.ts +12 -12
- package/lib/category/category.gql.d.ts +1 -1
- package/lib/category/category.service.d.ts +2 -2
- package/lib/{api → contact-card}/contact-card.service.d.ts +9 -9
- package/lib/contact-card/contact-card2.gql.d.ts +25 -0
- package/lib/{api → contact-card}/contact-card2.service.d.ts +11 -12
- package/lib/{cryptography → encryption}/encryption.service.d.ts +2 -2
- package/lib/{api/file.service.d.ts → file-upload/file-upload.service.d.ts} +3 -7
- package/lib/file-upload/file-upload.types.d.ts +5 -0
- package/lib/{auth → idle}/idle.service.d.ts +4 -4
- package/lib/items2/item2.service.d.ts +11 -11
- package/lib/{cryptography → key}/key-factory.service.d.ts +2 -2
- package/lib/{cryptography → key}/key-graph.service.d.ts +5 -5
- package/lib/{cryptography → key}/key-meta.service.d.ts +1 -1
- package/lib/{cryptography → key}/key.service.d.ts +2 -2
- package/lib/{cryptography/cryptography.types.d.ts → key/key.types.d.ts} +9 -13
- package/lib/{api → key-exchange}/key-exchange.service.d.ts +5 -5
- package/lib/{api → key-exchange}/key-exchange.types.d.ts +4 -4
- package/lib/{api → key-exchange}/key-exchange2.gql.d.ts +1 -1
- package/lib/{api → key-exchange}/key-exchange2.service.d.ts +71 -18
- package/lib/{auth → lbop}/lbop.service.d.ts +7 -7
- package/lib/{api → lock}/lock.gql.d.ts +1 -1
- package/lib/{api → lock}/lock.service.d.ts +1 -1
- package/lib/message/message.gql.d.ts +13 -0
- package/lib/message/message.service.d.ts +29 -0
- package/lib/message/message.types.d.ts +12 -0
- package/lib/password/password.gql.d.ts +3 -0
- package/lib/{auth → password}/password.service.d.ts +8 -8
- package/lib/{api → persist}/persist.service.d.ts +3 -3
- package/lib/{users → profile}/profile-details.service.d.ts +3 -3
- package/lib/{users → profile}/profile.gql.d.ts +2 -2
- package/lib/{users → profile}/profile.service.d.ts +6 -6
- package/lib/{users → profile}/profile.types.d.ts +1 -1
- package/lib/record/record-attachment.service.d.ts +6 -6
- package/lib/record/record.service.d.ts +1 -1
- package/lib/{auth → register}/register.service.d.ts +4 -4
- package/lib/scenario/scenario.controller.d.ts +1 -1
- package/lib/scenario/scenario.service.d.ts +2 -2
- package/lib/scenario/scenario.types.d.ts +1 -1
- package/lib/{api → shared-contact-card}/shared-contact-card.service.d.ts +9 -9
- package/lib/{api → shared-contact-card}/shared-contact-card2.gql.d.ts +1 -1
- package/lib/{api → shared-contact-card}/shared-contact-card2.service.d.ts +6 -6
- package/lib/{trusted-parties → tp-assembly}/tp-assembly.d.ts +7 -7
- package/lib/{trusted-parties → tp-assembly}/tp-assembly.types.d.ts +1 -1
- package/lib/{trusted-parties → tp-password-reset}/tp-password-reset-request.service.d.ts +4 -8
- package/lib/{trusted-parties → tp-password-reset}/tp-password-reset-user.service.d.ts +7 -13
- package/lib/{trusted-parties → tp-password-reset}/tp-password-reset.controller.d.ts +1 -1
- package/lib/tp-password-reset/tp-password-reset.gql.d.ts +63 -0
- package/lib/{trusted-parties/tp-password-reset.gql.d.ts → tp-password-reset/tp-password-reset.private.gql.d.ts} +1 -63
- package/lib/tp-password-reset/tp-password-reset.private.service.d.ts +59 -0
- package/lib/{trusted-parties → tp-password-reset}/tp-password-reset.service.d.ts +6 -89
- package/lib/tp-password-reset/tp-password-reset.types.d.ts +40 -0
- package/lib/{trusted-parties → trusted-party}/trusted-party.service.d.ts +7 -7
- package/lib/{trusted-parties → trusted-party}/trusted-party.types.d.ts +2 -3
- package/lib/{trusted-parties → trusted-party}/trusted-party2.gql.d.ts +0 -22
- package/lib/trusted-party/trusted-party2.gql.private.d.ts +23 -0
- package/lib/{trusted-parties → trusted-party}/trusted-party2.service.d.ts +11 -35
- package/lib/trusted-party/trusted-party2.types.d.ts +12 -0
- package/lib/{users → user}/user.gql.d.ts +1 -1
- package/lib/{users → user}/user.types.d.ts +1 -1
- package/lifeready-core.d.ts +14 -12
- package/lifeready-core.metadata.json +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +48 -50
- package/esm2015/lib/api/contact-card.gql.js +0 -79
- package/esm2015/lib/api/contact-card.service.js +0 -154
- package/esm2015/lib/api/contact-card2.gql.js +0 -60
- package/esm2015/lib/api/contact-card2.service.js +0 -103
- package/esm2015/lib/api/file.service.js +0 -74
- package/esm2015/lib/api/key-exchange.gql.js +0 -188
- package/esm2015/lib/api/key-exchange.service.js +0 -442
- package/esm2015/lib/api/key-exchange.types.js +0 -7
- package/esm2015/lib/api/key-exchange2.gql.js +0 -171
- package/esm2015/lib/api/key-exchange2.service.js +0 -480
- package/esm2015/lib/api/lock.gql.js +0 -40
- package/esm2015/lib/api/lock.service.js +0 -64
- package/esm2015/lib/api/message.service.js +0 -138
- package/esm2015/lib/api/persist.service.js +0 -181
- package/esm2015/lib/api/shared-contact-card.service.js +0 -119
- package/esm2015/lib/api/shared-contact-card2.gql.js +0 -41
- package/esm2015/lib/api/shared-contact-card2.service.js +0 -117
- package/esm2015/lib/api/time.service.js +0 -146
- package/esm2015/lib/auth/lbop.service.js +0 -355
- package/esm2015/lib/auth/password.service.js +0 -315
- package/esm2015/lib/auth/register.service.js +0 -172
- package/esm2015/lib/auth/two-factor.service.js +0 -74
- package/esm2015/lib/cryptography/cryptography.types.js +0 -11
- package/esm2015/lib/cryptography/encryption.service.js +0 -189
- package/esm2015/lib/cryptography/key-factory.service.js +0 -237
- package/esm2015/lib/cryptography/key-meta.service.js +0 -200
- package/esm2015/lib/cryptography/key.service.js +0 -124
- package/esm2015/lib/cryptography/slip39.service.js +0 -169
- package/esm2015/lib/cryptography/web-crypto.service.js +0 -29
- package/esm2015/lib/trusted-parties/tp-assembly.gql.private.js +0 -22
- package/esm2015/lib/trusted-parties/tp-assembly.js +0 -365
- package/esm2015/lib/trusted-parties/tp-assembly.types.js +0 -1
- package/esm2015/lib/trusted-parties/tp-password-reset-request.service.js +0 -113
- package/esm2015/lib/trusted-parties/tp-password-reset-user.service.js +0 -129
- package/esm2015/lib/trusted-parties/tp-password-reset.constants.js +0 -4
- package/esm2015/lib/trusted-parties/tp-password-reset.controller.js +0 -34
- package/esm2015/lib/trusted-parties/tp-password-reset.gql.js +0 -237
- package/esm2015/lib/trusted-parties/tp-password-reset.service.js +0 -95
- package/esm2015/lib/trusted-parties/trusted-party.gql.js +0 -148
- package/esm2015/lib/trusted-parties/trusted-party.service.js +0 -326
- package/esm2015/lib/trusted-parties/trusted-party.types.js +0 -41
- package/esm2015/lib/trusted-parties/trusted-party2.gql.js +0 -87
- package/esm2015/lib/trusted-parties/trusted-party2.service.js +0 -218
- package/esm2015/lib/users/profile-details.service.js +0 -214
- package/esm2015/lib/users/profile.gql.js +0 -97
- package/esm2015/lib/users/profile.service.js +0 -169
- package/esm2015/lib/users/profile.types.js +0 -34
- package/esm2015/lib/users/user.gql.js +0 -60
- package/esm2015/lib/users/user.service.js +0 -79
- package/esm2015/lib/users/user.types.js +0 -1
- package/lib/api/contact-card2.gql.d.ts +0 -34
- package/lib/api/message.service.d.ts +0 -59
- /package/lib/{api → contact-card}/contact-card.gql.d.ts +0 -0
- /package/lib/{auth → idle}/idle.types.d.ts +0 -0
- /package/lib/{api → key-exchange}/key-exchange.gql.d.ts +0 -0
- /package/lib/scenario/{scenario.gql.private.d.ts → scenario.private.gql.d.ts} +0 -0
- /package/lib/{cryptography → slip39}/slip39.service.d.ts +0 -0
- /package/lib/{api → time}/time.service.d.ts +0 -0
- /package/lib/{trusted-parties/tp-assembly.gql.private.d.ts → tp-assembly/tp-assembly.private.gql.d.ts} +0 -0
- /package/lib/{trusted-parties → tp-password-reset}/tp-password-reset.constants.d.ts +0 -0
- /package/lib/{trusted-parties → trusted-party}/trusted-party.gql.d.ts +0 -0
- /package/lib/{auth → two-factor}/two-factor.service.d.ts +0 -0
- /package/lib/{users → user}/user.service.d.ts +0 -0
- /package/lib/{cryptography → web-crypto}/web-crypto.service.d.ts +0 -0
|
@@ -1,28 +1,28 @@
|
|
|
1
1
|
var Item2Service_1;
|
|
2
2
|
import { __awaiter, __decorate } from "tslib";
|
|
3
3
|
import { Injectable, Injector, NgZone } from '@angular/core';
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
4
|
+
import { LrMergedMutation, LrMutation, LrService } from '../api/lr-graphql';
|
|
5
|
+
import { FileUploadService } from '../file-upload/file-upload.service';
|
|
6
|
+
import { KeyFactoryService } from '../key/key-factory.service';
|
|
7
|
+
import { KeyGraphService } from '../key/key-graph.service';
|
|
8
|
+
import { KeyService } from '../key/key.service';
|
|
9
|
+
import { LockService } from '../lock/lock.service';
|
|
7
10
|
import { LrBadArgumentException } from '../_common/exceptions';
|
|
8
11
|
import { RunOutsideAngular } from '../_common/run-outside-angular';
|
|
9
|
-
import {
|
|
10
|
-
import { CreateDirectoryMutation, DeleteDirectoryMutation, CreateFileMutation, DeleteFileMutation, UpdateFileMutation, UpdateDirectoryMutation, ArchiveDirectoryMutation, UnarchiveDirectoryMutation, ChangeDirectoryParentsMutation, ChangeFileParentsMutation, BeginDeleteChildItemLinksWindowMutation, TempDirectoryQuery, RevertFileMutation, } from './item2.gql';
|
|
11
|
-
import { LrMergedMutation, LrMutation, LrService } from '../api/lr-graphql';
|
|
12
|
-
import { LockService } from '../api/lock.service';
|
|
12
|
+
import { ArchiveDirectoryMutation, BeginDeleteChildItemLinksWindowMutation, ChangeDirectoryParentsMutation, ChangeFileParentsMutation, CreateDirectoryMutation, CreateFileMutation, DeleteDirectoryMutation, DeleteFileMutation, RevertFileMutation, TempDirectoryQuery, UnarchiveDirectoryMutation, UpdateDirectoryMutation, UpdateFileMutation, } from './item2.gql';
|
|
13
13
|
import { DirectoryKeyQuery, FileKeyQuery, FileStateKeyQuery, } from './item2.gql.private';
|
|
14
14
|
import * as i0 from "@angular/core";
|
|
15
|
-
import * as i1 from "../
|
|
16
|
-
import * as i2 from "../
|
|
17
|
-
import * as i3 from "../
|
|
18
|
-
import * as i4 from "../
|
|
19
|
-
import * as i5 from "../
|
|
15
|
+
import * as i1 from "../file-upload/file-upload.service";
|
|
16
|
+
import * as i2 from "../key/key.service";
|
|
17
|
+
import * as i3 from "../key/key-factory.service";
|
|
18
|
+
import * as i4 from "../key/key-graph.service";
|
|
19
|
+
import * as i5 from "../lock/lock.service";
|
|
20
20
|
let Item2Service = Item2Service_1 = class Item2Service extends LrService {
|
|
21
|
-
constructor(ngZone, injector,
|
|
21
|
+
constructor(ngZone, injector, fileUploadService, keyService, keyFactory, keyGraph, lockService) {
|
|
22
22
|
super(injector);
|
|
23
23
|
this.ngZone = ngZone;
|
|
24
24
|
this.injector = injector;
|
|
25
|
-
this.
|
|
25
|
+
this.fileUploadService = fileUploadService;
|
|
26
26
|
this.keyService = keyService;
|
|
27
27
|
this.keyFactory = keyFactory;
|
|
28
28
|
this.keyGraph = keyGraph;
|
|
@@ -30,7 +30,7 @@ let Item2Service = Item2Service_1 = class Item2Service extends LrService {
|
|
|
30
30
|
}
|
|
31
31
|
downloadFileContent(options) {
|
|
32
32
|
return __awaiter(this, void 0, void 0, function* () {
|
|
33
|
-
const fileContent = yield this.
|
|
33
|
+
const fileContent = yield this.fileUploadService.downloadEncryptedFile2(options.fileStateNodeId);
|
|
34
34
|
const fileStateKey = yield this.keyGraph.getKey(options.fileStateKeyId, () => this.getFileStateKeyId(options.fileStateNodeId));
|
|
35
35
|
return this.keyGraph.decryptFromString(fileStateKey, fileContent, {
|
|
36
36
|
payloadType: 'ArrayBuffer',
|
|
@@ -379,7 +379,7 @@ let Item2Service = Item2Service_1 = class Item2Service extends LrService {
|
|
|
379
379
|
return __awaiter(this, void 0, void 0, function* () {
|
|
380
380
|
// Each version of the file is encrypted using a new key.
|
|
381
381
|
const fileStateKey = yield this.keyFactory.createKey();
|
|
382
|
-
const fileContent = options.file && (yield this.
|
|
382
|
+
const fileContent = options.file && (yield this.fileUploadService.loadFile(options.file));
|
|
383
383
|
let contentResource;
|
|
384
384
|
if (fileContent) {
|
|
385
385
|
const cipherFileContent = yield this.keyGraph.encryptToString(fileStateKey, fileContent);
|
|
@@ -387,7 +387,7 @@ let Item2Service = Item2Service_1 = class Item2Service extends LrService {
|
|
|
387
387
|
contentResource = yield options.upload(cipherFileContent);
|
|
388
388
|
}
|
|
389
389
|
else {
|
|
390
|
-
contentResource = yield this.
|
|
390
|
+
contentResource = yield this.fileUploadService.uploadEncryptedFile({
|
|
391
391
|
encryptedContent: cipherFileContent,
|
|
392
392
|
});
|
|
393
393
|
}
|
|
@@ -492,7 +492,7 @@ Item2Service.TEMP_DIRECTORY_PLAIN_META_FILTER = JSON.stringify({
|
|
|
492
492
|
},
|
|
493
493
|
],
|
|
494
494
|
});
|
|
495
|
-
Item2Service.ɵprov = i0.ɵɵdefineInjectable({ factory: function Item2Service_Factory() { return new Item2Service(i0.ɵɵinject(i0.NgZone), i0.ɵɵinject(i0.INJECTOR), i0.ɵɵinject(i1.
|
|
495
|
+
Item2Service.ɵprov = i0.ɵɵdefineInjectable({ factory: function Item2Service_Factory() { return new Item2Service(i0.ɵɵinject(i0.NgZone), i0.ɵɵinject(i0.INJECTOR), i0.ɵɵinject(i1.FileUploadService), i0.ɵɵinject(i2.KeyService), i0.ɵɵinject(i3.KeyFactoryService), i0.ɵɵinject(i4.KeyGraphService), i0.ɵɵinject(i5.LockService)); }, token: Item2Service, providedIn: "root" });
|
|
496
496
|
Item2Service.decorators = [
|
|
497
497
|
{ type: Injectable, args: [{
|
|
498
498
|
providedIn: 'root',
|
|
@@ -501,7 +501,7 @@ Item2Service.decorators = [
|
|
|
501
501
|
Item2Service.ctorParameters = () => [
|
|
502
502
|
{ type: NgZone },
|
|
503
503
|
{ type: Injector },
|
|
504
|
-
{ type:
|
|
504
|
+
{ type: FileUploadService },
|
|
505
505
|
{ type: KeyService },
|
|
506
506
|
{ type: KeyFactoryService },
|
|
507
507
|
{ type: KeyGraphService },
|
|
@@ -513,4 +513,4 @@ Item2Service = Item2Service_1 = __decorate([
|
|
|
513
513
|
})
|
|
514
514
|
], Item2Service);
|
|
515
515
|
export { Item2Service };
|
|
516
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"item2.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/items2/item2.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Injector, NgZone } from '@angular/core';\nimport { JWK } from 'node-jose';\nimport { KeyFactoryService } from '../cryptography/key-factory.service';\nimport { KeyGraphService } from '../cryptography/key-graph.service';\nimport { KeyService } from '../cryptography/key.service';\nimport { LrBadArgumentException } from '../_common/exceptions';\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\nimport { FileService } from '../api/file.service';\nimport {\n  CreateDirectoryMutation,\n  DeleteDirectoryMutation,\n  CreateFileMutation,\n  DeleteFileMutation,\n  UpdateFileMutation,\n  UpdateDirectoryMutation,\n  ArchiveDirectoryMutation,\n  UnarchiveDirectoryMutation,\n  ChangeDirectoryParentsMutation,\n  ChangeFileParentsMutation,\n  BeginDeleteChildItemLinksWindowMutation,\n  TempDirectoryQuery,\n  RevertFileMutation,\n} from './item2.gql';\nimport {\n  ChangeFileParentsOptions,\n  ChangeItemParentsOptions,\n  ChangeDirectoryParentsOptions,\n  CreateDirectoryOptions,\n  CreateFileOptions,\n  DownloadFileContentOptions,\n  FileParentDirectoryInput,\n  ParentDirectoryInput,\n  ParentDirectoryOptions,\n  ParentRootDirectoryInput,\n  UpdateDirectoryOptions,\n  UpdateFileOptions,\n  BeginDeleteChildItemLinksWindowOptions,\n  CreateDirectoryTreeOptions,\n  RevertFileOptions,\n} from './item2.types';\nimport { LrMergedMutation, LrMutation, LrService } from '../api/lr-graphql';\nimport { DirectoryNode, ID, JSONObject, LrRelayIdInput } from '../api/types';\nimport { LockService } from '../api/lock.service';\nimport {\n  DirectoryKeyQuery,\n  FileKeyQuery,\n  FileStateKeyQuery,\n} from './item2.gql.private';\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class Item2Service extends LrService {\n  constructor(\n    private ngZone: NgZone,\n    private injector: Injector,\n    private fileService: FileService,\n    private keyService: KeyService,\n    private keyFactory: KeyFactoryService,\n    private keyGraph: KeyGraphService,\n    private lockService: LockService\n  ) {\n    super(injector);\n  }\n\n  static TEMP_DIRECTORY_PLAIN_META = { kcType: 'temp' };\n  static TEMP_DIRECTORY_PLAIN_META_FILTER = JSON.stringify({\n    filter: [\n      {\n        contains: Item2Service.TEMP_DIRECTORY_PLAIN_META,\n      },\n    ],\n  });\n\n  async downloadFileContent(\n    options: DownloadFileContentOptions\n  ): Promise<ArrayBuffer> {\n    const fileContent = await this.fileService.downloadEncryptedFile2(\n      options.fileStateNodeId\n    );\n\n    const fileStateKey = await this.keyGraph.getKey(\n      options.fileStateKeyId,\n      () => this.getFileStateKeyId(options.fileStateNodeId)\n    );\n\n    return this.keyGraph.decryptFromString(fileStateKey, fileContent, {\n      payloadType: 'ArrayBuffer',\n    });\n  }\n\n  async getDirectoryKeyId(directoryId: LrRelayIdInput) {\n    return (\n      await this.query({\n        query: DirectoryKeyQuery,\n        variables: {\n          id: directoryId,\n        },\n      })\n    ).directory.keyId;\n  }\n\n  async getFileKeyId(fileId: LrRelayIdInput) {\n    return (\n      await this.query({\n        query: FileKeyQuery,\n        variables: {\n          id: fileId,\n        },\n      })\n    ).file.keyId;\n  }\n\n  async getDirectoryKey(\n    directoryId: LrRelayIdInput,\n    directoryKeyId?: LrRelayIdInput\n  ) {\n    return this.keyGraph.getKey(directoryKeyId, () =>\n      this.getDirectoryKeyId(directoryId)\n    );\n  }\n\n  async getFileKey(fileId: LrRelayIdInput, fileKeyId?: LrRelayIdInput) {\n    return this.keyGraph.getKey(fileKeyId, () => this.getFileKeyId(fileId));\n  }\n\n  createDirectoryExec(options: CreateDirectoryOptions) {\n    return this.mutate(this.createDirectoryMutation(options));\n  }\n\n  createDirectory(options: CreateDirectoryOptions) {\n    return this.createDirectoryMutation(options);\n  }\n\n  async createDirectoryMutation(options: CreateDirectoryOptions) {\n    return new LrMutation({\n      mutation: CreateDirectoryMutation,\n      variables: {\n        input: await this.prepareCreateDirectory(options),\n      },\n    });\n  }\n\n  updateDirectoryExec(options: UpdateDirectoryOptions) {\n    return this.mutate(this.updateDirectoryMutation(options));\n  }\n\n  updateDirectory(options: UpdateDirectoryOptions) {\n    return this.updateDirectoryMutation(options);\n  }\n\n  async updateDirectoryMutation(options: UpdateDirectoryOptions) {\n    return new LrMutation({\n      mutation: UpdateDirectoryMutation,\n      variables: {\n        input: await this.prepareUpdateDirectory(options),\n      },\n    });\n  }\n\n  deleteDirectoryExec(id: ID) {\n    return this.mutate(this.deleteDirectoryMutation(id));\n  }\n\n  deleteDirectory(id: ID) {\n    return this.deleteDirectoryMutation(id);\n  }\n\n  deleteDirectoryMutation(id: ID) {\n    return new LrMutation({\n      mutation: DeleteDirectoryMutation,\n      variables: {\n        input: {\n          directoryId: id,\n        },\n      },\n    });\n  }\n\n  createFileExec(options: CreateFileOptions) {\n    return this.mutate(this.createFileMutation(options));\n  }\n\n  createFile(options: CreateFileOptions) {\n    return this.createFileMutation(options);\n  }\n\n  async createFileMutation(options: CreateFileOptions) {\n    return new LrMutation({\n      mutation: CreateFileMutation,\n      variables: {\n        input: await this.prepareCreateFile(options),\n      },\n    });\n  }\n\n  updateFileExec(options: UpdateFileOptions) {\n    return this.mutate(this.updateFileMutation(options));\n  }\n\n  updateFile(options: UpdateFileOptions) {\n    return this.updateFileMutation(options);\n  }\n\n  async updateFileMutation(options: UpdateFileOptions) {\n    return new LrMutation({\n      mutation: UpdateFileMutation,\n      variables: {\n        input: await this.prepareUpdateFile(options),\n      },\n    });\n  }\n\n  revertFileExec(options: RevertFileOptions) {\n    return this.mutate(this.revertFileMutation(options));\n  }\n\n  revertFile(options: RevertFileOptions) {\n    return this.revertFileMutation(options);\n  }\n\n  async revertFileMutation(options: RevertFileOptions) {\n    return new LrMutation({\n      mutation: RevertFileMutation,\n      variables: {\n        input: options,\n      },\n    });\n  }\n\n  deleteFileExec(id: ID) {\n    return this.mutate(this.deleteFileMutation(id));\n  }\n\n  deleteFile(id: ID) {\n    return this.deleteFileMutation(id);\n  }\n\n  deleteFileMutation(id: ID) {\n    return new LrMutation({\n      mutation: DeleteFileMutation,\n      variables: {\n        input: {\n          fileId: id,\n        },\n      },\n    });\n  }\n\n  archiveDirectoryExec(directoryId: string, recursive: boolean) {\n    return this.mutate(this.archiveDirectoryMutation(directoryId, recursive));\n  }\n\n  archiveDirectory(directoryId: string, recursive: boolean) {\n    return this.archiveDirectoryMutation(directoryId, recursive);\n  }\n\n  archiveDirectoryMutation(directoryId: string, recursive: boolean) {\n    return new LrMutation({\n      mutation: ArchiveDirectoryMutation,\n      variables: {\n        input: {\n          directoryId,\n          recursive,\n        },\n      },\n    });\n  }\n\n  unarchiveDirectoryExec(directoryId: string, recursive: boolean) {\n    return this.mutate(this.unarchiveDirectoryMutation(directoryId, recursive));\n  }\n\n  unarchiveDirectory(directoryId: string, recursive: boolean) {\n    return this.unarchiveDirectoryMutation(directoryId, recursive);\n  }\n\n  unarchiveDirectoryMutation(directoryId: string, recursive: boolean) {\n    return new LrMutation({\n      mutation: UnarchiveDirectoryMutation,\n      variables: {\n        input: {\n          directoryId,\n          recursive,\n        },\n      },\n    });\n  }\n\n  changeDirectoryParents(options: ChangeDirectoryParentsOptions) {\n    return this.mutate(this.changeDirectoryParentsMutation(options));\n  }\n\n  async changeDirectoryParentsMutation(options: ChangeDirectoryParentsOptions) {\n    return new LrMutation({\n      mutation: ChangeDirectoryParentsMutation,\n      variables: {\n        input: await this.prepareChangeDirectoryParents(options),\n      },\n    });\n  }\n\n  async changeFileParents(options: ChangeFileParentsOptions) {\n    return this.mutate(this.changeFileParentsMutation(options));\n  }\n\n  async changeFileParentsMutation(options: ChangeFileParentsOptions) {\n    return new LrMutation({\n      mutation: ChangeFileParentsMutation,\n      variables: {\n        input: await this.prepareChangeFileParents(options),\n      },\n    });\n  }\n\n  beginDeleteChildItemLinksWindow(\n    options: BeginDeleteChildItemLinksWindowOptions\n  ) {\n    return this.mutate(this.beginDeleteChildItemLinksWindowMutation(options));\n  }\n\n  async beginDeleteChildItemLinksWindowMutation(\n    options: BeginDeleteChildItemLinksWindowOptions\n  ) {\n    return new LrMutation({\n      mutation: BeginDeleteChildItemLinksWindowMutation,\n      variables: {\n        input: options,\n      },\n    });\n  }\n\n  /**\n   *\n   * This method may raise VERSION_MISMATCH exception if there is a race condition\n   * when multiple clients try to create the temp directory.\n   *\n   * TODO There is a retry mechanism in graphql with exponential back off but that's internal.\n   * But need to use an exponential back off lib if we want to retry here.\n   *\n   * @returns The ID of the temp directory\n   *\n   */\n  async ensureTempDirectory(): Promise<Pick<DirectoryNode, 'id' | 'keyId'>> {\n    const existing = await this.query({\n      query: TempDirectoryQuery,\n      variables: {\n        plainMeta: Item2Service.TEMP_DIRECTORY_PLAIN_META_FILTER,\n      },\n    });\n\n    if (existing.rootDirectories.edges.length > 1) {\n      console.error(\n        `There is more than 1 temp directory (plainMeta filter: ${Item2Service.TEMP_DIRECTORY_PLAIN_META_FILTER})`\n      );\n    }\n\n    if (existing.rootDirectories.edges.length === 0) {\n      // Doesn't exist yet, create it\n      const createDirectory = await this.createDirectory({\n        asRootDirectory: true,\n        plainMetaJson: Item2Service.TEMP_DIRECTORY_PLAIN_META,\n      });\n\n      // Optimistic lock on the current user.\n      const updateLock = this.lockService.updateLockMutation({\n        version: existing.lock?.version,\n      });\n\n      // Because this.mutate() only handles simple types we need to use the more\n      // advanced this.lrGraphQL.lrMutate()\n      const [createDirectoryResult, _] = await this.lrGraphQL.lrMutate(\n        LrMergedMutation.create([createDirectory, updateLock])\n      );\n\n      const { id, keyId } = createDirectoryResult.createDirectory.directory;\n      return {\n        id,\n        keyId,\n      };\n    } else {\n      // Return existing temp\n      const { id, keyId } = existing.rootDirectories.edges[0].node;\n      return {\n        id,\n        keyId,\n      };\n    }\n  }\n\n  async createDirectoryTree(options: CreateDirectoryTreeOptions) {\n    return this.mutate(this.createDirectoryTreeMutation(options));\n  }\n\n  /**\n   * You must run this mutation within the temp directory cleanup window on the\n   * server, otherwise the temp directory will get cleaned up.\n   *\n   */\n  async createDirectoryTreeMutation(options: CreateDirectoryTreeOptions) {\n    const tempDir = await this.ensureTempDirectory();\n\n    // Clear the temp directory of the ones we are about to create.\n    await this.beginDeleteChildItemLinksWindow({\n      directoryId: tempDir.id,\n      requestWindowMs: options.requestWindowMs,\n    });\n\n    // Create the directory that has contents\n    const dirId = (\n      await this.createDirectoryExec({\n        cipherMetaClearJson: options.cipherMetaClearJson,\n        parentDirectories: [\n          {\n            directoryId: tempDir.id,\n            wrappingKeyId: tempDir.keyId,\n          },\n        ],\n        plainMetaJson: options.plainMetaJson,\n      })\n    ).createDirectory.directory.id;\n\n    // Create the contents\n    await options.createContent(dirId);\n\n    // TODO client-side check for timeout on requestWindowMs\n    // TODO return the server time where delete is scheduled. Expirable mutation\n\n    // Return the mutation that moves the directory into the dst directories\n    return this.changeDirectoryParentsMutation({\n      directoryId: dirId,\n      parentsToRemove: [tempDir.id],\n      parentsToAdd: options.parentDirectories,\n    });\n  }\n\n  // ------------------------------------------------------------------------------\n  // ------------------------------------------------------------------------------\n  // Helpers\n  // ------------------------------------------------------------------------------\n  // ------------------------------------------------------------------------------\n\n  private async prepareParentDirectory(\n    options: ParentDirectoryOptions,\n    newKey: JWK.Key\n  ): Promise<ParentDirectoryInput> {\n    // If directory's key is not already in the key graph, then need to\n    // fetch the directory's key.\n    const wrappingKey = await this.getDirectoryKey(\n      options.directoryId,\n      options.wrappingKeyId\n    );\n\n    return {\n      directoryId: options.directoryId,\n      wrappingKeyId: wrappingKey.id,\n      wrappedKey: await this.keyGraph.wrapKey(wrappingKey, newKey),\n      linkType: options.linkType,\n    };\n  }\n\n  private async getFileStateKeyId(fileStateNodeId: LrRelayIdInput) {\n    return (\n      await this.query({\n        query: FileStateKeyQuery,\n        variables: {\n          id: fileStateNodeId,\n        },\n      })\n    ).fileState.keyId;\n  }\n\n  private async prepareCreateFileState(\n    fileKey: JWK.Key,\n    options: CreateFileOptions | UpdateFileOptions\n  ) {\n    // Each version of the file is encrypted using a new key.\n    const fileStateKey = await this.keyFactory.createKey();\n\n    const fileContent =\n      options.file && (await this.fileService.loadFile(options.file));\n\n    let contentResource: string;\n    if (fileContent) {\n      const cipherFileContent = await this.keyGraph.encryptToString(\n        fileStateKey,\n        fileContent\n      );\n      if (options.upload) {\n        contentResource = await options.upload(cipherFileContent);\n      } else {\n        contentResource = await this.fileService.uploadEncryptedFile({\n          encryptedContent: cipherFileContent,\n        });\n      }\n      console.log('contentResource', contentResource);\n    }\n\n    return {\n      ...(await this.prepareItem(fileStateKey, options)),\n      wrappedStateKey: await this.keyGraph.wrapKey(fileKey, fileStateKey),\n      contentResource,\n    };\n  }\n\n  private async prepareChangeItemParents(\n    options: ChangeItemParentsOptions,\n    itemKey: JWK.Key\n  ) {\n    const parentsToAdd = await Promise.all(\n      options.parentsToAdd.map((t) => this.prepareParentDirectory(t, itemKey))\n    );\n\n    return {\n      directoriesToRemove: options.parentsToRemove,\n      directoriesToAdd: parentsToAdd,\n    };\n  }\n\n  private async prepareItem(\n    key: JWK.Key,\n    options: { plainMetaJson?: JSONObject; cipherMetaClearJson?: JSONObject }\n  ) {\n    const { plainMetaJson, cipherMetaClearJson } = options;\n\n    return {\n      plainMeta: plainMetaJson && JSON.stringify(plainMetaJson),\n      cipherMeta:\n        cipherMetaClearJson &&\n        (await this.keyGraph.encryptToString(key, cipherMetaClearJson)),\n    };\n  }\n\n  private async prepareCreateDirectory(options: CreateDirectoryOptions) {\n    const directoryKey = await this.keyFactory.createKey();\n    options.parentDirectories = options.parentDirectories || [];\n    if (!options.asRootDirectory && !options.parentDirectories?.length) {\n      throw new LrBadArgumentException(\n        'A new directory must be either a root directory or a sub-directory. So you must provide either parentDirectories and/or asRootDirectory parameter.'\n      );\n    }\n\n    const parentDirectories = await Promise.all(\n      options.parentDirectories?.map((t) =>\n        this.prepareParentDirectory(t, directoryKey)\n      )\n    );\n\n    // TODO this is rather an unfortunate name, change it to asRootDirectory.\n    let parentRootDirectory: ParentRootDirectoryInput;\n    if (options.asRootDirectory) {\n      const rootKey = this.keyService.getCurrentRootKey();\n      parentRootDirectory = {\n        wrappingKeyId: rootKey.id,\n        wrappedKey: await this.keyGraph.wrapKey(rootKey, directoryKey),\n      };\n    }\n\n    const itemInput = await this.prepareItem(directoryKey, options);\n\n    return {\n      ...itemInput,\n      parentDirectories,\n      parentRootDirectory,\n    };\n  }\n\n  private async prepareUpdateDirectory(options: UpdateDirectoryOptions) {\n    const directoryKey = await this.getDirectoryKey(\n      options.directoryId,\n      options.directoryKeyId\n    );\n\n    const itemInput = await this.prepareItem(directoryKey.jwk, options);\n\n    return {\n      ...itemInput,\n      directoryId: options.directoryId,\n    };\n  }\n\n  private async prepareCreateFile(options: CreateFileOptions) {\n    const fileKey = await this.keyFactory.createKey();\n\n    const parentDirectories = await Promise.all(\n      options.parentDirectories.map(async (t) => {\n        const { directoryId, wrappingKeyId, wrappedKey } =\n          await this.prepareParentDirectory(t, fileKey);\n        // remap from ParentDirectoryInput to FileParentDirectoryInput\n        // TODO the server should really just use wrappedKey instead of wrappedFileKey\n        return {\n          directoryId,\n          wrappingKeyId,\n          wrappedFileKey: wrappedKey,\n        } as FileParentDirectoryInput;\n      })\n    );\n\n    const input = await this.prepareCreateFileState(fileKey, options);\n\n    return {\n      ...input,\n      parentDirectories,\n    };\n  }\n\n  private async prepareUpdateFile(options: UpdateFileOptions) {\n    const fileKey = await this.getFileKey(options.fileId, options.fileKeyId);\n    const input = await this.prepareCreateFileState(fileKey.jwk, options);\n\n    return {\n      ...input,\n      fileId: options.fileId,\n    };\n  }\n\n  private async prepareChangeDirectoryParents(\n    options: ChangeDirectoryParentsOptions\n  ) {\n    const directoryKey = await this.getDirectoryKey(\n      options.directoryId,\n      options.directoryKeyId\n    );\n\n    const input = await this.prepareChangeItemParents(\n      options,\n      directoryKey.jwk\n    );\n\n    return {\n      ...input,\n      directoryId: options.directoryId,\n    };\n  }\n\n  private async prepareChangeFileParents(options: ChangeFileParentsOptions) {\n    const fileKey = await this.getFileKey(options.fileId, options.fileKeyId);\n\n    const input = await this.prepareChangeItemParents(options, fileKey.jwk);\n\n    return {\n      ...input,\n      fileId: options.fileId,\n    };\n  }\n}\n"]}
|
|
516
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"item2.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/items2/item2.service.ts"],"names":[],"mappings":";;AAAA,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAE7D,OAAO,EAAE,gBAAgB,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAE5E,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AACvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAC;AAC/D,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AACnE,OAAO,EACL,wBAAwB,EACxB,uCAAuC,EACvC,8BAA8B,EAC9B,yBAAyB,EACzB,uBAAuB,EACvB,kBAAkB,EAClB,uBAAuB,EACvB,kBAAkB,EAClB,kBAAkB,EAClB,kBAAkB,EAClB,0BAA0B,EAC1B,uBAAuB,EACvB,kBAAkB,GACnB,MAAM,aAAa,CAAC;AACrB,OAAO,EACL,iBAAiB,EACjB,YAAY,EACZ,iBAAiB,GAClB,MAAM,qBAAqB,CAAC;;;;;;;IAyBhB,YAAY,0BAAZ,YAAa,SAAQ,SAAS;IACzC,YACU,MAAc,EACd,QAAkB,EAClB,iBAAoC,EACpC,UAAsB,EACtB,UAA6B,EAC7B,QAAyB,EACzB,WAAwB;QAEhC,KAAK,CAAC,QAAQ,CAAC,CAAC;QARR,WAAM,GAAN,MAAM,CAAQ;QACd,aAAQ,GAAR,QAAQ,CAAU;QAClB,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,eAAU,GAAV,UAAU,CAAY;QACtB,eAAU,GAAV,UAAU,CAAmB;QAC7B,aAAQ,GAAR,QAAQ,CAAiB;QACzB,gBAAW,GAAX,WAAW,CAAa;IAGlC,CAAC;IAWK,mBAAmB,CACvB,OAAmC;;YAEnC,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,sBAAsB,CACrE,OAAO,CAAC,eAAe,CACxB,CAAC;YAEF,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAC7C,OAAO,CAAC,cAAc,EACtB,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,eAAe,CAAC,CACtD,CAAC;YAEF,OAAO,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAAC,YAAY,EAAE,WAAW,EAAE;gBAChE,WAAW,EAAE,aAAa;aAC3B,CAAC,CAAC;QACL,CAAC;KAAA;IAEK,iBAAiB,CAAC,WAA2B;;YACjD,OAAO,CACL,MAAM,IAAI,CAAC,KAAK,CAAC;gBACf,KAAK,EAAE,iBAAiB;gBACxB,SAAS,EAAE;oBACT,EAAE,EAAE,WAAW;iBAChB;aACF,CAAC,CACH,CAAC,SAAS,CAAC,KAAK,CAAC;QACpB,CAAC;KAAA;IAEK,YAAY,CAAC,MAAsB;;YACvC,OAAO,CACL,MAAM,IAAI,CAAC,KAAK,CAAC;gBACf,KAAK,EAAE,YAAY;gBACnB,SAAS,EAAE;oBACT,EAAE,EAAE,MAAM;iBACX;aACF,CAAC,CACH,CAAC,IAAI,CAAC,KAAK,CAAC;QACf,CAAC;KAAA;IAEK,eAAe,CACnB,WAA2B,EAC3B,cAA+B;;YAE/B,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,cAAc,EAAE,GAAG,EAAE,CAC/C,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,CACpC,CAAC;QACJ,CAAC;KAAA;IAEK,UAAU,CAAC,MAAsB,EAAE,SAA0B;;YACjE,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,SAAS,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC;QAC1E,CAAC;KAAA;IAED,mBAAmB,CAAC,OAA+B;QACjD,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,uBAAuB,CAAC,OAAO,CAAC,CAAC,CAAC;IAC5D,CAAC;IAED,eAAe,CAAC,OAA+B;QAC7C,OAAO,IAAI,CAAC,uBAAuB,CAAC,OAAO,CAAC,CAAC;IAC/C,CAAC;IAEK,uBAAuB,CAAC,OAA+B;;YAC3D,OAAO,IAAI,UAAU,CAAC;gBACpB,QAAQ,EAAE,uBAAuB;gBACjC,SAAS,EAAE;oBACT,KAAK,EAAE,MAAM,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC;iBAClD;aACF,CAAC,CAAC;QACL,CAAC;KAAA;IAED,mBAAmB,CAAC,OAA+B;QACjD,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,uBAAuB,CAAC,OAAO,CAAC,CAAC,CAAC;IAC5D,CAAC;IAED,eAAe,CAAC,OAA+B;QAC7C,OAAO,IAAI,CAAC,uBAAuB,CAAC,OAAO,CAAC,CAAC;IAC/C,CAAC;IAEK,uBAAuB,CAAC,OAA+B;;YAC3D,OAAO,IAAI,UAAU,CAAC;gBACpB,QAAQ,EAAE,uBAAuB;gBACjC,SAAS,EAAE;oBACT,KAAK,EAAE,MAAM,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC;iBAClD;aACF,CAAC,CAAC;QACL,CAAC;KAAA;IAED,mBAAmB,CAAC,EAAM;QACxB,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,uBAAuB,CAAC,EAAE,CAAC,CAAC,CAAC;IACvD,CAAC;IAED,eAAe,CAAC,EAAM;QACpB,OAAO,IAAI,CAAC,uBAAuB,CAAC,EAAE,CAAC,CAAC;IAC1C,CAAC;IAED,uBAAuB,CAAC,EAAM;QAC5B,OAAO,IAAI,UAAU,CAAC;YACpB,QAAQ,EAAE,uBAAuB;YACjC,SAAS,EAAE;gBACT,KAAK,EAAE;oBACL,WAAW,EAAE,EAAE;iBAChB;aACF;SACF,CAAC,CAAC;IACL,CAAC;IAED,cAAc,CAAC,OAA0B;QACvC,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,CAAC;IACvD,CAAC;IAED,UAAU,CAAC,OAA0B;QACnC,OAAO,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;IAC1C,CAAC;IAEK,kBAAkB,CAAC,OAA0B;;YACjD,OAAO,IAAI,UAAU,CAAC;gBACpB,QAAQ,EAAE,kBAAkB;gBAC5B,SAAS,EAAE;oBACT,KAAK,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC;iBAC7C;aACF,CAAC,CAAC;QACL,CAAC;KAAA;IAED,cAAc,CAAC,OAA0B;QACvC,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,CAAC;IACvD,CAAC;IAED,UAAU,CAAC,OAA0B;QACnC,OAAO,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;IAC1C,CAAC;IAEK,kBAAkB,CAAC,OAA0B;;YACjD,OAAO,IAAI,UAAU,CAAC;gBACpB,QAAQ,EAAE,kBAAkB;gBAC5B,SAAS,EAAE;oBACT,KAAK,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC;iBAC7C;aACF,CAAC,CAAC;QACL,CAAC;KAAA;IAED,cAAc,CAAC,OAA0B;QACvC,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,CAAC;IACvD,CAAC;IAED,UAAU,CAAC,OAA0B;QACnC,OAAO,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;IAC1C,CAAC;IAEK,kBAAkB,CAAC,OAA0B;;YACjD,OAAO,IAAI,UAAU,CAAC;gBACpB,QAAQ,EAAE,kBAAkB;gBAC5B,SAAS,EAAE;oBACT,KAAK,EAAE,OAAO;iBACf;aACF,CAAC,CAAC;QACL,CAAC;KAAA;IAED,cAAc,CAAC,EAAM;QACnB,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,kBAAkB,CAAC,EAAE,CAAC,CAAC,CAAC;IAClD,CAAC;IAED,UAAU,CAAC,EAAM;QACf,OAAO,IAAI,CAAC,kBAAkB,CAAC,EAAE,CAAC,CAAC;IACrC,CAAC;IAED,kBAAkB,CAAC,EAAM;QACvB,OAAO,IAAI,UAAU,CAAC;YACpB,QAAQ,EAAE,kBAAkB;YAC5B,SAAS,EAAE;gBACT,KAAK,EAAE;oBACL,MAAM,EAAE,EAAE;iBACX;aACF;SACF,CAAC,CAAC;IACL,CAAC;IAED,oBAAoB,CAAC,WAAmB,EAAE,SAAkB;QAC1D,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,wBAAwB,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC,CAAC;IAC5E,CAAC;IAED,gBAAgB,CAAC,WAAmB,EAAE,SAAkB;QACtD,OAAO,IAAI,CAAC,wBAAwB,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;IAC/D,CAAC;IAED,wBAAwB,CAAC,WAAmB,EAAE,SAAkB;QAC9D,OAAO,IAAI,UAAU,CAAC;YACpB,QAAQ,EAAE,wBAAwB;YAClC,SAAS,EAAE;gBACT,KAAK,EAAE;oBACL,WAAW;oBACX,SAAS;iBACV;aACF;SACF,CAAC,CAAC;IACL,CAAC;IAED,sBAAsB,CAAC,WAAmB,EAAE,SAAkB;QAC5D,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,0BAA0B,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC,CAAC;IAC9E,CAAC;IAED,kBAAkB,CAAC,WAAmB,EAAE,SAAkB;QACxD,OAAO,IAAI,CAAC,0BAA0B,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;IACjE,CAAC;IAED,0BAA0B,CAAC,WAAmB,EAAE,SAAkB;QAChE,OAAO,IAAI,UAAU,CAAC;YACpB,QAAQ,EAAE,0BAA0B;YACpC,SAAS,EAAE;gBACT,KAAK,EAAE;oBACL,WAAW;oBACX,SAAS;iBACV;aACF;SACF,CAAC,CAAC;IACL,CAAC;IAED,sBAAsB,CAAC,OAAsC;QAC3D,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,8BAA8B,CAAC,OAAO,CAAC,CAAC,CAAC;IACnE,CAAC;IAEK,8BAA8B,CAAC,OAAsC;;YACzE,OAAO,IAAI,UAAU,CAAC;gBACpB,QAAQ,EAAE,8BAA8B;gBACxC,SAAS,EAAE;oBACT,KAAK,EAAE,MAAM,IAAI,CAAC,6BAA6B,CAAC,OAAO,CAAC;iBACzD;aACF,CAAC,CAAC;QACL,CAAC;KAAA;IAEK,iBAAiB,CAAC,OAAiC;;YACvD,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,OAAO,CAAC,CAAC,CAAC;QAC9D,CAAC;KAAA;IAEK,yBAAyB,CAAC,OAAiC;;YAC/D,OAAO,IAAI,UAAU,CAAC;gBACpB,QAAQ,EAAE,yBAAyB;gBACnC,SAAS,EAAE;oBACT,KAAK,EAAE,MAAM,IAAI,CAAC,wBAAwB,CAAC,OAAO,CAAC;iBACpD;aACF,CAAC,CAAC;QACL,CAAC;KAAA;IAED,+BAA+B,CAC7B,OAA+C;QAE/C,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,uCAAuC,CAAC,OAAO,CAAC,CAAC,CAAC;IAC5E,CAAC;IAEK,uCAAuC,CAC3C,OAA+C;;YAE/C,OAAO,IAAI,UAAU,CAAC;gBACpB,QAAQ,EAAE,uCAAuC;gBACjD,SAAS,EAAE;oBACT,KAAK,EAAE,OAAO;iBACf;aACF,CAAC,CAAC;QACL,CAAC;KAAA;IAED;;;;;;;;;;OAUG;IACG,mBAAmB;;;YACvB,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC;gBAChC,KAAK,EAAE,kBAAkB;gBACzB,SAAS,EAAE;oBACT,SAAS,EAAE,cAAY,CAAC,gCAAgC;iBACzD;aACF,CAAC,CAAC;YAEH,IAAI,QAAQ,CAAC,eAAe,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;gBAC7C,OAAO,CAAC,KAAK,CACX,0DAA0D,cAAY,CAAC,gCAAgC,GAAG,CAC3G,CAAC;aACH;YAED,IAAI,QAAQ,CAAC,eAAe,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;gBAC/C,+BAA+B;gBAC/B,MAAM,eAAe,GAAG,MAAM,IAAI,CAAC,eAAe,CAAC;oBACjD,eAAe,EAAE,IAAI;oBACrB,aAAa,EAAE,cAAY,CAAC,yBAAyB;iBACtD,CAAC,CAAC;gBAEH,uCAAuC;gBACvC,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,kBAAkB,CAAC;oBACrD,OAAO,QAAE,QAAQ,CAAC,IAAI,0CAAE,OAAO;iBAChC,CAAC,CAAC;gBAEH,0EAA0E;gBAC1E,qCAAqC;gBACrC,MAAM,CAAC,qBAAqB,EAAE,CAAC,CAAC,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,QAAQ,CAC9D,gBAAgB,CAAC,MAAM,CAAC,CAAC,eAAe,EAAE,UAAU,CAAC,CAAC,CACvD,CAAC;gBAEF,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,GAAG,qBAAqB,CAAC,eAAe,CAAC,SAAS,CAAC;gBACtE,OAAO;oBACL,EAAE;oBACF,KAAK;iBACN,CAAC;aACH;iBAAM;gBACL,uBAAuB;gBACvB,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,GAAG,QAAQ,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;gBAC7D,OAAO;oBACL,EAAE;oBACF,KAAK;iBACN,CAAC;aACH;;KACF;IAEK,mBAAmB,CAAC,OAAmC;;YAC3D,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,2BAA2B,CAAC,OAAO,CAAC,CAAC,CAAC;QAChE,CAAC;KAAA;IAED;;;;OAIG;IACG,2BAA2B,CAAC,OAAmC;;YACnE,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAEjD,+DAA+D;YAC/D,MAAM,IAAI,CAAC,+BAA+B,CAAC;gBACzC,WAAW,EAAE,OAAO,CAAC,EAAE;gBACvB,eAAe,EAAE,OAAO,CAAC,eAAe;aACzC,CAAC,CAAC;YAEH,yCAAyC;YACzC,MAAM,KAAK,GAAG,CACZ,MAAM,IAAI,CAAC,mBAAmB,CAAC;gBAC7B,mBAAmB,EAAE,OAAO,CAAC,mBAAmB;gBAChD,iBAAiB,EAAE;oBACjB;wBACE,WAAW,EAAE,OAAO,CAAC,EAAE;wBACvB,aAAa,EAAE,OAAO,CAAC,KAAK;qBAC7B;iBACF;gBACD,aAAa,EAAE,OAAO,CAAC,aAAa;aACrC,CAAC,CACH,CAAC,eAAe,CAAC,SAAS,CAAC,EAAE,CAAC;YAE/B,sBAAsB;YACtB,MAAM,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAEnC,wDAAwD;YACxD,4EAA4E;YAE5E,wEAAwE;YACxE,OAAO,IAAI,CAAC,8BAA8B,CAAC;gBACzC,WAAW,EAAE,KAAK;gBAClB,eAAe,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC;gBAC7B,YAAY,EAAE,OAAO,CAAC,iBAAiB;aACxC,CAAC,CAAC;QACL,CAAC;KAAA;IAED,iFAAiF;IACjF,iFAAiF;IACjF,UAAU;IACV,iFAAiF;IACjF,iFAAiF;IAEnE,sBAAsB,CAClC,OAA+B,EAC/B,MAAe;;YAEf,mEAAmE;YACnE,6BAA6B;YAC7B,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,eAAe,CAC5C,OAAO,CAAC,WAAW,EACnB,OAAO,CAAC,aAAa,CACtB,CAAC;YAEF,OAAO;gBACL,WAAW,EAAE,OAAO,CAAC,WAAW;gBAChC,aAAa,EAAE,WAAW,CAAC,EAAE;gBAC7B,UAAU,EAAE,MAAM,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,WAAW,EAAE,MAAM,CAAC;gBAC5D,QAAQ,EAAE,OAAO,CAAC,QAAQ;aAC3B,CAAC;QACJ,CAAC;KAAA;IAEa,iBAAiB,CAAC,eAA+B;;YAC7D,OAAO,CACL,MAAM,IAAI,CAAC,KAAK,CAAC;gBACf,KAAK,EAAE,iBAAiB;gBACxB,SAAS,EAAE;oBACT,EAAE,EAAE,eAAe;iBACpB;aACF,CAAC,CACH,CAAC,SAAS,CAAC,KAAK,CAAC;QACpB,CAAC;KAAA;IAEa,sBAAsB,CAClC,OAAgB,EAChB,OAA8C;;YAE9C,yDAAyD;YACzD,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC;YAEvD,MAAM,WAAW,GACf,OAAO,CAAC,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;YAExE,IAAI,eAAuB,CAAC;YAC5B,IAAI,WAAW,EAAE;gBACf,MAAM,iBAAiB,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,eAAe,CAC3D,YAAY,EACZ,WAAW,CACZ,CAAC;gBACF,IAAI,OAAO,CAAC,MAAM,EAAE;oBAClB,eAAe,GAAG,MAAM,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC;iBAC3D;qBAAM;oBACL,eAAe,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,mBAAmB,CAAC;wBACjE,gBAAgB,EAAE,iBAAiB;qBACpC,CAAC,CAAC;iBACJ;gBACD,OAAO,CAAC,GAAG,CAAC,iBAAiB,EAAE,eAAe,CAAC,CAAC;aACjD;YAED,uCACK,CAAC,MAAM,IAAI,CAAC,WAAW,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC,KAClD,eAAe,EAAE,MAAM,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,EAAE,YAAY,CAAC,EACnE,eAAe,IACf;QACJ,CAAC;KAAA;IAEa,wBAAwB,CACpC,OAAiC,EACjC,OAAgB;;YAEhB,MAAM,YAAY,GAAG,MAAM,OAAO,CAAC,GAAG,CACpC,OAAO,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,CACzE,CAAC;YAEF,OAAO;gBACL,mBAAmB,EAAE,OAAO,CAAC,eAAe;gBAC5C,gBAAgB,EAAE,YAAY;aAC/B,CAAC;QACJ,CAAC;KAAA;IAEa,WAAW,CACvB,GAAY,EACZ,OAAyE;;YAEzE,MAAM,EAAE,aAAa,EAAE,mBAAmB,EAAE,GAAG,OAAO,CAAC;YAEvD,OAAO;gBACL,SAAS,EAAE,aAAa,IAAI,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC;gBACzD,UAAU,EACR,mBAAmB;oBACnB,CAAC,MAAM,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,GAAG,EAAE,mBAAmB,CAAC,CAAC;aAClE,CAAC;QACJ,CAAC;KAAA;IAEa,sBAAsB,CAAC,OAA+B;;;YAClE,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC;YACvD,OAAO,CAAC,iBAAiB,GAAG,OAAO,CAAC,iBAAiB,IAAI,EAAE,CAAC;YAC5D,IAAI,CAAC,OAAO,CAAC,eAAe,IAAI,QAAC,OAAO,CAAC,iBAAiB,0CAAE,MAAM,CAAA,EAAE;gBAClE,MAAM,IAAI,sBAAsB,CAC9B,oJAAoJ,CACrJ,CAAC;aACH;YAED,MAAM,iBAAiB,GAAG,MAAM,OAAO,CAAC,GAAG,OACzC,OAAO,CAAC,iBAAiB,0CAAE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CACnC,IAAI,CAAC,sBAAsB,CAAC,CAAC,EAAE,YAAY,CAAC,EAE/C,CAAC;YAEF,yEAAyE;YACzE,IAAI,mBAA6C,CAAC;YAClD,IAAI,OAAO,CAAC,eAAe,EAAE;gBAC3B,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,iBAAiB,EAAE,CAAC;gBACpD,mBAAmB,GAAG;oBACpB,aAAa,EAAE,OAAO,CAAC,EAAE;oBACzB,UAAU,EAAE,MAAM,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,EAAE,YAAY,CAAC;iBAC/D,CAAC;aACH;YAED,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;YAEhE,uCACK,SAAS,KACZ,iBAAiB;gBACjB,mBAAmB,IACnB;;KACH;IAEa,sBAAsB,CAAC,OAA+B;;YAClE,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,eAAe,CAC7C,OAAO,CAAC,WAAW,EACnB,OAAO,CAAC,cAAc,CACvB,CAAC;YAEF,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;YAEpE,uCACK,SAAS,KACZ,WAAW,EAAE,OAAO,CAAC,WAAW,IAChC;QACJ,CAAC;KAAA;IAEa,iBAAiB,CAAC,OAA0B;;YACxD,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC;YAElD,MAAM,iBAAiB,GAAG,MAAM,OAAO,CAAC,GAAG,CACzC,OAAO,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAO,CAAC,EAAE,EAAE;gBACxC,MAAM,EAAE,WAAW,EAAE,aAAa,EAAE,UAAU,EAAE,GAC9C,MAAM,IAAI,CAAC,sBAAsB,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;gBAChD,8DAA8D;gBAC9D,8EAA8E;gBAC9E,OAAO;oBACL,WAAW;oBACX,aAAa;oBACb,cAAc,EAAE,UAAU;iBACC,CAAC;YAChC,CAAC,CAAA,CAAC,CACH,CAAC;YAEF,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,sBAAsB,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;YAElE,uCACK,KAAK,KACR,iBAAiB,IACjB;QACJ,CAAC;KAAA;IAEa,iBAAiB,CAAC,OAA0B;;YACxD,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC;YACzE,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;YAEtE,uCACK,KAAK,KACR,MAAM,EAAE,OAAO,CAAC,MAAM,IACtB;QACJ,CAAC;KAAA;IAEa,6BAA6B,CACzC,OAAsC;;YAEtC,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,eAAe,CAC7C,OAAO,CAAC,WAAW,EACnB,OAAO,CAAC,cAAc,CACvB,CAAC;YAEF,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,wBAAwB,CAC/C,OAAO,EACP,YAAY,CAAC,GAAG,CACjB,CAAC;YAEF,uCACK,KAAK,KACR,WAAW,EAAE,OAAO,CAAC,WAAW,IAChC;QACJ,CAAC;KAAA;IAEa,wBAAwB,CAAC,OAAiC;;YACtE,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC;YAEzE,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,wBAAwB,CAAC,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;YAExE,uCACK,KAAK,KACR,MAAM,EAAE,OAAO,CAAC,MAAM,IACtB;QACJ,CAAC;KAAA;CACF,CAAA;AApkBQ,sCAAyB,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC;AAC/C,6CAAgC,GAAG,IAAI,CAAC,SAAS,CAAC;IACvD,MAAM,EAAE;QACN;YACE,QAAQ,EAAE,cAAY,CAAC,yBAAyB;SACjD;KACF;CACF,CAAC,CAAC;;;YAvBJ,UAAU,SAAC;gBACV,UAAU,EAAE,MAAM;aACnB;;;YAtD8B,MAAM;YAAhB,QAAQ;YAIpB,iBAAiB;YAGjB,UAAU;YAFV,iBAAiB;YACjB,eAAe;YAEf,WAAW;;AA+CP,YAAY;IANxB,iBAAiB,CAAC;QACjB,UAAU,EAAE,QAAQ;KACrB,CAAC;GAIW,YAAY,CAilBxB;SAjlBY,YAAY","sourcesContent":["import { Injectable, Injector, NgZone } from '@angular/core';\nimport { JWK } from 'node-jose';\nimport { LrMergedMutation, LrMutation, LrService } from '../api/lr-graphql';\nimport { DirectoryNode, ID, JSONObject, LrRelayIdInput } from '../api/types';\nimport { FileUploadService } from '../file-upload/file-upload.service';\nimport { KeyFactoryService } from '../key/key-factory.service';\nimport { KeyGraphService } from '../key/key-graph.service';\nimport { KeyService } from '../key/key.service';\nimport { LockService } from '../lock/lock.service';\nimport { LrBadArgumentException } from '../_common/exceptions';\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\nimport {\n  ArchiveDirectoryMutation,\n  BeginDeleteChildItemLinksWindowMutation,\n  ChangeDirectoryParentsMutation,\n  ChangeFileParentsMutation,\n  CreateDirectoryMutation,\n  CreateFileMutation,\n  DeleteDirectoryMutation,\n  DeleteFileMutation,\n  RevertFileMutation,\n  TempDirectoryQuery,\n  UnarchiveDirectoryMutation,\n  UpdateDirectoryMutation,\n  UpdateFileMutation,\n} from './item2.gql';\nimport {\n  DirectoryKeyQuery,\n  FileKeyQuery,\n  FileStateKeyQuery,\n} from './item2.gql.private';\nimport {\n  BeginDeleteChildItemLinksWindowOptions,\n  ChangeDirectoryParentsOptions,\n  ChangeFileParentsOptions,\n  ChangeItemParentsOptions,\n  CreateDirectoryOptions,\n  CreateDirectoryTreeOptions,\n  CreateFileOptions,\n  DownloadFileContentOptions,\n  FileParentDirectoryInput,\n  ParentDirectoryInput,\n  ParentDirectoryOptions,\n  ParentRootDirectoryInput,\n  RevertFileOptions,\n  UpdateDirectoryOptions,\n  UpdateFileOptions,\n} from './item2.types';\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class Item2Service extends LrService {\n  constructor(\n    private ngZone: NgZone,\n    private injector: Injector,\n    private fileUploadService: FileUploadService,\n    private keyService: KeyService,\n    private keyFactory: KeyFactoryService,\n    private keyGraph: KeyGraphService,\n    private lockService: LockService\n  ) {\n    super(injector);\n  }\n\n  static TEMP_DIRECTORY_PLAIN_META = { kcType: 'temp' };\n  static TEMP_DIRECTORY_PLAIN_META_FILTER = JSON.stringify({\n    filter: [\n      {\n        contains: Item2Service.TEMP_DIRECTORY_PLAIN_META,\n      },\n    ],\n  });\n\n  async downloadFileContent(\n    options: DownloadFileContentOptions\n  ): Promise<ArrayBuffer> {\n    const fileContent = await this.fileUploadService.downloadEncryptedFile2(\n      options.fileStateNodeId\n    );\n\n    const fileStateKey = await this.keyGraph.getKey(\n      options.fileStateKeyId,\n      () => this.getFileStateKeyId(options.fileStateNodeId)\n    );\n\n    return this.keyGraph.decryptFromString(fileStateKey, fileContent, {\n      payloadType: 'ArrayBuffer',\n    });\n  }\n\n  async getDirectoryKeyId(directoryId: LrRelayIdInput) {\n    return (\n      await this.query({\n        query: DirectoryKeyQuery,\n        variables: {\n          id: directoryId,\n        },\n      })\n    ).directory.keyId;\n  }\n\n  async getFileKeyId(fileId: LrRelayIdInput) {\n    return (\n      await this.query({\n        query: FileKeyQuery,\n        variables: {\n          id: fileId,\n        },\n      })\n    ).file.keyId;\n  }\n\n  async getDirectoryKey(\n    directoryId: LrRelayIdInput,\n    directoryKeyId?: LrRelayIdInput\n  ) {\n    return this.keyGraph.getKey(directoryKeyId, () =>\n      this.getDirectoryKeyId(directoryId)\n    );\n  }\n\n  async getFileKey(fileId: LrRelayIdInput, fileKeyId?: LrRelayIdInput) {\n    return this.keyGraph.getKey(fileKeyId, () => this.getFileKeyId(fileId));\n  }\n\n  createDirectoryExec(options: CreateDirectoryOptions) {\n    return this.mutate(this.createDirectoryMutation(options));\n  }\n\n  createDirectory(options: CreateDirectoryOptions) {\n    return this.createDirectoryMutation(options);\n  }\n\n  async createDirectoryMutation(options: CreateDirectoryOptions) {\n    return new LrMutation({\n      mutation: CreateDirectoryMutation,\n      variables: {\n        input: await this.prepareCreateDirectory(options),\n      },\n    });\n  }\n\n  updateDirectoryExec(options: UpdateDirectoryOptions) {\n    return this.mutate(this.updateDirectoryMutation(options));\n  }\n\n  updateDirectory(options: UpdateDirectoryOptions) {\n    return this.updateDirectoryMutation(options);\n  }\n\n  async updateDirectoryMutation(options: UpdateDirectoryOptions) {\n    return new LrMutation({\n      mutation: UpdateDirectoryMutation,\n      variables: {\n        input: await this.prepareUpdateDirectory(options),\n      },\n    });\n  }\n\n  deleteDirectoryExec(id: ID) {\n    return this.mutate(this.deleteDirectoryMutation(id));\n  }\n\n  deleteDirectory(id: ID) {\n    return this.deleteDirectoryMutation(id);\n  }\n\n  deleteDirectoryMutation(id: ID) {\n    return new LrMutation({\n      mutation: DeleteDirectoryMutation,\n      variables: {\n        input: {\n          directoryId: id,\n        },\n      },\n    });\n  }\n\n  createFileExec(options: CreateFileOptions) {\n    return this.mutate(this.createFileMutation(options));\n  }\n\n  createFile(options: CreateFileOptions) {\n    return this.createFileMutation(options);\n  }\n\n  async createFileMutation(options: CreateFileOptions) {\n    return new LrMutation({\n      mutation: CreateFileMutation,\n      variables: {\n        input: await this.prepareCreateFile(options),\n      },\n    });\n  }\n\n  updateFileExec(options: UpdateFileOptions) {\n    return this.mutate(this.updateFileMutation(options));\n  }\n\n  updateFile(options: UpdateFileOptions) {\n    return this.updateFileMutation(options);\n  }\n\n  async updateFileMutation(options: UpdateFileOptions) {\n    return new LrMutation({\n      mutation: UpdateFileMutation,\n      variables: {\n        input: await this.prepareUpdateFile(options),\n      },\n    });\n  }\n\n  revertFileExec(options: RevertFileOptions) {\n    return this.mutate(this.revertFileMutation(options));\n  }\n\n  revertFile(options: RevertFileOptions) {\n    return this.revertFileMutation(options);\n  }\n\n  async revertFileMutation(options: RevertFileOptions) {\n    return new LrMutation({\n      mutation: RevertFileMutation,\n      variables: {\n        input: options,\n      },\n    });\n  }\n\n  deleteFileExec(id: ID) {\n    return this.mutate(this.deleteFileMutation(id));\n  }\n\n  deleteFile(id: ID) {\n    return this.deleteFileMutation(id);\n  }\n\n  deleteFileMutation(id: ID) {\n    return new LrMutation({\n      mutation: DeleteFileMutation,\n      variables: {\n        input: {\n          fileId: id,\n        },\n      },\n    });\n  }\n\n  archiveDirectoryExec(directoryId: string, recursive: boolean) {\n    return this.mutate(this.archiveDirectoryMutation(directoryId, recursive));\n  }\n\n  archiveDirectory(directoryId: string, recursive: boolean) {\n    return this.archiveDirectoryMutation(directoryId, recursive);\n  }\n\n  archiveDirectoryMutation(directoryId: string, recursive: boolean) {\n    return new LrMutation({\n      mutation: ArchiveDirectoryMutation,\n      variables: {\n        input: {\n          directoryId,\n          recursive,\n        },\n      },\n    });\n  }\n\n  unarchiveDirectoryExec(directoryId: string, recursive: boolean) {\n    return this.mutate(this.unarchiveDirectoryMutation(directoryId, recursive));\n  }\n\n  unarchiveDirectory(directoryId: string, recursive: boolean) {\n    return this.unarchiveDirectoryMutation(directoryId, recursive);\n  }\n\n  unarchiveDirectoryMutation(directoryId: string, recursive: boolean) {\n    return new LrMutation({\n      mutation: UnarchiveDirectoryMutation,\n      variables: {\n        input: {\n          directoryId,\n          recursive,\n        },\n      },\n    });\n  }\n\n  changeDirectoryParents(options: ChangeDirectoryParentsOptions) {\n    return this.mutate(this.changeDirectoryParentsMutation(options));\n  }\n\n  async changeDirectoryParentsMutation(options: ChangeDirectoryParentsOptions) {\n    return new LrMutation({\n      mutation: ChangeDirectoryParentsMutation,\n      variables: {\n        input: await this.prepareChangeDirectoryParents(options),\n      },\n    });\n  }\n\n  async changeFileParents(options: ChangeFileParentsOptions) {\n    return this.mutate(this.changeFileParentsMutation(options));\n  }\n\n  async changeFileParentsMutation(options: ChangeFileParentsOptions) {\n    return new LrMutation({\n      mutation: ChangeFileParentsMutation,\n      variables: {\n        input: await this.prepareChangeFileParents(options),\n      },\n    });\n  }\n\n  beginDeleteChildItemLinksWindow(\n    options: BeginDeleteChildItemLinksWindowOptions\n  ) {\n    return this.mutate(this.beginDeleteChildItemLinksWindowMutation(options));\n  }\n\n  async beginDeleteChildItemLinksWindowMutation(\n    options: BeginDeleteChildItemLinksWindowOptions\n  ) {\n    return new LrMutation({\n      mutation: BeginDeleteChildItemLinksWindowMutation,\n      variables: {\n        input: options,\n      },\n    });\n  }\n\n  /**\n   *\n   * This method may raise VERSION_MISMATCH exception if there is a race condition\n   * when multiple clients try to create the temp directory.\n   *\n   * TODO There is a retry mechanism in graphql with exponential back off but that's internal.\n   * But need to use an exponential back off lib if we want to retry here.\n   *\n   * @returns The ID of the temp directory\n   *\n   */\n  async ensureTempDirectory(): Promise<Pick<DirectoryNode, 'id' | 'keyId'>> {\n    const existing = await this.query({\n      query: TempDirectoryQuery,\n      variables: {\n        plainMeta: Item2Service.TEMP_DIRECTORY_PLAIN_META_FILTER,\n      },\n    });\n\n    if (existing.rootDirectories.edges.length > 1) {\n      console.error(\n        `There is more than 1 temp directory (plainMeta filter: ${Item2Service.TEMP_DIRECTORY_PLAIN_META_FILTER})`\n      );\n    }\n\n    if (existing.rootDirectories.edges.length === 0) {\n      // Doesn't exist yet, create it\n      const createDirectory = await this.createDirectory({\n        asRootDirectory: true,\n        plainMetaJson: Item2Service.TEMP_DIRECTORY_PLAIN_META,\n      });\n\n      // Optimistic lock on the current user.\n      const updateLock = this.lockService.updateLockMutation({\n        version: existing.lock?.version,\n      });\n\n      // Because this.mutate() only handles simple types we need to use the more\n      // advanced this.lrGraphQL.lrMutate()\n      const [createDirectoryResult, _] = await this.lrGraphQL.lrMutate(\n        LrMergedMutation.create([createDirectory, updateLock])\n      );\n\n      const { id, keyId } = createDirectoryResult.createDirectory.directory;\n      return {\n        id,\n        keyId,\n      };\n    } else {\n      // Return existing temp\n      const { id, keyId } = existing.rootDirectories.edges[0].node;\n      return {\n        id,\n        keyId,\n      };\n    }\n  }\n\n  async createDirectoryTree(options: CreateDirectoryTreeOptions) {\n    return this.mutate(this.createDirectoryTreeMutation(options));\n  }\n\n  /**\n   * You must run this mutation within the temp directory cleanup window on the\n   * server, otherwise the temp directory will get cleaned up.\n   *\n   */\n  async createDirectoryTreeMutation(options: CreateDirectoryTreeOptions) {\n    const tempDir = await this.ensureTempDirectory();\n\n    // Clear the temp directory of the ones we are about to create.\n    await this.beginDeleteChildItemLinksWindow({\n      directoryId: tempDir.id,\n      requestWindowMs: options.requestWindowMs,\n    });\n\n    // Create the directory that has contents\n    const dirId = (\n      await this.createDirectoryExec({\n        cipherMetaClearJson: options.cipherMetaClearJson,\n        parentDirectories: [\n          {\n            directoryId: tempDir.id,\n            wrappingKeyId: tempDir.keyId,\n          },\n        ],\n        plainMetaJson: options.plainMetaJson,\n      })\n    ).createDirectory.directory.id;\n\n    // Create the contents\n    await options.createContent(dirId);\n\n    // TODO client-side check for timeout on requestWindowMs\n    // TODO return the server time where delete is scheduled. Expirable mutation\n\n    // Return the mutation that moves the directory into the dst directories\n    return this.changeDirectoryParentsMutation({\n      directoryId: dirId,\n      parentsToRemove: [tempDir.id],\n      parentsToAdd: options.parentDirectories,\n    });\n  }\n\n  // ------------------------------------------------------------------------------\n  // ------------------------------------------------------------------------------\n  // Helpers\n  // ------------------------------------------------------------------------------\n  // ------------------------------------------------------------------------------\n\n  private async prepareParentDirectory(\n    options: ParentDirectoryOptions,\n    newKey: JWK.Key\n  ): Promise<ParentDirectoryInput> {\n    // If directory's key is not already in the key graph, then need to\n    // fetch the directory's key.\n    const wrappingKey = await this.getDirectoryKey(\n      options.directoryId,\n      options.wrappingKeyId\n    );\n\n    return {\n      directoryId: options.directoryId,\n      wrappingKeyId: wrappingKey.id,\n      wrappedKey: await this.keyGraph.wrapKey(wrappingKey, newKey),\n      linkType: options.linkType,\n    };\n  }\n\n  private async getFileStateKeyId(fileStateNodeId: LrRelayIdInput) {\n    return (\n      await this.query({\n        query: FileStateKeyQuery,\n        variables: {\n          id: fileStateNodeId,\n        },\n      })\n    ).fileState.keyId;\n  }\n\n  private async prepareCreateFileState(\n    fileKey: JWK.Key,\n    options: CreateFileOptions | UpdateFileOptions\n  ) {\n    // Each version of the file is encrypted using a new key.\n    const fileStateKey = await this.keyFactory.createKey();\n\n    const fileContent =\n      options.file && (await this.fileUploadService.loadFile(options.file));\n\n    let contentResource: string;\n    if (fileContent) {\n      const cipherFileContent = await this.keyGraph.encryptToString(\n        fileStateKey,\n        fileContent\n      );\n      if (options.upload) {\n        contentResource = await options.upload(cipherFileContent);\n      } else {\n        contentResource = await this.fileUploadService.uploadEncryptedFile({\n          encryptedContent: cipherFileContent,\n        });\n      }\n      console.log('contentResource', contentResource);\n    }\n\n    return {\n      ...(await this.prepareItem(fileStateKey, options)),\n      wrappedStateKey: await this.keyGraph.wrapKey(fileKey, fileStateKey),\n      contentResource,\n    };\n  }\n\n  private async prepareChangeItemParents(\n    options: ChangeItemParentsOptions,\n    itemKey: JWK.Key\n  ) {\n    const parentsToAdd = await Promise.all(\n      options.parentsToAdd.map((t) => this.prepareParentDirectory(t, itemKey))\n    );\n\n    return {\n      directoriesToRemove: options.parentsToRemove,\n      directoriesToAdd: parentsToAdd,\n    };\n  }\n\n  private async prepareItem(\n    key: JWK.Key,\n    options: { plainMetaJson?: JSONObject; cipherMetaClearJson?: JSONObject }\n  ) {\n    const { plainMetaJson, cipherMetaClearJson } = options;\n\n    return {\n      plainMeta: plainMetaJson && JSON.stringify(plainMetaJson),\n      cipherMeta:\n        cipherMetaClearJson &&\n        (await this.keyGraph.encryptToString(key, cipherMetaClearJson)),\n    };\n  }\n\n  private async prepareCreateDirectory(options: CreateDirectoryOptions) {\n    const directoryKey = await this.keyFactory.createKey();\n    options.parentDirectories = options.parentDirectories || [];\n    if (!options.asRootDirectory && !options.parentDirectories?.length) {\n      throw new LrBadArgumentException(\n        'A new directory must be either a root directory or a sub-directory. So you must provide either parentDirectories and/or asRootDirectory parameter.'\n      );\n    }\n\n    const parentDirectories = await Promise.all(\n      options.parentDirectories?.map((t) =>\n        this.prepareParentDirectory(t, directoryKey)\n      )\n    );\n\n    // TODO this is rather an unfortunate name, change it to asRootDirectory.\n    let parentRootDirectory: ParentRootDirectoryInput;\n    if (options.asRootDirectory) {\n      const rootKey = this.keyService.getCurrentRootKey();\n      parentRootDirectory = {\n        wrappingKeyId: rootKey.id,\n        wrappedKey: await this.keyGraph.wrapKey(rootKey, directoryKey),\n      };\n    }\n\n    const itemInput = await this.prepareItem(directoryKey, options);\n\n    return {\n      ...itemInput,\n      parentDirectories,\n      parentRootDirectory,\n    };\n  }\n\n  private async prepareUpdateDirectory(options: UpdateDirectoryOptions) {\n    const directoryKey = await this.getDirectoryKey(\n      options.directoryId,\n      options.directoryKeyId\n    );\n\n    const itemInput = await this.prepareItem(directoryKey.jwk, options);\n\n    return {\n      ...itemInput,\n      directoryId: options.directoryId,\n    };\n  }\n\n  private async prepareCreateFile(options: CreateFileOptions) {\n    const fileKey = await this.keyFactory.createKey();\n\n    const parentDirectories = await Promise.all(\n      options.parentDirectories.map(async (t) => {\n        const { directoryId, wrappingKeyId, wrappedKey } =\n          await this.prepareParentDirectory(t, fileKey);\n        // remap from ParentDirectoryInput to FileParentDirectoryInput\n        // TODO the server should really just use wrappedKey instead of wrappedFileKey\n        return {\n          directoryId,\n          wrappingKeyId,\n          wrappedFileKey: wrappedKey,\n        } as FileParentDirectoryInput;\n      })\n    );\n\n    const input = await this.prepareCreateFileState(fileKey, options);\n\n    return {\n      ...input,\n      parentDirectories,\n    };\n  }\n\n  private async prepareUpdateFile(options: UpdateFileOptions) {\n    const fileKey = await this.getFileKey(options.fileId, options.fileKeyId);\n    const input = await this.prepareCreateFileState(fileKey.jwk, options);\n\n    return {\n      ...input,\n      fileId: options.fileId,\n    };\n  }\n\n  private async prepareChangeDirectoryParents(\n    options: ChangeDirectoryParentsOptions\n  ) {\n    const directoryKey = await this.getDirectoryKey(\n      options.directoryId,\n      options.directoryKeyId\n    );\n\n    const input = await this.prepareChangeItemParents(\n      options,\n      directoryKey.jwk\n    );\n\n    return {\n      ...input,\n      directoryId: options.directoryId,\n    };\n  }\n\n  private async prepareChangeFileParents(options: ChangeFileParentsOptions) {\n    const fileKey = await this.getFileKey(options.fileId, options.fileKeyId);\n\n    const input = await this.prepareChangeItemParents(options, fileKey.jwk);\n\n    return {\n      ...input,\n      fileId: options.fileId,\n    };\n  }\n}\n"]}
|
|
@@ -0,0 +1,237 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { Injectable } from '@angular/core';
|
|
3
|
+
import { JWK } from 'node-jose';
|
|
4
|
+
import { WebCryptoService } from '../web-crypto/web-crypto.service';
|
|
5
|
+
import { LrBadArgumentException, LrSuspiciousException, } from '../_common/exceptions';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "../web-crypto/web-crypto.service";
|
|
8
|
+
export function sha256(message) {
|
|
9
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
10
|
+
// encode as UTF-8
|
|
11
|
+
const msgBuffer = new TextEncoder().encode(message);
|
|
12
|
+
// hash the message
|
|
13
|
+
const hashBuffer = yield crypto.subtle.digest('SHA-256', msgBuffer);
|
|
14
|
+
// convert ArrayBuffer to Array
|
|
15
|
+
const hashArray = Array.from(new Uint8Array(hashBuffer));
|
|
16
|
+
// convert bytes to hex string
|
|
17
|
+
const hashHex = hashArray
|
|
18
|
+
.map((b) => ('00' + b.toString(16)).slice(-2))
|
|
19
|
+
.join('');
|
|
20
|
+
return hashHex;
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
export class KeyFactoryService {
|
|
24
|
+
constructor(webCryptoService) {
|
|
25
|
+
this.webCryptoService = webCryptoService;
|
|
26
|
+
// Global keys store. Otherwise, each call to asKey creates a new keyStore.
|
|
27
|
+
// <AZ> Did not seem to improve speed.
|
|
28
|
+
// public static keyStore = JWK.createKeyStore();
|
|
29
|
+
// AZ: This can't be change easily. It's basically a PassK or PassIdp rotation.
|
|
30
|
+
// todo: we should eventually increase this periodically to match with Moore's law.
|
|
31
|
+
// The iterations for each key are kept by the server as well but we assume the value
|
|
32
|
+
// from the server is not trustworthy, so need to have minimum thresholds here.
|
|
33
|
+
// If creating new keys, these minimum are used.
|
|
34
|
+
this.MIN_PASS_IDP_PBKDF_ITER = 100000;
|
|
35
|
+
this.MIN_PASS_KEY_PBKDF_ITER = 100000;
|
|
36
|
+
this.MIN_LBOP_KEY_PBKDF_ITER = 100000;
|
|
37
|
+
// These are used as the default values. They must be larger than the minimum values.
|
|
38
|
+
this.DEFAULT_PASS_IDP_PBKDF_ITER = this.MIN_PASS_IDP_PBKDF_ITER;
|
|
39
|
+
this.DEFAULT_PASS_KEY_PBKDF_ITER = this.MIN_PASS_KEY_PBKDF_ITER;
|
|
40
|
+
this.DEFAULT_LBOP_KEY_PBKDF_ITER = this.MIN_LBOP_KEY_PBKDF_ITER;
|
|
41
|
+
this.crypto = this.webCryptoService.crypto;
|
|
42
|
+
}
|
|
43
|
+
static asKey(key, form, extras) {
|
|
44
|
+
// <AZ> Using a single global key store did not seem to improve speed.
|
|
45
|
+
// return KeyFactoryService.keyStore.add(key, form, extras);
|
|
46
|
+
return JWK.asKey(key, form, extras);
|
|
47
|
+
}
|
|
48
|
+
randomString(digits) {
|
|
49
|
+
if (digits <= 0) {
|
|
50
|
+
throw new LrBadArgumentException('digits <= 0');
|
|
51
|
+
}
|
|
52
|
+
const validChars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
|
|
53
|
+
let array = new Uint32Array(digits);
|
|
54
|
+
this.crypto.getRandomValues(array);
|
|
55
|
+
array = array.map((x) => validChars.charCodeAt(x % validChars.length));
|
|
56
|
+
return String.fromCharCode.apply(null, array);
|
|
57
|
+
}
|
|
58
|
+
randomDigitsNoZeros(digits) {
|
|
59
|
+
return this.randomChoices([1, 2, 3, 4, 5, 6, 7, 8, 9], digits).join('');
|
|
60
|
+
}
|
|
61
|
+
randomChoices(array, chooseN) {
|
|
62
|
+
if (array.length <= 1) {
|
|
63
|
+
throw new LrBadArgumentException('array.length <= 0');
|
|
64
|
+
}
|
|
65
|
+
if (chooseN <= 0) {
|
|
66
|
+
throw new LrBadArgumentException('chooseN <= 0');
|
|
67
|
+
}
|
|
68
|
+
const values = new Uint32Array(chooseN);
|
|
69
|
+
this.crypto.getRandomValues(values);
|
|
70
|
+
const ret = [];
|
|
71
|
+
values.forEach((v) => ret.push(array[v % array.length]));
|
|
72
|
+
return ret;
|
|
73
|
+
}
|
|
74
|
+
createSalt() {
|
|
75
|
+
return this.randomString(16);
|
|
76
|
+
}
|
|
77
|
+
createKey() {
|
|
78
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
79
|
+
const key = yield this.crypto.subtle.generateKey({
|
|
80
|
+
name: 'AES-GCM',
|
|
81
|
+
length: 256,
|
|
82
|
+
}, true, // whether the key is extractable (i.e. can be used in exportKey)
|
|
83
|
+
['encrypt', 'decrypt'] // must be ["encrypt", "decrypt"] or ["wrapKey", "unwrapKey"]
|
|
84
|
+
);
|
|
85
|
+
const jwk = yield this.crypto.subtle.exportKey('jwk', key);
|
|
86
|
+
// Removing the fields not needed by node-jose
|
|
87
|
+
delete jwk.ext;
|
|
88
|
+
delete jwk.key_ops;
|
|
89
|
+
return KeyFactoryService.asKey(jwk);
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
createSignKey() {
|
|
93
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
94
|
+
const key = yield this.crypto.subtle.generateKey({
|
|
95
|
+
name: 'HMAC',
|
|
96
|
+
hash: { name: 'SHA-512' },
|
|
97
|
+
}, true, ['sign', 'verify']);
|
|
98
|
+
const jwk = yield this.crypto.subtle.exportKey('jwk', key);
|
|
99
|
+
// Removing the fields not needed by node-jose
|
|
100
|
+
delete jwk.key_ops;
|
|
101
|
+
delete jwk.ext;
|
|
102
|
+
return KeyFactoryService.asKey(jwk);
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
createPkcKey() {
|
|
106
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
107
|
+
// node-jose is not using Forge properly. It should be calling the async version of
|
|
108
|
+
// pki.rsa.generateKeyPair() with a callback. Instead it calls the sync version. Webcrypto
|
|
109
|
+
// does not support sync version, so it uses the javascript implementation, which is way too slow.
|
|
110
|
+
// So we generate using webcrypto and import the key.
|
|
111
|
+
// Unfortunately Elliptical Curve is not supported by Webcrypto. So we have to settle for RSA.
|
|
112
|
+
const key = yield this.crypto.subtle.generateKey({
|
|
113
|
+
name: 'RSA-OAEP',
|
|
114
|
+
modulusLength: 2048,
|
|
115
|
+
// As per suggestion: https://developer.mozilla.org/en-US/docs/Web/API/RsaHashedKeyGenParams
|
|
116
|
+
publicExponent: new Uint8Array([0x01, 0x00, 0x01]),
|
|
117
|
+
hash: { name: 'SHA-256' },
|
|
118
|
+
}, true, // whether the key is extractable (i.e. can be used in exportKey)
|
|
119
|
+
['encrypt', 'decrypt'] // must be ["encrypt", "decrypt"] or ["wrapKey", "unwrapKey"]
|
|
120
|
+
);
|
|
121
|
+
const jwk = yield this.crypto.subtle.exportKey('jwk', key.privateKey);
|
|
122
|
+
// Removing the fields not needed by node-jose
|
|
123
|
+
delete jwk.key_ops;
|
|
124
|
+
delete jwk.ext;
|
|
125
|
+
return KeyFactoryService.asKey(jwk);
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
createPkcSignKey() {
|
|
129
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
130
|
+
const key = yield this.crypto.subtle.generateKey({
|
|
131
|
+
name: 'RSASSA-PKCS1-v1_5',
|
|
132
|
+
modulusLength: 2048,
|
|
133
|
+
// As per suggestion: https://developer.mozilla.org/en-US/docs/Web/API/RsaHashedKeyGenParams
|
|
134
|
+
publicExponent: new Uint8Array([0x01, 0x00, 0x01]),
|
|
135
|
+
hash: { name: 'SHA-256' },
|
|
136
|
+
}, true, // whether the key is extractable (i.e. can be used in exportKey)
|
|
137
|
+
['sign', 'verify'] // can be any combination of "sign" and "verify"
|
|
138
|
+
);
|
|
139
|
+
const jwk = yield this.crypto.subtle.exportKey('jwk', key.privateKey);
|
|
140
|
+
// Removing the fields not needed by node-jose
|
|
141
|
+
delete jwk.key_ops;
|
|
142
|
+
delete jwk.ext;
|
|
143
|
+
return KeyFactoryService.asKey(jwk);
|
|
144
|
+
});
|
|
145
|
+
}
|
|
146
|
+
deriveKey({ password, salt, iterations, kid, }) {
|
|
147
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
148
|
+
const enc = new TextEncoder();
|
|
149
|
+
const rawKey = yield this.crypto.subtle.importKey('raw', enc.encode(password), 'PBKDF2', false, ['deriveBits', 'deriveKey']);
|
|
150
|
+
const passKey = yield crypto.subtle.deriveKey({
|
|
151
|
+
name: 'PBKDF2',
|
|
152
|
+
salt: new TextEncoder().encode(salt),
|
|
153
|
+
iterations,
|
|
154
|
+
hash: 'SHA-256',
|
|
155
|
+
}, rawKey, { name: 'AES-GCM', length: 256 }, true, ['encrypt', 'decrypt']);
|
|
156
|
+
const passKeyJson = yield crypto.subtle.exportKey('jwk', passKey);
|
|
157
|
+
if (kid) {
|
|
158
|
+
passKeyJson.kid = kid;
|
|
159
|
+
}
|
|
160
|
+
const jwk = yield KeyFactoryService.asKey(passKeyJson);
|
|
161
|
+
return { jwk };
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
derivePassIdp(params) {
|
|
165
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
166
|
+
if (params.iterations < this.MIN_PASS_IDP_PBKDF_ITER) {
|
|
167
|
+
throw new LrSuspiciousException(`The number of PassIdp key derivation iterations sent from the server (${params.iterations}) is lower than the minimum (${this.MIN_PASS_IDP_PBKDF_ITER})`);
|
|
168
|
+
}
|
|
169
|
+
return this.deriveKey(params);
|
|
170
|
+
});
|
|
171
|
+
}
|
|
172
|
+
derivePassKey(params) {
|
|
173
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
174
|
+
if (params.iterations < this.MIN_PASS_KEY_PBKDF_ITER) {
|
|
175
|
+
throw new LrSuspiciousException(`The number of PassKey key derivation iterations sent from the server(${params.iterations}) is lower than the minimum(${this.MIN_PASS_KEY_PBKDF_ITER})`);
|
|
176
|
+
}
|
|
177
|
+
return this.deriveKey(params);
|
|
178
|
+
});
|
|
179
|
+
}
|
|
180
|
+
deriveLbopKey(params) {
|
|
181
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
182
|
+
if (params.iterations < this.MIN_LBOP_KEY_PBKDF_ITER) {
|
|
183
|
+
throw new LrSuspiciousException(`The number of LbopKey key derivation iterations sent from the server(${params.iterations}) is lower than the minimum(${this.MIN_LBOP_KEY_PBKDF_ITER})`);
|
|
184
|
+
}
|
|
185
|
+
return this.deriveKey(params);
|
|
186
|
+
});
|
|
187
|
+
}
|
|
188
|
+
createKid() {
|
|
189
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
190
|
+
// todo: AZ: node-jose source uses node's default UUID() function for kid, so just change to use that.
|
|
191
|
+
// for now, we are just creating a new key to use it's kid.
|
|
192
|
+
// The kid is a part of the JWK system. LR backend maintains the key hierarchy separately with it's own
|
|
193
|
+
// key id. But we just use it here as a double check.
|
|
194
|
+
return (yield this.createKey()).kid;
|
|
195
|
+
});
|
|
196
|
+
}
|
|
197
|
+
createPassIdpParams() {
|
|
198
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
199
|
+
return {
|
|
200
|
+
salt: this.createSalt(),
|
|
201
|
+
iterations: this.DEFAULT_PASS_IDP_PBKDF_ITER,
|
|
202
|
+
};
|
|
203
|
+
});
|
|
204
|
+
}
|
|
205
|
+
createPassKeyParams() {
|
|
206
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
207
|
+
return {
|
|
208
|
+
salt: this.createSalt(),
|
|
209
|
+
kid: yield this.createKid(),
|
|
210
|
+
iterations: this.DEFAULT_PASS_KEY_PBKDF_ITER,
|
|
211
|
+
};
|
|
212
|
+
});
|
|
213
|
+
}
|
|
214
|
+
createLbopKeyParams() {
|
|
215
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
216
|
+
return {
|
|
217
|
+
salt: this.createSalt(),
|
|
218
|
+
// todo: AZ: node-jose source uses node's default UUID() function for kid, so just change to use that.
|
|
219
|
+
// for now, we are just creating a new key to use it's kid.
|
|
220
|
+
// The kid is a part of the JWK system. LR backend maintains the key hierarchy separately with it's own
|
|
221
|
+
// key id. But we just use it here as a double check.
|
|
222
|
+
kid: yield this.createKid(),
|
|
223
|
+
iterations: this.DEFAULT_PASS_KEY_PBKDF_ITER,
|
|
224
|
+
};
|
|
225
|
+
});
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
KeyFactoryService.ɵprov = i0.ɵɵdefineInjectable({ factory: function KeyFactoryService_Factory() { return new KeyFactoryService(i0.ɵɵinject(i1.WebCryptoService)); }, token: KeyFactoryService, providedIn: "root" });
|
|
229
|
+
KeyFactoryService.decorators = [
|
|
230
|
+
{ type: Injectable, args: [{
|
|
231
|
+
providedIn: 'root',
|
|
232
|
+
},] }
|
|
233
|
+
];
|
|
234
|
+
KeyFactoryService.ctorParameters = () => [
|
|
235
|
+
{ type: WebCryptoService }
|
|
236
|
+
];
|
|
237
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key-factory.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/key/key-factory.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { JWK } from 'node-jose';\nimport { JSONObject } from '../api/types';\nimport { WebCryptoService } from '../web-crypto/web-crypto.service';\nimport {\n  LrBadArgumentException,\n  LrSuspiciousException,\n} from '../_common/exceptions';\nimport {\n  DeriveKeyResult,\n  DeriveLbopKeyParams,\n  DerivePassIdpParams,\n  DerivePassKeyParams,\n  LbopKeyParams,\n  PassIdpParams,\n  PassKeyParams,\n} from './key.types';\n\nexport async function sha256(message) {\n  // encode as UTF-8\n  const msgBuffer = new TextEncoder().encode(message);\n\n  // hash the message\n  const hashBuffer = await crypto.subtle.digest('SHA-256', msgBuffer);\n\n  // convert ArrayBuffer to Array\n  const hashArray = Array.from(new Uint8Array(hashBuffer));\n\n  // convert bytes to hex string\n  const hashHex = hashArray\n    .map((b) => ('00' + b.toString(16)).slice(-2))\n    .join('');\n  return hashHex;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class KeyFactoryService {\n  constructor(private webCryptoService: WebCryptoService) {\n    this.crypto = this.webCryptoService.crypto;\n  }\n  private readonly crypto;\n  // Global keys store. Otherwise, each call to asKey creates a new keyStore.\n  // <AZ> Did not seem to improve speed.\n  // public static keyStore = JWK.createKeyStore();\n\n  // AZ: This can't be change easily. It's basically a PassK or PassIdp rotation.\n  // todo: we should eventually increase this periodically to match with Moore's law.\n  // The iterations for each key are kept by the server as well but we assume the value\n  // from the server is not trustworthy, so need to have minimum thresholds here.\n  // If creating new keys, these minimum are used.\n  public readonly MIN_PASS_IDP_PBKDF_ITER = 100000;\n  public readonly MIN_PASS_KEY_PBKDF_ITER = 100000;\n  public readonly MIN_LBOP_KEY_PBKDF_ITER = 100000;\n\n  // These are used as the default values. They must be larger than the minimum values.\n  public readonly DEFAULT_PASS_IDP_PBKDF_ITER = this.MIN_PASS_IDP_PBKDF_ITER;\n  public readonly DEFAULT_PASS_KEY_PBKDF_ITER = this.MIN_PASS_KEY_PBKDF_ITER;\n  public readonly DEFAULT_LBOP_KEY_PBKDF_ITER = this.MIN_LBOP_KEY_PBKDF_ITER;\n\n  static asKey(\n    key: string | Buffer | object | JWK.RawKey,\n    form?:\n      | 'json'\n      | 'private'\n      | 'pkcs8'\n      | 'public'\n      | 'spki'\n      | 'pkix'\n      | 'x509'\n      | 'pem',\n    extras?: Record<string, unknown>\n  ): Promise<JWK.Key> {\n    // <AZ> Using a single global key store did not seem to improve speed.\n    // return KeyFactoryService.keyStore.add(key, form, extras);\n    return JWK.asKey(key, form, extras);\n  }\n\n  randomString(digits: number): string {\n    if (digits <= 0) {\n      throw new LrBadArgumentException('digits <= 0');\n    }\n    const validChars =\n      'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\n    let array = new Uint32Array(digits);\n    this.crypto.getRandomValues(array);\n    array = array.map((x) => validChars.charCodeAt(x % validChars.length));\n    return String.fromCharCode.apply(null, array);\n  }\n\n  randomDigitsNoZeros(digits: number): string {\n    return this.randomChoices([1, 2, 3, 4, 5, 6, 7, 8, 9], digits).join('');\n  }\n\n  randomChoices<T>(array: T[], chooseN: number): T[] {\n    if (array.length <= 1) {\n      throw new LrBadArgumentException('array.length <= 0');\n    }\n    if (chooseN <= 0) {\n      throw new LrBadArgumentException('chooseN <= 0');\n    }\n    const values = new Uint32Array(chooseN);\n    this.crypto.getRandomValues(values);\n    const ret: T[] = [];\n    values.forEach((v) => ret.push(array[v % array.length]));\n    return ret;\n  }\n\n  createSalt(): string {\n    return this.randomString(16);\n  }\n\n  async createKey(): Promise<JWK.Key> {\n    const key = await this.crypto.subtle.generateKey(\n      {\n        name: 'AES-GCM',\n        length: 256, // can be  128, 192, or 256\n      },\n      true, // whether the key is extractable (i.e. can be used in exportKey)\n      ['encrypt', 'decrypt'] // must be [\"encrypt\", \"decrypt\"] or [\"wrapKey\", \"unwrapKey\"]\n    );\n\n    const jwk = await this.crypto.subtle.exportKey('jwk', key);\n\n    // Removing the fields not needed by node-jose\n    delete jwk.ext;\n    delete jwk.key_ops;\n\n    return KeyFactoryService.asKey(jwk);\n  }\n\n  async createSignKey(): Promise<JWK.Key> {\n    const key = await this.crypto.subtle.generateKey(\n      {\n        name: 'HMAC',\n        hash: { name: 'SHA-512' },\n      },\n      true,\n      ['sign', 'verify']\n    );\n\n    const jwk = await this.crypto.subtle.exportKey('jwk', key);\n\n    // Removing the fields not needed by node-jose\n    delete jwk.key_ops;\n    delete jwk.ext;\n\n    return KeyFactoryService.asKey(jwk);\n  }\n\n  async createPkcKey(): Promise<JWK.Key> {\n    // node-jose is not using Forge properly. It should be calling the async version of\n    // pki.rsa.generateKeyPair() with a callback. Instead it calls the sync version. Webcrypto\n    // does not support sync version, so it uses the javascript implementation, which is way too slow.\n    // So we generate using webcrypto and import the key.\n    // Unfortunately Elliptical Curve is not supported by Webcrypto. So we have to settle for RSA.\n    const key = await this.crypto.subtle.generateKey(\n      {\n        name: 'RSA-OAEP',\n        modulusLength: 2048, // can be 1024, 2048, 3072, 4096 ... 16384\n        // As per suggestion: https://developer.mozilla.org/en-US/docs/Web/API/RsaHashedKeyGenParams\n        publicExponent: new Uint8Array([0x01, 0x00, 0x01]),\n        hash: { name: 'SHA-256' }, // can be \"SHA-1\", \"SHA-256\", \"SHA-384\", or \"SHA-512\"\n      },\n      true, // whether the key is extractable (i.e. can be used in exportKey)\n      ['encrypt', 'decrypt'] // must be [\"encrypt\", \"decrypt\"] or [\"wrapKey\", \"unwrapKey\"]\n    );\n\n    const jwk = await this.crypto.subtle.exportKey('jwk', key.privateKey);\n    // Removing the fields not needed by node-jose\n    delete jwk.key_ops;\n    delete jwk.ext;\n\n    return KeyFactoryService.asKey(jwk);\n  }\n\n  async createPkcSignKey(): Promise<JWK.Key> {\n    const key = await this.crypto.subtle.generateKey(\n      {\n        name: 'RSASSA-PKCS1-v1_5',\n        modulusLength: 2048, // can be 1024, 2048, or 4096\n        // As per suggestion: https://developer.mozilla.org/en-US/docs/Web/API/RsaHashedKeyGenParams\n        publicExponent: new Uint8Array([0x01, 0x00, 0x01]),\n        hash: { name: 'SHA-256' }, // can be \"SHA-1\", \"SHA-256\", \"SHA-384\", or \"SHA-512\"\n      },\n      true, // whether the key is extractable (i.e. can be used in exportKey)\n      ['sign', 'verify'] // can be any combination of \"sign\" and \"verify\"\n    );\n\n    const jwk = await this.crypto.subtle.exportKey('jwk', key.privateKey);\n\n    // Removing the fields not needed by node-jose\n    delete jwk.key_ops;\n    delete jwk.ext;\n\n    return KeyFactoryService.asKey(jwk);\n  }\n\n  async deriveKey({\n    password,\n    salt,\n    iterations,\n    kid,\n  }: {\n    password: string;\n    salt: string;\n    iterations: number;\n    kid?: string;\n  }): Promise<DeriveKeyResult> {\n    const enc = new TextEncoder();\n    const rawKey = await this.crypto.subtle.importKey(\n      'raw',\n      enc.encode(password),\n      'PBKDF2',\n      false,\n      ['deriveBits', 'deriveKey']\n    );\n\n    const passKey = await crypto.subtle.deriveKey(\n      {\n        name: 'PBKDF2',\n        salt: new TextEncoder().encode(salt),\n        iterations,\n        hash: 'SHA-256',\n      },\n      rawKey,\n      { name: 'AES-GCM', length: 256 },\n      true,\n      ['encrypt', 'decrypt']\n    );\n\n    const passKeyJson: JSONObject = await crypto.subtle.exportKey(\n      'jwk',\n      passKey\n    );\n    if (kid) {\n      passKeyJson.kid = kid;\n    }\n\n    const jwk = await KeyFactoryService.asKey(passKeyJson);\n\n    return { jwk };\n  }\n\n  async derivePassIdp(params: DerivePassIdpParams): Promise<DeriveKeyResult> {\n    if (params.iterations < this.MIN_PASS_IDP_PBKDF_ITER) {\n      throw new LrSuspiciousException(\n        `The number of PassIdp key derivation iterations sent from the server (${params.iterations}) is lower than the minimum (${this.MIN_PASS_IDP_PBKDF_ITER})`\n      );\n    }\n    return this.deriveKey(params);\n  }\n\n  async derivePassKey(params: DerivePassKeyParams): Promise<DeriveKeyResult> {\n    if (params.iterations < this.MIN_PASS_KEY_PBKDF_ITER) {\n      throw new LrSuspiciousException(\n        `The number of PassKey key derivation iterations sent from the server(${params.iterations}) is lower than the minimum(${this.MIN_PASS_KEY_PBKDF_ITER})`\n      );\n    }\n    return this.deriveKey(params);\n  }\n\n  async deriveLbopKey(params: DeriveLbopKeyParams): Promise<DeriveKeyResult> {\n    if (params.iterations < this.MIN_LBOP_KEY_PBKDF_ITER) {\n      throw new LrSuspiciousException(\n        `The number of LbopKey key derivation iterations sent from the server(${params.iterations}) is lower than the minimum(${this.MIN_LBOP_KEY_PBKDF_ITER})`\n      );\n    }\n    return this.deriveKey(params);\n  }\n\n  async createKid(): Promise<string> {\n    // todo: AZ: node-jose source uses node's default UUID() function for kid, so just change to use that.\n    // for now, we are just creating a new key to use it's kid.\n    // The kid is a part of the JWK system. LR backend maintains the key hierarchy separately with it's own\n    // key id. But we just use it here as a double check.\n    return (await this.createKey()).kid;\n  }\n\n  async createPassIdpParams(): Promise<PassIdpParams> {\n    return {\n      salt: this.createSalt(),\n      iterations: this.DEFAULT_PASS_IDP_PBKDF_ITER,\n    };\n  }\n\n  async createPassKeyParams(): Promise<PassKeyParams> {\n    return {\n      salt: this.createSalt(),\n      kid: await this.createKid(),\n      iterations: this.DEFAULT_PASS_KEY_PBKDF_ITER,\n    };\n  }\n\n  async createLbopKeyParams(): Promise<LbopKeyParams> {\n    return {\n      salt: this.createSalt(),\n      // todo: AZ: node-jose source uses node's default UUID() function for kid, so just change to use that.\n      // for now, we are just creating a new key to use it's kid.\n      // The kid is a part of the JWK system. LR backend maintains the key hierarchy separately with it's own\n      // key id. But we just use it here as a double check.\n      kid: await this.createKid(),\n      iterations: this.DEFAULT_PASS_KEY_PBKDF_ITER,\n    };\n  }\n}\n"]}
|