@lifeready/core 1.0.13 → 1.0.15

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 (219) hide show
  1. package/README.md +62 -62
  2. package/bundles/lifeready-core.umd.js +14315 -14315
  3. package/bundles/lifeready-core.umd.js.map +1 -1
  4. package/bundles/lifeready-core.umd.min.js.map +1 -1
  5. package/esm2015/lib/_common/ast.js +40 -40
  6. package/esm2015/lib/_common/deferred-promise.js +24 -24
  7. package/esm2015/lib/_common/exceptions.js +157 -157
  8. package/esm2015/lib/_common/queries.gql.js +190 -190
  9. package/esm2015/lib/_common/run-outside-angular.js +79 -79
  10. package/esm2015/lib/_common/types.js +1 -1
  11. package/esm2015/lib/_common/utils.js +52 -52
  12. package/esm2015/lib/api/contact-card.gql.js +79 -79
  13. package/esm2015/lib/api/contact-card.service.js +154 -154
  14. package/esm2015/lib/api/contact-card2.gql.js +60 -60
  15. package/esm2015/lib/api/contact-card2.service.js +103 -103
  16. package/esm2015/lib/api/file.service.js +74 -74
  17. package/esm2015/lib/api/key-exchange.gql.js +188 -188
  18. package/esm2015/lib/api/key-exchange.service.js +442 -442
  19. package/esm2015/lib/api/key-exchange.types.js +18 -18
  20. package/esm2015/lib/api/key-exchange2.gql.js +171 -171
  21. package/esm2015/lib/api/key-exchange2.service.js +479 -479
  22. package/esm2015/lib/api/lock.gql.js +40 -40
  23. package/esm2015/lib/api/lock.service.js +64 -64
  24. package/esm2015/lib/api/lr-apollo.service.js +46 -46
  25. package/esm2015/lib/api/lr-graphql/index.js +6 -6
  26. package/esm2015/lib/api/lr-graphql/lr-graphql.service.js +155 -155
  27. package/esm2015/lib/api/lr-graphql/lr-merged-mutation.js +213 -213
  28. package/esm2015/lib/api/lr-graphql/lr-mutation-base.js +51 -51
  29. package/esm2015/lib/api/lr-graphql/lr-mutation.js +48 -48
  30. package/esm2015/lib/api/lr-graphql/lr.service.js +18 -18
  31. package/esm2015/lib/api/message.service.js +138 -138
  32. package/esm2015/lib/api/persist.service.js +181 -181
  33. package/esm2015/lib/api/query-processor/common-processors.service.js +93 -93
  34. package/esm2015/lib/api/query-processor/index.js +3 -3
  35. package/esm2015/lib/api/query-processor/query-processor.service.js +262 -262
  36. package/esm2015/lib/api/query-processor/tp-password-reset-processor.service.js +109 -109
  37. package/esm2015/lib/api/shared-contact-card.service.js +119 -119
  38. package/esm2015/lib/api/shared-contact-card2.gql.js +41 -41
  39. package/esm2015/lib/api/shared-contact-card2.service.js +117 -117
  40. package/esm2015/lib/api/time.service.js +146 -146
  41. package/esm2015/lib/api/types/graphql.types.js +7 -7
  42. package/esm2015/lib/api/types/index.js +3 -3
  43. package/esm2015/lib/api/types/lr-graphql.types.js +101 -101
  44. package/esm2015/lib/auth/auth.config.js +57 -57
  45. package/esm2015/lib/auth/auth.gql.js +48 -48
  46. package/esm2015/lib/auth/auth.types.js +27 -27
  47. package/esm2015/lib/auth/idle.service.js +168 -168
  48. package/esm2015/lib/auth/idle.types.js +7 -7
  49. package/esm2015/lib/auth/lbop.service.js +355 -355
  50. package/esm2015/lib/auth/life-ready-auth.service.js +488 -488
  51. package/esm2015/lib/auth/password.service.js +320 -320
  52. package/esm2015/lib/auth/register.service.js +172 -172
  53. package/esm2015/lib/auth/two-factor.service.js +74 -74
  54. package/esm2015/lib/category/category-meta.service.js +99 -99
  55. package/esm2015/lib/category/category.gql.js +406 -406
  56. package/esm2015/lib/category/category.service.js +390 -390
  57. package/esm2015/lib/category/category.types.js +29 -29
  58. package/esm2015/lib/cryptography/cryptography.types.js +11 -11
  59. package/esm2015/lib/cryptography/encryption.service.js +189 -189
  60. package/esm2015/lib/cryptography/key-factory.service.js +237 -237
  61. package/esm2015/lib/cryptography/key-graph.service.js +299 -299
  62. package/esm2015/lib/cryptography/key-meta.service.js +200 -200
  63. package/esm2015/lib/cryptography/key.service.js +124 -124
  64. package/esm2015/lib/cryptography/slip39.service.js +169 -169
  65. package/esm2015/lib/cryptography/web-crypto.service.js +29 -29
  66. package/esm2015/lib/items2/item2.gql.js +139 -139
  67. package/esm2015/lib/items2/item2.service.js +498 -498
  68. package/esm2015/lib/items2/item2.types.js +1 -1
  69. package/esm2015/lib/life-ready.config.js +84 -84
  70. package/esm2015/lib/life-ready.module.js +74 -74
  71. package/esm2015/lib/notification/notification.gql.js +43 -43
  72. package/esm2015/lib/notification/notification.service.js +118 -118
  73. package/esm2015/lib/plan/plan.gql.js +123 -123
  74. package/esm2015/lib/plan/plan.service.js +149 -149
  75. package/esm2015/lib/plan/plan.types.js +11 -11
  76. package/esm2015/lib/record/record-attachment.service.js +101 -101
  77. package/esm2015/lib/record/record.gql.js +179 -179
  78. package/esm2015/lib/record/record.service.js +206 -206
  79. package/esm2015/lib/record/record.types.js +15 -15
  80. package/esm2015/lib/record-type/record-type.service.js +75 -75
  81. package/esm2015/lib/record-type/record-type.types.js +28 -28
  82. package/esm2015/lib/scenario/scenario.constants.js +2 -2
  83. package/esm2015/lib/scenario/scenario.controller.js +34 -34
  84. package/esm2015/lib/scenario/scenario.gql.js +72 -72
  85. package/esm2015/lib/scenario/scenario.gql.private.js +198 -198
  86. package/esm2015/lib/scenario/scenario.service.js +538 -538
  87. package/esm2015/lib/scenario/scenario.types.js +1 -1
  88. package/esm2015/lib/trusted-parties/tp-assembly.gql.private.js +22 -22
  89. package/esm2015/lib/trusted-parties/tp-assembly.js +362 -362
  90. package/esm2015/lib/trusted-parties/tp-assembly.types.js +1 -1
  91. package/esm2015/lib/trusted-parties/tp-password-reset-request.service.js +113 -113
  92. package/esm2015/lib/trusted-parties/tp-password-reset-user.service.js +129 -129
  93. package/esm2015/lib/trusted-parties/tp-password-reset.constants.js +4 -4
  94. package/esm2015/lib/trusted-parties/tp-password-reset.controller.js +34 -34
  95. package/esm2015/lib/trusted-parties/tp-password-reset.gql.js +236 -236
  96. package/esm2015/lib/trusted-parties/tp-password-reset.service.js +95 -95
  97. package/esm2015/lib/trusted-parties/trusted-party.gql.js +148 -148
  98. package/esm2015/lib/trusted-parties/trusted-party.service.js +326 -326
  99. package/esm2015/lib/trusted-parties/trusted-party.types.js +41 -41
  100. package/esm2015/lib/trusted-parties/trusted-party2.gql.js +87 -87
  101. package/esm2015/lib/trusted-parties/trusted-party2.service.js +215 -215
  102. package/esm2015/lib/users/profile-details.service.js +214 -214
  103. package/esm2015/lib/users/profile.gql.js +97 -97
  104. package/esm2015/lib/users/profile.service.js +169 -169
  105. package/esm2015/lib/users/profile.types.js +34 -34
  106. package/esm2015/lib/users/user.gql.js +60 -60
  107. package/esm2015/lib/users/user.service.js +79 -79
  108. package/esm2015/lib/users/user.types.js +5 -5
  109. package/esm2015/lifeready-core.js +13 -13
  110. package/esm2015/public-api.js +71 -71
  111. package/fesm2015/lifeready-core.js +12258 -12258
  112. package/fesm2015/lifeready-core.js.map +1 -1
  113. package/lib/_common/ast.d.ts +11 -11
  114. package/lib/_common/deferred-promise.d.ts +12 -12
  115. package/lib/_common/exceptions.d.ts +109 -109
  116. package/lib/_common/queries.gql.d.ts +10 -10
  117. package/lib/_common/run-outside-angular.d.ts +14 -14
  118. package/lib/_common/types.d.ts +10 -10
  119. package/lib/_common/utils.d.ts +9 -9
  120. package/lib/api/contact-card.gql.d.ts +7 -7
  121. package/lib/api/contact-card.service.d.ts +52 -52
  122. package/lib/api/contact-card2.gql.d.ts +34 -34
  123. package/lib/api/contact-card2.service.d.ts +49 -49
  124. package/lib/api/file.service.d.ts +18 -18
  125. package/lib/api/key-exchange.gql.d.ts +9 -9
  126. package/lib/api/key-exchange.service.d.ts +39 -39
  127. package/lib/api/key-exchange.types.d.ts +196 -196
  128. package/lib/api/key-exchange2.gql.d.ts +125 -125
  129. package/lib/api/key-exchange2.service.d.ts +187 -187
  130. package/lib/api/lock.gql.d.ts +27 -27
  131. package/lib/api/lock.service.d.ts +34 -34
  132. package/lib/api/lr-apollo.service.d.ts +15 -15
  133. package/lib/api/lr-graphql/index.d.ts +5 -5
  134. package/lib/api/lr-graphql/lr-graphql.service.d.ts +60 -60
  135. package/lib/api/lr-graphql/lr-merged-mutation.d.ts +28 -28
  136. package/lib/api/lr-graphql/lr-mutation-base.d.ts +28 -28
  137. package/lib/api/lr-graphql/lr-mutation.d.ts +8 -8
  138. package/lib/api/lr-graphql/lr.service.d.ts +9 -9
  139. package/lib/api/message.service.d.ts +58 -58
  140. package/lib/api/persist.service.d.ts +31 -31
  141. package/lib/api/query-processor/common-processors.service.d.ts +36 -36
  142. package/lib/api/query-processor/index.d.ts +2 -2
  143. package/lib/api/query-processor/query-processor.service.d.ts +18 -18
  144. package/lib/api/query-processor/tp-password-reset-processor.service.d.ts +15 -15
  145. package/lib/api/shared-contact-card.service.d.ts +33 -33
  146. package/lib/api/shared-contact-card2.gql.d.ts +36 -36
  147. package/lib/api/shared-contact-card2.service.d.ts +45 -45
  148. package/lib/api/time.service.d.ts +16 -16
  149. package/lib/api/types/graphql.types.d.ts +29 -29
  150. package/lib/api/types/index.d.ts +2 -2
  151. package/lib/api/types/lr-graphql.types.d.ts +502 -502
  152. package/lib/auth/auth.config.d.ts +5 -5
  153. package/lib/auth/auth.gql.d.ts +15 -15
  154. package/lib/auth/auth.types.d.ts +66 -66
  155. package/lib/auth/idle.service.d.ts +40 -40
  156. package/lib/auth/idle.types.d.ts +10 -10
  157. package/lib/auth/lbop.service.d.ts +91 -91
  158. package/lib/auth/life-ready-auth.service.d.ts +61 -61
  159. package/lib/auth/password.service.d.ts +78 -78
  160. package/lib/auth/register.service.d.ts +25 -25
  161. package/lib/auth/two-factor.service.d.ts +15 -15
  162. package/lib/category/category-meta.service.d.ts +23 -23
  163. package/lib/category/category.gql.d.ts +45 -45
  164. package/lib/category/category.service.d.ts +67 -67
  165. package/lib/category/category.types.d.ts +79 -79
  166. package/lib/cryptography/cryptography.types.d.ts +83 -83
  167. package/lib/cryptography/encryption.service.d.ts +41 -41
  168. package/lib/cryptography/key-factory.service.d.ts +38 -38
  169. package/lib/cryptography/key-graph.service.d.ts +41 -41
  170. package/lib/cryptography/key-meta.service.d.ts +44 -44
  171. package/lib/cryptography/key.service.d.ts +36 -36
  172. package/lib/cryptography/slip39.service.d.ts +43 -43
  173. package/lib/cryptography/web-crypto.service.d.ts +5 -5
  174. package/lib/items2/item2.gql.d.ts +123 -123
  175. package/lib/items2/item2.service.d.ts +203 -203
  176. package/lib/items2/item2.types.d.ts +70 -70
  177. package/lib/life-ready.config.d.ts +14 -14
  178. package/lib/life-ready.module.d.ts +5 -5
  179. package/lib/notification/notification.gql.d.ts +37 -37
  180. package/lib/notification/notification.service.d.ts +63 -63
  181. package/lib/plan/plan.gql.d.ts +11 -11
  182. package/lib/plan/plan.service.d.ts +33 -33
  183. package/lib/plan/plan.types.d.ts +31 -31
  184. package/lib/record/record-attachment.service.d.ts +16 -16
  185. package/lib/record/record.gql.d.ts +14 -14
  186. package/lib/record/record.service.d.ts +25 -25
  187. package/lib/record/record.types.d.ts +57 -57
  188. package/lib/record-type/record-type.service.d.ts +11 -11
  189. package/lib/record-type/record-type.types.d.ts +50 -50
  190. package/lib/scenario/scenario.constants.d.ts +1 -1
  191. package/lib/scenario/scenario.controller.d.ts +10 -10
  192. package/lib/scenario/scenario.gql.d.ts +62 -62
  193. package/lib/scenario/scenario.gql.private.d.ts +16 -16
  194. package/lib/scenario/scenario.service.d.ts +233 -233
  195. package/lib/scenario/scenario.types.d.ts +50 -50
  196. package/lib/trusted-parties/tp-assembly.d.ts +177 -177
  197. package/lib/trusted-parties/tp-assembly.gql.private.d.ts +5 -5
  198. package/lib/trusted-parties/tp-assembly.types.d.ts +38 -38
  199. package/lib/trusted-parties/tp-password-reset-request.service.d.ts +20 -20
  200. package/lib/trusted-parties/tp-password-reset-user.service.d.ts +35 -35
  201. package/lib/trusted-parties/tp-password-reset.constants.d.ts +3 -3
  202. package/lib/trusted-parties/tp-password-reset.controller.d.ts +10 -10
  203. package/lib/trusted-parties/tp-password-reset.gql.d.ts +223 -223
  204. package/lib/trusted-parties/tp-password-reset.service.d.ts +188 -188
  205. package/lib/trusted-parties/trusted-party.gql.d.ts +9 -9
  206. package/lib/trusted-parties/trusted-party.service.d.ts +44 -44
  207. package/lib/trusted-parties/trusted-party.types.d.ts +102 -102
  208. package/lib/trusted-parties/trusted-party2.gql.d.ts +79 -79
  209. package/lib/trusted-parties/trusted-party2.service.d.ts +114 -114
  210. package/lib/users/profile-details.service.d.ts +21 -21
  211. package/lib/users/profile.gql.d.ts +11 -11
  212. package/lib/users/profile.service.d.ts +35 -35
  213. package/lib/users/profile.types.d.ts +96 -96
  214. package/lib/users/user.gql.d.ts +9 -9
  215. package/lib/users/user.service.d.ts +12 -12
  216. package/lib/users/user.types.d.ts +23 -23
  217. package/lifeready-core.d.ts +12 -12
  218. package/package.json +1 -1
  219. package/public-api.d.ts +67 -67
@@ -1,27 +1,27 @@
1
- import { CognitoUser } from '@aws-amplify/auth';
2
- export class CognitoChallengeUser extends CognitoUser {
3
- constructor() {
4
- super(...arguments);
5
- this.isTpPasswordResetUser = false;
6
- }
7
- }
8
- export var FeatureAction;
9
- (function (FeatureAction) {
10
- // Just the one for now
11
- FeatureAction["ACCESS"] = "access";
12
- })(FeatureAction || (FeatureAction = {}));
13
- export class Features {
14
- }
15
- export class CurrentUser {
16
- }
17
- export class LoginResult {
18
- }
19
- export class RegisterResult {
20
- }
21
- export var RecoveryStatus;
22
- (function (RecoveryStatus) {
23
- RecoveryStatus["NONE"] = "none";
24
- RecoveryStatus["NEW_PASSWORD"] = "new-password";
25
- RecoveryStatus["OLD_PASSWORD"] = "old-password";
26
- })(RecoveryStatus || (RecoveryStatus = {}));
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIvb3B0L2F0bGFzc2lhbi9waXBlbGluZXMvYWdlbnQvYnVpbGQvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJsaWIvYXV0aC9hdXRoLnR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQW9CaEQsTUFBTSxPQUFPLG9CQUFxQixTQUFRLFdBQVc7SUFBckQ7O1FBSUUsMEJBQXFCLEdBQUcsS0FBSyxDQUFDO0lBQ2hDLENBQUM7Q0FBQTtBQUVELE1BQU0sQ0FBTixJQUFZLGFBR1g7QUFIRCxXQUFZLGFBQWE7SUFDdkIsdUJBQXVCO0lBQ3ZCLGtDQUFpQixDQUFBO0FBQ25CLENBQUMsRUFIVyxhQUFhLEtBQWIsYUFBYSxRQUd4QjtBQUVELE1BQU0sT0FBTyxRQUFRO0NBSXBCO0FBRUQsTUFBTSxPQUFPLFdBQVc7Q0FnQnZCO0FBTUQsTUFBTSxPQUFPLFdBQVc7Q0FLdkI7QUFFRCxNQUFNLE9BQU8sY0FBYztDQUsxQjtBQUVELE1BQU0sQ0FBTixJQUFZLGNBSVg7QUFKRCxXQUFZLGNBQWM7SUFDeEIsK0JBQWEsQ0FBQTtJQUNiLCtDQUE2QixDQUFBO0lBQzdCLCtDQUE2QixDQUFBO0FBQy9CLENBQUMsRUFKVyxjQUFjLEtBQWQsY0FBYyxRQUl6QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvZ25pdG9Vc2VyIH0gZnJvbSAnQGF3cy1hbXBsaWZ5L2F1dGgnO1xuaW1wb3J0IHsgSldLIH0gZnJvbSAnbm9kZS1qb3NlJztcbmltcG9ydCB7IFRwUGFzc3dvcmRSZXNldFVzZXJOb2RlIH0gZnJvbSAnLi4vYXBpL3R5cGVzJztcbmltcG9ydCB7XG4gIFBhc3NJZHBQYXJhbXMsXG4gIFBhc3NLZXlQYXJhbXMsXG59IGZyb20gJy4uL2NyeXB0b2dyYXBoeS9jcnlwdG9ncmFwaHkudHlwZXMnO1xuaW1wb3J0IHsgVXNlclBsYW4gfSBmcm9tICcuLi9wbGFuL3BsYW4udHlwZXMnO1xuaW1wb3J0IHsgQ3VycmVudFVzZXJLZXksIE1haW5Db250YWN0Q2FyZCB9IGZyb20gJy4uL3VzZXJzL3Byb2ZpbGUudHlwZXMnO1xuaW1wb3J0IHsgVXNlckRlbGV0ZSB9IGZyb20gJy4uL3VzZXJzL3VzZXIudHlwZXMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFBhc3NLZXlCdW5kbGUge1xuICBwYXNzS2V5UGFyYW1zOiBQYXNzS2V5UGFyYW1zO1xuICBwYXNzS2V5OiBKV0suS2V5O1xuICBwYXNzSWRwUGFyYW1zOiBQYXNzSWRwUGFyYW1zO1xuICBwYXNzSWRwOiBKV0suS2V5O1xuICBwYXNzSWRwVmVyaWZpZXI6IEpXSy5LZXk7XG4gIHdyYXBwZWRQYXNzSWRwVmVyaWZpZXJQcms6IG9iamVjdDtcbn1cblxuZXhwb3J0IGNsYXNzIENvZ25pdG9DaGFsbGVuZ2VVc2VyIGV4dGVuZHMgQ29nbml0b1VzZXIge1xuICByZWNvdmVyeVN0YXR1czogUmVjb3ZlcnlTdGF0dXM7XG4gIGNoYWxsZW5nZU5hbWU6ICdTTVNfTUZBJyB8ICdTT0ZUV0FSRV9UT0tFTl9NRkEnO1xuICBjaGFsbGVuZ2VQYXJhbTogYW55O1xuICBpc1RwUGFzc3dvcmRSZXNldFVzZXIgPSBmYWxzZTtcbn1cblxuZXhwb3J0IGVudW0gRmVhdHVyZUFjdGlvbiB7XG4gIC8vIEp1c3QgdGhlIG9uZSBmb3Igbm93XG4gIEFDQ0VTUyA9ICdhY2Nlc3MnLFxufVxuXG5leHBvcnQgY2xhc3MgRmVhdHVyZXMge1xuICBteVZhdWx0OiBGZWF0dXJlQWN0aW9uW107XG4gIHRwVmF1bHQ6IEZlYXR1cmVBY3Rpb25bXTtcbiAgc2hhcmVWYXVsdDogRmVhdHVyZUFjdGlvbltdO1xufVxuXG5leHBvcnQgY2xhc3MgQ3VycmVudFVzZXIge1xuICBpZDogc3RyaW5nO1xuICBzdWI6IHN0cmluZztcbiAgdXNlcm5hbWU6IHN0cmluZztcbiAgY3VycmVudFVzZXJLZXk6IEN1cnJlbnRVc2VyS2V5O1xuICBlbWFpbDogc3RyaW5nO1xuICBlbWFpbFZlcmlmaWVkOiBib29sZWFuO1xuICBwaG9uZTogc3RyaW5nO1xuICBwaG9uZVZlcmlmaWVkOiBib29sZWFuO1xuICBnZXRBY2Nlc3NKd3RUb2tlbjogKCkgPT4gc3RyaW5nO1xuICBjb250YWN0Q2FyZDogTWFpbkNvbnRhY3RDYXJkO1xuICB1c2VyRGVsZXRlPzogVXNlckRlbGV0ZTtcbiAgdXNlclBsYW5zOiBVc2VyUGxhbltdO1xuICBmZWF0dXJlczogRmVhdHVyZXM7XG4gIGhhc1RQVmF1bHRBY2Nlc3M6IGJvb2xlYW47XG4gIHNlc3Npb25FbmNyeXB0aW9uS2V5OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHBQYXNzd29yZFJlc2V0VXNlciBleHRlbmRzIFRwUGFzc3dvcmRSZXNldFVzZXJOb2RlIHtcbiAgc3ViOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjbGFzcyBMb2dpblJlc3VsdCB7XG4gIGhhc0NoYWxsZW5nZTogYm9vbGVhbjtcbiAgY2hhbGxlbmdlPzogQ29nbml0b0NoYWxsZW5nZVVzZXI7XG4gIHVzZXI/OiBDdXJyZW50VXNlcjtcbiAgcmVzZXRVc2VyPzogVHBQYXNzd29yZFJlc2V0VXNlck5vZGU7XG59XG5cbmV4cG9ydCBjbGFzcyBSZWdpc3RlclJlc3VsdCB7XG4gIHVzZXJuYW1lOiBzdHJpbmc7XG4gIHVzZXJJZDogc3RyaW5nO1xuICBwcmVTaWduVXBUb2tlbjogc3RyaW5nO1xuICB1c2VyU3ViOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBlbnVtIFJlY292ZXJ5U3RhdHVzIHtcbiAgTk9ORSA9ICdub25lJyxcbiAgTkVXX1BBU1NXT1JEID0gJ25ldy1wYXNzd29yZCcsXG4gIE9MRF9QQVNTV09SRCA9ICdvbGQtcGFzc3dvcmQnLFxufVxuIl19
1
+ import { CognitoUser } from '@aws-amplify/auth';
2
+ export class CognitoChallengeUser extends CognitoUser {
3
+ constructor() {
4
+ super(...arguments);
5
+ this.isTpPasswordResetUser = false;
6
+ }
7
+ }
8
+ export var FeatureAction;
9
+ (function (FeatureAction) {
10
+ // Just the one for now
11
+ FeatureAction["ACCESS"] = "access";
12
+ })(FeatureAction || (FeatureAction = {}));
13
+ export class Features {
14
+ }
15
+ export class CurrentUser {
16
+ }
17
+ export class LoginResult {
18
+ }
19
+ export class RegisterResult {
20
+ }
21
+ export var RecoveryStatus;
22
+ (function (RecoveryStatus) {
23
+ RecoveryStatus["NONE"] = "none";
24
+ RecoveryStatus["NEW_PASSWORD"] = "new-password";
25
+ RecoveryStatus["OLD_PASSWORD"] = "old-password";
26
+ })(RecoveryStatus || (RecoveryStatus = {}));
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiJDOi9Qcm9qZWN0cy9rYy1jbGllbnQvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJsaWIvYXV0aC9hdXRoLnR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQW9CaEQsTUFBTSxPQUFPLG9CQUFxQixTQUFRLFdBQVc7SUFBckQ7O1FBSUUsMEJBQXFCLEdBQUcsS0FBSyxDQUFDO0lBQ2hDLENBQUM7Q0FBQTtBQUVELE1BQU0sQ0FBTixJQUFZLGFBR1g7QUFIRCxXQUFZLGFBQWE7SUFDdkIsdUJBQXVCO0lBQ3ZCLGtDQUFpQixDQUFBO0FBQ25CLENBQUMsRUFIVyxhQUFhLEtBQWIsYUFBYSxRQUd4QjtBQUVELE1BQU0sT0FBTyxRQUFRO0NBSXBCO0FBRUQsTUFBTSxPQUFPLFdBQVc7Q0FnQnZCO0FBTUQsTUFBTSxPQUFPLFdBQVc7Q0FLdkI7QUFFRCxNQUFNLE9BQU8sY0FBYztDQUsxQjtBQUVELE1BQU0sQ0FBTixJQUFZLGNBSVg7QUFKRCxXQUFZLGNBQWM7SUFDeEIsK0JBQWEsQ0FBQTtJQUNiLCtDQUE2QixDQUFBO0lBQzdCLCtDQUE2QixDQUFBO0FBQy9CLENBQUMsRUFKVyxjQUFjLEtBQWQsY0FBYyxRQUl6QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvZ25pdG9Vc2VyIH0gZnJvbSAnQGF3cy1hbXBsaWZ5L2F1dGgnO1xyXG5pbXBvcnQgeyBKV0sgfSBmcm9tICdub2RlLWpvc2UnO1xyXG5pbXBvcnQgeyBUcFBhc3N3b3JkUmVzZXRVc2VyTm9kZSB9IGZyb20gJy4uL2FwaS90eXBlcyc7XHJcbmltcG9ydCB7XHJcbiAgUGFzc0lkcFBhcmFtcyxcclxuICBQYXNzS2V5UGFyYW1zLFxyXG59IGZyb20gJy4uL2NyeXB0b2dyYXBoeS9jcnlwdG9ncmFwaHkudHlwZXMnO1xyXG5pbXBvcnQgeyBVc2VyUGxhbiB9IGZyb20gJy4uL3BsYW4vcGxhbi50eXBlcyc7XHJcbmltcG9ydCB7IEN1cnJlbnRVc2VyS2V5LCBNYWluQ29udGFjdENhcmQgfSBmcm9tICcuLi91c2Vycy9wcm9maWxlLnR5cGVzJztcclxuaW1wb3J0IHsgVXNlckRlbGV0ZSB9IGZyb20gJy4uL3VzZXJzL3VzZXIudHlwZXMnO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBQYXNzS2V5QnVuZGxlIHtcclxuICBwYXNzS2V5UGFyYW1zOiBQYXNzS2V5UGFyYW1zO1xyXG4gIHBhc3NLZXk6IEpXSy5LZXk7XHJcbiAgcGFzc0lkcFBhcmFtczogUGFzc0lkcFBhcmFtcztcclxuICBwYXNzSWRwOiBKV0suS2V5O1xyXG4gIHBhc3NJZHBWZXJpZmllcjogSldLLktleTtcclxuICB3cmFwcGVkUGFzc0lkcFZlcmlmaWVyUHJrOiBvYmplY3Q7XHJcbn1cclxuXHJcbmV4cG9ydCBjbGFzcyBDb2duaXRvQ2hhbGxlbmdlVXNlciBleHRlbmRzIENvZ25pdG9Vc2VyIHtcclxuICByZWNvdmVyeVN0YXR1czogUmVjb3ZlcnlTdGF0dXM7XHJcbiAgY2hhbGxlbmdlTmFtZTogJ1NNU19NRkEnIHwgJ1NPRlRXQVJFX1RPS0VOX01GQSc7XHJcbiAgY2hhbGxlbmdlUGFyYW06IGFueTtcclxuICBpc1RwUGFzc3dvcmRSZXNldFVzZXIgPSBmYWxzZTtcclxufVxyXG5cclxuZXhwb3J0IGVudW0gRmVhdHVyZUFjdGlvbiB7XHJcbiAgLy8gSnVzdCB0aGUgb25lIGZvciBub3dcclxuICBBQ0NFU1MgPSAnYWNjZXNzJyxcclxufVxyXG5cclxuZXhwb3J0IGNsYXNzIEZlYXR1cmVzIHtcclxuICBteVZhdWx0OiBGZWF0dXJlQWN0aW9uW107XHJcbiAgdHBWYXVsdDogRmVhdHVyZUFjdGlvbltdO1xyXG4gIHNoYXJlVmF1bHQ6IEZlYXR1cmVBY3Rpb25bXTtcclxufVxyXG5cclxuZXhwb3J0IGNsYXNzIEN1cnJlbnRVc2VyIHtcclxuICBpZDogc3RyaW5nO1xyXG4gIHN1Yjogc3RyaW5nO1xyXG4gIHVzZXJuYW1lOiBzdHJpbmc7XHJcbiAgY3VycmVudFVzZXJLZXk6IEN1cnJlbnRVc2VyS2V5O1xyXG4gIGVtYWlsOiBzdHJpbmc7XHJcbiAgZW1haWxWZXJpZmllZDogYm9vbGVhbjtcclxuICBwaG9uZTogc3RyaW5nO1xyXG4gIHBob25lVmVyaWZpZWQ6IGJvb2xlYW47XHJcbiAgZ2V0QWNjZXNzSnd0VG9rZW46ICgpID0+IHN0cmluZztcclxuICBjb250YWN0Q2FyZDogTWFpbkNvbnRhY3RDYXJkO1xyXG4gIHVzZXJEZWxldGU/OiBVc2VyRGVsZXRlO1xyXG4gIHVzZXJQbGFuczogVXNlclBsYW5bXTtcclxuICBmZWF0dXJlczogRmVhdHVyZXM7XHJcbiAgaGFzVFBWYXVsdEFjY2VzczogYm9vbGVhbjtcclxuICBzZXNzaW9uRW5jcnlwdGlvbktleTogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFRwUGFzc3dvcmRSZXNldFVzZXIgZXh0ZW5kcyBUcFBhc3N3b3JkUmVzZXRVc2VyTm9kZSB7XHJcbiAgc3ViOiBzdHJpbmc7XHJcbn1cclxuXHJcbmV4cG9ydCBjbGFzcyBMb2dpblJlc3VsdCB7XHJcbiAgaGFzQ2hhbGxlbmdlOiBib29sZWFuO1xyXG4gIGNoYWxsZW5nZT86IENvZ25pdG9DaGFsbGVuZ2VVc2VyO1xyXG4gIHVzZXI/OiBDdXJyZW50VXNlcjtcclxuICByZXNldFVzZXI/OiBUcFBhc3N3b3JkUmVzZXRVc2VyTm9kZTtcclxufVxyXG5cclxuZXhwb3J0IGNsYXNzIFJlZ2lzdGVyUmVzdWx0IHtcclxuICB1c2VybmFtZTogc3RyaW5nO1xyXG4gIHVzZXJJZDogc3RyaW5nO1xyXG4gIHByZVNpZ25VcFRva2VuOiBzdHJpbmc7XHJcbiAgdXNlclN1Yjogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgZW51bSBSZWNvdmVyeVN0YXR1cyB7XHJcbiAgTk9ORSA9ICdub25lJyxcclxuICBORVdfUEFTU1dPUkQgPSAnbmV3LXBhc3N3b3JkJyxcclxuICBPTERfUEFTU1dPUkQgPSAnb2xkLXBhc3N3b3JkJyxcclxufVxyXG4iXX0=
@@ -1,168 +1,168 @@
1
- import { __awaiter } from "tslib";
2
- import { Inject, Injectable } from '@angular/core';
3
- import { Idle, DEFAULT_INTERRUPTSOURCES } from '@ng-idle/core';
4
- import { Keepalive } from '@ng-idle/keepalive';
5
- import { KeyService } from '../cryptography/key.service';
6
- import { LrBadArgumentException, LrBadStateException, } from '../_common/exceptions';
7
- import { LR_CONFIG } from '../life-ready.config';
8
- import { HttpClient } from '@angular/common/http';
9
- import { Config } from './idle.types';
10
- import { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';
11
- import * as i0 from "@angular/core";
12
- import * as i1 from "../life-ready.config";
13
- import * as i2 from "@angular/common/http";
14
- import * as i3 from "@ng-idle/core";
15
- import * as i4 from "@ng-idle/keepalive";
16
- import * as i5 from "../cryptography/key.service";
17
- import * as i6 from "@aws-amplify/auth/lib-esm/Auth";
18
- export class IdleService {
19
- constructor(config, http, idle, keepalive, keyService, auth) {
20
- this.config = config;
21
- this.http = http;
22
- this.idle = idle;
23
- this.keepalive = keepalive;
24
- this.keyService = keyService;
25
- this.auth = auth;
26
- this.IDLE_EXPIRY_KEY = 'ng2Idle.main.expiry';
27
- this.IDLING_KEY = 'ng2Idle.main.idling';
28
- this.initCalled = false;
29
- }
30
- assertInit() {
31
- if (!this.initCalled) {
32
- throw new LrBadStateException('Call IdleService.init() first.');
33
- }
34
- }
35
- init(params) {
36
- return __awaiter(this, void 0, void 0, function* () {
37
- if (this.initCalled) {
38
- throw new LrBadStateException('IdleService.init() can only be called once. IdleService.start() calls init() with default values if init() has not been called yet.');
39
- }
40
- this.initCalled = true;
41
- // Defaults
42
- params = Object.assign({ onTimeout: null, onKeepalive: null, idleSec: Config.IDLE, timeoutSec: Config.TIMEOUT, keepAliveIntervalSec: Config.KEEP_ALIVE_INTERVAL }, params);
43
- // If timeoutSec == 0 then the onTimeout() callback is never called.
44
- if (params.timeoutSec < 0.01) {
45
- throw new LrBadArgumentException('Minimum value for IdleService.init({ timeoutSec }) is 0.01');
46
- }
47
- this.onTimeout = params.onTimeout;
48
- this.onKeepalive = params.onKeepalive;
49
- // ------------------------------------------------------------------------
50
- // Setup Idle
51
- // ------------------------------------------------------------------------
52
- // sets an idle timeout of 5 seconds, for testing purposes.
53
- this.idle.setIdle(params.idleSec);
54
- // sets a timeout period of 5 seconds. after 10 seconds of inactivity, the user will be considered timed out.
55
- this.idle.setTimeout(params.timeoutSec);
56
- // sets the default interrupts, in this case, things like clicks, scrolls, touches to the document
57
- this.idle.setInterrupts(DEFAULT_INTERRUPTSOURCES);
58
- this.idle.onIdleEnd.subscribe(() => console.log('Idle stopped'));
59
- this.idle.onIdleStart.subscribe(() => console.log('Idle started'));
60
- this.idle.onTimeout.subscribe(() => __awaiter(this, void 0, void 0, function* () {
61
- console.log('Idle timed out');
62
- this.reset();
63
- yield Promise.resolve(this.onTimeout && this.onTimeout());
64
- }));
65
- this.idle.onTimeoutWarning.subscribe((countdown) => console.log(`Will timeout in ${countdown} seconds!`));
66
- // ------------------------------------------------------------------------
67
- // Setup Keepalive
68
- // ------------------------------------------------------------------------
69
- // Ref: https://github.com/moribvndvs/ng2-idle#readme
70
- // ng-idle will instruct @ng-idle/keepalive to ping while the user is active, and stop once
71
- // they go idle or time out. When the user resumes activity or the idle state is reset, it will
72
- // ping immediately and then resume pinging.
73
- this.keepalive.interval(params.keepAliveIntervalSec);
74
- console.log(`Keep alive interval set at: ${Config.KEEP_ALIVE_INTERVAL} seconds`);
75
- this.keepalive.onPing.subscribe(() => this.onPing());
76
- // If the browser tab has been closed for a period longer thant the inactivity
77
- // period, then we should logout right from the start.
78
- const idleExpiry = localStorage.getItem(this.IDLE_EXPIRY_KEY);
79
- if (idleExpiry &&
80
- parseInt(idleExpiry, 10) + this.idle.getTimeout() * 1000 < Date.now()) {
81
- this.reset();
82
- yield Promise.resolve(this.onTimeout && this.onTimeout());
83
- }
84
- });
85
- }
86
- keepalivePost() {
87
- return __awaiter(this, void 0, void 0, function* () {
88
- // currentAuthenticatedUser() refreshes the access token if required.
89
- const cognitoUser = yield this.auth.currentAuthenticatedUser();
90
- const keepaliveResult = yield this.http
91
- .post(`${this.config.authUrl}auth/keepalive/`, null, {
92
- withCredentials: true,
93
- headers: {
94
- Authorization: `Bearer ${cognitoUser
95
- .getSignInUserSession()
96
- .getAccessToken()
97
- .getJwtToken()}`,
98
- },
99
- })
100
- .toPromise();
101
- return {
102
- keepaliveResult,
103
- expiresAfterSeconds: this.idle.getIdle() +
104
- this.idle.getTimeout() +
105
- this.keepalive.interval(),
106
- };
107
- });
108
- }
109
- persistMasterKey(masterKey) {
110
- return __awaiter(this, void 0, void 0, function* () {
111
- // The keepalive API call extends the server-side session, the session cookie expiry, refresh key cookie
112
- // expiry, and returns the session expiry.
113
- // NOTE Use time delta rather than absolute time, since client clock and server clock maybe
114
- // out of sync. We can't use the serverTime() functionality because the cookie expiry still
115
- // run on local clock.
116
- const { expiresAfterSeconds } = yield this.keepalivePost();
117
- // Persist the derived passKey
118
- yield this.keyService.persistMasterKey(masterKey, expiresAfterSeconds);
119
- console.log('setMasterKey() done');
120
- });
121
- }
122
- onPing() {
123
- return __awaiter(this, void 0, void 0, function* () {
124
- console.log(`Keep alive triggered at time: ${Date.now()}. Interval set at: ${this.keepalive.interval()} seconds`);
125
- // Keepalive API will extend the session expiry.
126
- const { expiresAfterSeconds } = yield this.keepalivePost();
127
- // Extend the expiry of the persisted key
128
- yield this.keyService.setMasterKeyExpiresAfterSeconds(expiresAfterSeconds);
129
- yield Promise.resolve(this.onKeepalive && this.onKeepalive());
130
- });
131
- }
132
- start() {
133
- return __awaiter(this, void 0, void 0, function* () {
134
- if (!this.initCalled) {
135
- yield this.init();
136
- }
137
- if (this.idle.isRunning()) {
138
- return;
139
- }
140
- // Ping does not seem to happen right at the start. So we call it explicitly
141
- yield this.onPing();
142
- this.idle.watch();
143
- });
144
- }
145
- stop() {
146
- this.idle.stop();
147
- this.reset();
148
- }
149
- reset() {
150
- localStorage.removeItem(this.IDLE_EXPIRY_KEY);
151
- localStorage.removeItem(this.IDLING_KEY);
152
- }
153
- }
154
- IdleService.ɵprov = i0.ɵɵdefineInjectable({ factory: function IdleService_Factory() { return new IdleService(i0.ɵɵinject(i1.LR_CONFIG), i0.ɵɵinject(i2.HttpClient), i0.ɵɵinject(i3.Idle), i0.ɵɵinject(i4.Keepalive), i0.ɵɵinject(i5.KeyService), i0.ɵɵinject(i6.AuthClass)); }, token: IdleService, providedIn: "root" });
155
- IdleService.decorators = [
156
- { type: Injectable, args: [{
157
- providedIn: 'root',
158
- },] }
159
- ];
160
- IdleService.ctorParameters = () => [
161
- { type: undefined, decorators: [{ type: Inject, args: [LR_CONFIG,] }] },
162
- { type: HttpClient },
163
- { type: Idle },
164
- { type: Keepalive },
165
- { type: KeyService },
166
- { type: AuthClass }
167
- ];
168
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"idle.service.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/auth/idle.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core';\nimport { Idle, DEFAULT_INTERRUPTSOURCES } from '@ng-idle/core';\nimport { Keepalive } from '@ng-idle/keepalive';\nimport { KeyService } from '../cryptography/key.service';\nimport {\n  LrBadArgumentException,\n  LrBadStateException,\n} from '../_common/exceptions';\nimport { LifeReadyConfig, LR_CONFIG } from '../life-ready.config';\nimport { HttpClient } from '@angular/common/http';\nimport { Config, KeepaliveResult } from './idle.types';\nimport { Key } from '../cryptography/cryptography.types';\nimport { CognitoUser } from '@aws-amplify/auth';\nimport { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';\n\nexport interface IdleServiceInit {\n  // TODO: this should be EventEmitter instead of a callback.\n  onTimeout?: (() => any) | (() => Promise<any>) | null;\n  onKeepalive?: (() => any) | (() => Promise<any>) | null;\n  idleSec?: number;\n  timeoutSec?: number;\n  keepAliveIntervalSec?: number;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class IdleService {\n  private readonly IDLE_EXPIRY_KEY = 'ng2Idle.main.expiry';\n  private readonly IDLING_KEY = 'ng2Idle.main.idling';\n\n  private initCalled = false;\n  private onTimeout: (() => any) | (() => Promise<any>) | null;\n  private onKeepalive: (() => any) | (() => Promise<any>) | null;\n\n  constructor(\n    @Inject(LR_CONFIG) private config: LifeReadyConfig,\n    private http: HttpClient,\n    private idle: Idle,\n    private keepalive: Keepalive,\n    private keyService: KeyService,\n    private auth: AuthClass\n  ) {}\n\n  private assertInit(): void {\n    if (!this.initCalled) {\n      throw new LrBadStateException('Call IdleService.init() first.');\n    }\n  }\n\n  public async init(params?: IdleServiceInit): Promise<void> {\n    if (this.initCalled) {\n      throw new LrBadStateException(\n        'IdleService.init() can only be called once. IdleService.start() calls init() with default values if init() has not been called yet.'\n      );\n    }\n\n    this.initCalled = true;\n\n    // Defaults\n    params = {\n      onTimeout: null,\n      onKeepalive: null,\n      idleSec: Config.IDLE,\n      timeoutSec: Config.TIMEOUT,\n      keepAliveIntervalSec: Config.KEEP_ALIVE_INTERVAL,\n      ...params,\n    };\n\n    // If timeoutSec == 0 then the onTimeout() callback is never called.\n    if (params.timeoutSec < 0.01) {\n      throw new LrBadArgumentException(\n        'Minimum value for IdleService.init({ timeoutSec }) is 0.01'\n      );\n    }\n\n    this.onTimeout = params.onTimeout;\n    this.onKeepalive = params.onKeepalive;\n\n    // ------------------------------------------------------------------------\n    // Setup Idle\n    // ------------------------------------------------------------------------\n    // sets an idle timeout of 5 seconds, for testing purposes.\n    this.idle.setIdle(params.idleSec);\n    // sets a timeout period of 5 seconds. after 10 seconds of inactivity, the user will be considered timed out.\n    this.idle.setTimeout(params.timeoutSec);\n    // sets the default interrupts, in this case, things like clicks, scrolls, touches to the document\n    this.idle.setInterrupts(DEFAULT_INTERRUPTSOURCES);\n\n    this.idle.onIdleEnd.subscribe(() => console.log('Idle stopped'));\n    this.idle.onIdleStart.subscribe(() => console.log('Idle started'));\n\n    this.idle.onTimeout.subscribe(async () => {\n      console.log('Idle timed out');\n      this.reset();\n      await Promise.resolve(this.onTimeout && this.onTimeout());\n    });\n    this.idle.onTimeoutWarning.subscribe((countdown: any) =>\n      console.log(`Will timeout in ${countdown} seconds!`)\n    );\n\n    // ------------------------------------------------------------------------\n    // Setup Keepalive\n    // ------------------------------------------------------------------------\n    // Ref: https://github.com/moribvndvs/ng2-idle#readme\n    // ng-idle will instruct @ng-idle/keepalive to ping while the user is active, and stop once\n    // they go idle or time out. When the user resumes activity or the idle state is reset, it will\n    // ping immediately and then resume pinging.\n    this.keepalive.interval(params.keepAliveIntervalSec);\n    console.log(\n      `Keep alive interval set at: ${Config.KEEP_ALIVE_INTERVAL} seconds`\n    );\n\n    this.keepalive.onPing.subscribe(() => this.onPing());\n\n    // If the browser tab has been closed for a period longer thant the inactivity\n    // period, then we should logout right from the start.\n    const idleExpiry = localStorage.getItem(this.IDLE_EXPIRY_KEY);\n    if (\n      idleExpiry &&\n      parseInt(idleExpiry, 10) + this.idle.getTimeout() * 1000 < Date.now()\n    ) {\n      this.reset();\n      await Promise.resolve(this.onTimeout && this.onTimeout());\n    }\n  }\n\n  public async keepalivePost(): Promise<{\n    expiresAfterSeconds: number;\n    keepaliveResult: KeepaliveResult;\n  }> {\n    // currentAuthenticatedUser() refreshes the access token if required.\n    const cognitoUser: CognitoUser = await this.auth.currentAuthenticatedUser();\n\n    const keepaliveResult = await this.http\n      .post<KeepaliveResult>(`${this.config.authUrl}auth/keepalive/`, null, {\n        withCredentials: true, // /auth/keepalive/ will be extending the sessions cookie.\n        headers: {\n          Authorization: `Bearer ${cognitoUser\n            .getSignInUserSession()\n            .getAccessToken()\n            .getJwtToken()}`,\n        },\n      })\n      .toPromise();\n\n    return {\n      keepaliveResult,\n      expiresAfterSeconds:\n        this.idle.getIdle() +\n        this.idle.getTimeout() +\n        this.keepalive.interval(),\n    };\n  }\n\n  public async persistMasterKey(masterKey: Key): Promise<void> {\n    // The keepalive API call extends the server-side session, the session cookie expiry, refresh key cookie\n    // expiry, and returns the session expiry.\n    // NOTE Use time delta rather than absolute time, since client clock and server clock maybe\n    // out of sync. We can't use the serverTime() functionality because the cookie expiry still\n    // run on local clock.\n    const { expiresAfterSeconds } = await this.keepalivePost();\n\n    // Persist the derived passKey\n    await this.keyService.persistMasterKey(masterKey, expiresAfterSeconds);\n\n    console.log('setMasterKey() done');\n  }\n\n  private async onPing(): Promise<void> {\n    console.log(\n      `Keep alive triggered at time: ${Date.now()}. Interval set at: ${this.keepalive.interval()} seconds`\n    );\n\n    // Keepalive API will extend the session expiry.\n    const { expiresAfterSeconds } = await this.keepalivePost();\n\n    // Extend the expiry of the persisted key\n    await this.keyService.setMasterKeyExpiresAfterSeconds(expiresAfterSeconds);\n\n    await Promise.resolve(this.onKeepalive && this.onKeepalive());\n  }\n\n  public async start(): Promise<void> {\n    if (!this.initCalled) {\n      await this.init();\n    }\n\n    if (this.idle.isRunning()) {\n      return;\n    }\n\n    // Ping does not seem to happen right at the start. So we call it explicitly\n    await this.onPing();\n\n    this.idle.watch();\n  }\n\n  public stop(): void {\n    this.idle.stop();\n    this.reset();\n  }\n\n  private reset() {\n    localStorage.removeItem(this.IDLE_EXPIRY_KEY);\n    localStorage.removeItem(this.IDLING_KEY);\n  }\n}\n"]}
1
+ import { __awaiter } from "tslib";
2
+ import { Inject, Injectable } from '@angular/core';
3
+ import { Idle, DEFAULT_INTERRUPTSOURCES } from '@ng-idle/core';
4
+ import { Keepalive } from '@ng-idle/keepalive';
5
+ import { KeyService } from '../cryptography/key.service';
6
+ import { LrBadArgumentException, LrBadStateException, } from '../_common/exceptions';
7
+ import { LR_CONFIG } from '../life-ready.config';
8
+ import { HttpClient } from '@angular/common/http';
9
+ import { Config } from './idle.types';
10
+ import { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "../life-ready.config";
13
+ import * as i2 from "@angular/common/http";
14
+ import * as i3 from "@ng-idle/core";
15
+ import * as i4 from "@ng-idle/keepalive";
16
+ import * as i5 from "../cryptography/key.service";
17
+ import * as i6 from "@aws-amplify/auth/lib-esm/Auth";
18
+ export class IdleService {
19
+ constructor(config, http, idle, keepalive, keyService, auth) {
20
+ this.config = config;
21
+ this.http = http;
22
+ this.idle = idle;
23
+ this.keepalive = keepalive;
24
+ this.keyService = keyService;
25
+ this.auth = auth;
26
+ this.IDLE_EXPIRY_KEY = 'ng2Idle.main.expiry';
27
+ this.IDLING_KEY = 'ng2Idle.main.idling';
28
+ this.initCalled = false;
29
+ }
30
+ assertInit() {
31
+ if (!this.initCalled) {
32
+ throw new LrBadStateException('Call IdleService.init() first.');
33
+ }
34
+ }
35
+ init(params) {
36
+ return __awaiter(this, void 0, void 0, function* () {
37
+ if (this.initCalled) {
38
+ throw new LrBadStateException('IdleService.init() can only be called once. IdleService.start() calls init() with default values if init() has not been called yet.');
39
+ }
40
+ this.initCalled = true;
41
+ // Defaults
42
+ params = Object.assign({ onTimeout: null, onKeepalive: null, idleSec: Config.IDLE, timeoutSec: Config.TIMEOUT, keepAliveIntervalSec: Config.KEEP_ALIVE_INTERVAL }, params);
43
+ // If timeoutSec == 0 then the onTimeout() callback is never called.
44
+ if (params.timeoutSec < 0.01) {
45
+ throw new LrBadArgumentException('Minimum value for IdleService.init({ timeoutSec }) is 0.01');
46
+ }
47
+ this.onTimeout = params.onTimeout;
48
+ this.onKeepalive = params.onKeepalive;
49
+ // ------------------------------------------------------------------------
50
+ // Setup Idle
51
+ // ------------------------------------------------------------------------
52
+ // sets an idle timeout of 5 seconds, for testing purposes.
53
+ this.idle.setIdle(params.idleSec);
54
+ // sets a timeout period of 5 seconds. after 10 seconds of inactivity, the user will be considered timed out.
55
+ this.idle.setTimeout(params.timeoutSec);
56
+ // sets the default interrupts, in this case, things like clicks, scrolls, touches to the document
57
+ this.idle.setInterrupts(DEFAULT_INTERRUPTSOURCES);
58
+ this.idle.onIdleEnd.subscribe(() => console.log('Idle stopped'));
59
+ this.idle.onIdleStart.subscribe(() => console.log('Idle started'));
60
+ this.idle.onTimeout.subscribe(() => __awaiter(this, void 0, void 0, function* () {
61
+ console.log('Idle timed out');
62
+ this.reset();
63
+ yield Promise.resolve(this.onTimeout && this.onTimeout());
64
+ }));
65
+ this.idle.onTimeoutWarning.subscribe((countdown) => console.log(`Will timeout in ${countdown} seconds!`));
66
+ // ------------------------------------------------------------------------
67
+ // Setup Keepalive
68
+ // ------------------------------------------------------------------------
69
+ // Ref: https://github.com/moribvndvs/ng2-idle#readme
70
+ // ng-idle will instruct @ng-idle/keepalive to ping while the user is active, and stop once
71
+ // they go idle or time out. When the user resumes activity or the idle state is reset, it will
72
+ // ping immediately and then resume pinging.
73
+ this.keepalive.interval(params.keepAliveIntervalSec);
74
+ console.log(`Keep alive interval set at: ${Config.KEEP_ALIVE_INTERVAL} seconds`);
75
+ this.keepalive.onPing.subscribe(() => this.onPing());
76
+ // If the browser tab has been closed for a period longer thant the inactivity
77
+ // period, then we should logout right from the start.
78
+ const idleExpiry = localStorage.getItem(this.IDLE_EXPIRY_KEY);
79
+ if (idleExpiry &&
80
+ parseInt(idleExpiry, 10) + this.idle.getTimeout() * 1000 < Date.now()) {
81
+ this.reset();
82
+ yield Promise.resolve(this.onTimeout && this.onTimeout());
83
+ }
84
+ });
85
+ }
86
+ keepalivePost() {
87
+ return __awaiter(this, void 0, void 0, function* () {
88
+ // currentAuthenticatedUser() refreshes the access token if required.
89
+ const cognitoUser = yield this.auth.currentAuthenticatedUser();
90
+ const keepaliveResult = yield this.http
91
+ .post(`${this.config.authUrl}auth/keepalive/`, null, {
92
+ withCredentials: true,
93
+ headers: {
94
+ Authorization: `Bearer ${cognitoUser
95
+ .getSignInUserSession()
96
+ .getAccessToken()
97
+ .getJwtToken()}`,
98
+ },
99
+ })
100
+ .toPromise();
101
+ return {
102
+ keepaliveResult,
103
+ expiresAfterSeconds: this.idle.getIdle() +
104
+ this.idle.getTimeout() +
105
+ this.keepalive.interval(),
106
+ };
107
+ });
108
+ }
109
+ persistMasterKey(masterKey) {
110
+ return __awaiter(this, void 0, void 0, function* () {
111
+ // The keepalive API call extends the server-side session, the session cookie expiry, refresh key cookie
112
+ // expiry, and returns the session expiry.
113
+ // NOTE Use time delta rather than absolute time, since client clock and server clock maybe
114
+ // out of sync. We can't use the serverTime() functionality because the cookie expiry still
115
+ // run on local clock.
116
+ const { expiresAfterSeconds } = yield this.keepalivePost();
117
+ // Persist the derived passKey
118
+ yield this.keyService.persistMasterKey(masterKey, expiresAfterSeconds);
119
+ console.log('setMasterKey() done');
120
+ });
121
+ }
122
+ onPing() {
123
+ return __awaiter(this, void 0, void 0, function* () {
124
+ console.log(`Keep alive triggered at time: ${Date.now()}. Interval set at: ${this.keepalive.interval()} seconds`);
125
+ // Keepalive API will extend the session expiry.
126
+ const { expiresAfterSeconds } = yield this.keepalivePost();
127
+ // Extend the expiry of the persisted key
128
+ yield this.keyService.setMasterKeyExpiresAfterSeconds(expiresAfterSeconds);
129
+ yield Promise.resolve(this.onKeepalive && this.onKeepalive());
130
+ });
131
+ }
132
+ start() {
133
+ return __awaiter(this, void 0, void 0, function* () {
134
+ if (!this.initCalled) {
135
+ yield this.init();
136
+ }
137
+ if (this.idle.isRunning()) {
138
+ return;
139
+ }
140
+ // Ping does not seem to happen right at the start. So we call it explicitly
141
+ yield this.onPing();
142
+ this.idle.watch();
143
+ });
144
+ }
145
+ stop() {
146
+ this.idle.stop();
147
+ this.reset();
148
+ }
149
+ reset() {
150
+ localStorage.removeItem(this.IDLE_EXPIRY_KEY);
151
+ localStorage.removeItem(this.IDLING_KEY);
152
+ }
153
+ }
154
+ IdleService.ɵprov = i0.ɵɵdefineInjectable({ factory: function IdleService_Factory() { return new IdleService(i0.ɵɵinject(i1.LR_CONFIG), i0.ɵɵinject(i2.HttpClient), i0.ɵɵinject(i3.Idle), i0.ɵɵinject(i4.Keepalive), i0.ɵɵinject(i5.KeyService), i0.ɵɵinject(i6.AuthClass)); }, token: IdleService, providedIn: "root" });
155
+ IdleService.decorators = [
156
+ { type: Injectable, args: [{
157
+ providedIn: 'root',
158
+ },] }
159
+ ];
160
+ IdleService.ctorParameters = () => [
161
+ { type: undefined, decorators: [{ type: Inject, args: [LR_CONFIG,] }] },
162
+ { type: HttpClient },
163
+ { type: Idle },
164
+ { type: Keepalive },
165
+ { type: KeyService },
166
+ { type: AuthClass }
167
+ ];
168
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"idle.service.js","sourceRoot":"C:/Projects/kc-client/projects/core/src/","sources":["lib/auth/idle.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core';\r\nimport { Idle, DEFAULT_INTERRUPTSOURCES } from '@ng-idle/core';\r\nimport { Keepalive } from '@ng-idle/keepalive';\r\nimport { KeyService } from '../cryptography/key.service';\r\nimport {\r\n  LrBadArgumentException,\r\n  LrBadStateException,\r\n} from '../_common/exceptions';\r\nimport { LifeReadyConfig, LR_CONFIG } from '../life-ready.config';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { Config, KeepaliveResult } from './idle.types';\r\nimport { Key } from '../cryptography/cryptography.types';\r\nimport { CognitoUser } from '@aws-amplify/auth';\r\nimport { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';\r\n\r\nexport interface IdleServiceInit {\r\n  // TODO: this should be EventEmitter instead of a callback.\r\n  onTimeout?: (() => any) | (() => Promise<any>) | null;\r\n  onKeepalive?: (() => any) | (() => Promise<any>) | null;\r\n  idleSec?: number;\r\n  timeoutSec?: number;\r\n  keepAliveIntervalSec?: number;\r\n}\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class IdleService {\r\n  private readonly IDLE_EXPIRY_KEY = 'ng2Idle.main.expiry';\r\n  private readonly IDLING_KEY = 'ng2Idle.main.idling';\r\n\r\n  private initCalled = false;\r\n  private onTimeout: (() => any) | (() => Promise<any>) | null;\r\n  private onKeepalive: (() => any) | (() => Promise<any>) | null;\r\n\r\n  constructor(\r\n    @Inject(LR_CONFIG) private config: LifeReadyConfig,\r\n    private http: HttpClient,\r\n    private idle: Idle,\r\n    private keepalive: Keepalive,\r\n    private keyService: KeyService,\r\n    private auth: AuthClass\r\n  ) {}\r\n\r\n  private assertInit(): void {\r\n    if (!this.initCalled) {\r\n      throw new LrBadStateException('Call IdleService.init() first.');\r\n    }\r\n  }\r\n\r\n  public async init(params?: IdleServiceInit): Promise<void> {\r\n    if (this.initCalled) {\r\n      throw new LrBadStateException(\r\n        'IdleService.init() can only be called once. IdleService.start() calls init() with default values if init() has not been called yet.'\r\n      );\r\n    }\r\n\r\n    this.initCalled = true;\r\n\r\n    // Defaults\r\n    params = {\r\n      onTimeout: null,\r\n      onKeepalive: null,\r\n      idleSec: Config.IDLE,\r\n      timeoutSec: Config.TIMEOUT,\r\n      keepAliveIntervalSec: Config.KEEP_ALIVE_INTERVAL,\r\n      ...params,\r\n    };\r\n\r\n    // If timeoutSec == 0 then the onTimeout() callback is never called.\r\n    if (params.timeoutSec < 0.01) {\r\n      throw new LrBadArgumentException(\r\n        'Minimum value for IdleService.init({ timeoutSec }) is 0.01'\r\n      );\r\n    }\r\n\r\n    this.onTimeout = params.onTimeout;\r\n    this.onKeepalive = params.onKeepalive;\r\n\r\n    // ------------------------------------------------------------------------\r\n    // Setup Idle\r\n    // ------------------------------------------------------------------------\r\n    // sets an idle timeout of 5 seconds, for testing purposes.\r\n    this.idle.setIdle(params.idleSec);\r\n    // sets a timeout period of 5 seconds. after 10 seconds of inactivity, the user will be considered timed out.\r\n    this.idle.setTimeout(params.timeoutSec);\r\n    // sets the default interrupts, in this case, things like clicks, scrolls, touches to the document\r\n    this.idle.setInterrupts(DEFAULT_INTERRUPTSOURCES);\r\n\r\n    this.idle.onIdleEnd.subscribe(() => console.log('Idle stopped'));\r\n    this.idle.onIdleStart.subscribe(() => console.log('Idle started'));\r\n\r\n    this.idle.onTimeout.subscribe(async () => {\r\n      console.log('Idle timed out');\r\n      this.reset();\r\n      await Promise.resolve(this.onTimeout && this.onTimeout());\r\n    });\r\n    this.idle.onTimeoutWarning.subscribe((countdown: any) =>\r\n      console.log(`Will timeout in ${countdown} seconds!`)\r\n    );\r\n\r\n    // ------------------------------------------------------------------------\r\n    // Setup Keepalive\r\n    // ------------------------------------------------------------------------\r\n    // Ref: https://github.com/moribvndvs/ng2-idle#readme\r\n    // ng-idle will instruct @ng-idle/keepalive to ping while the user is active, and stop once\r\n    // they go idle or time out. When the user resumes activity or the idle state is reset, it will\r\n    // ping immediately and then resume pinging.\r\n    this.keepalive.interval(params.keepAliveIntervalSec);\r\n    console.log(\r\n      `Keep alive interval set at: ${Config.KEEP_ALIVE_INTERVAL} seconds`\r\n    );\r\n\r\n    this.keepalive.onPing.subscribe(() => this.onPing());\r\n\r\n    // If the browser tab has been closed for a period longer thant the inactivity\r\n    // period, then we should logout right from the start.\r\n    const idleExpiry = localStorage.getItem(this.IDLE_EXPIRY_KEY);\r\n    if (\r\n      idleExpiry &&\r\n      parseInt(idleExpiry, 10) + this.idle.getTimeout() * 1000 < Date.now()\r\n    ) {\r\n      this.reset();\r\n      await Promise.resolve(this.onTimeout && this.onTimeout());\r\n    }\r\n  }\r\n\r\n  public async keepalivePost(): Promise<{\r\n    expiresAfterSeconds: number;\r\n    keepaliveResult: KeepaliveResult;\r\n  }> {\r\n    // currentAuthenticatedUser() refreshes the access token if required.\r\n    const cognitoUser: CognitoUser = await this.auth.currentAuthenticatedUser();\r\n\r\n    const keepaliveResult = await this.http\r\n      .post<KeepaliveResult>(`${this.config.authUrl}auth/keepalive/`, null, {\r\n        withCredentials: true, // /auth/keepalive/ will be extending the sessions cookie.\r\n        headers: {\r\n          Authorization: `Bearer ${cognitoUser\r\n            .getSignInUserSession()\r\n            .getAccessToken()\r\n            .getJwtToken()}`,\r\n        },\r\n      })\r\n      .toPromise();\r\n\r\n    return {\r\n      keepaliveResult,\r\n      expiresAfterSeconds:\r\n        this.idle.getIdle() +\r\n        this.idle.getTimeout() +\r\n        this.keepalive.interval(),\r\n    };\r\n  }\r\n\r\n  public async persistMasterKey(masterKey: Key): Promise<void> {\r\n    // The keepalive API call extends the server-side session, the session cookie expiry, refresh key cookie\r\n    // expiry, and returns the session expiry.\r\n    // NOTE Use time delta rather than absolute time, since client clock and server clock maybe\r\n    // out of sync. We can't use the serverTime() functionality because the cookie expiry still\r\n    // run on local clock.\r\n    const { expiresAfterSeconds } = await this.keepalivePost();\r\n\r\n    // Persist the derived passKey\r\n    await this.keyService.persistMasterKey(masterKey, expiresAfterSeconds);\r\n\r\n    console.log('setMasterKey() done');\r\n  }\r\n\r\n  private async onPing(): Promise<void> {\r\n    console.log(\r\n      `Keep alive triggered at time: ${Date.now()}. Interval set at: ${this.keepalive.interval()} seconds`\r\n    );\r\n\r\n    // Keepalive API will extend the session expiry.\r\n    const { expiresAfterSeconds } = await this.keepalivePost();\r\n\r\n    // Extend the expiry of the persisted key\r\n    await this.keyService.setMasterKeyExpiresAfterSeconds(expiresAfterSeconds);\r\n\r\n    await Promise.resolve(this.onKeepalive && this.onKeepalive());\r\n  }\r\n\r\n  public async start(): Promise<void> {\r\n    if (!this.initCalled) {\r\n      await this.init();\r\n    }\r\n\r\n    if (this.idle.isRunning()) {\r\n      return;\r\n    }\r\n\r\n    // Ping does not seem to happen right at the start. So we call it explicitly\r\n    await this.onPing();\r\n\r\n    this.idle.watch();\r\n  }\r\n\r\n  public stop(): void {\r\n    this.idle.stop();\r\n    this.reset();\r\n  }\r\n\r\n  private reset() {\r\n    localStorage.removeItem(this.IDLE_EXPIRY_KEY);\r\n    localStorage.removeItem(this.IDLING_KEY);\r\n  }\r\n}\r\n"]}
@@ -1,7 +1,7 @@
1
- export var Config;
2
- (function (Config) {
3
- Config[Config["TIMEOUT"] = 0.01] = "TIMEOUT";
4
- Config[Config["IDLE"] = 1200] = "IDLE";
5
- Config[Config["KEEP_ALIVE_INTERVAL"] = 60] = "KEEP_ALIVE_INTERVAL";
6
- })(Config || (Config = {}));
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWRsZS50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIvb3B0L2F0bGFzc2lhbi9waXBlbGluZXMvYWdlbnQvYnVpbGQvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJsaWIvYXV0aC9pZGxlLnR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLE1BSVg7QUFKRCxXQUFZLE1BQU07SUFDaEIsNENBQWMsQ0FBQTtJQUNkLHNDQUFjLENBQUE7SUFDZCxrRUFBNEIsQ0FBQTtBQUM5QixDQUFDLEVBSlcsTUFBTSxLQUFOLE1BQU0sUUFJakIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBDb25maWcge1xuICBUSU1FT1VUID0gMC4wMSwgLy8gc2Vjb25kcywgbWluIHZhbHVlIDAuMDEsIGFmdGVyIHN0YXRlIGlzIGlkbGUsIHdhaXQgZm9yIFRJTUVPVVQgc2Vjb25kcyBiZWZvcmUgdGFraW5nIGFjdGlvblxuICBJRExFID0gNjAgKiAyMCwgLy8gc2Vjb25kcywgcGVyaW9kIG9mIGluYWN0aXZpdHkgdG8gY29uc2lkZXIgc3RhdGUgYXMgaWRsZVxuICBLRUVQX0FMSVZFX0lOVEVSVkFMID0gNjAgKiAxLCAvLyBzZWNvbmRzLCB0cmlnZ2VyZWQgb24gYSByZWd1bGFyIGJhc2lzIHdoaWxlIGFjdGl2ZSAoaS5lLiB3aGlsZSBub3QgaWRsaW5nKVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEtlZXBhbGl2ZVJlc3VsdCB7XG4gIHNlc3Npb246IHtcbiAgICBleHBpcmVzX2FmdGVyX3NlY29uZHM6IG51bWJlcjtcbiAgfTtcbn1cbiJdfQ==
1
+ export var Config;
2
+ (function (Config) {
3
+ Config[Config["TIMEOUT"] = 0.01] = "TIMEOUT";
4
+ Config[Config["IDLE"] = 1200] = "IDLE";
5
+ Config[Config["KEEP_ALIVE_INTERVAL"] = 60] = "KEEP_ALIVE_INTERVAL";
6
+ })(Config || (Config = {}));
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWRsZS50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiJDOi9Qcm9qZWN0cy9rYy1jbGllbnQvcHJvamVjdHMvY29yZS9zcmMvIiwic291cmNlcyI6WyJsaWIvYXV0aC9pZGxlLnR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLE1BSVg7QUFKRCxXQUFZLE1BQU07SUFDaEIsNENBQWMsQ0FBQTtJQUNkLHNDQUFjLENBQUE7SUFDZCxrRUFBNEIsQ0FBQTtBQUM5QixDQUFDLEVBSlcsTUFBTSxLQUFOLE1BQU0sUUFJakIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBDb25maWcge1xyXG4gIFRJTUVPVVQgPSAwLjAxLCAvLyBzZWNvbmRzLCBtaW4gdmFsdWUgMC4wMSwgYWZ0ZXIgc3RhdGUgaXMgaWRsZSwgd2FpdCBmb3IgVElNRU9VVCBzZWNvbmRzIGJlZm9yZSB0YWtpbmcgYWN0aW9uXHJcbiAgSURMRSA9IDYwICogMjAsIC8vIHNlY29uZHMsIHBlcmlvZCBvZiBpbmFjdGl2aXR5IHRvIGNvbnNpZGVyIHN0YXRlIGFzIGlkbGVcclxuICBLRUVQX0FMSVZFX0lOVEVSVkFMID0gNjAgKiAxLCAvLyBzZWNvbmRzLCB0cmlnZ2VyZWQgb24gYSByZWd1bGFyIGJhc2lzIHdoaWxlIGFjdGl2ZSAoaS5lLiB3aGlsZSBub3QgaWRsaW5nKVxyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEtlZXBhbGl2ZVJlc3VsdCB7XHJcbiAgc2Vzc2lvbjoge1xyXG4gICAgZXhwaXJlc19hZnRlcl9zZWNvbmRzOiBudW1iZXI7XHJcbiAgfTtcclxufVxyXG4iXX0=