@lifeready/core 0.6.0-beta.1

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/README.md +62 -0
  2. package/bundles/lifeready-core.umd.js +15939 -0
  3. package/bundles/lifeready-core.umd.js.map +1 -0
  4. package/bundles/lifeready-core.umd.min.js +2 -0
  5. package/bundles/lifeready-core.umd.min.js.map +1 -0
  6. package/esm2015/lib/_common/ast.js +40 -0
  7. package/esm2015/lib/_common/deferred-promise.js +24 -0
  8. package/esm2015/lib/_common/exceptions.js +157 -0
  9. package/esm2015/lib/_common/queries.gql.js +190 -0
  10. package/esm2015/lib/_common/run-outside-angular.js +79 -0
  11. package/esm2015/lib/_common/types.js +1 -0
  12. package/esm2015/lib/_common/utils.js +44 -0
  13. package/esm2015/lib/api/contact-card.gql.js +79 -0
  14. package/esm2015/lib/api/contact-card.service.js +154 -0
  15. package/esm2015/lib/api/contact-card2.gql.js +60 -0
  16. package/esm2015/lib/api/contact-card2.service.js +103 -0
  17. package/esm2015/lib/api/file.service.js +74 -0
  18. package/esm2015/lib/api/item2.gql.js +110 -0
  19. package/esm2015/lib/api/item2.service.js +311 -0
  20. package/esm2015/lib/api/key-exchange.gql.js +188 -0
  21. package/esm2015/lib/api/key-exchange.service.js +442 -0
  22. package/esm2015/lib/api/key-exchange.types.js +18 -0
  23. package/esm2015/lib/api/key-exchange2.gql.js +171 -0
  24. package/esm2015/lib/api/key-exchange2.service.js +479 -0
  25. package/esm2015/lib/api/lock.gql.js +40 -0
  26. package/esm2015/lib/api/lock.service.js +64 -0
  27. package/esm2015/lib/api/lr-apollo.service.js +46 -0
  28. package/esm2015/lib/api/lr-graphql/index.js +6 -0
  29. package/esm2015/lib/api/lr-graphql/lr-graphql.service.js +155 -0
  30. package/esm2015/lib/api/lr-graphql/lr-merged-mutation.js +213 -0
  31. package/esm2015/lib/api/lr-graphql/lr-mutation-base.js +51 -0
  32. package/esm2015/lib/api/lr-graphql/lr-mutation.js +48 -0
  33. package/esm2015/lib/api/lr-graphql/lr.service.js +18 -0
  34. package/esm2015/lib/api/message.service.js +138 -0
  35. package/esm2015/lib/api/persist.service.js +181 -0
  36. package/esm2015/lib/api/query-processor/common-processors.service.js +93 -0
  37. package/esm2015/lib/api/query-processor/index.js +3 -0
  38. package/esm2015/lib/api/query-processor/query-processor.service.js +192 -0
  39. package/esm2015/lib/api/query-processor/tp-password-reset-processor.service.js +109 -0
  40. package/esm2015/lib/api/shared-contact-card.service.js +119 -0
  41. package/esm2015/lib/api/shared-contact-card2.gql.js +41 -0
  42. package/esm2015/lib/api/shared-contact-card2.service.js +117 -0
  43. package/esm2015/lib/api/time.service.js +146 -0
  44. package/esm2015/lib/api/types/graphql.types.js +7 -0
  45. package/esm2015/lib/api/types/index.js +3 -0
  46. package/esm2015/lib/api/types/lr-graphql.types.js +71 -0
  47. package/esm2015/lib/auth/auth.config.js +57 -0
  48. package/esm2015/lib/auth/auth.gql.js +48 -0
  49. package/esm2015/lib/auth/auth.types.js +27 -0
  50. package/esm2015/lib/auth/idle.service.js +168 -0
  51. package/esm2015/lib/auth/idle.types.js +7 -0
  52. package/esm2015/lib/auth/lbop.service.js +355 -0
  53. package/esm2015/lib/auth/life-ready-auth.service.js +333 -0
  54. package/esm2015/lib/auth/password.service.js +320 -0
  55. package/esm2015/lib/auth/register.service.js +172 -0
  56. package/esm2015/lib/auth/two-factor.service.js +74 -0
  57. package/esm2015/lib/category/category-meta.service.js +99 -0
  58. package/esm2015/lib/category/category.gql.js +406 -0
  59. package/esm2015/lib/category/category.service.js +390 -0
  60. package/esm2015/lib/category/category.types.js +29 -0
  61. package/esm2015/lib/cryptography/cryptography.types.js +11 -0
  62. package/esm2015/lib/cryptography/encryption.service.js +189 -0
  63. package/esm2015/lib/cryptography/key-factory.service.js +237 -0
  64. package/esm2015/lib/cryptography/key-graph.service.js +280 -0
  65. package/esm2015/lib/cryptography/key-meta.service.js +200 -0
  66. package/esm2015/lib/cryptography/key.service.js +124 -0
  67. package/esm2015/lib/cryptography/slip39.service.js +169 -0
  68. package/esm2015/lib/cryptography/web-crypto.service.js +29 -0
  69. package/esm2015/lib/life-ready.config.js +84 -0
  70. package/esm2015/lib/life-ready.module.js +74 -0
  71. package/esm2015/lib/plan/plan.gql.js +123 -0
  72. package/esm2015/lib/plan/plan.service.js +149 -0
  73. package/esm2015/lib/plan/plan.types.js +11 -0
  74. package/esm2015/lib/record/record-attachment.service.js +101 -0
  75. package/esm2015/lib/record/record.gql.js +179 -0
  76. package/esm2015/lib/record/record.service.js +206 -0
  77. package/esm2015/lib/record/record.types.js +15 -0
  78. package/esm2015/lib/record-type/record-type.service.js +75 -0
  79. package/esm2015/lib/record-type/record-type.types.js +28 -0
  80. package/esm2015/lib/scenario/approvals/scenario-approval.gql.js +105 -0
  81. package/esm2015/lib/scenario/approvals/scenario-approval.types.js +1 -0
  82. package/esm2015/lib/scenario/approvals/scenario-approver.service.js +300 -0
  83. package/esm2015/lib/scenario/claimants/scenario-claimant.gql.js +52 -0
  84. package/esm2015/lib/scenario/claimants/scenario-claimant.service.js +97 -0
  85. package/esm2015/lib/scenario/claimants/scenario-claimant.types.js +1 -0
  86. package/esm2015/lib/scenario/receivers/scenario-receiver.gql.js +150 -0
  87. package/esm2015/lib/scenario/receivers/scenario-receiver.service.js +229 -0
  88. package/esm2015/lib/scenario/receivers/scenario-receiver.types.js +1 -0
  89. package/esm2015/lib/scenario/scenario-setup.service.js +269 -0
  90. package/esm2015/lib/scenario/scenario.gql.js +368 -0
  91. package/esm2015/lib/scenario/scenario.service.js +611 -0
  92. package/esm2015/lib/scenario/scenario.types.js +64 -0
  93. package/esm2015/lib/search/search.gql.js +62 -0
  94. package/esm2015/lib/search/search.service.js +156 -0
  95. package/esm2015/lib/search/search.types.js +6 -0
  96. package/esm2015/lib/trusted-parties/tp-password-reset-request.service.js +112 -0
  97. package/esm2015/lib/trusted-parties/tp-password-reset-user.service.js +266 -0
  98. package/esm2015/lib/trusted-parties/tp-password-reset.gql.js +232 -0
  99. package/esm2015/lib/trusted-parties/tp-password-reset.service.js +300 -0
  100. package/esm2015/lib/trusted-parties/trusted-party.gql.js +148 -0
  101. package/esm2015/lib/trusted-parties/trusted-party.service.js +326 -0
  102. package/esm2015/lib/trusted-parties/trusted-party.types.js +41 -0
  103. package/esm2015/lib/trusted-parties/trusted-party2.gql.js +87 -0
  104. package/esm2015/lib/trusted-parties/trusted-party2.service.js +215 -0
  105. package/esm2015/lib/users/profile-details.service.js +214 -0
  106. package/esm2015/lib/users/profile.gql.js +97 -0
  107. package/esm2015/lib/users/profile.service.js +169 -0
  108. package/esm2015/lib/users/profile.types.js +34 -0
  109. package/esm2015/lib/users/user.gql.js +60 -0
  110. package/esm2015/lib/users/user.service.js +79 -0
  111. package/esm2015/lib/users/user.types.js +5 -0
  112. package/esm2015/lifeready-core.js +10 -0
  113. package/esm2015/public-api.js +81 -0
  114. package/fesm2015/lifeready-core.js +13290 -0
  115. package/fesm2015/lifeready-core.js.map +1 -0
  116. package/lib/_common/ast.d.ts +11 -0
  117. package/lib/_common/deferred-promise.d.ts +12 -0
  118. package/lib/_common/exceptions.d.ts +109 -0
  119. package/lib/_common/queries.gql.d.ts +10 -0
  120. package/lib/_common/run-outside-angular.d.ts +14 -0
  121. package/lib/_common/types.d.ts +10 -0
  122. package/lib/_common/utils.d.ts +3 -0
  123. package/lib/api/contact-card.gql.d.ts +7 -0
  124. package/lib/api/contact-card.service.d.ts +52 -0
  125. package/lib/api/contact-card2.gql.d.ts +34 -0
  126. package/lib/api/contact-card2.service.d.ts +49 -0
  127. package/lib/api/file.service.d.ts +18 -0
  128. package/lib/api/item2.gql.d.ts +96 -0
  129. package/lib/api/item2.service.d.ts +177 -0
  130. package/lib/api/key-exchange.gql.d.ts +9 -0
  131. package/lib/api/key-exchange.service.d.ts +39 -0
  132. package/lib/api/key-exchange.types.d.ts +196 -0
  133. package/lib/api/key-exchange2.gql.d.ts +125 -0
  134. package/lib/api/key-exchange2.service.d.ts +187 -0
  135. package/lib/api/lock.gql.d.ts +27 -0
  136. package/lib/api/lock.service.d.ts +25 -0
  137. package/lib/api/lr-apollo.service.d.ts +15 -0
  138. package/lib/api/lr-graphql/index.d.ts +5 -0
  139. package/lib/api/lr-graphql/lr-graphql.service.d.ts +60 -0
  140. package/lib/api/lr-graphql/lr-merged-mutation.d.ts +27 -0
  141. package/lib/api/lr-graphql/lr-mutation-base.d.ts +28 -0
  142. package/lib/api/lr-graphql/lr-mutation.d.ts +8 -0
  143. package/lib/api/lr-graphql/lr.service.d.ts +9 -0
  144. package/lib/api/message.service.d.ts +58 -0
  145. package/lib/api/persist.service.d.ts +31 -0
  146. package/lib/api/query-processor/common-processors.service.d.ts +36 -0
  147. package/lib/api/query-processor/index.d.ts +2 -0
  148. package/lib/api/query-processor/query-processor.service.d.ts +18 -0
  149. package/lib/api/query-processor/tp-password-reset-processor.service.d.ts +15 -0
  150. package/lib/api/shared-contact-card.service.d.ts +33 -0
  151. package/lib/api/shared-contact-card2.gql.d.ts +36 -0
  152. package/lib/api/shared-contact-card2.service.d.ts +45 -0
  153. package/lib/api/time.service.d.ts +16 -0
  154. package/lib/api/types/graphql.types.d.ts +29 -0
  155. package/lib/api/types/index.d.ts +2 -0
  156. package/lib/api/types/lr-graphql.types.d.ts +385 -0
  157. package/lib/auth/auth.config.d.ts +5 -0
  158. package/lib/auth/auth.gql.d.ts +15 -0
  159. package/lib/auth/auth.types.d.ts +66 -0
  160. package/lib/auth/idle.service.d.ts +40 -0
  161. package/lib/auth/idle.types.d.ts +10 -0
  162. package/lib/auth/lbop.service.d.ts +91 -0
  163. package/lib/auth/life-ready-auth.service.d.ts +46 -0
  164. package/lib/auth/password.service.d.ts +78 -0
  165. package/lib/auth/register.service.d.ts +25 -0
  166. package/lib/auth/two-factor.service.d.ts +15 -0
  167. package/lib/category/category-meta.service.d.ts +23 -0
  168. package/lib/category/category.gql.d.ts +45 -0
  169. package/lib/category/category.service.d.ts +67 -0
  170. package/lib/category/category.types.d.ts +79 -0
  171. package/lib/cryptography/cryptography.types.d.ts +83 -0
  172. package/lib/cryptography/encryption.service.d.ts +41 -0
  173. package/lib/cryptography/key-factory.service.d.ts +38 -0
  174. package/lib/cryptography/key-graph.service.d.ts +33 -0
  175. package/lib/cryptography/key-meta.service.d.ts +44 -0
  176. package/lib/cryptography/key.service.d.ts +36 -0
  177. package/lib/cryptography/slip39.service.d.ts +43 -0
  178. package/lib/cryptography/web-crypto.service.d.ts +5 -0
  179. package/lib/life-ready.config.d.ts +14 -0
  180. package/lib/life-ready.module.d.ts +5 -0
  181. package/lib/plan/plan.gql.d.ts +11 -0
  182. package/lib/plan/plan.service.d.ts +33 -0
  183. package/lib/plan/plan.types.d.ts +31 -0
  184. package/lib/record/record-attachment.service.d.ts +16 -0
  185. package/lib/record/record.gql.d.ts +14 -0
  186. package/lib/record/record.service.d.ts +25 -0
  187. package/lib/record/record.types.d.ts +57 -0
  188. package/lib/record-type/record-type.service.d.ts +11 -0
  189. package/lib/record-type/record-type.types.d.ts +50 -0
  190. package/lib/scenario/approvals/scenario-approval.gql.d.ts +7 -0
  191. package/lib/scenario/approvals/scenario-approval.types.d.ts +63 -0
  192. package/lib/scenario/approvals/scenario-approver.service.d.ts +32 -0
  193. package/lib/scenario/claimants/scenario-claimant.gql.d.ts +5 -0
  194. package/lib/scenario/claimants/scenario-claimant.service.d.ts +17 -0
  195. package/lib/scenario/claimants/scenario-claimant.types.d.ts +18 -0
  196. package/lib/scenario/receivers/scenario-receiver.gql.d.ts +8 -0
  197. package/lib/scenario/receivers/scenario-receiver.service.d.ts +30 -0
  198. package/lib/scenario/receivers/scenario-receiver.types.d.ts +54 -0
  199. package/lib/scenario/scenario-setup.service.d.ts +22 -0
  200. package/lib/scenario/scenario.gql.d.ts +34 -0
  201. package/lib/scenario/scenario.service.d.ts +58 -0
  202. package/lib/scenario/scenario.types.d.ts +217 -0
  203. package/lib/search/search.gql.d.ts +1 -0
  204. package/lib/search/search.service.d.ts +25 -0
  205. package/lib/search/search.types.d.ts +20 -0
  206. package/lib/trusted-parties/tp-password-reset-request.service.d.ts +20 -0
  207. package/lib/trusted-parties/tp-password-reset-user.service.d.ts +41 -0
  208. package/lib/trusted-parties/tp-password-reset.gql.d.ts +218 -0
  209. package/lib/trusted-parties/tp-password-reset.service.d.ts +131 -0
  210. package/lib/trusted-parties/trusted-party.gql.d.ts +9 -0
  211. package/lib/trusted-parties/trusted-party.service.d.ts +44 -0
  212. package/lib/trusted-parties/trusted-party.types.d.ts +102 -0
  213. package/lib/trusted-parties/trusted-party2.gql.d.ts +79 -0
  214. package/lib/trusted-parties/trusted-party2.service.d.ts +114 -0
  215. package/lib/users/profile-details.service.d.ts +21 -0
  216. package/lib/users/profile.gql.d.ts +11 -0
  217. package/lib/users/profile.service.d.ts +35 -0
  218. package/lib/users/profile.types.d.ts +96 -0
  219. package/lib/users/user.gql.d.ts +9 -0
  220. package/lib/users/user.service.d.ts +12 -0
  221. package/lib/users/user.types.d.ts +23 -0
  222. package/lifeready-core.d.ts +9 -0
  223. package/lifeready-core.metadata.json +1 -0
  224. package/package.json +29 -0
  225. package/public-api.d.ts +77 -0
@@ -0,0 +1,171 @@
1
+ import { gqlTyped } from '../_common/ast';
2
+ export const KeyExchangeFragment = gqlTyped `
3
+ fragment KeyExchangeFragment on KeyExchangeNode {
4
+ id
5
+ token
6
+ state
7
+ mode
8
+ isInitiator
9
+ initiator {
10
+ id
11
+ username
12
+ }
13
+ responder {
14
+ id
15
+ username
16
+ }
17
+ created
18
+ modified
19
+ tokenExpiryTime
20
+ isExpired
21
+ initiatorRootKeyCipher
22
+ initiatorActionRequired
23
+ responderActionRequired
24
+ responderEmailAddress
25
+ otk {
26
+ state
27
+ otKeyParams
28
+ otKeyCipher
29
+ sharedKey {
30
+ id
31
+ }
32
+ mkSharedKey {
33
+ id
34
+ }
35
+ initiatorSigPxk {
36
+ id
37
+ }
38
+ responderSigPxk {
39
+ id
40
+ }
41
+ initiatorOneTimePbkCipher
42
+ responderPbkCipher
43
+ }
44
+ }
45
+ `;
46
+ export const UserSharedKeyFragment = gqlTyped `
47
+ fragment UserSharedKeyFragment on UserSharedKeyNode {
48
+ userSigPrk {
49
+ id
50
+ }
51
+ otherSigPbk {
52
+ id
53
+ }
54
+ sharedKey {
55
+ id
56
+ }
57
+ mkSharedKey {
58
+ id
59
+ }
60
+ }`;
61
+ export const KeyExchangesQuery2 = gqlTyped `
62
+ query KeyExchangesQuery2($state: String) {
63
+ keyExchanges(state: $state) {
64
+ edges {
65
+ node {
66
+ ...KeyExchangeFragment
67
+ }
68
+ }
69
+ }
70
+ }
71
+ ${KeyExchangeFragment}
72
+ `;
73
+ export const KeyExchangeQuery2 = gqlTyped `
74
+ query KeyExchangeQuery2($id: LrRelayIdInput!) {
75
+ keyExchange(id: $id) {
76
+ ...KeyExchangeFragment
77
+ }
78
+ }
79
+ ${KeyExchangeFragment}
80
+ `;
81
+ export const KeyExchangeTokenQuery2 = gqlTyped `
82
+ query KeyExchangeTokenQuery2($id: LrRelayIdInput!, $token: String) {
83
+ keyExchange(id: $id, token: $token) {
84
+ ...KeyExchangeFragment
85
+ }
86
+ }
87
+ ${KeyExchangeFragment}
88
+ `;
89
+ export const CancelKeyExchangeMutation = gqlTyped `
90
+ mutation CancelKeyExchangeMutation($input: CancelKeyExchangeInput!) {
91
+ cancelKeyExchange(input: $input) {
92
+ keyExchange {
93
+ id
94
+ }
95
+ }
96
+ }
97
+ `;
98
+ export const DeclineKeyExchangeMutation = gqlTyped `
99
+ mutation DeclineKeyExchangeMutation($input: DeclineKeyExchangeInput!) {
100
+ declineKeyExchange(input: $input) {
101
+ keyExchange {
102
+ id
103
+ }
104
+ }
105
+ }
106
+ `;
107
+ export const InitiateKeyExchangeOtkMutation = gqlTyped `
108
+ mutation InitiateKeyExchangeOtkMutation(
109
+ $input: InitiateKeyExchangeOtkInput!
110
+ ) {
111
+ initiateKeyExchangeOtk(input: $input) {
112
+ keyExchange {
113
+ ...KeyExchangeFragment
114
+ }
115
+ }
116
+ }
117
+ ${KeyExchangeFragment}
118
+ `;
119
+ export const RespondKeyExchangeOtkMutation = gqlTyped `
120
+ mutation RespondKeyExchangeOtkMutation($input: RespondKeyExchangeOtkInput!) {
121
+ respondKeyExchangeOtk(input: $input) {
122
+ keyExchange {
123
+ ...KeyExchangeFragment
124
+ }
125
+ userSharedKey {
126
+ ...UserSharedKeyFragment
127
+ }
128
+ tp {
129
+ id
130
+ }
131
+ }
132
+ }
133
+ ${KeyExchangeFragment}
134
+ ${UserSharedKeyFragment}
135
+ `;
136
+ export const CompleteKeyExchangeOtkMutation = gqlTyped `
137
+ mutation CompleteKeyExchangeOtkMutation(
138
+ $input: CompleteKeyExchangeOtkInput!
139
+ ) {
140
+ completeKeyExchangeOtk(input: $input) {
141
+ keyExchange {
142
+ ...KeyExchangeFragment
143
+ }
144
+ userSharedKey {
145
+ ...UserSharedKeyFragment
146
+ }
147
+ tp {
148
+ id
149
+ }
150
+ }
151
+ }
152
+ ${KeyExchangeFragment}
153
+ ${UserSharedKeyFragment}
154
+ `;
155
+ export const CurrentUserSharedKeyQuery2 = gqlTyped `
156
+ query CurrentUserSharedKeyQuery2(
157
+ $username: String
158
+ $userId: LrRelayIdInput
159
+ ) {
160
+ currentUserSharedKey(
161
+ username: $username
162
+ userId: $userId
163
+ ) {
164
+ userSharedKey {
165
+ ...UserSharedKeyFragment
166
+ }
167
+ }
168
+ }
169
+ ${UserSharedKeyFragment}
170
+ `;
171
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5LWV4Y2hhbmdlMi5ncWwuanMiLCJzb3VyY2VSb290IjoiQzovUHJvamVjdHMvdGVzdC9wcm9qZWN0cy9jb3JlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9hcGkva2V5LWV4Y2hhbmdlMi5ncWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBOEQxQyxNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxRQUFRLENBQXFCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0NBMkMvRCxDQUFDO0FBZ0JGLE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFHLFFBQVEsQ0FBdUI7Ozs7Ozs7Ozs7Ozs7O0VBY2xFLENBQUM7QUFLSCxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxRQUFRLENBQW9COzs7Ozs7Ozs7O0VBVTVELG1CQUFtQjtDQUNwQixDQUFDO0FBS0YsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsUUFBUSxDQUFtQjs7Ozs7O0VBTTFELG1CQUFtQjtDQUNwQixDQUFDO0FBT0YsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsUUFBUSxDQUF3Qjs7Ozs7O0VBTXBFLG1CQUFtQjtDQUNwQixDQUFDO0FBU0YsTUFBTSxDQUFDLE1BQU0seUJBQXlCLEdBQUcsUUFBUSxDQUEyQjs7Ozs7Ozs7Q0FRM0UsQ0FBQztBQVNGLE1BQU0sQ0FBQyxNQUFNLDBCQUEwQixHQUFHLFFBQVEsQ0FBNEI7Ozs7Ozs7O0NBUTdFLENBQUM7QUFPRixNQUFNLENBQUMsTUFBTSw4QkFBOEIsR0FBRyxRQUFRLENBQWdDOzs7Ozs7Ozs7O0VBVXBGLG1CQUFtQjtDQUNwQixDQUFDO0FBV0YsTUFBTSxDQUFDLE1BQU0sNkJBQTZCLEdBQUcsUUFBUSxDQUErQjs7Ozs7Ozs7Ozs7Ozs7RUFjbEYsbUJBQW1CO0VBQ25CLHFCQUFxQjtDQUN0QixDQUFDO0FBV0YsTUFBTSxDQUFDLE1BQU0sOEJBQThCLEdBQUcsUUFBUSxDQUFnQzs7Ozs7Ozs7Ozs7Ozs7OztFQWdCcEYsbUJBQW1CO0VBQ25CLHFCQUFxQjtDQUN0QixDQUFDO0FBT0YsTUFBTSxDQUFDLE1BQU0sMEJBQTBCLEdBQUcsUUFBUSxDQUE0Qjs7Ozs7Ozs7Ozs7Ozs7RUFjNUUscUJBQXFCO0NBQ3RCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgZ3FsIGZyb20gJ2dyYXBocWwtdGFnJztcclxuaW1wb3J0IHsgSldLIH0gZnJvbSAnbm9kZS1qb3NlJztcclxuaW1wb3J0IHsgZ3FsVHlwZWQgfSBmcm9tICcuLi9fY29tbW9uL2FzdCc7XHJcbmltcG9ydCB7XHJcbiAgQ29ubmVjdGlvbixcclxuICBEYXRlVGltZSxcclxuICBJRCxcclxuICBMckVtYWlsLFxyXG4gIE90S2V5Q2lwaGVyQ2xlYXJKc29uMixcclxufSBmcm9tICcuL3R5cGVzJztcclxuXHJcbmV4cG9ydCB0eXBlIEtleUV4Y2hhbmdlU3RhdGUyID1cclxuICB8ICdJTl9QUk9HUkVTUydcclxuICB8ICdDT01QTEVURUQnXHJcbiAgfCAnREVDTElORUQnXHJcbiAgfCAnQ0FOQ0VMTEVEJ1xyXG4gIHwgJ0RFTEVURUQnO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBLZXlFeGNoYW5nZUZyYWdtZW50IHtcclxuICBpZDogSUQ7XHJcbiAgdG9rZW46IHN0cmluZztcclxuICBzdGF0ZTogS2V5RXhjaGFuZ2VTdGF0ZTI7XHJcbiAgbW9kZTogJ09USyc7XHJcbiAgaXNJbml0aWF0b3I6IGJvb2xlYW47XHJcbiAgaW5pdGlhdG9yOiB7XHJcbiAgICBpZDogSUQ7XHJcbiAgICB1c2VybmFtZTogc3RyaW5nO1xyXG4gIH07XHJcbiAgcmVzcG9uZGVyOiB7XHJcbiAgICBpZDogSUQ7XHJcbiAgICB1c2VybmFtZTogc3RyaW5nO1xyXG4gIH07XHJcbiAgY3JlYXRlZDogRGF0ZVRpbWU7XHJcbiAgbW9kaWZpZWQ6IERhdGVUaW1lO1xyXG4gIHRva2VuRXhwaXJ5VGltZTogRGF0ZVRpbWU7XHJcbiAgaXNFeHBpcmVkOiBib29sZWFuO1xyXG4gIGluaXRpYXRvclJvb3RLZXlDaXBoZXI6IHN0cmluZztcclxuICBpbml0aWF0b3JSb290S2V5Q2lwaGVyQ2xlYXJKc29uOiBhbnk7XHJcbiAgaW5pdGlhdG9yQWN0aW9uUmVxdWlyZWQ6IGJvb2xlYW47XHJcbiAgcmVzcG9uZGVyQWN0aW9uUmVxdWlyZWQ6IGJvb2xlYW47XHJcbiAgcmVzcG9uZGVyRW1haWxBZGRyZXNzOiBMckVtYWlsO1xyXG4gIG90azoge1xyXG4gICAgc3RhdGU6ICdPVEtfSU5JVElBVEVEJyB8ICdPVEtfQUNDRVBURUQnIHwgJ09US19DT01QTEVURUQnO1xyXG4gICAgb3RLZXlQYXJhbXM6IHN0cmluZztcclxuICAgIG90S2V5Q2lwaGVyOiBzdHJpbmc7XHJcbiAgICBvdEtleT86IEpXSy5LZXk7XHJcbiAgICBvdEtleUNpcGhlckNsZWFySnNvbj86IE90S2V5Q2lwaGVyQ2xlYXJKc29uMjtcclxuICAgIHNoYXJlZEtleToge1xyXG4gICAgICBpZDogSUQ7XHJcbiAgICB9O1xyXG4gICAgbWtTaGFyZWRLZXk6IHtcclxuICAgICAgaWQ6IElEO1xyXG4gICAgfTtcclxuICAgIGluaXRpYXRvclNpZ1B4azoge1xyXG4gICAgICBpZDogSUQ7XHJcbiAgICB9O1xyXG4gICAgcmVzcG9uZGVyU2lnUHhrOiB7XHJcbiAgICAgIGlkOiBJRDtcclxuICAgIH07XHJcbiAgICBpbml0aWF0b3JPbmVUaW1lUGJrQ2lwaGVyOiBzdHJpbmc7XHJcbiAgICBpbml0aWF0b3JPbmVUaW1lUGJrQ2lwaGVyQ2xlYXJKc29uOiBhbnk7XHJcbiAgICByZXNwb25kZXJQYmtDaXBoZXI6IHN0cmluZztcclxuICB9O1xyXG59XHJcbmV4cG9ydCBjb25zdCBLZXlFeGNoYW5nZUZyYWdtZW50ID0gZ3FsVHlwZWQ8S2V5RXhjaGFuZ2VGcmFnbWVudD5gXHJcbmZyYWdtZW50IEtleUV4Y2hhbmdlRnJhZ21lbnQgb24gS2V5RXhjaGFuZ2VOb2RlIHtcclxuICBpZFxyXG4gIHRva2VuXHJcbiAgc3RhdGVcclxuICBtb2RlXHJcbiAgaXNJbml0aWF0b3JcclxuICBpbml0aWF0b3Ige1xyXG4gICAgaWRcclxuICAgIHVzZXJuYW1lXHJcbiAgfVxyXG4gIHJlc3BvbmRlciB7XHJcbiAgICBpZFxyXG4gICAgdXNlcm5hbWVcclxuICB9XHJcbiAgY3JlYXRlZFxyXG4gIG1vZGlmaWVkXHJcbiAgdG9rZW5FeHBpcnlUaW1lXHJcbiAgaXNFeHBpcmVkXHJcbiAgaW5pdGlhdG9yUm9vdEtleUNpcGhlclxyXG4gIGluaXRpYXRvckFjdGlvblJlcXVpcmVkXHJcbiAgcmVzcG9uZGVyQWN0aW9uUmVxdWlyZWRcclxuICByZXNwb25kZXJFbWFpbEFkZHJlc3NcclxuICBvdGsge1xyXG4gICAgc3RhdGVcclxuICAgIG90S2V5UGFyYW1zXHJcbiAgICBvdEtleUNpcGhlclxyXG4gICAgc2hhcmVkS2V5IHtcclxuICAgICAgaWRcclxuICAgIH1cclxuICAgIG1rU2hhcmVkS2V5IHtcclxuICAgICAgaWRcclxuICAgIH1cclxuICAgIGluaXRpYXRvclNpZ1B4ayB7XHJcbiAgICAgIGlkXHJcbiAgICB9XHJcbiAgICByZXNwb25kZXJTaWdQeGsge1xyXG4gICAgICBpZFxyXG4gICAgfVxyXG4gICAgaW5pdGlhdG9yT25lVGltZVBia0NpcGhlclxyXG4gICAgcmVzcG9uZGVyUGJrQ2lwaGVyXHJcbiAgfVxyXG59XHJcbmA7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFVzZXJTaGFyZWRLZXlGcmFnbWVudCB7XHJcbiAgdXNlclNpZ1Byazoge1xyXG4gICAgaWQ6IElEO1xyXG4gIH07XHJcbiAgb3RoZXJTaWdQYms6IHtcclxuICAgIGlkOiBJRDtcclxuICB9O1xyXG4gIHNoYXJlZEtleToge1xyXG4gICAgaWQ6IElEO1xyXG4gIH07XHJcbiAgbWtTaGFyZWRLZXk6IHtcclxuICAgIGlkOiBJRDtcclxuICB9O1xyXG59XHJcbmV4cG9ydCBjb25zdCBVc2VyU2hhcmVkS2V5RnJhZ21lbnQgPSBncWxUeXBlZDxVc2VyU2hhcmVkS2V5RnJhZ21lbnQ+YFxyXG5mcmFnbWVudCBVc2VyU2hhcmVkS2V5RnJhZ21lbnQgb24gVXNlclNoYXJlZEtleU5vZGUge1xyXG4gIHVzZXJTaWdQcmsge1xyXG4gICAgaWRcclxuICB9XHJcbiAgb3RoZXJTaWdQYmsge1xyXG4gICAgaWRcclxuICB9XHJcbiAgc2hhcmVkS2V5IHtcclxuICAgIGlkXHJcbiAgfVxyXG4gIG1rU2hhcmVkS2V5IHtcclxuICAgIGlkXHJcbiAgfVxyXG59YDtcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgS2V5RXhjaGFuZ2VzUXVlcnkyIHtcclxuICBrZXlFeGNoYW5nZXM6IENvbm5lY3Rpb248S2V5RXhjaGFuZ2VGcmFnbWVudD47XHJcbn1cclxuZXhwb3J0IGNvbnN0IEtleUV4Y2hhbmdlc1F1ZXJ5MiA9IGdxbFR5cGVkPEtleUV4Y2hhbmdlc1F1ZXJ5Mj5gXHJcbnF1ZXJ5IEtleUV4Y2hhbmdlc1F1ZXJ5Migkc3RhdGU6IFN0cmluZykge1xyXG4gIGtleUV4Y2hhbmdlcyhzdGF0ZTogJHN0YXRlKSB7XHJcbiAgICBlZGdlcyB7XHJcbiAgICAgIG5vZGUge1xyXG4gICAgICAgIC4uLktleUV4Y2hhbmdlRnJhZ21lbnRcclxuICAgICAgfVxyXG4gICAgfVxyXG4gIH1cclxufVxyXG4ke0tleUV4Y2hhbmdlRnJhZ21lbnR9XHJcbmA7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEtleUV4Y2hhbmdlUXVlcnkyIHtcclxuICBrZXlFeGNoYW5nZTogS2V5RXhjaGFuZ2VGcmFnbWVudDtcclxufVxyXG5leHBvcnQgY29uc3QgS2V5RXhjaGFuZ2VRdWVyeTIgPSBncWxUeXBlZDxLZXlFeGNoYW5nZVF1ZXJ5Mj5gXHJcbnF1ZXJ5IEtleUV4Y2hhbmdlUXVlcnkyKCRpZDogTHJSZWxheUlkSW5wdXQhKSB7XHJcbiAga2V5RXhjaGFuZ2UoaWQ6ICRpZCkge1xyXG4gICAgLi4uS2V5RXhjaGFuZ2VGcmFnbWVudFxyXG4gIH1cclxufVxyXG4ke0tleUV4Y2hhbmdlRnJhZ21lbnR9XHJcbmA7XHJcblxyXG4vLyBLZXkgZ3JhcGggaXMgb25seSBhdmFpbGFibGUgZm9yIGF1dGhlbnRpY2F0ZWQgdXNlcnMuIFRoaXMgcXVlcnlcclxuLy8gaXMgZm9yIHVuYXV0aGVudGljYXRlZCB1c2Vycy5cclxuZXhwb3J0IGludGVyZmFjZSBLZXlFeGNoYW5nZVRva2VuUXVlcnkyIHtcclxuICBrZXlFeGNoYW5nZTogS2V5RXhjaGFuZ2VGcmFnbWVudDtcclxufVxyXG5leHBvcnQgY29uc3QgS2V5RXhjaGFuZ2VUb2tlblF1ZXJ5MiA9IGdxbFR5cGVkPEtleUV4Y2hhbmdlVG9rZW5RdWVyeTI+YFxyXG5xdWVyeSBLZXlFeGNoYW5nZVRva2VuUXVlcnkyKCRpZDogTHJSZWxheUlkSW5wdXQhLCAkdG9rZW46IFN0cmluZykge1xyXG4gIGtleUV4Y2hhbmdlKGlkOiAkaWQsIHRva2VuOiAkdG9rZW4pIHtcclxuICAgIC4uLktleUV4Y2hhbmdlRnJhZ21lbnRcclxuICB9XHJcbn1cclxuJHtLZXlFeGNoYW5nZUZyYWdtZW50fVxyXG5gO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBDYW5jZWxLZXlFeGNoYW5nZU11dGF0aW9uIHtcclxuICBjYW5jZWxLZXlFeGNoYW5nZToge1xyXG4gICAga2V5RXhjaGFuZ2U6IHtcclxuICAgICAgaWQ6IElEO1xyXG4gICAgfTtcclxuICB9O1xyXG59XHJcbmV4cG9ydCBjb25zdCBDYW5jZWxLZXlFeGNoYW5nZU11dGF0aW9uID0gZ3FsVHlwZWQ8Q2FuY2VsS2V5RXhjaGFuZ2VNdXRhdGlvbj5gXHJcbm11dGF0aW9uIENhbmNlbEtleUV4Y2hhbmdlTXV0YXRpb24oJGlucHV0OiBDYW5jZWxLZXlFeGNoYW5nZUlucHV0ISkge1xyXG4gIGNhbmNlbEtleUV4Y2hhbmdlKGlucHV0OiAkaW5wdXQpIHtcclxuICAgIGtleUV4Y2hhbmdlIHtcclxuICAgICAgaWRcclxuICAgIH1cclxuICB9XHJcbn1cclxuYDtcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgRGVjbGluZUtleUV4Y2hhbmdlTXV0YXRpb24ge1xyXG4gIGRlY2xpbmVLZXlFeGNoYW5nZToge1xyXG4gICAga2V5RXhjaGFuZ2U6IHtcclxuICAgICAgaWQ6IElEO1xyXG4gICAgfTtcclxuICB9O1xyXG59XHJcbmV4cG9ydCBjb25zdCBEZWNsaW5lS2V5RXhjaGFuZ2VNdXRhdGlvbiA9IGdxbFR5cGVkPERlY2xpbmVLZXlFeGNoYW5nZU11dGF0aW9uPmBcclxubXV0YXRpb24gRGVjbGluZUtleUV4Y2hhbmdlTXV0YXRpb24oJGlucHV0OiBEZWNsaW5lS2V5RXhjaGFuZ2VJbnB1dCEpIHtcclxuICBkZWNsaW5lS2V5RXhjaGFuZ2UoaW5wdXQ6ICRpbnB1dCkge1xyXG4gICAga2V5RXhjaGFuZ2Uge1xyXG4gICAgICBpZFxyXG4gICAgfVxyXG4gIH1cclxufVxyXG5gO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBJbml0aWF0ZUtleUV4Y2hhbmdlT3RrTXV0YXRpb24ge1xyXG4gIGluaXRpYXRlS2V5RXhjaGFuZ2VPdGs6IHtcclxuICAgIGtleUV4Y2hhbmdlOiBLZXlFeGNoYW5nZUZyYWdtZW50O1xyXG4gIH07XHJcbn1cclxuZXhwb3J0IGNvbnN0IEluaXRpYXRlS2V5RXhjaGFuZ2VPdGtNdXRhdGlvbiA9IGdxbFR5cGVkPEluaXRpYXRlS2V5RXhjaGFuZ2VPdGtNdXRhdGlvbj5gXHJcbm11dGF0aW9uIEluaXRpYXRlS2V5RXhjaGFuZ2VPdGtNdXRhdGlvbihcclxuICAkaW5wdXQ6IEluaXRpYXRlS2V5RXhjaGFuZ2VPdGtJbnB1dCFcclxuKSB7XHJcbiAgaW5pdGlhdGVLZXlFeGNoYW5nZU90ayhpbnB1dDogJGlucHV0KSB7XHJcbiAgICBrZXlFeGNoYW5nZSB7XHJcbiAgICAgIC4uLktleUV4Y2hhbmdlRnJhZ21lbnRcclxuICAgIH1cclxuICB9XHJcbn1cclxuJHtLZXlFeGNoYW5nZUZyYWdtZW50fVxyXG5gO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBSZXNwb25kS2V5RXhjaGFuZ2VPdGtNdXRhdGlvbiB7XHJcbiAgcmVzcG9uZEtleUV4Y2hhbmdlT3RrOiB7XHJcbiAgICBrZXlFeGNoYW5nZTogS2V5RXhjaGFuZ2VGcmFnbWVudDtcclxuICAgIHVzZXJTaGFyZWRLZXk6IFVzZXJTaGFyZWRLZXlGcmFnbWVudDtcclxuICAgIHRwOiB7XHJcbiAgICAgIGlkOiBJRDtcclxuICAgIH07XHJcbiAgfTtcclxufVxyXG5leHBvcnQgY29uc3QgUmVzcG9uZEtleUV4Y2hhbmdlT3RrTXV0YXRpb24gPSBncWxUeXBlZDxSZXNwb25kS2V5RXhjaGFuZ2VPdGtNdXRhdGlvbj5gXHJcbm11dGF0aW9uIFJlc3BvbmRLZXlFeGNoYW5nZU90a011dGF0aW9uKCRpbnB1dDogUmVzcG9uZEtleUV4Y2hhbmdlT3RrSW5wdXQhKSB7XHJcbiAgcmVzcG9uZEtleUV4Y2hhbmdlT3RrKGlucHV0OiAkaW5wdXQpIHtcclxuICAgIGtleUV4Y2hhbmdlIHtcclxuICAgICAgLi4uS2V5RXhjaGFuZ2VGcmFnbWVudFxyXG4gICAgfVxyXG4gICAgdXNlclNoYXJlZEtleSB7XHJcbiAgICAgIC4uLlVzZXJTaGFyZWRLZXlGcmFnbWVudFxyXG4gICAgfVxyXG4gICAgdHAge1xyXG4gICAgICBpZFxyXG4gICAgfVxyXG4gIH1cclxufVxyXG4ke0tleUV4Y2hhbmdlRnJhZ21lbnR9XHJcbiR7VXNlclNoYXJlZEtleUZyYWdtZW50fVxyXG5gO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBDb21wbGV0ZUtleUV4Y2hhbmdlT3RrTXV0YXRpb24ge1xyXG4gIGNvbXBsZXRlS2V5RXhjaGFuZ2VPdGs6IHtcclxuICAgIGtleUV4Y2hhbmdlOiBLZXlFeGNoYW5nZUZyYWdtZW50O1xyXG4gICAgdXNlclNoYXJlZEtleTogVXNlclNoYXJlZEtleUZyYWdtZW50O1xyXG4gICAgdHA6IHtcclxuICAgICAgaWQ6IElEO1xyXG4gICAgfTtcclxuICB9O1xyXG59XHJcbmV4cG9ydCBjb25zdCBDb21wbGV0ZUtleUV4Y2hhbmdlT3RrTXV0YXRpb24gPSBncWxUeXBlZDxDb21wbGV0ZUtleUV4Y2hhbmdlT3RrTXV0YXRpb24+YFxyXG5tdXRhdGlvbiBDb21wbGV0ZUtleUV4Y2hhbmdlT3RrTXV0YXRpb24oXHJcbiAgJGlucHV0OiBDb21wbGV0ZUtleUV4Y2hhbmdlT3RrSW5wdXQhXHJcbikge1xyXG4gIGNvbXBsZXRlS2V5RXhjaGFuZ2VPdGsoaW5wdXQ6ICRpbnB1dCkge1xyXG4gICAga2V5RXhjaGFuZ2Uge1xyXG4gICAgICAuLi5LZXlFeGNoYW5nZUZyYWdtZW50XHJcbiAgICB9XHJcbiAgICB1c2VyU2hhcmVkS2V5IHtcclxuICAgICAgLi4uVXNlclNoYXJlZEtleUZyYWdtZW50XHJcbiAgICB9XHJcbiAgICB0cCB7XHJcbiAgICAgIGlkXHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiR7S2V5RXhjaGFuZ2VGcmFnbWVudH1cclxuJHtVc2VyU2hhcmVkS2V5RnJhZ21lbnR9XHJcbmA7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEN1cnJlbnRVc2VyU2hhcmVkS2V5UXVlcnkyIHtcclxuICBjdXJyZW50VXNlclNoYXJlZEtleToge1xyXG4gICAgdXNlclNoYXJlZEtleTogVXNlclNoYXJlZEtleUZyYWdtZW50O1xyXG4gIH07XHJcbn1cclxuZXhwb3J0IGNvbnN0IEN1cnJlbnRVc2VyU2hhcmVkS2V5UXVlcnkyID0gZ3FsVHlwZWQ8Q3VycmVudFVzZXJTaGFyZWRLZXlRdWVyeTI+YFxyXG5xdWVyeSBDdXJyZW50VXNlclNoYXJlZEtleVF1ZXJ5MihcclxuICAkdXNlcm5hbWU6IFN0cmluZ1xyXG4gICR1c2VySWQ6IExyUmVsYXlJZElucHV0XHJcbikge1xyXG4gIGN1cnJlbnRVc2VyU2hhcmVkS2V5KFxyXG4gICAgdXNlcm5hbWU6ICR1c2VybmFtZVxyXG4gICAgdXNlcklkOiAkdXNlcklkXHJcbiAgKSB7XHJcbiAgICB1c2VyU2hhcmVkS2V5IHtcclxuICAgICAgLi4uVXNlclNoYXJlZEtleUZyYWdtZW50XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiR7VXNlclNoYXJlZEtleUZyYWdtZW50fVxyXG5gO1xyXG4iXX0=