@blue-repository/types 0.10.0 → 0.12.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 (239) hide show
  1. package/README.md +1 -1
  2. package/dist/meta.d.ts +2 -2
  3. package/dist/meta.d.ts.map +1 -1
  4. package/dist/meta.js +2 -3
  5. package/dist/meta.js.map +1 -1
  6. package/dist/packages/common/blue-ids.d.ts +1 -0
  7. package/dist/packages/common/blue-ids.d.ts.map +1 -1
  8. package/dist/packages/common/blue-ids.js +1 -0
  9. package/dist/packages/common/blue-ids.js.map +1 -1
  10. package/dist/packages/common/contents/Currency.d.ts +8 -0
  11. package/dist/packages/common/contents/Currency.d.ts.map +1 -0
  12. package/dist/packages/common/contents/Currency.js +8 -0
  13. package/dist/packages/common/contents/Currency.js.map +1 -0
  14. package/dist/packages/common/contents/index.d.ts +8 -0
  15. package/dist/packages/common/contents/index.d.ts.map +1 -1
  16. package/dist/packages/common/contents/index.js +3 -0
  17. package/dist/packages/common/contents/index.js.map +1 -1
  18. package/dist/packages/common/index.d.ts +22 -0
  19. package/dist/packages/common/index.d.ts.map +1 -1
  20. package/dist/packages/common/meta.d.ts +10 -0
  21. package/dist/packages/common/meta.d.ts.map +1 -1
  22. package/dist/packages/common/meta.js +11 -0
  23. package/dist/packages/common/meta.js.map +1 -1
  24. package/dist/packages/common/schemas/Currency.d.ts +8 -0
  25. package/dist/packages/common/schemas/Currency.d.ts.map +1 -0
  26. package/dist/packages/common/schemas/Currency.js +5 -0
  27. package/dist/packages/common/schemas/Currency.js.map +1 -0
  28. package/dist/packages/common/schemas/index.d.ts +6 -0
  29. package/dist/packages/common/schemas/index.d.ts.map +1 -1
  30. package/dist/packages/common/schemas/index.js +3 -0
  31. package/dist/packages/common/schemas/index.js.map +1 -1
  32. package/dist/packages/conversation/blue-ids.d.ts +10 -7
  33. package/dist/packages/conversation/blue-ids.d.ts.map +1 -1
  34. package/dist/packages/conversation/blue-ids.js +10 -7
  35. package/dist/packages/conversation/blue-ids.js.map +1 -1
  36. package/dist/packages/conversation/contents/AcceptChangeWorkflow.d.ts +1 -1
  37. package/dist/packages/conversation/contents/AcceptChangeWorkflow.js +1 -1
  38. package/dist/packages/conversation/contents/AcceptChangeWorkflow.js.map +1 -1
  39. package/dist/packages/conversation/contents/ChangeOperation.d.ts +1 -1
  40. package/dist/packages/conversation/contents/ChangeOperation.js +1 -1
  41. package/dist/packages/conversation/contents/ChangeRequest.d.ts +8 -8
  42. package/dist/packages/conversation/contents/ChangeRequest.js +8 -8
  43. package/dist/packages/conversation/contents/ChangeRequest.js.map +1 -1
  44. package/dist/packages/conversation/contents/ChangeWorkflow.d.ts +2 -2
  45. package/dist/packages/conversation/contents/ChangeWorkflow.js +2 -2
  46. package/dist/packages/conversation/contents/ChangeWorkflow.js.map +1 -1
  47. package/dist/packages/conversation/contents/CustomerActionRequested.d.ts +44 -0
  48. package/dist/packages/conversation/contents/CustomerActionRequested.d.ts.map +1 -0
  49. package/dist/packages/conversation/contents/CustomerActionRequested.js +44 -0
  50. package/dist/packages/conversation/contents/CustomerActionRequested.js.map +1 -0
  51. package/dist/packages/conversation/contents/CustomerConsent.d.ts +233 -0
  52. package/dist/packages/conversation/contents/CustomerConsent.d.ts.map +1 -0
  53. package/dist/packages/conversation/contents/CustomerConsent.js +244 -0
  54. package/dist/packages/conversation/contents/CustomerConsent.js.map +1 -0
  55. package/dist/packages/conversation/contents/CustomerConsentRevoked.d.ts +17 -0
  56. package/dist/packages/conversation/contents/CustomerConsentRevoked.d.ts.map +1 -0
  57. package/dist/packages/conversation/contents/CustomerConsentRevoked.js +17 -0
  58. package/dist/packages/conversation/contents/CustomerConsentRevoked.js.map +1 -0
  59. package/dist/packages/conversation/contents/ProposeChangeOperation.d.ts +1 -1
  60. package/dist/packages/conversation/contents/ProposeChangeOperation.js +1 -1
  61. package/dist/packages/conversation/contents/ProposeChangeWorkflow.d.ts +2 -2
  62. package/dist/packages/conversation/contents/ProposeChangeWorkflow.js +2 -2
  63. package/dist/packages/conversation/contents/ProposeChangeWorkflow.js.map +1 -1
  64. package/dist/packages/conversation/contents/RejectChangeWorkflow.d.ts +1 -1
  65. package/dist/packages/conversation/contents/RejectChangeWorkflow.js +1 -1
  66. package/dist/packages/conversation/contents/RejectChangeWorkflow.js.map +1 -1
  67. package/dist/packages/conversation/contents/index.d.ts +482 -188
  68. package/dist/packages/conversation/contents/index.d.ts.map +1 -1
  69. package/dist/packages/conversation/contents/index.js +30 -21
  70. package/dist/packages/conversation/contents/index.js.map +1 -1
  71. package/dist/packages/conversation/index.d.ts +1319 -390
  72. package/dist/packages/conversation/index.d.ts.map +1 -1
  73. package/dist/packages/conversation/meta.d.ts +57 -27
  74. package/dist/packages/conversation/meta.d.ts.map +1 -1
  75. package/dist/packages/conversation/meta.js +53 -20
  76. package/dist/packages/conversation/meta.js.map +1 -1
  77. package/dist/packages/conversation/schemas/ChangeOperation.d.ts +5 -5
  78. package/dist/packages/conversation/schemas/ChangeRequest.d.ts +3 -3
  79. package/dist/packages/conversation/schemas/ChangeRequest.js +1 -1
  80. package/dist/packages/conversation/schemas/ChangeRequest.js.map +1 -1
  81. package/dist/packages/conversation/schemas/ChangeWorkflow.d.ts +5 -5
  82. package/dist/packages/conversation/schemas/CustomerActionRequested.d.ts +40 -0
  83. package/dist/packages/conversation/schemas/CustomerActionRequested.d.ts.map +1 -0
  84. package/dist/packages/conversation/schemas/CustomerActionRequested.js +15 -0
  85. package/dist/packages/conversation/schemas/CustomerActionRequested.js.map +1 -0
  86. package/dist/packages/conversation/schemas/CustomerConsent.d.ts +548 -0
  87. package/dist/packages/conversation/schemas/CustomerConsent.d.ts.map +1 -0
  88. package/dist/packages/conversation/schemas/CustomerConsent.js +31 -0
  89. package/dist/packages/conversation/schemas/CustomerConsent.js.map +1 -0
  90. package/dist/packages/conversation/schemas/CustomerConsentRevoked.d.ts +29 -0
  91. package/dist/packages/conversation/schemas/CustomerConsentRevoked.d.ts.map +1 -0
  92. package/dist/packages/conversation/schemas/CustomerConsentRevoked.js +11 -0
  93. package/dist/packages/conversation/schemas/CustomerConsentRevoked.js.map +1 -0
  94. package/dist/packages/conversation/schemas/DocumentBootstrapFailed.d.ts +2 -2
  95. package/dist/packages/conversation/schemas/DocumentBootstrapResponded.d.ts +2 -2
  96. package/dist/packages/conversation/schemas/ProposeChangeOperation.d.ts +5 -5
  97. package/dist/packages/conversation/schemas/ProposeChangeWorkflow.d.ts +5 -5
  98. package/dist/packages/conversation/schemas/index.d.ts +645 -34
  99. package/dist/packages/conversation/schemas/index.d.ts.map +1 -1
  100. package/dist/packages/conversation/schemas/index.js +16 -7
  101. package/dist/packages/conversation/schemas/index.js.map +1 -1
  102. package/dist/packages/myos/index.d.ts +284 -284
  103. package/dist/packages/myos/schemas/AddingParticipantRequested.d.ts +4 -4
  104. package/dist/packages/myos/schemas/AddingParticipantResponded.d.ts +6 -6
  105. package/dist/packages/myos/schemas/CallOperationFailed.d.ts +2 -2
  106. package/dist/packages/myos/schemas/ChatGPTConnectorAgent.d.ts +6 -6
  107. package/dist/packages/myos/schemas/DocumentSessionBootstrap.d.ts +4 -4
  108. package/dist/packages/myos/schemas/LinkedDocumentsPermissionGrantToAccount.d.ts +60 -60
  109. package/dist/packages/myos/schemas/LinkedDocumentsPermissionGrantToDocument.d.ts +34 -34
  110. package/dist/packages/myos/schemas/LinkedDocumentsPermissionRejected.d.ts +2 -2
  111. package/dist/packages/myos/schemas/LinkedDocumentsPermissionRevokeRequested.d.ts +2 -2
  112. package/dist/packages/myos/schemas/LinkedDocumentsPermissionRevoked.d.ts +2 -2
  113. package/dist/packages/myos/schemas/LinkedDocumentsPermissionRevokingInProgress.d.ts +2 -2
  114. package/dist/packages/myos/schemas/MyOSAdminBase.d.ts +6 -6
  115. package/dist/packages/myos/schemas/MyOSTimelineChannel.d.ts +2 -2
  116. package/dist/packages/myos/schemas/Participant.d.ts +2 -2
  117. package/dist/packages/myos/schemas/ParticipantActivated.d.ts +4 -4
  118. package/dist/packages/myos/schemas/ParticipantResolved.d.ts +4 -4
  119. package/dist/packages/myos/schemas/SingleDocumentPermissionGrantResponded.d.ts +2 -2
  120. package/dist/packages/myos/schemas/SingleDocumentPermissionGrantToAccount.d.ts +60 -60
  121. package/dist/packages/myos/schemas/SingleDocumentPermissionGrantToDocument.d.ts +34 -34
  122. package/dist/packages/myos/schemas/SingleDocumentPermissionRejected.d.ts +2 -2
  123. package/dist/packages/myos/schemas/SingleDocumentPermissionRevokeRequested.d.ts +2 -2
  124. package/dist/packages/myos/schemas/SubscriptionToSessionFailed.d.ts +2 -2
  125. package/dist/packages/myos/schemas/SubscriptionToSessionRevoked.d.ts +2 -2
  126. package/dist/packages/myos/schemas/WorkerAgencyPermissionGrant.d.ts +34 -34
  127. package/dist/packages/myos/schemas/WorkerAgencyPermissionRejected.d.ts +2 -2
  128. package/dist/packages/myos/schemas/WorkerAgencyPermissionRevokeRequested.d.ts +2 -2
  129. package/dist/packages/myos/schemas/index.d.ts +284 -284
  130. package/dist/packages/paynote/blue-ids.d.ts +10 -2
  131. package/dist/packages/paynote/blue-ids.d.ts.map +1 -1
  132. package/dist/packages/paynote/blue-ids.js +10 -2
  133. package/dist/packages/paynote/blue-ids.js.map +1 -1
  134. package/dist/packages/paynote/contents/CardTransactionMonitoringRequestRejected.d.ts +34 -0
  135. package/dist/packages/paynote/contents/CardTransactionMonitoringRequestRejected.d.ts.map +1 -0
  136. package/dist/packages/paynote/contents/CardTransactionMonitoringRequestRejected.js +34 -0
  137. package/dist/packages/paynote/contents/CardTransactionMonitoringRequestRejected.js.map +1 -0
  138. package/dist/packages/paynote/contents/CardTransactionMonitoringStarted.d.ts +38 -0
  139. package/dist/packages/paynote/contents/CardTransactionMonitoringStarted.d.ts.map +1 -0
  140. package/dist/packages/paynote/contents/CardTransactionMonitoringStarted.js +38 -0
  141. package/dist/packages/paynote/contents/CardTransactionMonitoringStarted.js.map +1 -0
  142. package/dist/packages/paynote/contents/CardTransactionMonitoringStopped.d.ts +30 -0
  143. package/dist/packages/paynote/contents/CardTransactionMonitoringStopped.d.ts.map +1 -0
  144. package/dist/packages/paynote/contents/CardTransactionMonitoringStopped.js +30 -0
  145. package/dist/packages/paynote/contents/CardTransactionMonitoringStopped.js.map +1 -0
  146. package/dist/packages/paynote/contents/CardTransactionPayNote.d.ts +13 -0
  147. package/dist/packages/paynote/contents/CardTransactionPayNote.d.ts.map +1 -0
  148. package/dist/packages/paynote/contents/CardTransactionPayNote.js +13 -0
  149. package/dist/packages/paynote/contents/CardTransactionPayNote.js.map +1 -0
  150. package/dist/packages/paynote/contents/CardTransactionReport.d.ts +43 -0
  151. package/dist/packages/paynote/contents/CardTransactionReport.d.ts.map +1 -0
  152. package/dist/packages/paynote/contents/CardTransactionReport.js +43 -0
  153. package/dist/packages/paynote/contents/CardTransactionReport.js.map +1 -0
  154. package/dist/packages/paynote/contents/MerchantToCustomerPayNote.d.ts +8 -0
  155. package/dist/packages/paynote/contents/MerchantToCustomerPayNote.d.ts.map +1 -0
  156. package/dist/packages/paynote/contents/MerchantToCustomerPayNote.js +8 -0
  157. package/dist/packages/paynote/contents/MerchantToCustomerPayNote.js.map +1 -0
  158. package/dist/packages/paynote/contents/PayNote.d.ts +44 -0
  159. package/dist/packages/paynote/contents/PayNote.d.ts.map +1 -1
  160. package/dist/packages/paynote/contents/PayNote.js +46 -0
  161. package/dist/packages/paynote/contents/PayNote.js.map +1 -1
  162. package/dist/packages/paynote/contents/PayNoteDelivery.d.ts +4 -10
  163. package/dist/packages/paynote/contents/PayNoteDelivery.d.ts.map +1 -1
  164. package/dist/packages/paynote/contents/PayNoteDelivery.js +4 -10
  165. package/dist/packages/paynote/contents/PayNoteDelivery.js.map +1 -1
  166. package/dist/packages/paynote/contents/StartCardTransactionMonitoringRequested.d.ts +28 -0
  167. package/dist/packages/paynote/contents/StartCardTransactionMonitoringRequested.d.ts.map +1 -0
  168. package/dist/packages/paynote/contents/StartCardTransactionMonitoringRequested.js +28 -0
  169. package/dist/packages/paynote/contents/StartCardTransactionMonitoringRequested.js.map +1 -0
  170. package/dist/packages/paynote/contents/TransactionStatus.d.ts +26 -0
  171. package/dist/packages/paynote/contents/TransactionStatus.d.ts.map +1 -0
  172. package/dist/packages/paynote/contents/TransactionStatus.js +26 -0
  173. package/dist/packages/paynote/contents/TransactionStatus.js.map +1 -0
  174. package/dist/packages/paynote/contents/index.d.ts +590 -332
  175. package/dist/packages/paynote/contents/index.d.ts.map +1 -1
  176. package/dist/packages/paynote/contents/index.js +30 -6
  177. package/dist/packages/paynote/contents/index.js.map +1 -1
  178. package/dist/packages/paynote/index.d.ts +2383 -792
  179. package/dist/packages/paynote/index.d.ts.map +1 -1
  180. package/dist/packages/paynote/meta.d.ts +87 -7
  181. package/dist/packages/paynote/meta.d.ts.map +1 -1
  182. package/dist/packages/paynote/meta.js +93 -5
  183. package/dist/packages/paynote/meta.js.map +1 -1
  184. package/dist/packages/paynote/schemas/CaptureDeclined.d.ts +2 -2
  185. package/dist/packages/paynote/schemas/CaptureFailed.d.ts +2 -2
  186. package/dist/packages/paynote/schemas/CardTransactionCaptureLockChangeFailed.d.ts +2 -2
  187. package/dist/packages/paynote/schemas/CardTransactionMonitoringRequestRejected.d.ts +34 -0
  188. package/dist/packages/paynote/schemas/CardTransactionMonitoringRequestRejected.d.ts.map +1 -0
  189. package/dist/packages/paynote/schemas/CardTransactionMonitoringRequestRejected.js +13 -0
  190. package/dist/packages/paynote/schemas/CardTransactionMonitoringRequestRejected.js.map +1 -0
  191. package/dist/packages/paynote/schemas/CardTransactionMonitoringStarted.d.ts +37 -0
  192. package/dist/packages/paynote/schemas/CardTransactionMonitoringStarted.d.ts.map +1 -0
  193. package/dist/packages/paynote/schemas/CardTransactionMonitoringStarted.js +14 -0
  194. package/dist/packages/paynote/schemas/CardTransactionMonitoringStarted.js.map +1 -0
  195. package/dist/packages/paynote/schemas/CardTransactionMonitoringStopped.d.ts +27 -0
  196. package/dist/packages/paynote/schemas/CardTransactionMonitoringStopped.d.ts.map +1 -0
  197. package/dist/packages/paynote/schemas/CardTransactionMonitoringStopped.js +12 -0
  198. package/dist/packages/paynote/schemas/CardTransactionMonitoringStopped.js.map +1 -0
  199. package/dist/packages/paynote/schemas/CardTransactionPayNote.d.ts +473 -0
  200. package/dist/packages/paynote/schemas/CardTransactionPayNote.d.ts.map +1 -0
  201. package/dist/packages/paynote/schemas/CardTransactionPayNote.js +11 -0
  202. package/dist/packages/paynote/schemas/CardTransactionPayNote.js.map +1 -0
  203. package/dist/packages/paynote/schemas/CardTransactionReport.d.ts +85 -0
  204. package/dist/packages/paynote/schemas/CardTransactionReport.d.ts.map +1 -0
  205. package/dist/packages/paynote/schemas/CardTransactionReport.js +18 -0
  206. package/dist/packages/paynote/schemas/CardTransactionReport.js.map +1 -0
  207. package/dist/packages/paynote/schemas/ChildPayNoteIssuanceDeclined.d.ts +2 -2
  208. package/dist/packages/paynote/schemas/MerchantToCustomerPayNote.d.ts +435 -0
  209. package/dist/packages/paynote/schemas/MerchantToCustomerPayNote.d.ts.map +1 -0
  210. package/dist/packages/paynote/schemas/MerchantToCustomerPayNote.js +9 -0
  211. package/dist/packages/paynote/schemas/MerchantToCustomerPayNote.js.map +1 -0
  212. package/dist/packages/paynote/schemas/PayNote.d.ts +200 -0
  213. package/dist/packages/paynote/schemas/PayNote.d.ts.map +1 -1
  214. package/dist/packages/paynote/schemas/PayNote.js +6 -0
  215. package/dist/packages/paynote/schemas/PayNote.js.map +1 -1
  216. package/dist/packages/paynote/schemas/PayNoteCancellationRejected.d.ts +2 -2
  217. package/dist/packages/paynote/schemas/PayNoteDelivery.d.ts +58 -128
  218. package/dist/packages/paynote/schemas/PayNoteDelivery.d.ts.map +1 -1
  219. package/dist/packages/paynote/schemas/PayNoteDelivery.js +0 -1
  220. package/dist/packages/paynote/schemas/PayNoteDelivery.js.map +1 -1
  221. package/dist/packages/paynote/schemas/PayNoteRejected.d.ts +2 -2
  222. package/dist/packages/paynote/schemas/ReservationDeclined.d.ts +2 -2
  223. package/dist/packages/paynote/schemas/ReservationReleaseDeclined.d.ts +2 -2
  224. package/dist/packages/paynote/schemas/SettlementAmountRejected.d.ts +2 -2
  225. package/dist/packages/paynote/schemas/StartCardTransactionMonitoringRequested.d.ts +31 -0
  226. package/dist/packages/paynote/schemas/StartCardTransactionMonitoringRequested.d.ts.map +1 -0
  227. package/dist/packages/paynote/schemas/StartCardTransactionMonitoringRequested.js +12 -0
  228. package/dist/packages/paynote/schemas/StartCardTransactionMonitoringRequested.js.map +1 -0
  229. package/dist/packages/paynote/schemas/TransactionStatus.d.ts +33 -0
  230. package/dist/packages/paynote/schemas/TransactionStatus.d.ts.map +1 -0
  231. package/dist/packages/paynote/schemas/TransactionStatus.js +13 -0
  232. package/dist/packages/paynote/schemas/TransactionStatus.js.map +1 -0
  233. package/dist/packages/paynote/schemas/index.d.ts +1508 -239
  234. package/dist/packages/paynote/schemas/index.d.ts.map +1 -1
  235. package/dist/packages/paynote/schemas/index.js +26 -2
  236. package/dist/packages/paynote/schemas/index.js.map +1 -1
  237. package/dist/repository.d.ts +5577 -3035
  238. package/dist/repository.d.ts.map +1 -1
  239. package/package.json +2 -2
@@ -4,7 +4,7 @@ export declare const ChangeWorkflow: {
4
4
  readonly request: {
5
5
  readonly description: "Expected request payload for this workflow.";
6
6
  readonly type: {
7
- readonly blueId: "9KDfK6k1HBAyHckj5VuWXFMLkgY5cJBESKT4eoq1bnrw";
7
+ readonly blueId: "6KZwmcsyYNiJhn2pAfS9LAFTxTRHcDw4yzPwV3A3SSQp";
8
8
  };
9
9
  };
10
10
  readonly steps: {
@@ -13,7 +13,7 @@ export declare const ChangeWorkflow: {
13
13
  readonly type: {
14
14
  readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
15
15
  };
16
- readonly value: "const issues = [];\n\nconst request = event.message.request || {};\n\nconst changeDescription = request.changeDescription;\nconst rawChangeset = request.changeset;\nconst rawSectionChanges = request.sectionChanges;\nconst requestSectionChanges = rawSectionChanges || {};\n\nconst toText = (value) => {\n const raw = value && value.value ? value.value : value;\n return raw && raw.trim ? raw.trim() : '';\n};\nconst asList = (value) => Array.isArray(value) ? value : [];\nconst hasType = (value) => value && value.type;\nconst escapePointer = (value) => {\n const text = toText(value);\n return text.split('~').join('~0').split('/').join('~1');\n};\nconst requestChangeset = asList(rawChangeset);\n\nconst uniqueKeys = (values, label) => {\n const seen = new Set();\n const output = [];\n for (const value of values) {\n const key = toText(value);\n if (!key) {\n issues.push(label + ' contains invalid key');\n continue;\n }\n if (seen.has(key)) {\n issues.push(label + ' contains duplicate key: ' + key);\n continue;\n }\n seen.add(key);\n output.push(key);\n }\n return output;\n};\n\nconst sameStringSet = (left, right) => {\n if (left.length !== right.length) return false;\n const set = new Set(left);\n if (set.size !== right.length) return false;\n for (const value of right) {\n if (!set.has(value)) return false;\n }\n return true;\n};\n\nconst contracts = Object(document('/contracts') || {});\n\nconst isDocumentSection = (contract) =>\n !!contract && Array.isArray(contract.relatedContracts);\n\nconst isContractsChangePolicy = (contract) => {\n if (!contract) return false;\n return 'requireSectionChanges' in contract;\n};\n\nconst findPolicy = () => {\n for (const key of Object.keys(contracts)) {\n const contract = contracts[key];\n if (isContractsChangePolicy(contract)) {\n return contract;\n }\n }\n return null;\n};\n\nconst policy = findPolicy();\nconst policyEnabled = !!policy && policy.requireSectionChanges !== false;\n\nif (!toText(changeDescription)) {\n issues.push('changeDescription is missing');\n}\n\nconst hasChangeset = !!rawChangeset;\nconst hasSectionChanges = !!rawSectionChanges;\n\nif (!hasChangeset && !hasSectionChanges) {\n issues.push('changeset or sectionChanges is required');\n}\n\nconst isContractsPath = (path) => {\n const value = toText(path);\n return value === '/contracts' || value.startsWith('/contracts/');\n};\nif (policyEnabled && hasChangeset) {\n for (const entry of requestChangeset) {\n if (entry && isContractsPath(entry.path)) {\n issues.push('changeset cannot modify /contracts when Contracts Change Policy is enabled');\n break;\n }\n }\n}\nconst isProposedChangePath = (path) =>\n toText(path).startsWith('/proposedChange');\nif (hasChangeset) {\n for (const entry of requestChangeset) {\n if (entry && isProposedChangePath(entry.path)) {\n issues.push('changeset cannot modify /proposedChange');\n break;\n }\n }\n}\n\nconst existingSections = {};\nfor (const key of Object.keys(contracts)) {\n const contract = contracts[key];\n if (isDocumentSection(contract)) {\n existingSections[key] = contract;\n }\n}\n\nconst contractIndex = {};\nfor (const sectionKey of Object.keys(existingSections)) {\n const section = existingSections[sectionKey];\n const related = asList(section.relatedContracts);\n for (const relatedKey of related) {\n const contractKey = toText(relatedKey);\n if (!contractKey) continue;\n if (contractIndex[contractKey] && contractIndex[contractKey] !== sectionKey) {\n contractIndex[contractKey] = null;\n } else if (!contractIndex[contractKey]) {\n contractIndex[contractKey] = sectionKey;\n }\n }\n}\n\nconst normalizeSectionDefinition = (sectionDef, label) => {\n if (!sectionDef) {\n issues.push(label + ' entry must be an object');\n return null;\n }\n const sectionKey = toText(sectionDef.sectionKey);\n if (!sectionKey) {\n issues.push(label + ' sectionKey is missing');\n return null;\n }\n const section = sectionDef.section;\n if (!section) {\n issues.push(label + ' section is missing');\n return null;\n }\n\n const rawContractsMap = sectionDef.contracts && sectionDef.contracts.value\n ? sectionDef.contracts.value\n : sectionDef.contracts || {};\n const contractDefs = [];\n const contractKeys = [];\n for (const [rawKey, contract] of Object.entries(rawContractsMap)) {\n if (\n rawKey === 'type' ||\n rawKey === 'keyType' ||\n rawKey === 'valueType' ||\n rawKey === 'description'\n ) {\n continue;\n }\n const key = toText(rawKey);\n if (!key) {\n issues.push(label + ' contract key is missing');\n continue;\n }\n if (!contract) {\n issues.push(label + ' contract ' + key + ' is missing or invalid');\n continue;\n }\n if (!hasType(contract)) {\n issues.push(label + ' contract ' + key + ' is missing type');\n }\n contractDefs.push({ key, contract });\n contractKeys.push(key);\n }\n\n if (!hasType(section)) {\n issues.push(label + ' section ' + sectionKey + ' is missing type');\n }\n\n const related = section.relatedContracts\n ? uniqueKeys(asList(section.relatedContracts), label + ' section ' + sectionKey + ' relatedContracts')\n : null;\n if (related && !sameStringSet(related, contractKeys)) {\n issues.push(label + ' section ' + sectionKey + ' relatedContracts must match contracts');\n }\n\n const normalizedRelated = related || contractKeys;\n const normalizedSection = Object.assign({}, section, {\n type: 'Conversation/Document Section',\n relatedContracts: normalizedRelated\n });\n\n return {\n sectionKey,\n section: normalizedSection,\n contractDefs,\n contractKeys\n };\n};\n\nconst sectionChangeset = [];\nconst seenSectionKeys = new Set();\nconst seenContractKeys = new Set();\n\nconst addList = asList(requestSectionChanges.add);\nconst modifyList = asList(requestSectionChanges.modify);\nconst removeList = asList(requestSectionChanges.remove);\n\nfor (const entry of addList) {\n const normalized = normalizeSectionDefinition(entry, 'sectionChanges.add');\n if (!normalized) continue;\n const sectionKey = normalized.sectionKey;\n if (seenSectionKeys.has(sectionKey)) {\n issues.push('section key duplicated in sectionChanges: ' + sectionKey);\n continue;\n }\n seenSectionKeys.add(sectionKey);\n\n if (contracts[sectionKey]) {\n issues.push('section key already exists at /contracts/' + sectionKey);\n }\n\n for (const contractKey of normalized.contractKeys) {\n if (seenContractKeys.has(contractKey)) {\n issues.push('contract key used by multiple sections in request: ' + contractKey);\n continue;\n }\n seenContractKeys.add(contractKey);\n if (contracts[contractKey]) {\n issues.push('contract key already exists at /contracts/' + contractKey);\n }\n }\n\n for (const contractDef of normalized.contractDefs) {\n sectionChangeset.push({\n op: 'add',\n path: '/contracts/' + escapePointer(contractDef.key),\n val: contractDef.contract\n });\n }\n sectionChangeset.push({\n op: 'add',\n path: '/contracts/' + escapePointer(sectionKey),\n val: normalized.section\n });\n}\n\nfor (const entry of modifyList) {\n const normalized = normalizeSectionDefinition(entry, 'sectionChanges.modify');\n if (!normalized) continue;\n const sectionKey = normalized.sectionKey;\n if (seenSectionKeys.has(sectionKey)) {\n issues.push('section key duplicated in sectionChanges: ' + sectionKey);\n continue;\n }\n seenSectionKeys.add(sectionKey);\n\n const existingSection = contracts[sectionKey];\n if (!existingSection) {\n issues.push('section key does not exist at /contracts/' + sectionKey);\n } else if (!isDocumentSection(existingSection)) {\n issues.push('existing section at /contracts/' + sectionKey + ' is not a Document Section');\n }\n\n const existingRelated =\n existingSection && existingSection.relatedContracts\n ? asList(existingSection.relatedContracts)\n : [];\n if (existingSection && !existingSection.relatedContracts) {\n issues.push('existing section ' + sectionKey + ' is missing relatedContracts');\n }\n\n for (const contractKey of normalized.contractKeys) {\n if (seenContractKeys.has(contractKey)) {\n issues.push('contract key used by multiple sections in request: ' + contractKey);\n continue;\n }\n seenContractKeys.add(contractKey);\n if (contractIndex[contractKey] && contractIndex[contractKey] !== sectionKey) {\n issues.push('contract key ' + contractKey + ' is linked to another section');\n }\n }\n\n for (const contractDef of normalized.contractDefs) {\n const op = contracts[contractDef.key] ? 'replace' : 'add';\n sectionChangeset.push({\n op,\n path: '/contracts/' + escapePointer(contractDef.key),\n val: contractDef.contract\n });\n }\n\n const toRemove = uniqueKeys(existingRelated, 'sectionChanges.modify remove list').filter(\n (key) => !normalized.contractKeys.includes(key)\n );\n for (const contractKey of toRemove) {\n if (contractIndex[contractKey] && contractIndex[contractKey] !== sectionKey) {\n issues.push('contract key ' + contractKey + ' is linked to another section');\n continue;\n }\n sectionChangeset.push({\n op: 'remove',\n path: '/contracts/' + escapePointer(contractKey)\n });\n }\n\n sectionChangeset.push({\n op: 'replace',\n path: '/contracts/' + escapePointer(sectionKey),\n val: normalized.section\n });\n}\n\nconst removeKeys = uniqueKeys(removeList, 'sectionChanges.remove');\nfor (const sectionKey of removeKeys) {\n if (seenSectionKeys.has(sectionKey)) {\n issues.push('section key duplicated in sectionChanges: ' + sectionKey);\n continue;\n }\n seenSectionKeys.add(sectionKey);\n\n const existingSection = contracts[sectionKey];\n if (!existingSection) {\n issues.push('section key does not exist at /contracts/' + sectionKey);\n continue;\n }\n if (!isDocumentSection(existingSection)) {\n issues.push('existing section at /contracts/' + sectionKey + ' is not a Document Section');\n continue;\n }\n\n const related = existingSection.relatedContracts\n ? uniqueKeys(asList(existingSection.relatedContracts), 'sectionChanges.remove relatedContracts')\n : [];\n if (!existingSection.relatedContracts) {\n issues.push('existing section ' + sectionKey + ' is missing relatedContracts');\n }\n\n for (const contractKey of related) {\n if (contractIndex[contractKey] && contractIndex[contractKey] !== sectionKey) {\n issues.push('contract key ' + contractKey + ' is linked to another section');\n continue;\n }\n sectionChangeset.push({\n op: 'remove',\n path: '/contracts/' + escapePointer(contractKey)\n });\n }\n sectionChangeset.push({\n op: 'remove',\n path: '/contracts/' + escapePointer(sectionKey)\n });\n}\nconst combinedChangeset = sectionChangeset.concat(hasChangeset ? requestChangeset : []);\n\nif (combinedChangeset.length === 0) {\n issues.push('no changes provided');\n}\n\nif (issues.length > 0) {\n return {\n changeset: [],\n events: [\n {\n type: \"Conversation/Proposed Change Invalid\",\n reason: issues.join('; ')\n }\n ]\n }\n}\n\nreturn {\n changeset: combinedChangeset\n};\n";
16
+ readonly value: "const invalid = (reason) => ({\n changeset: [],\n events: [{ type: 'Conversation/Proposed Change Invalid', reason }]\n});\n\nconst isArray = Array.isArray;\n\nconst change = event.message.request;\n\nconst summary = change?.summary;\nif (!summary || typeof summary !== 'string') {\n return invalid('summary is missing');\n}\n\nconst requestChangeset = isArray(change?.changeset) ? change.changeset : [];\nconst sectionChanges = change.sectionChanges;\n\nconst entryPath = (entry) => `${entry?.path || ''}`;\nconst isContractsPath = (p) => p === '/contracts' || p.startsWith('/contracts/');\nconst isProposedChangePath = (p) => p.startsWith('/proposedChange');\n\nconst contracts = document('/contracts') || {};\nconst policy = Object.values(contracts).find((c) => c?.requireSectionChanges !== undefined);\nconst policyEnabled = !!policy && policy.requireSectionChanges !== false;\n\nif (\n policyEnabled &&\n requestChangeset.some((e) => isContractsPath(entryPath(e)))\n) {\n return invalid('changeset cannot modify /contracts when Contracts Change Policy is enabled');\n}\n\nif (requestChangeset.some((e) => isProposedChangePath(entryPath(e)))) {\n return invalid('changeset cannot modify /proposedChange');\n}\n\nconst escapePointer = (value) =>\n `${value}`.split('~').join('~0').split('/').join('~1');\n\nconst contractPtr = (key) => '/contracts/' + escapePointer(key);\n\nconst isMetaKey = (key) =>\n key === 'type' || key === 'keyType' || key === 'valueType' || key === 'description';\n\nconst contractKeysFromMap = (contractsMap) =>\n Object.keys(contractsMap || {}).filter((k) => !isMetaKey(k));\n\nconst normalizeSection = (section, contractKeys) => ({\n ...(section || {}),\n type: 'Conversation/Document Section',\n relatedContracts: (section?.relatedContracts?.length ? section.relatedContracts : contractKeys)\n});\n\nconst hasMatchingRelatedContracts = (section, contractKeys) => {\n const related = isArray(section?.relatedContracts)\n ? section.relatedContracts.map((value) => `${value}`)\n : [];\n if (!related.length) {\n return true;\n }\n if (related.length !== contractKeys.length) {\n return false;\n }\n const relatedMap = {};\n for (const value of related) {\n const key = `${value}`;\n relatedMap[key] = (relatedMap[key] || 0) + 1;\n }\n if (Object.keys(relatedMap).length !== contractKeys.length) {\n return false;\n }\n for (const key of contractKeys) {\n if (!relatedMap[key]) {\n return false;\n }\n }\n return true;\n};\n\nconst sectionChangeset = [];\nconst seenSectionKeys = {};\nconst seenContractKeys = {};\nconst existingContractKeys = {};\nfor (const key of Object.keys(contracts || {}).filter((k) => !isMetaKey(k))) {\n existingContractKeys[key] = true;\n}\n\nconst trackSectionKey = (sectionKey) => {\n if (seenSectionKeys[sectionKey]) {\n return invalid(`section key duplicated in sectionChanges: ${sectionKey}`);\n }\n seenSectionKeys[sectionKey] = true;\n return null;\n};\n\nconst trackContractKey = (sectionKey, contractKey) => {\n const existingSection = seenContractKeys[contractKey];\n if (existingSection && existingSection !== sectionKey) {\n return invalid(`contract key used by multiple sections in request: ${contractKey}`);\n }\n seenContractKeys[contractKey] = sectionKey;\n return null;\n};\n\nconst addList = isArray(sectionChanges?.add) ? sectionChanges.add : [];\nfor (const entry of addList) {\n const sectionKey = `${entry?.sectionKey || ''}`;\n if (!sectionKey) return invalid('sectionChanges.add is missing sectionKey');\n\n const sectionKeyDup = trackSectionKey(sectionKey);\n if (sectionKeyDup) return sectionKeyDup;\n\n if (existingContractKeys[sectionKey]) {\n return invalid(`contract key already exists at ${contractPtr(sectionKey)}`);\n }\n\n const contractsMap = entry?.contracts || {};\n const contractKeys = contractKeysFromMap(contractsMap).map((key) => `${key}`);\n\n if (!hasMatchingRelatedContracts(entry?.section, contractKeys)) {\n return invalid('relatedContracts must match contracts');\n }\n\n for (const key of contractKeys) {\n if (existingContractKeys[key]) {\n return invalid(`contract key already exists at ${contractPtr(key)}`);\n }\n const dup = trackContractKey(sectionKey, key);\n if (dup) return dup;\n }\n\n for (const key of contractKeys) {\n sectionChangeset.push({ op: 'add', path: contractPtr(key), val: contractsMap[key] });\n }\n\n sectionChangeset.push({\n op: 'add',\n path: contractPtr(sectionKey),\n val: normalizeSection(entry?.section, contractKeys)\n });\n}\n\nconst modifyList = isArray(sectionChanges?.modify) ? sectionChanges.modify : [];\nfor (const entry of modifyList) {\n const sectionKey = `${entry?.sectionKey || ''}`;\n if (!sectionKey) return invalid('sectionChanges.modify is missing sectionKey');\n\n const sectionKeyDup = trackSectionKey(sectionKey);\n if (sectionKeyDup) return sectionKeyDup;\n\n const existingRelated = isArray(contracts?.[sectionKey]?.relatedContracts)\n ? contracts[sectionKey].relatedContracts.map((value) => `${value}`)\n : [];\n const existingRelatedMap = {};\n for (const value of existingRelated) {\n existingRelatedMap[`${value}`] = true;\n }\n\n const contractsMap = entry?.contracts || {};\n const contractKeys = contractKeysFromMap(contractsMap).map((key) => `${key}`);\n\n if (!hasMatchingRelatedContracts(entry?.section, contractKeys)) {\n return invalid('relatedContracts must match contracts');\n }\n\n for (const key of contractKeys) {\n const dup = trackContractKey(sectionKey, key);\n if (dup) return dup;\n if (existingContractKeys[key] && !existingRelatedMap[key]) {\n return invalid(`contract key already exists at ${contractPtr(key)}`);\n }\n }\n\n for (const key of contractKeys) {\n sectionChangeset.push({ op: 'add', path: contractPtr(key), val: contractsMap[key] });\n }\n\n for (const oldKey of existingRelated) {\n if (contractKeys.indexOf(oldKey) === -1) {\n sectionChangeset.push({ op: 'remove', path: contractPtr(oldKey) });\n }\n }\n\n sectionChangeset.push({\n op: 'add',\n path: contractPtr(sectionKey),\n val: normalizeSection(entry?.section, contractKeys)\n });\n}\n\nconst removeList = isArray(sectionChanges?.remove) ? sectionChanges.remove : [];\nfor (const entry of removeList) {\n const sectionKey = `${entry?.sectionKey || entry || ''}`;\n if (!sectionKey) return invalid('sectionChanges.remove is missing sectionKey');\n\n const related = isArray(contracts?.[sectionKey]?.relatedContracts)\n ? contracts[sectionKey].relatedContracts\n : [];\n\n for (const key of related) {\n sectionChangeset.push({ op: 'remove', path: contractPtr(key) });\n }\n sectionChangeset.push({ op: 'remove', path: contractPtr(sectionKey) });\n}\n\nconst combined = sectionChangeset.concat(requestChangeset);\n\nif (combined.length === 0) {\n return invalid('no changes provided');\n}\n\nreturn { changeset: combined };\n";
17
17
  };
18
18
  readonly name: "Prepare";
19
19
  readonly type: {
@@ -4,7 +4,7 @@ export const ChangeWorkflow = {
4
4
  request: {
5
5
  description: 'Expected request payload for this workflow.',
6
6
  type: {
7
- blueId: '9KDfK6k1HBAyHckj5VuWXFMLkgY5cJBESKT4eoq1bnrw',
7
+ blueId: '6KZwmcsyYNiJhn2pAfS9LAFTxTRHcDw4yzPwV3A3SSQp',
8
8
  },
9
9
  },
10
10
  steps: {
@@ -14,7 +14,7 @@ export const ChangeWorkflow = {
14
14
  type: {
15
15
  blueId: 'DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K',
16
16
  },
17
- value: "const issues = [];\n\nconst request = event.message.request || {};\n\nconst changeDescription = request.changeDescription;\nconst rawChangeset = request.changeset;\nconst rawSectionChanges = request.sectionChanges;\nconst requestSectionChanges = rawSectionChanges || {};\n\nconst toText = (value) => {\n const raw = value && value.value ? value.value : value;\n return raw && raw.trim ? raw.trim() : '';\n};\nconst asList = (value) => Array.isArray(value) ? value : [];\nconst hasType = (value) => value && value.type;\nconst escapePointer = (value) => {\n const text = toText(value);\n return text.split('~').join('~0').split('/').join('~1');\n};\nconst requestChangeset = asList(rawChangeset);\n\nconst uniqueKeys = (values, label) => {\n const seen = new Set();\n const output = [];\n for (const value of values) {\n const key = toText(value);\n if (!key) {\n issues.push(label + ' contains invalid key');\n continue;\n }\n if (seen.has(key)) {\n issues.push(label + ' contains duplicate key: ' + key);\n continue;\n }\n seen.add(key);\n output.push(key);\n }\n return output;\n};\n\nconst sameStringSet = (left, right) => {\n if (left.length !== right.length) return false;\n const set = new Set(left);\n if (set.size !== right.length) return false;\n for (const value of right) {\n if (!set.has(value)) return false;\n }\n return true;\n};\n\nconst contracts = Object(document('/contracts') || {});\n\nconst isDocumentSection = (contract) =>\n !!contract && Array.isArray(contract.relatedContracts);\n\nconst isContractsChangePolicy = (contract) => {\n if (!contract) return false;\n return 'requireSectionChanges' in contract;\n};\n\nconst findPolicy = () => {\n for (const key of Object.keys(contracts)) {\n const contract = contracts[key];\n if (isContractsChangePolicy(contract)) {\n return contract;\n }\n }\n return null;\n};\n\nconst policy = findPolicy();\nconst policyEnabled = !!policy && policy.requireSectionChanges !== false;\n\nif (!toText(changeDescription)) {\n issues.push('changeDescription is missing');\n}\n\nconst hasChangeset = !!rawChangeset;\nconst hasSectionChanges = !!rawSectionChanges;\n\nif (!hasChangeset && !hasSectionChanges) {\n issues.push('changeset or sectionChanges is required');\n}\n\nconst isContractsPath = (path) => {\n const value = toText(path);\n return value === '/contracts' || value.startsWith('/contracts/');\n};\nif (policyEnabled && hasChangeset) {\n for (const entry of requestChangeset) {\n if (entry && isContractsPath(entry.path)) {\n issues.push('changeset cannot modify /contracts when Contracts Change Policy is enabled');\n break;\n }\n }\n}\nconst isProposedChangePath = (path) =>\n toText(path).startsWith('/proposedChange');\nif (hasChangeset) {\n for (const entry of requestChangeset) {\n if (entry && isProposedChangePath(entry.path)) {\n issues.push('changeset cannot modify /proposedChange');\n break;\n }\n }\n}\n\nconst existingSections = {};\nfor (const key of Object.keys(contracts)) {\n const contract = contracts[key];\n if (isDocumentSection(contract)) {\n existingSections[key] = contract;\n }\n}\n\nconst contractIndex = {};\nfor (const sectionKey of Object.keys(existingSections)) {\n const section = existingSections[sectionKey];\n const related = asList(section.relatedContracts);\n for (const relatedKey of related) {\n const contractKey = toText(relatedKey);\n if (!contractKey) continue;\n if (contractIndex[contractKey] && contractIndex[contractKey] !== sectionKey) {\n contractIndex[contractKey] = null;\n } else if (!contractIndex[contractKey]) {\n contractIndex[contractKey] = sectionKey;\n }\n }\n}\n\nconst normalizeSectionDefinition = (sectionDef, label) => {\n if (!sectionDef) {\n issues.push(label + ' entry must be an object');\n return null;\n }\n const sectionKey = toText(sectionDef.sectionKey);\n if (!sectionKey) {\n issues.push(label + ' sectionKey is missing');\n return null;\n }\n const section = sectionDef.section;\n if (!section) {\n issues.push(label + ' section is missing');\n return null;\n }\n\n const rawContractsMap = sectionDef.contracts && sectionDef.contracts.value\n ? sectionDef.contracts.value\n : sectionDef.contracts || {};\n const contractDefs = [];\n const contractKeys = [];\n for (const [rawKey, contract] of Object.entries(rawContractsMap)) {\n if (\n rawKey === 'type' ||\n rawKey === 'keyType' ||\n rawKey === 'valueType' ||\n rawKey === 'description'\n ) {\n continue;\n }\n const key = toText(rawKey);\n if (!key) {\n issues.push(label + ' contract key is missing');\n continue;\n }\n if (!contract) {\n issues.push(label + ' contract ' + key + ' is missing or invalid');\n continue;\n }\n if (!hasType(contract)) {\n issues.push(label + ' contract ' + key + ' is missing type');\n }\n contractDefs.push({ key, contract });\n contractKeys.push(key);\n }\n\n if (!hasType(section)) {\n issues.push(label + ' section ' + sectionKey + ' is missing type');\n }\n\n const related = section.relatedContracts\n ? uniqueKeys(asList(section.relatedContracts), label + ' section ' + sectionKey + ' relatedContracts')\n : null;\n if (related && !sameStringSet(related, contractKeys)) {\n issues.push(label + ' section ' + sectionKey + ' relatedContracts must match contracts');\n }\n\n const normalizedRelated = related || contractKeys;\n const normalizedSection = Object.assign({}, section, {\n type: 'Conversation/Document Section',\n relatedContracts: normalizedRelated\n });\n\n return {\n sectionKey,\n section: normalizedSection,\n contractDefs,\n contractKeys\n };\n};\n\nconst sectionChangeset = [];\nconst seenSectionKeys = new Set();\nconst seenContractKeys = new Set();\n\nconst addList = asList(requestSectionChanges.add);\nconst modifyList = asList(requestSectionChanges.modify);\nconst removeList = asList(requestSectionChanges.remove);\n\nfor (const entry of addList) {\n const normalized = normalizeSectionDefinition(entry, 'sectionChanges.add');\n if (!normalized) continue;\n const sectionKey = normalized.sectionKey;\n if (seenSectionKeys.has(sectionKey)) {\n issues.push('section key duplicated in sectionChanges: ' + sectionKey);\n continue;\n }\n seenSectionKeys.add(sectionKey);\n\n if (contracts[sectionKey]) {\n issues.push('section key already exists at /contracts/' + sectionKey);\n }\n\n for (const contractKey of normalized.contractKeys) {\n if (seenContractKeys.has(contractKey)) {\n issues.push('contract key used by multiple sections in request: ' + contractKey);\n continue;\n }\n seenContractKeys.add(contractKey);\n if (contracts[contractKey]) {\n issues.push('contract key already exists at /contracts/' + contractKey);\n }\n }\n\n for (const contractDef of normalized.contractDefs) {\n sectionChangeset.push({\n op: 'add',\n path: '/contracts/' + escapePointer(contractDef.key),\n val: contractDef.contract\n });\n }\n sectionChangeset.push({\n op: 'add',\n path: '/contracts/' + escapePointer(sectionKey),\n val: normalized.section\n });\n}\n\nfor (const entry of modifyList) {\n const normalized = normalizeSectionDefinition(entry, 'sectionChanges.modify');\n if (!normalized) continue;\n const sectionKey = normalized.sectionKey;\n if (seenSectionKeys.has(sectionKey)) {\n issues.push('section key duplicated in sectionChanges: ' + sectionKey);\n continue;\n }\n seenSectionKeys.add(sectionKey);\n\n const existingSection = contracts[sectionKey];\n if (!existingSection) {\n issues.push('section key does not exist at /contracts/' + sectionKey);\n } else if (!isDocumentSection(existingSection)) {\n issues.push('existing section at /contracts/' + sectionKey + ' is not a Document Section');\n }\n\n const existingRelated =\n existingSection && existingSection.relatedContracts\n ? asList(existingSection.relatedContracts)\n : [];\n if (existingSection && !existingSection.relatedContracts) {\n issues.push('existing section ' + sectionKey + ' is missing relatedContracts');\n }\n\n for (const contractKey of normalized.contractKeys) {\n if (seenContractKeys.has(contractKey)) {\n issues.push('contract key used by multiple sections in request: ' + contractKey);\n continue;\n }\n seenContractKeys.add(contractKey);\n if (contractIndex[contractKey] && contractIndex[contractKey] !== sectionKey) {\n issues.push('contract key ' + contractKey + ' is linked to another section');\n }\n }\n\n for (const contractDef of normalized.contractDefs) {\n const op = contracts[contractDef.key] ? 'replace' : 'add';\n sectionChangeset.push({\n op,\n path: '/contracts/' + escapePointer(contractDef.key),\n val: contractDef.contract\n });\n }\n\n const toRemove = uniqueKeys(existingRelated, 'sectionChanges.modify remove list').filter(\n (key) => !normalized.contractKeys.includes(key)\n );\n for (const contractKey of toRemove) {\n if (contractIndex[contractKey] && contractIndex[contractKey] !== sectionKey) {\n issues.push('contract key ' + contractKey + ' is linked to another section');\n continue;\n }\n sectionChangeset.push({\n op: 'remove',\n path: '/contracts/' + escapePointer(contractKey)\n });\n }\n\n sectionChangeset.push({\n op: 'replace',\n path: '/contracts/' + escapePointer(sectionKey),\n val: normalized.section\n });\n}\n\nconst removeKeys = uniqueKeys(removeList, 'sectionChanges.remove');\nfor (const sectionKey of removeKeys) {\n if (seenSectionKeys.has(sectionKey)) {\n issues.push('section key duplicated in sectionChanges: ' + sectionKey);\n continue;\n }\n seenSectionKeys.add(sectionKey);\n\n const existingSection = contracts[sectionKey];\n if (!existingSection) {\n issues.push('section key does not exist at /contracts/' + sectionKey);\n continue;\n }\n if (!isDocumentSection(existingSection)) {\n issues.push('existing section at /contracts/' + sectionKey + ' is not a Document Section');\n continue;\n }\n\n const related = existingSection.relatedContracts\n ? uniqueKeys(asList(existingSection.relatedContracts), 'sectionChanges.remove relatedContracts')\n : [];\n if (!existingSection.relatedContracts) {\n issues.push('existing section ' + sectionKey + ' is missing relatedContracts');\n }\n\n for (const contractKey of related) {\n if (contractIndex[contractKey] && contractIndex[contractKey] !== sectionKey) {\n issues.push('contract key ' + contractKey + ' is linked to another section');\n continue;\n }\n sectionChangeset.push({\n op: 'remove',\n path: '/contracts/' + escapePointer(contractKey)\n });\n }\n sectionChangeset.push({\n op: 'remove',\n path: '/contracts/' + escapePointer(sectionKey)\n });\n}\nconst combinedChangeset = sectionChangeset.concat(hasChangeset ? requestChangeset : []);\n\nif (combinedChangeset.length === 0) {\n issues.push('no changes provided');\n}\n\nif (issues.length > 0) {\n return {\n changeset: [],\n events: [\n {\n type: \"Conversation/Proposed Change Invalid\",\n reason: issues.join('; ')\n }\n ]\n }\n}\n\nreturn {\n changeset: combinedChangeset\n};\n",
17
+ value: "const invalid = (reason) => ({\n changeset: [],\n events: [{ type: 'Conversation/Proposed Change Invalid', reason }]\n});\n\nconst isArray = Array.isArray;\n\nconst change = event.message.request;\n\nconst summary = change?.summary;\nif (!summary || typeof summary !== 'string') {\n return invalid('summary is missing');\n}\n\nconst requestChangeset = isArray(change?.changeset) ? change.changeset : [];\nconst sectionChanges = change.sectionChanges;\n\nconst entryPath = (entry) => `${entry?.path || ''}`;\nconst isContractsPath = (p) => p === '/contracts' || p.startsWith('/contracts/');\nconst isProposedChangePath = (p) => p.startsWith('/proposedChange');\n\nconst contracts = document('/contracts') || {};\nconst policy = Object.values(contracts).find((c) => c?.requireSectionChanges !== undefined);\nconst policyEnabled = !!policy && policy.requireSectionChanges !== false;\n\nif (\n policyEnabled &&\n requestChangeset.some((e) => isContractsPath(entryPath(e)))\n) {\n return invalid('changeset cannot modify /contracts when Contracts Change Policy is enabled');\n}\n\nif (requestChangeset.some((e) => isProposedChangePath(entryPath(e)))) {\n return invalid('changeset cannot modify /proposedChange');\n}\n\nconst escapePointer = (value) =>\n `${value}`.split('~').join('~0').split('/').join('~1');\n\nconst contractPtr = (key) => '/contracts/' + escapePointer(key);\n\nconst isMetaKey = (key) =>\n key === 'type' || key === 'keyType' || key === 'valueType' || key === 'description';\n\nconst contractKeysFromMap = (contractsMap) =>\n Object.keys(contractsMap || {}).filter((k) => !isMetaKey(k));\n\nconst normalizeSection = (section, contractKeys) => ({\n ...(section || {}),\n type: 'Conversation/Document Section',\n relatedContracts: (section?.relatedContracts?.length ? section.relatedContracts : contractKeys)\n});\n\nconst hasMatchingRelatedContracts = (section, contractKeys) => {\n const related = isArray(section?.relatedContracts)\n ? section.relatedContracts.map((value) => `${value}`)\n : [];\n if (!related.length) {\n return true;\n }\n if (related.length !== contractKeys.length) {\n return false;\n }\n const relatedMap = {};\n for (const value of related) {\n const key = `${value}`;\n relatedMap[key] = (relatedMap[key] || 0) + 1;\n }\n if (Object.keys(relatedMap).length !== contractKeys.length) {\n return false;\n }\n for (const key of contractKeys) {\n if (!relatedMap[key]) {\n return false;\n }\n }\n return true;\n};\n\nconst sectionChangeset = [];\nconst seenSectionKeys = {};\nconst seenContractKeys = {};\nconst existingContractKeys = {};\nfor (const key of Object.keys(contracts || {}).filter((k) => !isMetaKey(k))) {\n existingContractKeys[key] = true;\n}\n\nconst trackSectionKey = (sectionKey) => {\n if (seenSectionKeys[sectionKey]) {\n return invalid(`section key duplicated in sectionChanges: ${sectionKey}`);\n }\n seenSectionKeys[sectionKey] = true;\n return null;\n};\n\nconst trackContractKey = (sectionKey, contractKey) => {\n const existingSection = seenContractKeys[contractKey];\n if (existingSection && existingSection !== sectionKey) {\n return invalid(`contract key used by multiple sections in request: ${contractKey}`);\n }\n seenContractKeys[contractKey] = sectionKey;\n return null;\n};\n\nconst addList = isArray(sectionChanges?.add) ? sectionChanges.add : [];\nfor (const entry of addList) {\n const sectionKey = `${entry?.sectionKey || ''}`;\n if (!sectionKey) return invalid('sectionChanges.add is missing sectionKey');\n\n const sectionKeyDup = trackSectionKey(sectionKey);\n if (sectionKeyDup) return sectionKeyDup;\n\n if (existingContractKeys[sectionKey]) {\n return invalid(`contract key already exists at ${contractPtr(sectionKey)}`);\n }\n\n const contractsMap = entry?.contracts || {};\n const contractKeys = contractKeysFromMap(contractsMap).map((key) => `${key}`);\n\n if (!hasMatchingRelatedContracts(entry?.section, contractKeys)) {\n return invalid('relatedContracts must match contracts');\n }\n\n for (const key of contractKeys) {\n if (existingContractKeys[key]) {\n return invalid(`contract key already exists at ${contractPtr(key)}`);\n }\n const dup = trackContractKey(sectionKey, key);\n if (dup) return dup;\n }\n\n for (const key of contractKeys) {\n sectionChangeset.push({ op: 'add', path: contractPtr(key), val: contractsMap[key] });\n }\n\n sectionChangeset.push({\n op: 'add',\n path: contractPtr(sectionKey),\n val: normalizeSection(entry?.section, contractKeys)\n });\n}\n\nconst modifyList = isArray(sectionChanges?.modify) ? sectionChanges.modify : [];\nfor (const entry of modifyList) {\n const sectionKey = `${entry?.sectionKey || ''}`;\n if (!sectionKey) return invalid('sectionChanges.modify is missing sectionKey');\n\n const sectionKeyDup = trackSectionKey(sectionKey);\n if (sectionKeyDup) return sectionKeyDup;\n\n const existingRelated = isArray(contracts?.[sectionKey]?.relatedContracts)\n ? contracts[sectionKey].relatedContracts.map((value) => `${value}`)\n : [];\n const existingRelatedMap = {};\n for (const value of existingRelated) {\n existingRelatedMap[`${value}`] = true;\n }\n\n const contractsMap = entry?.contracts || {};\n const contractKeys = contractKeysFromMap(contractsMap).map((key) => `${key}`);\n\n if (!hasMatchingRelatedContracts(entry?.section, contractKeys)) {\n return invalid('relatedContracts must match contracts');\n }\n\n for (const key of contractKeys) {\n const dup = trackContractKey(sectionKey, key);\n if (dup) return dup;\n if (existingContractKeys[key] && !existingRelatedMap[key]) {\n return invalid(`contract key already exists at ${contractPtr(key)}`);\n }\n }\n\n for (const key of contractKeys) {\n sectionChangeset.push({ op: 'add', path: contractPtr(key), val: contractsMap[key] });\n }\n\n for (const oldKey of existingRelated) {\n if (contractKeys.indexOf(oldKey) === -1) {\n sectionChangeset.push({ op: 'remove', path: contractPtr(oldKey) });\n }\n }\n\n sectionChangeset.push({\n op: 'add',\n path: contractPtr(sectionKey),\n val: normalizeSection(entry?.section, contractKeys)\n });\n}\n\nconst removeList = isArray(sectionChanges?.remove) ? sectionChanges.remove : [];\nfor (const entry of removeList) {\n const sectionKey = `${entry?.sectionKey || entry || ''}`;\n if (!sectionKey) return invalid('sectionChanges.remove is missing sectionKey');\n\n const related = isArray(contracts?.[sectionKey]?.relatedContracts)\n ? contracts[sectionKey].relatedContracts\n : [];\n\n for (const key of related) {\n sectionChangeset.push({ op: 'remove', path: contractPtr(key) });\n }\n sectionChangeset.push({ op: 'remove', path: contractPtr(sectionKey) });\n}\n\nconst combined = sectionChangeset.concat(requestChangeset);\n\nif (combined.length === 0) {\n return invalid('no changes provided');\n}\n\nreturn { changeset: combined };\n",
18
18
  },
19
19
  name: 'Prepare',
20
20
  type: {
@@ -1 +1 @@
1
- {"version":3,"file":"ChangeWorkflow.js","sourceRoot":"","sources":["../../../../src/packages/conversation/contents/ChangeWorkflow.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,cAAc,GAAG;IAC5B,WAAW,EAAE,4DAA4D;IACzE,IAAI,EAAE,iBAAiB;IACvB,OAAO,EAAE;QACP,WAAW,EAAE,6CAA6C;QAC1D,IAAI,EAAE;YACJ,MAAM,EAAE,8CAA8C;SACvD;KACF;IACD,KAAK,EAAE;QACL,KAAK,EAAE;YACL;gBACE,IAAI,EAAE;oBACJ,IAAI,EAAE;wBACJ,MAAM,EAAE,8CAA8C;qBACvD;oBACD,KAAK,EACH,8rWAA8rW;iBACjsW;gBACD,IAAI,EAAE,SAAS;gBACf,IAAI,EAAE;oBACJ,MAAM,EAAE,8CAA8C;iBACvD;aACF;YACD;gBACE,SAAS,EAAE;oBACT,IAAI,EAAE;wBACJ,MAAM,EAAE,8CAA8C;qBACvD;oBACD,KAAK,EAAE,4BAA4B;iBACpC;gBACD,IAAI,EAAE,OAAO;gBACb,IAAI,EAAE;oBACJ,MAAM,EAAE,8CAA8C;iBACvD;aACF;SACF;KACF;IACD,IAAI,EAAE;QACJ,MAAM,EAAE,8CAA8C;KACvD;CACO,CAAC"}
1
+ {"version":3,"file":"ChangeWorkflow.js","sourceRoot":"","sources":["../../../../src/packages/conversation/contents/ChangeWorkflow.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,cAAc,GAAG;IAC5B,WAAW,EAAE,4DAA4D;IACzE,IAAI,EAAE,iBAAiB;IACvB,OAAO,EAAE;QACP,WAAW,EAAE,6CAA6C;QAC1D,IAAI,EAAE;YACJ,MAAM,EAAE,8CAA8C;SACvD;KACF;IACD,KAAK,EAAE;QACL,KAAK,EAAE;YACL;gBACE,IAAI,EAAE;oBACJ,IAAI,EAAE;wBACJ,MAAM,EAAE,8CAA8C;qBACvD;oBACD,KAAK,EACH,g1NAAg1N;iBACn1N;gBACD,IAAI,EAAE,SAAS;gBACf,IAAI,EAAE;oBACJ,MAAM,EAAE,8CAA8C;iBACvD;aACF;YACD;gBACE,SAAS,EAAE;oBACT,IAAI,EAAE;wBACJ,MAAM,EAAE,8CAA8C;qBACvD;oBACD,KAAK,EAAE,4BAA4B;iBACpC;gBACD,IAAI,EAAE,OAAO;gBACb,IAAI,EAAE;oBACJ,MAAM,EAAE,8CAA8C;iBACvD;aACF;SACF;KACF;IACD,IAAI,EAAE;QACJ,MAAM,EAAE,8CAA8C;KACvD;CACO,CAAC"}
@@ -0,0 +1,44 @@
1
+ export declare const CustomerActionRequested: {
2
+ readonly actionId: {
3
+ readonly description: "Optional idempotency key for the action request.";
4
+ readonly type: {
5
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
6
+ };
7
+ };
8
+ readonly actionType: {
9
+ readonly description: "consentApproval | callOperation | informational";
10
+ readonly type: {
11
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
12
+ };
13
+ };
14
+ readonly description: "A document suggests that the bank should ask the customer to take a specific action in the bank UI.";
15
+ readonly message: {
16
+ readonly description: "Human-readable message describing what is expected.";
17
+ readonly type: {
18
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
19
+ };
20
+ };
21
+ readonly name: "Customer Action Requested";
22
+ readonly operationName: {
23
+ readonly description: "Optional contract operation to execute (used for callOperation).";
24
+ readonly type: {
25
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
26
+ };
27
+ };
28
+ readonly prefillRequestJson: {
29
+ readonly description: "Optional JSON string to prefill the operation request form.";
30
+ readonly type: {
31
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
32
+ };
33
+ };
34
+ readonly title: {
35
+ readonly description: "Short title for the pending action.";
36
+ readonly type: {
37
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
38
+ };
39
+ };
40
+ readonly type: {
41
+ readonly blueId: "8f9UhHMbRe62sFgzQVheToaJPYi7t7HPNVvpQTbqfL5n";
42
+ };
43
+ };
44
+ //# sourceMappingURL=CustomerActionRequested.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CustomerActionRequested.d.ts","sourceRoot":"","sources":["../../../../src/packages/conversation/contents/CustomerActionRequested.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,uBAAuB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA4C1B,CAAC"}
@@ -0,0 +1,44 @@
1
+ export const CustomerActionRequested = {
2
+ actionId: {
3
+ description: 'Optional idempotency key for the action request.',
4
+ type: {
5
+ blueId: 'DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K',
6
+ },
7
+ },
8
+ actionType: {
9
+ description: 'consentApproval | callOperation | informational',
10
+ type: {
11
+ blueId: 'DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K',
12
+ },
13
+ },
14
+ description: 'A document suggests that the bank should ask the customer to take a specific action in the bank UI.',
15
+ message: {
16
+ description: 'Human-readable message describing what is expected.',
17
+ type: {
18
+ blueId: 'DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K',
19
+ },
20
+ },
21
+ name: 'Customer Action Requested',
22
+ operationName: {
23
+ description: 'Optional contract operation to execute (used for callOperation).',
24
+ type: {
25
+ blueId: 'DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K',
26
+ },
27
+ },
28
+ prefillRequestJson: {
29
+ description: 'Optional JSON string to prefill the operation request form.',
30
+ type: {
31
+ blueId: 'DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K',
32
+ },
33
+ },
34
+ title: {
35
+ description: 'Short title for the pending action.',
36
+ type: {
37
+ blueId: 'DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K',
38
+ },
39
+ },
40
+ type: {
41
+ blueId: '8f9UhHMbRe62sFgzQVheToaJPYi7t7HPNVvpQTbqfL5n',
42
+ },
43
+ };
44
+ //# sourceMappingURL=CustomerActionRequested.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CustomerActionRequested.js","sourceRoot":"","sources":["../../../../src/packages/conversation/contents/CustomerActionRequested.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,uBAAuB,GAAG;IACrC,QAAQ,EAAE;QACR,WAAW,EAAE,kDAAkD;QAC/D,IAAI,EAAE;YACJ,MAAM,EAAE,8CAA8C;SACvD;KACF;IACD,UAAU,EAAE;QACV,WAAW,EAAE,iDAAiD;QAC9D,IAAI,EAAE;YACJ,MAAM,EAAE,8CAA8C;SACvD;KACF;IACD,WAAW,EACT,qGAAqG;IACvG,OAAO,EAAE;QACP,WAAW,EAAE,qDAAqD;QAClE,IAAI,EAAE;YACJ,MAAM,EAAE,8CAA8C;SACvD;KACF;IACD,IAAI,EAAE,2BAA2B;IACjC,aAAa,EAAE;QACb,WAAW,EACT,kEAAkE;QACpE,IAAI,EAAE;YACJ,MAAM,EAAE,8CAA8C;SACvD;KACF;IACD,kBAAkB,EAAE;QAClB,WAAW,EAAE,6DAA6D;QAC1E,IAAI,EAAE;YACJ,MAAM,EAAE,8CAA8C;SACvD;KACF;IACD,KAAK,EAAE;QACL,WAAW,EAAE,qCAAqC;QAClD,IAAI,EAAE;YACJ,MAAM,EAAE,8CAA8C;SACvD;KACF;IACD,IAAI,EAAE;QACJ,MAAM,EAAE,8CAA8C;KACvD;CACO,CAAC"}
@@ -0,0 +1,233 @@
1
+ export declare const CustomerConsent: {
2
+ readonly consentDetails: {
3
+ readonly description: "Generic scope details (merchant id, event categories, requesting contract refs, etc.).";
4
+ readonly keyType: {
5
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
6
+ };
7
+ readonly type: {
8
+ readonly blueId: "G7fBT9PSod1RfHLHkpafAGBDVAJMrMhAMY51ERcyXNrj";
9
+ };
10
+ readonly valueType: {
11
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
12
+ };
13
+ };
14
+ readonly consentKind: {
15
+ readonly description: "Classification of the consent (e.g., cardTransactionMonitoring).";
16
+ readonly type: {
17
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
18
+ };
19
+ };
20
+ readonly consentStatus: {
21
+ readonly description: "Consent state (granted, revoked).";
22
+ readonly type: {
23
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
24
+ };
25
+ readonly value: "granted";
26
+ };
27
+ readonly contracts: {
28
+ readonly granteeChannel: {
29
+ readonly description: "Grantee (e.g., merchant MyOS timeline).";
30
+ readonly type: {
31
+ readonly blueId: "HCF8mXnX3dFjQ8osjxb4Wzm2Nm1DoXnTYuA5sPnV7NTs";
32
+ };
33
+ };
34
+ readonly granterChannel: {
35
+ readonly description: "Granter (customer represented by the bank; customer has no MyOS account).";
36
+ readonly type: {
37
+ readonly blueId: "HCF8mXnX3dFjQ8osjxb4Wzm2Nm1DoXnTYuA5sPnV7NTs";
38
+ };
39
+ };
40
+ readonly guarantorChannel: {
41
+ readonly description: "Bank/admin channel.";
42
+ readonly type: {
43
+ readonly blueId: "HCF8mXnX3dFjQ8osjxb4Wzm2Nm1DoXnTYuA5sPnV7NTs";
44
+ };
45
+ };
46
+ readonly initialize: {
47
+ readonly channel: {
48
+ readonly type: {
49
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
50
+ };
51
+ readonly value: "initLifecycleChannel";
52
+ };
53
+ readonly steps: {
54
+ readonly items: readonly [{
55
+ readonly changeset: {
56
+ readonly items: readonly [{
57
+ readonly op: {
58
+ readonly type: {
59
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
60
+ };
61
+ readonly value: "replace";
62
+ };
63
+ readonly path: {
64
+ readonly type: {
65
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
66
+ };
67
+ readonly value: "/consentStatus";
68
+ };
69
+ readonly val: {
70
+ readonly type: {
71
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
72
+ };
73
+ readonly value: "granted";
74
+ };
75
+ }];
76
+ };
77
+ readonly name: "Initialize";
78
+ readonly type: {
79
+ readonly blueId: "FtHZJzH4hqAoGxFBjsmy1svfT4BwEBB4aHpFSZycZLLa";
80
+ };
81
+ }];
82
+ };
83
+ readonly type: {
84
+ readonly blueId: "7X3LkN54Yp88JgZbppPhP6hM3Jqiqv8Z2i4kS7phXtQe";
85
+ };
86
+ };
87
+ readonly initLifecycleChannel: {
88
+ readonly event: {
89
+ readonly type: {
90
+ readonly blueId: "BrpmpNt5JkapeUvPqYcxgXZrHNZX3R757dRwuXXdfNM2";
91
+ };
92
+ };
93
+ readonly type: {
94
+ readonly blueId: "H2aCCTUcLMTJozWkn7HPUjyFBFxamraw1q8DyWk87zxr";
95
+ };
96
+ };
97
+ readonly revokeConsent: {
98
+ readonly channel: {
99
+ readonly type: {
100
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
101
+ };
102
+ readonly value: "granterChannel";
103
+ };
104
+ readonly description: "Customer revokes the consent.";
105
+ readonly request: {
106
+ readonly reason: {
107
+ readonly type: {
108
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
109
+ };
110
+ };
111
+ readonly revokedAt: {
112
+ readonly type: {
113
+ readonly blueId: "GQaGqFxHDz64L1c9QkCbz52ths6bMVtpHnw4QDngzQYs";
114
+ };
115
+ };
116
+ };
117
+ readonly type: {
118
+ readonly blueId: "BoAiqVUZv9Fum3wFqaX2JnQMBHJLxJSo2V9U2UBmCfsC";
119
+ };
120
+ };
121
+ readonly revokeConsentImpl: {
122
+ readonly operation: {
123
+ readonly type: {
124
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
125
+ };
126
+ readonly value: "revokeConsent";
127
+ };
128
+ readonly steps: {
129
+ readonly items: readonly [{
130
+ readonly code: {
131
+ readonly type: {
132
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
133
+ };
134
+ readonly value: "const request = event?.message?.request || {};\nconst reason = request.reason || \"\";\nconst revokedAt = request.revokedAt || \"\";\nconst canRevoke = document('/consentStatus') === \"granted\";\n\nreturn {\n reason,\n revokedAt,\n canRevoke,\n events: canRevoke\n ? [{ type: \"Conversation/Customer Consent Revoked\", reason, revokedAt }]\n : []\n};\n";
135
+ };
136
+ readonly name: "Capture";
137
+ readonly type: {
138
+ readonly blueId: "ExZxT61PSpWHpEAtP2WKMXXqxEYN7Z13j7Zv36Dp99kS";
139
+ };
140
+ }, {
141
+ readonly changeset: {
142
+ readonly items: readonly [{
143
+ readonly op: {
144
+ readonly type: {
145
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
146
+ };
147
+ readonly value: "replace";
148
+ };
149
+ readonly path: {
150
+ readonly type: {
151
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
152
+ };
153
+ readonly value: "/consentStatus";
154
+ };
155
+ readonly val: {
156
+ readonly type: {
157
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
158
+ };
159
+ readonly value: "revoked";
160
+ };
161
+ }, {
162
+ readonly op: {
163
+ readonly type: {
164
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
165
+ };
166
+ readonly value: "replace";
167
+ };
168
+ readonly path: {
169
+ readonly type: {
170
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
171
+ };
172
+ readonly value: "/revocationReason";
173
+ };
174
+ readonly val: {
175
+ readonly type: {
176
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
177
+ };
178
+ readonly value: "${steps['Capture'].reason}";
179
+ };
180
+ }, {
181
+ readonly op: {
182
+ readonly type: {
183
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
184
+ };
185
+ readonly value: "replace";
186
+ };
187
+ readonly path: {
188
+ readonly type: {
189
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
190
+ };
191
+ readonly value: "/revokedAt";
192
+ };
193
+ readonly val: {
194
+ readonly type: {
195
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
196
+ };
197
+ readonly value: "${steps['Capture'].revokedAt}";
198
+ };
199
+ }];
200
+ };
201
+ readonly name: "Apply";
202
+ readonly type: {
203
+ readonly blueId: "FtHZJzH4hqAoGxFBjsmy1svfT4BwEBB4aHpFSZycZLLa";
204
+ };
205
+ }];
206
+ };
207
+ readonly type: {
208
+ readonly blueId: "CGdxkNjPcsdescqLPz6SNLsMyak6demQQr7RoKNHbCyv";
209
+ };
210
+ };
211
+ };
212
+ readonly description: "Generic customer consent granted to a grantee (e.g., merchant).";
213
+ readonly grantedAt: {
214
+ readonly description: "Timestamp when consent was granted.";
215
+ readonly type: {
216
+ readonly blueId: "GQaGqFxHDz64L1c9QkCbz52ths6bMVtpHnw4QDngzQYs";
217
+ };
218
+ };
219
+ readonly name: "Customer Consent";
220
+ readonly revocationReason: {
221
+ readonly description: "Reason for revocation.";
222
+ readonly type: {
223
+ readonly blueId: "DLRQwz7MQeCrzjy9bohPNwtCxKEBbKaMK65KBrwjfG6K";
224
+ };
225
+ };
226
+ readonly revokedAt: {
227
+ readonly description: "Timestamp when consent was revoked.";
228
+ readonly type: {
229
+ readonly blueId: "GQaGqFxHDz64L1c9QkCbz52ths6bMVtpHnw4QDngzQYs";
230
+ };
231
+ };
232
+ };
233
+ //# sourceMappingURL=CustomerConsent.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CustomerConsent.d.ts","sourceRoot":"","sources":["../../../../src/packages/conversation/contents/CustomerConsent.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAuPlB,CAAC"}