@lifeready/core 1.0.15 → 1.0.16

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,18 +1,18 @@
1
- export var OtkState;
2
- (function (OtkState) {
3
- OtkState["OTK_INITIATED"] = "OTK_INITIATED";
4
- OtkState["OTK_ACCEPTED"] = "OTK_ACCEPTED";
5
- OtkState["OTK_COMPLETED"] = "OTK_COMPLETED";
6
- })(OtkState || (OtkState = {}));
7
- export var KeyExchangeState;
8
- (function (KeyExchangeState) {
9
- KeyExchangeState["IN_PROGRESS"] = "IN_PROGRESS";
10
- KeyExchangeState["COMPLETED"] = "COMPLETED";
11
- KeyExchangeState["DECLINED"] = "DECLINED";
12
- KeyExchangeState["CANCELLED"] = "CANCELLED";
13
- })(KeyExchangeState || (KeyExchangeState = {}));
14
- export var KeyExchangeMode;
15
- (function (KeyExchangeMode) {
16
- KeyExchangeMode["OTK"] = "OTK";
17
- })(KeyExchangeMode || (KeyExchangeMode = {}));
18
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key-exchange.types.js","sourceRoot":"C:/Projects/kc-client/projects/core/src/","sources":["lib/api/key-exchange.types.ts"],"names":[],"mappings":"AAsFA,MAAM,CAAN,IAAY,QAIX;AAJD,WAAY,QAAQ;IAClB,2CAA+B,CAAA;IAC/B,yCAA6B,CAAA;IAC7B,2CAA+B,CAAA;AACjC,CAAC,EAJW,QAAQ,KAAR,QAAQ,QAInB;AAgCD,MAAM,CAAN,IAAY,gBAKX;AALD,WAAY,gBAAgB;IAC1B,+CAA2B,CAAA;IAC3B,2CAAuB,CAAA;IACvB,yCAAqB,CAAA;IACrB,2CAAuB,CAAA;AACzB,CAAC,EALW,gBAAgB,KAAhB,gBAAgB,QAK3B;AAED,MAAM,CAAN,IAAY,eAEX;AAFD,WAAY,eAAe;IACzB,8BAAW,CAAA;AACb,CAAC,EAFW,eAAe,KAAf,eAAe,QAE1B","sourcesContent":["import { Key } from '../cryptography/cryptography.types';\r\nimport { AccessLevel } from '../category/category.types';\r\nimport { JWK } from 'node-jose';\r\nimport { ContactCardName, TrustedPartyDetails } from '../users/profile.types';\r\n\r\n// Will be encrypted using the root key of the initiator\r\nexport interface PlainInitiatorRootKeyCipher {\r\n  nonce: string;\r\n  oneTimePrk: object; // onetime public encryption key responder use to send data back to initiator\r\n  otKey: object;\r\n  initiatorContactCard?: {\r\n    // Owner only access to this data\r\n    plainOwnerCipherDataJson: any;\r\n    // Shared read access between owner and receiver. Only the owner has write access.\r\n    plainSharedCipherDataJson: any;\r\n  };\r\n  initiator: {\r\n    message?: KeyExchangeMessage;\r\n    contactCard?: {\r\n      // Shared read access between owner and receiver. Only the owner has write access.\r\n      plainSharedCipherDataJson: TrustedPartyDetails;\r\n    };\r\n  };\r\n}\r\n\r\nexport interface SharedContactCardInput {\r\n  plainCipherDataJson?: any;\r\n  plainSharedCipherDataJson?: any;\r\n  sharedCipherKey?: object;\r\n}\r\n\r\nexport interface PreparedPermissions {\r\n  categories?: { categoryId: string; accessLevel: AccessLevel }[];\r\n  records?: { recordId: string; accessLevel: AccessLevel }[];\r\n}\r\n\r\nexport interface KeyExchangeMessage {\r\n  name?: string;\r\n  email?: string;\r\n  message?: string;\r\n  permissions?: PreparedPermissions;\r\n}\r\n\r\nexport interface PlainOtKeyCipher {\r\n  nonce: string;\r\n  initiator: {\r\n    oneTimePbk: object; // onetime public encryption key responder use to send data back to initiator\r\n    pbk: object; // public encryption key\r\n    sigPbk: object; // public signing key\r\n    profile?: {\r\n      username?: string;\r\n    };\r\n    message?: KeyExchangeMessage;\r\n    contactCard?: {\r\n      // Shared read access between owner and receiver. Only the owner has write access.\r\n      plainSharedCipherDataJson: TrustedPartyDetails;\r\n    };\r\n  };\r\n}\r\n\r\nexport interface DecryptedOtk {\r\n  plainOtKeyCipher: PlainOtKeyCipher;\r\n  otKey: JWK.Key; // The one-time key\r\n}\r\n\r\nexport interface PlainInitiatorOneTimePbkCipher {\r\n  nonce: string;\r\n  sharedKey: object;\r\n  mkSharedKey: object;\r\n  responder: {\r\n    pbk: object;\r\n    sigPbk: object;\r\n    profile?: {\r\n      username?: string;\r\n    };\r\n    message?: KeyExchangeMessage;\r\n    contactCard?: {\r\n      plainSharedCipherDataJson: TrustedPartyDetails;\r\n      // Note that this is _not_ the same key as the sharedKey. The sharedKey wraps\r\n      // this key in the key graph. But because this key has not been entered into\r\n      // the key graph then the responder calls the API, we pass the JWK directly here.\r\n      sharedCipherKey: object;\r\n    };\r\n  };\r\n}\r\n\r\nexport enum OtkState {\r\n  OTK_INITIATED = 'OTK_INITIATED',\r\n  OTK_ACCEPTED = 'OTK_ACCEPTED',\r\n  OTK_COMPLETED = 'OTK_COMPLETED',\r\n}\r\n\r\nexport interface KeyExchangeContactCardInput {\r\n  // Accessible by the server and initiator. Server side notification emails need to know some\r\n  // information about the initiator.\r\n  ownerPlainData?: {\r\n    name: ContactCardName;\r\n  };\r\n  // Owner only access to this data\r\n  plainOwnerCipherDataJson: any;\r\n  // Shared read access between owner and receiver. Only the owner has write access.\r\n  plainSharedCipherDataJson: TrustedPartyDetails;\r\n}\r\n\r\nexport interface InitiateOtkInput {\r\n  email?: string;\r\n  message?: KeyExchangeMessage;\r\n  contactCard?: KeyExchangeContactCardInput;\r\n  upgrade?: boolean;\r\n}\r\n\r\nexport interface RespondOtkInput {\r\n  id: string;\r\n  token: string;\r\n  decryptedOtk: DecryptedOtk;\r\n  message?: KeyExchangeMessage;\r\n  initiatorContactCard?: {\r\n    plainReceiverCipherDataJson: any;\r\n  };\r\n  responderContactCard?: KeyExchangeContactCardInput;\r\n}\r\n\r\nexport enum KeyExchangeState {\r\n  IN_PROGRESS = 'IN_PROGRESS',\r\n  COMPLETED = 'COMPLETED',\r\n  DECLINED = 'DECLINED',\r\n  CANCELLED = 'CANCELLED',\r\n}\r\n\r\nexport enum KeyExchangeMode {\r\n  OTK = 'OTK',\r\n}\r\n\r\nexport interface Otk {\r\n  id: string;\r\n  state: OtkState;\r\n  otKeyParams: string;\r\n  otKeyCipher: string;\r\n  sharedKey: Key;\r\n  mkSharedKey: Key;\r\n  initiatorSigPxk: Key;\r\n  responderSigPxk: Key;\r\n  // Encrypted\r\n  initiatorOneTimePbkCipher: string; // single time use public key created by the initiator.\r\n  responderPbkCipher?: string; // responderPbk is the long lived Pbk of the responder.\r\n}\r\n\r\nexport interface KeyExchange {\r\n  id: string;\r\n  state: KeyExchangeState;\r\n  mode: KeyExchangeMode;\r\n  created: string;\r\n  modified: string;\r\n  isInitiator: boolean;\r\n  initiator: {\r\n    id: string;\r\n    username: string;\r\n  };\r\n  responder: {\r\n    id: string;\r\n    username: string;\r\n  };\r\n  initiatorActionRequired?: boolean;\r\n  responderActionRequired?: boolean;\r\n  responderEmailAddress?: string;\r\n  token?: string;\r\n  tokenExpiryTime?: string;\r\n  isExpired?: boolean;\r\n  otk?: Otk;\r\n  initiatorRootKeyCipher: string;\r\n}\r\n\r\nexport interface DecryptedKeyExchange extends KeyExchange {\r\n  decryptedOtk?: DecryptedOtk;\r\n  message?: KeyExchangeMessage;\r\n  contactCard?: TrustedPartyDetails;\r\n  myMessage?: KeyExchangeMessage;\r\n  myContactCard?: TrustedPartyDetails;\r\n}\r\n\r\nexport interface GetKeyExchangeOptions {\r\n  // The otKey as a raw string. i.e. key.toJSON(true).k\r\n  otKeyK?: string;\r\n  // User need the token if they have not responded to the key exchange yet.\r\n  // Once they've responded (hence proven they have the OOB Key) they become\r\n  // the \"responder\" of this exchange, and can access it when signed in.\r\n  token?: string;\r\n}\r\n\r\nexport interface RespondOtk {\r\n  keyExchange: KeyExchange;\r\n  userSharedKey: UserSharedKey;\r\n  tp: {\r\n    id: string;\r\n  };\r\n}\r\n\r\nexport interface CompleteOtk {\r\n  keyExchange: KeyExchange;\r\n  userSharedKey: UserSharedKey;\r\n  tp: {\r\n    id: string;\r\n  };\r\n}\r\n\r\nexport interface UserSharedKey {\r\n  userSigPrk: Key;\r\n  sharedKey: Key;\r\n  mkSharedKey?: Key;\r\n  mkPxk?: Key;\r\n  mkReshareRequestCipher?: string;\r\n  mkReshareResponseCipher?: string;\r\n  mkReshareRequestSent?: boolean;\r\n  mkReshareResponseSent?: boolean;\r\n}\r\n\r\nexport interface GetKeyExchangeListOptions {\r\n  orderBy?:\r\n    | 'created'\r\n    | '-created'\r\n    | 'modified'\r\n    | '-modified'\r\n    | 'expiry_time'\r\n    | '-expiry_time';\r\n  isExpired?: boolean;\r\n  initiatorActionRequired?: boolean;\r\n  responderActionRequired?: boolean;\r\n  initiator?: string;\r\n  responder?: string;\r\n  state?: 'IN_PROGRESS' | 'COMPLETED' | 'DECLINED' | 'CANCELLED';\r\n}\r\n\r\nexport interface PlainResponderPbkCipher {\r\n  otKey: object;\r\n}\r\n"]}
1
+ export var OtkState;
2
+ (function (OtkState) {
3
+ OtkState["OTK_INITIATED"] = "OTK_INITIATED";
4
+ OtkState["OTK_ACCEPTED"] = "OTK_ACCEPTED";
5
+ OtkState["OTK_COMPLETED"] = "OTK_COMPLETED";
6
+ })(OtkState || (OtkState = {}));
7
+ export var KeyExchangeState;
8
+ (function (KeyExchangeState) {
9
+ KeyExchangeState["IN_PROGRESS"] = "IN_PROGRESS";
10
+ KeyExchangeState["COMPLETED"] = "COMPLETED";
11
+ KeyExchangeState["DECLINED"] = "DECLINED";
12
+ KeyExchangeState["CANCELLED"] = "CANCELLED";
13
+ })(KeyExchangeState || (KeyExchangeState = {}));
14
+ export var KeyExchangeMode;
15
+ (function (KeyExchangeMode) {
16
+ KeyExchangeMode["OTK"] = "OTK";
17
+ })(KeyExchangeMode || (KeyExchangeMode = {}));
18
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key-exchange.types.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/api/key-exchange.types.ts"],"names":[],"mappings":"AAsFA,MAAM,CAAN,IAAY,QAIX;AAJD,WAAY,QAAQ;IAClB,2CAA+B,CAAA;IAC/B,yCAA6B,CAAA;IAC7B,2CAA+B,CAAA;AACjC,CAAC,EAJW,QAAQ,KAAR,QAAQ,QAInB;AAgCD,MAAM,CAAN,IAAY,gBAKX;AALD,WAAY,gBAAgB;IAC1B,+CAA2B,CAAA;IAC3B,2CAAuB,CAAA;IACvB,yCAAqB,CAAA;IACrB,2CAAuB,CAAA;AACzB,CAAC,EALW,gBAAgB,KAAhB,gBAAgB,QAK3B;AAED,MAAM,CAAN,IAAY,eAEX;AAFD,WAAY,eAAe;IACzB,8BAAW,CAAA;AACb,CAAC,EAFW,eAAe,KAAf,eAAe,QAE1B","sourcesContent":["import { Key } from '../cryptography/cryptography.types';\nimport { AccessLevel } from '../category/category.types';\nimport { JWK } from 'node-jose';\nimport { ContactCardName, TrustedPartyDetails } from '../users/profile.types';\n\n// Will be encrypted using the root key of the initiator\nexport interface PlainInitiatorRootKeyCipher {\n  nonce: string;\n  oneTimePrk: object; // onetime public encryption key responder use to send data back to initiator\n  otKey: object;\n  initiatorContactCard?: {\n    // Owner only access to this data\n    plainOwnerCipherDataJson: any;\n    // Shared read access between owner and receiver. Only the owner has write access.\n    plainSharedCipherDataJson: any;\n  };\n  initiator: {\n    message?: KeyExchangeMessage;\n    contactCard?: {\n      // Shared read access between owner and receiver. Only the owner has write access.\n      plainSharedCipherDataJson: TrustedPartyDetails;\n    };\n  };\n}\n\nexport interface SharedContactCardInput {\n  plainCipherDataJson?: any;\n  plainSharedCipherDataJson?: any;\n  sharedCipherKey?: object;\n}\n\nexport interface PreparedPermissions {\n  categories?: { categoryId: string; accessLevel: AccessLevel }[];\n  records?: { recordId: string; accessLevel: AccessLevel }[];\n}\n\nexport interface KeyExchangeMessage {\n  name?: string;\n  email?: string;\n  message?: string;\n  permissions?: PreparedPermissions;\n}\n\nexport interface PlainOtKeyCipher {\n  nonce: string;\n  initiator: {\n    oneTimePbk: object; // onetime public encryption key responder use to send data back to initiator\n    pbk: object; // public encryption key\n    sigPbk: object; // public signing key\n    profile?: {\n      username?: string;\n    };\n    message?: KeyExchangeMessage;\n    contactCard?: {\n      // Shared read access between owner and receiver. Only the owner has write access.\n      plainSharedCipherDataJson: TrustedPartyDetails;\n    };\n  };\n}\n\nexport interface DecryptedOtk {\n  plainOtKeyCipher: PlainOtKeyCipher;\n  otKey: JWK.Key; // The one-time key\n}\n\nexport interface PlainInitiatorOneTimePbkCipher {\n  nonce: string;\n  sharedKey: object;\n  mkSharedKey: object;\n  responder: {\n    pbk: object;\n    sigPbk: object;\n    profile?: {\n      username?: string;\n    };\n    message?: KeyExchangeMessage;\n    contactCard?: {\n      plainSharedCipherDataJson: TrustedPartyDetails;\n      // Note that this is _not_ the same key as the sharedKey. The sharedKey wraps\n      // this key in the key graph. But because this key has not been entered into\n      // the key graph then the responder calls the API, we pass the JWK directly here.\n      sharedCipherKey: object;\n    };\n  };\n}\n\nexport enum OtkState {\n  OTK_INITIATED = 'OTK_INITIATED',\n  OTK_ACCEPTED = 'OTK_ACCEPTED',\n  OTK_COMPLETED = 'OTK_COMPLETED',\n}\n\nexport interface KeyExchangeContactCardInput {\n  // Accessible by the server and initiator. Server side notification emails need to know some\n  // information about the initiator.\n  ownerPlainData?: {\n    name: ContactCardName;\n  };\n  // Owner only access to this data\n  plainOwnerCipherDataJson: any;\n  // Shared read access between owner and receiver. Only the owner has write access.\n  plainSharedCipherDataJson: TrustedPartyDetails;\n}\n\nexport interface InitiateOtkInput {\n  email?: string;\n  message?: KeyExchangeMessage;\n  contactCard?: KeyExchangeContactCardInput;\n  upgrade?: boolean;\n}\n\nexport interface RespondOtkInput {\n  id: string;\n  token: string;\n  decryptedOtk: DecryptedOtk;\n  message?: KeyExchangeMessage;\n  initiatorContactCard?: {\n    plainReceiverCipherDataJson: any;\n  };\n  responderContactCard?: KeyExchangeContactCardInput;\n}\n\nexport enum KeyExchangeState {\n  IN_PROGRESS = 'IN_PROGRESS',\n  COMPLETED = 'COMPLETED',\n  DECLINED = 'DECLINED',\n  CANCELLED = 'CANCELLED',\n}\n\nexport enum KeyExchangeMode {\n  OTK = 'OTK',\n}\n\nexport interface Otk {\n  id: string;\n  state: OtkState;\n  otKeyParams: string;\n  otKeyCipher: string;\n  sharedKey: Key;\n  mkSharedKey: Key;\n  initiatorSigPxk: Key;\n  responderSigPxk: Key;\n  // Encrypted\n  initiatorOneTimePbkCipher: string; // single time use public key created by the initiator.\n  responderPbkCipher?: string; // responderPbk is the long lived Pbk of the responder.\n}\n\nexport interface KeyExchange {\n  id: string;\n  state: KeyExchangeState;\n  mode: KeyExchangeMode;\n  created: string;\n  modified: string;\n  isInitiator: boolean;\n  initiator: {\n    id: string;\n    username: string;\n  };\n  responder: {\n    id: string;\n    username: string;\n  };\n  initiatorActionRequired?: boolean;\n  responderActionRequired?: boolean;\n  responderEmailAddress?: string;\n  token?: string;\n  tokenExpiryTime?: string;\n  isExpired?: boolean;\n  otk?: Otk;\n  initiatorRootKeyCipher: string;\n}\n\nexport interface DecryptedKeyExchange extends KeyExchange {\n  decryptedOtk?: DecryptedOtk;\n  message?: KeyExchangeMessage;\n  contactCard?: TrustedPartyDetails;\n  myMessage?: KeyExchangeMessage;\n  myContactCard?: TrustedPartyDetails;\n}\n\nexport interface GetKeyExchangeOptions {\n  // The otKey as a raw string. i.e. key.toJSON(true).k\n  otKeyK?: string;\n  // User need the token if they have not responded to the key exchange yet.\n  // Once they've responded (hence proven they have the OOB Key) they become\n  // the \"responder\" of this exchange, and can access it when signed in.\n  token?: string;\n}\n\nexport interface RespondOtk {\n  keyExchange: KeyExchange;\n  userSharedKey: UserSharedKey;\n  tp: {\n    id: string;\n  };\n}\n\nexport interface CompleteOtk {\n  keyExchange: KeyExchange;\n  userSharedKey: UserSharedKey;\n  tp: {\n    id: string;\n  };\n}\n\nexport interface UserSharedKey {\n  userSigPrk: Key;\n  sharedKey: Key;\n  mkSharedKey?: Key;\n  mkPxk?: Key;\n  mkReshareRequestCipher?: string;\n  mkReshareResponseCipher?: string;\n  mkReshareRequestSent?: boolean;\n  mkReshareResponseSent?: boolean;\n}\n\nexport interface GetKeyExchangeListOptions {\n  orderBy?:\n    | 'created'\n    | '-created'\n    | 'modified'\n    | '-modified'\n    | 'expiry_time'\n    | '-expiry_time';\n  isExpired?: boolean;\n  initiatorActionRequired?: boolean;\n  responderActionRequired?: boolean;\n  initiator?: string;\n  responder?: string;\n  state?: 'IN_PROGRESS' | 'COMPLETED' | 'DECLINED' | 'CANCELLED';\n}\n\nexport interface PlainResponderPbkCipher {\n  otKey: object;\n}\n"]}
@@ -1,171 +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,{"version":3,"file":"key-exchange2.gql.js","sourceRoot":"C:/Projects/kc-client/projects/core/src/","sources":["lib/api/key-exchange2.gql.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AA8D1C,MAAM,CAAC,MAAM,mBAAmB,GAAG,QAAQ,CAAqB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA2C/D,CAAC;AAgBF,MAAM,CAAC,MAAM,qBAAqB,GAAG,QAAQ,CAAuB;;;;;;;;;;;;;;EAclE,CAAC;AAKH,MAAM,CAAC,MAAM,kBAAkB,GAAG,QAAQ,CAAoB;;;;;;;;;;EAU5D,mBAAmB;CACpB,CAAC;AAKF,MAAM,CAAC,MAAM,iBAAiB,GAAG,QAAQ,CAAmB;;;;;;EAM1D,mBAAmB;CACpB,CAAC;AAOF,MAAM,CAAC,MAAM,sBAAsB,GAAG,QAAQ,CAAwB;;;;;;EAMpE,mBAAmB;CACpB,CAAC;AASF,MAAM,CAAC,MAAM,yBAAyB,GAAG,QAAQ,CAA2B;;;;;;;;CAQ3E,CAAC;AASF,MAAM,CAAC,MAAM,0BAA0B,GAAG,QAAQ,CAA4B;;;;;;;;CAQ7E,CAAC;AAOF,MAAM,CAAC,MAAM,8BAA8B,GAAG,QAAQ,CAAgC;;;;;;;;;;EAUpF,mBAAmB;CACpB,CAAC;AAWF,MAAM,CAAC,MAAM,6BAA6B,GAAG,QAAQ,CAA+B;;;;;;;;;;;;;;EAclF,mBAAmB;EACnB,qBAAqB;CACtB,CAAC;AAWF,MAAM,CAAC,MAAM,8BAA8B,GAAG,QAAQ,CAAgC;;;;;;;;;;;;;;;;EAgBpF,mBAAmB;EACnB,qBAAqB;CACtB,CAAC;AAOF,MAAM,CAAC,MAAM,0BAA0B,GAAG,QAAQ,CAA4B;;;;;;;;;;;;;;EAc5E,qBAAqB;CACtB,CAAC","sourcesContent":["import gql from 'graphql-tag';\r\nimport { JWK } from 'node-jose';\r\nimport { gqlTyped } from '../_common/ast';\r\nimport {\r\n  Connection,\r\n  DateTime,\r\n  ID,\r\n  LrEmail,\r\n  OtKeyCipherClearJson2,\r\n} from './types';\r\n\r\nexport type KeyExchangeState2 =\r\n  | 'IN_PROGRESS'\r\n  | 'COMPLETED'\r\n  | 'DECLINED'\r\n  | 'CANCELLED'\r\n  | 'DELETED';\r\n\r\nexport interface KeyExchangeFragment {\r\n  id: ID;\r\n  token: string;\r\n  state: KeyExchangeState2;\r\n  mode: 'OTK';\r\n  isInitiator: boolean;\r\n  initiator: {\r\n    id: ID;\r\n    username: string;\r\n  };\r\n  responder: {\r\n    id: ID;\r\n    username: string;\r\n  };\r\n  created: DateTime;\r\n  modified: DateTime;\r\n  tokenExpiryTime: DateTime;\r\n  isExpired: boolean;\r\n  initiatorRootKeyCipher: string;\r\n  initiatorRootKeyCipherClearJson: any;\r\n  initiatorActionRequired: boolean;\r\n  responderActionRequired: boolean;\r\n  responderEmailAddress: LrEmail;\r\n  otk: {\r\n    state: 'OTK_INITIATED' | 'OTK_ACCEPTED' | 'OTK_COMPLETED';\r\n    otKeyParams: string;\r\n    otKeyCipher: string;\r\n    otKey?: JWK.Key;\r\n    otKeyCipherClearJson?: OtKeyCipherClearJson2;\r\n    sharedKey: {\r\n      id: ID;\r\n    };\r\n    mkSharedKey: {\r\n      id: ID;\r\n    };\r\n    initiatorSigPxk: {\r\n      id: ID;\r\n    };\r\n    responderSigPxk: {\r\n      id: ID;\r\n    };\r\n    initiatorOneTimePbkCipher: string;\r\n    initiatorOneTimePbkCipherClearJson: any;\r\n    responderPbkCipher: string;\r\n  };\r\n}\r\nexport const KeyExchangeFragment = gqlTyped<KeyExchangeFragment>`\r\nfragment KeyExchangeFragment on KeyExchangeNode {\r\n  id\r\n  token\r\n  state\r\n  mode\r\n  isInitiator\r\n  initiator {\r\n    id\r\n    username\r\n  }\r\n  responder {\r\n    id\r\n    username\r\n  }\r\n  created\r\n  modified\r\n  tokenExpiryTime\r\n  isExpired\r\n  initiatorRootKeyCipher\r\n  initiatorActionRequired\r\n  responderActionRequired\r\n  responderEmailAddress\r\n  otk {\r\n    state\r\n    otKeyParams\r\n    otKeyCipher\r\n    sharedKey {\r\n      id\r\n    }\r\n    mkSharedKey {\r\n      id\r\n    }\r\n    initiatorSigPxk {\r\n      id\r\n    }\r\n    responderSigPxk {\r\n      id\r\n    }\r\n    initiatorOneTimePbkCipher\r\n    responderPbkCipher\r\n  }\r\n}\r\n`;\r\n\r\nexport interface UserSharedKeyFragment {\r\n  userSigPrk: {\r\n    id: ID;\r\n  };\r\n  otherSigPbk: {\r\n    id: ID;\r\n  };\r\n  sharedKey: {\r\n    id: ID;\r\n  };\r\n  mkSharedKey: {\r\n    id: ID;\r\n  };\r\n}\r\nexport const UserSharedKeyFragment = gqlTyped<UserSharedKeyFragment>`\r\nfragment UserSharedKeyFragment on UserSharedKeyNode {\r\n  userSigPrk {\r\n    id\r\n  }\r\n  otherSigPbk {\r\n    id\r\n  }\r\n  sharedKey {\r\n    id\r\n  }\r\n  mkSharedKey {\r\n    id\r\n  }\r\n}`;\r\n\r\nexport interface KeyExchangesQuery2 {\r\n  keyExchanges: Connection<KeyExchangeFragment>;\r\n}\r\nexport const KeyExchangesQuery2 = gqlTyped<KeyExchangesQuery2>`\r\nquery KeyExchangesQuery2($state: String) {\r\n  keyExchanges(state: $state) {\r\n    edges {\r\n      node {\r\n        ...KeyExchangeFragment\r\n      }\r\n    }\r\n  }\r\n}\r\n${KeyExchangeFragment}\r\n`;\r\n\r\nexport interface KeyExchangeQuery2 {\r\n  keyExchange: KeyExchangeFragment;\r\n}\r\nexport const KeyExchangeQuery2 = gqlTyped<KeyExchangeQuery2>`\r\nquery KeyExchangeQuery2($id: LrRelayIdInput!) {\r\n  keyExchange(id: $id) {\r\n    ...KeyExchangeFragment\r\n  }\r\n}\r\n${KeyExchangeFragment}\r\n`;\r\n\r\n// Key graph is only available for authenticated users. This query\r\n// is for unauthenticated users.\r\nexport interface KeyExchangeTokenQuery2 {\r\n  keyExchange: KeyExchangeFragment;\r\n}\r\nexport const KeyExchangeTokenQuery2 = gqlTyped<KeyExchangeTokenQuery2>`\r\nquery KeyExchangeTokenQuery2($id: LrRelayIdInput!, $token: String) {\r\n  keyExchange(id: $id, token: $token) {\r\n    ...KeyExchangeFragment\r\n  }\r\n}\r\n${KeyExchangeFragment}\r\n`;\r\n\r\nexport interface CancelKeyExchangeMutation {\r\n  cancelKeyExchange: {\r\n    keyExchange: {\r\n      id: ID;\r\n    };\r\n  };\r\n}\r\nexport const CancelKeyExchangeMutation = gqlTyped<CancelKeyExchangeMutation>`\r\nmutation CancelKeyExchangeMutation($input: CancelKeyExchangeInput!) {\r\n  cancelKeyExchange(input: $input) {\r\n    keyExchange {\r\n      id\r\n    }\r\n  }\r\n}\r\n`;\r\n\r\nexport interface DeclineKeyExchangeMutation {\r\n  declineKeyExchange: {\r\n    keyExchange: {\r\n      id: ID;\r\n    };\r\n  };\r\n}\r\nexport const DeclineKeyExchangeMutation = gqlTyped<DeclineKeyExchangeMutation>`\r\nmutation DeclineKeyExchangeMutation($input: DeclineKeyExchangeInput!) {\r\n  declineKeyExchange(input: $input) {\r\n    keyExchange {\r\n      id\r\n    }\r\n  }\r\n}\r\n`;\r\n\r\nexport interface InitiateKeyExchangeOtkMutation {\r\n  initiateKeyExchangeOtk: {\r\n    keyExchange: KeyExchangeFragment;\r\n  };\r\n}\r\nexport const InitiateKeyExchangeOtkMutation = gqlTyped<InitiateKeyExchangeOtkMutation>`\r\nmutation InitiateKeyExchangeOtkMutation(\r\n  $input: InitiateKeyExchangeOtkInput!\r\n) {\r\n  initiateKeyExchangeOtk(input: $input) {\r\n    keyExchange {\r\n      ...KeyExchangeFragment\r\n    }\r\n  }\r\n}\r\n${KeyExchangeFragment}\r\n`;\r\n\r\nexport interface RespondKeyExchangeOtkMutation {\r\n  respondKeyExchangeOtk: {\r\n    keyExchange: KeyExchangeFragment;\r\n    userSharedKey: UserSharedKeyFragment;\r\n    tp: {\r\n      id: ID;\r\n    };\r\n  };\r\n}\r\nexport const RespondKeyExchangeOtkMutation = gqlTyped<RespondKeyExchangeOtkMutation>`\r\nmutation RespondKeyExchangeOtkMutation($input: RespondKeyExchangeOtkInput!) {\r\n  respondKeyExchangeOtk(input: $input) {\r\n    keyExchange {\r\n      ...KeyExchangeFragment\r\n    }\r\n    userSharedKey {\r\n      ...UserSharedKeyFragment\r\n    }\r\n    tp {\r\n      id\r\n    }\r\n  }\r\n}\r\n${KeyExchangeFragment}\r\n${UserSharedKeyFragment}\r\n`;\r\n\r\nexport interface CompleteKeyExchangeOtkMutation {\r\n  completeKeyExchangeOtk: {\r\n    keyExchange: KeyExchangeFragment;\r\n    userSharedKey: UserSharedKeyFragment;\r\n    tp: {\r\n      id: ID;\r\n    };\r\n  };\r\n}\r\nexport const CompleteKeyExchangeOtkMutation = gqlTyped<CompleteKeyExchangeOtkMutation>`\r\nmutation CompleteKeyExchangeOtkMutation(\r\n  $input: CompleteKeyExchangeOtkInput!\r\n) {\r\n  completeKeyExchangeOtk(input: $input) {\r\n    keyExchange {\r\n      ...KeyExchangeFragment\r\n    }\r\n    userSharedKey {\r\n      ...UserSharedKeyFragment\r\n    }\r\n    tp {\r\n      id\r\n    }\r\n  }\r\n}\r\n${KeyExchangeFragment}\r\n${UserSharedKeyFragment}\r\n`;\r\n\r\nexport interface CurrentUserSharedKeyQuery2 {\r\n  currentUserSharedKey: {\r\n    userSharedKey: UserSharedKeyFragment;\r\n  };\r\n}\r\nexport const CurrentUserSharedKeyQuery2 = gqlTyped<CurrentUserSharedKeyQuery2>`\r\nquery CurrentUserSharedKeyQuery2(\r\n  $username: String\r\n  $userId: LrRelayIdInput\r\n) {\r\n  currentUserSharedKey(\r\n    username: $username\r\n    userId: $userId\r\n  ) {\r\n    userSharedKey {\r\n      ...UserSharedKeyFragment\r\n    }\r\n  }\r\n}\r\n${UserSharedKeyFragment}\r\n`;\r\n"]}
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,{"version":3,"file":"key-exchange2.gql.js","sourceRoot":"/opt/atlassian/pipelines/agent/build/projects/core/src/","sources":["lib/api/key-exchange2.gql.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AA8D1C,MAAM,CAAC,MAAM,mBAAmB,GAAG,QAAQ,CAAqB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA2C/D,CAAC;AAgBF,MAAM,CAAC,MAAM,qBAAqB,GAAG,QAAQ,CAAuB;;;;;;;;;;;;;;EAclE,CAAC;AAKH,MAAM,CAAC,MAAM,kBAAkB,GAAG,QAAQ,CAAoB;;;;;;;;;;EAU5D,mBAAmB;CACpB,CAAC;AAKF,MAAM,CAAC,MAAM,iBAAiB,GAAG,QAAQ,CAAmB;;;;;;EAM1D,mBAAmB;CACpB,CAAC;AAOF,MAAM,CAAC,MAAM,sBAAsB,GAAG,QAAQ,CAAwB;;;;;;EAMpE,mBAAmB;CACpB,CAAC;AASF,MAAM,CAAC,MAAM,yBAAyB,GAAG,QAAQ,CAA2B;;;;;;;;CAQ3E,CAAC;AASF,MAAM,CAAC,MAAM,0BAA0B,GAAG,QAAQ,CAA4B;;;;;;;;CAQ7E,CAAC;AAOF,MAAM,CAAC,MAAM,8BAA8B,GAAG,QAAQ,CAAgC;;;;;;;;;;EAUpF,mBAAmB;CACpB,CAAC;AAWF,MAAM,CAAC,MAAM,6BAA6B,GAAG,QAAQ,CAA+B;;;;;;;;;;;;;;EAclF,mBAAmB;EACnB,qBAAqB;CACtB,CAAC;AAWF,MAAM,CAAC,MAAM,8BAA8B,GAAG,QAAQ,CAAgC;;;;;;;;;;;;;;;;EAgBpF,mBAAmB;EACnB,qBAAqB;CACtB,CAAC;AAOF,MAAM,CAAC,MAAM,0BAA0B,GAAG,QAAQ,CAA4B;;;;;;;;;;;;;;EAc5E,qBAAqB;CACtB,CAAC","sourcesContent":["import gql from 'graphql-tag';\nimport { JWK } from 'node-jose';\nimport { gqlTyped } from '../_common/ast';\nimport {\n  Connection,\n  DateTime,\n  ID,\n  LrEmail,\n  OtKeyCipherClearJson2,\n} from './types';\n\nexport type KeyExchangeState2 =\n  | 'IN_PROGRESS'\n  | 'COMPLETED'\n  | 'DECLINED'\n  | 'CANCELLED'\n  | 'DELETED';\n\nexport interface KeyExchangeFragment {\n  id: ID;\n  token: string;\n  state: KeyExchangeState2;\n  mode: 'OTK';\n  isInitiator: boolean;\n  initiator: {\n    id: ID;\n    username: string;\n  };\n  responder: {\n    id: ID;\n    username: string;\n  };\n  created: DateTime;\n  modified: DateTime;\n  tokenExpiryTime: DateTime;\n  isExpired: boolean;\n  initiatorRootKeyCipher: string;\n  initiatorRootKeyCipherClearJson: any;\n  initiatorActionRequired: boolean;\n  responderActionRequired: boolean;\n  responderEmailAddress: LrEmail;\n  otk: {\n    state: 'OTK_INITIATED' | 'OTK_ACCEPTED' | 'OTK_COMPLETED';\n    otKeyParams: string;\n    otKeyCipher: string;\n    otKey?: JWK.Key;\n    otKeyCipherClearJson?: OtKeyCipherClearJson2;\n    sharedKey: {\n      id: ID;\n    };\n    mkSharedKey: {\n      id: ID;\n    };\n    initiatorSigPxk: {\n      id: ID;\n    };\n    responderSigPxk: {\n      id: ID;\n    };\n    initiatorOneTimePbkCipher: string;\n    initiatorOneTimePbkCipherClearJson: any;\n    responderPbkCipher: string;\n  };\n}\nexport const KeyExchangeFragment = gqlTyped<KeyExchangeFragment>`\nfragment KeyExchangeFragment on KeyExchangeNode {\n  id\n  token\n  state\n  mode\n  isInitiator\n  initiator {\n    id\n    username\n  }\n  responder {\n    id\n    username\n  }\n  created\n  modified\n  tokenExpiryTime\n  isExpired\n  initiatorRootKeyCipher\n  initiatorActionRequired\n  responderActionRequired\n  responderEmailAddress\n  otk {\n    state\n    otKeyParams\n    otKeyCipher\n    sharedKey {\n      id\n    }\n    mkSharedKey {\n      id\n    }\n    initiatorSigPxk {\n      id\n    }\n    responderSigPxk {\n      id\n    }\n    initiatorOneTimePbkCipher\n    responderPbkCipher\n  }\n}\n`;\n\nexport interface UserSharedKeyFragment {\n  userSigPrk: {\n    id: ID;\n  };\n  otherSigPbk: {\n    id: ID;\n  };\n  sharedKey: {\n    id: ID;\n  };\n  mkSharedKey: {\n    id: ID;\n  };\n}\nexport const UserSharedKeyFragment = gqlTyped<UserSharedKeyFragment>`\nfragment UserSharedKeyFragment on UserSharedKeyNode {\n  userSigPrk {\n    id\n  }\n  otherSigPbk {\n    id\n  }\n  sharedKey {\n    id\n  }\n  mkSharedKey {\n    id\n  }\n}`;\n\nexport interface KeyExchangesQuery2 {\n  keyExchanges: Connection<KeyExchangeFragment>;\n}\nexport const KeyExchangesQuery2 = gqlTyped<KeyExchangesQuery2>`\nquery KeyExchangesQuery2($state: String) {\n  keyExchanges(state: $state) {\n    edges {\n      node {\n        ...KeyExchangeFragment\n      }\n    }\n  }\n}\n${KeyExchangeFragment}\n`;\n\nexport interface KeyExchangeQuery2 {\n  keyExchange: KeyExchangeFragment;\n}\nexport const KeyExchangeQuery2 = gqlTyped<KeyExchangeQuery2>`\nquery KeyExchangeQuery2($id: LrRelayIdInput!) {\n  keyExchange(id: $id) {\n    ...KeyExchangeFragment\n  }\n}\n${KeyExchangeFragment}\n`;\n\n// Key graph is only available for authenticated users. This query\n// is for unauthenticated users.\nexport interface KeyExchangeTokenQuery2 {\n  keyExchange: KeyExchangeFragment;\n}\nexport const KeyExchangeTokenQuery2 = gqlTyped<KeyExchangeTokenQuery2>`\nquery KeyExchangeTokenQuery2($id: LrRelayIdInput!, $token: String) {\n  keyExchange(id: $id, token: $token) {\n    ...KeyExchangeFragment\n  }\n}\n${KeyExchangeFragment}\n`;\n\nexport interface CancelKeyExchangeMutation {\n  cancelKeyExchange: {\n    keyExchange: {\n      id: ID;\n    };\n  };\n}\nexport const CancelKeyExchangeMutation = gqlTyped<CancelKeyExchangeMutation>`\nmutation CancelKeyExchangeMutation($input: CancelKeyExchangeInput!) {\n  cancelKeyExchange(input: $input) {\n    keyExchange {\n      id\n    }\n  }\n}\n`;\n\nexport interface DeclineKeyExchangeMutation {\n  declineKeyExchange: {\n    keyExchange: {\n      id: ID;\n    };\n  };\n}\nexport const DeclineKeyExchangeMutation = gqlTyped<DeclineKeyExchangeMutation>`\nmutation DeclineKeyExchangeMutation($input: DeclineKeyExchangeInput!) {\n  declineKeyExchange(input: $input) {\n    keyExchange {\n      id\n    }\n  }\n}\n`;\n\nexport interface InitiateKeyExchangeOtkMutation {\n  initiateKeyExchangeOtk: {\n    keyExchange: KeyExchangeFragment;\n  };\n}\nexport const InitiateKeyExchangeOtkMutation = gqlTyped<InitiateKeyExchangeOtkMutation>`\nmutation InitiateKeyExchangeOtkMutation(\n  $input: InitiateKeyExchangeOtkInput!\n) {\n  initiateKeyExchangeOtk(input: $input) {\n    keyExchange {\n      ...KeyExchangeFragment\n    }\n  }\n}\n${KeyExchangeFragment}\n`;\n\nexport interface RespondKeyExchangeOtkMutation {\n  respondKeyExchangeOtk: {\n    keyExchange: KeyExchangeFragment;\n    userSharedKey: UserSharedKeyFragment;\n    tp: {\n      id: ID;\n    };\n  };\n}\nexport const RespondKeyExchangeOtkMutation = gqlTyped<RespondKeyExchangeOtkMutation>`\nmutation RespondKeyExchangeOtkMutation($input: RespondKeyExchangeOtkInput!) {\n  respondKeyExchangeOtk(input: $input) {\n    keyExchange {\n      ...KeyExchangeFragment\n    }\n    userSharedKey {\n      ...UserSharedKeyFragment\n    }\n    tp {\n      id\n    }\n  }\n}\n${KeyExchangeFragment}\n${UserSharedKeyFragment}\n`;\n\nexport interface CompleteKeyExchangeOtkMutation {\n  completeKeyExchangeOtk: {\n    keyExchange: KeyExchangeFragment;\n    userSharedKey: UserSharedKeyFragment;\n    tp: {\n      id: ID;\n    };\n  };\n}\nexport const CompleteKeyExchangeOtkMutation = gqlTyped<CompleteKeyExchangeOtkMutation>`\nmutation CompleteKeyExchangeOtkMutation(\n  $input: CompleteKeyExchangeOtkInput!\n) {\n  completeKeyExchangeOtk(input: $input) {\n    keyExchange {\n      ...KeyExchangeFragment\n    }\n    userSharedKey {\n      ...UserSharedKeyFragment\n    }\n    tp {\n      id\n    }\n  }\n}\n${KeyExchangeFragment}\n${UserSharedKeyFragment}\n`;\n\nexport interface CurrentUserSharedKeyQuery2 {\n  currentUserSharedKey: {\n    userSharedKey: UserSharedKeyFragment;\n  };\n}\nexport const CurrentUserSharedKeyQuery2 = gqlTyped<CurrentUserSharedKeyQuery2>`\nquery CurrentUserSharedKeyQuery2(\n  $username: String\n  $userId: LrRelayIdInput\n) {\n  currentUserSharedKey(\n    username: $username\n    userId: $userId\n  ) {\n    userSharedKey {\n      ...UserSharedKeyFragment\n    }\n  }\n}\n${UserSharedKeyFragment}\n`;\n"]}