@lifeready/core 1.0.21 → 1.0.23
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 +10612 -10527
- package/bundles/lifeready-core.umd.js.map +1 -1
- package/bundles/lifeready-core.umd.min.js +1 -15
- package/bundles/lifeready-core.umd.min.js.map +1 -1
- package/esm2015/lib/_common/ast.js +2 -1
- package/esm2015/lib/_common/deferred-promise.js +1 -1
- package/esm2015/lib/_common/exceptions.js +1 -1
- package/esm2015/lib/_common/queries.gql.js +1 -1
- package/esm2015/lib/_common/run-outside-angular.js +3 -2
- package/esm2015/lib/_common/types.js +2 -1
- package/esm2015/lib/_common/utils.js +2 -1
- package/esm2015/lib/api/lr-apollo.service.js +4 -3
- package/esm2015/lib/api/lr-graphql/index.js +1 -1
- package/esm2015/lib/api/lr-graphql/lr-graphql.service.js +9 -8
- package/esm2015/lib/api/lr-graphql/lr-merged-mutation.js +5 -6
- package/esm2015/lib/api/lr-graphql/lr-mutation-base.js +1 -1
- package/esm2015/lib/api/lr-graphql/lr-mutation.js +3 -3
- package/esm2015/lib/api/lr-graphql/lr.service.js +1 -1
- package/esm2015/lib/api/query-processor/common-processors.service.js +4 -3
- package/esm2015/lib/api/query-processor/index.js +1 -1
- package/esm2015/lib/api/query-processor/query-processor.service.js +5 -4
- package/esm2015/lib/api/query-processor/tp-password-reset-processor.service.js +8 -7
- package/esm2015/lib/api/types/graphql.types.js +2 -1
- package/esm2015/lib/api/types/index.js +1 -1
- package/esm2015/lib/api/types/lr-graphql.types.js +1 -1
- package/esm2015/lib/auth/auth.config.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 +36 -32
- package/esm2015/lib/category/category-meta.service.js +1 -1
- package/esm2015/lib/category/category.gql.js +3 -2
- package/esm2015/lib/category/category.service.js +9 -8
- package/esm2015/lib/category/category.types.js +1 -1
- package/esm2015/lib/contact-card/contact-card.gql.js +79 -0
- package/esm2015/lib/contact-card/contact-card.service.js +156 -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 +190 -0
- package/esm2015/lib/file-upload/file-upload.service.js +74 -0
- package/esm2015/lib/file-upload/file-upload.types.js +2 -0
- package/esm2015/lib/idle/idle.service.js +168 -0
- package/esm2015/lib/idle/idle.types.js +7 -0
- package/esm2015/lib/item2/item2.gql.js +127 -0
- package/esm2015/lib/item2/item2.gql.private.js +23 -0
- package/esm2015/lib/item2/item2.service.js +519 -0
- package/esm2015/lib/item2/item2.types.js +2 -0
- package/esm2015/lib/key/key-factory.service.js +237 -0
- package/esm2015/lib/key/key-graph.service.js +300 -0
- package/esm2015/lib/key/key-meta.service.js +201 -0
- package/esm2015/lib/{cryptography → key}/key.service.js +4 -4
- 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 +441 -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 +357 -0
- package/esm2015/lib/life-ready.config.js +2 -1
- 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 +118 -0
- package/esm2015/lib/message/message.types.js +2 -0
- package/esm2015/lib/notification/notification.gql.js +1 -1
- package/esm2015/lib/notification/notification.service.js +2 -2
- package/esm2015/lib/password/password.gql.js +28 -0
- package/esm2015/lib/password/password.service.js +316 -0
- package/esm2015/lib/persist/persist.service.js +181 -0
- package/esm2015/lib/plan/plan.gql.js +1 -1
- package/esm2015/lib/plan/plan.service.js +3 -2
- package/esm2015/lib/plan/plan.types.js +1 -1
- package/esm2015/lib/profile/profile-details.service.js +215 -0
- package/esm2015/lib/profile/profile.gql.js +98 -0
- package/esm2015/lib/profile/profile.service.js +170 -0
- package/esm2015/lib/profile/profile.types.js +34 -0
- package/esm2015/lib/record/record-attachment.service.js +16 -15
- package/esm2015/lib/record/record.gql.js +1 -1
- package/esm2015/lib/record/record.service.js +8 -8
- package/esm2015/lib/record/record.types.js +1 -1
- package/esm2015/lib/record-type/record-type.service.js +1 -1
- package/esm2015/lib/record-type/record-type.types.js +1 -1
- package/esm2015/lib/register/register.service.js +173 -0
- package/esm2015/lib/scenario/scenario.constants.js +1 -1
- package/esm2015/lib/scenario/scenario.controller.js +2 -2
- package/esm2015/lib/scenario/scenario.gql.js +1 -1
- package/esm2015/lib/scenario/scenario.private.gql.js +198 -0
- package/esm2015/lib/scenario/scenario.service.js +19 -17
- package/esm2015/lib/scenario/scenario.types.js +2 -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 +167 -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 +2 -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 +118 -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 +2 -0
- package/esm2015/lib/trusted-party/trusted-party.gql.js +148 -0
- package/esm2015/lib/trusted-party/trusted-party.service.js +327 -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 +2 -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 +80 -0
- package/esm2015/lib/user/user.types.js +2 -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 +8764 -8737
- package/fesm2015/lifeready-core.js.map +1 -1
- package/lib/_common/types.d.ts +3 -1
- package/lib/_common/utils.d.ts +2 -2
- package/lib/api/lr-apollo.service.d.ts +2 -2
- package/lib/api/lr-graphql/lr-graphql.service.d.ts +26 -8
- package/lib/api/lr-graphql/lr-merged-mutation.d.ts +22 -4
- package/lib/api/lr-graphql/lr-mutation.d.ts +1 -2
- 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 +2 -2
- package/lib/api/types/lr-graphql.types.d.ts +14 -3
- package/lib/auth/auth.gql.d.ts +0 -3
- package/lib/auth/auth.types.d.ts +5 -5
- package/lib/auth/life-ready-auth.service.d.ts +13 -13
- package/lib/category/category.gql.d.ts +1 -1
- package/lib/category/category.service.d.ts +3 -3
- 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/contact-card/contact-card2.service.d.ts +64 -0
- package/lib/{cryptography → encryption}/encryption.service.d.ts +10 -9
- package/lib/{api/file.service.d.ts → file-upload/file-upload.service.d.ts} +5 -8
- package/lib/file-upload/file-upload.types.d.ts +5 -0
- package/lib/{auth → idle}/idle.service.d.ts +6 -6
- package/lib/{items2 → item2}/item2.gql.d.ts +16 -16
- package/lib/{items2 → item2}/item2.service.d.ts +34 -35
- package/lib/{cryptography → key}/key-factory.service.d.ts +4 -3
- package/lib/{cryptography → key}/key-graph.service.d.ts +6 -6
- 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} +13 -17
- 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 +82 -29
- package/lib/{auth → lbop}/lbop.service.d.ts +7 -7
- package/lib/life-ready.config.d.ts +1 -1
- 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 +36 -0
- package/lib/message/message.types.d.ts +12 -0
- package/lib/notification/notification.service.d.ts +3 -2
- package/lib/password/password.gql.d.ts +3 -0
- package/lib/{auth → password}/password.service.d.ts +9 -9
- package/lib/{api → persist}/persist.service.d.ts +3 -3
- package/lib/plan/plan.service.d.ts +3 -2
- package/lib/plan/plan.types.d.ts +2 -1
- 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 +3 -2
- package/lib/record/record-attachment.service.d.ts +6 -6
- package/lib/record/record.service.d.ts +3 -3
- 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 +105 -5
- 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/{cryptography → slip39}/slip39.service.d.ts +0 -1
- package/lib/{trusted-parties → tp-assembly}/tp-assembly.d.ts +7 -7
- package/lib/{trusted-parties → tp-assembly}/tp-assembly.types.d.ts +3 -3
- package/lib/{trusted-parties → tp-password-reset}/tp-password-reset-request.service.d.ts +5 -9
- 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.service.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 +2 -2
- 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/idle.service.js +0 -168
- package/esm2015/lib/auth/idle.types.js +0 -7
- 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-graph.service.js +0 -299
- package/esm2015/lib/cryptography/key-meta.service.js +0 -200
- package/esm2015/lib/cryptography/slip39.service.js +0 -169
- package/esm2015/lib/cryptography/web-crypto.service.js +0 -29
- package/esm2015/lib/items2/item2.gql.js +0 -127
- package/esm2015/lib/items2/item2.gql.private.js +0 -23
- package/esm2015/lib/items2/item2.service.js +0 -516
- package/esm2015/lib/items2/item2.types.js +0 -1
- package/esm2015/lib/scenario/scenario.gql.private.js +0 -198
- 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/contact-card2.service.d.ts +0 -50
- 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/{items2 → item2}/item2.gql.private.d.ts +0 -0
- /package/lib/{items2 → item2}/item2.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/{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/{cryptography → web-crypto}/web-crypto.service.d.ts +0 -0
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
export class CurrentUserKey {
|
|
2
|
+
}
|
|
3
|
+
export class ApiCurrentUser {
|
|
4
|
+
}
|
|
5
|
+
export class ApiContactCard {
|
|
6
|
+
}
|
|
7
|
+
export class ContactCardName {
|
|
8
|
+
constructor(input) {
|
|
9
|
+
this.name = input.name;
|
|
10
|
+
this.title = input.title;
|
|
11
|
+
this.firstName = input.firstName;
|
|
12
|
+
this.lastName = input.lastName;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
export class ContactCardAddress {
|
|
16
|
+
}
|
|
17
|
+
export class MainContactCardProperty {
|
|
18
|
+
}
|
|
19
|
+
export class MainContactCardFields {
|
|
20
|
+
}
|
|
21
|
+
export class MainContactCard extends MainContactCardFields {
|
|
22
|
+
}
|
|
23
|
+
export class MainContactCardPlainFields {
|
|
24
|
+
}
|
|
25
|
+
export var PasswordChangeStatus;
|
|
26
|
+
(function (PasswordChangeStatus) {
|
|
27
|
+
PasswordChangeStatus["InProgress"] = "IN_PROGRESS";
|
|
28
|
+
PasswordChangeStatus["Recovery"] = "RECOVERY";
|
|
29
|
+
})(PasswordChangeStatus || (PasswordChangeStatus = {}));
|
|
30
|
+
export class PassIdpApiResult {
|
|
31
|
+
}
|
|
32
|
+
export class TrustedPartyDetails {
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZmlsZS50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi9wcm9maWxlL3Byb2ZpbGUudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS0EsTUFBTSxPQUFPLGNBQWM7Q0FNMUI7QUFFRCxNQUFNLE9BQU8sY0FBYztDQU8xQjtBQUVELE1BQU0sT0FBTyxjQUFjO0NBTTFCO0FBRUQsTUFBTSxPQUFPLGVBQWU7SUFNMUIsWUFBWSxLQUFVO1FBQ3BCLElBQUksQ0FBQyxJQUFJLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQztRQUN2QixJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUM7UUFDekIsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUMsU0FBUyxDQUFDO1FBQ2pDLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDLFFBQVEsQ0FBQztJQUNqQyxDQUFDO0NBQ0Y7QUFFRCxNQUFNLE9BQU8sa0JBQWtCO0NBTzlCO0FBRUQsTUFBTSxPQUFPLHVCQUF1QjtDQUtuQztBQUVELE1BQU0sT0FBTyxxQkFBcUI7Q0FNakM7QUFFRCxNQUFNLE9BQU8sZUFBZ0IsU0FBUSxxQkFBcUI7Q0FHekQ7QUFFRCxNQUFNLE9BQU8sMEJBQTBCO0NBRXRDO0FBRUQsTUFBTSxDQUFOLElBQVksb0JBR1g7QUFIRCxXQUFZLG9CQUFvQjtJQUM5QixrREFBMEIsQ0FBQTtJQUMxQiw2Q0FBcUIsQ0FBQTtBQUN2QixDQUFDLEVBSFcsb0JBQW9CLEtBQXBCLG9CQUFvQixRQUcvQjtBQUVELE1BQU0sT0FBTyxnQkFBZ0I7Q0FRNUI7QUFFRCxNQUFNLE9BQU8sbUJBQW1CO0NBUy9CIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueSAqL1xuaW1wb3J0IHsgVXNlckRlbGV0ZU5vZGUgfSBmcm9tICcuLi9hcGkvdHlwZXMnO1xuaW1wb3J0IHsgRmVhdHVyZXMgfSBmcm9tICcuLi9hdXRoL2F1dGgudHlwZXMnO1xuaW1wb3J0IHsgUGFzc0lkcFBhcmFtcywgUGFzc0tleSB9IGZyb20gJy4uL2tleS9rZXkudHlwZXMnO1xuXG5leHBvcnQgY2xhc3MgQ3VycmVudFVzZXJLZXkge1xuICBwYXNzS2V5PzogUGFzc0tleTtcbiAgbWFzdGVyS2V5PzogeyBpZDogc3RyaW5nIH07XG4gIHJvb3RLZXk/OiB7IGlkOiBzdHJpbmcgfTtcbiAgcHhrPzogeyBpZDogc3RyaW5nIH07XG4gIHNpZ1B4az86IHsgaWQ6IHN0cmluZyB9O1xufVxuXG5leHBvcnQgY2xhc3MgQXBpQ3VycmVudFVzZXIge1xuICBpZDogc3RyaW5nO1xuICB1c2VybmFtZTogc3RyaW5nO1xuICBjdXJyZW50VXNlcktleTogQ3VycmVudFVzZXJLZXk7XG4gIHVzZXJEZWxldGU6IFVzZXJEZWxldGVOb2RlO1xuICBmZWF0dXJlczogRmVhdHVyZXM7XG4gIHNlc3Npb25FbmNyeXB0aW9uS2V5OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjbGFzcyBBcGlDb250YWN0Q2FyZCB7XG4gIGlkOiBzdHJpbmc7XG4gIGNpcGhlckRhdGE6IHN0cmluZztcbiAga2V5OiB7XG4gICAgaWQ6IHN0cmluZztcbiAgfTtcbn1cblxuZXhwb3J0IGNsYXNzIENvbnRhY3RDYXJkTmFtZSB7XG4gIG5hbWU6IHN0cmluZztcbiAgdGl0bGU/OiBzdHJpbmc7XG4gIGZpcnN0TmFtZT86IHN0cmluZztcbiAgbGFzdE5hbWU/OiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3IoaW5wdXQ6IGFueSkge1xuICAgIHRoaXMubmFtZSA9IGlucHV0Lm5hbWU7XG4gICAgdGhpcy50aXRsZSA9IGlucHV0LnRpdGxlO1xuICAgIHRoaXMuZmlyc3ROYW1lID0gaW5wdXQuZmlyc3ROYW1lO1xuICAgIHRoaXMubGFzdE5hbWUgPSBpbnB1dC5sYXN0TmFtZTtcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgQ29udGFjdENhcmRBZGRyZXNzIHtcbiAgZnVsbEFkZHJlc3M6IHN0cmluZztcbiAgc3RyZWV0QWRkcmVzczogc3RyaW5nO1xuICBzdWJ1cmI6IHN0cmluZztcbiAgc3RhdGU6IHN0cmluZztcbiAgcG9zdGNvZGU6IHN0cmluZztcbiAgY291bnRyeTogc3RyaW5nO1xufVxuXG5leHBvcnQgY2xhc3MgTWFpbkNvbnRhY3RDYXJkUHJvcGVydHk8VD4ge1xuICB2YWx1ZTogVDtcbiAgaGFzTXVsdGlwbGU6IGJvb2xlYW47XG5cbiAgdmFsdWVzPzogeyBpZDogc3RyaW5nOyBsYWJlbDogc3RyaW5nOyB2YWx1ZTogVCB9W107XG59XG5cbmV4cG9ydCBjbGFzcyBNYWluQ29udGFjdENhcmRGaWVsZHMge1xuICBuYW1lOiBNYWluQ29udGFjdENhcmRQcm9wZXJ0eTxDb250YWN0Q2FyZE5hbWU+O1xuICBlbWFpbDogTWFpbkNvbnRhY3RDYXJkUHJvcGVydHk8c3RyaW5nPjtcbiAgaW1hZ2U6IE1haW5Db250YWN0Q2FyZFByb3BlcnR5PHN0cmluZz47XG4gIHBob25lOiBNYWluQ29udGFjdENhcmRQcm9wZXJ0eTxzdHJpbmc+O1xuICBhZGRyZXNzOiBNYWluQ29udGFjdENhcmRQcm9wZXJ0eTxDb250YWN0Q2FyZEFkZHJlc3M+O1xufVxuXG5leHBvcnQgY2xhc3MgTWFpbkNvbnRhY3RDYXJkIGV4dGVuZHMgTWFpbkNvbnRhY3RDYXJkRmllbGRzIHtcbiAgaWQ6IHN0cmluZztcbiAga2V5SWQ6IHN0cmluZztcbn1cblxuZXhwb3J0IGNsYXNzIE1haW5Db250YWN0Q2FyZFBsYWluRmllbGRzIHtcbiAgbmFtZTogQ29udGFjdENhcmROYW1lO1xufVxuXG5leHBvcnQgZW51bSBQYXNzd29yZENoYW5nZVN0YXR1cyB7XG4gIEluUHJvZ3Jlc3MgPSAnSU5fUFJPR1JFU1MnLFxuICBSZWNvdmVyeSA9ICdSRUNPVkVSWScsXG59XG5cbmV4cG9ydCBjbGFzcyBQYXNzSWRwQXBpUmVzdWx0IHtcbiAgcGFzc3dvcmRDaGFuZ2VTdGF0dXM/OiBQYXNzd29yZENoYW5nZVN0YXR1cztcbiAgY3VycmVudFBhc3NJZHBQYXJhbXM6IFBhc3NJZHBQYXJhbXM7XG4gIG5ld1Bhc3NJZHBQYXJhbXM6IFBhc3NJZHBQYXJhbXM7XG4gIHRwUGFzc3dvcmRSZXNldDoge1xuICAgIHBhc3NJZHBQYXJhbXM6IFBhc3NJZHBQYXJhbXM7XG4gICAgcmVzZXRVc2VybmFtZTogc3RyaW5nO1xuICB9O1xufVxuXG5leHBvcnQgY2xhc3MgVHJ1c3RlZFBhcnR5RGV0YWlscyB7XG4gIG5hbWU6IENvbnRhY3RDYXJkTmFtZTtcbiAgZW1haWw/OiBzdHJpbmc7XG4gIGltYWdlPzogc3RyaW5nO1xuICBwaG9uZXM/OiB7IGxhYmVsOiBzdHJpbmc7IHZhbHVlOiBzdHJpbmcgfVtdO1xuICBhZGRyZXNzZXM/OiB7XG4gICAgbGFiZWw6IHN0cmluZztcbiAgICB2YWx1ZTogQ29udGFjdENhcmRBZGRyZXNzO1xuICB9W107XG59XG4iXX0=
|
|
@@ -1,25 +1,26 @@
|
|
|
1
1
|
import { __awaiter } from "tslib";
|
|
2
|
+
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
2
3
|
import { Injectable } from '@angular/core';
|
|
3
|
-
import { FileType, DeleteFileMutation, CreateFileMutation } from './record.gql';
|
|
4
4
|
import { LrApolloService } from '../api/lr-apollo.service';
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
5
|
+
import { FileUploadService } from '../file-upload/file-upload.service';
|
|
6
|
+
import { KeyGraphService } from '../key/key-graph.service';
|
|
7
|
+
import { KeyMetaService } from '../key/key-meta.service';
|
|
8
|
+
import { CreateFileMutation, DeleteFileMutation, FileType } from './record.gql';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
|
-
import * as i1 from "../
|
|
10
|
+
import * as i1 from "../file-upload/file-upload.service";
|
|
10
11
|
import * as i2 from "../api/lr-apollo.service";
|
|
11
|
-
import * as i3 from "../
|
|
12
|
-
import * as i4 from "../
|
|
12
|
+
import * as i3 from "../key/key-meta.service";
|
|
13
|
+
import * as i4 from "../key/key-graph.service";
|
|
13
14
|
export class RecordAttachmentService {
|
|
14
|
-
constructor(
|
|
15
|
-
this.
|
|
15
|
+
constructor(fileUploadService, lrApollo, keyMetaService, keyGraph) {
|
|
16
|
+
this.fileUploadService = fileUploadService;
|
|
16
17
|
this.lrApollo = lrApollo;
|
|
17
18
|
this.keyMetaService = keyMetaService;
|
|
18
19
|
this.keyGraph = keyGraph;
|
|
19
20
|
}
|
|
20
21
|
downloadAttachment(fileStateNodeId, keyId) {
|
|
21
22
|
return __awaiter(this, void 0, void 0, function* () {
|
|
22
|
-
const encryptedFile = yield this.
|
|
23
|
+
const encryptedFile = yield this.fileUploadService.downloadEncryptedFile(fileStateNodeId);
|
|
23
24
|
return yield this.keyGraph.decryptFile(keyId, encryptedFile);
|
|
24
25
|
});
|
|
25
26
|
}
|
|
@@ -51,9 +52,9 @@ export class RecordAttachmentService {
|
|
|
51
52
|
fileSize: attachment.file.size,
|
|
52
53
|
lastModified: attachment.file.lastModified,
|
|
53
54
|
};
|
|
54
|
-
const fileContent = yield this.
|
|
55
|
+
const fileContent = yield this.fileUploadService.loadFile(attachment.file);
|
|
55
56
|
const doubleWrappedContent = yield this.keyMetaService.doubleWrapContent(secureContent, [recordId], fileContent);
|
|
56
|
-
const contentId = yield this.
|
|
57
|
+
const contentId = yield this.fileUploadService.uploadEncryptedFile({
|
|
57
58
|
encryptedContent: doubleWrappedContent.cipherFileContent,
|
|
58
59
|
fileName: attachment.name,
|
|
59
60
|
});
|
|
@@ -86,16 +87,16 @@ export class RecordAttachmentService {
|
|
|
86
87
|
});
|
|
87
88
|
}
|
|
88
89
|
}
|
|
89
|
-
RecordAttachmentService.ɵprov = i0.ɵɵdefineInjectable({ factory: function RecordAttachmentService_Factory() { return new RecordAttachmentService(i0.ɵɵinject(i1.
|
|
90
|
+
RecordAttachmentService.ɵprov = i0.ɵɵdefineInjectable({ factory: function RecordAttachmentService_Factory() { return new RecordAttachmentService(i0.ɵɵinject(i1.FileUploadService), i0.ɵɵinject(i2.LrApolloService), i0.ɵɵinject(i3.KeyMetaService), i0.ɵɵinject(i4.KeyGraphService)); }, token: RecordAttachmentService, providedIn: "root" });
|
|
90
91
|
RecordAttachmentService.decorators = [
|
|
91
92
|
{ type: Injectable, args: [{
|
|
92
93
|
providedIn: 'root',
|
|
93
94
|
},] }
|
|
94
95
|
];
|
|
95
96
|
RecordAttachmentService.ctorParameters = () => [
|
|
96
|
-
{ type:
|
|
97
|
+
{ type: FileUploadService },
|
|
97
98
|
{ type: LrApolloService },
|
|
98
99
|
{ type: KeyMetaService },
|
|
99
100
|
{ type: KeyGraphService }
|
|
100
101
|
];
|
|
101
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"record-attachment.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/record/record-attachment.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Injectable } from '@angular/core';\nimport { LrApolloService } from '../api/lr-apollo.service';\nimport { FileUploadService } from '../file-upload/file-upload.service';\nimport { KeyGraphService } from '../key/key-graph.service';\nimport { KeyMetaService } from '../key/key-meta.service';\nimport { CreateFileMutation, DeleteFileMutation, FileType } from './record.gql';\nimport { NewAttachment, NewOrUpdatedAttachment } from './record.types';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class RecordAttachmentService {\n  constructor(\n    private fileUploadService: FileUploadService,\n    private lrApollo: LrApolloService,\n    private keyMetaService: KeyMetaService,\n    private keyGraph: KeyGraphService\n  ) {}\n\n  async downloadAttachment(\n    fileStateNodeId: string,\n    keyId: string\n  ): Promise<any> {\n    const encryptedFile = await this.fileUploadService.downloadEncryptedFile(\n      fileStateNodeId\n    );\n\n    return await this.keyGraph.decryptFile(keyId, encryptedFile);\n  }\n\n  async uploadAttachments(\n    recordId: string,\n    attachments: NewOrUpdatedAttachment[]\n  ): Promise<string[]> {\n    const fileIds = await Promise.all(\n      (attachments || []).map(async (x) => {\n        if (x.fileId) {\n          if (x.isDeleted) {\n            await this.deleteAttachment(x.fileId);\n            return null;\n          } else {\n            return x.fileId;\n          }\n        } else {\n          return await this.addAttachment(recordId, x);\n        }\n      })\n    );\n    return fileIds.filter((x) => x);\n  }\n\n  private async addAttachment(\n    recordId: string,\n    attachment: NewAttachment\n  ): Promise<string> {\n    const secureContent = {\n      name: attachment.name,\n      fieldId: attachment.fieldId,\n      fileType: attachment.file.type,\n      fileSize: attachment.file.size,\n      lastModified: attachment.file.lastModified,\n    };\n    const fileContent = await this.fileUploadService.loadFile(attachment.file);\n    const doubleWrappedContent = await this.keyMetaService.doubleWrapContent(\n      secureContent,\n      [recordId],\n      fileContent\n    );\n\n    const contentId = await this.fileUploadService.uploadEncryptedFile({\n      encryptedContent: doubleWrappedContent.cipherFileContent,\n      fileName: attachment.name,\n    });\n\n    // Save file\n    const response = await this.lrApollo.mutate<any>({\n      mutation: CreateFileMutation,\n      variables: {\n        input: {\n          plainMeta: JSON.stringify({ fileType: FileType.RecordAttachment }),\n          wrappedStateKey: doubleWrappedContent.doubleWrappedKey,\n          cipherMeta: doubleWrappedContent.cipherMeta,\n          parentDirectories: doubleWrappedContent.wrappedKeys.map((x) => ({\n            directoryId: x.directoryId,\n            wrappingKeyId: x.wrappingKeyId,\n            wrappedFileKey: x.wrappedKey,\n          })),\n          contentResource: contentId,\n        },\n      },\n    });\n    return response.createFile.file.id;\n  }\n\n  async deleteAttachment(fileId: string): Promise<void> {\n    await this.lrApollo.mutate({\n      mutation: DeleteFileMutation,\n      variables: { fileId },\n    });\n  }\n}\n"]}
|
|
@@ -176,4 +176,4 @@ export const DeleteFileMutation = gql `
|
|
|
176
176
|
}
|
|
177
177
|
}
|
|
178
178
|
`;
|
|
179
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
179
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjb3JkLmdxbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi9yZWNvcmQvcmVjb3JkLmdxbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEdBQUcsTUFBTSxhQUFhLENBQUM7QUFDOUIsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDMUQsT0FBTyxFQUNMLHdCQUF3QixFQUN4QixxQkFBcUIsRUFDckIsWUFBWSxHQUNiLE1BQU0sMEJBQTBCLENBQUM7QUFFbEMsTUFBTSxDQUFOLElBQVksUUFHWDtBQUhELFdBQVksUUFBUTtJQUNsQiw0Q0FBZ0MsQ0FBQTtJQUNoQyxrREFBc0MsQ0FBQTtBQUN4QyxDQUFDLEVBSFcsUUFBUSxLQUFSLFFBQVEsUUFHbkI7QUFFRCxNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQ2hELE1BQU0sRUFBRTtRQUNOO1lBQ0UsUUFBUSxFQUFFO2dCQUNSLFFBQVEsRUFBRSxRQUFRLENBQUMsYUFBYTthQUNqQztTQUNGO0tBQ0Y7Q0FDRixDQUFDLENBQUM7QUFFSCxNQUFNLENBQUMsTUFBTSxzQkFBc0IsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQ25ELE1BQU0sRUFBRTtRQUNOO1lBQ0UsUUFBUSxFQUFFO2dCQUNSLFFBQVEsRUFBRSxRQUFRLENBQUMsZ0JBQWdCO2FBQ3BDO1NBQ0Y7S0FDRjtDQUNGLENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRyxDQUFDLEtBQUssR0FBRyx3QkFBd0IsRUFBRSxFQUFFLENBQUMsR0FBRyxDQUFBOzs7Ozs7Ozs7Ozs7Ozs7O01BZ0JqRSxZQUFZO01BQ1oscUJBQXFCLENBQUMsS0FBSyxDQUFDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0VBNkRoQyxnQkFBZ0I7Q0FDakIsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLDZCQUE2QixHQUFHLEdBQUcsQ0FBQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0NBcUIvQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQUcsR0FBRyxDQUFBOzs7Ozs7OztDQVF0QyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sNkJBQTZCLEdBQUcsR0FBRyxDQUFBOzs7Ozs7OztDQVEvQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQUcsR0FBRyxDQUFBOzs7Ozs7OztDQVF0QyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQUcsR0FBRyxDQUFBOzs7Ozs7Q0FNdEMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLEdBQUcsQ0FBQTs7Ozs7Ozs7Q0FRcEMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLEdBQUcsQ0FBQTs7Ozs7O0NBTXBDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgZ3FsIGZyb20gJ2dyYXBocWwtdGFnJztcbmltcG9ydCB7IEtleUdyYXBoRnJhZ21lbnQgfSBmcm9tICcuLi9fY29tbW9uL3F1ZXJpZXMuZ3FsJztcbmltcG9ydCB7XG4gIERFRkFVTFRfQlJFQURDUlVNQl9ERVBUSCxcbiAgcGFyZW50Q2F0ZWdvcmllc0ZpZWxkLFxuICBBY2Nlc3NGaWVsZHMsXG59IGZyb20gJy4uL2NhdGVnb3J5L2NhdGVnb3J5LmdxbCc7XG5cbmV4cG9ydCBlbnVtIEZpbGVUeXBlIHtcbiAgUmVjb3JkQ29udGVudCA9ICdyZWNvcmQtY29udGVudCcsXG4gIFJlY29yZEF0dGFjaG1lbnQgPSAncmVjb3JkLWF0dGFjaG1lbnQnLFxufVxuXG5leHBvcnQgY29uc3QgUmVjb3JkQ29udGVudEZpbHRlciA9IEpTT04uc3RyaW5naWZ5KHtcbiAgZmlsdGVyOiBbXG4gICAge1xuICAgICAgY29udGFpbnM6IHtcbiAgICAgICAgZmlsZVR5cGU6IEZpbGVUeXBlLlJlY29yZENvbnRlbnQsXG4gICAgICB9LFxuICAgIH0sXG4gIF0sXG59KTtcblxuZXhwb3J0IGNvbnN0IFJlY29yZEF0dGFjaG1lbnRGaWx0ZXIgPSBKU09OLnN0cmluZ2lmeSh7XG4gIGZpbHRlcjogW1xuICAgIHtcbiAgICAgIGNvbnRhaW5zOiB7XG4gICAgICAgIGZpbGVUeXBlOiBGaWxlVHlwZS5SZWNvcmRBdHRhY2htZW50LFxuICAgICAgfSxcbiAgICB9LFxuICBdLFxufSk7XG5cbmV4cG9ydCBjb25zdCBHZXRSZWNvcmRRdWVyeSA9IChkZXB0aCA9IERFRkFVTFRfQlJFQURDUlVNQl9ERVBUSCkgPT4gZ3FsYFxucXVlcnkgUmVjb3JkKFxuICAkaWQ6IExyUmVsYXlJZElucHV0ISxcbiAgJGNhY2hlZEtleUlkczogW0xyUmVsYXlJZElucHV0IV0sXG4gICRjYXRlZ29yeUZpbHRlcjogTHJKU09ORmlsdGVyLFxuICAkY29udGVudEZpbHRlcjogTHJKU09ORmlsdGVyLFxuICAkYXR0YWNobWVudHNGaWx0ZXI6IExySlNPTkZpbHRlcixcbikge1xuICByZWNvcmQ6IGRpcmVjdG9yeShpZDogJGlkKSB7XG4gICAgaWRcbiAgICBrZXlJZFxuICAgIGFyY2hpdmVkXG4gICAgcGxhaW5NZXRhXG4gICAgY2lwaGVyTWV0YVxuICAgIGNyZWF0ZWRcbiAgICBtb2RpZmllZFxuICAgICR7QWNjZXNzRmllbGRzfVxuICAgICR7cGFyZW50Q2F0ZWdvcmllc0ZpZWxkKGRlcHRoKX1cbiAgICBjb250ZW50OiBjaGlsZEZpbGVMaW5rcyhwbGFpbk1ldGE6ICRjb250ZW50RmlsdGVyKSB7XG4gICAgICBlZGdlcyB7XG4gICAgICAgIG5vZGUge1xuICAgICAgICAgIGNoaWxkRmlsZSB7XG4gICAgICAgICAgICBpZFxuICAgICAgICAgICAga2V5SWRcbiAgICAgICAgICAgIGFyY2hpdmVkXG4gICAgICAgICAgICBjdXJyZW50VmVyc2lvbiB7XG4gICAgICAgICAgICAgIHN0YXRlIHtcbiAgICAgICAgICAgICAgICBpZFxuICAgICAgICAgICAgICAgIGtleUlkXG4gICAgICAgICAgICAgICAgcGxhaW5NZXRhXG4gICAgICAgICAgICAgICAgY2lwaGVyTWV0YVxuICAgICAgICAgICAgICAgIGNyZWF0ZWRcbiAgICAgICAgICAgICAgICBtb2RpZmllZFxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICB2ZXJzaW9ucyB7XG4gICAgICAgICAgICAgIGVkZ2VzIHtcbiAgICAgICAgICAgICAgICBub2RlIHtcbiAgICAgICAgICAgICAgICAgIG9wZXJhdGlvblxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgICBhdHRhY2htZW50czogY2hpbGRGaWxlTGlua3MocGxhaW5NZXRhOiAkYXR0YWNobWVudHNGaWx0ZXIpIHtcbiAgICAgIGVkZ2VzIHtcbiAgICAgICAgbm9kZSB7XG4gICAgICAgICAgY2hpbGRGaWxlIHtcbiAgICAgICAgICAgIGlkXG4gICAgICAgICAgICBrZXlJZFxuICAgICAgICAgICAgYXJjaGl2ZWRcbiAgICAgICAgICAgIGN1cnJlbnRWZXJzaW9uIHtcbiAgICAgICAgICAgICAgc3RhdGUge1xuICAgICAgICAgICAgICAgIGlkXG4gICAgICAgICAgICAgICAga2V5SWRcbiAgICAgICAgICAgICAgICBwbGFpbk1ldGFcbiAgICAgICAgICAgICAgICBjaXBoZXJNZXRhXG4gICAgICAgICAgICAgICAgY29udGVudFJlc291cmNlXG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHZlcnNpb25zIHtcbiAgICAgICAgICAgICAgZWRnZXMge1xuICAgICAgICAgICAgICAgIG5vZGUge1xuICAgICAgICAgICAgICAgICAgb3BlcmF0aW9uXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICB9XG4gIGtleUdyYXBoKGNhY2hlZEtleUlkczogJGNhY2hlZEtleUlkcykge1xuICAgIC4uLktleUdyYXBoRnJhZ21lbnRcbiAgfVxufVxuJHtLZXlHcmFwaEZyYWdtZW50fVxuYDtcblxuZXhwb3J0IGNvbnN0IENyZWF0ZVJlY29yZENvbnRhaW5lck11dGF0aW9uID0gZ3FsYFxuICBtdXRhdGlvbiBDcmVhdGVSZWNvcmRDb250YWluZXIoXG4gICAgJHBsYWluTWV0YTogTHJKU09OU3RyaW5nXG4gICAgJGNpcGhlck1ldGE6IFN0cmluZ1xuICAgICRwYXJlbnREaXJlY3RvcmllczogW1BhcmVudERpcmVjdG9yeUlucHV0IV1cbiAgICAkcGFyZW50Um9vdERpcmVjdG9yeTogUGFyZW50Um9vdERpcmVjdG9yeUlucHV0XG4gICkge1xuICAgIG5ldzogY3JlYXRlRGlyZWN0b3J5KFxuICAgICAgaW5wdXQ6IHtcbiAgICAgICAgcGxhaW5NZXRhOiAkcGxhaW5NZXRhXG4gICAgICAgIGNpcGhlck1ldGE6ICRjaXBoZXJNZXRhXG4gICAgICAgIHBhcmVudERpcmVjdG9yaWVzOiAkcGFyZW50RGlyZWN0b3JpZXNcbiAgICAgICAgcGFyZW50Um9vdERpcmVjdG9yeTogJHBhcmVudFJvb3REaXJlY3RvcnlcbiAgICAgIH1cbiAgICApIHtcbiAgICAgIGNhdGVnb3J5OiBkaXJlY3Rvcnkge1xuICAgICAgICBpZFxuICAgICAgICBrZXlJZFxuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IENyZWF0ZVJlY29yZE11dGF0aW9uID0gZ3FsYFxuICBtdXRhdGlvbiBDcmVhdGVGaWxlKCRpbnB1dDogQ3JlYXRlRmlsZUlucHV0ISkge1xuICAgIGNyZWF0ZUZpbGUoaW5wdXQ6ICRpbnB1dCkge1xuICAgICAgZmlsZSB7XG4gICAgICAgIGlkXG4gICAgICB9XG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgVXBkYXRlUmVjb3JkQ29udGFpbmVyTXV0YXRpb24gPSBncWxgXG4gIG11dGF0aW9uIFVwZGF0ZVJlY29yZCgkaW5wdXQ6IFVwZGF0ZURpcmVjdG9yeUlucHV0ISkge1xuICAgIHVwZGF0ZURpcmVjdG9yeShpbnB1dDogJGlucHV0KSB7XG4gICAgICBkaXJlY3Rvcnkge1xuICAgICAgICBpZFxuICAgICAgfVxuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFVwZGF0ZVJlY29yZE11dGF0aW9uID0gZ3FsYFxuICBtdXRhdGlvbiBVcGRhdGVGaWxlKCRpbnB1dDogVXBkYXRlRmlsZUlucHV0ISkge1xuICAgIHVwZGF0ZUZpbGUoaW5wdXQ6ICRpbnB1dCkge1xuICAgICAgZmlsZSB7XG4gICAgICAgIGlkXG4gICAgICB9XG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgRGVsZXRlUmVjb3JkTXV0YXRpb24gPSBncWxgXG4gIG11dGF0aW9uIERlbGV0ZVJlY29yZCgkcmVjb3JkSWQ6IExyUmVsYXlJZElucHV0ISkge1xuICAgIGRlbGV0ZURpcmVjdG9yeShpbnB1dDogeyBkaXJlY3RvcnlJZDogJHJlY29yZElkIH0pIHtcbiAgICAgIGlkXG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgQ3JlYXRlRmlsZU11dGF0aW9uID0gZ3FsYFxuICBtdXRhdGlvbiBDcmVhdGVGaWxlKCRpbnB1dDogQ3JlYXRlRmlsZUlucHV0ISkge1xuICAgIGNyZWF0ZUZpbGUoaW5wdXQ6ICRpbnB1dCkge1xuICAgICAgZmlsZSB7XG4gICAgICAgIGlkXG4gICAgICB9XG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgRGVsZXRlRmlsZU11dGF0aW9uID0gZ3FsYFxuICBtdXRhdGlvbiBEZWxldGVGaWxlKCRmaWxlSWQ6IExyUmVsYXlJZElucHV0ISkge1xuICAgIGRlbGV0ZUZpbGUoaW5wdXQ6IHsgZmlsZUlkOiAkZmlsZUlkIH0pIHtcbiAgICAgIGlkXG4gICAgfVxuICB9XG5gO1xuIl19
|
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
import { __awaiter } from "tslib";
|
|
2
|
-
|
|
2
|
+
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
3
3
|
import { Injectable } from '@angular/core';
|
|
4
4
|
import { LrApolloService } from '../api/lr-apollo.service';
|
|
5
|
-
import { CategoryFilter } from '../category/category.gql';
|
|
6
|
-
import { KeyMetaService } from '../cryptography/key-meta.service';
|
|
7
|
-
import { DirectoryType } from './../category/category.gql';
|
|
8
|
-
import { CreateRecordContainerMutation, CreateRecordMutation, DeleteRecordMutation, FileType, GetRecordQuery, RecordAttachmentFilter, RecordContentFilter, UpdateRecordMutation, } from './record.gql';
|
|
9
|
-
import { AccessLevel } from '../category/category.types';
|
|
5
|
+
import { CategoryFilter, DirectoryType } from '../category/category.gql';
|
|
10
6
|
import { CategoryService } from '../category/category.service';
|
|
7
|
+
import { AccessLevel } from '../category/category.types';
|
|
8
|
+
import { KeyMetaService } from '../key/key-meta.service';
|
|
9
|
+
import { RecordAttachmentService } from './record-attachment.service';
|
|
10
|
+
import { CreateRecordContainerMutation, CreateRecordMutation, DeleteRecordMutation, FileType, GetRecordQuery, RecordAttachmentFilter, RecordContentFilter, UpdateRecordMutation, } from './record.gql';
|
|
11
11
|
import * as i0 from "@angular/core";
|
|
12
12
|
import * as i1 from "../api/lr-apollo.service";
|
|
13
|
-
import * as i2 from "../
|
|
13
|
+
import * as i2 from "../key/key-meta.service";
|
|
14
14
|
import * as i3 from "../category/category.service";
|
|
15
15
|
import * as i4 from "./record-attachment.service";
|
|
16
16
|
export class RecordService {
|
|
@@ -203,4 +203,4 @@ RecordService.ctorParameters = () => [
|
|
|
203
203
|
{ type: CategoryService },
|
|
204
204
|
{ type: RecordAttachmentService }
|
|
205
205
|
];
|
|
206
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"record.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/record/record.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { RecordAttachmentService } from './record-attachment.service';\nimport { Injectable } from '@angular/core';\nimport { LrApolloService } from '../api/lr-apollo.service';\nimport { CategoryFilter } from '../category/category.gql';\nimport { KeyMetaService } from '../cryptography/key-meta.service';\nimport { DirectoryType } from './../category/category.gql';\nimport {\n  LrRecord,\n  NewRecord,\n  UpdatedRecord,\n  RecordAttachment,\n} from './record.types';\nimport {\n  CreateRecordContainerMutation,\n  CreateRecordMutation,\n  DeleteRecordMutation,\n  FileType,\n  GetRecordQuery,\n  RecordAttachmentFilter,\n  RecordContentFilter,\n  UpdateRecordContainerMutation,\n  UpdateRecordMutation,\n} from './record.gql';\nimport { Category, AccessLevel } from '../category/category.types';\nimport { CategoryService } from '../category/category.service';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class RecordService {\n  constructor(\n    private lrApollo: LrApolloService,\n    private keyMetaService: KeyMetaService,\n    private categoryService: CategoryService,\n    private recordAttachmentService: RecordAttachmentService\n  ) {}\n\n  public async getRecord(recordId: string): Promise<LrRecord> {\n    const { record } = await this.lrApollo.query<any>({\n      query: GetRecordQuery(),\n      variables: {\n        id: recordId,\n        categoryFilter: CategoryFilter,\n        contentFilter: RecordContentFilter,\n        attachmentsFilter: RecordAttachmentFilter,\n      },\n    });\n    const contents = record.content.edges[0].node.childFile;\n    const { name, recordType, fields } =\n      (await this.keyMetaService.decryptMeta(contents.currentVersion.state)) ||\n      {};\n    const categories = await Promise.all<Category[]>(\n      record.parentCategories.edges.map(async (x: any) => [\n        ...(await this.categoryService.mapParentCategories(\n          x.node.parentDirectory\n        )),\n        await this.categoryService.mapCategory(x.node.parentDirectory),\n      ])\n    );\n    const attachments = await this.mapAttachments(record.attachments.edges);\n    const isOwner =\n      record.accessRoles &&\n      record.accessRoles.some((x) => x.role === AccessLevel.Owner);\n\n    return {\n      id: record.id,\n      keyId: record.keyId,\n      updateKeyId: contents.keyId,\n      updateId: contents.id,\n      name,\n      recordType,\n      fields,\n      categories,\n      attachments,\n      myAccessLevel: isOwner ? AccessLevel.Owner : record.accessRoles[0].role,\n      sharedAccess: isOwner\n        ? record.accessRoles\n            .filter((x) => x.role !== AccessLevel.Owner)\n            .map((x) => ({\n              trustedPartyId: x.trustedParty && x.trustedParty.id,\n              accessLevel: x.role,\n              isInherited: x.method === 'inherited',\n              inheritedFrom: x.inheritedFrom && x.inheritedFrom.id,\n            }))\n        : [],\n      isArchived: !!record.archived,\n      createdOn: record.created,\n      lastModified:\n        new Date(record.modified) >\n        new Date(contents.currentVersion.state.modified)\n          ? record.modified\n          : contents.currentVersion.state.modified,\n    };\n  }\n\n  private async mapAttachments(\n    attachments: any[]\n  ): Promise<RecordAttachment[]> {\n    return await Promise.all<RecordAttachment>(\n      attachments\n        .map((x) => x.node.childFile)\n        .map(async (x: any) => {\n          const { name, fieldId, fileType, fileSize, lastModified } =\n            (await this.keyMetaService.decryptMeta(x.currentVersion.state)) ||\n            {};\n\n          return {\n            fileId: x.id,\n            keyId: x.currentVersion.state.keyId,\n            contentId: x.currentVersion.state.id,\n            fieldId,\n            name,\n            fileType,\n            fileSize,\n            lastModified,\n          };\n        })\n    );\n  }\n\n  public async createRecord(\n    newRecord: NewRecord\n  ): Promise<{ recordId: string; attachmentError?: Error }> {\n    // Create directory that holds the record\n    const wrappedContent = await this.keyMetaService.wrapContent(\n      null,\n      newRecord.categoryIds\n    );\n    const response = await this.lrApollo.mutate<any>({\n      mutation: CreateRecordContainerMutation,\n      variables: {\n        plainMeta: JSON.stringify({\n          directoryType: DirectoryType.Record,\n          isHidden: false,\n        }),\n        parentDirectories: wrappedContent.wrappedKeys,\n        parentRootDirectory: wrappedContent.rootKey,\n      },\n    });\n    const recordId = response.new.category.id;\n    const secureContent = {\n      name: newRecord.name,\n      recordType: newRecord.recordType,\n      fields: newRecord.fields,\n    };\n    const doubleWrappedContent = await this.keyMetaService.doubleWrapContent(\n      secureContent,\n      [recordId]\n    );\n\n    // Create the file that holds the record contents\n    await this.lrApollo.mutate({\n      mutation: CreateRecordMutation,\n      variables: {\n        input: {\n          plainMeta: JSON.stringify({ fileType: FileType.RecordContent }),\n          wrappedStateKey: doubleWrappedContent.doubleWrappedKey,\n          cipherMeta: doubleWrappedContent.cipherMeta,\n          parentDirectories: doubleWrappedContent.wrappedKeys.map((x) => ({\n            directoryId: x.directoryId,\n            wrappingKeyId: x.wrappingKeyId,\n            wrappedFileKey: x.wrappedKey,\n          })),\n        },\n      },\n    });\n\n    try {\n      await this.recordAttachmentService.uploadAttachments(\n        recordId,\n        newRecord.attachments\n      );\n    } catch (e) {\n      console.error(e);\n      return { recordId, attachmentError: e };\n    }\n    return { recordId };\n  }\n\n  public async updateRecord(\n    recordId: string,\n    updateId: string,\n    updateKeyId: string,\n    updatedRecord: UpdatedRecord\n  ): Promise<{ recordId: string; attachmentError?: Error }> {\n    const secureContent = {\n      name: updatedRecord.name,\n      recordType: updatedRecord.recordType,\n      fields: updatedRecord.fields,\n    };\n    const reWrappedContent = await this.keyMetaService.reWrapContent(\n      updateKeyId,\n      secureContent\n    );\n\n    await this.lrApollo.mutate({\n      mutation: UpdateRecordMutation,\n      variables: {\n        input: {\n          fileId: updateId,\n          plainMeta: JSON.stringify({ fileType: FileType.RecordContent }),\n          wrappedStateKey: reWrappedContent.doubleWrappedKey,\n          cipherMeta: reWrappedContent.cipherMeta,\n        },\n      },\n    });\n\n    try {\n      await this.recordAttachmentService.uploadAttachments(\n        recordId,\n        updatedRecord.attachments\n      );\n    } catch (e) {\n      console.error(e);\n      return { recordId, attachmentError: e };\n    }\n    return { recordId };\n  }\n\n  public async archiveRecord(recordId: string): Promise<void> {\n    // All content of the record should also be archived, hence, recursive=true\n    return this.categoryService.archiveDirectory(recordId, true);\n  }\n\n  public async unarchiveRecord(recordId: string): Promise<void> {\n    // All content of the record should also be unarchived, hence, recursive=true\n    return this.categoryService.unarchiveDirectory(recordId, true);\n  }\n\n  public async deleteRecord(recordId: string): Promise<void> {\n    await this.lrApollo.mutate({\n      mutation: DeleteRecordMutation,\n      variables: { recordId },\n    });\n  }\n}\n"]}
|
|
206
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"record.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/record/record.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Injectable } from '@angular/core';\nimport { LrApolloService } from '../api/lr-apollo.service';\nimport { CategoryFilter, DirectoryType } from '../category/category.gql';\nimport { CategoryService } from '../category/category.service';\nimport { AccessLevel, Category } from '../category/category.types';\nimport { KeyMetaService } from '../key/key-meta.service';\nimport { RecordAttachmentService } from './record-attachment.service';\nimport {\n  CreateRecordContainerMutation,\n  CreateRecordMutation,\n  DeleteRecordMutation,\n  FileType,\n  GetRecordQuery,\n  RecordAttachmentFilter,\n  RecordContentFilter,\n  UpdateRecordMutation,\n} from './record.gql';\nimport {\n  LrRecord,\n  NewRecord,\n  RecordAttachment,\n  UpdatedRecord,\n} from './record.types';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class RecordService {\n  constructor(\n    private lrApollo: LrApolloService,\n    private keyMetaService: KeyMetaService,\n    private categoryService: CategoryService,\n    private recordAttachmentService: RecordAttachmentService\n  ) {}\n\n  public async getRecord(recordId: string): Promise<LrRecord> {\n    const { record } = await this.lrApollo.query<any>({\n      query: GetRecordQuery(),\n      variables: {\n        id: recordId,\n        categoryFilter: CategoryFilter,\n        contentFilter: RecordContentFilter,\n        attachmentsFilter: RecordAttachmentFilter,\n      },\n    });\n    const contents = record.content.edges[0].node.childFile;\n    const { name, recordType, fields } =\n      (await this.keyMetaService.decryptMeta(contents.currentVersion.state)) ||\n      {};\n    const categories = await Promise.all<Category[]>(\n      record.parentCategories.edges.map(async (x: any) => [\n        ...(await this.categoryService.mapParentCategories(\n          x.node.parentDirectory\n        )),\n        await this.categoryService.mapCategory(x.node.parentDirectory),\n      ])\n    );\n    const attachments = await this.mapAttachments(record.attachments.edges);\n    const isOwner =\n      record.accessRoles &&\n      record.accessRoles.some((x) => x.role === AccessLevel.Owner);\n\n    return {\n      id: record.id,\n      keyId: record.keyId,\n      updateKeyId: contents.keyId,\n      updateId: contents.id,\n      name,\n      recordType,\n      fields,\n      categories,\n      attachments,\n      myAccessLevel: isOwner ? AccessLevel.Owner : record.accessRoles[0].role,\n      sharedAccess: isOwner\n        ? record.accessRoles\n            .filter((x) => x.role !== AccessLevel.Owner)\n            .map((x) => ({\n              trustedPartyId: x.trustedParty && x.trustedParty.id,\n              accessLevel: x.role,\n              isInherited: x.method === 'inherited',\n              inheritedFrom: x.inheritedFrom && x.inheritedFrom.id,\n            }))\n        : [],\n      isArchived: !!record.archived,\n      createdOn: record.created,\n      lastModified:\n        new Date(record.modified) >\n        new Date(contents.currentVersion.state.modified)\n          ? record.modified\n          : contents.currentVersion.state.modified,\n    };\n  }\n\n  private async mapAttachments(\n    attachments: any[]\n  ): Promise<RecordAttachment[]> {\n    return await Promise.all<RecordAttachment>(\n      attachments\n        .map((x) => x.node.childFile)\n        .map(async (x: any) => {\n          const { name, fieldId, fileType, fileSize, lastModified } =\n            (await this.keyMetaService.decryptMeta(x.currentVersion.state)) ||\n            {};\n\n          return {\n            fileId: x.id,\n            keyId: x.currentVersion.state.keyId,\n            contentId: x.currentVersion.state.id,\n            fieldId,\n            name,\n            fileType,\n            fileSize,\n            lastModified,\n          };\n        })\n    );\n  }\n\n  public async createRecord(\n    newRecord: NewRecord\n  ): Promise<{ recordId: string; attachmentError?: Error }> {\n    // Create directory that holds the record\n    const wrappedContent = await this.keyMetaService.wrapContent(\n      null,\n      newRecord.categoryIds\n    );\n    const response = await this.lrApollo.mutate<any>({\n      mutation: CreateRecordContainerMutation,\n      variables: {\n        plainMeta: JSON.stringify({\n          directoryType: DirectoryType.Record,\n          isHidden: false,\n        }),\n        parentDirectories: wrappedContent.wrappedKeys,\n        parentRootDirectory: wrappedContent.rootKey,\n      },\n    });\n    const recordId = response.new.category.id;\n    const secureContent = {\n      name: newRecord.name,\n      recordType: newRecord.recordType,\n      fields: newRecord.fields,\n    };\n    const doubleWrappedContent = await this.keyMetaService.doubleWrapContent(\n      secureContent,\n      [recordId]\n    );\n\n    // Create the file that holds the record contents\n    await this.lrApollo.mutate({\n      mutation: CreateRecordMutation,\n      variables: {\n        input: {\n          plainMeta: JSON.stringify({ fileType: FileType.RecordContent }),\n          wrappedStateKey: doubleWrappedContent.doubleWrappedKey,\n          cipherMeta: doubleWrappedContent.cipherMeta,\n          parentDirectories: doubleWrappedContent.wrappedKeys.map((x) => ({\n            directoryId: x.directoryId,\n            wrappingKeyId: x.wrappingKeyId,\n            wrappedFileKey: x.wrappedKey,\n          })),\n        },\n      },\n    });\n\n    try {\n      await this.recordAttachmentService.uploadAttachments(\n        recordId,\n        newRecord.attachments\n      );\n    } catch (e) {\n      console.error(e);\n      return { recordId, attachmentError: e };\n    }\n    return { recordId };\n  }\n\n  public async updateRecord(\n    recordId: string,\n    updateId: string,\n    updateKeyId: string,\n    updatedRecord: UpdatedRecord\n  ): Promise<{ recordId: string; attachmentError?: Error }> {\n    const secureContent = {\n      name: updatedRecord.name,\n      recordType: updatedRecord.recordType,\n      fields: updatedRecord.fields,\n    };\n    const reWrappedContent = await this.keyMetaService.reWrapContent(\n      updateKeyId,\n      secureContent\n    );\n\n    await this.lrApollo.mutate({\n      mutation: UpdateRecordMutation,\n      variables: {\n        input: {\n          fileId: updateId,\n          plainMeta: JSON.stringify({ fileType: FileType.RecordContent }),\n          wrappedStateKey: reWrappedContent.doubleWrappedKey,\n          cipherMeta: reWrappedContent.cipherMeta,\n        },\n      },\n    });\n\n    try {\n      await this.recordAttachmentService.uploadAttachments(\n        recordId,\n        updatedRecord.attachments\n      );\n    } catch (e) {\n      console.error(e);\n      return { recordId, attachmentError: e };\n    }\n    return { recordId };\n  }\n\n  public async archiveRecord(recordId: string): Promise<void> {\n    // All content of the record should also be archived, hence, recursive=true\n    return this.categoryService.archiveDirectory(recordId, true);\n  }\n\n  public async unarchiveRecord(recordId: string): Promise<void> {\n    // All content of the record should also be unarchived, hence, recursive=true\n    return this.categoryService.unarchiveDirectory(recordId, true);\n  }\n\n  public async deleteRecord(recordId: string): Promise<void> {\n    await this.lrApollo.mutate({\n      mutation: DeleteRecordMutation,\n      variables: { recordId },\n    });\n  }\n}\n"]}
|
|
@@ -12,4 +12,4 @@ export class NewOrUpdatedAttachment extends NewAttachment {
|
|
|
12
12
|
}
|
|
13
13
|
export class UpdatedRecord {
|
|
14
14
|
}
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjb3JkLnR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9zcmMvbGliL3JlY29yZC9yZWNvcmQudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0JBLE1BQU0sT0FBTyxXQUFXO0NBTXZCO0FBRUQsTUFBTSxPQUFPLGdCQUFnQjtDQVU1QjtBQUVELE1BQU0sT0FBTyxRQUFRO0NBbUJwQjtBQUVELE1BQU0sT0FBTyxhQUFhO0NBSXpCO0FBRUQsTUFBTSxPQUFPLFNBQVM7Q0FPckI7QUFFRCxNQUFNLE9BQU8sc0JBQXVCLFNBQVEsYUFBYTtDQUd4RDtBQUVELE1BQU0sT0FBTyxhQUFhO0NBTXpCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQWNjZXNzTGV2ZWwsXG4gIENhdGVnb3J5LFxuICBTaGFyZWRBY2Nlc3MsXG59IGZyb20gJy4uL2NhdGVnb3J5L2NhdGVnb3J5LnR5cGVzJztcbmltcG9ydCB7XG4gIFJlY29yZEZpZWxkVHlwZSxcbiAgUmVjb3JkVHlwZUZpZWxkT3B0aW9uLFxuICBSZWNvcmRUeXBlU3VtbWFyeSxcbn0gZnJvbSAnLi4vcmVjb3JkLXR5cGUvcmVjb3JkLXR5cGUudHlwZXMnO1xuXG5leHBvcnQgdHlwZSBSZWNvcmRGaWVsZFZhbHVlID1cbiAgfCBzdHJpbmdcbiAgfCBzdHJpbmdbXVxuICB8IFJlY29yZFR5cGVGaWVsZE9wdGlvblxuICB8IFJlY29yZFR5cGVGaWVsZE9wdGlvbltdXG4gIHwgUmVjb3JkRmllbGRbXTtcblxuZXhwb3J0IGNsYXNzIFJlY29yZEZpZWxkIHtcbiAgaWQ/OiBzdHJpbmc7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIHR5cGU6IFJlY29yZEZpZWxkVHlwZTtcblxuICB2YWx1ZT86IFJlY29yZEZpZWxkVmFsdWU7XG59XG5cbmV4cG9ydCBjbGFzcyBSZWNvcmRBdHRhY2htZW50IHtcbiAgZmlsZUlkOiBzdHJpbmc7XG4gIGtleUlkOiBzdHJpbmc7XG4gIGZpZWxkSWQ/OiBzdHJpbmc7XG4gIGNvbnRlbnRJZDogc3RyaW5nO1xuXG4gIG5hbWU6IHN0cmluZztcbiAgZmlsZVR5cGU6IHN0cmluZztcbiAgZmlsZVNpemU6IG51bWJlcjtcbiAgbGFzdE1vZGlmaWVkOiBudW1iZXIgfCBEYXRlO1xufVxuXG5leHBvcnQgY2xhc3MgTHJSZWNvcmQge1xuICBpZDogc3RyaW5nO1xuICAvLyBUaGlzIGlzIHRoZSBrZXkgb2YgdGhlIGRpcmVjdG9yeSB0aGF0IHJlcHJlc2VudHMgdGhlIHJlY29yZFxuICBrZXlJZDogc3RyaW5nO1xuICAvLyBUaGlzIGlzIHRoZSBrZXkgb2YgdGhlIGZpbGUgY29udGFpbmVkIGluIHNpZGUgdGhlIHJlY29yZCB0aGF0IGhvbGRzIHRoZSByZWNvcmQncyBmaWVsZHMuXG4gIHVwZGF0ZUtleUlkOiBzdHJpbmc7XG4gIHVwZGF0ZUlkOiBzdHJpbmc7XG5cbiAgbmFtZTogc3RyaW5nO1xuICBjYXRlZ29yaWVzPzogQ2F0ZWdvcnlbXVtdO1xuICBmaWVsZHM/OiBSZWNvcmRGaWVsZFtdO1xuICBhdHRhY2htZW50cz86IFJlY29yZEF0dGFjaG1lbnRbXTtcblxuICByZWNvcmRUeXBlOiBSZWNvcmRUeXBlU3VtbWFyeTtcbiAgY3JlYXRlZE9uOiBzdHJpbmcgfCBEYXRlO1xuICBsYXN0TW9kaWZpZWQ6IHN0cmluZyB8IERhdGU7XG4gIGlzQXJjaGl2ZWQ6IGJvb2xlYW47XG4gIG15QWNjZXNzTGV2ZWw6IEFjY2Vzc0xldmVsO1xuICBzaGFyZWRBY2Nlc3M6IFNoYXJlZEFjY2Vzc1tdO1xufVxuXG5leHBvcnQgY2xhc3MgTmV3QXR0YWNobWVudCB7XG4gIGZpZWxkSWQ/OiBzdHJpbmc7XG4gIG5hbWU6IHN0cmluZztcbiAgZmlsZT86IEZpbGU7XG59XG5cbmV4cG9ydCBjbGFzcyBOZXdSZWNvcmQge1xuICBuYW1lOiBzdHJpbmc7XG4gIHJlY29yZFR5cGU6IFJlY29yZFR5cGVTdW1tYXJ5O1xuICBjYXRlZ29yeUlkczogc3RyaW5nW107XG5cbiAgZmllbGRzPzogUmVjb3JkRmllbGRbXTtcbiAgYXR0YWNobWVudHM/OiBOZXdBdHRhY2htZW50W107XG59XG5cbmV4cG9ydCBjbGFzcyBOZXdPclVwZGF0ZWRBdHRhY2htZW50IGV4dGVuZHMgTmV3QXR0YWNobWVudCB7XG4gIGZpbGVJZD86IHN0cmluZztcbiAgaXNEZWxldGVkPzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGNsYXNzIFVwZGF0ZWRSZWNvcmQge1xuICBuYW1lOiBzdHJpbmc7XG4gIHJlY29yZFR5cGU6IFJlY29yZFR5cGVTdW1tYXJ5O1xuXG4gIGZpZWxkcz86IFJlY29yZEZpZWxkW107XG4gIGF0dGFjaG1lbnRzPzogTmV3T3JVcGRhdGVkQXR0YWNobWVudFtdO1xufVxuIl19
|
|
@@ -72,4 +72,4 @@ RecordTypeService.ctorParameters = () => [
|
|
|
72
72
|
{ type: HttpClient }
|
|
73
73
|
];
|
|
74
74
|
export { ɵ0 };
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjb3JkLXR5cGUuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi9yZWNvcmQtdHlwZS9yZWNvcmQtdHlwZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDbEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBSTNDLE1BQU0sV0FBVyxHQUFHLENBQUMsQ0FBVyxFQUFFLENBQVcsRUFBRSxFQUFFO0lBQy9DLElBQUksQ0FBQyxLQUFLLENBQUM7UUFBRSxPQUFPLElBQUksQ0FBQztJQUN6QixJQUFJLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxJQUFJLElBQUk7UUFBRSxPQUFPLEtBQUssQ0FBQztJQUN6QyxJQUFJLENBQUMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDLE1BQU07UUFBRSxPQUFPLEtBQUssQ0FBQztJQUV4QyxLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsRUFBRTtRQUNqQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQUUsT0FBTyxLQUFLLENBQUM7S0FDakM7SUFDRCxPQUFPLElBQUksQ0FBQztBQUNkLENBQUMsQ0FBQzs7QUFLRixNQUFNLE9BQU8saUJBQWlCO0lBSTVCLFlBQW9CLElBQWdCO1FBQWhCLFNBQUksR0FBSixJQUFJLENBQVk7SUFBRyxDQUFDO0lBRTNCLGNBQWM7O1lBQ3pCLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFO2dCQUNyQixJQUFJLENBQUMsV0FBVyxHQUFHLE1BQU0sSUFBSSxDQUFDLElBQUk7cUJBQy9CLEdBQUcsQ0FBZSxnQ0FBZ0MsQ0FBQztxQkFDbkQsU0FBUyxFQUFFLENBQUM7YUFDaEI7WUFDRCxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRTtnQkFDcEIsSUFBSSxDQUFDLFVBQVUsR0FBRyxNQUFNLElBQUksQ0FBQyxJQUFJO3FCQUM5QixHQUFHLENBQW9CLDhCQUE4QixDQUFDO3FCQUN0RCxTQUFTLEVBQUUsQ0FBQzthQUNoQjtZQUVELE1BQU0sYUFBYSxHQUFHLElBQUksQ0FBQyxVQUFVO2lCQUNsQyxHQUFHLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLEdBQUcsQ0FBQyxhQUFhLENBQUM7aUJBQy9CLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUMsR0FBRyxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztZQUVoRCxNQUFNLHlCQUF5QixHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDLENBQUMsVUFBVSxFQUFFLEVBQUUsQ0FBQyxpQ0FDbEUsVUFBVSxLQUNiLGFBQWEsRUFBRSxVQUFVLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFO29CQUMvQyxPQUFPLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxZQUFZLEVBQUUsRUFBRTt3QkFDOUIsTUFBTSxNQUFNLEdBQUcsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksS0FBSyxZQUFZLENBQUMsQ0FBQzt3QkFDbEUsSUFBSSxNQUFNLEVBQUU7NEJBQ1YsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDO3lCQUNwQjs2QkFBTTs0QkFDTCxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxLQUFLLFlBQVksQ0FBQyxDQUFDLElBQUksQ0FBQzt5QkFDbEU7b0JBQ0gsQ0FBQyxDQUFDLENBQUM7Z0JBQ0wsQ0FBQyxDQUFDLElBQ0YsQ0FBQyxDQUFDO1lBQ0osT0FBTyxPQUFPLENBQUMsT0FBTyxDQUFDLHlCQUF5QixDQUFDLENBQUM7UUFDcEQsQ0FBQztLQUFBO0lBRVksYUFBYSxDQUFDLFlBQW9COztZQUM3QyxPQUFPLENBQUMsTUFBTSxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLEtBQUssWUFBWSxDQUFDLENBQUM7UUFDMUUsQ0FBQztLQUFBO0lBRVkseUJBQXlCLENBQ3BDLFlBQXNCOztZQUV0QixNQUFNLFdBQVcsR0FBRyxNQUFNLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztZQUVoRCxPQUFPLFdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUM5QixDQUFDLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsV0FBVyxDQUFDLENBQUMsRUFBRSxZQUFZLENBQUMsQ0FBQyxDQUN2RCxDQUFDO1FBQ0osQ0FBQztLQUFBOzs7O1lBckRGLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQjs7O1lBbEJRLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGVmYXVsdENhdGVnb3J5IH0gZnJvbSAnLi4vY2F0ZWdvcnkvY2F0ZWdvcnkudHlwZXMnO1xuaW1wb3J0IHsgUmVjb3JkVHlwZSB9IGZyb20gJy4vcmVjb3JkLXR5cGUudHlwZXMnO1xuXG5jb25zdCBhcnJheXNFcXVhbCA9IChhOiBzdHJpbmdbXSwgYjogc3RyaW5nW10pID0+IHtcbiAgaWYgKGEgPT09IGIpIHJldHVybiB0cnVlO1xuICBpZiAoYSA9PSBudWxsIHx8IGIgPT0gbnVsbCkgcmV0dXJuIGZhbHNlO1xuICBpZiAoYS5sZW5ndGggIT09IGIubGVuZ3RoKSByZXR1cm4gZmFsc2U7XG5cbiAgZm9yIChsZXQgaSA9IDA7IGkgPCBhLmxlbmd0aDsgKytpKSB7XG4gICAgaWYgKGFbaV0gIT09IGJbaV0pIHJldHVybiBmYWxzZTtcbiAgfVxuICByZXR1cm4gdHJ1ZTtcbn07XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBSZWNvcmRUeXBlU2VydmljZSB7XG4gIHByaXZhdGUgcmVjb3JkVHlwZXM6IFJlY29yZFR5cGVbXTtcbiAgcHJpdmF0ZSBjYXRlZ29yaWVzOiBEZWZhdWx0Q2F0ZWdvcnlbXTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGh0dHA6IEh0dHBDbGllbnQpIHt9XG5cbiAgcHVibGljIGFzeW5jIGdldFJlY29yZFR5cGVzKCk6IFByb21pc2U8UmVjb3JkVHlwZVtdPiB7XG4gICAgaWYgKCF0aGlzLnJlY29yZFR5cGVzKSB7XG4gICAgICB0aGlzLnJlY29yZFR5cGVzID0gYXdhaXQgdGhpcy5odHRwXG4gICAgICAgIC5nZXQ8UmVjb3JkVHlwZVtdPignL2Fzc2V0cy9tZXRhL3JlY29yZC10eXBlcy5qc29uJylcbiAgICAgICAgLnRvUHJvbWlzZSgpO1xuICAgIH1cbiAgICBpZiAoIXRoaXMuY2F0ZWdvcmllcykge1xuICAgICAgdGhpcy5jYXRlZ29yaWVzID0gYXdhaXQgdGhpcy5odHRwXG4gICAgICAgIC5nZXQ8RGVmYXVsdENhdGVnb3J5W10+KCcvYXNzZXRzL21ldGEvY2F0ZWdvcmllcy5qc29uJylcbiAgICAgICAgLnRvUHJvbWlzZSgpO1xuICAgIH1cblxuICAgIGNvbnN0IHN1YkNhdGVnb3JpZXMgPSB0aGlzLmNhdGVnb3JpZXNcbiAgICAgIC5tYXAoKGNhdCkgPT4gY2F0LnN1YkNhdGVnb3JpZXMpXG4gICAgICAucmVkdWNlKChhY2MsIG5leHQpID0+IFsuLi5hY2MsIC4uLm5leHRdLCBbXSk7XG5cbiAgICBjb25zdCByZWNvcmRUeXBlc1dpdGhDYXRlZ29yaWVzID0gdGhpcy5yZWNvcmRUeXBlcy5tYXAoKHJlY29yZFR5cGUpID0+ICh7XG4gICAgICAuLi5yZWNvcmRUeXBlLFxuICAgICAgY2F0ZWdvcnlOYW1lczogcmVjb3JkVHlwZS5jYXRlZ29yaWVzLm1hcCgoY2F0KSA9PiB7XG4gICAgICAgIHJldHVybiBjYXQubWFwKChjYXRlZ29yeUNvZGUpID0+IHtcbiAgICAgICAgICBjb25zdCBzdWJDYXQgPSBzdWJDYXRlZ29yaWVzLmZpbmQoKGMpID0+IGMuY29kZSA9PT0gY2F0ZWdvcnlDb2RlKTtcbiAgICAgICAgICBpZiAoc3ViQ2F0KSB7XG4gICAgICAgICAgICByZXR1cm4gc3ViQ2F0Lm5hbWU7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHJldHVybiB0aGlzLmNhdGVnb3JpZXMuZmluZCgoYykgPT4gYy5jb2RlID09PSBjYXRlZ29yeUNvZGUpLm5hbWU7XG4gICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICAgIH0pLFxuICAgIH0pKTtcbiAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKHJlY29yZFR5cGVzV2l0aENhdGVnb3JpZXMpO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIGdldFJlY29yZFR5cGUocmVjb3JkVHlwZUlkOiBzdHJpbmcpOiBQcm9taXNlPFJlY29yZFR5cGU+IHtcbiAgICByZXR1cm4gKGF3YWl0IHRoaXMuZ2V0UmVjb3JkVHlwZXMoKSkuZmluZCgoeCkgPT4geC5pZCA9PT0gcmVjb3JkVHlwZUlkKTtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBnZXRSZWNvcmRUeXBlc0ZvckNhdGVnb3J5KFxuICAgIGNhdGVnb3J5VHJlZTogc3RyaW5nW11cbiAgKTogUHJvbWlzZTxSZWNvcmRUeXBlW10+IHtcbiAgICBjb25zdCByZWNvcmRUeXBlcyA9IGF3YWl0IHRoaXMuZ2V0UmVjb3JkVHlwZXMoKTtcblxuICAgIHJldHVybiByZWNvcmRUeXBlcy5maWx0ZXIoKHgpID0+XG4gICAgICB4LmNhdGVnb3JpZXMuc29tZSgoeSkgPT4gYXJyYXlzRXF1YWwoeSwgY2F0ZWdvcnlUcmVlKSlcbiAgICApO1xuICB9XG59XG4iXX0=
|
|
@@ -25,4 +25,4 @@ export class RecordTypeField {
|
|
|
25
25
|
}
|
|
26
26
|
export class RecordTypeSummary {
|
|
27
27
|
}
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjb3JkLXR5cGUudHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3NyYy9saWIvcmVjb3JkLXR5cGUvcmVjb3JkLXR5cGUudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksZUFpQlg7QUFqQkQsV0FBWSxlQUFlO0lBQ3pCLGdDQUFhLENBQUE7SUFDYixrQ0FBZSxDQUFBO0lBQ2YsOEJBQVcsQ0FBQTtJQUNYLGtDQUFlLENBQUE7SUFDZixnQ0FBYSxDQUFBO0lBQ2Isd0NBQXFCLENBQUE7SUFDckIsd0NBQXFCLENBQUE7SUFDckIsb0NBQWlCLENBQUE7SUFDakIsZ0RBQTZCLENBQUE7SUFDN0IsOENBQTJCLENBQUE7SUFDM0IsZ0NBQWEsQ0FBQTtJQUNiLDBDQUF1QixDQUFBO0lBQ3ZCLG9DQUFpQixDQUFBO0lBQ2pCLDhDQUEyQixDQUFBO0lBQzNCLGtDQUFlLENBQUE7SUFDZixvQ0FBaUIsQ0FBQTtBQUNuQixDQUFDLEVBakJXLGVBQWUsS0FBZixlQUFlLFFBaUIxQjtBQUVELE1BQU0sT0FBTyxVQUFVO0NBWXRCO0FBRUQsTUFBTSxPQUFPLHFCQUFxQjtDQUlqQztBQUVELE1BQU0sT0FBTyxlQUFlO0NBWTNCO0FBRUQsTUFBTSxPQUFPLGlCQUFpQjtDQUk3QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIFJlY29yZEZpZWxkVHlwZSB7XG4gIFRleHQgPSAndGV4dCcsXG4gIEVtYWlsID0gJ2VtYWlsJyxcbiAgVXJsID0gJ3VybCcsXG4gIFBob25lID0gJ3Bob25lJyxcbiAgRGF0ZSA9ICdkYXRlJyxcbiAgUGFzc3dvcmQgPSAncGFzc3dvcmQnLFxuICBUZXh0QXJlYSA9ICd0ZXh0QXJlYScsXG4gIFNlbGVjdCA9ICdzZWxlY3QnLFxuICBTaW5nbGVDaG9pY2UgPSAnc2luZ2xlQ2hvaWNlJyxcbiAgTXVsdGlDaG9pY2UgPSAnbXVsdGlDaG9pY2UnLFxuICBGaWxlID0gJ2ZpbGUnLFxuICBNdWx0aUZpbGUgPSAnbXVsdGlGaWxlJyxcbiAgUmVjb3JkID0gJ3JlY29yZCcsXG4gIE11bHRpUmVjb3JkID0gJ211bHRpUmVjb3JkJyxcbiAgR3JvdXAgPSAnZ3JvdXAnLFxuICBDdXN0b20gPSAnY3VzdG9tJyxcbn1cblxuZXhwb3J0IGNsYXNzIFJlY29yZFR5cGUge1xuICBpZDogc3RyaW5nO1xuICB2ZXJzaW9uOiBudW1iZXI7XG4gIG5hbWU6IHN0cmluZztcbiAgdGFnczogc3RyaW5nW107XG5cbiAgYWxsb3dBdHRhY2htZW50czogYm9vbGVhbjtcbiAgYWxsb3dDdXN0b21GaWVsZHM6IGJvb2xlYW47XG5cbiAgZmllbGRzOiBSZWNvcmRUeXBlRmllbGRbXTtcbiAgY2F0ZWdvcmllczogc3RyaW5nW11bXTtcbiAgY2F0ZWdvcnlOYW1lczogc3RyaW5nW11bXTtcbn1cblxuZXhwb3J0IGNsYXNzIFJlY29yZFR5cGVGaWVsZE9wdGlvbiB7XG4gIG5hbWU6IHN0cmluZztcblxuICBjYXRlZ29yaWVzPzogc3RyaW5nW11bXTtcbn1cblxuZXhwb3J0IGNsYXNzIFJlY29yZFR5cGVGaWVsZCB7XG4gIGlkOiBzdHJpbmc7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIHR5cGU6IFJlY29yZEZpZWxkVHlwZTtcbiAgcGxhY2Vob2xkZXI/OiBzdHJpbmc7XG4gIGhpbnQ/OiBzdHJpbmc7XG4gIGlzTWFuZGF0b3J5PzogYm9vbGVhbjtcblxuICBvcHRpb25zPzogUmVjb3JkVHlwZUZpZWxkT3B0aW9uW107XG4gIGV4dGVuc2lvbnM/OiBzdHJpbmc7XG4gIHJlY29yZFR5cGVJZHM/OiBzdHJpbmdbXTtcbiAgZmllbGRzPzogUmVjb3JkVHlwZUZpZWxkW107XG59XG5cbmV4cG9ydCBjbGFzcyBSZWNvcmRUeXBlU3VtbWFyeSB7XG4gIGlkOiBzdHJpbmc7XG4gIHZlcnNpb246IG51bWJlcjtcbiAgbmFtZTogc3RyaW5nO1xufVxuIl19
|
|
@@ -0,0 +1,173 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { HttpClient } from '@angular/common/http';
|
|
3
|
+
import { Inject, Injectable } from '@angular/core';
|
|
4
|
+
import { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';
|
|
5
|
+
import { EncryptionService } from '../encryption/encryption.service';
|
|
6
|
+
import { KeyFactoryService } from '../key/key-factory.service';
|
|
7
|
+
import { LR_CONFIG } from '../life-ready.config';
|
|
8
|
+
import { PasswordService } from '../password/password.service';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "../life-ready.config";
|
|
11
|
+
import * as i2 from "@aws-amplify/auth/lib-esm/Auth";
|
|
12
|
+
import * as i3 from "@angular/common/http";
|
|
13
|
+
import * as i4 from "../key/key-factory.service";
|
|
14
|
+
import * as i5 from "../encryption/encryption.service";
|
|
15
|
+
import * as i6 from "../password/password.service";
|
|
16
|
+
export class RegisterService {
|
|
17
|
+
constructor(config, auth, http, keyFactory, encryptionService, passwordService) {
|
|
18
|
+
this.config = config;
|
|
19
|
+
this.auth = auth;
|
|
20
|
+
this.http = http;
|
|
21
|
+
this.keyFactory = keyFactory;
|
|
22
|
+
this.encryptionService = encryptionService;
|
|
23
|
+
this.passwordService = passwordService;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Request a verification code to be sent out to an email.
|
|
27
|
+
* @return Info needed to be submitted along with the verification code
|
|
28
|
+
*/
|
|
29
|
+
verifyEmail(email) {
|
|
30
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
31
|
+
const { claim_id } = yield this.http
|
|
32
|
+
.post(`${this.config.authUrl}cove/claim/email/`, {
|
|
33
|
+
address: email,
|
|
34
|
+
context: 'signup',
|
|
35
|
+
})
|
|
36
|
+
.toPromise();
|
|
37
|
+
return claim_id;
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
verifyPhone(phoneNumber) {
|
|
41
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
42
|
+
const { claim_id } = yield this.http
|
|
43
|
+
.post(`${this.config.authUrl}cove/claim/sms/`, {
|
|
44
|
+
address: phoneNumber,
|
|
45
|
+
context: 'signup',
|
|
46
|
+
})
|
|
47
|
+
.toPromise();
|
|
48
|
+
return claim_id;
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
confirmVerificationCode(verificationId, verificationCode) {
|
|
52
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
53
|
+
const { token } = yield this.http
|
|
54
|
+
.post(`${this.config.authUrl}cove/respond/`, {
|
|
55
|
+
claim_id: verificationId,
|
|
56
|
+
v_code: verificationCode,
|
|
57
|
+
})
|
|
58
|
+
.toPromise();
|
|
59
|
+
return token;
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
register(email, password, verificationId, verificationToken, verificationType = 'email') {
|
|
63
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
64
|
+
// Generate the key material needed for PassIdp which will be the password used for Cognito.
|
|
65
|
+
const passKeyBundle = yield this.passwordService.createPassKeyBundle(password);
|
|
66
|
+
const masterKey = yield this.keyFactory.createKey();
|
|
67
|
+
const wrappedMasterKey = yield this.encryptionService.encrypt(passKeyBundle.passKey, masterKey.toJSON(true));
|
|
68
|
+
const rootKey = yield this.keyFactory.createKey();
|
|
69
|
+
const wrappedRootKey = yield this.encryptionService.encrypt(masterKey, rootKey.toJSON(true));
|
|
70
|
+
// Encryption PKC key
|
|
71
|
+
const prk = yield this.keyFactory.createPkcKey();
|
|
72
|
+
const wrappedPrk = yield this.encryptionService.encrypt(rootKey, prk.toJSON(true));
|
|
73
|
+
// Signing PKC key
|
|
74
|
+
const sigPrk = yield this.keyFactory.createPkcSignKey();
|
|
75
|
+
const wrappedSigPrk = yield this.encryptionService.encrypt(rootKey, sigPrk.toJSON(true));
|
|
76
|
+
// API call to setup profile
|
|
77
|
+
const user = yield this.http
|
|
78
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
79
|
+
.post(`${this.config.authUrl}users/`, {
|
|
80
|
+
claims: [
|
|
81
|
+
{
|
|
82
|
+
type: verificationType,
|
|
83
|
+
token: verificationToken,
|
|
84
|
+
claim_id: verificationId,
|
|
85
|
+
},
|
|
86
|
+
],
|
|
87
|
+
pass_idp_params: passKeyBundle.passIdpParams,
|
|
88
|
+
pass_idp_verifier_pbk: passKeyBundle.passIdpVerifier.toJSON(),
|
|
89
|
+
wrapped_pass_idp_verifier_prk: passKeyBundle.wrappedPassIdpVerifierPrk,
|
|
90
|
+
pass_key_params: passKeyBundle.passKeyParams,
|
|
91
|
+
wrapped_master_key: wrappedMasterKey,
|
|
92
|
+
wrapped_root_key: wrappedRootKey,
|
|
93
|
+
pbk: prk.toJSON(),
|
|
94
|
+
wrapped_prk: wrappedPrk,
|
|
95
|
+
sig_pbk: sigPrk.toJSON(),
|
|
96
|
+
wrapped_sig_prk: wrappedSigPrk,
|
|
97
|
+
})
|
|
98
|
+
.toPromise();
|
|
99
|
+
// API call to create user on cognito
|
|
100
|
+
const attributes = {};
|
|
101
|
+
user.claims.forEach((claim) => {
|
|
102
|
+
attributes[claim.type] = claim.value;
|
|
103
|
+
});
|
|
104
|
+
// Random suffix for uniqueness. If there's a duplicate, then used just needs to
|
|
105
|
+
// sign up again. But chances of collision is low.
|
|
106
|
+
const suffix = this.keyFactory.randomDigitsNoZeros(4);
|
|
107
|
+
const cognitoUser = yield this.auth.signUp({
|
|
108
|
+
username: `${email.split('@')[0]}.${suffix}`,
|
|
109
|
+
password: this.passwordService.getPassIdpString(passKeyBundle.passIdp),
|
|
110
|
+
attributes,
|
|
111
|
+
// Unfortunately, validationData is not passed to the post
|
|
112
|
+
// confirmation cognito trigger. So can can't do the association there.
|
|
113
|
+
// The current workflow will create a new user on LR before signing up
|
|
114
|
+
// with Cognito. Then Cognito can use the user.id and user.pre_sign_up_token to
|
|
115
|
+
// do the validation of the attributes.
|
|
116
|
+
// validationData: [
|
|
117
|
+
// new CognitoUserAttribute({
|
|
118
|
+
// Name: "user_id",
|
|
119
|
+
// Value: String(user.id)
|
|
120
|
+
// }),
|
|
121
|
+
// new CognitoUserAttribute({
|
|
122
|
+
// Name: "user_pre_sign_up_token",
|
|
123
|
+
// Value: user.pre_sign_up_token
|
|
124
|
+
// })
|
|
125
|
+
// ]
|
|
126
|
+
clientMetadata: {
|
|
127
|
+
user_id: String(user.id),
|
|
128
|
+
user_pre_sign_up_token: String(user.pre_sign_up_token),
|
|
129
|
+
},
|
|
130
|
+
});
|
|
131
|
+
return {
|
|
132
|
+
username: cognitoUser.user.getUsername(),
|
|
133
|
+
userId: user.id,
|
|
134
|
+
preSignUpToken: user.pre_sign_up_token,
|
|
135
|
+
userSub: cognitoUser.userSub,
|
|
136
|
+
};
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
hibpBreachedAccounts(account) {
|
|
140
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
141
|
+
// The account is just the email
|
|
142
|
+
try {
|
|
143
|
+
const response = yield this.http
|
|
144
|
+
.get(`${this.config.authUrl}users/hibp/breachedaccount/${account}/?truncateResponse=false`)
|
|
145
|
+
.toPromise();
|
|
146
|
+
return response;
|
|
147
|
+
}
|
|
148
|
+
catch (error) {
|
|
149
|
+
if (error.status === 404) {
|
|
150
|
+
return null;
|
|
151
|
+
}
|
|
152
|
+
else {
|
|
153
|
+
throw error;
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
});
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
RegisterService.ɵprov = i0.ɵɵdefineInjectable({ factory: function RegisterService_Factory() { return new RegisterService(i0.ɵɵinject(i1.LR_CONFIG), i0.ɵɵinject(i2.AuthClass), i0.ɵɵinject(i3.HttpClient), i0.ɵɵinject(i4.KeyFactoryService), i0.ɵɵinject(i5.EncryptionService), i0.ɵɵinject(i6.PasswordService)); }, token: RegisterService, providedIn: "root" });
|
|
160
|
+
RegisterService.decorators = [
|
|
161
|
+
{ type: Injectable, args: [{
|
|
162
|
+
providedIn: 'root',
|
|
163
|
+
},] }
|
|
164
|
+
];
|
|
165
|
+
RegisterService.ctorParameters = () => [
|
|
166
|
+
{ type: undefined, decorators: [{ type: Inject, args: [LR_CONFIG,] }] },
|
|
167
|
+
{ type: AuthClass },
|
|
168
|
+
{ type: HttpClient },
|
|
169
|
+
{ type: KeyFactoryService },
|
|
170
|
+
{ type: EncryptionService },
|
|
171
|
+
{ type: PasswordService }
|
|
172
|
+
];
|
|
173
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"register.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/register/register.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Inject, Injectable } from '@angular/core';\nimport { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';\nimport { JSONObject } from '../api/types';\nimport { RegisterResult } from '../auth/auth.types';\nimport { EncryptionService } from '../encryption/encryption.service';\nimport { KeyFactoryService } from '../key/key-factory.service';\nimport { LifeReadyConfig, LR_CONFIG } from '../life-ready.config';\nimport { PasswordService } from '../password/password.service';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class RegisterService {\n  constructor(\n    @Inject(LR_CONFIG) private config: LifeReadyConfig,\n    private auth: AuthClass,\n    private http: HttpClient,\n    private keyFactory: KeyFactoryService,\n    private encryptionService: EncryptionService,\n    private passwordService: PasswordService\n  ) {}\n\n  /**\n   * Request a verification code to be sent out to an email.\n   * @return Info needed to be submitted along with the verification code\n   */\n  public async verifyEmail(email: string): Promise<string> {\n    const { claim_id } = await this.http\n      .post<{ claim_id }>(`${this.config.authUrl}cove/claim/email/`, {\n        address: email,\n        context: 'signup',\n      })\n      .toPromise();\n    return claim_id;\n  }\n\n  public async verifyPhone(phoneNumber: string): Promise<string> {\n    const { claim_id } = await this.http\n      .post<{ claim_id }>(`${this.config.authUrl}cove/claim/sms/`, {\n        address: phoneNumber,\n        context: 'signup',\n      })\n      .toPromise();\n    return claim_id;\n  }\n\n  public async confirmVerificationCode(\n    verificationId: string,\n    verificationCode: string\n  ): Promise<string> {\n    const { token } = await this.http\n      .post<{ token }>(`${this.config.authUrl}cove/respond/`, {\n        claim_id: verificationId,\n        v_code: verificationCode,\n      })\n      .toPromise();\n    return token;\n  }\n\n  public async register(\n    email: string,\n    password: string,\n    verificationId: string,\n    verificationToken: string,\n    verificationType: 'email' | 'phone' = 'email'\n  ): Promise<RegisterResult> {\n    // Generate the key material needed for PassIdp which will be the password used for Cognito.\n    const passKeyBundle = await this.passwordService.createPassKeyBundle(\n      password\n    );\n\n    const masterKey = await this.keyFactory.createKey();\n    const wrappedMasterKey = await this.encryptionService.encrypt(\n      passKeyBundle.passKey,\n      masterKey.toJSON(true)\n    );\n\n    const rootKey = await this.keyFactory.createKey();\n    const wrappedRootKey = await this.encryptionService.encrypt(\n      masterKey,\n      rootKey.toJSON(true)\n    );\n\n    // Encryption PKC key\n    const prk = await this.keyFactory.createPkcKey();\n    const wrappedPrk = await this.encryptionService.encrypt(\n      rootKey,\n      prk.toJSON(true)\n    );\n\n    // Signing PKC key\n    const sigPrk = await this.keyFactory.createPkcSignKey();\n    const wrappedSigPrk = await this.encryptionService.encrypt(\n      rootKey,\n      sigPrk.toJSON(true)\n    );\n\n    // API call to setup profile\n    const user = await this.http\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      .post<any>(`${this.config.authUrl}users/`, {\n        claims: [\n          {\n            type: verificationType,\n            token: verificationToken,\n            claim_id: verificationId,\n          },\n        ],\n        pass_idp_params: passKeyBundle.passIdpParams,\n        pass_idp_verifier_pbk: passKeyBundle.passIdpVerifier.toJSON(),\n        wrapped_pass_idp_verifier_prk: passKeyBundle.wrappedPassIdpVerifierPrk,\n        pass_key_params: passKeyBundle.passKeyParams,\n        wrapped_master_key: wrappedMasterKey,\n        wrapped_root_key: wrappedRootKey,\n        pbk: prk.toJSON(), // public encryption key\n        wrapped_prk: wrappedPrk,\n        sig_pbk: sigPrk.toJSON(), // public signing key\n        wrapped_sig_prk: wrappedSigPrk,\n      })\n      .toPromise();\n\n    // API call to create user on cognito\n    const attributes = {};\n    user.claims.forEach((claim) => {\n      attributes[claim.type] = claim.value;\n    });\n\n    // Random suffix for uniqueness. If there's a duplicate, then used just needs to\n    // sign up again. But chances of collision is low.\n    const suffix = this.keyFactory.randomDigitsNoZeros(4);\n\n    const cognitoUser = await this.auth.signUp({\n      username: `${email.split('@')[0]}.${suffix}`,\n      password: this.passwordService.getPassIdpString(passKeyBundle.passIdp),\n      attributes,\n      // Unfortunately, validationData is not passed to the post\n      // confirmation cognito trigger. So can can't do the association there.\n      // The current workflow will create a new user on LR before signing up\n      // with Cognito. Then Cognito can use the user.id and user.pre_sign_up_token to\n      // do the validation of the attributes.\n      // validationData: [\n      //   new CognitoUserAttribute({\n      //     Name: \"user_id\",\n      //     Value: String(user.id)\n      //   }),\n      //   new CognitoUserAttribute({\n      //     Name: \"user_pre_sign_up_token\",\n      //     Value: user.pre_sign_up_token\n      //   })\n      // ]\n      clientMetadata: {\n        user_id: String(user.id),\n        user_pre_sign_up_token: String(user.pre_sign_up_token),\n      },\n    });\n\n    return {\n      username: cognitoUser.user.getUsername(),\n      userId: user.id,\n      preSignUpToken: user.pre_sign_up_token,\n      userSub: cognitoUser.userSub,\n    };\n  }\n\n  public async hibpBreachedAccounts(account: string) {\n    // The account is just the email\n    try {\n      const response = await this.http\n        .get<JSONObject>(\n          `${this.config.authUrl}users/hibp/breachedaccount/${account}/?truncateResponse=false`\n        )\n        .toPromise();\n      return response;\n    } catch (error) {\n      if (error.status === 404) {\n        return null;\n      } else {\n        throw error;\n      }\n    }\n  }\n}\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export const SCENARIO_SLIP39_PASSPHRASE = 'lifeready';
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NlbmFyaW8uY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9zcmMvbGliL3NjZW5hcmlvL3NjZW5hcmlvLmNvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSwwQkFBMEIsR0FBRyxXQUFXLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgU0NFTkFSSU9fU0xJUDM5X1BBU1NQSFJBU0UgPSAnbGlmZXJlYWR5JztcbiJdfQ==
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
2
|
import { Injectable, Injector, NgZone } from '@angular/core';
|
|
3
|
-
import { TpAssemblyController } from '../
|
|
3
|
+
import { TpAssemblyController } from '../tp-assembly/tp-assembly';
|
|
4
4
|
import { RunOutsideAngular } from '../_common/run-outside-angular';
|
|
5
5
|
import { SCENARIO_SLIP39_PASSPHRASE } from './scenario.constants';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
@@ -31,4 +31,4 @@ ScenarioAssemblyController = __decorate([
|
|
|
31
31
|
})
|
|
32
32
|
], ScenarioAssemblyController);
|
|
33
33
|
export { ScenarioAssemblyController };
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NlbmFyaW8uY29udHJvbGxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi9zY2VuYXJpby9zY2VuYXJpby5jb250cm9sbGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFN0QsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDbkUsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7O0lBUXJELDBCQUEwQixTQUExQiwwQkFBMkIsU0FBUSxvQkFBb0I7SUFHbEUsWUFBb0IsTUFBYyxFQUFVLFFBQWtCO1FBQzVELEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQztRQURFLFdBQU0sR0FBTixNQUFNLENBQVE7UUFBVSxhQUFRLEdBQVIsUUFBUSxDQUFVO1FBRjlELHFCQUFnQixHQUFHLDBCQUEwQixDQUFDO0lBSTlDLENBQUM7SUFFRCxrQkFBa0IsQ0FBQyxFQUFVO1FBQzNCLE9BQU8sRUFBRSxDQUFDLG9CQUFvQixDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsRUFBRSxDQUFDO0lBQzVELENBQUM7Q0FDRixDQUFBOzs7WUFiQSxVQUFVLFNBQUM7Z0JBQ1YsVUFBVSxFQUFFLE1BQU07YUFDbkI7OztZQVg4QixNQUFNO1lBQWhCLFFBQVE7O0FBWWhCLDBCQUEwQjtJQU50QyxpQkFBaUIsQ0FBQztRQUNqQixVQUFVLEVBQUUsUUFBUTtLQUNyQixDQUFDO0dBSVcsMEJBQTBCLENBVXRDO1NBVlksMEJBQTBCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgSW5qZWN0b3IsIE5nWm9uZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVHBOb2RlIH0gZnJvbSAnLi4vYXBpL3R5cGVzJztcbmltcG9ydCB7IFRwQXNzZW1ibHlDb250cm9sbGVyIH0gZnJvbSAnLi4vdHAtYXNzZW1ibHkvdHAtYXNzZW1ibHknO1xuaW1wb3J0IHsgUnVuT3V0c2lkZUFuZ3VsYXIgfSBmcm9tICcuLi9fY29tbW9uL3J1bi1vdXRzaWRlLWFuZ3VsYXInO1xuaW1wb3J0IHsgU0NFTkFSSU9fU0xJUDM5X1BBU1NQSFJBU0UgfSBmcm9tICcuL3NjZW5hcmlvLmNvbnN0YW50cyc7XG5cbkBSdW5PdXRzaWRlQW5ndWxhcih7XG4gIG5nWm9uZU5hbWU6ICduZ1pvbmUnLFxufSlcbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBTY2VuYXJpb0Fzc2VtYmx5Q29udHJvbGxlciBleHRlbmRzIFRwQXNzZW1ibHlDb250cm9sbGVyIHtcbiAgc2xpcDM5UGFzc3BocmFzZSA9IFNDRU5BUklPX1NMSVAzOV9QQVNTUEhSQVNFO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgbmdab25lOiBOZ1pvbmUsIHByaXZhdGUgaW5qZWN0b3I6IEluamVjdG9yKSB7XG4gICAgc3VwZXIoaW5qZWN0b3IpO1xuICB9XG5cbiAgZ2V0VHBXcmFwcGluZ0tleUlkKHRwOiBUcE5vZGUpIHtcbiAgICByZXR1cm4gdHAuY3VycmVudFVzZXJTaGFyZWRLZXkudXNlclNoYXJlZEtleS5zaGFyZWRLZXkuaWQ7XG4gIH1cbn1cbiJdfQ==
|