@lifeready/core 1.0.21 → 1.0.22

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (228) hide show
  1. package/bundles/lifeready-core.umd.js +9745 -9700
  2. package/bundles/lifeready-core.umd.js.map +1 -1
  3. package/bundles/lifeready-core.umd.min.js +2 -2
  4. package/bundles/lifeready-core.umd.min.js.map +1 -1
  5. package/esm2015/lib/_common/run-outside-angular.js +2 -2
  6. package/esm2015/lib/_common/types.js +1 -1
  7. package/esm2015/lib/api/lr-apollo.service.js +3 -3
  8. package/esm2015/lib/api/lr-graphql/lr-graphql.service.js +3 -3
  9. package/esm2015/lib/api/query-processor/common-processors.service.js +3 -3
  10. package/esm2015/lib/api/query-processor/query-processor.service.js +4 -4
  11. package/esm2015/lib/api/query-processor/tp-password-reset-processor.service.js +6 -5
  12. package/esm2015/lib/api/types/lr-graphql.types.js +1 -1
  13. package/esm2015/lib/auth/auth.gql.js +1 -28
  14. package/esm2015/lib/auth/auth.types.js +1 -1
  15. package/esm2015/lib/auth/life-ready-auth.service.js +32 -31
  16. package/esm2015/lib/category/category.gql.js +1 -1
  17. package/esm2015/lib/category/category.service.js +6 -6
  18. package/esm2015/lib/contact-card/contact-card.gql.js +79 -0
  19. package/esm2015/lib/contact-card/contact-card.service.js +154 -0
  20. package/esm2015/lib/contact-card/contact-card2.gql.js +29 -0
  21. package/esm2015/lib/contact-card/contact-card2.service.js +103 -0
  22. package/esm2015/lib/encryption/encryption.service.js +189 -0
  23. package/esm2015/lib/file-upload/file-upload.service.js +74 -0
  24. package/esm2015/lib/file-upload/file-upload.types.js +1 -0
  25. package/esm2015/lib/{auth → idle}/idle.service.js +7 -7
  26. package/esm2015/lib/{auth → idle}/idle.types.js +1 -1
  27. package/esm2015/lib/items2/item2.service.js +20 -20
  28. package/esm2015/lib/key/key-factory.service.js +237 -0
  29. package/esm2015/lib/{cryptography → key}/key-graph.service.js +10 -10
  30. package/esm2015/lib/key/key-meta.service.js +200 -0
  31. package/esm2015/lib/key/key.service.js +124 -0
  32. package/esm2015/lib/key/key.types.js +11 -0
  33. package/esm2015/lib/key-exchange/key-exchange.gql.js +188 -0
  34. package/esm2015/lib/key-exchange/key-exchange.service.js +443 -0
  35. package/esm2015/lib/key-exchange/key-exchange.types.js +7 -0
  36. package/esm2015/lib/key-exchange/key-exchange2.gql.js +171 -0
  37. package/esm2015/lib/key-exchange/key-exchange2.service.js +500 -0
  38. package/esm2015/lib/lbop/lbop.service.js +355 -0
  39. package/esm2015/lib/life-ready.module.js +2 -27
  40. package/esm2015/lib/lock/lock.gql.js +40 -0
  41. package/esm2015/lib/lock/lock.service.js +64 -0
  42. package/esm2015/lib/message/message.gql.js +32 -0
  43. package/esm2015/lib/message/message.service.js +116 -0
  44. package/esm2015/lib/message/message.types.js +1 -0
  45. package/esm2015/lib/password/password.gql.js +28 -0
  46. package/esm2015/lib/password/password.service.js +315 -0
  47. package/esm2015/lib/persist/persist.service.js +180 -0
  48. package/esm2015/lib/profile/profile-details.service.js +214 -0
  49. package/esm2015/lib/profile/profile.gql.js +97 -0
  50. package/esm2015/lib/profile/profile.service.js +169 -0
  51. package/esm2015/lib/profile/profile.types.js +34 -0
  52. package/esm2015/lib/record/record-attachment.service.js +15 -15
  53. package/esm2015/lib/record/record.service.js +3 -3
  54. package/esm2015/lib/register/register.service.js +172 -0
  55. package/esm2015/lib/scenario/scenario.controller.js +2 -2
  56. package/esm2015/lib/scenario/{scenario.gql.private.js → scenario.private.gql.js} +1 -1
  57. package/esm2015/lib/scenario/scenario.service.js +9 -9
  58. package/esm2015/lib/scenario/scenario.types.js +1 -1
  59. package/esm2015/lib/shared-contact-card/shared-contact-card.service.js +119 -0
  60. package/esm2015/lib/shared-contact-card/shared-contact-card2.gql.js +41 -0
  61. package/esm2015/lib/shared-contact-card/shared-contact-card2.service.js +117 -0
  62. package/esm2015/lib/slip39/slip39.service.js +169 -0
  63. package/esm2015/lib/time/time.service.js +146 -0
  64. package/esm2015/lib/tp-assembly/tp-assembly.js +365 -0
  65. package/esm2015/lib/tp-assembly/tp-assembly.private.gql.js +22 -0
  66. package/esm2015/lib/tp-assembly/tp-assembly.types.js +1 -0
  67. package/esm2015/lib/tp-password-reset/tp-password-reset-request.service.js +100 -0
  68. package/esm2015/lib/tp-password-reset/tp-password-reset-user.service.js +117 -0
  69. package/esm2015/lib/tp-password-reset/tp-password-reset.constants.js +4 -0
  70. package/esm2015/lib/tp-password-reset/tp-password-reset.controller.js +34 -0
  71. package/esm2015/lib/tp-password-reset/tp-password-reset.gql.js +74 -0
  72. package/esm2015/lib/tp-password-reset/tp-password-reset.private.gql.js +165 -0
  73. package/esm2015/lib/tp-password-reset/tp-password-reset.private.service.js +54 -0
  74. package/esm2015/lib/tp-password-reset/tp-password-reset.service.js +92 -0
  75. package/esm2015/lib/tp-password-reset/tp-password-reset.types.js +1 -0
  76. package/esm2015/lib/trusted-party/trusted-party.gql.js +148 -0
  77. package/esm2015/lib/trusted-party/trusted-party.service.js +326 -0
  78. package/esm2015/lib/trusted-party/trusted-party.types.js +41 -0
  79. package/esm2015/lib/trusted-party/trusted-party2.gql.js +64 -0
  80. package/esm2015/lib/trusted-party/trusted-party2.gql.private.js +25 -0
  81. package/esm2015/lib/trusted-party/trusted-party2.service.js +224 -0
  82. package/esm2015/lib/trusted-party/trusted-party2.types.js +1 -0
  83. package/esm2015/lib/two-factor/two-factor.service.js +74 -0
  84. package/esm2015/lib/user/user.gql.js +60 -0
  85. package/esm2015/lib/user/user.service.js +79 -0
  86. package/esm2015/lib/user/user.types.js +1 -0
  87. package/esm2015/lib/web-crypto/web-crypto.service.js +29 -0
  88. package/esm2015/lifeready-core.js +15 -13
  89. package/esm2015/public-api.js +49 -51
  90. package/fesm2015/lifeready-core.js +9232 -9214
  91. package/fesm2015/lifeready-core.js.map +1 -1
  92. package/lib/_common/types.d.ts +3 -1
  93. package/lib/api/lr-apollo.service.d.ts +1 -1
  94. package/lib/api/lr-graphql/lr-graphql.service.d.ts +1 -1
  95. package/lib/api/query-processor/common-processors.service.d.ts +1 -1
  96. package/lib/api/query-processor/query-processor.service.d.ts +1 -1
  97. package/lib/api/query-processor/tp-password-reset-processor.service.d.ts +1 -1
  98. package/lib/api/types/lr-graphql.types.d.ts +11 -0
  99. package/lib/auth/auth.gql.d.ts +0 -3
  100. package/lib/auth/auth.types.d.ts +2 -2
  101. package/lib/auth/life-ready-auth.service.d.ts +12 -12
  102. package/lib/category/category.gql.d.ts +1 -1
  103. package/lib/category/category.service.d.ts +2 -2
  104. package/lib/{api → contact-card}/contact-card.service.d.ts +9 -9
  105. package/lib/contact-card/contact-card2.gql.d.ts +25 -0
  106. package/lib/{api → contact-card}/contact-card2.service.d.ts +11 -12
  107. package/lib/{cryptography → encryption}/encryption.service.d.ts +2 -2
  108. package/lib/{api/file.service.d.ts → file-upload/file-upload.service.d.ts} +3 -7
  109. package/lib/file-upload/file-upload.types.d.ts +5 -0
  110. package/lib/{auth → idle}/idle.service.d.ts +4 -4
  111. package/lib/items2/item2.service.d.ts +11 -11
  112. package/lib/{cryptography → key}/key-factory.service.d.ts +2 -2
  113. package/lib/{cryptography → key}/key-graph.service.d.ts +5 -5
  114. package/lib/{cryptography → key}/key-meta.service.d.ts +1 -1
  115. package/lib/{cryptography → key}/key.service.d.ts +2 -2
  116. package/lib/{cryptography/cryptography.types.d.ts → key/key.types.d.ts} +9 -13
  117. package/lib/{api → key-exchange}/key-exchange.service.d.ts +5 -5
  118. package/lib/{api → key-exchange}/key-exchange.types.d.ts +4 -4
  119. package/lib/{api → key-exchange}/key-exchange2.gql.d.ts +1 -1
  120. package/lib/{api → key-exchange}/key-exchange2.service.d.ts +71 -18
  121. package/lib/{auth → lbop}/lbop.service.d.ts +7 -7
  122. package/lib/{api → lock}/lock.gql.d.ts +1 -1
  123. package/lib/{api → lock}/lock.service.d.ts +1 -1
  124. package/lib/message/message.gql.d.ts +13 -0
  125. package/lib/message/message.service.d.ts +29 -0
  126. package/lib/message/message.types.d.ts +12 -0
  127. package/lib/password/password.gql.d.ts +3 -0
  128. package/lib/{auth → password}/password.service.d.ts +8 -8
  129. package/lib/{api → persist}/persist.service.d.ts +3 -3
  130. package/lib/{users → profile}/profile-details.service.d.ts +3 -3
  131. package/lib/{users → profile}/profile.gql.d.ts +2 -2
  132. package/lib/{users → profile}/profile.service.d.ts +6 -6
  133. package/lib/{users → profile}/profile.types.d.ts +1 -1
  134. package/lib/record/record-attachment.service.d.ts +6 -6
  135. package/lib/record/record.service.d.ts +1 -1
  136. package/lib/{auth → register}/register.service.d.ts +4 -4
  137. package/lib/scenario/scenario.controller.d.ts +1 -1
  138. package/lib/scenario/scenario.service.d.ts +2 -2
  139. package/lib/scenario/scenario.types.d.ts +1 -1
  140. package/lib/{api → shared-contact-card}/shared-contact-card.service.d.ts +9 -9
  141. package/lib/{api → shared-contact-card}/shared-contact-card2.gql.d.ts +1 -1
  142. package/lib/{api → shared-contact-card}/shared-contact-card2.service.d.ts +6 -6
  143. package/lib/{trusted-parties → tp-assembly}/tp-assembly.d.ts +7 -7
  144. package/lib/{trusted-parties → tp-assembly}/tp-assembly.types.d.ts +1 -1
  145. package/lib/{trusted-parties → tp-password-reset}/tp-password-reset-request.service.d.ts +4 -8
  146. package/lib/{trusted-parties → tp-password-reset}/tp-password-reset-user.service.d.ts +7 -13
  147. package/lib/{trusted-parties → tp-password-reset}/tp-password-reset.controller.d.ts +1 -1
  148. package/lib/tp-password-reset/tp-password-reset.gql.d.ts +63 -0
  149. package/lib/{trusted-parties/tp-password-reset.gql.d.ts → tp-password-reset/tp-password-reset.private.gql.d.ts} +1 -63
  150. package/lib/tp-password-reset/tp-password-reset.private.service.d.ts +59 -0
  151. package/lib/{trusted-parties → tp-password-reset}/tp-password-reset.service.d.ts +6 -89
  152. package/lib/tp-password-reset/tp-password-reset.types.d.ts +40 -0
  153. package/lib/{trusted-parties → trusted-party}/trusted-party.service.d.ts +7 -7
  154. package/lib/{trusted-parties → trusted-party}/trusted-party.types.d.ts +2 -3
  155. package/lib/{trusted-parties → trusted-party}/trusted-party2.gql.d.ts +0 -22
  156. package/lib/trusted-party/trusted-party2.gql.private.d.ts +23 -0
  157. package/lib/{trusted-parties → trusted-party}/trusted-party2.service.d.ts +11 -35
  158. package/lib/trusted-party/trusted-party2.types.d.ts +12 -0
  159. package/lib/{users → user}/user.gql.d.ts +1 -1
  160. package/lib/{users → user}/user.types.d.ts +1 -1
  161. package/lifeready-core.d.ts +14 -12
  162. package/lifeready-core.metadata.json +1 -1
  163. package/package.json +1 -1
  164. package/public-api.d.ts +48 -50
  165. package/esm2015/lib/api/contact-card.gql.js +0 -79
  166. package/esm2015/lib/api/contact-card.service.js +0 -154
  167. package/esm2015/lib/api/contact-card2.gql.js +0 -60
  168. package/esm2015/lib/api/contact-card2.service.js +0 -103
  169. package/esm2015/lib/api/file.service.js +0 -74
  170. package/esm2015/lib/api/key-exchange.gql.js +0 -188
  171. package/esm2015/lib/api/key-exchange.service.js +0 -442
  172. package/esm2015/lib/api/key-exchange.types.js +0 -7
  173. package/esm2015/lib/api/key-exchange2.gql.js +0 -171
  174. package/esm2015/lib/api/key-exchange2.service.js +0 -480
  175. package/esm2015/lib/api/lock.gql.js +0 -40
  176. package/esm2015/lib/api/lock.service.js +0 -64
  177. package/esm2015/lib/api/message.service.js +0 -138
  178. package/esm2015/lib/api/persist.service.js +0 -181
  179. package/esm2015/lib/api/shared-contact-card.service.js +0 -119
  180. package/esm2015/lib/api/shared-contact-card2.gql.js +0 -41
  181. package/esm2015/lib/api/shared-contact-card2.service.js +0 -117
  182. package/esm2015/lib/api/time.service.js +0 -146
  183. package/esm2015/lib/auth/lbop.service.js +0 -355
  184. package/esm2015/lib/auth/password.service.js +0 -315
  185. package/esm2015/lib/auth/register.service.js +0 -172
  186. package/esm2015/lib/auth/two-factor.service.js +0 -74
  187. package/esm2015/lib/cryptography/cryptography.types.js +0 -11
  188. package/esm2015/lib/cryptography/encryption.service.js +0 -189
  189. package/esm2015/lib/cryptography/key-factory.service.js +0 -237
  190. package/esm2015/lib/cryptography/key-meta.service.js +0 -200
  191. package/esm2015/lib/cryptography/key.service.js +0 -124
  192. package/esm2015/lib/cryptography/slip39.service.js +0 -169
  193. package/esm2015/lib/cryptography/web-crypto.service.js +0 -29
  194. package/esm2015/lib/trusted-parties/tp-assembly.gql.private.js +0 -22
  195. package/esm2015/lib/trusted-parties/tp-assembly.js +0 -365
  196. package/esm2015/lib/trusted-parties/tp-assembly.types.js +0 -1
  197. package/esm2015/lib/trusted-parties/tp-password-reset-request.service.js +0 -113
  198. package/esm2015/lib/trusted-parties/tp-password-reset-user.service.js +0 -129
  199. package/esm2015/lib/trusted-parties/tp-password-reset.constants.js +0 -4
  200. package/esm2015/lib/trusted-parties/tp-password-reset.controller.js +0 -34
  201. package/esm2015/lib/trusted-parties/tp-password-reset.gql.js +0 -237
  202. package/esm2015/lib/trusted-parties/tp-password-reset.service.js +0 -95
  203. package/esm2015/lib/trusted-parties/trusted-party.gql.js +0 -148
  204. package/esm2015/lib/trusted-parties/trusted-party.service.js +0 -326
  205. package/esm2015/lib/trusted-parties/trusted-party.types.js +0 -41
  206. package/esm2015/lib/trusted-parties/trusted-party2.gql.js +0 -87
  207. package/esm2015/lib/trusted-parties/trusted-party2.service.js +0 -218
  208. package/esm2015/lib/users/profile-details.service.js +0 -214
  209. package/esm2015/lib/users/profile.gql.js +0 -97
  210. package/esm2015/lib/users/profile.service.js +0 -169
  211. package/esm2015/lib/users/profile.types.js +0 -34
  212. package/esm2015/lib/users/user.gql.js +0 -60
  213. package/esm2015/lib/users/user.service.js +0 -79
  214. package/esm2015/lib/users/user.types.js +0 -1
  215. package/lib/api/contact-card2.gql.d.ts +0 -34
  216. package/lib/api/message.service.d.ts +0 -59
  217. /package/lib/{api → contact-card}/contact-card.gql.d.ts +0 -0
  218. /package/lib/{auth → idle}/idle.types.d.ts +0 -0
  219. /package/lib/{api → key-exchange}/key-exchange.gql.d.ts +0 -0
  220. /package/lib/scenario/{scenario.gql.private.d.ts → scenario.private.gql.d.ts} +0 -0
  221. /package/lib/{cryptography → slip39}/slip39.service.d.ts +0 -0
  222. /package/lib/{api → time}/time.service.d.ts +0 -0
  223. /package/lib/{trusted-parties/tp-assembly.gql.private.d.ts → tp-assembly/tp-assembly.private.gql.d.ts} +0 -0
  224. /package/lib/{trusted-parties → tp-password-reset}/tp-password-reset.constants.d.ts +0 -0
  225. /package/lib/{trusted-parties → trusted-party}/trusted-party.gql.d.ts +0 -0
  226. /package/lib/{auth → two-factor}/two-factor.service.d.ts +0 -0
  227. /package/lib/{users → user}/user.service.d.ts +0 -0
  228. /package/lib/{cryptography → web-crypto}/web-crypto.service.d.ts +0 -0
@@ -1,40 +0,0 @@
1
- import { gqlTyped } from '../_common/ast';
2
- export const LockFragment = gqlTyped `
3
- fragment LockFragment on LockField {
4
- created
5
- modified
6
- version
7
- expiryTime
8
- state
9
- }`;
10
- export const UpdateLockMutation = gqlTyped `
11
- mutation UpdateLockMutation($input: UpdateLockInput!) {
12
- updateLock(input: $input) {
13
- lock {
14
- ...LockFragment
15
- }
16
- }
17
- }
18
- ${LockFragment}
19
- `;
20
- export const AcquireLockMutation = gqlTyped `
21
- mutation AcquireLockMutation($input: AcquireLockInput!) {
22
- acquireLock(input: $input) {
23
- lock {
24
- ...LockFragment
25
- }
26
- }
27
- }
28
- ${LockFragment}
29
- `;
30
- export const ReleaseLockMutation = gqlTyped `
31
- mutation ReleaseLockMutation($input: ReleaseLockInput!) {
32
- releaseLock(input: $input) {
33
- lock {
34
- ...LockFragment
35
- }
36
- }
37
- }
38
- ${LockFragment}
39
- `;
40
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jay5ncWwuanMiLCJzb3VyY2VSb290IjoiL29wdC9hdGxhc3NpYW4vcGlwZWxpbmVzL2FnZW50L2J1aWxkL3Byb2plY3RzL2NvcmUvc3JjLyIsInNvdXJjZXMiOlsibGliL2FwaS9sb2NrLmdxbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFVMUMsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUFHLFFBQVEsQ0FBb0I7Ozs7Ozs7RUFPdEQsQ0FBQztBQU9ILE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLFFBQVEsQ0FBMEI7Ozs7Ozs7O0VBUWxFLFlBQVk7Q0FDYixDQUFDO0FBT0YsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQUcsUUFBUSxDQUEyQjs7Ozs7Ozs7RUFRcEUsWUFBWTtDQUNiLENBQUM7QUFPRixNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxRQUFRLENBQTJCOzs7Ozs7OztFQVFwRSxZQUFZO0NBQ2IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEpXSyB9IGZyb20gJ25vZGUtam9zZSc7XG5pbXBvcnQgeyBncWxUeXBlZCB9IGZyb20gJy4uL19jb21tb24vYXN0JztcbmltcG9ydCB7IERhdGVUaW1lLCBMb2NrU3RhdGUsIFVVSUQgfSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IGludGVyZmFjZSBMb2NrRnJhZ21lbnRSZXN1bHQge1xuICBjcmVhdGVkOiBEYXRlVGltZTtcbiAgbW9kaWZpZWQ6IERhdGVUaW1lO1xuICB2ZXJzaW9uPzogVVVJRDtcbiAgZXhwaXJ5VGltZTogRGF0ZVRpbWU7XG4gIHN0YXRlOiBMb2NrU3RhdGU7XG59XG5leHBvcnQgY29uc3QgTG9ja0ZyYWdtZW50ID0gZ3FsVHlwZWQ8TG9ja0ZyYWdtZW50UmVzdWx0PmBcbmZyYWdtZW50IExvY2tGcmFnbWVudCBvbiBMb2NrRmllbGQge1xuICBjcmVhdGVkXG4gIG1vZGlmaWVkXG4gIHZlcnNpb25cbiAgZXhwaXJ5VGltZVxuICBzdGF0ZVxufWA7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVXBkYXRlTG9ja011dGF0aW9uUmVzdWx0IHtcbiAgdXBkYXRlTG9jazoge1xuICAgIGxvY2s6IExvY2tGcmFnbWVudFJlc3VsdDtcbiAgfTtcbn1cbmV4cG9ydCBjb25zdCBVcGRhdGVMb2NrTXV0YXRpb24gPSBncWxUeXBlZDxVcGRhdGVMb2NrTXV0YXRpb25SZXN1bHQ+YFxubXV0YXRpb24gVXBkYXRlTG9ja011dGF0aW9uKCRpbnB1dDogVXBkYXRlTG9ja0lucHV0ISkge1xuICB1cGRhdGVMb2NrKGlucHV0OiAkaW5wdXQpIHtcbiAgICBsb2NrIHtcbiAgICAgIC4uLkxvY2tGcmFnbWVudFxuICAgIH1cbiAgfVxufVxuJHtMb2NrRnJhZ21lbnR9XG5gO1xuXG5leHBvcnQgaW50ZXJmYWNlIEFjcXVpcmVMb2NrTXV0YXRpb25SZXN1bHQge1xuICBhY3F1aXJlTG9jazoge1xuICAgIGxvY2s6IExvY2tGcmFnbWVudFJlc3VsdDtcbiAgfTtcbn1cbmV4cG9ydCBjb25zdCBBY3F1aXJlTG9ja011dGF0aW9uID0gZ3FsVHlwZWQ8QWNxdWlyZUxvY2tNdXRhdGlvblJlc3VsdD5gXG5tdXRhdGlvbiBBY3F1aXJlTG9ja011dGF0aW9uKCRpbnB1dDogQWNxdWlyZUxvY2tJbnB1dCEpIHtcbiAgYWNxdWlyZUxvY2soaW5wdXQ6ICRpbnB1dCkge1xuICAgIGxvY2sge1xuICAgICAgLi4uTG9ja0ZyYWdtZW50XG4gICAgfVxuICB9XG59XG4ke0xvY2tGcmFnbWVudH1cbmA7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVsZWFzZUxvY2tNdXRhdGlvblJlc3VsdCB7XG4gIHJlbGVhc2VMb2NrOiB7XG4gICAgbG9jazogTG9ja0ZyYWdtZW50UmVzdWx0O1xuICB9O1xufVxuZXhwb3J0IGNvbnN0IFJlbGVhc2VMb2NrTXV0YXRpb24gPSBncWxUeXBlZDxSZWxlYXNlTG9ja011dGF0aW9uUmVzdWx0PmBcbm11dGF0aW9uIFJlbGVhc2VMb2NrTXV0YXRpb24oJGlucHV0OiBSZWxlYXNlTG9ja0lucHV0ISkge1xuICByZWxlYXNlTG9jayhpbnB1dDogJGlucHV0KSB7XG4gICAgbG9jayB7XG4gICAgICAuLi5Mb2NrRnJhZ21lbnRcbiAgICB9XG4gIH1cbn1cbiR7TG9ja0ZyYWdtZW50fVxuYDtcbiJdfQ==
@@ -1,64 +0,0 @@
1
- import { __decorate } from "tslib";
2
- import { Injectable, Injector, NgZone } from '@angular/core';
3
- import { LrMutation, LrService } from './lr-graphql';
4
- import { AcquireLockMutation, ReleaseLockMutation, UpdateLockMutation, } from './lock.gql';
5
- import { RunOutsideAngular } from '../_common/run-outside-angular';
6
- import * as i0 from "@angular/core";
7
- let LockService = class LockService extends LrService {
8
- constructor(ngZone, injector) {
9
- super(injector);
10
- this.ngZone = ngZone;
11
- this.injector = injector;
12
- }
13
- // Updating the lock version is always to be down along with another mutation.
14
- updateLockMutation(options) {
15
- return new LrMutation({
16
- mutation: UpdateLockMutation,
17
- variables: {
18
- input: {
19
- resourceId: options.resourceId,
20
- version: options.version,
21
- },
22
- },
23
- });
24
- }
25
- acquireLockMutation(options) {
26
- return new LrMutation({
27
- mutation: AcquireLockMutation,
28
- variables: {
29
- input: {
30
- resourceId: options.resourceId,
31
- timeoutMs: options.timeoutMs,
32
- },
33
- },
34
- });
35
- }
36
- releaseLockMutation(options) {
37
- return new LrMutation({
38
- mutation: ReleaseLockMutation,
39
- variables: {
40
- input: {
41
- resourceId: options.resourceId,
42
- version: options.version,
43
- },
44
- },
45
- });
46
- }
47
- };
48
- LockService.ɵprov = i0.ɵɵdefineInjectable({ factory: function LockService_Factory() { return new LockService(i0.ɵɵinject(i0.NgZone), i0.ɵɵinject(i0.INJECTOR)); }, token: LockService, providedIn: "root" });
49
- LockService.decorators = [
50
- { type: Injectable, args: [{
51
- providedIn: 'root',
52
- },] }
53
- ];
54
- LockService.ctorParameters = () => [
55
- { type: NgZone },
56
- { type: Injector }
57
- ];
58
- LockService = __decorate([
59
- RunOutsideAngular({
60
- ngZoneName: 'ngZone',
61
- })
62
- ], LockService);
63
- export { LockService };
64
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jay5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6Ii9vcHQvYXRsYXNzaWFuL3BpcGVsaW5lcy9hZ2VudC9idWlsZC9wcm9qZWN0cy9jb3JlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9hcGkvbG9jay5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQVcsTUFBTSxlQUFlLENBQUM7QUFDdEUsT0FBTyxFQUFFLFVBQVUsRUFBRSxTQUFTLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDckQsT0FBTyxFQUNMLG1CQUFtQixFQUNuQixtQkFBbUIsRUFDbkIsa0JBQWtCLEdBQ25CLE1BQU0sWUFBWSxDQUFDO0FBQ3BCLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDOztJQVF0RCxXQUFXLFNBQVgsV0FBWSxTQUFRLFNBQVM7SUFDeEMsWUFBb0IsTUFBYyxFQUFVLFFBQWtCO1FBQzVELEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQztRQURFLFdBQU0sR0FBTixNQUFNLENBQVE7UUFBVSxhQUFRLEdBQVIsUUFBUSxDQUFVO0lBRTlELENBQUM7SUFFRCw4RUFBOEU7SUFDOUUsa0JBQWtCLENBQUMsT0FBaUQ7UUFDbEUsT0FBTyxJQUFJLFVBQVUsQ0FBQztZQUNwQixRQUFRLEVBQUUsa0JBQWtCO1lBQzVCLFNBQVMsRUFBRTtnQkFDVCxLQUFLLEVBQUU7b0JBQ0wsVUFBVSxFQUFFLE9BQU8sQ0FBQyxVQUFVO29CQUM5QixPQUFPLEVBQUUsT0FBTyxDQUFDLE9BQU87aUJBQ3pCO2FBQ0Y7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsbUJBQW1CLENBQUMsT0FBbUQ7UUFDckUsT0FBTyxJQUFJLFVBQVUsQ0FBQztZQUNwQixRQUFRLEVBQUUsbUJBQW1CO1lBQzdCLFNBQVMsRUFBRTtnQkFDVCxLQUFLLEVBQUU7b0JBQ0wsVUFBVSxFQUFFLE9BQU8sQ0FBQyxVQUFVO29CQUM5QixTQUFTLEVBQUUsT0FBTyxDQUFDLFNBQVM7aUJBQzdCO2FBQ0Y7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsbUJBQW1CLENBQUMsT0FBZ0Q7UUFDbEUsT0FBTyxJQUFJLFVBQVUsQ0FBQztZQUNwQixRQUFRLEVBQUUsbUJBQW1CO1lBQzdCLFNBQVMsRUFBRTtnQkFDVCxLQUFLLEVBQUU7b0JBQ0wsVUFBVSxFQUFFLE9BQU8sQ0FBQyxVQUFVO29CQUM5QixPQUFPLEVBQUUsT0FBTyxDQUFDLE9BQU87aUJBQ3pCO2FBQ0Y7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0YsQ0FBQTs7O1lBNUNBLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQjs7O1lBZDhCLE1BQU07WUFBaEIsUUFBUTs7QUFlaEIsV0FBVztJQU52QixpQkFBaUIsQ0FBQztRQUNqQixVQUFVLEVBQUUsUUFBUTtLQUNyQixDQUFDO0dBSVcsV0FBVyxDQXlDdkI7U0F6Q1ksV0FBVyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIEluamVjdG9yLCBOZ1pvbmUsIFZpZXdSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IExyTXV0YXRpb24sIExyU2VydmljZSB9IGZyb20gJy4vbHItZ3JhcGhxbCc7XG5pbXBvcnQge1xuICBBY3F1aXJlTG9ja011dGF0aW9uLFxuICBSZWxlYXNlTG9ja011dGF0aW9uLFxuICBVcGRhdGVMb2NrTXV0YXRpb24sXG59IGZyb20gJy4vbG9jay5ncWwnO1xuaW1wb3J0IHsgUnVuT3V0c2lkZUFuZ3VsYXIgfSBmcm9tICcuLi9fY29tbW9uL3J1bi1vdXRzaWRlLWFuZ3VsYXInO1xuXG5AUnVuT3V0c2lkZUFuZ3VsYXIoe1xuICBuZ1pvbmVOYW1lOiAnbmdab25lJyxcbn0pXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgTG9ja1NlcnZpY2UgZXh0ZW5kcyBMclNlcnZpY2Uge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIG5nWm9uZTogTmdab25lLCBwcml2YXRlIGluamVjdG9yOiBJbmplY3Rvcikge1xuICAgIHN1cGVyKGluamVjdG9yKTtcbiAgfVxuXG4gIC8vIFVwZGF0aW5nIHRoZSBsb2NrIHZlcnNpb24gaXMgYWx3YXlzIHRvIGJlIGRvd24gYWxvbmcgd2l0aCBhbm90aGVyIG11dGF0aW9uLlxuICB1cGRhdGVMb2NrTXV0YXRpb24ob3B0aW9uczogeyByZXNvdXJjZUlkPzogc3RyaW5nOyB2ZXJzaW9uOiBzdHJpbmcgfSkge1xuICAgIHJldHVybiBuZXcgTHJNdXRhdGlvbih7XG4gICAgICBtdXRhdGlvbjogVXBkYXRlTG9ja011dGF0aW9uLFxuICAgICAgdmFyaWFibGVzOiB7XG4gICAgICAgIGlucHV0OiB7XG4gICAgICAgICAgcmVzb3VyY2VJZDogb3B0aW9ucy5yZXNvdXJjZUlkLFxuICAgICAgICAgIHZlcnNpb246IG9wdGlvbnMudmVyc2lvbixcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgfSk7XG4gIH1cblxuICBhY3F1aXJlTG9ja011dGF0aW9uKG9wdGlvbnM6IHsgcmVzb3VyY2VJZD86IHN0cmluZzsgdGltZW91dE1zOiBudW1iZXIgfSkge1xuICAgIHJldHVybiBuZXcgTHJNdXRhdGlvbih7XG4gICAgICBtdXRhdGlvbjogQWNxdWlyZUxvY2tNdXRhdGlvbixcbiAgICAgIHZhcmlhYmxlczoge1xuICAgICAgICBpbnB1dDoge1xuICAgICAgICAgIHJlc291cmNlSWQ6IG9wdGlvbnMucmVzb3VyY2VJZCxcbiAgICAgICAgICB0aW1lb3V0TXM6IG9wdGlvbnMudGltZW91dE1zLFxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICB9KTtcbiAgfVxuXG4gIHJlbGVhc2VMb2NrTXV0YXRpb24ob3B0aW9uczogeyByZXNvdXJjZUlkOiBzdHJpbmc7IHZlcnNpb246IHN0cmluZyB9KSB7XG4gICAgcmV0dXJuIG5ldyBMck11dGF0aW9uKHtcbiAgICAgIG11dGF0aW9uOiBSZWxlYXNlTG9ja011dGF0aW9uLFxuICAgICAgdmFyaWFibGVzOiB7XG4gICAgICAgIGlucHV0OiB7XG4gICAgICAgICAgcmVzb3VyY2VJZDogb3B0aW9ucy5yZXNvdXJjZUlkLFxuICAgICAgICAgIHZlcnNpb246IG9wdGlvbnMudmVyc2lvbixcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
@@ -1,138 +0,0 @@
1
- import { __awaiter } from "tslib";
2
- import { Injectable } from '@angular/core';
3
- import gql from 'graphql-tag';
4
- import { EncryptionService } from '../cryptography/encryption.service';
5
- import { KeyGraphService } from '../cryptography/key-graph.service';
6
- import { KeyGraphFragment } from '../_common/queries.gql';
7
- import { KeyExchangeService } from './key-exchange.service';
8
- import { LrApolloService } from './lr-apollo.service';
9
- import * as i0 from "@angular/core";
10
- import * as i1 from "./lr-apollo.service";
11
- import * as i2 from "../cryptography/key-graph.service";
12
- import * as i3 from "../cryptography/encryption.service";
13
- import * as i4 from "./key-exchange.service";
14
- export const SendMessageMutation = gql `
15
- mutation SendMessage($input: SendMessageInput!) {
16
- sendMessage(input: $input) {
17
- message {
18
- id
19
- }
20
- }
21
- }
22
- `;
23
- export const MessageQuery = gql `
24
- query Message($id: LrRelayIdInput!) {
25
- message(id: $id) {
26
- id
27
- sender {
28
- username
29
- }
30
- receiver {
31
- username
32
- }
33
- plainMessage
34
- signedCipherMessage
35
- sharedKey {
36
- id
37
- }
38
- senderSigPbk {
39
- id
40
- }
41
- }
42
- keyGraph {
43
- ...KeyGraphFragment
44
- }
45
- }
46
- ${KeyGraphFragment}
47
- `;
48
- export class MessageService {
49
- constructor(lrApollo, keyGraph, encryptionService, keyExchangeService) {
50
- this.lrApollo = lrApollo;
51
- this.keyGraph = keyGraph;
52
- this.encryptionService = encryptionService;
53
- this.keyExchangeService = keyExchangeService;
54
- this.encrypt = this.encryptionService.encrypt.bind(this.encryptionService);
55
- this.decrypt = this.encryptionService.decrypt.bind(this.encryptionService);
56
- this.sign = this.encryptionService.sign.bind(this.encryptionService);
57
- this.verify = this.encryptionService.verify.bind(this.encryptionService);
58
- }
59
- sendMessage({ username, userId, plainMessageJson, plainCipherMessageJson, }) {
60
- return __awaiter(this, void 0, void 0, function* () {
61
- const userSharedKey = yield this.keyExchangeService.currentUserSharedKey({
62
- username,
63
- userId,
64
- });
65
- const input = {
66
- receiverUsername: username,
67
- receiverId: userId,
68
- sharedKeyId: userSharedKey.sharedKey.id,
69
- senderSigPbkId: userSharedKey.userSigPrk.id,
70
- };
71
- if (plainCipherMessageJson) {
72
- const sharedKey = yield this.keyGraph.getJwkKey(userSharedKey.sharedKey.id);
73
- const cipherMessage = yield this.encrypt(sharedKey, plainCipherMessageJson);
74
- const senderSigPrk = yield this.keyGraph.getJwkKey(userSharedKey.userSigPrk.id);
75
- const signedCipherMessage = yield this.sign(senderSigPrk, cipherMessage);
76
- input.signedCipherMessage = JSON.stringify(signedCipherMessage);
77
- }
78
- if (plainMessageJson) {
79
- input.plainMessage = JSON.stringify(plainMessageJson);
80
- }
81
- const res = yield this.lrApollo.query({
82
- query: SendMessageMutation,
83
- variables: {
84
- input,
85
- },
86
- });
87
- return res.sendMessage;
88
- });
89
- }
90
- decryptMessage(message, { sharedKey, senderSigPbk }) {
91
- return __awaiter(this, void 0, void 0, function* () {
92
- const signedCipherMessage = yield this.verify(senderSigPbk, JSON.parse(message.signedCipherMessage));
93
- message.plainSignedCipherMessageJson = yield this.decrypt(sharedKey, signedCipherMessage);
94
- });
95
- }
96
- getMessage(id) {
97
- return __awaiter(this, void 0, void 0, function* () {
98
- const res = yield this.lrApollo.query({
99
- query: MessageQuery,
100
- variables: {
101
- id,
102
- },
103
- });
104
- this.keyGraph.addKeys(res.keyGraph);
105
- const message = res.message;
106
- const sharedKey = yield this.keyGraph.getJwkKey(message.sharedKey.id);
107
- // The sender would be getting the Prk back. The receiver gets the Pbk back.
108
- // But only the Pbk is needed here to verify signature.
109
- // So both sender and receiver can access this message.
110
- const senderSigPbk = yield this.keyGraph.getJwkKey(message.senderSigPbk.id);
111
- // Test bad signature
112
- // senderSigPbk = senderSigPbk.toJSON();
113
- // senderSigPbk.n = "x" + senderSigPbk.n.substring(1);
114
- // senderSigPbk = await KFS.asKey(senderSigPbk);
115
- yield this.decryptMessage(message, {
116
- sharedKey,
117
- senderSigPbk,
118
- });
119
- if (message.plainMessage) {
120
- message.plainMessageJson = JSON.parse(message.plainMessage);
121
- }
122
- return res.message;
123
- });
124
- }
125
- }
126
- MessageService.ɵprov = i0.ɵɵdefineInjectable({ factory: function MessageService_Factory() { return new MessageService(i0.ɵɵinject(i1.LrApolloService), i0.ɵɵinject(i2.KeyGraphService), i0.ɵɵinject(i3.EncryptionService), i0.ɵɵinject(i4.KeyExchangeService)); }, token: MessageService, providedIn: "root" });
127
- MessageService.decorators = [
128
- { type: Injectable, args: [{
129
- providedIn: 'root',
130
- },] }
131
- ];
132
- MessageService.ctorParameters = () => [
133
- { type: LrApolloService },
134
- { type: KeyGraphService },
135
- { type: EncryptionService },
136
- { type: KeyExchangeService }
137
- ];
138
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"message.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/api/message.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport gql from 'graphql-tag';\nimport { JWK } from 'node-jose';\nimport { EncryptionService } from '../cryptography/encryption.service';\nimport { KeyGraphService } from '../cryptography/key-graph.service';\nimport { KeyGraphFragment } from '../_common/queries.gql';\nimport { KeyExchangeService } from './key-exchange.service';\nimport { LrApolloService } from './lr-apollo.service';\nimport { KeyFactoryService as KFS } from '../cryptography/key-factory.service';\nimport { JSONObject } from './types';\n\nexport const SendMessageMutation = gql`\n  mutation SendMessage($input: SendMessageInput!) {\n    sendMessage(input: $input) {\n      message {\n        id\n      }\n    }\n  }\n`;\n\nexport const MessageQuery = gql`\n  query Message($id: LrRelayIdInput!) {\n    message(id: $id) {\n      id\n      sender {\n        username\n      }\n      receiver {\n        username\n      }\n      plainMessage\n      signedCipherMessage\n      sharedKey {\n        id\n      }\n      senderSigPbk {\n        id\n      }\n    }\n    keyGraph {\n      ...KeyGraphFragment\n    }\n  }\n  ${KeyGraphFragment}\n`;\n\nexport interface SendMessage {\n  message: {\n    id: string;\n  };\n}\n\nexport interface SendMessageInput {\n  username?: string;\n  userId?: string;\n  plainMessageJson?: JSONObject;\n  plainCipherMessageJson?: JSONObject;\n}\n\nexport interface Message {\n  id: string;\n  sender: {\n    id: string;\n    username: string;\n  };\n  receiver: {\n    id: string;\n    username: string;\n  };\n  plainMessage: string;\n  plainMessageJson?: JSONObject;\n  signedCipherMessage: string;\n  plainSignedCipherMessageJson?: JSONObject;\n  senderSigPbk: {\n    id: string;\n  };\n  sharedKey: {\n    id: string;\n  };\n}\n\ninterface DecryptMessageOptions {\n  sharedKey: JWK.Key;\n  senderSigPbk: JWK.Key;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class MessageService {\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 lrApollo: LrApolloService,\n    private keyGraph: KeyGraphService,\n    private encryptionService: EncryptionService,\n    private keyExchangeService: KeyExchangeService\n  ) {}\n\n  async sendMessage({\n    username,\n    userId,\n    plainMessageJson,\n    plainCipherMessageJson,\n  }: SendMessageInput): Promise<SendMessage> {\n    const userSharedKey = await this.keyExchangeService.currentUserSharedKey({\n      username,\n      userId,\n    });\n\n    const input: any = {\n      receiverUsername: username,\n      receiverId: userId,\n      sharedKeyId: userSharedKey.sharedKey.id,\n      senderSigPbkId: userSharedKey.userSigPrk.id,\n    };\n\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      const signedCipherMessage = await this.sign(senderSigPrk, cipherMessage);\n\n      input.signedCipherMessage = JSON.stringify(signedCipherMessage);\n    }\n\n    if (plainMessageJson) {\n      input.plainMessage = JSON.stringify(plainMessageJson);\n    }\n\n    const res = await this.lrApollo.query<any>({\n      query: SendMessageMutation,\n      variables: {\n        input,\n      },\n    });\n\n    return res.sendMessage;\n  }\n\n  async decryptMessage(\n    message: Message,\n    { sharedKey, senderSigPbk }: DecryptMessageOptions\n  ): Promise<void> {\n    const signedCipherMessage = await this.verify(\n      senderSigPbk,\n      JSON.parse(message.signedCipherMessage)\n    );\n\n    message.plainSignedCipherMessageJson = await this.decrypt(\n      sharedKey,\n      signedCipherMessage\n    );\n  }\n\n  async getMessage(id: string): Promise<Message> {\n    const res = await this.lrApollo.query<any>({\n      query: MessageQuery,\n      variables: {\n        id,\n      },\n    });\n\n    this.keyGraph.addKeys(res.keyGraph);\n\n    const message = res.message as 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,181 +0,0 @@
1
- import { __awaiter } from "tslib";
2
- import { Injectable, Injector } from '@angular/core';
3
- import { CookieService } from 'ngx-cookie-service';
4
- import { EncryptionService } from '../cryptography/encryption.service';
5
- import { isDevMode } from '@angular/core';
6
- import { LrBadArgumentException } from '../_common/exceptions';
7
- import { KeyFactoryService as KFS } from '../cryptography/key-factory.service';
8
- import * as i0 from "@angular/core";
9
- import * as i1 from "../cryptography/key-factory.service";
10
- import * as i2 from "ngx-cookie-service";
11
- import * as i3 from "../cryptography/encryption.service";
12
- export class PersistService {
13
- constructor(keyFactory, cookieService, encryptionService, injector) {
14
- this.keyFactory = keyFactory;
15
- this.cookieService = cookieService;
16
- this.encryptionService = encryptionService;
17
- this.injector = injector;
18
- this.KEY_PREFIX = 'lrSession-';
19
- this.cookieSecure = true;
20
- this.serverSessionEncryptionKey = null;
21
- if (isDevMode()) {
22
- this.setCookieSecure(false);
23
- }
24
- }
25
- setServerSessionEncryptionKey(key) {
26
- this.serverSessionEncryptionKey = key;
27
- }
28
- clearServerSessionEncryptionKey() {
29
- this.serverSessionEncryptionKey = null;
30
- }
31
- // It's important that set and delete cookie use exactly the same set of parameters.
32
- getCookieParams() {
33
- return {
34
- path: '/',
35
- domain: null,
36
- secure: this.cookieSecure,
37
- sameSite: 'Lax',
38
- };
39
- }
40
- clear() {
41
- // Remove all cookies
42
- Object.keys(this.cookieService.getAll()).forEach((key) => {
43
- if (key.startsWith(this.KEY_PREFIX)) {
44
- this.deletePrefixedName(key);
45
- }
46
- });
47
- // Remove all persisted session variables
48
- Object.keys(localStorage).forEach((key) => {
49
- if (key.startsWith(this.KEY_PREFIX)) {
50
- this.deletePrefixedName(key);
51
- }
52
- });
53
- }
54
- setCookieSecure(value) {
55
- this.cookieSecure = value;
56
- if (!value) {
57
- if (isDevMode()) {
58
- console.warn('The cookie secure flag in persistService has been set to false, set it to true in production mode');
59
- }
60
- else {
61
- throw new LrBadArgumentException('Can not set PersistService cookie secure flag to false in production mode.');
62
- }
63
- }
64
- }
65
- prefixName(name) {
66
- return this.KEY_PREFIX + name;
67
- }
68
- delete(name) {
69
- this.deletePrefixedName(this.prefixName(name));
70
- }
71
- deletePrefixedName(prefixedName) {
72
- const params = this.getCookieParams();
73
- this.cookieService.delete(prefixedName, // name: string,
74
- params.path, // path?: string,
75
- params.domain, // domain ?: string,
76
- params.secure, // secure ?: boolean,
77
- params.sameSite // sameSite ?: 'Lax' | 'None' | 'Strict'): void;
78
- );
79
- localStorage.removeItem(prefixedName);
80
- }
81
- set({ name, value, serverSession, expiry, }) {
82
- return __awaiter(this, void 0, void 0, function* () {
83
- const prefixedName = this.prefixName(name);
84
- let item;
85
- if (serverSession) {
86
- item = {
87
- serverSession: true,
88
- data: yield this.encryptionService.encryptToString(this.serverSessionEncryptionKey, value),
89
- };
90
- }
91
- else {
92
- item = {
93
- data: value,
94
- };
95
- }
96
- if (expiry) {
97
- const key = yield this.keyFactory.createKey();
98
- item.expiry = expiry.toISOString();
99
- item.data = yield this.encryptionService.encryptToString(key, item.data);
100
- const cookieItem = {
101
- key: key.toJSON(true),
102
- };
103
- // If path is set to anything other than "/" then the cookie is only
104
- // accessible by JS if the current URL has the same prefix as the path.
105
- // Ideally we don't want the encryption key cookie to be sent at all, but
106
- // since the encrypted content is held in localstorage, it is not a security
107
- // risk, i.e. it is at least as secure as storing only in localstorage.
108
- const params = this.getCookieParams();
109
- this.cookieService.set(prefixedName, // name: string,
110
- JSON.stringify(cookieItem), // value: string,
111
- expiry, // expires?: number | Date,
112
- params.path, // path?: string,
113
- params.domain, // domain?: string,
114
- params.secure, // secure?: boolean,
115
- params.sameSite // sameSite?: 'Lax' | 'None' | 'Strict'
116
- );
117
- }
118
- localStorage.setItem(prefixedName, JSON.stringify(item));
119
- });
120
- }
121
- get(name) {
122
- return __awaiter(this, void 0, void 0, function* () {
123
- const prefixedName = this.prefixName(name);
124
- try {
125
- const ret = yield this.getImpl(prefixedName);
126
- if (ret == null) {
127
- // Clear any cookies to keep things in sync.
128
- this.deletePrefixedName(prefixedName);
129
- }
130
- return ret;
131
- }
132
- catch (error) {
133
- this.deletePrefixedName(prefixedName);
134
- throw error;
135
- }
136
- });
137
- }
138
- getImpl(name) {
139
- return __awaiter(this, void 0, void 0, function* () {
140
- const itemString = localStorage.getItem(name);
141
- if (!itemString) {
142
- return null;
143
- }
144
- const item = JSON.parse(itemString);
145
- let data;
146
- if (item.expiry) {
147
- const cookieItemString = this.cookieService.get(name);
148
- if (!cookieItemString) {
149
- // Probably expired, but we won't make any interpretations since if we only used
150
- // cookies we can't tell if it's expired or explicitly removed. So we just make
151
- // the behaviour here consistent with that.
152
- console.log('No cookie.');
153
- return null;
154
- }
155
- const cookieItem = JSON.parse(cookieItemString);
156
- const key = yield KFS.asKey(cookieItem.key);
157
- data = yield this.encryptionService.decrypt(key, item.data);
158
- }
159
- else {
160
- data = item.data;
161
- }
162
- if (item.serverSession) {
163
- data = yield this.encryptionService.decrypt(this.serverSessionEncryptionKey, data);
164
- }
165
- return data;
166
- });
167
- }
168
- }
169
- PersistService.ɵprov = i0.ɵɵdefineInjectable({ factory: function PersistService_Factory() { return new PersistService(i0.ɵɵinject(i1.KeyFactoryService), i0.ɵɵinject(i2.CookieService), i0.ɵɵinject(i3.EncryptionService), i0.ɵɵinject(i0.INJECTOR)); }, token: PersistService, providedIn: "root" });
170
- PersistService.decorators = [
171
- { type: Injectable, args: [{
172
- providedIn: 'root',
173
- },] }
174
- ];
175
- PersistService.ctorParameters = () => [
176
- { type: KFS },
177
- { type: CookieService },
178
- { type: EncryptionService },
179
- { type: Injector }
180
- ];
181
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"persist.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/api/persist.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { JWK } from 'node-jose';\nimport { Injectable, Injector } from '@angular/core';\nimport { CookieService } from 'ngx-cookie-service';\nimport { EncryptionService } from '../cryptography/encryption.service';\nimport { isDevMode } from '@angular/core';\nimport { LrBadArgumentException } from '../_common/exceptions';\nimport { KeyFactoryService as KFS } from '../cryptography/key-factory.service';\n\ninterface Item {\n  data: string;\n  expiry?: string; // iso format\n  serverSession?: boolean;\n}\n\ninterface CookieItem {\n  key: any;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class PersistService {\n  private readonly KEY_PREFIX = 'lrSession-';\n\n  private cookieSecure = true;\n  private serverSessionEncryptionKey: JWK.Key = null;\n\n  constructor(\n    private keyFactory: KFS,\n    private cookieService: CookieService,\n    private encryptionService: EncryptionService,\n    private injector: Injector\n  ) {\n    if (isDevMode()) {\n      this.setCookieSecure(false);\n    }\n  }\n\n  setServerSessionEncryptionKey(key: JWK.Key) {\n    this.serverSessionEncryptionKey = key;\n  }\n\n  clearServerSessionEncryptionKey() {\n    this.serverSessionEncryptionKey = null;\n  }\n\n  // It's important that set and delete cookie use exactly the same set of parameters.\n  private getCookieParams() {\n    return {\n      path: '/',\n      domain: null, // which means the current domain of the frontend app.\n      secure: this.cookieSecure,\n      sameSite: 'Lax' as 'Lax' | 'None' | 'Strict',\n    };\n  }\n\n  public clear() {\n    // Remove all cookies\n    Object.keys(this.cookieService.getAll()).forEach((key) => {\n      if (key.startsWith(this.KEY_PREFIX)) {\n        this.deletePrefixedName(key);\n      }\n    });\n\n    // Remove all persisted session variables\n    Object.keys(localStorage).forEach((key) => {\n      if (key.startsWith(this.KEY_PREFIX)) {\n        this.deletePrefixedName(key);\n      }\n    });\n  }\n\n  public setCookieSecure(value: boolean) {\n    this.cookieSecure = value;\n    if (!value) {\n      if (isDevMode()) {\n        console.warn(\n          'The cookie secure flag in persistService has been set to false, set it to true in production mode'\n        );\n      } else {\n        throw new LrBadArgumentException(\n          'Can not set PersistService cookie secure flag to false in production mode.'\n        );\n      }\n    }\n  }\n\n  private prefixName(name: string): string {\n    return this.KEY_PREFIX + name;\n  }\n\n  public delete(name: string): void {\n    this.deletePrefixedName(this.prefixName(name));\n  }\n\n  private deletePrefixedName(prefixedName: string): void {\n    const params = this.getCookieParams();\n    this.cookieService.delete(\n      prefixedName, // name: string,\n      params.path, // path?: string,\n      params.domain, // domain ?: string,\n      params.secure, // secure ?: boolean,\n      params.sameSite // sameSite ?: 'Lax' | 'None' | 'Strict'): void;\n    );\n    localStorage.removeItem(prefixedName);\n  }\n\n  public async set({\n    name,\n    value,\n    serverSession,\n    expiry,\n  }: {\n    name: string;\n    value: any;\n    serverSession: boolean;\n    expiry?: Date;\n  }): Promise<void> {\n    const prefixedName = this.prefixName(name);\n\n    let item: Item;\n\n    if (serverSession) {\n      item = {\n        serverSession: true,\n        data: await this.encryptionService.encryptToString(\n          this.serverSessionEncryptionKey,\n          value\n        ),\n      };\n    } else {\n      item = {\n        data: value,\n      };\n    }\n\n    if (expiry) {\n      const key = await this.keyFactory.createKey();\n      item.expiry = expiry.toISOString();\n      item.data = await this.encryptionService.encryptToString(key, item.data);\n\n      const cookieItem: CookieItem = {\n        key: key.toJSON(true),\n      };\n\n      // If path is set to anything other than \"/\" then the cookie is only\n      // accessible by JS if the current URL has the same prefix as the path.\n      // Ideally we don't want the encryption key cookie to be sent at all, but\n      // since the encrypted content is held in localstorage, it is not a security\n      // risk, i.e. it is at least as secure as storing only in localstorage.\n      const params = this.getCookieParams();\n      this.cookieService.set(\n        prefixedName, // name: string,\n        JSON.stringify(cookieItem), // value: string,\n        expiry, // expires?: number | Date,\n        params.path, // path?: string,\n        params.domain, // domain?: string,\n        params.secure, // secure?: boolean,\n        params.sameSite // sameSite?: 'Lax' | 'None' | 'Strict'\n      );\n    }\n\n    localStorage.setItem(prefixedName, JSON.stringify(item));\n  }\n\n  public async get(name: string): Promise<any> {\n    const prefixedName = this.prefixName(name);\n\n    try {\n      const ret = await this.getImpl(prefixedName);\n      if (ret == null) {\n        // Clear any cookies to keep things in sync.\n        this.deletePrefixedName(prefixedName);\n      }\n      return ret;\n    } catch (error) {\n      this.deletePrefixedName(prefixedName);\n      throw error;\n    }\n  }\n\n  private async getImpl(name: string): Promise<any> {\n    const itemString = localStorage.getItem(name);\n    if (!itemString) {\n      return null;\n    }\n\n    const item: Item = JSON.parse(itemString);\n\n    let data: any;\n\n    if (item.expiry) {\n      const cookieItemString = this.cookieService.get(name);\n      if (!cookieItemString) {\n        // Probably expired, but we won't make any interpretations since if we only used\n        // cookies we can't tell if it's expired or explicitly removed. So we just make\n        // the behaviour here consistent with that.\n        console.log('No cookie.');\n        return null;\n      }\n\n      const cookieItem = JSON.parse(cookieItemString);\n\n      const key = await KFS.asKey(cookieItem.key);\n\n      data = await this.encryptionService.decrypt(key, item.data);\n    } else {\n      data = item.data;\n    }\n\n    if (item.serverSession) {\n      data = await this.encryptionService.decrypt(\n        this.serverSessionEncryptionKey,\n        data\n      );\n    }\n\n    return data;\n  }\n}\n"]}
@@ -1,119 +0,0 @@
1
- import { __awaiter } from "tslib";
2
- import { Injectable } from '@angular/core';
3
- import gql from 'graphql-tag';
4
- import { EncryptionService } from '../cryptography/encryption.service';
5
- import { KeyGraphService } from '../cryptography/key-graph.service';
6
- import { KeyService } from '../cryptography/key.service';
7
- import { ContactCardName } from '../users/profile.types';
8
- import { LrApolloService } from './lr-apollo.service';
9
- import * as i0 from "@angular/core";
10
- import * as i1 from "../cryptography/key.service";
11
- import * as i2 from "./lr-apollo.service";
12
- import * as i3 from "../cryptography/key-graph.service";
13
- import * as i4 from "../cryptography/encryption.service";
14
- export const SharedContactCardFields = `
15
- id
16
- owner {
17
- id
18
- username
19
- }
20
- ownerKey {
21
- id
22
- }
23
- ownerCipherData
24
- receiver {
25
- id
26
- username
27
- }
28
- receiverKey {
29
- id
30
- }
31
- receiverCipherData
32
- sharedKey {
33
- id
34
- }
35
- sharedCipherData
36
- sharedCipherDataSig
37
- sharedCipherDataSigPxk {
38
- id
39
- }
40
- `;
41
- const UpdateOwnedContactCard = gql `
42
- mutation UpdateOwnedContactCard(
43
- $input: UpdateOwnedContactCardInput!
44
- ) {
45
- updateOwnedContactCard(
46
- input: $input
47
- ) {
48
- ownedContactCard {
49
- ${SharedContactCardFields}
50
- }
51
- }
52
- }`;
53
- export class SharedContactCardService {
54
- constructor(keyService, lrApollo, keyGraph, encryptionService) {
55
- this.keyService = keyService;
56
- this.lrApollo = lrApollo;
57
- this.keyGraph = keyGraph;
58
- this.encryptionService = encryptionService;
59
- }
60
- decryptSharedTrustedPartyDetails(cc) {
61
- return __awaiter(this, void 0, void 0, function* () {
62
- const details = yield this.decryptTrustedPartyDetails(cc);
63
- return Object.assign({ id: cc.id, ownedKeyId: cc.ownerKey.id, sharedKeyId: cc.sharedKey.id }, details);
64
- });
65
- }
66
- decryptTrustedPartyDetails(cc) {
67
- return __awaiter(this, void 0, void 0, function* () {
68
- if (cc && cc.sharedKey && cc.sharedCipherData) {
69
- try {
70
- return yield this.encryptionService.decrypt(yield this.keyGraph.getJwkKey(cc.sharedKey.id), cc.sharedCipherData);
71
- }
72
- catch (e) {
73
- console.error('Cannot decrypt trusted party details', e);
74
- }
75
- }
76
- return null;
77
- });
78
- }
79
- updateMySharedContactCard(id, ownedKeyId, sharedKeyId, contactCard) {
80
- return __awaiter(this, void 0, void 0, function* () {
81
- const ownerKey = yield this.keyGraph.getKey(ownedKeyId);
82
- const sharedKey = yield this.keyGraph.getKey(sharedKeyId);
83
- const sigPxk = yield this.keyService.getCurrentSigPxk();
84
- const sharedCipherData = yield this.encryptionService.encrypt(sharedKey.jwk, contactCard);
85
- const sharedCipherDataSig = JSON.stringify(yield this.encryptionService.sign(sigPxk.jwk, sharedCipherData));
86
- const ownerPlainData = {
87
- name: new ContactCardName(contactCard.name),
88
- };
89
- const ownerPlainDataSig = JSON.stringify(yield this.encryptionService.sign(sigPxk.jwk, ownerPlainData));
90
- yield this.lrApollo.mutate({
91
- mutation: UpdateOwnedContactCard,
92
- variables: {
93
- input: {
94
- id,
95
- ownerCipherData: '',
96
- ownerKeyId: ownerKey.id,
97
- sharedCipherDataSig,
98
- sharedKeyId: sharedKey.id,
99
- sigPxkId: sigPxk.id,
100
- ownerPlainDataSig,
101
- },
102
- },
103
- });
104
- });
105
- }
106
- }
107
- SharedContactCardService.ɵprov = i0.ɵɵdefineInjectable({ factory: function SharedContactCardService_Factory() { return new SharedContactCardService(i0.ɵɵinject(i1.KeyService), i0.ɵɵinject(i2.LrApolloService), i0.ɵɵinject(i3.KeyGraphService), i0.ɵɵinject(i4.EncryptionService)); }, token: SharedContactCardService, providedIn: "root" });
108
- SharedContactCardService.decorators = [
109
- { type: Injectable, args: [{
110
- providedIn: 'root',
111
- },] }
112
- ];
113
- SharedContactCardService.ctorParameters = () => [
114
- { type: KeyService },
115
- { type: LrApolloService },
116
- { type: KeyGraphService },
117
- { type: EncryptionService }
118
- ];
119
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"shared-contact-card.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/api/shared-contact-card.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport gql from 'graphql-tag';\nimport { Key } from '../cryptography/cryptography.types';\nimport { EncryptionService } from '../cryptography/encryption.service';\nimport { KeyGraphService } from '../cryptography/key-graph.service';\nimport { KeyService } from '../cryptography/key.service';\nimport { SharedTrustedPartyDetails } from '../trusted-parties/trusted-party.types';\nimport { ContactCardName, TrustedPartyDetails } from '../users/profile.types';\nimport { User } from '../users/user.types';\nimport { KeyGraphField } from '../_common/queries.gql';\nimport { LrApolloService } from './lr-apollo.service';\nimport { JSONObject } from './types';\n\nexport const SharedContactCardFields = `\n  id\n  owner {\n    id\n    username\n  }\n  ownerKey {\n    id\n  }\n  ownerCipherData\n  receiver {\n    id\n    username\n  }\n  receiverKey {\n    id\n  }\n  receiverCipherData\n  sharedKey {\n    id\n  }\n  sharedCipherData\n  sharedCipherDataSig\n  sharedCipherDataSigPxk {\n    id\n  }\n`;\n\nconst UpdateOwnedContactCard = gql`\nmutation UpdateOwnedContactCard(\n  $input: UpdateOwnedContactCardInput!\n) {\n  updateOwnedContactCard(\n    input: $input\n  ) {\n    ownedContactCard {\n      ${SharedContactCardFields}\n    }\n  }\n}`;\n\ninterface UpdateOwnedContactCard {\n  updateOwnedContactCard: {\n    ownedContactCard: SharedContactCard;\n  };\n}\n\nexport interface SharedContactCard {\n  id: string;\n  owner: User;\n  ownerKey: Key;\n  ownerCipherData: string;\n  receiver: User;\n  receiverKey: Key;\n  receiverCipherData: string;\n  sharedKey: Key;\n  sharedCipherData: string;\n  // Decrypted\n  plainOwnerCipherDataJson: JSONObject;\n  plainReceiverCipherDataJson: JSONObject;\n  plainSharedCipherDataJson: JSONObject;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class SharedContactCardService {\n  constructor(\n    private keyService: KeyService,\n    private lrApollo: LrApolloService,\n    private keyGraph: KeyGraphService,\n    private encryptionService: EncryptionService\n  ) {}\n\n  async decryptSharedTrustedPartyDetails(\n    cc: SharedContactCard\n  ): Promise<SharedTrustedPartyDetails> {\n    const details = await this.decryptTrustedPartyDetails(cc);\n\n    return {\n      id: cc.id,\n      ownedKeyId: cc.ownerKey.id,\n      sharedKeyId: cc.sharedKey.id,\n      ...details,\n    };\n  }\n\n  async decryptTrustedPartyDetails(\n    cc: SharedContactCard\n  ): Promise<TrustedPartyDetails> {\n    if (cc && cc.sharedKey && cc.sharedCipherData) {\n      try {\n        return await this.encryptionService.decrypt(\n          await this.keyGraph.getJwkKey(cc.sharedKey.id),\n          cc.sharedCipherData\n        );\n      } catch (e) {\n        console.error('Cannot decrypt trusted party details', e);\n      }\n    }\n    return null;\n  }\n\n  async updateMySharedContactCard(\n    id: string,\n    ownedKeyId: string,\n    sharedKeyId: string,\n    contactCard: TrustedPartyDetails\n  ): Promise<void> {\n    const ownerKey = await this.keyGraph.getKey(ownedKeyId);\n    const sharedKey = await this.keyGraph.getKey(sharedKeyId);\n    const sigPxk = await this.keyService.getCurrentSigPxk();\n\n    const sharedCipherData = await this.encryptionService.encrypt(\n      sharedKey.jwk,\n      contactCard\n    );\n    const sharedCipherDataSig = JSON.stringify(\n      await this.encryptionService.sign(sigPxk.jwk, sharedCipherData)\n    );\n\n    const ownerPlainData = {\n      name: new ContactCardName(contactCard.name),\n    };\n    const ownerPlainDataSig = JSON.stringify(\n      await this.encryptionService.sign(sigPxk.jwk, ownerPlainData)\n    );\n\n    await this.lrApollo.mutate<UpdateOwnedContactCard>({\n      mutation: UpdateOwnedContactCard,\n      variables: {\n        input: {\n          id,\n          ownerCipherData: '',\n          ownerKeyId: ownerKey.id,\n          sharedCipherDataSig,\n          sharedKeyId: sharedKey.id,\n          sigPxkId: sigPxk.id,\n          ownerPlainDataSig,\n        },\n      },\n    });\n  }\n}\n"]}