@lifeready/core 9.0.8 → 10.0.0

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 (225) hide show
  1. package/fesm2022/lifeready-core.mjs +10522 -0
  2. package/fesm2022/lifeready-core.mjs.map +1 -0
  3. package/package.json +21 -16
  4. package/types/lifeready-core.d.ts +5329 -0
  5. package/bundles/lifeready-core.umd.js +0 -13231
  6. package/bundles/lifeready-core.umd.js.map +0 -1
  7. package/bundles/lifeready-core.umd.min.js +0 -2
  8. package/bundles/lifeready-core.umd.min.js.map +0 -1
  9. package/esm2015/lib/_common/ast.js +0 -41
  10. package/esm2015/lib/_common/deferred-promise.js +0 -24
  11. package/esm2015/lib/_common/exceptions.js +0 -186
  12. package/esm2015/lib/_common/index.js +0 -3
  13. package/esm2015/lib/_common/kc-lodash.js +0 -11
  14. package/esm2015/lib/_common/key.js +0 -28
  15. package/esm2015/lib/_common/queries.gql.js +0 -43
  16. package/esm2015/lib/_common/run-outside-angular.js +0 -80
  17. package/esm2015/lib/_common/storage.js +0 -28
  18. package/esm2015/lib/_common/types.js +0 -2
  19. package/esm2015/lib/_common/utils.js +0 -73
  20. package/esm2015/lib/api/lr-apollo.service.js +0 -47
  21. package/esm2015/lib/api/lr-graphql/index.js +0 -6
  22. package/esm2015/lib/api/lr-graphql/lr-graphql.service.js +0 -170
  23. package/esm2015/lib/api/lr-graphql/lr-merged-mutation.js +0 -216
  24. package/esm2015/lib/api/lr-graphql/lr-mutation-base.js +0 -51
  25. package/esm2015/lib/api/lr-graphql/lr-mutation.js +0 -91
  26. package/esm2015/lib/api/lr-graphql/lr.service.js +0 -18
  27. package/esm2015/lib/api/query-processor/common-processors.service.js +0 -94
  28. package/esm2015/lib/api/query-processor/index.js +0 -3
  29. package/esm2015/lib/api/query-processor/query-processor.service.js +0 -307
  30. package/esm2015/lib/api/query-processor/tp-password-reset-processor.service.js +0 -110
  31. package/esm2015/lib/api/types/graphql.types.js +0 -8
  32. package/esm2015/lib/api/types/index.js +0 -3
  33. package/esm2015/lib/api/types/lr-graphql.types.js +0 -182
  34. package/esm2015/lib/auth/auth.config.js +0 -57
  35. package/esm2015/lib/auth/auth.gql.private.js +0 -85
  36. package/esm2015/lib/auth/auth.service.js +0 -616
  37. package/esm2015/lib/auth/auth.types.js +0 -19
  38. package/esm2015/lib/contact-card/contact-card.gql.js +0 -79
  39. package/esm2015/lib/contact-card/contact-card.service.js +0 -156
  40. package/esm2015/lib/contact-card/contact-card2.gql.js +0 -29
  41. package/esm2015/lib/contact-card/contact-card2.service.js +0 -103
  42. package/esm2015/lib/encryption/encryption.service.js +0 -188
  43. package/esm2015/lib/file-upload/file-upload.service.js +0 -70
  44. package/esm2015/lib/file-upload/file-upload.types.js +0 -2
  45. package/esm2015/lib/idle/idle.service.js +0 -159
  46. package/esm2015/lib/idle/idle.types.js +0 -7
  47. package/esm2015/lib/item/item.gql.js +0 -166
  48. package/esm2015/lib/item/item.gql.private.js +0 -41
  49. package/esm2015/lib/item/item.service.js +0 -662
  50. package/esm2015/lib/item/item.types.js +0 -2
  51. package/esm2015/lib/key/key-factory.service.js +0 -226
  52. package/esm2015/lib/key/key-graph.service.js +0 -314
  53. package/esm2015/lib/key/key-meta.service.js +0 -153
  54. package/esm2015/lib/key/key.service.js +0 -124
  55. package/esm2015/lib/key/key.types.js +0 -16
  56. package/esm2015/lib/key-exchange/key-exchange.gql.js +0 -174
  57. package/esm2015/lib/key-exchange/key-exchange.service.js +0 -496
  58. package/esm2015/lib/lbop/lbop.service.js +0 -351
  59. package/esm2015/lib/life-ready.config.js +0 -96
  60. package/esm2015/lib/life-ready.module.js +0 -42
  61. package/esm2015/lib/lock/lock.gql.js +0 -40
  62. package/esm2015/lib/lock/lock.service.js +0 -64
  63. package/esm2015/lib/notification/notification.gql.js +0 -43
  64. package/esm2015/lib/notification/notification.service.js +0 -118
  65. package/esm2015/lib/password/password.gql.js +0 -28
  66. package/esm2015/lib/password/password.service.js +0 -309
  67. package/esm2015/lib/persist/persist.service.js +0 -181
  68. package/esm2015/lib/plan/plan.gql.js +0 -91
  69. package/esm2015/lib/plan/plan.service.js +0 -191
  70. package/esm2015/lib/plan/plan.types.js +0 -2
  71. package/esm2015/lib/profile/profile-details.service.js +0 -261
  72. package/esm2015/lib/profile/profile.gql.js +0 -170
  73. package/esm2015/lib/profile/profile.service.js +0 -166
  74. package/esm2015/lib/profile/profile.types.js +0 -45
  75. package/esm2015/lib/register/register.service.js +0 -173
  76. package/esm2015/lib/register/register.types.js +0 -3
  77. package/esm2015/lib/reminder/reminder.gql.js +0 -27
  78. package/esm2015/lib/reminder/reminder.service.js +0 -85
  79. package/esm2015/lib/reminder/reminder.types.js +0 -2
  80. package/esm2015/lib/scenario/scenario.constants.js +0 -2
  81. package/esm2015/lib/scenario/scenario.controller.js +0 -34
  82. package/esm2015/lib/scenario/scenario.gql.js +0 -90
  83. package/esm2015/lib/scenario/scenario.private.gql.js +0 -200
  84. package/esm2015/lib/scenario/scenario.service.js +0 -679
  85. package/esm2015/lib/scenario/scenario.types.js +0 -2
  86. package/esm2015/lib/server-config/server-config.gql.js +0 -9
  87. package/esm2015/lib/server-config/server-config.service.js +0 -41
  88. package/esm2015/lib/shared-contact-card/shared-contact-card.service.js +0 -119
  89. package/esm2015/lib/shared-contact-card/shared-contact-card2.gql.js +0 -41
  90. package/esm2015/lib/shared-contact-card/shared-contact-card2.service.js +0 -117
  91. package/esm2015/lib/slip39/slip39.service.js +0 -167
  92. package/esm2015/lib/time/time.service.js +0 -152
  93. package/esm2015/lib/tp-assembly/tp-assembly.js +0 -363
  94. package/esm2015/lib/tp-assembly/tp-assembly.private.gql.js +0 -22
  95. package/esm2015/lib/tp-assembly/tp-assembly.types.js +0 -2
  96. package/esm2015/lib/tp-password-reset/tp-password-reset-request.service.js +0 -98
  97. package/esm2015/lib/tp-password-reset/tp-password-reset-user.service.js +0 -121
  98. package/esm2015/lib/tp-password-reset/tp-password-reset.constants.js +0 -4
  99. package/esm2015/lib/tp-password-reset/tp-password-reset.controller.js +0 -34
  100. package/esm2015/lib/tp-password-reset/tp-password-reset.gql.js +0 -74
  101. package/esm2015/lib/tp-password-reset/tp-password-reset.private.gql.js +0 -166
  102. package/esm2015/lib/tp-password-reset/tp-password-reset.private.service.js +0 -54
  103. package/esm2015/lib/tp-password-reset/tp-password-reset.service.js +0 -110
  104. package/esm2015/lib/tp-password-reset/tp-password-reset.types.js +0 -2
  105. package/esm2015/lib/trusted-party/trusted-party.gql.js +0 -96
  106. package/esm2015/lib/trusted-party/trusted-party.gql.private.js +0 -51
  107. package/esm2015/lib/trusted-party/trusted-party.service.js +0 -461
  108. package/esm2015/lib/trusted-party/trusted-party.types.js +0 -2
  109. package/esm2015/lib/two-factor/two-factor.service.js +0 -74
  110. package/esm2015/lib/user/user.gql.js +0 -32
  111. package/esm2015/lib/user/user.service.js +0 -58
  112. package/esm2015/lib/user/user.types.js +0 -2
  113. package/esm2015/lib/web-crypto/web-crypto.service.js +0 -29
  114. package/esm2015/lifeready-core.js +0 -17
  115. package/esm2015/public-api.js +0 -60
  116. package/fesm2015/lifeready-core.js +0 -10970
  117. package/fesm2015/lifeready-core.js.map +0 -1
  118. package/lib/_common/ast.d.ts +0 -11
  119. package/lib/_common/deferred-promise.d.ts +0 -12
  120. package/lib/_common/exceptions.d.ts +0 -126
  121. package/lib/_common/index.d.ts +0 -2
  122. package/lib/_common/kc-lodash.d.ts +0 -5
  123. package/lib/_common/key.d.ts +0 -14
  124. package/lib/_common/queries.gql.d.ts +0 -4
  125. package/lib/_common/run-outside-angular.d.ts +0 -14
  126. package/lib/_common/storage.d.ts +0 -13
  127. package/lib/_common/types.d.ts +0 -15
  128. package/lib/_common/utils.d.ts +0 -12
  129. package/lib/api/lr-apollo.service.d.ts +0 -15
  130. package/lib/api/lr-graphql/index.d.ts +0 -5
  131. package/lib/api/lr-graphql/lr-graphql.service.d.ts +0 -81
  132. package/lib/api/lr-graphql/lr-merged-mutation.d.ts +0 -46
  133. package/lib/api/lr-graphql/lr-mutation-base.d.ts +0 -28
  134. package/lib/api/lr-graphql/lr-mutation.d.ts +0 -48
  135. package/lib/api/lr-graphql/lr.service.d.ts +0 -9
  136. package/lib/api/query-processor/common-processors.service.d.ts +0 -36
  137. package/lib/api/query-processor/index.d.ts +0 -2
  138. package/lib/api/query-processor/query-processor.service.d.ts +0 -18
  139. package/lib/api/query-processor/tp-password-reset-processor.service.d.ts +0 -15
  140. package/lib/api/types/graphql.types.d.ts +0 -30
  141. package/lib/api/types/index.d.ts +0 -2
  142. package/lib/api/types/lr-graphql.types.d.ts +0 -807
  143. package/lib/auth/auth.config.d.ts +0 -5
  144. package/lib/auth/auth.gql.private.d.ts +0 -25
  145. package/lib/auth/auth.service.d.ts +0 -72
  146. package/lib/auth/auth.types.d.ts +0 -70
  147. package/lib/contact-card/contact-card.gql.d.ts +0 -7
  148. package/lib/contact-card/contact-card.service.d.ts +0 -53
  149. package/lib/contact-card/contact-card2.gql.d.ts +0 -25
  150. package/lib/contact-card/contact-card2.service.d.ts +0 -64
  151. package/lib/encryption/encryption.service.d.ts +0 -42
  152. package/lib/file-upload/file-upload.service.d.ts +0 -15
  153. package/lib/file-upload/file-upload.types.d.ts +0 -5
  154. package/lib/idle/idle.service.d.ts +0 -47
  155. package/lib/idle/idle.types.d.ts +0 -10
  156. package/lib/item/item.gql.d.ts +0 -134
  157. package/lib/item/item.gql.private.d.ts +0 -35
  158. package/lib/item/item.service.d.ts +0 -201
  159. package/lib/item/item.types.d.ts +0 -95
  160. package/lib/key/key-factory.service.d.ts +0 -40
  161. package/lib/key/key-graph.service.d.ts +0 -41
  162. package/lib/key/key-meta.service.d.ts +0 -51
  163. package/lib/key/key.service.d.ts +0 -36
  164. package/lib/key/key.types.d.ts +0 -86
  165. package/lib/key-exchange/key-exchange.gql.d.ts +0 -141
  166. package/lib/key-exchange/key-exchange.service.d.ts +0 -179
  167. package/lib/lbop/lbop.service.d.ts +0 -99
  168. package/lib/life-ready.config.d.ts +0 -26
  169. package/lib/life-ready.module.d.ts +0 -5
  170. package/lib/lock/lock.gql.d.ts +0 -27
  171. package/lib/lock/lock.service.d.ts +0 -34
  172. package/lib/notification/notification.gql.d.ts +0 -37
  173. package/lib/notification/notification.service.d.ts +0 -64
  174. package/lib/password/password.gql.d.ts +0 -3
  175. package/lib/password/password.service.d.ts +0 -79
  176. package/lib/persist/persist.service.d.ts +0 -31
  177. package/lib/plan/plan.gql.d.ts +0 -69
  178. package/lib/plan/plan.service.d.ts +0 -111
  179. package/lib/plan/plan.types.d.ts +0 -16
  180. package/lib/profile/profile-details.service.d.ts +0 -20
  181. package/lib/profile/profile.gql.d.ts +0 -21
  182. package/lib/profile/profile.service.d.ts +0 -32
  183. package/lib/profile/profile.types.d.ts +0 -121
  184. package/lib/register/register.service.d.ts +0 -25
  185. package/lib/register/register.types.d.ts +0 -6
  186. package/lib/reminder/reminder.gql.d.ts +0 -23
  187. package/lib/reminder/reminder.service.d.ts +0 -33
  188. package/lib/reminder/reminder.types.d.ts +0 -17
  189. package/lib/scenario/scenario.constants.d.ts +0 -1
  190. package/lib/scenario/scenario.controller.d.ts +0 -10
  191. package/lib/scenario/scenario.gql.d.ts +0 -78
  192. package/lib/scenario/scenario.private.gql.d.ts +0 -16
  193. package/lib/scenario/scenario.service.d.ts +0 -655
  194. package/lib/scenario/scenario.types.d.ts +0 -64
  195. package/lib/server-config/server-config.gql.d.ts +0 -5
  196. package/lib/server-config/server-config.service.d.ts +0 -9
  197. package/lib/shared-contact-card/shared-contact-card.service.d.ts +0 -33
  198. package/lib/shared-contact-card/shared-contact-card2.gql.d.ts +0 -36
  199. package/lib/shared-contact-card/shared-contact-card2.service.d.ts +0 -45
  200. package/lib/slip39/slip39.service.d.ts +0 -42
  201. package/lib/time/time.service.d.ts +0 -26
  202. package/lib/tp-assembly/tp-assembly.d.ts +0 -177
  203. package/lib/tp-assembly/tp-assembly.private.gql.d.ts +0 -5
  204. package/lib/tp-assembly/tp-assembly.types.d.ts +0 -40
  205. package/lib/tp-password-reset/tp-password-reset-request.service.d.ts +0 -16
  206. package/lib/tp-password-reset/tp-password-reset-user.service.d.ts +0 -29
  207. package/lib/tp-password-reset/tp-password-reset.constants.d.ts +0 -3
  208. package/lib/tp-password-reset/tp-password-reset.controller.d.ts +0 -10
  209. package/lib/tp-password-reset/tp-password-reset.gql.d.ts +0 -63
  210. package/lib/tp-password-reset/tp-password-reset.private.gql.d.ts +0 -163
  211. package/lib/tp-password-reset/tp-password-reset.private.service.d.ts +0 -59
  212. package/lib/tp-password-reset/tp-password-reset.service.d.ts +0 -112
  213. package/lib/tp-password-reset/tp-password-reset.types.d.ts +0 -40
  214. package/lib/trusted-party/trusted-party.gql.d.ts +0 -85
  215. package/lib/trusted-party/trusted-party.gql.private.d.ts +0 -40
  216. package/lib/trusted-party/trusted-party.service.d.ts +0 -192
  217. package/lib/trusted-party/trusted-party.types.d.ts +0 -31
  218. package/lib/two-factor/two-factor.service.d.ts +0 -15
  219. package/lib/user/user.gql.d.ts +0 -8
  220. package/lib/user/user.service.d.ts +0 -9
  221. package/lib/user/user.types.d.ts +0 -16
  222. package/lib/web-crypto/web-crypto.service.d.ts +0 -5
  223. package/lifeready-core.d.ts +0 -16
  224. package/lifeready-core.metadata.json +0 -1
  225. package/public-api.d.ts +0 -56
@@ -1,188 +0,0 @@
1
- import { __awaiter } from "tslib";
2
- /* eslint-disable @typescript-eslint/no-explicit-any */
3
- import { Injectable } from '@angular/core';
4
- import { JWE, JWS } from 'node-jose';
5
- import { PayloadType } from '../key/key.types';
6
- import { TimeService } from '../time/time.service';
7
- import { KcBadArgumentException, KcBadSignatureException, } from './../_common/exceptions';
8
- import * as i0 from "@angular/core";
9
- import * as i1 from "../time/time.service";
10
- export var JoseSerialization;
11
- (function (JoseSerialization) {
12
- JoseSerialization["JSON"] = "JSON";
13
- JoseSerialization["COMPACT"] = "COMPACT";
14
- })(JoseSerialization || (JoseSerialization = {}));
15
- export const VERIFY_OPTIONS_DEFAULT = {
16
- payloadType: PayloadType.JSON,
17
- returnOnlyPayload: true,
18
- };
19
- export const DECRYPT_OPTIONS_DEFAULT = {
20
- payloadType: PayloadType.JSON,
21
- returnOnlyPayload: true,
22
- serializations: [JoseSerialization.JSON],
23
- };
24
- export function isSymmetricKey(key) {
25
- // TODO: make sure this covers all cases.
26
- return key.kty === 'oct';
27
- }
28
- export function asJwk(key) {
29
- // TODO: make sure this covers all cases.
30
- // Excluded:
31
- // key.use - only for public keys, Ref: https://tools.ietf.org/html/rfc7517#section-4.2
32
- if (key.id && key.jwk) {
33
- return key.jwk;
34
- }
35
- else if (key.keystore && key.length && key.kty && key.kid && key.alg) {
36
- return key;
37
- }
38
- else {
39
- return null;
40
- }
41
- }
42
- export class EncryptionService {
43
- constructor(timeService) {
44
- this.timeService = timeService;
45
- }
46
- decrypt(key, // string is assumed to be key.id, will unwrap key.
47
- jwe, // string will be JSON.parsed
48
- options) {
49
- return __awaiter(this, void 0, void 0, function* () {
50
- const opt = {
51
- algorithms: ['dir', 'A*GCM', 'RSA-OAEP-*'],
52
- };
53
- options = Object.assign(Object.assign({}, DECRYPT_OPTIONS_DEFAULT), options);
54
- if (key.jwk) {
55
- key = key.jwk;
56
- }
57
- if (typeof jwe === 'string') {
58
- if (options.serializations.includes(JoseSerialization.JSON)) {
59
- try {
60
- jwe = JSON.parse(jwe);
61
- }
62
- catch (error) {
63
- if (options.serializations.includes(JoseSerialization.COMPACT)) {
64
- console.log('Not a JSON-formatted JWE, it maybe compact serialisation format.');
65
- }
66
- else {
67
- throw error;
68
- }
69
- }
70
- }
71
- }
72
- // {result} is a Object with:
73
- // * header: the combined 'protected' and 'unprotected' header members
74
- // * protected: an array of the member names from the "protected" member
75
- // * key: Key used to decrypt
76
- // * payload: Buffer of the decrypted content
77
- // * plaintext: Buffer of the decrypted content (alternate), just a reference to payload
78
- const res = yield JWE.createDecrypt(key, opt).decrypt(jwe);
79
- res.payload = this.decodePayload(options.payloadType, res.payload);
80
- if (options.returnOnlyPayload) {
81
- return res.payload;
82
- }
83
- else {
84
- return res;
85
- }
86
- });
87
- }
88
- // TODO rename this to encrypt() and use as the most common use case
89
- encryptToString(key, content) {
90
- return __awaiter(this, void 0, void 0, function* () {
91
- return JSON.stringify(yield this.encrypt(key, content));
92
- });
93
- }
94
- // TODO rename this to encryptToJSON() and use this when required.
95
- encrypt(key, content) {
96
- return __awaiter(this, void 0, void 0, function* () {
97
- if (content == null) {
98
- throw new Error('Encrypting null/undefined content.');
99
- }
100
- if (!(content instanceof ArrayBuffer)) {
101
- content = new TextEncoder().encode(JSON.stringify(content));
102
- }
103
- return JWE.createEncrypt({
104
- contentAlg: 'A256GCM',
105
- fields: {
106
- timestamp: yield this.timeService.serverNow(),
107
- },
108
- }, key)
109
- .update(content)
110
- .final();
111
- });
112
- }
113
- // <AZ> Unlike signContent, the serialised "content" variable is contained inside
114
- // the result. So ordering of fields within "content" is not an issue.
115
- sign(key, content) {
116
- return __awaiter(this, void 0, void 0, function* () {
117
- const signer = JWS.createSign({
118
- fields: {
119
- timestamp: yield this.timeService.serverNow(),
120
- },
121
- }, key);
122
- if (content instanceof Buffer) {
123
- signer.update(content);
124
- }
125
- else {
126
- signer.update(JSON.stringify(content), 'utf8');
127
- }
128
- return signer.final();
129
- });
130
- }
131
- signToString(key, content) {
132
- return __awaiter(this, void 0, void 0, function* () {
133
- return JSON.stringify(yield this.sign(key, content));
134
- });
135
- }
136
- verify(key, jws, options) {
137
- return __awaiter(this, void 0, void 0, function* () {
138
- const opt = {
139
- algorithms: ['RS*'],
140
- };
141
- options = Object.assign(Object.assign({}, VERIFY_OPTIONS_DEFAULT), options);
142
- try {
143
- const res = yield JWS.createVerify(key, opt).verify(jws);
144
- res.payload = this.decodePayload(options.payloadType, res.payload);
145
- if (options.returnOnlyPayload) {
146
- return res.payload;
147
- }
148
- else {
149
- return res;
150
- }
151
- }
152
- catch (error) {
153
- throw new KcBadSignatureException(`Bad signature: ${error}`);
154
- }
155
- });
156
- }
157
- encryptThenSign({ key, sigPrk, }, content) {
158
- return __awaiter(this, void 0, void 0, function* () {
159
- const cipher = JSON.stringify(yield this.encrypt(key, content));
160
- const sig = yield this.sign(sigPrk, cipher);
161
- delete sig.payload;
162
- return {
163
- cipher,
164
- sig: JSON.stringify(sig),
165
- };
166
- });
167
- }
168
- decodePayload(payloadType, payload) {
169
- switch (payloadType) {
170
- case PayloadType.JSON:
171
- return JSON.parse(new TextDecoder().decode(payload));
172
- case PayloadType.UINT_8_ARRAY:
173
- return payload;
174
- default:
175
- throw new KcBadArgumentException(`Unknown payloadType: ${payloadType}`);
176
- }
177
- }
178
- }
179
- EncryptionService.ɵprov = i0.ɵɵdefineInjectable({ factory: function EncryptionService_Factory() { return new EncryptionService(i0.ɵɵinject(i1.TimeService)); }, token: EncryptionService, providedIn: "root" });
180
- EncryptionService.decorators = [
181
- { type: Injectable, args: [{
182
- providedIn: 'root',
183
- },] }
184
- ];
185
- EncryptionService.ctorParameters = () => [
186
- { type: TimeService }
187
- ];
188
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW5jcnlwdGlvbi5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9zcmMvbGliL2VuY3J5cHRpb24vZW5jcnlwdGlvbi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSx1REFBdUQ7QUFDdkQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsR0FBRyxFQUFPLEdBQUcsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUUxQyxPQUFPLEVBQU8sV0FBVyxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDcEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ25ELE9BQU8sRUFDTCxzQkFBc0IsRUFDdEIsdUJBQXVCLEdBQ3hCLE1BQU0seUJBQXlCLENBQUM7OztBQUVqQyxNQUFNLENBQU4sSUFBWSxpQkFHWDtBQUhELFdBQVksaUJBQWlCO0lBQzNCLGtDQUFhLENBQUE7SUFDYix3Q0FBbUIsQ0FBQTtBQUNyQixDQUFDLEVBSFcsaUJBQWlCLEtBQWpCLGlCQUFpQixRQUc1QjtBQWFELE1BQU0sQ0FBQyxNQUFNLHNCQUFzQixHQUFrQjtJQUNuRCxXQUFXLEVBQUUsV0FBVyxDQUFDLElBQUk7SUFDN0IsaUJBQWlCLEVBQUUsSUFBSTtDQUN4QixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sdUJBQXVCLEdBQW1CO0lBQ3JELFdBQVcsRUFBRSxXQUFXLENBQUMsSUFBSTtJQUM3QixpQkFBaUIsRUFBRSxJQUFJO0lBQ3ZCLGNBQWMsRUFBRSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQztDQUN6QyxDQUFDO0FBRUYsTUFBTSxVQUFVLGNBQWMsQ0FBQyxHQUFZO0lBQ3pDLHlDQUF5QztJQUN6QyxPQUFPLEdBQUcsQ0FBQyxHQUFHLEtBQUssS0FBSyxDQUFDO0FBQzNCLENBQUM7QUFFRCxNQUFNLFVBQVUsS0FBSyxDQUFD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QUUsQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQztZQUN2RCxLQUFLLFdBQVcsQ0FBQyxZQUFZO2dCQUMzQixPQUFPLE9BQU8sQ0FBQztZQUNqQjtnQkFDRSxNQUFNLElBQUksc0JBQXNCLENBQUMsd0JBQXdCLFdBQVcsRUFBRSxDQUFDLENBQUM7U0FDM0U7SUFDSCxDQUFDOzs7O1lBekxGLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQjs7O1lBdERRLFdBQVciLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55ICovXG5pbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBKV0UsIEpXSywgSldTIH0gZnJvbSAnbm9kZS1qb3NlJztcbmltcG9ydCB7IEpTT05PYmplY3QgfSBmcm9tICcuLi9hcGkvdHlwZXMnO1xuaW1wb3J0IHsgS2V5LCBQYXlsb2FkVHlwZSB9IGZyb20gJy4uL2tleS9rZXkudHlwZXMnO1xuaW1wb3J0IHsgVGltZVNlcnZpY2UgfSBmcm9tICcuLi90aW1lL3RpbWUuc2VydmljZSc7XG5pbXBvcnQge1xuICBLY0JhZEFyZ3VtZW50RXhjZXB0aW9uLFxuICBLY0JhZFNpZ25hdHVyZUV4Y2VwdGlvbixcbn0gZnJvbSAnLi8uLi9fY29tbW9uL2V4Y2VwdGlvbnMnO1xuXG5leHBvcnQgZW51bSBKb3NlU2VyaWFsaXphdGlvbiB7XG4gIEpTT04gPSAnSlNPTicsXG4gIENPTVBBQ1QgPSAnQ09NUEFDVCcsXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVmVyaWZ5T3B0aW9ucyB7XG4gIHBheWxvYWRUeXBlPzogUGF5bG9hZFR5cGU7XG4gIHJldHVybk9ubHlQYXlsb2FkPzogYm9vbGVhbjsgLy8gSWYgdHJ1ZSwgcmV0dXJuIG9ubHkgdGhlIGRlY29kZWQgcGF5bG9hZC5cbn1cblxuZXhwb3J0IGludGVyZmFjZSBEZWNyeXB0T3B0aW9ucyB7XG4gIHBheWxvYWRUeXBlPzogUGF5bG9hZFR5cGU7XG4gIHJldHVybk9ubHlQYXlsb2FkPzogYm9vbGVhbjsgLy8gSWYgdHJ1ZSwgcmV0dXJuIG9ubHkgdGhlIGRlY29kZWQgcGF5bG9hZC5cbiAgc2VyaWFsaXphdGlvbnM/OiBKb3NlU2VyaWFsaXphdGlvbltdO1xufVxuXG5leHBvcnQgY29uc3QgVkVSSUZZX09QVElPTlNfREVGQVVMVDogVmVyaWZ5T3B0aW9ucyA9IHtcbiAgcGF5bG9hZFR5cGU6IFBheWxvYWRUeXBlLkpTT04sXG4gIHJldHVybk9ubHlQYXlsb2FkOiB0cnVlLFxufTtcblxuZXhwb3J0IGNvbnN0IERFQ1JZUFRfT1BUSU9OU19ERUZBVUxUOiBEZWNyeXB0T3B0aW9ucyA9IHtcbiAgcGF5bG9hZFR5cGU6IFBheWxvYWRUeXBlLkpTT04sXG4gIHJldHVybk9ubHlQYXlsb2FkOiB0cnVlLFxuICBzZXJpYWxpemF0aW9uczogW0pvc2VTZXJpYWxpemF0aW9uLkpTT05dLFxufTtcblxuZXhwb3J0IGZ1bmN0aW9uIGlzU3ltbWV0cmljS2V5KGtleTogSldLLktleSkge1xuICAvLyBUT0RPOiBtYWtlIHN1cmUgdGhpcyBjb3ZlcnMgYWxsIGNhc2VzLlxuICByZXR1cm4ga2V5Lmt0eSA9PT0gJ29jdCc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBhc0p3ayhrZXk6IEpXSy5LZXkgfCBLZXkgfCBhbnkpOiBKV0suS2V5IHwgbnVsbCB7XG4gIC8vIFRPRE86IG1ha2Ugc3VyZSB0aGlzIGNvdmVycyBhbGwgY2FzZXMuXG4gIC8vIEV4Y2x1ZGVkOlxuICAvLyAgIGtleS51c2UgLSBvbmx5IGZvciBwdWJsaWMga2V5cywgUmVmOiBodHRwczovL3Rvb2xzLmlldGYub3JnL2h0bWwvcmZjNzUxNyNzZWN0aW9uLTQuMlxuXG4gIGlmIChrZXkuaWQgJiYga2V5Lmp3aykge1xuICAgIHJldHVybiBrZXkuandrO1xuICB9IGVsc2UgaWYgKGtleS5rZXlzdG9yZSAmJiBrZXkubGVuZ3RoICYmIGtleS5rdHkgJiYga2V5LmtpZCAmJiBrZXkuYWxnKSB7XG4gICAgcmV0dXJuIGtleTtcbiAgfSBlbHNlIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxufVxuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgRW5jcnlwdGlvblNlcnZpY2Uge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHRpbWVTZXJ2aWNlOiBUaW1lU2VydmljZSkge31cblxuICBhc3luYyBkZWNyeXB0KFxuICAgIGtleTogSldLLktleSB8IEtleSwgLy8gc3RyaW5nIGlzIGFzc3VtZWQgdG8gYmUga2V5LmlkLCB3aWxsIHVud3JhcCBrZXkuXG4gICAgandlOiBSZWNvcmQ8c3RyaW5nLCBKU09OT2JqZWN0PiB8IHN0cmluZywgLy8gc3RyaW5nIHdpbGwgYmUgSlNPTi5wYXJzZWRcbiAgICBvcHRpb25zPzogRGVjcnlwdE9wdGlvbnNcbiAgKTogUHJvbWlzZTxKV0UuRGVjcnlwdFJlc3VsdCB8IGFueT4ge1xuICAgIGNvbnN0IG9wdCA9IHtcbiAgICAgIGFsZ29yaXRobXM6IFsnZGlyJywgJ0EqR0NNJywgJ1JTQS1PQUVQLSonXSxcbiAgICB9O1xuXG4gICAgb3B0aW9ucyA9IHtcbiAgICAgIC4uLkRFQ1JZUFRfT1BUSU9OU19ERUZBVUxULFxuICAgICAgLi4ub3B0aW9ucyxcbiAgICB9O1xuXG4gICAgaWYgKChrZXkgYXMgS2V5KS5qd2spIHtcbiAgICAgIGtleSA9IChrZXkgYXMgS2V5KS5qd2s7XG4gICAgfVxuXG4gICAgaWYgKHR5cGVvZiBqd2UgPT09ICdzdHJpbmcnKSB7XG4gICAgICBpZiAob3B0aW9ucy5zZXJpYWxpemF0aW9ucy5pbmNsdWRlcyhKb3NlU2VyaWFsaXphdGlvbi5KU09OKSkge1xuICAgICAgICB0cnkge1xuICAgICAgICAgIGp3ZSA9IEpTT04ucGFyc2UoandlKTtcbiAgICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgICBpZiAob3B0aW9ucy5zZXJpYWxpemF0aW9ucy5pbmNsdWRlcyhKb3NlU2VyaWFsaXphdGlvbi5DT01QQUNUKSkge1xuICAgICAgICAgICAgY29uc29sZS5sb2coXG4gICAgICAgICAgICAgICdOb3QgYSBKU09OLWZvcm1hdHRlZCBKV0UsIGl0IG1heWJlIGNvbXBhY3Qgc2VyaWFsaXNhdGlvbiBmb3JtYXQuJ1xuICAgICAgICAgICAgKTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdGhyb3cgZXJyb3I7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuXG4gICAgLy8ge3Jlc3VsdH0gaXMgYSBPYmplY3Qgd2l0aDpcbiAgICAvLyAqICBoZWFkZXI6IHRoZSBjb21iaW5lZCAncHJvdGVjdGVkJyBhbmQgJ3VucHJvdGVjdGVkJyBoZWFkZXIgbWVtYmVyc1xuICAgIC8vICogIHByb3RlY3RlZDogYW4gYXJyYXkgb2YgdGhlIG1lbWJlciBuYW1lcyBmcm9tIHRoZSBcInByb3RlY3RlZFwiIG1lbWJlclxuICAgIC8vICogIGtleTogS2V5IHVzZWQgdG8gZGVjcnlwdFxuICAgIC8vICogIHBheWxvYWQ6IEJ1ZmZlciBvZiB0aGUgZGVjcnlwdGVkIGNvbnRlbnRcbiAgICAvLyAqICBwbGFpbnRleHQ6IEJ1ZmZlciBvZiB0aGUgZGVjcnlwdGVkIGNvbnRlbnQgKGFsdGVybmF0ZSksIGp1c3QgYSByZWZlcmVuY2UgdG8gcGF5bG9hZFxuICAgIGNvbnN0IHJlcyA9IGF3YWl0IEpXRS5jcmVhdGVEZWNyeXB0KGtleSBhcyBKV0suS2V5LCBvcHQpLmRlY3J5cHQoXG4gICAgICBqd2UgYXMgYW55XG4gICAgKTtcblxuICAgIHJlcy5wYXlsb2FkID0gdGhpcy5kZWNvZGVQYXlsb2FkKG9wdGlvbnMucGF5bG9hZFR5cGUsIHJlcy5wYXlsb2FkKTtcblxuICAgIGlmIChvcHRpb25zLnJldHVybk9ubHlQYXlsb2FkKSB7XG4gICAgICByZXR1cm4gcmVzLnBheWxvYWQ7XG4gICAgfSBlbHNlIHtcbiAgICAgIHJldHVybiByZXM7XG4gICAgfVxuICB9XG5cbiAgLy8gVE9ETyByZW5hbWUgdGhpcyB0byBlbmNyeXB0KCkgYW5kIHVzZSBhcyB0aGUgbW9zdCBjb21tb24gdXNlIGNhc2VcbiAgYXN5bmMgZW5jcnlwdFRvU3RyaW5nKFxuICAgIGtleTogSldLLktleSxcbiAgICBjb250ZW50OiBBcnJheUJ1ZmZlciB8IHN0cmluZyB8IFJlY29yZDxzdHJpbmcsIEpTT05PYmplY3Q+XG4gICk6IFByb21pc2U8c3RyaW5nPiB7XG4gICAgcmV0dXJuIEpTT04uc3RyaW5naWZ5KGF3YWl0IHRoaXMuZW5jcnlwdChrZXksIGNvbnRlbnQpKTtcbiAgfVxuXG4gIC8vIFRPRE8gcmVuYW1lIHRoaXMgdG8gZW5jcnlwdFRvSlNPTigpIGFuZCB1c2UgdGhpcyB3aGVuIHJlcXVpcmVkLlxuICBhc3luYyBlbmNyeXB0KFxuICAgIGtleTogSldLLktleSxcbiAgICBjb250ZW50OiBBcnJheUJ1ZmZlciB8IHN0cmluZyB8IFJlY29yZDxzdHJpbmcsIEpTT05PYmplY3Q+XG4gICk6IFByb21pc2U8YW55PiB7XG4gICAgaWYgKGNvbnRlbnQgPT0gbnVsbCkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdFbmNyeXB0aW5nIG51bGwvdW5kZWZpbmVkIGNvbnRlbnQuJyk7XG4gICAgfVxuXG4gICAgaWYgKCEoY29udGVudCBpbnN0YW5jZW9mIEFycmF5QnVmZmVyKSkge1xuICAgICAgY29udGVudCA9IG5ldyBUZXh0RW5jb2RlcigpLmVuY29kZShKU09OLnN0cmluZ2lmeShjb250ZW50KSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIEpXRS5jcmVhdGVFbmNyeXB0KFxuICAgICAge1xuICAgICAgICBjb250ZW50QWxnOiAnQTI1NkdDTScsXG4gICAgICAgIGZpZWxkczoge1xuICAgICAgICAgIHRpbWVzdGFtcDogYXdhaXQgdGhpcy50aW1lU2VydmljZS5zZXJ2ZXJOb3coKSxcbiAgICAgICAgfSxcbiAgICAgIH0gYXMgYW55LFxuICAgICAga2V5XG4gICAgKVxuICAgICAgLnVwZGF0ZShjb250ZW50KVxuICAgICAgLmZpbmFsKCkgYXMgYW55O1xuICB9XG5cbiAgLy8gPEFaPiBVbmxpa2Ugc2lnbkNvbnRlbnQsIHRoZSBzZXJpYWxpc2VkIFwiY29udGVudFwiIHZhcmlhYmxlIGlzIGNvbnRhaW5lZCBpbnNpZGVcbiAgLy8gdGhlIHJlc3VsdC4gU28gb3JkZXJpbmcgb2YgZmllbGRzIHdpdGhpbiBcImNvbnRlbnRcIiBpcyBub3QgYW4gaXNzdWUuXG4gIGFzeW5jIHNpZ24oXG4gICAga2V5OiBKV0suS2V5LFxuICAgIGNvbnRlbnQ6IEJ1ZmZlciB8IHN0cmluZyB8IFJlY29yZDxzdHJpbmcsIEpTT05PYmplY3Q+XG4gICk6IFByb21pc2U8YW55PiB7XG4gICAgY29uc3Qgc2lnbmVyID0gSldTLmNyZWF0ZVNpZ24oXG4gICAgICB7XG4gICAgICAgIGZpZWxkczoge1xuICAgICAgICAgIHRpbWVzdGFtcDogYXdhaXQgdGhpcy50aW1lU2VydmljZS5zZXJ2ZXJOb3coKSxcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgICBrZXlcbiAgICApO1xuXG4gICAgaWYgKGNvbnRlbnQgaW5zdGFuY2VvZiBCdWZmZXIpIHtcbiAgICAgIHNpZ25lci51cGRhdGUoY29udGVudCk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHNpZ25lci51cGRhdGUoSlNPTi5zdHJpbmdpZnkoY29udGVudCksICd1dGY4Jyk7XG4gICAgfVxuXG4gICAgcmV0dXJuIHNpZ25lci5maW5hbCgpO1xuICB9XG5cbiAgYXN5bmMgc2lnblRvU3RyaW5nKFxuICAgIGtleTogSldLLktleSxcbiAgICBjb250ZW50OiBCdWZmZXIgfCBzdHJpbmcgfCBSZWNvcmQ8c3RyaW5nLCBKU09OT2JqZWN0PlxuICApOiBQcm9taXNlPHN0cmluZz4ge1xuICAgIHJldHVybiBKU09OLnN0cmluZ2lmeShhd2FpdCB0aGlzLnNpZ24oa2V5LCBjb250ZW50KSk7XG4gIH1cblxuICBhc3luYyB2ZXJpZnkoXG4gICAga2V5OiBKV0suS2V5LFxuICAgIGp3czogUmVjb3JkPHN0cmluZywgSlNPTk9iamVjdD4sXG4gICAgb3B0aW9ucz86IFZlcmlmeU9wdGlvbnNcbiAgKTogUHJvbWlzZTxhbnk+IHtcbiAgICBjb25zdCBvcHQgPSB7XG4gICAgICBhbGdvcml0aG1zOiBbJ1JTKiddLFxuICAgIH07XG5cbiAgICBvcHRpb25zID0ge1xuICAgICAgLi4uVkVSSUZZX09QVElPTlNfREVGQVVMVCxcbiAgICAgIC4uLm9wdGlvbnMsXG4gICAgfTtcblxuICAgIHRyeSB7XG4gICAgICBjb25zdCByZXMgPSBhd2FpdCBKV1MuY3JlYXRlVmVyaWZ5KGtleSwgb3B0KS52ZXJpZnkoandzIGFzIGFueSk7XG5cbiAgICAgIHJlcy5wYXlsb2FkID0gdGhpcy5kZWNvZGVQYXlsb2FkKG9wdGlvbnMucGF5bG9hZFR5cGUsIHJlcy5wYXlsb2FkKTtcblxuICAgICAgaWYgKG9wdGlvbnMucmV0dXJuT25seVBheWxvYWQpIHtcbiAgICAgICAgcmV0dXJuIHJlcy5wYXlsb2FkO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcmV0dXJuIHJlcztcbiAgICAgIH1cbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgdGhyb3cgbmV3IEtjQmFkU2lnbmF0dXJlRXhjZXB0aW9uKGBCYWQgc2lnbmF0dXJlOiAke2Vycm9yfWApO1xuICAgIH1cbiAgfVxuXG4gIGFzeW5jIGVuY3J5cHRUaGVuU2lnbihcbiAgICB7XG4gICAgICBrZXksXG4gICAgICBzaWdQcmssXG4gICAgfToge1xuICAgICAga2V5OiBKV0suS2V5O1xuICAgICAgc2lnUHJrOiBKV0suS2V5O1xuICAgIH0sXG4gICAgY29udGVudDogQXJyYXlCdWZmZXIgfCBzdHJpbmcgfCBSZWNvcmQ8c3RyaW5nLCBKU09OT2JqZWN0PlxuICApOiBQcm9taXNlPHsgY2lwaGVyOiBzdHJpbmc7IHNpZzogc3RyaW5nIH0+IHtcbiAgICBjb25zdCBjaXBoZXIgPSBKU09OLnN0cmluZ2lmeShhd2FpdCB0aGlzLmVuY3J5cHQoa2V5LCBjb250ZW50KSk7XG4gICAgY29uc3Qgc2lnID0gYXdhaXQgdGhpcy5zaWduKHNpZ1ByaywgY2lwaGVyKTtcbiAgICBkZWxldGUgc2lnLnBheWxvYWQ7XG5cbiAgICByZXR1cm4ge1xuICAgICAgY2lwaGVyLFxuICAgICAgc2lnOiBKU09OLnN0cmluZ2lmeShzaWcpLFxuICAgIH07XG4gIH1cblxuICBwcml2YXRlIGRlY29kZVBheWxvYWQoXG4gICAgcGF5bG9hZFR5cGU6IFBheWxvYWRUeXBlLFxuICAgIHBheWxvYWQ6IFVpbnQ4QXJyYXlcbiAgKTogVWludDhBcnJheSB8IGFueSB7XG4gICAgc3dpdGNoIChwYXlsb2FkVHlwZSkge1xuICAgICAgY2FzZSBQYXlsb2FkVHlwZS5KU09OOlxuICAgICAgICByZXR1cm4gSlNPTi5wYXJzZShuZXcgVGV4dERlY29kZXIoKS5kZWNvZGUocGF5bG9hZCkpO1xuICAgICAgY2FzZSBQYXlsb2FkVHlwZS5VSU5UXzhfQVJSQVk6XG4gICAgICAgIHJldHVybiBwYXlsb2FkO1xuICAgICAgZGVmYXVsdDpcbiAgICAgICAgdGhyb3cgbmV3IEtjQmFkQXJndW1lbnRFeGNlcHRpb24oYFVua25vd24gcGF5bG9hZFR5cGU6ICR7cGF5bG9hZFR5cGV9YCk7XG4gICAgfVxuICB9XG59XG4iXX0=
@@ -1,70 +0,0 @@
1
- import { __awaiter } from "tslib";
2
- import { HttpClient } from '@angular/common/http';
3
- import { Inject, Injectable } from '@angular/core';
4
- import { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';
5
- import { httpOptions, KC_CONFIG } from '../life-ready.config';
6
- import * as i0 from "@angular/core";
7
- import * as i1 from "../life-ready.config";
8
- import * as i2 from "@angular/common/http";
9
- import * as i3 from "@aws-amplify/auth/lib-esm/Auth";
10
- export class FileUploadService {
11
- constructor(config, http, auth) {
12
- this.config = config;
13
- this.http = http;
14
- this.auth = auth;
15
- }
16
- downloadEncryptedFileJson(fileStateNodeId) {
17
- return __awaiter(this, void 0, void 0, function* () {
18
- return JSON.parse(yield this.downloadEncryptedFile(fileStateNodeId));
19
- });
20
- }
21
- downloadEncryptedFile(fileStateNodeId) {
22
- return __awaiter(this, void 0, void 0, function* () {
23
- const url = `${this.config.apiUrl}files/download/?file_state_node_id=${fileStateNodeId}`;
24
- const content = yield this.http
25
- .get(url, Object.assign(Object.assign({}, (yield httpOptions(this.auth, this.config))), { responseType: 'text' }))
26
- .toPromise();
27
- return content;
28
- });
29
- }
30
- loadFile(file) {
31
- return __awaiter(this, void 0, void 0, function* () {
32
- if (file instanceof ArrayBuffer) {
33
- return file;
34
- }
35
- else {
36
- return new Promise((resolve) => {
37
- const reader = new FileReader();
38
- reader.onload = () => {
39
- // OK to type cast here since we are using readAsArrayBuffer.
40
- resolve(reader.result);
41
- };
42
- reader.readAsArrayBuffer(file);
43
- });
44
- }
45
- });
46
- }
47
- uploadEncryptedFile(options) {
48
- return __awaiter(this, void 0, void 0, function* () {
49
- const { encryptedContent, fileName } = options;
50
- const formData = new FormData();
51
- formData.append('content', new Blob([encryptedContent]), fileName);
52
- const { content_resource } = yield this.http
53
- .post(`${this.config.apiUrl}files/upload/`, formData, yield httpOptions(this.auth, this.config))
54
- .toPromise();
55
- return content_resource;
56
- });
57
- }
58
- }
59
- FileUploadService.ɵprov = i0.ɵɵdefineInjectable({ factory: function FileUploadService_Factory() { return new FileUploadService(i0.ɵɵinject(i1.KC_CONFIG), i0.ɵɵinject(i2.HttpClient), i0.ɵɵinject(i3.AuthClass)); }, token: FileUploadService, providedIn: "root" });
60
- FileUploadService.decorators = [
61
- { type: Injectable, args: [{
62
- providedIn: 'root',
63
- },] }
64
- ];
65
- FileUploadService.ctorParameters = () => [
66
- { type: undefined, decorators: [{ type: Inject, args: [KC_CONFIG,] }] },
67
- { type: HttpClient },
68
- { type: AuthClass }
69
- ];
70
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi9maWxlLXVwbG9hZC9maWxlLXVwbG9hZC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDbEQsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBRTNELE9BQU8sRUFBRSxXQUFXLEVBQVksU0FBUyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7Ozs7O0FBTXhFLE1BQU0sT0FBTyxpQkFBaUI7SUFDNUIsWUFDNkIsTUFBZ0IsRUFDbkMsSUFBZ0IsRUFDaEIsSUFBZTtRQUZJLFdBQU0sR0FBTixNQUFNLENBQVU7UUFDbkMsU0FBSSxHQUFKLElBQUksQ0FBWTtRQUNoQixTQUFJLEdBQUosSUFBSSxDQUFXO0lBQ3RCLENBQUM7SUFFRSx5QkFBeUIsQ0FDN0IsZUFBdUI7O1lBRXZCLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDO1FBQ3ZFLENBQUM7S0FBQTtJQUVLLHFCQUFxQixDQUFDLGVBQXVCOztZQUNqRCxNQUFNLEdBQUcsR0FBRyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxzQ0FBc0MsZUFBZSxFQUFFLENBQUM7WUFFekYsTUFBTSxPQUFPLEdBQUcsTUFBTSxJQUFJLENBQUMsSUFBSTtpQkFDNUIsR0FBRyxDQUFDLEdBQUcsa0NBQ0gsQ0FBQyxNQUFNLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxLQUM5QyxZQUFZLEVBQUUsTUFBTSxJQUNwQjtpQkFDRCxTQUFTLEVBQUUsQ0FBQztZQUVmLE9BQU8sT0FBTyxDQUFDO1FBQ2pCLENBQUM7S0FBQTtJQUVLLFFBQVEsQ0FBQyxJQUF3Qjs7WUFDckMsSUFBSSxJQUFJLFlBQVksV0FBVyxFQUFFO2dCQUMvQixPQUFPLElBQUksQ0FBQzthQUNiO2lCQUFNO2dCQUNMLE9BQU8sSUFBSSxPQUFPLENBQWMsQ0FBQyxPQUFPLEVBQUUsRUFBRTtvQkFDMUMsTUFBTSxNQUFNLEdBQUcsSUFBSSxVQUFVLEVBQUUsQ0FBQztvQkFDaEMsTUFBTSxDQUFDLE1BQU0sR0FBRyxHQUFHLEVBQUU7d0JBQ25CLDZEQUE2RDt3QkFDN0QsT0FBTyxDQUFDLE1BQU0sQ0FBQyxNQUFxQixDQUFDLENBQUM7b0JBQ3hDLENBQUMsQ0FBQztvQkFDRixNQUFNLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQ2pDLENBQUMsQ0FBQyxDQUFDO2FBQ0o7UUFDSCxDQUFDO0tBQUE7SUFFSyxtQkFBbUIsQ0FDdkIsT0FBbUM7O1lBRW5DLE1BQU0sRUFBRSxnQkFBZ0IsRUFBRSxRQUFRLEVBQUUsR0FBRyxPQUFPLENBQUM7WUFFL0MsTUFBTSxRQUFRLEdBQUcsSUFBSSxRQUFRLEVBQUUsQ0FBQztZQUNoQyxRQUFRLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBRSxJQUFJLElBQUksQ0FBQyxDQUFDLGdCQUFnQixDQUFDLENBQUMsRUFBRSxRQUFRLENBQUMsQ0FBQztZQUVuRSxNQUFNLEVBQUUsZ0JBQWdCLEVBQUUsR0FBRyxNQUFNLElBQUksQ0FBQyxJQUFJO2lCQUN6QyxJQUFJLENBQ0gsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sZUFBZSxFQUNwQyxRQUFRLEVBQ1IsTUFBTSxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLENBQzFDO2lCQUNBLFNBQVMsRUFBRSxDQUFDO1lBRWYsT0FBTyxnQkFBZ0IsQ0FBQztRQUMxQixDQUFDO0tBQUE7Ozs7WUE3REYsVUFBVSxTQUFDO2dCQUNWLFVBQVUsRUFBRSxNQUFNO2FBQ25COzs7NENBR0ksTUFBTSxTQUFDLFNBQVM7WUFaWixVQUFVO1lBRVYsU0FBUyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEh0dHBDbGllbnQgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQgeyBJbmplY3QsIEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEF1dGhDbGFzcyB9IGZyb20gJ0Bhd3MtYW1wbGlmeS9hdXRoL2xpYi1lc20vQXV0aCc7XG5pbXBvcnQgeyBKU09OT2JqZWN0IH0gZnJvbSAnLi4vYXBpL3R5cGVzJztcbmltcG9ydCB7IGh0dHBPcHRpb25zLCBLY0NvbmZpZywgS0NfQ09ORklHIH0gZnJvbSAnLi4vbGlmZS1yZWFkeS5jb25maWcnO1xuaW1wb3J0IHsgVXBsb2FkRW5jcnlwdGVkRmlsZU9wdGlvbnMgfSBmcm9tICcuL2ZpbGUtdXBsb2FkLnR5cGVzJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIEZpbGVVcGxvYWRTZXJ2aWNlIHtcbiAgY29uc3RydWN0b3IoXG4gICAgQEluamVjdChLQ19DT05GSUcpIHByaXZhdGUgY29uZmlnOiBLY0NvbmZpZyxcbiAgICBwcml2YXRlIGh0dHA6IEh0dHBDbGllbnQsXG4gICAgcHJpdmF0ZSBhdXRoOiBBdXRoQ2xhc3NcbiAgKSB7fVxuXG4gIGFzeW5jIGRvd25sb2FkRW5jcnlwdGVkRmlsZUpzb24oXG4gICAgZmlsZVN0YXRlTm9kZUlkOiBzdHJpbmdcbiAgKTogUHJvbWlzZTxKU09OT2JqZWN0PiB7XG4gICAgcmV0dXJuIEpTT04ucGFyc2UoYXdhaXQgdGhpcy5kb3dubG9hZEVuY3J5cHRlZEZpbGUoZmlsZVN0YXRlTm9kZUlkKSk7XG4gIH1cblxuICBhc3luYyBkb3dubG9hZEVuY3J5cHRlZEZpbGUoZmlsZVN0YXRlTm9kZUlkOiBzdHJpbmcpOiBQcm9taXNlPHN0cmluZz4ge1xuICAgIGNvbnN0IHVybCA9IGAke3RoaXMuY29uZmlnLmFwaVVybH1maWxlcy9kb3dubG9hZC8/ZmlsZV9zdGF0ZV9ub2RlX2lkPSR7ZmlsZVN0YXRlTm9kZUlkfWA7XG5cbiAgICBjb25zdCBjb250ZW50ID0gYXdhaXQgdGhpcy5odHRwXG4gICAgICAuZ2V0KHVybCwge1xuICAgICAgICAuLi4oYXdhaXQgaHR0cE9wdGlvbnModGhpcy5hdXRoLCB0aGlzLmNvbmZpZykpLFxuICAgICAgICByZXNwb25zZVR5cGU6ICd0ZXh0JyxcbiAgICAgIH0pXG4gICAgICAudG9Qcm9taXNlKCk7XG5cbiAgICByZXR1cm4gY29udGVudDtcbiAgfVxuXG4gIGFzeW5jIGxvYWRGaWxlKGZpbGU6IEZpbGUgfCBBcnJheUJ1ZmZlcik6IFByb21pc2U8QXJyYXlCdWZmZXI+IHtcbiAgICBpZiAoZmlsZSBpbnN0YW5jZW9mIEFycmF5QnVmZmVyKSB7XG4gICAgICByZXR1cm4gZmlsZTtcbiAgICB9IGVsc2Uge1xuICAgICAgcmV0dXJuIG5ldyBQcm9taXNlPEFycmF5QnVmZmVyPigocmVzb2x2ZSkgPT4ge1xuICAgICAgICBjb25zdCByZWFkZXIgPSBuZXcgRmlsZVJlYWRlcigpO1xuICAgICAgICByZWFkZXIub25sb2FkID0gKCkgPT4ge1xuICAgICAgICAgIC8vIE9LIHRvIHR5cGUgY2FzdCBoZXJlIHNpbmNlIHdlIGFyZSB1c2luZyByZWFkQXNBcnJheUJ1ZmZlci5cbiAgICAgICAgICByZXNvbHZlKHJlYWRlci5yZXN1bHQgYXMgQXJyYXlCdWZmZXIpO1xuICAgICAgICB9O1xuICAgICAgICByZWFkZXIucmVhZEFzQXJyYXlCdWZmZXIoZmlsZSk7XG4gICAgICB9KTtcbiAgICB9XG4gIH1cblxuICBhc3luYyB1cGxvYWRFbmNyeXB0ZWRGaWxlKFxuICAgIG9wdGlvbnM6IFVwbG9hZEVuY3J5cHRlZEZpbGVPcHRpb25zXG4gICk6IFByb21pc2U8c3RyaW5nPiB7XG4gICAgY29uc3QgeyBlbmNyeXB0ZWRDb250ZW50LCBmaWxlTmFtZSB9ID0gb3B0aW9ucztcblxuICAgIGNvbnN0IGZvcm1EYXRhID0gbmV3IEZvcm1EYXRhKCk7XG4gICAgZm9ybURhdGEuYXBwZW5kKCdjb250ZW50JywgbmV3IEJsb2IoW2VuY3J5cHRlZENvbnRlbnRdKSwgZmlsZU5hbWUpO1xuXG4gICAgY29uc3QgeyBjb250ZW50X3Jlc291cmNlIH0gPSBhd2FpdCB0aGlzLmh0dHBcbiAgICAgIC5wb3N0PHsgY29udGVudF9yZXNvdXJjZSB9PihcbiAgICAgICAgYCR7dGhpcy5jb25maWcuYXBpVXJsfWZpbGVzL3VwbG9hZC9gLFxuICAgICAgICBmb3JtRGF0YSxcbiAgICAgICAgYXdhaXQgaHR0cE9wdGlvbnModGhpcy5hdXRoLCB0aGlzLmNvbmZpZylcbiAgICAgIClcbiAgICAgIC50b1Byb21pc2UoKTtcblxuICAgIHJldHVybiBjb250ZW50X3Jlc291cmNlO1xuICB9XG59XG4iXX0=
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS11cGxvYWQudHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3NyYy9saWIvZmlsZS11cGxvYWQvZmlsZS11cGxvYWQudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIEZpbGVDb250ZW50Q29udGV4dCA9ICdGSUxFX1NUQVRFJztcblxuZXhwb3J0IGludGVyZmFjZSBVcGxvYWRFbmNyeXB0ZWRGaWxlT3B0aW9ucyB7XG4gIGVuY3J5cHRlZENvbnRlbnQ6IHN0cmluZztcbiAgLy8gVE9ETyBBZGQgaW4gdGhlIGNvbnRleHQgZmllbGQgYW5kIG1ha2UgaXQgbWFuZGF0b3J5XG4gIC8vIGNvbnRleHQ6IEZpbGVDb250ZW50Q29udGV4dDtcbiAgZmlsZU5hbWU/OiBzdHJpbmc7XG59XG4iXX0=
@@ -1,159 +0,0 @@
1
- import { __awaiter } from "tslib";
2
- import { HttpClient } from '@angular/common/http';
3
- import { Inject, Injectable } from '@angular/core';
4
- import { AuthClass } from '@aws-amplify/auth/lib-esm/Auth';
5
- import { DEFAULT_INTERRUPTSOURCES, Idle } from '@ng-idle/core';
6
- import { Keepalive } from '@ng-idle/keepalive';
7
- import { KeyService } from '../key/key.service';
8
- import { httpOptions, KC_CONFIG } from '../life-ready.config';
9
- import { KcBadArgumentException, KcBadStateException, } from '../_common/exceptions';
10
- import { Config } from './idle.types';
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 "../key/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 KcBadStateException('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 KcBadStateException('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 KcBadArgumentException('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({ onInit: false }));
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({ onInit: true }));
83
- }
84
- });
85
- }
86
- keepalivePost() {
87
- return __awaiter(this, void 0, void 0, function* () {
88
- const keepaliveResult = yield this.http
89
- .post(`${this.config.authUrl}auth/keepalive/`, null,
90
- // /auth/keepalive/ will be extending the sessions cookie.
91
- yield httpOptions(this.auth, this.config))
92
- .toPromise();
93
- return {
94
- keepaliveResult,
95
- expiresAfterSeconds: this.idle.getIdle() +
96
- this.idle.getTimeout() +
97
- this.keepalive.interval(),
98
- };
99
- });
100
- }
101
- persistMasterKey(masterKey) {
102
- return __awaiter(this, void 0, void 0, function* () {
103
- // The keepalive API call extends the server-side session, the session cookie expiry, refresh key cookie
104
- // expiry, and returns the session expiry.
105
- // NOTE Use time delta rather than absolute time, since client clock and server clock maybe
106
- // out of sync. We can't use the serverTime() functionality because the cookie expiry still
107
- // run on local clock.
108
- const { expiresAfterSeconds } = yield this.keepalivePost();
109
- // Persist the derived passKey
110
- yield this.keyService.persistMasterKey(masterKey, expiresAfterSeconds);
111
- });
112
- }
113
- onPing() {
114
- return __awaiter(this, void 0, void 0, function* () {
115
- console.log(`Keep alive triggered at time: ${Date.now()}. Interval set at: ${this.keepalive.interval()} seconds`);
116
- // Keepalive API will extend the session expiry.
117
- const { expiresAfterSeconds } = yield this.keepalivePost();
118
- // Extend the expiry of the persisted key
119
- yield this.keyService.setMasterKeyExpiresAfterSeconds(expiresAfterSeconds);
120
- yield Promise.resolve(this.onKeepalive && this.onKeepalive());
121
- });
122
- }
123
- start() {
124
- return __awaiter(this, void 0, void 0, function* () {
125
- if (!this.initCalled) {
126
- yield this.init();
127
- }
128
- if (this.idle.isRunning()) {
129
- return;
130
- }
131
- // Ping does not seem to happen right at the start. So we call it explicitly
132
- yield this.onPing();
133
- this.idle.watch();
134
- });
135
- }
136
- stop() {
137
- this.idle.stop();
138
- this.reset();
139
- }
140
- reset() {
141
- localStorage.removeItem(this.IDLE_EXPIRY_KEY);
142
- localStorage.removeItem(this.IDLING_KEY);
143
- }
144
- }
145
- IdleService.ɵprov = i0.ɵɵdefineInjectable({ factory: function IdleService_Factory() { return new IdleService(i0.ɵɵinject(i1.KC_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" });
146
- IdleService.decorators = [
147
- { type: Injectable, args: [{
148
- providedIn: 'root',
149
- },] }
150
- ];
151
- IdleService.ctorParameters = () => [
152
- { type: undefined, decorators: [{ type: Inject, args: [KC_CONFIG,] }] },
153
- { type: HttpClient },
154
- { type: Idle },
155
- { type: Keepalive },
156
- { type: KeyService },
157
- { type: AuthClass }
158
- ];
159
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWRsZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9zcmMvbGliL2lkbGUvaWRsZS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDbEQsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQzNELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxJQUFJLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDL0QsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUVoRCxPQUFPLEVBQUUsV0FBVyxFQUFZLFNBQVMsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3hFLE9BQU8sRUFDTCxzQkFBc0IsRUFDdEIsbUJBQW1CLEdBQ3BCLE1BQU0sdUJBQXVCLENBQUM7QUFDL0IsT0FBTyxFQUFFLE1BQU0sRUFBbUIsTUFBTSxjQUFjLENBQUM7Ozs7Ozs7O0FBd0J2RCxNQUFNLE9BQU8sV0FBVztJQVF0QixZQUM2QixNQUFnQixFQUNuQyxJQUFnQixFQUNoQixJQUFVLEVBQ1YsU0FBb0IsRUFDcEIsVUFBc0IsRUFDdEIsSUFBZTtRQUxJLFdBQU0sR0FBTixNQUFNLENBQVU7UUFDbkMsU0FBSSxHQUFKLElBQUksQ0FBWTtRQUNoQixTQUFJLEdBQUosSUFBSSxDQUFNO1FBQ1YsY0FBUyxHQUFULFNBQVMsQ0FBVztRQUNwQixlQUFVLEdBQVYsVUFBVSxDQUFZO1FBQ3RCLFNBQUksR0FBSixJQUFJLENBQVc7UUFiUixvQkFBZSxHQUFHLHFCQUFxQixDQUFDO1FBQ3hDLGVBQVUsR0FBRyxxQkFBcUIsQ0FBQztRQUU1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Q0FBQztRQUM5QyxZQUFZLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUMzQyxDQUFDOzs7O1lBaExGLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQjs7OzRDQVVJLE1BQU0sU0FBQyxTQUFTO1lBN0NaLFVBQVU7WUFHZ0IsSUFBSTtZQUM5QixTQUFTO1lBQ1QsVUFBVTtZQUhWLFNBQVMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgSW5qZWN0LCBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBdXRoQ2xhc3MgfSBmcm9tICdAYXdzLWFtcGxpZnkvYXV0aC9saWItZXNtL0F1dGgnO1xuaW1wb3J0IHsgREVGQVVMVF9JTlRFUlJVUFRTT1VSQ0VTLCBJZGxlIH0gZnJvbSAnQG5nLWlkbGUvY29yZSc7XG5pbXBvcnQgeyBLZWVwYWxpdmUgfSBmcm9tICdAbmctaWRsZS9rZWVwYWxpdmUnO1xuaW1wb3J0IHsgS2V5U2VydmljZSB9IGZyb20gJy4uL2tleS9rZXkuc2VydmljZSc7XG5pbXBvcnQgeyBLZXkgfSBmcm9tICcuLi9rZXkva2V5LnR5cGVzJztcbmltcG9ydCB7IGh0dHBPcHRpb25zLCBLY0NvbmZpZywgS0NfQ09ORklHIH0gZnJvbSAnLi4vbGlmZS1yZWFkeS5jb25maWcnO1xuaW1wb3J0IHtcbiAgS2NCYWRBcmd1bWVudEV4Y2VwdGlvbixcbiAgS2NCYWRTdGF0ZUV4Y2VwdGlvbixcbn0gZnJvbSAnLi4vX2NvbW1vbi9leGNlcHRpb25zJztcbmltcG9ydCB7IENvbmZpZywgS2VlcGFsaXZlUmVzdWx0IH0gZnJvbSAnLi9pZGxlLnR5cGVzJztcblxuLyoqXG4gKiBvbkluaXQ6IHRydWUgd2hlbiBvblRpbWVvdXQgaXMgY2FsbGVkIGZyb20gdGhlIGluaXQoKSBmdW5jdGlvbi4gaS5lLiB0YWIgd2FzIGNsb3NlZCBhbmQgb24gcmVsb2FkaW5nIHRoZSB3ZWJhcHAgaXQgYWxyZWFkeSB0aW1lZCBvdXQuXG4gKi9cbmV4cG9ydCB0eXBlIElkbGVTZXJ2aWNlT25UaW1lb3V0ID0gKHtcbiAgb25Jbml0OiBib29sZWFuLFxufSkgPT4gdm9pZCB8IFByb21pc2U8dm9pZD47XG5cbmV4cG9ydCB0eXBlIElkbGVTZXJ2aWNlT25LZWVwYWxpdmUgPSAoKSA9PiB2b2lkIHwgUHJvbWlzZTx2b2lkPjtcblxuZXhwb3J0IGludGVyZmFjZSBJZGxlU2VydmljZUluaXQge1xuICAvLyBLZWVwIHRoZXNlIGFzIGNhbGxiYWNrcyBzbyB3ZSBjYW4gZW5zdXJlIHRoZXkgYXJlIGNhbGxlZCBpbW1lZGlhdGVseSB3aXRob3V0IGdvaW5nIGludG8gdGhlXG4gIC8vIGV2ZW50IGxvb3AuXG4gIG9uVGltZW91dD86IElkbGVTZXJ2aWNlT25UaW1lb3V0O1xuICBvbktlZXBhbGl2ZT86IElkbGVTZXJ2aWNlT25LZWVwYWxpdmU7XG4gIGlkbGVTZWM/OiBudW1iZXI7XG4gIHRpbWVvdXRTZWM/OiBudW1iZXI7XG4gIGtlZXBBbGl2ZUludGVydmFsU2VjPzogbnVtYmVyO1xufVxuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgSWRsZVNlcnZpY2Uge1xuICBwcml2YXRlIHJlYWRvbmx5IElETEVfRVhQSVJZX0tFWSA9ICduZzJJZGxlLm1haW4uZXhwaXJ5JztcbiAgcHJpdmF0ZSByZWFkb25seSBJRExJTkdfS0VZID0gJ25nMklkbGUubWFpbi5pZGxpbmcnO1xuXG4gIHByaXZhdGUgaW5pdENhbGxlZCA9IGZhbHNlO1xuICBwcml2YXRlIG9uVGltZW91dDogSWRsZVNlcnZpY2VPblRpbWVvdXQ7XG4gIHByaXZhdGUgb25LZWVwYWxpdmU6IElkbGVTZXJ2aWNlT25LZWVwYWxpdmU7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgQEluamVjdChLQ19DT05GSUcpIHByaXZhdGUgY29uZmlnOiBLY0NvbmZpZyxcbiAgICBwcml2YXRlIGh0dHA6IEh0dHBDbGllbnQsXG4gICAgcHJpdmF0ZSBpZGxlOiBJZGxlLFxuICAgIHByaXZhdGUga2VlcGFsaXZlOiBLZWVwYWxpdmUsXG4gICAgcHJpdmF0ZSBrZXlTZXJ2aWNlOiBLZXlTZXJ2aWNlLFxuICAgIHByaXZhdGUgYXV0aDogQXV0aENsYXNzXG4gICkge31cblxuICBwcml2YXRlIGFzc2VydEluaXQoKTogdm9pZCB7XG4gICAgaWYgKCF0aGlzLmluaXRDYWxsZWQpIHtcbiAgICAgIHRocm93IG5ldyBLY0JhZFN0YXRlRXhjZXB0aW9uKCdDYWxsIElkbGVTZXJ2aWNlLmluaXQoKSBmaXJzdC4nKTtcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgaW5pdChwYXJhbXM/OiBJZGxlU2VydmljZUluaXQpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBpZiAodGhpcy5pbml0Q2FsbGVkKSB7XG4gICAgICB0aHJvdyBuZXcgS2NCYWRTdGF0ZUV4Y2VwdGlvbihcbiAgICAgICAgJ0lkbGVTZXJ2aWNlLmluaXQoKSBjYW4gb25seSBiZSBjYWxsZWQgb25jZS4gSWRsZVNlcnZpY2Uuc3RhcnQoKSBjYWxscyBpbml0KCkgd2l0aCBkZWZhdWx0IHZhbHVlcyBpZiBpbml0KCkgaGFzIG5vdCBiZWVuIGNhbGxlZCB5ZXQuJ1xuICAgICAgKTtcbiAgICB9XG5cbiAgICB0aGlzLmluaXRDYWxsZWQgPSB0cnVlO1xuXG4gICAgLy8gRGVmYXVsdHNcbiAgICBwYXJhbXMgPSB7XG4gICAgICBvblRpbWVvdXQ6IG51bGwsXG4gICAgICBvbktlZXBhbGl2ZTogbnVsbCxcbiAgICAgIGlkbGVTZWM6IENvbmZpZy5JRExFLFxuICAgICAgdGltZW91dFNlYzogQ29uZmlnLlRJTUVPVVQsXG4gICAgICBrZWVwQWxpdmVJbnRlcnZhbFNlYzogQ29uZmlnLktFRVBfQUxJVkVfSU5URVJWQUwsXG4gICAgICAuLi5wYXJhbXMsXG4gICAgfTtcblxuICAgIC8vIElmIHRpbWVvdXRTZWMgPT0gMCB0aGVuIHRoZSBvblRpbWVvdXQoKSBjYWxsYmFjayBpcyBuZXZlciBjYWxsZWQuXG4gICAgaWYgKHBhcmFtcy50aW1lb3V0U2VjIDwgMC4wMSkge1xuICAgICAgdGhyb3cgbmV3IEtjQmFkQXJndW1lbnRFeGNlcHRpb24oXG4gICAgICAgICdNaW5pbXVtIHZhbHVlIGZvciBJZGxlU2VydmljZS5pbml0KHsgdGltZW91dFNlYyB9KSBpcyAwLjAxJ1xuICAgICAgKTtcbiAgICB9XG5cbiAgICB0aGlzLm9uVGltZW91dCA9IHBhcmFtcy5vblRpbWVvdXQ7XG4gICAgdGhpcy5vbktlZXBhbGl2ZSA9IHBhcmFtcy5vbktlZXBhbGl2ZTtcblxuICAgIC8vIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLVxuICAgIC8vIFNldHVwIElkbGVcbiAgICAvLyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS1cbiAgICAvLyBzZXRzIGFuIGlkbGUgdGltZW91dCBvZiA1IHNlY29uZHMsIGZvciB0ZXN0aW5nIHB1cnBvc2VzLlxuICAgIHRoaXMuaWRsZS5zZXRJZGxlKHBhcmFtcy5pZGxlU2VjKTtcbiAgICAvLyBzZXRzIGEgdGltZW91dCBwZXJpb2Qgb2YgNSBzZWNvbmRzLiBhZnRlciAxMCBzZWNvbmRzIG9mIGluYWN0aXZpdHksIHRoZSB1c2VyIHdpbGwgYmUgY29uc2lkZXJlZCB0aW1lZCBvdXQuXG4gICAgdGhpcy5pZGxlLnNldFRpbWVvdXQocGFyYW1zLnRpbWVvdXRTZWMpO1xuICAgIC8vIHNldHMgdGhlIGRlZmF1bHQgaW50ZXJydXB0cywgaW4gdGhpcyBjYXNlLCB0aGluZ3MgbGlrZSBjbGlja3MsIHNjcm9sbHMsIHRvdWNoZXMgdG8gdGhlIGRvY3VtZW50XG4gICAgdGhpcy5pZGxlLnNldEludGVycnVwdHMoREVGQVVMVF9JTlRFUlJVUFRTT1VSQ0VTKTtcblxuICAgIHRoaXMuaWRsZS5vbklkbGVFbmQuc3Vic2NyaWJlKCgpID0+IGNvbnNvbGUubG9nKCdJZGxlIHN0b3BwZWQnKSk7XG4gICAgdGhpcy5pZGxlLm9uSWRsZVN0YXJ0LnN1YnNjcmliZSgoKSA9PiBjb25zb2xlLmxvZygnSWRsZSBzdGFydGVkJykpO1xuXG4gICAgdGhpcy5pZGxlLm9uVGltZW91dC5zdWJzY3JpYmUoYXN5bmMgKCkgPT4ge1xuICAgICAgY29uc29sZS5sb2coJ0lkbGUgdGltZWQgb3V0Jyk7XG4gICAgICB0aGlzLnJlc2V0KCk7XG4gICAgICBhd2FpdCBQcm9taXNlLnJlc29sdmUoXG4gICAgICAgIHRoaXMub25UaW1lb3V0ICYmIHRoaXMub25UaW1lb3V0KHsgb25Jbml0OiBmYWxzZSB9KVxuICAgICAgKTtcbiAgICB9KTtcbiAgICB0aGlzLmlkbGUub25UaW1lb3V0V2FybmluZy5zdWJzY3JpYmUoKGNvdW50ZG93bikgPT5cbiAgICAgIGNvbnNvbGUubG9nKGBXaWxsIHRpbWVvdXQgaW4gJHtjb3VudGRvd259IHNlY29uZHMhYClcbiAgICApO1xuXG4gICAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tXG4gICAgLy8gU2V0dXAgS2VlcGFsaXZlXG4gICAgLy8gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tXG4gICAgLy8gUmVmOiBodHRwczovL2dpdGh1Yi5jb20vbW9yaWJ2bmR2cy9uZzItaWRsZSNyZWFkbWVcbiAgICAvLyBuZy1pZGxlIHdpbGwgaW5zdHJ1Y3QgQG5nLWlkbGUva2VlcGFsaXZlIHRvIHBpbmcgd2hpbGUgdGhlIHVzZXIgaXMgYWN0aXZlLCBhbmQgc3RvcCBvbmNlXG4gICAgLy8gdGhleSBnbyBpZGxlIG9yIHRpbWUgb3V0LiBXaGVuIHRoZSB1c2VyIHJlc3VtZXMgYWN0aXZpdHkgb3IgdGhlIGlkbGUgc3RhdGUgaXMgcmVzZXQsIGl0IHdpbGxcbiAgICAvLyBwaW5nIGltbWVkaWF0ZWx5IGFuZCB0aGVuIHJlc3VtZSBwaW5naW5nLlxuICAgIHRoaXMua2VlcGFsaXZlLmludGVydmFsKHBhcmFtcy5rZWVwQWxpdmVJbnRlcnZhbFNlYyk7XG4gICAgY29uc29sZS5sb2coXG4gICAgICBgS2VlcCBhbGl2ZSBpbnRlcnZhbCBzZXQgYXQ6ICR7Q29uZmlnLktFRVBfQUxJVkVfSU5URVJWQUx9IHNlY29uZHNgXG4gICAgKTtcblxuICAgIHRoaXMua2VlcGFsaXZlLm9uUGluZy5zdWJzY3JpYmUoKCkgPT4gdGhpcy5vblBpbmcoKSk7XG5cbiAgICAvLyBJZiB0aGUgYnJvd3NlciB0YWIgaGFzIGJlZW4gY2xvc2VkIGZvciBhIHBlcmlvZCBsb25nZXIgdGhhbnQgdGhlIGluYWN0aXZpdHlcbiAgICAvLyBwZXJpb2QsIHRoZW4gd2Ugc2hvdWxkIGxvZ291dCByaWdodCBmcm9tIHRoZSBzdGFydC5cbiAgICBjb25zdCBpZGxlRXhwaXJ5ID0gbG9jYWxTdG9yYWdlLmdldEl0ZW0odGhpcy5JRExFX0VYUElSWV9LRVkpO1xuICAgIGlmIChcbiAgICAgIGlkbGVFeHBpcnkgJiZcbiAgICAgIHBhcnNlSW50KGlkbGVFeHBpcnksIDEwKSArIHRoaXMuaWRsZS5nZXRUaW1lb3V0KCkgKiAxMDAwIDwgRGF0ZS5ub3coKVxuICAgICkge1xuICAgICAgdGhpcy5yZXNldCgpO1xuICAgICAgYXdhaXQgUHJvbWlzZS5yZXNvbHZlKHRoaXMub25UaW1lb3V0ICYmIHRoaXMub25UaW1lb3V0KHsgb25Jbml0OiB0cnVlIH0pKTtcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgYXN5bmMga2VlcGFsaXZlUG9zdCgpOiBQcm9taXNlPHtcbiAgICBleHBpcmVzQWZ0ZXJTZWNvbmRzOiBudW1iZXI7XG4gICAga2VlcGFsaXZlUmVzdWx0OiBLZWVwYWxpdmVSZXN1bHQ7XG4gIH0+IHtcbiAgICBjb25zdCBrZWVwYWxpdmVSZXN1bHQgPSBhd2FpdCB0aGlzLmh0dHBcbiAgICAgIC5wb3N0PEtlZXBhbGl2ZVJlc3VsdD4oXG4gICAgICAgIGAke3RoaXMuY29uZmlnLmF1dGhVcmx9YXV0aC9rZWVwYWxpdmUvYCxcbiAgICAgICAgbnVsbCxcbiAgICAgICAgLy8gL2F1dGgva2VlcGFsaXZlLyB3aWxsIGJlIGV4dGVuZGluZyB0aGUgc2Vzc2lvbnMgY29va2llLlxuICAgICAgICBhd2FpdCBodHRwT3B0aW9ucyh0aGlzLmF1dGgsIHRoaXMuY29uZmlnKVxuICAgICAgKVxuICAgICAgLnRvUHJvbWlzZSgpO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIGtlZXBhbGl2ZVJlc3VsdCxcbiAgICAgIGV4cGlyZXNBZnRlclNlY29uZHM6XG4gICAgICAgIHRoaXMuaWRsZS5nZXRJZGxlKCkgK1xuICAgICAgICB0aGlzLmlkbGUuZ2V0VGltZW91dCgpICtcbiAgICAgICAgdGhpcy5rZWVwYWxpdmUuaW50ZXJ2YWwoKSxcbiAgICB9O1xuICB9XG5cbiAgcHVibGljIGFzeW5jIHBlcnNpc3RNYXN0ZXJLZXkobWFzdGVyS2V5OiBLZXkpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICAvLyBUaGUga2VlcGFsaXZlIEFQSSBjYWxsIGV4dGVuZHMgdGhlIHNlcnZlci1zaWRlIHNlc3Npb24sIHRoZSBzZXNzaW9uIGNvb2tpZSBleHBpcnksIHJlZnJlc2gga2V5IGNvb2tpZVxuICAgIC8vIGV4cGlyeSwgYW5kIHJldHVybnMgdGhlIHNlc3Npb24gZXhwaXJ5LlxuICAgIC8vIE5PVEUgVXNlIHRpbWUgZGVsdGEgcmF0aGVyIHRoYW4gYWJzb2x1dGUgdGltZSwgc2luY2UgY2xpZW50IGNsb2NrIGFuZCBzZXJ2ZXIgY2xvY2sgbWF5YmVcbiAgICAvLyBvdXQgb2Ygc3luYy4gV2UgY2FuJ3QgdXNlIHRoZSBzZXJ2ZXJUaW1lKCkgZnVuY3Rpb25hbGl0eSBiZWNhdXNlIHRoZSBjb29raWUgZXhwaXJ5IHN0aWxsXG4gICAgLy8gcnVuIG9uIGxvY2FsIGNsb2NrLlxuICAgIGNvbnN0IHsgZXhwaXJlc0FmdGVyU2Vjb25kcyB9ID0gYXdhaXQgdGhpcy5rZWVwYWxpdmVQb3N0KCk7XG5cbiAgICAvLyBQZXJzaXN0IHRoZSBkZXJpdmVkIHBhc3NLZXlcbiAgICBhd2FpdCB0aGlzLmtleVNlcnZpY2UucGVyc2lzdE1hc3RlcktleShtYXN0ZXJLZXksIGV4cGlyZXNBZnRlclNlY29uZHMpO1xuICB9XG5cbiAgcHJpdmF0ZSBhc3luYyBvblBpbmcoKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgY29uc29sZS5sb2coXG4gICAgICBgS2VlcCBhbGl2ZSB0cmlnZ2VyZWQgYXQgdGltZTogJHtEYXRlLm5vdygpfS4gSW50ZXJ2YWwgc2V0IGF0OiAke3RoaXMua2VlcGFsaXZlLmludGVydmFsKCl9IHNlY29uZHNgXG4gICAgKTtcblxuICAgIC8vIEtlZXBhbGl2ZSBBUEkgd2lsbCBleHRlbmQgdGhlIHNlc3Npb24gZXhwaXJ5LlxuICAgIGNvbnN0IHsgZXhwaXJlc0FmdGVyU2Vjb25kcyB9ID0gYXdhaXQgdGhpcy5rZWVwYWxpdmVQb3N0KCk7XG5cbiAgICAvLyBFeHRlbmQgdGhlIGV4cGlyeSBvZiB0aGUgcGVyc2lzdGVkIGtleVxuICAgIGF3YWl0IHRoaXMua2V5U2VydmljZS5zZXRNYXN0ZXJLZXlFeHBpcmVzQWZ0ZXJTZWNvbmRzKGV4cGlyZXNBZnRlclNlY29uZHMpO1xuXG4gICAgYXdhaXQgUHJvbWlzZS5yZXNvbHZlKHRoaXMub25LZWVwYWxpdmUgJiYgdGhpcy5vbktlZXBhbGl2ZSgpKTtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBzdGFydCgpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBpZiAoIXRoaXMuaW5pdENhbGxlZCkge1xuICAgICAgYXdhaXQgdGhpcy5pbml0KCk7XG4gICAgfVxuXG4gICAgaWYgKHRoaXMuaWRsZS5pc1J1bm5pbmcoKSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIC8vIFBpbmcgZG9lcyBub3Qgc2VlbSB0byBoYXBwZW4gcmlnaHQgYXQgdGhlIHN0YXJ0LiBTbyB3ZSBjYWxsIGl0IGV4cGxpY2l0bHlcbiAgICBhd2FpdCB0aGlzLm9uUGluZygpO1xuXG4gICAgdGhpcy5pZGxlLndhdGNoKCk7XG4gIH1cblxuICBwdWJsaWMgc3RvcCgpOiB2b2lkIHtcbiAgICB0aGlzLmlkbGUuc3RvcCgpO1xuICAgIHRoaXMucmVzZXQoKTtcbiAgfVxuXG4gIHByaXZhdGUgcmVzZXQoKSB7XG4gICAgbG9jYWxTdG9yYWdlLnJlbW92ZUl0ZW0odGhpcy5JRExFX0VYUElSWV9LRVkpO1xuICAgIGxvY2FsU3RvcmFnZS5yZW1vdmVJdGVtKHRoaXMuSURMSU5HX0tFWSk7XG4gIH1cbn1cbiJdfQ==
@@ -1,7 +0,0 @@
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWRsZS50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvc3JjL2xpYi9pZGxlL2lkbGUudHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksTUFJWDtBQUpELFdBQVksTUFBTTtJQUNoQiw0Q0FBYyxDQUFBO0lBQ2Qsc0NBQWMsQ0FBQTtJQUNkLGtFQUE0QixDQUFBO0FBQzlCLENBQUMsRUFKVyxNQUFNLEtBQU4sTUFBTSxRQUlqQiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIENvbmZpZyB7XG4gIFRJTUVPVVQgPSAwLjAxLCAvLyBzZWNvbmRzLCBtaW4gdmFsdWUgMC4wMSwgYWZ0ZXIgc3RhdGUgaXMgaWRsZSwgd2FpdCBmb3IgVElNRU9VVCBzZWNvbmRzIGJlZm9yZSB0YWtpbmcgYWN0aW9uXG4gIElETEUgPSA2MCAqIDIwLCAvLyBzZWNvbmRzLCBwZXJpb2Qgb2YgaW5hY3Rpdml0eSB0byBjb25zaWRlciBzdGF0ZSBhcyBpZGxlXG4gIEtFRVBfQUxJVkVfSU5URVJWQUwgPSA2MCAqIDEsIC8vIHNlY29uZHMsIHRyaWdnZXJlZCBvbiBhIHJlZ3VsYXIgYmFzaXMgd2hpbGUgYWN0aXZlIChpLmUuIHdoaWxlIG5vdCBpZGxpbmcpXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgS2VlcGFsaXZlUmVzdWx0IHtcbiAgc2Vzc2lvbjoge1xuICAgIGV4cGlyZXNfYWZ0ZXJfc2Vjb25kczogbnVtYmVyO1xuICB9O1xufVxuIl19