@lifeready/core 6.0.5 → 6.1.2

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.
Files changed (101) hide show
  1. package/bundles/lifeready-core.umd.js +3485 -7369
  2. package/bundles/lifeready-core.umd.js.map +1 -1
  3. package/bundles/lifeready-core.umd.min.js +1 -1
  4. package/bundles/lifeready-core.umd.min.js.map +1 -1
  5. package/esm2015/lib/auth2/auth.config.js +57 -0
  6. package/esm2015/lib/auth2/auth2.gql.private.js +8 -1
  7. package/esm2015/lib/auth2/auth2.service.js +3 -4
  8. package/esm2015/lib/auth2/auth2.types.js +1 -1
  9. package/esm2015/lib/encryption/encryption.service.js +7 -6
  10. package/esm2015/lib/file-upload/file-upload.service.js +4 -4
  11. package/esm2015/lib/idle/idle.service.js +1 -2
  12. package/esm2015/lib/item2/item2.service.js +17 -46
  13. package/esm2015/lib/key/key-graph.service.js +3 -3
  14. package/esm2015/lib/key/key-meta.service.js +16 -64
  15. package/esm2015/lib/key/key.types.js +6 -1
  16. package/esm2015/lib/key-exchange/key-exchange2.service.js +6 -25
  17. package/esm2015/lib/life-ready.module.js +2 -9
  18. package/esm2015/lib/password/password.service.js +1 -1
  19. package/esm2015/lib/profile/profile-details.service.js +120 -75
  20. package/esm2015/lib/profile/profile.gql.js +134 -1
  21. package/esm2015/lib/profile/profile.service.js +8 -5
  22. package/esm2015/lib/profile/profile.types.js +14 -3
  23. package/esm2015/lib/shared-contact-card/shared-contact-card.service.js +2 -2
  24. package/esm2015/lib/tp-password-reset/tp-password-reset.types.js +1 -1
  25. package/esm2015/lib/trusted-party/trusted-party2.service.js +3 -7
  26. package/esm2015/lifeready-core.js +7 -9
  27. package/esm2015/public-api.js +2 -20
  28. package/fesm2015/lifeready-core.js +3223 -6588
  29. package/fesm2015/lifeready-core.js.map +1 -1
  30. package/lib/auth2/auth2.gql.private.d.ts +15 -2
  31. package/lib/auth2/auth2.service.d.ts +1 -1
  32. package/lib/auth2/auth2.types.d.ts +19 -2
  33. package/lib/file-upload/file-upload.service.d.ts +2 -2
  34. package/lib/item2/item2.service.d.ts +12 -75
  35. package/lib/key/key-meta.service.d.ts +8 -1
  36. package/lib/key/key.types.d.ts +4 -1
  37. package/lib/key-exchange/key-exchange2.service.d.ts +5 -66
  38. package/lib/password/password.service.d.ts +1 -1
  39. package/lib/profile/profile-details.service.d.ts +10 -11
  40. package/lib/profile/profile.gql.d.ts +12 -0
  41. package/lib/profile/profile.service.d.ts +1 -3
  42. package/lib/profile/profile.types.d.ts +31 -4
  43. package/lib/shared-contact-card/shared-contact-card.service.d.ts +1 -2
  44. package/lib/tp-password-reset/tp-password-reset.types.d.ts +3 -3
  45. package/lib/trusted-party/trusted-party2.service.d.ts +2 -7
  46. package/lifeready-core.d.ts +6 -8
  47. package/lifeready-core.metadata.json +1 -1
  48. package/package.json +1 -1
  49. package/public-api.d.ts +1 -19
  50. package/esm2015/lib/auth/auth.config.js +0 -57
  51. package/esm2015/lib/auth/auth.gql.js +0 -16
  52. package/esm2015/lib/auth/auth.types.js +0 -18
  53. package/esm2015/lib/auth/life-ready-auth.service.js +0 -568
  54. package/esm2015/lib/category/category-meta.service.js +0 -99
  55. package/esm2015/lib/category/category.gql.js +0 -385
  56. package/esm2015/lib/category/category.service.js +0 -361
  57. package/esm2015/lib/category/category.types.js +0 -29
  58. package/esm2015/lib/key-exchange/key-exchange.gql.js +0 -188
  59. package/esm2015/lib/key-exchange/key-exchange.service.js +0 -436
  60. package/esm2015/lib/key-exchange/key-exchange.types.js +0 -7
  61. package/esm2015/lib/message/message.gql.js +0 -32
  62. package/esm2015/lib/message/message.service.js +0 -118
  63. package/esm2015/lib/message/message.types.js +0 -2
  64. package/esm2015/lib/plan/plan.gql.js +0 -123
  65. package/esm2015/lib/plan/plan.service.js +0 -150
  66. package/esm2015/lib/plan/plan.types.js +0 -11
  67. package/esm2015/lib/record/record-attachment.service.js +0 -102
  68. package/esm2015/lib/record/record.gql.js +0 -182
  69. package/esm2015/lib/record/record.service.js +0 -194
  70. package/esm2015/lib/record/record.types.js +0 -15
  71. package/esm2015/lib/record-type/record-type.service.js +0 -75
  72. package/esm2015/lib/record-type/record-type.types.js +0 -28
  73. package/esm2015/lib/trusted-party/trusted-party.gql.js +0 -148
  74. package/esm2015/lib/trusted-party/trusted-party.service.js +0 -308
  75. package/esm2015/lib/trusted-party/trusted-party.types.js +0 -41
  76. package/lib/auth/auth.gql.d.ts +0 -12
  77. package/lib/auth/auth.types.d.ts +0 -52
  78. package/lib/auth/life-ready-auth.service.d.ts +0 -73
  79. package/lib/category/category-meta.service.d.ts +0 -23
  80. package/lib/category/category.gql.d.ts +0 -44
  81. package/lib/category/category.service.d.ts +0 -66
  82. package/lib/category/category.types.d.ts +0 -75
  83. package/lib/key-exchange/key-exchange.gql.d.ts +0 -9
  84. package/lib/key-exchange/key-exchange.service.d.ts +0 -37
  85. package/lib/key-exchange/key-exchange.types.d.ts +0 -188
  86. package/lib/message/message.gql.d.ts +0 -13
  87. package/lib/message/message.service.d.ts +0 -36
  88. package/lib/message/message.types.d.ts +0 -12
  89. package/lib/plan/plan.gql.d.ts +0 -11
  90. package/lib/plan/plan.service.d.ts +0 -34
  91. package/lib/plan/plan.types.d.ts +0 -32
  92. package/lib/record/record-attachment.service.d.ts +0 -16
  93. package/lib/record/record.gql.d.ts +0 -14
  94. package/lib/record/record.service.d.ts +0 -25
  95. package/lib/record/record.types.d.ts +0 -56
  96. package/lib/record-type/record-type.service.d.ts +0 -11
  97. package/lib/record-type/record-type.types.d.ts +0 -50
  98. package/lib/trusted-party/trusted-party.gql.d.ts +0 -9
  99. package/lib/trusted-party/trusted-party.service.d.ts +0 -43
  100. package/lib/trusted-party/trusted-party.types.d.ts +0 -101
  101. /package/lib/{auth → auth2}/auth.config.d.ts +0 -0
@@ -1,118 +0,0 @@
1
- import { __awaiter, __decorate } from "tslib";
2
- import { Injectable, Injector, NgZone } from '@angular/core';
3
- import { LrMutation, LrService } from '../api/lr-graphql';
4
- import { EncryptionService } from '../encryption/encryption.service';
5
- import { KeyExchangeService } from '../key-exchange/key-exchange.service';
6
- import { KeyGraphService } from '../key/key-graph.service';
7
- import { RunOutsideAngular } from '../_common/run-outside-angular';
8
- import { MessageQuery, SendMessageMutation } from './message.gql';
9
- import * as i0 from "@angular/core";
10
- import * as i1 from "../key/key-graph.service";
11
- import * as i2 from "../encryption/encryption.service";
12
- import * as i3 from "../key-exchange/key-exchange.service";
13
- let MessageService = class MessageService extends LrService {
14
- constructor(ngZone, injector, keyGraph, encryptionService, keyExchangeService) {
15
- super(injector);
16
- this.ngZone = ngZone;
17
- this.injector = injector;
18
- this.keyGraph = keyGraph;
19
- this.encryptionService = encryptionService;
20
- this.keyExchangeService = keyExchangeService;
21
- this.encrypt = this.encryptionService.encrypt.bind(this.encryptionService);
22
- this.decrypt = this.encryptionService.decrypt.bind(this.encryptionService);
23
- this.sign = this.encryptionService.sign.bind(this.encryptionService);
24
- this.verify = this.encryptionService.verify.bind(this.encryptionService);
25
- }
26
- sendMessage(input) {
27
- return __awaiter(this, void 0, void 0, function* () {
28
- return this.mutate(this.sendMessageMutation(input));
29
- });
30
- }
31
- sendMessageMutation({ username, userId, plainMessageJson, plainCipherMessageJson, }) {
32
- return __awaiter(this, void 0, void 0, function* () {
33
- const userSharedKey = yield this.keyExchangeService.currentUserSharedKey({
34
- username,
35
- userId,
36
- });
37
- let signedCipherMessage;
38
- if (plainCipherMessageJson) {
39
- const sharedKey = yield this.keyGraph.getJwkKey(userSharedKey.sharedKey.id);
40
- const cipherMessage = yield this.encrypt(sharedKey, plainCipherMessageJson);
41
- const senderSigPrk = yield this.keyGraph.getJwkKey(userSharedKey.userSigPrk.id);
42
- signedCipherMessage = JSON.stringify(yield this.sign(senderSigPrk, cipherMessage));
43
- }
44
- let plainMessage;
45
- if (plainMessageJson) {
46
- plainMessage = JSON.stringify(plainMessageJson);
47
- }
48
- return new LrMutation({
49
- mutation: SendMessageMutation,
50
- variables: {
51
- input: {
52
- receiverUsername: username,
53
- receiverId: userId,
54
- sharedKeyId: userSharedKey.sharedKey.id,
55
- senderSigPbkId: userSharedKey.userSigPrk.id,
56
- signedCipherMessage,
57
- plainMessage,
58
- },
59
- },
60
- });
61
- });
62
- }
63
- decryptMessage(message, options) {
64
- return __awaiter(this, void 0, void 0, function* () {
65
- const signedCipherMessage = yield this.verify(options.senderSigPbk, JSON.parse(message.signedCipherMessage));
66
- message.signedCipherMessageClearJson = yield this.decrypt(options.sharedKey, signedCipherMessage);
67
- });
68
- }
69
- getMessage(id) {
70
- return __awaiter(this, void 0, void 0, function* () {
71
- const res = yield this.query({
72
- query: MessageQuery,
73
- variables: {
74
- id,
75
- },
76
- });
77
- // this.keyGraph.addKeys(res.keyGraph);
78
- const message = res.message;
79
- const sharedKey = yield this.keyGraph.getJwkKey(message.sharedKey.id);
80
- // The sender would be getting the Prk back. The receiver gets the Pbk back.
81
- // But only the Pbk is needed here to verify signature.
82
- // So both sender and receiver can access this message.
83
- const senderSigPbk = yield this.keyGraph.getJwkKey(message.senderSigPbk.id);
84
- // Test bad signature
85
- // senderSigPbk = senderSigPbk.toJSON();
86
- // senderSigPbk.n = "x" + senderSigPbk.n.substring(1);
87
- // senderSigPbk = await KFS.asKey(senderSigPbk);
88
- yield this.decryptMessage(message, {
89
- sharedKey,
90
- senderSigPbk,
91
- });
92
- if (message.plainMessage) {
93
- message.plainMessageJson = JSON.parse(message.plainMessage);
94
- }
95
- return res.message;
96
- });
97
- }
98
- };
99
- MessageService.ɵprov = i0.ɵɵdefineInjectable({ factory: function MessageService_Factory() { return new MessageService(i0.ɵɵinject(i0.NgZone), i0.ɵɵinject(i0.INJECTOR), i0.ɵɵinject(i1.KeyGraphService), i0.ɵɵinject(i2.EncryptionService), i0.ɵɵinject(i3.KeyExchangeService)); }, token: MessageService, providedIn: "root" });
100
- MessageService.decorators = [
101
- { type: Injectable, args: [{
102
- providedIn: 'root',
103
- },] }
104
- ];
105
- MessageService.ctorParameters = () => [
106
- { type: NgZone },
107
- { type: Injector },
108
- { type: KeyGraphService },
109
- { type: EncryptionService },
110
- { type: KeyExchangeService }
111
- ];
112
- MessageService = __decorate([
113
- RunOutsideAngular({
114
- ngZoneName: 'ngZone',
115
- })
116
- ], MessageService);
117
- export { MessageService };
118
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"message.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/message/message.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Injector, NgZone } from '@angular/core';\nimport { JWK } from 'node-jose';\nimport { LrMutation, LrService } from '../api/lr-graphql';\nimport { MessageNode } from '../api/types';\nimport { EncryptionService } from '../encryption/encryption.service';\nimport { KeyExchangeService } from '../key-exchange/key-exchange.service';\nimport { KeyGraphService } from '../key/key-graph.service';\nimport { RunOutsideAngular } from '../_common/run-outside-angular';\nimport { MessageQuery, SendMessageMutation } from './message.gql';\nimport { SendMessageInput } from './message.types';\n\n@RunOutsideAngular({\n  ngZoneName: 'ngZone',\n})\n@Injectable({\n  providedIn: 'root',\n})\nexport class MessageService extends LrService {\n  private readonly encrypt = this.encryptionService.encrypt.bind(\n    this.encryptionService\n  );\n  private readonly decrypt = this.encryptionService.decrypt.bind(\n    this.encryptionService\n  );\n  private readonly sign = this.encryptionService.sign.bind(\n    this.encryptionService\n  );\n  private readonly verify = this.encryptionService.verify.bind(\n    this.encryptionService\n  );\n\n  constructor(\n    private ngZone: NgZone,\n    private injector: Injector,\n    private keyGraph: KeyGraphService,\n    private encryptionService: EncryptionService,\n    private keyExchangeService: KeyExchangeService\n  ) {\n    super(injector);\n  }\n\n  async sendMessage(input: SendMessageInput) {\n    return this.mutate(this.sendMessageMutation(input));\n  }\n\n  async sendMessageMutation({\n    username,\n    userId,\n    plainMessageJson,\n    plainCipherMessageJson,\n  }: SendMessageInput) {\n    const userSharedKey = await this.keyExchangeService.currentUserSharedKey({\n      username,\n      userId,\n    });\n\n    let signedCipherMessage: string;\n    if (plainCipherMessageJson) {\n      const sharedKey = await this.keyGraph.getJwkKey(\n        userSharedKey.sharedKey.id\n      );\n      const cipherMessage = await this.encrypt(\n        sharedKey,\n        plainCipherMessageJson\n      );\n\n      const senderSigPrk = await this.keyGraph.getJwkKey(\n        userSharedKey.userSigPrk.id\n      );\n\n      signedCipherMessage = JSON.stringify(\n        await this.sign(senderSigPrk, cipherMessage)\n      );\n    }\n\n    let plainMessage: string;\n    if (plainMessageJson) {\n      plainMessage = JSON.stringify(plainMessageJson);\n    }\n\n    return new LrMutation({\n      mutation: SendMessageMutation,\n      variables: {\n        input: {\n          receiverUsername: username,\n          receiverId: userId,\n          sharedKeyId: userSharedKey.sharedKey.id,\n          senderSigPbkId: userSharedKey.userSigPrk.id,\n          signedCipherMessage,\n          plainMessage,\n        },\n      },\n    });\n  }\n\n  async decryptMessage(\n    message: MessageNode,\n    options: { sharedKey: JWK.Key; senderSigPbk: JWK.Key }\n  ): Promise<void> {\n    const signedCipherMessage = await this.verify(\n      options.senderSigPbk,\n      JSON.parse(message.signedCipherMessage)\n    );\n\n    message.signedCipherMessageClearJson = await this.decrypt(\n      options.sharedKey,\n      signedCipherMessage\n    );\n  }\n\n  async getMessage(id: string) {\n    const res = await this.query({\n      query: MessageQuery,\n      variables: {\n        id,\n      },\n    });\n\n    // this.keyGraph.addKeys(res.keyGraph);\n\n    const message = res.message;\n\n    const sharedKey = await this.keyGraph.getJwkKey(message.sharedKey.id);\n\n    // The sender would be getting the Prk back. The receiver gets the Pbk back.\n    // But only the Pbk is needed here to verify signature.\n    // So both sender and receiver can access this message.\n    const senderSigPbk = await this.keyGraph.getJwkKey(message.senderSigPbk.id);\n\n    // Test bad signature\n    // senderSigPbk = senderSigPbk.toJSON();\n    // senderSigPbk.n = \"x\" + senderSigPbk.n.substring(1);\n    // senderSigPbk = await KFS.asKey(senderSigPbk);\n\n    await this.decryptMessage(message, {\n      sharedKey,\n      senderSigPbk,\n    });\n\n    if (message.plainMessage) {\n      message.plainMessageJson = JSON.parse(message.plainMessage);\n    }\n\n    return res.message;\n  }\n}\n"]}
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVzc2FnZS50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi9tZXNzYWdlL21lc3NhZ2UudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEpXSyB9IGZyb20gJ25vZGUtam9zZSc7XG5pbXBvcnQgeyBKU09OT2JqZWN0IH0gZnJvbSAnLi4vYXBpL3R5cGVzJztcblxuZXhwb3J0IGludGVyZmFjZSBTZW5kTWVzc2FnZUlucHV0IHtcbiAgdXNlcm5hbWU/OiBzdHJpbmc7XG4gIHVzZXJJZD86IHN0cmluZztcbiAgcGxhaW5NZXNzYWdlSnNvbj86IEpTT05PYmplY3Q7XG4gIHBsYWluQ2lwaGVyTWVzc2FnZUpzb24/OiBKU09OT2JqZWN0O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERlY3J5cHRNZXNzYWdlT3B0aW9ucyB7XG4gIHNoYXJlZEtleTogSldLLktleTtcbiAgc2VuZGVyU2lnUGJrOiBKV0suS2V5O1xufVxuIl19
@@ -1,123 +0,0 @@
1
- import gql from 'graphql-tag';
2
- export const CreateStripeCheckoutSessionMutation = gql `
3
- mutation CreateStripeCheckoutSession(
4
- $priceId: String!
5
- $successUrl: String!
6
- $cancelUrl: String!
7
- ) {
8
- createStripeCheckoutSession(
9
- input: {
10
- priceId: $priceId
11
- successUrl: $successUrl
12
- cancelUrl: $cancelUrl
13
- }
14
- ) {
15
- sessionId
16
- }
17
- }
18
- `;
19
- export const CreateStripeBillingPortalSessionMutation = gql `
20
- mutation CreateStripeBillingPortalSession($returnUrl: String!) {
21
- createStripeBillingPortalSession(input: { returnUrl: $returnUrl }) {
22
- sessionUrl
23
- }
24
- }
25
- `;
26
- export const planFields = `
27
- name
28
- data
29
- state
30
- `;
31
- export const CreateUserIssuedPlanMutation = gql `
32
- mutation CreateUserIssuedPlan($input: CreateUserIssuedPlanInput!){
33
- createUserIssuedPlan(input: $input) {
34
- userIssuedPlan {
35
- id
36
- plan {
37
- ${planFields}
38
- }
39
- token
40
- tokenExpiryTime
41
- planPeriodEnd
42
- planPeriodEndAfterSeconds
43
- }
44
- }
45
- }`;
46
- export const DeleteUserIssuedPlanMutation = gql `
47
- mutation DeleteUserIssuedPlan($input: DeleteUserIssuedPlanInput!) {
48
- deleteUserIssuedPlan(input: $input) {
49
- id
50
- }
51
- }
52
- `;
53
- export const UserIssuablePlansQuery = gql `
54
- query UserIssuablePlans {
55
- userIssuablePlans {
56
- plan {
57
- ${planFields}
58
- }
59
- }
60
- }
61
- `;
62
- // Put other fields in as needed.
63
- export const UserIssuedPlansQuery = gql `
64
- query UserIssuedPlans {
65
- userIssuedPlans {
66
- edges {
67
- node {
68
- id
69
- }
70
- }
71
- }
72
- }
73
- `;
74
- export const UserIssuedPlanQuery = gql `
75
- query UserIssuedPlan(
76
- $id: LrRelayIdInput!
77
- $token: String
78
- ) {
79
- userIssuedPlan(
80
- id: $id
81
- token: $token
82
- ) {
83
- id
84
- plan {
85
- ${planFields}
86
- }
87
- planPeriodEnd
88
- planPeriodEndAfterSeconds
89
- }
90
- }
91
- `;
92
- export const AssociateUserIssuedPlanMutation = gql `
93
- mutation AssociateUserIssuedPlan($input: AssociateUserIssuedPlanInput!){
94
- associateUserIssuedPlan(input: $input) {
95
- userPlan {
96
- id
97
- plan {
98
- ${planFields}
99
- }
100
- periodEnd
101
- }
102
- }
103
- }`;
104
- export const UserPlansQuery = gql `
105
- query UserPlans {
106
- userPlans {
107
- id
108
- periodEnd
109
- plan {
110
- ${planFields}
111
- }
112
- }
113
- }
114
- `;
115
- export const StripeQuery = gql `
116
- query Stripe {
117
- stripe {
118
- id
119
- customer
120
- }
121
- }
122
- `;
123
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGxhbi5ncWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3NyYy9saWIvcGxhbi9wbGFuLmdxbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEdBQUcsTUFBTSxhQUFhLENBQUM7QUFFOUIsTUFBTSxDQUFDLE1BQU0sbUNBQW1DLEdBQUcsR0FBRyxDQUFBOzs7Ozs7Ozs7Ozs7Ozs7O0NBZ0JyRCxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sd0NBQXdDLEdBQUcsR0FBRyxDQUFBOzs7Ozs7Q0FNMUQsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLFVBQVUsR0FBRzs7OztDQUl6QixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sNEJBQTRCLEdBQUcsR0FBRyxDQUFBOzs7Ozs7VUFNckMsVUFBVTs7Ozs7Ozs7RUFRbEIsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLDRCQUE0QixHQUFHLEdBQUcsQ0FBQTs7Ozs7O0NBTTlDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxzQkFBc0IsR0FBRyxHQUFHLENBQUE7Ozs7UUFJakMsVUFBVTs7OztDQUlqQixDQUFDO0FBRUYsaUNBQWlDO0FBQ2pDLE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFHLEdBQUcsQ0FBQTs7Ozs7Ozs7OztDQVV0QyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQUcsR0FBRyxDQUFBOzs7Ozs7Ozs7OztRQVc5QixVQUFVOzs7Ozs7Q0FNakIsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLCtCQUErQixHQUFHLEdBQUcsQ0FBQTs7Ozs7O1VBTXhDLFVBQVU7Ozs7O0VBS2xCLENBQUM7QUFFSCxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsR0FBRyxDQUFBOzs7Ozs7UUFNekIsVUFBVTs7OztDQUlqQixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFHLEdBQUcsQ0FBQTs7Ozs7OztDQU83QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGdxbCBmcm9tICdncmFwaHFsLXRhZyc7XG5cbmV4cG9ydCBjb25zdCBDcmVhdGVTdHJpcGVDaGVja291dFNlc3Npb25NdXRhdGlvbiA9IGdxbGBcbiAgbXV0YXRpb24gQ3JlYXRlU3RyaXBlQ2hlY2tvdXRTZXNzaW9uKFxuICAgICRwcmljZUlkOiBTdHJpbmchXG4gICAgJHN1Y2Nlc3NVcmw6IFN0cmluZyFcbiAgICAkY2FuY2VsVXJsOiBTdHJpbmchXG4gICkge1xuICAgIGNyZWF0ZVN0cmlwZUNoZWNrb3V0U2Vzc2lvbihcbiAgICAgIGlucHV0OiB7XG4gICAgICAgIHByaWNlSWQ6ICRwcmljZUlkXG4gICAgICAgIHN1Y2Nlc3NVcmw6ICRzdWNjZXNzVXJsXG4gICAgICAgIGNhbmNlbFVybDogJGNhbmNlbFVybFxuICAgICAgfVxuICAgICkge1xuICAgICAgc2Vzc2lvbklkXG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgQ3JlYXRlU3RyaXBlQmlsbGluZ1BvcnRhbFNlc3Npb25NdXRhdGlvbiA9IGdxbGBcbiAgbXV0YXRpb24gQ3JlYXRlU3RyaXBlQmlsbGluZ1BvcnRhbFNlc3Npb24oJHJldHVyblVybDogU3RyaW5nISkge1xuICAgIGNyZWF0ZVN0cmlwZUJpbGxpbmdQb3J0YWxTZXNzaW9uKGlucHV0OiB7IHJldHVyblVybDogJHJldHVyblVybCB9KSB7XG4gICAgICBzZXNzaW9uVXJsXG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgcGxhbkZpZWxkcyA9IGBcbiAgbmFtZVxuICBkYXRhXG4gIHN0YXRlXG5gO1xuXG5leHBvcnQgY29uc3QgQ3JlYXRlVXNlcklzc3VlZFBsYW5NdXRhdGlvbiA9IGdxbGBcbm11dGF0aW9uIENyZWF0ZVVzZXJJc3N1ZWRQbGFuKCRpbnB1dDogQ3JlYXRlVXNlcklzc3VlZFBsYW5JbnB1dCEpe1xuICBjcmVhdGVVc2VySXNzdWVkUGxhbihpbnB1dDogJGlucHV0KSB7XG4gICAgdXNlcklzc3VlZFBsYW4ge1xuICAgICAgaWRcbiAgICAgIHBsYW4ge1xuICAgICAgICAke3BsYW5GaWVsZHN9XG4gICAgICB9XG4gICAgICB0b2tlblxuICAgICAgdG9rZW5FeHBpcnlUaW1lXG4gICAgICBwbGFuUGVyaW9kRW5kXG4gICAgICBwbGFuUGVyaW9kRW5kQWZ0ZXJTZWNvbmRzXG4gICAgfVxuICB9XG59YDtcblxuZXhwb3J0IGNvbnN0IERlbGV0ZVVzZXJJc3N1ZWRQbGFuTXV0YXRpb24gPSBncWxgXG4gIG11dGF0aW9uIERlbGV0ZVVzZXJJc3N1ZWRQbGFuKCRpbnB1dDogRGVsZXRlVXNlcklzc3VlZFBsYW5JbnB1dCEpIHtcbiAgICBkZWxldGVVc2VySXNzdWVkUGxhbihpbnB1dDogJGlucHV0KSB7XG4gICAgICBpZFxuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFVzZXJJc3N1YWJsZVBsYW5zUXVlcnkgPSBncWxgXG5xdWVyeSBVc2VySXNzdWFibGVQbGFucyB7XG4gIHVzZXJJc3N1YWJsZVBsYW5zIHtcbiAgICBwbGFuIHtcbiAgICAgICR7cGxhbkZpZWxkc31cbiAgICB9XG4gIH1cbn1cbmA7XG5cbi8vIFB1dCBvdGhlciBmaWVsZHMgaW4gYXMgbmVlZGVkLlxuZXhwb3J0IGNvbnN0IFVzZXJJc3N1ZWRQbGFuc1F1ZXJ5ID0gZ3FsYFxuICBxdWVyeSBVc2VySXNzdWVkUGxhbnMge1xuICAgIHVzZXJJc3N1ZWRQbGFucyB7XG4gICAgICBlZGdlcyB7XG4gICAgICAgIG5vZGUge1xuICAgICAgICAgIGlkXG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBVc2VySXNzdWVkUGxhblF1ZXJ5ID0gZ3FsYFxucXVlcnkgVXNlcklzc3VlZFBsYW4oXG4gICRpZDogTHJSZWxheUlkSW5wdXQhXG4gICR0b2tlbjogU3RyaW5nXG4pIHtcbiAgdXNlcklzc3VlZFBsYW4oXG4gICAgaWQ6ICRpZFxuICAgIHRva2VuOiAkdG9rZW5cbiAgKSB7XG4gICAgaWRcbiAgICBwbGFuIHtcbiAgICAgICR7cGxhbkZpZWxkc31cbiAgICB9XG4gICAgcGxhblBlcmlvZEVuZFxuICAgIHBsYW5QZXJpb2RFbmRBZnRlclNlY29uZHNcbiAgfVxufVxuYDtcblxuZXhwb3J0IGNvbnN0IEFzc29jaWF0ZVVzZXJJc3N1ZWRQbGFuTXV0YXRpb24gPSBncWxgXG5tdXRhdGlvbiBBc3NvY2lhdGVVc2VySXNzdWVkUGxhbigkaW5wdXQ6IEFzc29jaWF0ZVVzZXJJc3N1ZWRQbGFuSW5wdXQhKXtcbiAgYXNzb2NpYXRlVXNlcklzc3VlZFBsYW4oaW5wdXQ6ICRpbnB1dCkge1xuICAgIHVzZXJQbGFuIHtcbiAgICAgIGlkXG4gICAgICBwbGFuIHtcbiAgICAgICAgJHtwbGFuRmllbGRzfVxuICAgICAgfVxuICAgICAgcGVyaW9kRW5kXG4gICAgfVxuICB9XG59YDtcblxuZXhwb3J0IGNvbnN0IFVzZXJQbGFuc1F1ZXJ5ID0gZ3FsYFxucXVlcnkgVXNlclBsYW5zIHtcbiAgdXNlclBsYW5zIHtcbiAgICBpZFxuICAgIHBlcmlvZEVuZFxuICAgIHBsYW4ge1xuICAgICAgJHtwbGFuRmllbGRzfVxuICAgIH1cbiAgfVxufVxuYDtcblxuZXhwb3J0IGNvbnN0IFN0cmlwZVF1ZXJ5ID0gZ3FsYFxuICBxdWVyeSBTdHJpcGUge1xuICAgIHN0cmlwZSB7XG4gICAgICBpZFxuICAgICAgY3VzdG9tZXJcbiAgICB9XG4gIH1cbmA7XG4iXX0=
@@ -1,150 +0,0 @@
1
- import { __awaiter } from "tslib";
2
- /* eslint-disable @typescript-eslint/no-explicit-any */
3
- import { Injectable } from '@angular/core';
4
- import { LrApolloService } from '../api/lr-apollo.service';
5
- import { KcBadArgumentException } from '../_common/exceptions';
6
- import { AssociateUserIssuedPlanMutation, CreateStripeBillingPortalSessionMutation, CreateStripeCheckoutSessionMutation, CreateUserIssuedPlanMutation, DeleteUserIssuedPlanMutation, StripeQuery, UserIssuablePlansQuery, UserIssuedPlanQuery, UserIssuedPlansQuery, UserPlansQuery, } from './plan.gql';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "../api/lr-apollo.service";
9
- export function mapUserPlans(userPlans) {
10
- return userPlans.map((t) => {
11
- var _a;
12
- return (Object.assign(Object.assign({}, t), { periodEnd: t.periodEnd && new Date(t.periodEnd), subscription: { id: (_a = t.stripe) === null || _a === void 0 ? void 0 : _a.subscriptionId } }));
13
- });
14
- }
15
- export class PlanService {
16
- constructor(lrApollo) {
17
- this.lrApollo = lrApollo;
18
- }
19
- createStripeCheckoutSession(input) {
20
- return __awaiter(this, void 0, void 0, function* () {
21
- const res = yield this.lrApollo.mutate({
22
- mutation: CreateStripeCheckoutSessionMutation,
23
- variables: Object.assign({}, input),
24
- });
25
- return {
26
- id: res.createStripeCheckoutSession.sessionId,
27
- };
28
- });
29
- }
30
- createStripeBillingPortalSession(returnUrl) {
31
- return __awaiter(this, void 0, void 0, function* () {
32
- const res = yield this.lrApollo.mutate({
33
- mutation: CreateStripeBillingPortalSessionMutation,
34
- variables: {
35
- returnUrl,
36
- },
37
- });
38
- return {
39
- url: res.createStripeBillingPortalSession.sessionUrl,
40
- };
41
- });
42
- }
43
- getUserIssuablePlans() {
44
- return __awaiter(this, void 0, void 0, function* () {
45
- const { userIssuablePlans } = yield this.lrApollo.query({
46
- query: UserIssuablePlansQuery,
47
- });
48
- return userIssuablePlans;
49
- });
50
- }
51
- createUserIssuedPlan({ planName, tokenExpiryTime, planPeriodEnd, planPeriodEndAfterSeconds, }) {
52
- return __awaiter(this, void 0, void 0, function* () {
53
- if (planPeriodEnd == null && planPeriodEndAfterSeconds == null) {
54
- throw new KcBadArgumentException('Must specify either "planPeriodEnd" or "planPeriodEndAfterSeconds"');
55
- }
56
- const { createUserIssuedPlan } = yield this.lrApollo.mutate({
57
- mutation: CreateUserIssuedPlanMutation,
58
- variables: {
59
- input: {
60
- planName,
61
- tokenExpiryTime: tokenExpiryTime.toISOString(),
62
- planPeriodEnd: planPeriodEnd && planPeriodEnd.toISOString(),
63
- planPeriodEndAfterSeconds,
64
- },
65
- },
66
- });
67
- const { userIssuedPlan } = createUserIssuedPlan;
68
- return Object.assign(Object.assign({}, userIssuedPlan), { tokenExpiryTime: new Date(userIssuedPlan.tokenExpiryTime), planPeriodEnd: new Date(userIssuedPlan.planPeriodEnd) });
69
- });
70
- }
71
- deleteUserIssuedPlan(id) {
72
- return __awaiter(this, void 0, void 0, function* () {
73
- return yield this.lrApollo.mutate({
74
- mutation: DeleteUserIssuedPlanMutation,
75
- variables: {
76
- input: {
77
- id,
78
- },
79
- },
80
- });
81
- });
82
- }
83
- getUserIssuedPlans() {
84
- return __awaiter(this, void 0, void 0, function* () {
85
- const { userIssuedPlans } = yield this.lrApollo.query({
86
- query: UserIssuedPlansQuery,
87
- });
88
- return userIssuedPlans.edges.map((edge) => edge.node);
89
- });
90
- }
91
- getUserIssuedPlan(id, token) {
92
- return __awaiter(this, void 0, void 0, function* () {
93
- const { userIssuedPlan } = yield this.lrApollo.query({
94
- query: UserIssuedPlanQuery,
95
- variables: {
96
- id,
97
- token,
98
- },
99
- });
100
- return userIssuedPlan;
101
- });
102
- }
103
- associateUserIssuedPlan({ id, token, }) {
104
- return __awaiter(this, void 0, void 0, function* () {
105
- const { associateUserIssuedPlan } = yield this.lrApollo.query({
106
- query: AssociateUserIssuedPlanMutation,
107
- variables: {
108
- input: {
109
- id,
110
- token,
111
- },
112
- },
113
- });
114
- const { userPlan } = associateUserIssuedPlan;
115
- return Object.assign(Object.assign({}, userPlan), { periodEnd: new Date(userPlan.periodEnd) });
116
- });
117
- }
118
- getUserPlans() {
119
- return __awaiter(this, void 0, void 0, function* () {
120
- const { userPlans } = yield this.lrApollo.query({
121
- query: UserPlansQuery,
122
- });
123
- return mapUserPlans(userPlans);
124
- });
125
- }
126
- getPlanType(subscriptionId) {
127
- return __awaiter(this, void 0, void 0, function* () {
128
- const stripe = yield this.getStripe();
129
- return stripe.customer.subscriptions.data.filter((sub) => sub.id === subscriptionId)[0].items.data[0].plan.interval;
130
- });
131
- }
132
- getStripe() {
133
- return __awaiter(this, void 0, void 0, function* () {
134
- const { stripe } = yield this.lrApollo.query({
135
- query: StripeQuery,
136
- });
137
- return stripe;
138
- });
139
- }
140
- }
141
- PlanService.ɵprov = i0.ɵɵdefineInjectable({ factory: function PlanService_Factory() { return new PlanService(i0.ɵɵinject(i1.LrApolloService)); }, token: PlanService, providedIn: "root" });
142
- PlanService.decorators = [
143
- { type: Injectable, args: [{
144
- providedIn: 'root',
145
- },] }
146
- ];
147
- PlanService.ctorParameters = () => [
148
- { type: LrApolloService }
149
- ];
150
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"plan.service.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/plan/plan.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 { JSONObject } from '../api/types';\nimport { KcBadArgumentException } from '../_common/exceptions';\nimport {\n  AssociateUserIssuedPlanMutation,\n  CreateStripeBillingPortalSessionMutation,\n  CreateStripeCheckoutSessionMutation,\n  CreateUserIssuedPlanMutation,\n  DeleteUserIssuedPlanMutation,\n  StripeQuery,\n  UserIssuablePlansQuery,\n  UserIssuedPlanQuery,\n  UserIssuedPlansQuery,\n  UserPlansQuery,\n} from './plan.gql';\nimport {\n  StripeBillingPortalSession,\n  StripeCheckoutSession,\n  UserIssuablePlan,\n  UserIssuedPlan,\n  UserPlan,\n} from './plan.types';\n\nexport function mapUserPlans(userPlans: any[]): UserPlan[] {\n  return userPlans.map((t) => ({\n    ...t,\n    periodEnd: t.periodEnd && new Date(t.periodEnd),\n    subscription: { id: t.stripe?.subscriptionId },\n  }));\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class PlanService {\n  constructor(private lrApollo: LrApolloService) {}\n\n  async createStripeCheckoutSession(input: {\n    priceId: string;\n    successUrl: string;\n    cancelUrl: string;\n  }): Promise<StripeCheckoutSession> {\n    const res = await this.lrApollo.mutate<{\n      createStripeCheckoutSession: any;\n    }>({\n      mutation: CreateStripeCheckoutSessionMutation,\n      variables: {\n        ...input,\n      },\n    });\n    return {\n      id: res.createStripeCheckoutSession.sessionId,\n    };\n  }\n\n  async createStripeBillingPortalSession(\n    returnUrl: string\n  ): Promise<StripeBillingPortalSession> {\n    const res = await this.lrApollo.mutate<{\n      createStripeBillingPortalSession: any;\n    }>({\n      mutation: CreateStripeBillingPortalSessionMutation,\n      variables: {\n        returnUrl,\n      },\n    });\n    return {\n      url: res.createStripeBillingPortalSession.sessionUrl,\n    };\n  }\n\n  async getUserIssuablePlans(): Promise<UserIssuablePlan[]> {\n    const { userIssuablePlans } = await this.lrApollo.query<{\n      userIssuablePlans: any;\n    }>({\n      query: UserIssuablePlansQuery,\n    });\n\n    return userIssuablePlans;\n  }\n\n  async createUserIssuedPlan({\n    planName,\n    tokenExpiryTime,\n    planPeriodEnd,\n    planPeriodEndAfterSeconds,\n  }: {\n    planName: string;\n    tokenExpiryTime: Date;\n    planPeriodEnd?: Date;\n    planPeriodEndAfterSeconds?: number;\n  }): Promise<UserIssuedPlan> {\n    if (planPeriodEnd == null && planPeriodEndAfterSeconds == null) {\n      throw new KcBadArgumentException(\n        'Must specify either \"planPeriodEnd\" or \"planPeriodEndAfterSeconds\"'\n      );\n    }\n\n    const { createUserIssuedPlan } = await this.lrApollo.mutate<any>({\n      mutation: CreateUserIssuedPlanMutation,\n      variables: {\n        input: {\n          planName,\n          tokenExpiryTime: tokenExpiryTime.toISOString(),\n          planPeriodEnd: planPeriodEnd && planPeriodEnd.toISOString(),\n          planPeriodEndAfterSeconds,\n        },\n      },\n    });\n\n    const { userIssuedPlan } = createUserIssuedPlan;\n\n    return {\n      ...userIssuedPlan,\n      tokenExpiryTime: new Date(userIssuedPlan.tokenExpiryTime),\n      planPeriodEnd: new Date(userIssuedPlan.planPeriodEnd),\n    };\n  }\n\n  async deleteUserIssuedPlan(id: string): Promise<void> {\n    return await this.lrApollo.mutate<any>({\n      mutation: DeleteUserIssuedPlanMutation,\n      variables: {\n        input: {\n          id,\n        },\n      },\n    });\n  }\n\n  async getUserIssuedPlans(): Promise<any[]> {\n    const { userIssuedPlans } = await this.lrApollo.query<any>({\n      query: UserIssuedPlansQuery,\n    });\n\n    return userIssuedPlans.edges.map((edge) => edge.node);\n  }\n\n  async getUserIssuedPlan(id: string, token?: string): Promise<any> {\n    const { userIssuedPlan } = await this.lrApollo.query<any>({\n      query: UserIssuedPlanQuery,\n      variables: {\n        id,\n        token,\n      },\n    });\n\n    return userIssuedPlan;\n  }\n\n  async associateUserIssuedPlan({\n    id,\n    token,\n  }: {\n    id: string;\n    token: string;\n  }): Promise<UserPlan> {\n    const { associateUserIssuedPlan } = await this.lrApollo.query<any>({\n      query: AssociateUserIssuedPlanMutation,\n      variables: {\n        input: {\n          id,\n          token,\n        },\n      },\n    });\n\n    const { userPlan } = associateUserIssuedPlan;\n\n    return {\n      ...userPlan,\n      periodEnd: new Date(userPlan.periodEnd),\n    };\n  }\n\n  async getUserPlans(): Promise<UserPlan[]> {\n    const { userPlans } = await this.lrApollo.query<any>({\n      query: UserPlansQuery,\n    });\n\n    return mapUserPlans(userPlans);\n  }\n\n  async getPlanType(subscriptionId: string): Promise<string> {\n    const stripe: any = await this.getStripe();\n    return stripe.customer.subscriptions.data.filter(\n      (sub) => sub.id === subscriptionId\n    )[0].items.data[0].plan.interval;\n  }\n\n  async getStripe(): Promise<{\n    id: string;\n    customer: Record<string, JSONObject>;\n  }> {\n    const { stripe } = await this.lrApollo.query<any>({\n      query: StripeQuery,\n    });\n\n    return stripe;\n  }\n}\n"]}
@@ -1,11 +0,0 @@
1
- export class Plan {
2
- }
3
- export class Subscription {
4
- }
5
- export class UserPlan {
6
- }
7
- export class StripeCheckoutSession {
8
- }
9
- export class StripeBillingPortalSession {
10
- }
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGxhbi50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi9wbGFuL3BsYW4udHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxPQUFPLElBQUk7Q0FJaEI7QUFFRCxNQUFNLE9BQU8sWUFBWTtDQUV4QjtBQUVELE1BQU0sT0FBTyxRQUFRO0NBS3BCO0FBRUQsTUFBTSxPQUFPLHFCQUFxQjtDQUVqQztBQUVELE1BQU0sT0FBTywwQkFBMEI7Q0FFdEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBKU09OT2JqZWN0IH0gZnJvbSAnLi4vYXBpL3R5cGVzJztcblxuZXhwb3J0IGNsYXNzIFBsYW4ge1xuICBuYW1lOiBzdHJpbmc7XG4gIGRhdGE6IFJlY29yZDxzdHJpbmcsIEpTT05PYmplY3Q+O1xuICBzdGF0ZTogc3RyaW5nO1xufVxuXG5leHBvcnQgY2xhc3MgU3Vic2NyaXB0aW9uIHtcbiAgaWQ6IHN0cmluZztcbn1cblxuZXhwb3J0IGNsYXNzIFVzZXJQbGFuIHtcbiAgaWQ6IHN0cmluZztcbiAgcGxhbjogUGxhbjtcbiAgcGVyaW9kRW5kOiBEYXRlO1xuICBzdWJzY3JpcHRpb246IFN1YnNjcmlwdGlvbjtcbn1cblxuZXhwb3J0IGNsYXNzIFN0cmlwZUNoZWNrb3V0U2Vzc2lvbiB7XG4gIGlkOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjbGFzcyBTdHJpcGVCaWxsaW5nUG9ydGFsU2Vzc2lvbiB7XG4gIHVybDogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFVzZXJJc3N1YWJsZVBsYW4ge1xuICBwbGFuOiBQbGFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFVzZXJJc3N1ZWRQbGFuIHtcbiAgaWQ6IHN0cmluZztcbiAgcGxhbjogUGxhbjtcbiAgdG9rZW46IHN0cmluZztcbiAgdG9rZW5FeHBpcnlUaW1lOiBEYXRlO1xuICBwbGFuUGVyaW9kRW5kOiBEYXRlO1xuICBwbGFuUGVyaW9kRW5kQWZ0ZXJTZWNvbmRzOiBudW1iZXI7XG59XG4iXX0=
@@ -1,102 +0,0 @@
1
- import { __awaiter } from "tslib";
2
- /* eslint-disable @typescript-eslint/no-explicit-any */
3
- import { Injectable } from '@angular/core';
4
- import { LrApolloService } from '../api/lr-apollo.service';
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';
9
- import * as i0 from "@angular/core";
10
- import * as i1 from "../file-upload/file-upload.service";
11
- import * as i2 from "../api/lr-apollo.service";
12
- import * as i3 from "../key/key-meta.service";
13
- import * as i4 from "../key/key-graph.service";
14
- export class RecordAttachmentService {
15
- constructor(fileUploadService, lrApollo, keyMetaService, keyGraph) {
16
- this.fileUploadService = fileUploadService;
17
- this.lrApollo = lrApollo;
18
- this.keyMetaService = keyMetaService;
19
- this.keyGraph = keyGraph;
20
- }
21
- downloadAttachment(fileStateNodeId, keyId) {
22
- return __awaiter(this, void 0, void 0, function* () {
23
- const encryptedFile = yield this.fileUploadService.downloadEncryptedFile(fileStateNodeId);
24
- return yield this.keyGraph.decryptFile(keyId, encryptedFile);
25
- });
26
- }
27
- uploadAttachments(recordId, attachments) {
28
- return __awaiter(this, void 0, void 0, function* () {
29
- const fileIds = yield Promise.all((attachments || []).map((x) => __awaiter(this, void 0, void 0, function* () {
30
- if (x.fileId) {
31
- if (x.isDeleted) {
32
- yield this.deleteAttachment(x.fileId);
33
- return null;
34
- }
35
- else {
36
- return x.fileId;
37
- }
38
- }
39
- else {
40
- return yield this.addAttachment(recordId, x);
41
- }
42
- })));
43
- return fileIds.filter((x) => x);
44
- });
45
- }
46
- addAttachment(recordId, attachment) {
47
- return __awaiter(this, void 0, void 0, function* () {
48
- const secureContent = {
49
- name: attachment.name,
50
- fieldId: attachment.fieldId,
51
- fileType: attachment.file.type,
52
- fileSize: attachment.file.size,
53
- lastModified: attachment.file.lastModified,
54
- };
55
- const fileContent = yield this.fileUploadService.loadFile(attachment.file);
56
- const doubleWrappedContent = yield this.keyMetaService.doubleWrapContent(secureContent, [recordId], fileContent);
57
- const contentId = yield this.fileUploadService.uploadEncryptedFile({
58
- encryptedContent: doubleWrappedContent.cipherFileContent,
59
- fileName: attachment.name,
60
- });
61
- // Save file
62
- const response = yield this.lrApollo.mutate({
63
- mutation: CreateFileMutation,
64
- variables: {
65
- input: {
66
- plainMeta: JSON.stringify({ fileType: FileType.RecordAttachment }),
67
- wrappedStateKey: doubleWrappedContent.doubleWrappedKey,
68
- cipherMeta: doubleWrappedContent.cipherMeta,
69
- parentDirectories: doubleWrappedContent.wrappedKeys.map((x) => ({
70
- directoryId: x.directoryId,
71
- wrappingKeyId: x.wrappingKeyId,
72
- wrappedFileKey: x.wrappedKey,
73
- })),
74
- contentResource: contentId,
75
- },
76
- },
77
- });
78
- return response.createFile.file.id;
79
- });
80
- }
81
- deleteAttachment(fileId) {
82
- return __awaiter(this, void 0, void 0, function* () {
83
- yield this.lrApollo.mutate({
84
- mutation: DeleteFileMutation,
85
- variables: { fileId },
86
- });
87
- });
88
- }
89
- }
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" });
91
- RecordAttachmentService.decorators = [
92
- { type: Injectable, args: [{
93
- providedIn: 'root',
94
- },] }
95
- ];
96
- RecordAttachmentService.ctorParameters = () => [
97
- { type: FileUploadService },
98
- { type: LrApolloService },
99
- { type: KeyMetaService },
100
- { type: KeyGraphService }
101
- ];
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"]}