@proto-kit/protocol 0.1.1-develop.164 → 0.1.1-develop.1661

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 (453) hide show
  1. package/dist/Constants.js +1 -0
  2. package/dist/Constants.js.map +1 -0
  3. package/dist/hashing/mina-prefixes.d.ts +10 -0
  4. package/dist/hashing/mina-prefixes.d.ts.map +1 -0
  5. package/dist/hashing/mina-prefixes.js +10 -0
  6. package/dist/hashing/mina-prefixes.js.map +1 -0
  7. package/dist/hashing/protokit-prefixes.d.ts +10 -0
  8. package/dist/hashing/protokit-prefixes.d.ts.map +1 -0
  9. package/dist/hashing/protokit-prefixes.js +24 -0
  10. package/dist/hashing/protokit-prefixes.js.map +1 -0
  11. package/dist/hooks/AccountStateHook.d.ts +52 -0
  12. package/dist/hooks/AccountStateHook.d.ts.map +1 -0
  13. package/dist/hooks/AccountStateHook.js +52 -0
  14. package/dist/hooks/AccountStateHook.js.map +1 -0
  15. package/dist/hooks/BlockHeightHook.d.ts +7 -0
  16. package/dist/hooks/BlockHeightHook.d.ts.map +1 -0
  17. package/dist/hooks/BlockHeightHook.js +16 -0
  18. package/dist/hooks/BlockHeightHook.js.map +1 -0
  19. package/dist/hooks/LastStateRootBlockHook.d.ts +7 -0
  20. package/dist/hooks/LastStateRootBlockHook.d.ts.map +1 -0
  21. package/dist/hooks/LastStateRootBlockHook.js +16 -0
  22. package/dist/hooks/LastStateRootBlockHook.js.map +1 -0
  23. package/dist/hooks/NoopBlockHook.d.ts +8 -0
  24. package/dist/hooks/NoopBlockHook.d.ts.map +1 -0
  25. package/dist/hooks/NoopBlockHook.js +10 -0
  26. package/dist/hooks/NoopBlockHook.js.map +1 -0
  27. package/dist/hooks/NoopSettlementHook.d.ts +6 -0
  28. package/dist/hooks/NoopSettlementHook.d.ts.map +1 -0
  29. package/dist/{prover/statetransition/StateTransitionWitnessProvider.js → hooks/NoopSettlementHook.js} +8 -7
  30. package/dist/hooks/NoopSettlementHook.js.map +1 -0
  31. package/dist/hooks/NoopTransactionHook.d.ts +6 -0
  32. package/dist/hooks/NoopTransactionHook.d.ts.map +1 -0
  33. package/dist/hooks/NoopTransactionHook.js +11 -0
  34. package/dist/hooks/NoopTransactionHook.js.map +1 -0
  35. package/dist/index.d.ts +51 -9
  36. package/dist/index.d.ts.map +1 -1
  37. package/dist/index.js +52 -9
  38. package/dist/index.js.map +1 -0
  39. package/dist/model/AppliedStateTransitionBatch.d.ts +114 -0
  40. package/dist/model/AppliedStateTransitionBatch.d.ts.map +1 -0
  41. package/dist/model/AppliedStateTransitionBatch.js +16 -0
  42. package/dist/model/AppliedStateTransitionBatch.js.map +1 -0
  43. package/dist/model/MethodPublicOutput.d.ts +83 -29
  44. package/dist/model/MethodPublicOutput.d.ts.map +1 -1
  45. package/dist/model/MethodPublicOutput.js +4 -1
  46. package/dist/model/MethodPublicOutput.js.map +1 -0
  47. package/dist/model/Option.d.ts +70 -42
  48. package/dist/model/Option.d.ts.map +1 -1
  49. package/dist/model/Option.js +62 -47
  50. package/dist/model/Option.js.map +1 -0
  51. package/dist/model/Path.d.ts +4 -3
  52. package/dist/model/Path.d.ts.map +1 -1
  53. package/dist/model/Path.js +6 -5
  54. package/dist/model/Path.js.map +1 -0
  55. package/dist/model/RuntimeLike.d.ts +11 -0
  56. package/dist/model/RuntimeLike.d.ts.map +1 -0
  57. package/dist/model/RuntimeLike.js +2 -0
  58. package/dist/model/RuntimeLike.js.map +1 -0
  59. package/dist/model/StateTransition.d.ts +67 -16
  60. package/dist/model/StateTransition.d.ts.map +1 -1
  61. package/dist/model/StateTransition.js +18 -2
  62. package/dist/model/StateTransition.js.map +1 -0
  63. package/dist/model/StateTransitionProvableBatch.d.ts +389 -16
  64. package/dist/model/StateTransitionProvableBatch.d.ts.map +1 -1
  65. package/dist/model/StateTransitionProvableBatch.js +88 -11
  66. package/dist/model/StateTransitionProvableBatch.js.map +1 -0
  67. package/dist/model/network/NetworkState.d.ts +105 -9
  68. package/dist/model/network/NetworkState.d.ts.map +1 -1
  69. package/dist/model/network/NetworkState.js +20 -2
  70. package/dist/model/network/NetworkState.js.map +1 -0
  71. package/dist/model/transaction/RuntimeTransaction.d.ts +96 -28
  72. package/dist/model/transaction/RuntimeTransaction.d.ts.map +1 -1
  73. package/dist/model/transaction/RuntimeTransaction.js +75 -11
  74. package/dist/model/transaction/RuntimeTransaction.js.map +1 -0
  75. package/dist/model/transaction/SignedTransaction.d.ts +107 -0
  76. package/dist/model/transaction/SignedTransaction.d.ts.map +1 -0
  77. package/dist/model/transaction/SignedTransaction.js +34 -0
  78. package/dist/model/transaction/SignedTransaction.js.map +1 -0
  79. package/dist/model/transaction/ValueOption.d.ts +173 -0
  80. package/dist/model/transaction/ValueOption.d.ts.map +1 -0
  81. package/dist/model/transaction/ValueOption.js +25 -0
  82. package/dist/model/transaction/ValueOption.js.map +1 -0
  83. package/dist/protocol/Protocol.d.ts +27 -25
  84. package/dist/protocol/Protocol.d.ts.map +1 -1
  85. package/dist/protocol/Protocol.js +98 -28
  86. package/dist/protocol/Protocol.js.map +1 -0
  87. package/dist/protocol/ProtocolEnvironment.d.ts +9 -0
  88. package/dist/protocol/ProtocolEnvironment.d.ts.map +1 -0
  89. package/dist/protocol/ProtocolEnvironment.js +2 -0
  90. package/dist/protocol/ProtocolEnvironment.js.map +1 -0
  91. package/dist/protocol/ProtocolModule.d.ts +7 -7
  92. package/dist/protocol/ProtocolModule.d.ts.map +1 -1
  93. package/dist/protocol/ProtocolModule.js +10 -7
  94. package/dist/protocol/ProtocolModule.js.map +1 -0
  95. package/dist/protocol/ProvableBlockHook.d.ts +19 -0
  96. package/dist/protocol/ProvableBlockHook.d.ts.map +1 -0
  97. package/dist/protocol/ProvableBlockHook.js +21 -0
  98. package/dist/protocol/ProvableBlockHook.js.map +1 -0
  99. package/dist/protocol/ProvableTransactionHook.d.ts +34 -0
  100. package/dist/protocol/ProvableTransactionHook.d.ts.map +1 -0
  101. package/dist/protocol/ProvableTransactionHook.js +13 -0
  102. package/dist/protocol/ProvableTransactionHook.js.map +1 -0
  103. package/dist/protocol/TransitioningProtocolModule.d.ts +10 -0
  104. package/dist/protocol/TransitioningProtocolModule.d.ts.map +1 -0
  105. package/dist/protocol/TransitioningProtocolModule.js +9 -0
  106. package/dist/protocol/TransitioningProtocolModule.js.map +1 -0
  107. package/dist/prover/accumulators/AppliedBatchHashList.d.ts +18 -0
  108. package/dist/prover/accumulators/AppliedBatchHashList.d.ts.map +1 -0
  109. package/dist/prover/accumulators/AppliedBatchHashList.js +25 -0
  110. package/dist/prover/accumulators/AppliedBatchHashList.js.map +1 -0
  111. package/dist/prover/accumulators/StateTransitionReductionList.d.ts +12 -0
  112. package/dist/prover/accumulators/StateTransitionReductionList.d.ts.map +1 -0
  113. package/dist/prover/accumulators/StateTransitionReductionList.js +64 -0
  114. package/dist/prover/accumulators/StateTransitionReductionList.js.map +1 -0
  115. package/dist/prover/accumulators/TransactionHashList.d.ts +6 -0
  116. package/dist/prover/accumulators/TransactionHashList.d.ts.map +1 -0
  117. package/dist/prover/accumulators/TransactionHashList.js +8 -0
  118. package/dist/prover/accumulators/TransactionHashList.js.map +1 -0
  119. package/dist/prover/accumulators/WitnessedRootHashList.d.ts +137 -0
  120. package/dist/prover/accumulators/WitnessedRootHashList.d.ts.map +1 -0
  121. package/dist/prover/accumulators/WitnessedRootHashList.js +50 -0
  122. package/dist/prover/accumulators/WitnessedRootHashList.js.map +1 -0
  123. package/dist/prover/block/BlockProvable.d.ts +869 -65
  124. package/dist/prover/block/BlockProvable.d.ts.map +1 -1
  125. package/dist/prover/block/BlockProvable.js +86 -6
  126. package/dist/prover/block/BlockProvable.js.map +1 -0
  127. package/dist/prover/block/BlockProver.d.ts +82 -34
  128. package/dist/prover/block/BlockProver.d.ts.map +1 -1
  129. package/dist/prover/block/BlockProver.js +505 -86
  130. package/dist/prover/block/BlockProver.js.map +1 -0
  131. package/dist/prover/block/accummulators/BlockHashMerkleTree.d.ts +106 -0
  132. package/dist/prover/block/accummulators/BlockHashMerkleTree.d.ts.map +1 -0
  133. package/dist/prover/block/accummulators/BlockHashMerkleTree.js +25 -0
  134. package/dist/prover/block/accummulators/BlockHashMerkleTree.js.map +1 -0
  135. package/dist/prover/block/accummulators/RuntimeVerificationKeyTree.d.ts +139 -0
  136. package/dist/prover/block/accummulators/RuntimeVerificationKeyTree.d.ts.map +1 -0
  137. package/dist/prover/block/accummulators/RuntimeVerificationKeyTree.js +21 -0
  138. package/dist/prover/block/accummulators/RuntimeVerificationKeyTree.js.map +1 -0
  139. package/dist/prover/block/services/RuntimeVerificationKeyRootService.d.ts +7 -0
  140. package/dist/prover/block/services/RuntimeVerificationKeyRootService.d.ts.map +1 -0
  141. package/dist/prover/{statetransition/StateTransitionWitnessProviderReference.js → block/services/RuntimeVerificationKeyRootService.js} +11 -8
  142. package/dist/prover/block/services/RuntimeVerificationKeyRootService.js.map +1 -0
  143. package/dist/prover/statetransition/StateTransitionProvable.d.ts +137 -48
  144. package/dist/prover/statetransition/StateTransitionProvable.d.ts.map +1 -1
  145. package/dist/prover/statetransition/StateTransitionProvable.js +10 -5
  146. package/dist/prover/statetransition/StateTransitionProvable.js.map +1 -0
  147. package/dist/prover/statetransition/StateTransitionProver.d.ts +30 -17
  148. package/dist/prover/statetransition/StateTransitionProver.d.ts.map +1 -1
  149. package/dist/prover/statetransition/StateTransitionProver.js +169 -74
  150. package/dist/prover/statetransition/StateTransitionProver.js.map +1 -0
  151. package/dist/settlement/ContractModule.d.ts +16 -0
  152. package/dist/settlement/ContractModule.d.ts.map +1 -0
  153. package/dist/settlement/ContractModule.js +12 -0
  154. package/dist/settlement/ContractModule.js.map +1 -0
  155. package/dist/settlement/SettlementContractModule.d.ts +51 -0
  156. package/dist/settlement/SettlementContractModule.d.ts.map +1 -0
  157. package/dist/settlement/SettlementContractModule.js +80 -0
  158. package/dist/settlement/SettlementContractModule.js.map +1 -0
  159. package/dist/settlement/contracts/BridgeContract.d.ts +116 -0
  160. package/dist/settlement/contracts/BridgeContract.d.ts.map +1 -0
  161. package/dist/settlement/contracts/BridgeContract.js +259 -0
  162. package/dist/settlement/contracts/BridgeContract.js.map +1 -0
  163. package/dist/settlement/contracts/BridgeContractProtocolModule.d.ts +16 -0
  164. package/dist/settlement/contracts/BridgeContractProtocolModule.d.ts.map +1 -0
  165. package/dist/settlement/contracts/BridgeContractProtocolModule.js +41 -0
  166. package/dist/settlement/contracts/BridgeContractProtocolModule.js.map +1 -0
  167. package/dist/settlement/contracts/DispatchContractProtocolModule.d.ts +21 -0
  168. package/dist/settlement/contracts/DispatchContractProtocolModule.d.ts.map +1 -0
  169. package/dist/settlement/contracts/DispatchContractProtocolModule.js +57 -0
  170. package/dist/settlement/contracts/DispatchContractProtocolModule.js.map +1 -0
  171. package/dist/settlement/contracts/DispatchSmartContract.d.ts +44 -0
  172. package/dist/settlement/contracts/DispatchSmartContract.d.ts.map +1 -0
  173. package/dist/settlement/contracts/DispatchSmartContract.js +229 -0
  174. package/dist/settlement/contracts/DispatchSmartContract.js.map +1 -0
  175. package/dist/settlement/contracts/SettlementContractProtocolModule.d.ts +21 -0
  176. package/dist/settlement/contracts/SettlementContractProtocolModule.d.ts.map +1 -0
  177. package/dist/settlement/contracts/SettlementContractProtocolModule.js +84 -0
  178. package/dist/settlement/contracts/SettlementContractProtocolModule.js.map +1 -0
  179. package/dist/settlement/contracts/SettlementSmartContract.d.ts +123 -0
  180. package/dist/settlement/contracts/SettlementSmartContract.d.ts.map +1 -0
  181. package/dist/settlement/contracts/SettlementSmartContract.js +310 -0
  182. package/dist/settlement/contracts/SettlementSmartContract.js.map +1 -0
  183. package/dist/settlement/contracts/TokenBridgeTree.d.ts +228 -0
  184. package/dist/settlement/contracts/TokenBridgeTree.d.ts.map +1 -0
  185. package/dist/settlement/contracts/TokenBridgeTree.js +60 -0
  186. package/dist/settlement/contracts/TokenBridgeTree.js.map +1 -0
  187. package/dist/settlement/contracts/authorizations/ContractAuthorization.d.ts +10 -0
  188. package/dist/settlement/contracts/authorizations/ContractAuthorization.d.ts.map +1 -0
  189. package/dist/settlement/contracts/authorizations/ContractAuthorization.js +2 -0
  190. package/dist/settlement/contracts/authorizations/ContractAuthorization.js.map +1 -0
  191. package/dist/settlement/contracts/authorizations/TokenBridgeDeploymentAuth.d.ts +85 -0
  192. package/dist/settlement/contracts/authorizations/TokenBridgeDeploymentAuth.d.ts.map +1 -0
  193. package/dist/settlement/contracts/authorizations/TokenBridgeDeploymentAuth.js +11 -0
  194. package/dist/settlement/contracts/authorizations/TokenBridgeDeploymentAuth.js.map +1 -0
  195. package/dist/settlement/contracts/authorizations/UpdateMessagesHashAuth.d.ts +79 -0
  196. package/dist/settlement/contracts/authorizations/UpdateMessagesHashAuth.d.ts.map +1 -0
  197. package/dist/settlement/contracts/authorizations/UpdateMessagesHashAuth.js +11 -0
  198. package/dist/settlement/contracts/authorizations/UpdateMessagesHashAuth.js.map +1 -0
  199. package/dist/settlement/messages/Deposit.d.ts +77 -0
  200. package/dist/settlement/messages/Deposit.d.ts.map +1 -0
  201. package/dist/settlement/messages/Deposit.js +8 -0
  202. package/dist/settlement/messages/Deposit.js.map +1 -0
  203. package/dist/settlement/messages/OutgoingMessage.d.ts +67 -0
  204. package/dist/settlement/messages/OutgoingMessage.d.ts.map +1 -0
  205. package/dist/settlement/messages/OutgoingMessage.js +7 -0
  206. package/dist/settlement/messages/OutgoingMessage.js.map +1 -0
  207. package/dist/settlement/messages/OutgoingMessageArgument.d.ts +462 -0
  208. package/dist/settlement/messages/OutgoingMessageArgument.d.ts.map +1 -0
  209. package/dist/settlement/messages/OutgoingMessageArgument.js +40 -0
  210. package/dist/settlement/messages/OutgoingMessageArgument.js.map +1 -0
  211. package/dist/settlement/messages/Withdrawal.d.ts +2 -0
  212. package/dist/settlement/messages/Withdrawal.d.ts.map +1 -0
  213. package/dist/settlement/messages/Withdrawal.js +3 -0
  214. package/dist/settlement/messages/Withdrawal.js.map +1 -0
  215. package/dist/settlement/modularity/OutgoingMessageProcessor.d.ts +25 -0
  216. package/dist/settlement/modularity/OutgoingMessageProcessor.d.ts.map +1 -0
  217. package/dist/settlement/modularity/OutgoingMessageProcessor.js +30 -0
  218. package/dist/settlement/modularity/OutgoingMessageProcessor.js.map +1 -0
  219. package/dist/settlement/modularity/ProvableSettlementHook.d.ts +26 -0
  220. package/dist/settlement/modularity/ProvableSettlementHook.d.ts.map +1 -0
  221. package/dist/settlement/modularity/ProvableSettlementHook.js +4 -0
  222. package/dist/settlement/modularity/ProvableSettlementHook.js.map +1 -0
  223. package/dist/settlement/modularity/types.d.ts +8 -0
  224. package/dist/settlement/modularity/types.d.ts.map +1 -0
  225. package/dist/settlement/modularity/types.js +2 -0
  226. package/dist/settlement/modularity/types.js.map +1 -0
  227. package/dist/settlement/modules/NetworkStateSettlementModule.d.ts +11 -0
  228. package/dist/settlement/modules/NetworkStateSettlementModule.d.ts.map +1 -0
  229. package/dist/settlement/modules/NetworkStateSettlementModule.js +15 -0
  230. package/dist/settlement/modules/NetworkStateSettlementModule.js.map +1 -0
  231. package/dist/state/SimpleAsyncStateService.d.ts +6 -0
  232. package/dist/state/SimpleAsyncStateService.d.ts.map +1 -0
  233. package/dist/state/SimpleAsyncStateService.js +2 -0
  234. package/dist/state/SimpleAsyncStateService.js.map +1 -0
  235. package/dist/state/State.d.ts +68 -0
  236. package/dist/state/State.d.ts.map +1 -0
  237. package/dist/state/State.js +131 -0
  238. package/dist/state/State.js.map +1 -0
  239. package/dist/state/StateMap.d.ts +37 -0
  240. package/dist/state/StateMap.d.ts.map +1 -0
  241. package/dist/state/StateMap.js +56 -0
  242. package/dist/state/StateMap.js.map +1 -0
  243. package/dist/state/StateService.d.ts +6 -0
  244. package/dist/state/StateService.d.ts.map +1 -0
  245. package/dist/state/StateService.js +2 -0
  246. package/dist/state/StateService.js.map +1 -0
  247. package/dist/state/StateServiceProvider.d.ts +8 -0
  248. package/dist/state/StateServiceProvider.d.ts.map +1 -0
  249. package/dist/state/StateServiceProvider.js +37 -0
  250. package/dist/state/StateServiceProvider.js.map +1 -0
  251. package/dist/state/assert/assert.d.ts +12 -0
  252. package/dist/state/assert/assert.d.ts.map +1 -0
  253. package/dist/state/assert/assert.js +33 -0
  254. package/dist/state/assert/assert.js.map +1 -0
  255. package/dist/state/context/RuntimeMethodExecutionContext.d.ts +193 -0
  256. package/dist/state/context/RuntimeMethodExecutionContext.d.ts.map +1 -0
  257. package/dist/state/context/RuntimeMethodExecutionContext.js +138 -0
  258. package/dist/state/context/RuntimeMethodExecutionContext.js.map +1 -0
  259. package/dist/state/context/TransitionMethodExecutionContext.d.ts +23 -0
  260. package/dist/state/context/TransitionMethodExecutionContext.d.ts.map +1 -0
  261. package/dist/state/context/TransitionMethodExecutionContext.js +6 -0
  262. package/dist/state/context/TransitionMethodExecutionContext.js.map +1 -0
  263. package/dist/state/protocol/ProtocolState.d.ts +13 -0
  264. package/dist/state/protocol/ProtocolState.d.ts.map +1 -0
  265. package/dist/state/protocol/ProtocolState.js +58 -0
  266. package/dist/state/protocol/ProtocolState.js.map +1 -0
  267. package/dist/utils/FieldOptions.d.ts +62 -0
  268. package/dist/utils/FieldOptions.d.ts.map +1 -0
  269. package/dist/utils/FieldOptions.js +13 -0
  270. package/dist/utils/FieldOptions.js.map +1 -0
  271. package/dist/utils/MinaPrefixedProvableHashList.d.ts +19 -0
  272. package/dist/utils/MinaPrefixedProvableHashList.d.ts.map +1 -0
  273. package/dist/utils/MinaPrefixedProvableHashList.js +46 -0
  274. package/dist/utils/MinaPrefixedProvableHashList.js.map +1 -0
  275. package/dist/utils/PrefixedProvableHashList.d.ts +2 -2
  276. package/dist/utils/PrefixedProvableHashList.d.ts.map +1 -1
  277. package/dist/utils/PrefixedProvableHashList.js +2 -1
  278. package/dist/utils/PrefixedProvableHashList.js.map +1 -0
  279. package/dist/utils/ProvableHashList.d.ts +23 -4
  280. package/dist/utils/ProvableHashList.d.ts.map +1 -1
  281. package/dist/utils/ProvableHashList.js +38 -2
  282. package/dist/utils/ProvableHashList.js.map +1 -0
  283. package/dist/utils/ProvableReductionHashList.d.ts +18 -0
  284. package/dist/utils/ProvableReductionHashList.d.ts.map +1 -0
  285. package/dist/utils/ProvableReductionHashList.js +54 -0
  286. package/dist/utils/ProvableReductionHashList.js.map +1 -0
  287. package/dist/utils/StateTransitionReductionList.d.ts +11 -0
  288. package/dist/utils/StateTransitionReductionList.d.ts.map +1 -0
  289. package/dist/utils/StateTransitionReductionList.js +61 -0
  290. package/dist/utils/StateTransitionReductionList.js.map +1 -0
  291. package/dist/utils/utils.d.ts +20 -0
  292. package/dist/utils/utils.d.ts.map +1 -0
  293. package/dist/utils/utils.js +51 -0
  294. package/dist/utils/utils.js.map +1 -0
  295. package/jest.config.cjs +12 -1
  296. package/package.json +10 -9
  297. package/src/hashing/mina-prefixes.ts +10 -0
  298. package/src/hashing/protokit-prefixes.ts +37 -0
  299. package/src/hooks/AccountStateHook.ts +57 -0
  300. package/src/hooks/BlockHeightHook.ts +17 -0
  301. package/src/hooks/LastStateRootBlockHook.ts +25 -0
  302. package/src/hooks/NoopBlockHook.ts +24 -0
  303. package/src/hooks/NoopSettlementHook.ts +20 -0
  304. package/src/hooks/NoopTransactionHook.ts +13 -0
  305. package/src/index.ts +51 -9
  306. package/src/model/AppliedStateTransitionBatch.ts +16 -0
  307. package/src/model/MethodPublicOutput.ts +3 -1
  308. package/src/model/Option.ts +99 -60
  309. package/src/model/Path.ts +9 -5
  310. package/src/model/RuntimeLike.ts +12 -0
  311. package/src/model/StateTransition.ts +25 -3
  312. package/src/model/StateTransitionProvableBatch.ts +117 -14
  313. package/src/model/Transaction.ts +3 -1
  314. package/src/model/network/NetworkState.ts +21 -3
  315. package/src/model/transaction/RuntimeTransaction.ts +90 -15
  316. package/src/model/transaction/SignedTransaction.ts +47 -0
  317. package/src/model/transaction/ValueOption.ts +28 -0
  318. package/src/protocol/Protocol.ts +166 -74
  319. package/src/protocol/ProtocolEnvironment.ts +10 -0
  320. package/src/protocol/ProtocolModule.ts +16 -16
  321. package/src/protocol/ProvableBlockHook.ts +68 -0
  322. package/src/protocol/ProvableTransactionHook.ts +77 -0
  323. package/src/protocol/TransitioningProtocolModule.ts +12 -0
  324. package/src/prover/accumulators/AppliedBatchHashList.ts +32 -0
  325. package/src/prover/accumulators/StateTransitionReductionList.ts +92 -0
  326. package/src/prover/accumulators/TransactionHashList.ts +9 -0
  327. package/src/prover/accumulators/WitnessedRootHashList.ts +61 -0
  328. package/src/prover/block/BlockProvable.ts +188 -15
  329. package/src/prover/block/BlockProver.ts +979 -143
  330. package/src/prover/block/accummulators/BlockHashMerkleTree.ts +24 -0
  331. package/src/prover/block/accummulators/RuntimeVerificationKeyTree.ts +24 -0
  332. package/src/prover/block/services/RuntimeVerificationKeyRootService.ts +20 -0
  333. package/src/prover/statetransition/StateTransitionProvable.ts +26 -19
  334. package/src/prover/statetransition/StateTransitionProver.ts +338 -130
  335. package/src/settlement/ContractModule.ts +31 -0
  336. package/src/settlement/SettlementContractModule.ts +145 -0
  337. package/src/settlement/contracts/BridgeContract.ts +366 -0
  338. package/src/settlement/contracts/BridgeContractProtocolModule.ts +48 -0
  339. package/src/settlement/contracts/DispatchContractProtocolModule.ts +75 -0
  340. package/src/settlement/contracts/DispatchSmartContract.ts +325 -0
  341. package/src/settlement/contracts/SettlementContractProtocolModule.ts +113 -0
  342. package/src/settlement/contracts/SettlementSmartContract.ts +502 -0
  343. package/src/settlement/contracts/TokenBridgeTree.ts +73 -0
  344. package/src/settlement/contracts/authorizations/ContractAuthorization.ts +11 -0
  345. package/src/settlement/contracts/authorizations/TokenBridgeDeploymentAuth.ts +16 -0
  346. package/src/settlement/contracts/authorizations/UpdateMessagesHashAuth.ts +16 -0
  347. package/src/settlement/messages/Deposit.ts +7 -0
  348. package/src/settlement/messages/OutgoingMessage.ts +17 -0
  349. package/src/settlement/messages/OutgoingMessageArgument.ts +53 -0
  350. package/src/settlement/modularity/OutgoingMessageProcessor.ts +65 -0
  351. package/src/settlement/modularity/ProvableSettlementHook.ts +36 -0
  352. package/src/settlement/modularity/types.ts +22 -0
  353. package/src/settlement/modules/NetworkStateSettlementModule.ts +42 -0
  354. package/src/state/State.ts +177 -0
  355. package/src/state/StateMap.ts +73 -0
  356. package/src/state/StateService.ts +6 -0
  357. package/src/state/StateServiceProvider.ts +37 -0
  358. package/src/state/assert/assert.ts +38 -0
  359. package/src/state/context/RuntimeMethodExecutionContext.ts +181 -0
  360. package/src/state/context/TransitionMethodExecutionContext.ts +26 -0
  361. package/src/state/protocol/ProtocolState.ts +98 -0
  362. package/src/utils/FieldOptions.ts +13 -0
  363. package/src/utils/MinaPrefixedProvableHashList.ts +66 -0
  364. package/src/utils/PrefixedProvableHashList.ts +2 -2
  365. package/src/utils/ProvableHashList.ts +78 -3
  366. package/src/utils/ProvableReductionHashList.ts +77 -0
  367. package/src/utils/utils.ts +44 -55
  368. package/test/BlockProver.test.ts +161 -74
  369. package/test/Protocol.test.ts +20 -10
  370. package/test/State.test.ts +45 -0
  371. package/test/StateTransition.test.ts +57 -65
  372. package/test/TestingProtocol.ts +56 -0
  373. package/test/compiling/types.ts +28 -0
  374. package/test/model/Option.test.ts +72 -0
  375. package/test/model/StateTransitionProvableBatch.test.ts +137 -0
  376. package/test/modularity/types.ts +35 -0
  377. package/test/prover/block/BlockProver.test.ts +18 -0
  378. package/test/prover/statetransition/StateTransitionProver.test.ts +261 -0
  379. package/test/state/assert/assert.test.ts +56 -0
  380. package/test/tsconfig.json +7 -0
  381. package/test/utils/ProvableHashList.test.ts +44 -0
  382. package/test/utils/ProvableReductionHashList.test.ts +117 -0
  383. package/test/utils.test.ts +27 -0
  384. package/dist/config/ConfigurableModule.d.ts +0 -18
  385. package/dist/config/ConfigurableModule.d.ts.map +0 -1
  386. package/dist/config/ConfigurableModule.js +0 -20
  387. package/dist/config/ConfigurationAggregator.d.ts +0 -10
  388. package/dist/config/ConfigurationAggregator.d.ts.map +0 -1
  389. package/dist/config/ConfigurationAggregator.js +0 -35
  390. package/dist/config/ConfigurationReceiver.d.ts +0 -25
  391. package/dist/config/ConfigurationReceiver.d.ts.map +0 -1
  392. package/dist/config/ConfigurationReceiver.js +0 -36
  393. package/dist/config/ModuleContainer.d.ts +0 -44
  394. package/dist/config/ModuleContainer.d.ts.map +0 -1
  395. package/dist/config/ModuleContainer.js +0 -89
  396. package/dist/config/types.d.ts +0 -2
  397. package/dist/config/types.d.ts.map +0 -1
  398. package/dist/config/types.js +0 -1
  399. package/dist/model/MethodPublicInput.d.ts +0 -51
  400. package/dist/model/MethodPublicInput.d.ts.map +0 -1
  401. package/dist/model/MethodPublicInput.js +0 -11
  402. package/dist/model/transaction/ProtocolTransaction.d.ts +0 -70
  403. package/dist/model/transaction/ProtocolTransaction.d.ts.map +0 -1
  404. package/dist/model/transaction/ProtocolTransaction.js +0 -18
  405. package/dist/prover/block/BlockScopedModule.d.ts +0 -3
  406. package/dist/prover/block/BlockScopedModule.d.ts.map +0 -1
  407. package/dist/prover/block/BlockScopedModule.js +0 -6
  408. package/dist/prover/statetransition/StateTransitionWitnessProvider.d.ts +0 -16
  409. package/dist/prover/statetransition/StateTransitionWitnessProvider.d.ts.map +0 -1
  410. package/dist/prover/statetransition/StateTransitionWitnessProviderReference.d.ts +0 -7
  411. package/dist/prover/statetransition/StateTransitionWitnessProviderReference.d.ts.map +0 -1
  412. package/dist/src/model/Option.d.ts +0 -158
  413. package/dist/src/model/Option.d.ts.map +0 -1
  414. package/dist/src/model/Option.js +0 -53
  415. package/dist/src/model/Path.d.ts +0 -35
  416. package/dist/src/model/Path.d.ts.map +0 -1
  417. package/dist/src/model/Path.js +0 -51
  418. package/dist/src/model/StateTransition.d.ts +0 -201
  419. package/dist/src/model/StateTransition.d.ts.map +0 -1
  420. package/dist/src/model/StateTransition.js +0 -43
  421. package/dist/src/utils/PrefixedHashList.d.ts +0 -15
  422. package/dist/src/utils/PrefixedHashList.d.ts.map +0 -1
  423. package/dist/src/utils/PrefixedHashList.js +0 -28
  424. package/dist/src/utils/ProvableHashList.d.ts +0 -30
  425. package/dist/src/utils/ProvableHashList.d.ts.map +0 -1
  426. package/dist/src/utils/ProvableHashList.js +0 -43
  427. package/dist/utils/PrefixedHashList.d.ts +0 -14
  428. package/dist/utils/PrefixedHashList.d.ts.map +0 -1
  429. package/dist/utils/PrefixedHashList.js +0 -12
  430. package/dist/utils/Utils.d.ts +0 -17
  431. package/dist/utils/Utils.d.ts.map +0 -1
  432. package/dist/utils/Utils.js +0 -64
  433. package/dist/utils/merkletree/InMemoryMerkleTreeStorage.d.ts +0 -25
  434. package/dist/utils/merkletree/InMemoryMerkleTreeStorage.d.ts.map +0 -1
  435. package/dist/utils/merkletree/InMemoryMerkleTreeStorage.js +0 -77
  436. package/dist/utils/merkletree/MemoryMerkleTreeStorage.d.ts +0 -26
  437. package/dist/utils/merkletree/MemoryMerkleTreeStorage.d.ts.map +0 -1
  438. package/dist/utils/merkletree/MemoryMerkleTreeStorage.js +0 -79
  439. package/dist/utils/merkletree/MerkleTreeStore.d.ts +0 -11
  440. package/dist/utils/merkletree/MerkleTreeStore.d.ts.map +0 -1
  441. package/dist/utils/merkletree/MerkleTreeStore.js +0 -1
  442. package/dist/utils/merkletree/RollupMerkleTree.d.ts +0 -130
  443. package/dist/utils/merkletree/RollupMerkleTree.d.ts.map +0 -1
  444. package/dist/utils/merkletree/RollupMerkleTree.js +0 -244
  445. package/src/model/Option.test.ts +0 -21
  446. package/src/model/transaction/ProtocolTransaction.ts +0 -25
  447. package/src/prover/statetransition/StateTransitionWitnessProvider.ts +0 -24
  448. package/src/prover/statetransition/StateTransitionWitnessProviderReference.ts +0 -17
  449. package/src/utils/merkletree/InMemoryMerkleTreeStorage.ts +0 -106
  450. package/src/utils/merkletree/MerkleTreeStore.ts +0 -15
  451. package/src/utils/merkletree/RollupMerkleTree.ts +0 -250
  452. package/src/utils/merkletree/VirtualMerkleTreeStore.ts +0 -21
  453. package/tsconfig.test.json +0 -9
@@ -0,0 +1,462 @@
1
+ import { FlexibleProvablePure } from "o1js";
2
+ import { LinkedMerkleTreeReadWitness } from "@proto-kit/common";
3
+ export declare const OUTGOING_MESSAGE_BATCH_SIZE = 1;
4
+ export declare function createMessageStruct<T>(type: FlexibleProvablePure<T>): {
5
+ new (value: {
6
+ value: T | (Omit<import("o1js/dist/node/lib/provable/types/provable-intf").Provable<import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>, any>, "fromFields"> & {
7
+ fromFields: (fields: import("o1js/dist/node/lib/provable/field").Field[]) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
8
+ } & {
9
+ toInput: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => {
10
+ fields?: import("o1js/dist/node/lib/provable/field").Field[] | undefined;
11
+ packed?: [import("o1js/dist/node/lib/provable/field").Field, number][] | undefined;
12
+ };
13
+ toJSON: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => any;
14
+ fromJSON: (x: any) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
15
+ empty: () => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
16
+ } & (new (...args: any) => T) & {
17
+ _isStruct: true;
18
+ } extends import("o1js/dist/node/bindings/lib/generic").GenericProvable<T, any, import("o1js/dist/node/lib/provable/field").Field> ? T : T);
19
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
20
+ }): {
21
+ value: T | (Omit<import("o1js/dist/node/lib/provable/types/provable-intf").Provable<import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>, any>, "fromFields"> & {
22
+ fromFields: (fields: import("o1js/dist/node/lib/provable/field").Field[]) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
23
+ } & {
24
+ toInput: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => {
25
+ fields?: import("o1js/dist/node/lib/provable/field").Field[] | undefined;
26
+ packed?: [import("o1js/dist/node/lib/provable/field").Field, number][] | undefined;
27
+ };
28
+ toJSON: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => any;
29
+ fromJSON: (x: any) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
30
+ empty: () => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
31
+ } & (new (...args: any) => T) & {
32
+ _isStruct: true;
33
+ } extends import("o1js/dist/node/bindings/lib/generic").GenericProvable<T, any, import("o1js/dist/node/lib/provable/field").Field> ? T : T);
34
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
35
+ };
36
+ _isStruct: true;
37
+ toFields: (value: {
38
+ value: T | (Omit<import("o1js/dist/node/lib/provable/types/provable-intf").Provable<import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>, any>, "fromFields"> & {
39
+ fromFields: (fields: import("o1js/dist/node/lib/provable/field").Field[]) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
40
+ } & {
41
+ toInput: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => {
42
+ fields?: import("o1js/dist/node/lib/provable/field").Field[] | undefined;
43
+ packed?: [import("o1js/dist/node/lib/provable/field").Field, number][] | undefined;
44
+ };
45
+ toJSON: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => any;
46
+ fromJSON: (x: any) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
47
+ empty: () => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
48
+ } & (new (...args: any) => T) & {
49
+ _isStruct: true;
50
+ } extends import("o1js/dist/node/bindings/lib/generic").GenericProvable<T, any, import("o1js/dist/node/lib/provable/field").Field> ? T : T);
51
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
52
+ }) => import("o1js/dist/node/lib/provable/field").Field[];
53
+ toAuxiliary: (value?: {
54
+ value: T | (Omit<import("o1js/dist/node/lib/provable/types/provable-intf").Provable<import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>, any>, "fromFields"> & {
55
+ fromFields: (fields: import("o1js/dist/node/lib/provable/field").Field[]) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
56
+ } & {
57
+ toInput: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => {
58
+ fields?: import("o1js/dist/node/lib/provable/field").Field[] | undefined;
59
+ packed?: [import("o1js/dist/node/lib/provable/field").Field, number][] | undefined;
60
+ };
61
+ toJSON: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => any;
62
+ fromJSON: (x: any) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
63
+ empty: () => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
64
+ } & (new (...args: any) => T) & {
65
+ _isStruct: true;
66
+ } extends import("o1js/dist/node/bindings/lib/generic").GenericProvable<T, any, import("o1js/dist/node/lib/provable/field").Field> ? T : T);
67
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
68
+ } | undefined) => any[];
69
+ sizeInFields: () => number;
70
+ check: (value: {
71
+ value: T | (Omit<import("o1js/dist/node/lib/provable/types/provable-intf").Provable<import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>, any>, "fromFields"> & {
72
+ fromFields: (fields: import("o1js/dist/node/lib/provable/field").Field[]) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
73
+ } & {
74
+ toInput: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => {
75
+ fields?: import("o1js/dist/node/lib/provable/field").Field[] | undefined;
76
+ packed?: [import("o1js/dist/node/lib/provable/field").Field, number][] | undefined;
77
+ };
78
+ toJSON: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => any;
79
+ fromJSON: (x: any) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
80
+ empty: () => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
81
+ } & (new (...args: any) => T) & {
82
+ _isStruct: true;
83
+ } extends import("o1js/dist/node/bindings/lib/generic").GenericProvable<T, any, import("o1js/dist/node/lib/provable/field").Field> ? T : T);
84
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
85
+ }) => void;
86
+ toValue: (x: {
87
+ value: T | (Omit<import("o1js/dist/node/lib/provable/types/provable-intf").Provable<import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>, any>, "fromFields"> & {
88
+ fromFields: (fields: import("o1js/dist/node/lib/provable/field").Field[]) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
89
+ } & {
90
+ toInput: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => {
91
+ fields?: import("o1js/dist/node/lib/provable/field").Field[] | undefined;
92
+ packed?: [import("o1js/dist/node/lib/provable/field").Field, number][] | undefined;
93
+ };
94
+ toJSON: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => any;
95
+ fromJSON: (x: any) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
96
+ empty: () => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
97
+ } & (new (...args: any) => T) & {
98
+ _isStruct: true;
99
+ } extends import("o1js/dist/node/bindings/lib/generic").GenericProvable<T, any, import("o1js/dist/node/lib/provable/field").Field> ? T : T);
100
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
101
+ }) => {
102
+ value: any;
103
+ messageType: bigint;
104
+ };
105
+ fromValue: ((x: {
106
+ value: T | (Omit<import("o1js/dist/node/lib/provable/types/provable-intf").Provable<import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>, any>, "fromFields"> & {
107
+ fromFields: (fields: import("o1js/dist/node/lib/provable/field").Field[]) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
108
+ } & {
109
+ toInput: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => {
110
+ fields?: import("o1js/dist/node/lib/provable/field").Field[] | undefined;
111
+ packed?: [import("o1js/dist/node/lib/provable/field").Field, number][] | undefined;
112
+ };
113
+ toJSON: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => any;
114
+ fromJSON: (x: any) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
115
+ empty: () => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
116
+ } & (new (...args: any) => T) & {
117
+ _isStruct: true;
118
+ } extends import("o1js/dist/node/bindings/lib/generic").GenericProvable<T, any, import("o1js/dist/node/lib/provable/field").Field> ? T : T);
119
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
120
+ } | {
121
+ value: any;
122
+ messageType: bigint;
123
+ }) => {
124
+ value: T | (Omit<import("o1js/dist/node/lib/provable/types/provable-intf").Provable<import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>, any>, "fromFields"> & {
125
+ fromFields: (fields: import("o1js/dist/node/lib/provable/field").Field[]) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
126
+ } & {
127
+ toInput: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => {
128
+ fields?: import("o1js/dist/node/lib/provable/field").Field[] | undefined;
129
+ packed?: [import("o1js/dist/node/lib/provable/field").Field, number][] | undefined;
130
+ };
131
+ toJSON: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => any;
132
+ fromJSON: (x: any) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
133
+ empty: () => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
134
+ } & (new (...args: any) => T) & {
135
+ _isStruct: true;
136
+ } extends import("o1js/dist/node/bindings/lib/generic").GenericProvable<T, any, import("o1js/dist/node/lib/provable/field").Field> ? T : T);
137
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
138
+ }) & ((value: {
139
+ value: any;
140
+ messageType: string | number | bigint | import("o1js/dist/node/lib/provable/field").Field;
141
+ }) => {
142
+ value: T | (Omit<import("o1js/dist/node/lib/provable/types/provable-intf").Provable<import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>, any>, "fromFields"> & {
143
+ fromFields: (fields: import("o1js/dist/node/lib/provable/field").Field[]) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
144
+ } & {
145
+ toInput: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => {
146
+ fields?: import("o1js/dist/node/lib/provable/field").Field[] | undefined;
147
+ packed?: [import("o1js/dist/node/lib/provable/field").Field, number][] | undefined;
148
+ };
149
+ toJSON: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => any;
150
+ fromJSON: (x: any) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
151
+ empty: () => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
152
+ } & (new (...args: any) => T) & {
153
+ _isStruct: true;
154
+ } extends import("o1js/dist/node/bindings/lib/generic").GenericProvable<T, any, import("o1js/dist/node/lib/provable/field").Field> ? T : T);
155
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
156
+ });
157
+ fromFields: (fields: import("o1js/dist/node/lib/provable/field").Field[]) => {
158
+ value: T | (Omit<import("o1js/dist/node/lib/provable/types/provable-intf").Provable<import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>, any>, "fromFields"> & {
159
+ fromFields: (fields: import("o1js/dist/node/lib/provable/field").Field[]) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
160
+ } & {
161
+ toInput: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => {
162
+ fields?: import("o1js/dist/node/lib/provable/field").Field[] | undefined;
163
+ packed?: [import("o1js/dist/node/lib/provable/field").Field, number][] | undefined;
164
+ };
165
+ toJSON: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => any;
166
+ fromJSON: (x: any) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
167
+ empty: () => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
168
+ } & (new (...args: any) => T) & {
169
+ _isStruct: true;
170
+ } extends import("o1js/dist/node/bindings/lib/generic").GenericProvable<T, any, import("o1js/dist/node/lib/provable/field").Field> ? T : T);
171
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
172
+ };
173
+ toInput: (x: {
174
+ value: T | (Omit<import("o1js/dist/node/lib/provable/types/provable-intf").Provable<import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>, any>, "fromFields"> & {
175
+ fromFields: (fields: import("o1js/dist/node/lib/provable/field").Field[]) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
176
+ } & {
177
+ toInput: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => {
178
+ fields?: import("o1js/dist/node/lib/provable/field").Field[] | undefined;
179
+ packed?: [import("o1js/dist/node/lib/provable/field").Field, number][] | undefined;
180
+ };
181
+ toJSON: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => any;
182
+ fromJSON: (x: any) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
183
+ empty: () => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
184
+ } & (new (...args: any) => T) & {
185
+ _isStruct: true;
186
+ } extends import("o1js/dist/node/bindings/lib/generic").GenericProvable<T, any, import("o1js/dist/node/lib/provable/field").Field> ? T : T);
187
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
188
+ }) => {
189
+ fields?: import("o1js/dist/node/lib/provable/field").Field[] | undefined;
190
+ packed?: [import("o1js/dist/node/lib/provable/field").Field, number][] | undefined;
191
+ };
192
+ toJSON: (x: {
193
+ value: T | (Omit<import("o1js/dist/node/lib/provable/types/provable-intf").Provable<import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>, any>, "fromFields"> & {
194
+ fromFields: (fields: import("o1js/dist/node/lib/provable/field").Field[]) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
195
+ } & {
196
+ toInput: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => {
197
+ fields?: import("o1js/dist/node/lib/provable/field").Field[] | undefined;
198
+ packed?: [import("o1js/dist/node/lib/provable/field").Field, number][] | undefined;
199
+ };
200
+ toJSON: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => any;
201
+ fromJSON: (x: any) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
202
+ empty: () => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
203
+ } & (new (...args: any) => T) & {
204
+ _isStruct: true;
205
+ } extends import("o1js/dist/node/bindings/lib/generic").GenericProvable<T, any, import("o1js/dist/node/lib/provable/field").Field> ? T : T);
206
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
207
+ }) => {
208
+ value: any;
209
+ messageType: string;
210
+ };
211
+ fromJSON: (x: {
212
+ value: any;
213
+ messageType: string;
214
+ }) => {
215
+ value: T | (Omit<import("o1js/dist/node/lib/provable/types/provable-intf").Provable<import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>, any>, "fromFields"> & {
216
+ fromFields: (fields: import("o1js/dist/node/lib/provable/field").Field[]) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
217
+ } & {
218
+ toInput: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => {
219
+ fields?: import("o1js/dist/node/lib/provable/field").Field[] | undefined;
220
+ packed?: [import("o1js/dist/node/lib/provable/field").Field, number][] | undefined;
221
+ };
222
+ toJSON: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => any;
223
+ fromJSON: (x: any) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
224
+ empty: () => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
225
+ } & (new (...args: any) => T) & {
226
+ _isStruct: true;
227
+ } extends import("o1js/dist/node/bindings/lib/generic").GenericProvable<T, any, import("o1js/dist/node/lib/provable/field").Field> ? T : T);
228
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
229
+ };
230
+ empty: () => {
231
+ value: T | (Omit<import("o1js/dist/node/lib/provable/types/provable-intf").Provable<import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>, any>, "fromFields"> & {
232
+ fromFields: (fields: import("o1js/dist/node/lib/provable/field").Field[]) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
233
+ } & {
234
+ toInput: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => {
235
+ fields?: import("o1js/dist/node/lib/provable/field").Field[] | undefined;
236
+ packed?: [import("o1js/dist/node/lib/provable/field").Field, number][] | undefined;
237
+ };
238
+ toJSON: (x: import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>) => any;
239
+ fromJSON: (x: any) => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
240
+ empty: () => import("o1js/dist/node/bindings/lib/provable-generic").NonMethods<T>;
241
+ } & (new (...args: any) => T) & {
242
+ _isStruct: true;
243
+ } extends import("o1js/dist/node/bindings/lib/generic").GenericProvable<T, any, import("o1js/dist/node/lib/provable/field").Field> ? T : T);
244
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
245
+ };
246
+ };
247
+ declare const OutgoingMessageArgument_base: (new (value: {
248
+ witness: LinkedMerkleTreeReadWitness;
249
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
250
+ }) => {
251
+ witness: LinkedMerkleTreeReadWitness;
252
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
253
+ }) & {
254
+ _isStruct: true;
255
+ } & Omit<import("o1js/dist/node/lib/provable/types/provable-intf").Provable<{
256
+ witness: LinkedMerkleTreeReadWitness;
257
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
258
+ }, {
259
+ witness: {
260
+ leaf: {
261
+ value: bigint;
262
+ path: bigint;
263
+ nextPath: bigint;
264
+ };
265
+ merkleWitness: {
266
+ path: bigint[];
267
+ isLeft: boolean[];
268
+ };
269
+ };
270
+ messageType: bigint;
271
+ }>, "fromFields"> & {
272
+ fromFields: (fields: import("o1js/dist/node/lib/provable/field").Field[]) => {
273
+ witness: LinkedMerkleTreeReadWitness;
274
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
275
+ };
276
+ } & {
277
+ fromValue: (value: {
278
+ witness: LinkedMerkleTreeReadWitness | {
279
+ leaf: import("@proto-kit/common").LinkedLeafStruct | {
280
+ value: string | number | bigint | import("o1js/dist/node/lib/provable/field").Field;
281
+ path: string | number | bigint | import("o1js/dist/node/lib/provable/field").Field;
282
+ nextPath: string | number | bigint | import("o1js/dist/node/lib/provable/field").Field;
283
+ };
284
+ merkleWitness: {
285
+ height(): number;
286
+ calculateRoot(hash: import("o1js/dist/node/lib/provable/field").Field): import("o1js/dist/node/lib/provable/field").Field;
287
+ calculateIndex(): import("o1js/dist/node/lib/provable/field").Field;
288
+ checkMembership(root: import("o1js/dist/node/lib/provable/field").Field, key: import("o1js/dist/node/lib/provable/field").Field, value: import("o1js/dist/node/lib/provable/field").Field): import("o1js/dist/node/lib/provable/bool").Bool;
289
+ checkMembershipSimple(root: import("o1js/dist/node/lib/provable/field").Field, value: import("o1js/dist/node/lib/provable/field").Field): import("o1js/dist/node/lib/provable/bool").Bool;
290
+ checkMembershipGetRoots(root: import("o1js/dist/node/lib/provable/field").Field, key: import("o1js/dist/node/lib/provable/field").Field, value: import("o1js/dist/node/lib/provable/field").Field): [import("o1js/dist/node/lib/provable/bool").Bool, import("o1js/dist/node/lib/provable/field").Field, import("o1js/dist/node/lib/provable/field").Field];
291
+ toShortenedEntries(): string[];
292
+ path: import("o1js/dist/node/lib/provable/field").Field[];
293
+ isLeft: import("o1js/dist/node/lib/provable/bool").Bool[];
294
+ } | {
295
+ path: import("o1js/dist/node/lib/provable/field").Field[] | bigint[];
296
+ isLeft: import("o1js/dist/node/lib/provable/bool").Bool[] | boolean[];
297
+ };
298
+ };
299
+ messageType: string | number | bigint | import("o1js/dist/node/lib/provable/field").Field;
300
+ }) => {
301
+ witness: LinkedMerkleTreeReadWitness;
302
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
303
+ };
304
+ toInput: (x: {
305
+ witness: LinkedMerkleTreeReadWitness;
306
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
307
+ }) => {
308
+ fields?: import("o1js/dist/node/lib/provable/field").Field[] | undefined;
309
+ packed?: [import("o1js/dist/node/lib/provable/field").Field, number][] | undefined;
310
+ };
311
+ toJSON: (x: {
312
+ witness: LinkedMerkleTreeReadWitness;
313
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
314
+ }) => {
315
+ witness: {
316
+ leaf: {
317
+ value: string;
318
+ path: string;
319
+ nextPath: string;
320
+ };
321
+ merkleWitness: {
322
+ path: string[];
323
+ isLeft: boolean[];
324
+ };
325
+ };
326
+ messageType: string;
327
+ };
328
+ fromJSON: (x: {
329
+ witness: {
330
+ leaf: {
331
+ value: string;
332
+ path: string;
333
+ nextPath: string;
334
+ };
335
+ merkleWitness: {
336
+ path: string[];
337
+ isLeft: boolean[];
338
+ };
339
+ };
340
+ messageType: string;
341
+ }) => {
342
+ witness: LinkedMerkleTreeReadWitness;
343
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
344
+ };
345
+ empty: () => {
346
+ witness: LinkedMerkleTreeReadWitness;
347
+ messageType: import("o1js/dist/node/lib/provable/field").Field;
348
+ };
349
+ };
350
+ export declare class OutgoingMessageArgument extends OutgoingMessageArgument_base {
351
+ static dummy(): OutgoingMessageArgument;
352
+ }
353
+ declare const OutgoingMessageArgumentBatch_base: (new (value: {
354
+ arguments: OutgoingMessageArgument[];
355
+ isDummys: import("o1js/dist/node/lib/provable/bool").Bool[];
356
+ }) => {
357
+ arguments: OutgoingMessageArgument[];
358
+ isDummys: import("o1js/dist/node/lib/provable/bool").Bool[];
359
+ }) & {
360
+ _isStruct: true;
361
+ } & Omit<import("o1js/dist/node/lib/provable/types/provable-intf").Provable<{
362
+ arguments: OutgoingMessageArgument[];
363
+ isDummys: import("o1js/dist/node/lib/provable/bool").Bool[];
364
+ }, {
365
+ arguments: {
366
+ witness: {
367
+ leaf: {
368
+ value: bigint;
369
+ path: bigint;
370
+ nextPath: bigint;
371
+ };
372
+ merkleWitness: {
373
+ path: bigint[];
374
+ isLeft: boolean[];
375
+ };
376
+ };
377
+ messageType: bigint;
378
+ }[];
379
+ isDummys: boolean[];
380
+ }>, "fromFields"> & {
381
+ fromFields: (fields: import("o1js/dist/node/lib/provable/field").Field[]) => {
382
+ arguments: OutgoingMessageArgument[];
383
+ isDummys: import("o1js/dist/node/lib/provable/bool").Bool[];
384
+ };
385
+ } & {
386
+ fromValue: (value: {
387
+ arguments: OutgoingMessageArgument[] | {
388
+ witness: {
389
+ leaf: {
390
+ value: bigint;
391
+ path: bigint;
392
+ nextPath: bigint;
393
+ };
394
+ merkleWitness: {
395
+ path: bigint[];
396
+ isLeft: boolean[];
397
+ };
398
+ };
399
+ messageType: bigint;
400
+ }[];
401
+ isDummys: import("o1js/dist/node/lib/provable/bool").Bool[] | boolean[];
402
+ }) => {
403
+ arguments: OutgoingMessageArgument[];
404
+ isDummys: import("o1js/dist/node/lib/provable/bool").Bool[];
405
+ };
406
+ toInput: (x: {
407
+ arguments: OutgoingMessageArgument[];
408
+ isDummys: import("o1js/dist/node/lib/provable/bool").Bool[];
409
+ }) => {
410
+ fields?: import("o1js/dist/node/lib/provable/field").Field[] | undefined;
411
+ packed?: [import("o1js/dist/node/lib/provable/field").Field, number][] | undefined;
412
+ };
413
+ toJSON: (x: {
414
+ arguments: OutgoingMessageArgument[];
415
+ isDummys: import("o1js/dist/node/lib/provable/bool").Bool[];
416
+ }) => {
417
+ arguments: {
418
+ witness: {
419
+ leaf: {
420
+ value: string;
421
+ path: string;
422
+ nextPath: string;
423
+ };
424
+ merkleWitness: {
425
+ path: string[];
426
+ isLeft: boolean[];
427
+ };
428
+ };
429
+ messageType: string;
430
+ }[];
431
+ isDummys: boolean[];
432
+ };
433
+ fromJSON: (x: {
434
+ arguments: {
435
+ witness: {
436
+ leaf: {
437
+ value: string;
438
+ path: string;
439
+ nextPath: string;
440
+ };
441
+ merkleWitness: {
442
+ path: string[];
443
+ isLeft: boolean[];
444
+ };
445
+ };
446
+ messageType: string;
447
+ }[];
448
+ isDummys: boolean[];
449
+ }) => {
450
+ arguments: OutgoingMessageArgument[];
451
+ isDummys: import("o1js/dist/node/lib/provable/bool").Bool[];
452
+ };
453
+ empty: () => {
454
+ arguments: OutgoingMessageArgument[];
455
+ isDummys: import("o1js/dist/node/lib/provable/bool").Bool[];
456
+ };
457
+ };
458
+ export declare class OutgoingMessageArgumentBatch extends OutgoingMessageArgumentBatch_base {
459
+ static fromMessages(providedArguments: OutgoingMessageArgument[]): OutgoingMessageArgumentBatch;
460
+ }
461
+ export {};
462
+ //# sourceMappingURL=OutgoingMessageArgument.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OutgoingMessageArgument.d.ts","sourceRoot":"","sources":["../../../src/settlement/messages/OutgoingMessageArgument.ts"],"names":[],"mappings":"AAAA,OAAO,EAAe,oBAAoB,EAAoB,MAAM,MAAM,CAAC;AAC3E,OAAO,EAEL,2BAA2B,EAC5B,MAAM,mBAAmB,CAAC;AAK3B,eAAO,MAAM,2BAA2B,IAAI,CAAC;AAE7C,wBAAgB,mBAAmB,CAAC,CAAC,EAAE,IAAI,EAAE,oBAAoB,CAAC,CAAC,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAKnE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAED,qBAAa,uBAAwB,SAAQ,4BAG3C;WACc,KAAK,IAAI,uBAAuB;CAM/C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAED,qBAAa,4BAA6B,SAAQ,iCAOhD;WACc,YAAY,CAAC,iBAAiB,EAAE,uBAAuB,EAAE;CAcxE"}
@@ -0,0 +1,40 @@
1
+ import { Bool, Field, Provable, Struct } from "o1js";
2
+ import { LinkedMerkleTree, LinkedMerkleTreeReadWitness, } from "@proto-kit/common";
3
+ // TODO Make that dynamic based on processors configured
4
+ export const OUTGOING_MESSAGE_BATCH_SIZE = 1;
5
+ export function createMessageStruct(type) {
6
+ return class MessageStruct extends Struct({
7
+ value: type,
8
+ messageType: Field,
9
+ }) {
10
+ };
11
+ }
12
+ export class OutgoingMessageArgument extends Struct({
13
+ witness: LinkedMerkleTreeReadWitness,
14
+ messageType: Field,
15
+ }) {
16
+ static dummy() {
17
+ return new OutgoingMessageArgument({
18
+ witness: LinkedMerkleTree.dummyReadWitness(),
19
+ messageType: Field(0),
20
+ });
21
+ }
22
+ }
23
+ export class OutgoingMessageArgumentBatch extends Struct({
24
+ arguments: Provable.Array(OutgoingMessageArgument, OUTGOING_MESSAGE_BATCH_SIZE),
25
+ isDummys: Provable.Array(Bool, OUTGOING_MESSAGE_BATCH_SIZE),
26
+ }) {
27
+ static fromMessages(providedArguments) {
28
+ const batch = providedArguments.slice();
29
+ const isDummys = batch.map(() => Bool(false));
30
+ while (batch.length < OUTGOING_MESSAGE_BATCH_SIZE) {
31
+ batch.push(OutgoingMessageArgument.dummy());
32
+ isDummys.push(Bool(true));
33
+ }
34
+ return new OutgoingMessageArgumentBatch({
35
+ arguments: batch,
36
+ isDummys,
37
+ });
38
+ }
39
+ }
40
+ //# sourceMappingURL=OutgoingMessageArgument.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OutgoingMessageArgument.js","sourceRoot":"","sources":["../../../src/settlement/messages/OutgoingMessageArgument.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,KAAK,EAAwB,QAAQ,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAC3E,OAAO,EACL,gBAAgB,EAChB,2BAA2B,GAC5B,MAAM,mBAAmB,CAAC;AAI3B,wDAAwD;AACxD,MAAM,CAAC,MAAM,2BAA2B,GAAG,CAAC,CAAC;AAE7C,MAAM,UAAU,mBAAmB,CAAI,IAA6B;IAClE,OAAO,MAAM,aAAc,SAAQ,MAAM,CAAC;QACxC,KAAK,EAAE,IAAI;QACX,WAAW,EAAE,KAAK;KACnB,CAAC;KAAsD,CAAC;AAC3D,CAAC;AAED,MAAM,OAAO,uBAAwB,SAAQ,MAAM,CAAC;IAClD,OAAO,EAAE,2BAA2B;IACpC,WAAW,EAAE,KAAK;CACnB,CAAC;IACO,MAAM,CAAC,KAAK;QACjB,OAAO,IAAI,uBAAuB,CAAC;YACjC,OAAO,EAAE,gBAAgB,CAAC,gBAAgB,EAAE;YAC5C,WAAW,EAAE,KAAK,CAAC,CAAC,CAAC;SACtB,CAAC,CAAC;IACL,CAAC;CACF;AAED,MAAM,OAAO,4BAA6B,SAAQ,MAAM,CAAC;IACvD,SAAS,EAAE,QAAQ,CAAC,KAAK,CACvB,uBAAuB,EACvB,2BAA2B,CAC5B;IAED,QAAQ,EAAE,QAAQ,CAAC,KAAK,CAAC,IAAI,EAAE,2BAA2B,CAAC;CAC5D,CAAC;IACO,MAAM,CAAC,YAAY,CAAC,iBAA4C;QACrE,MAAM,KAAK,GAAG,iBAAiB,CAAC,KAAK,EAAE,CAAC;QACxC,MAAM,QAAQ,GAAG,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QAE9C,OAAO,KAAK,CAAC,MAAM,GAAG,2BAA2B,EAAE;YACjD,KAAK,CAAC,IAAI,CAAC,uBAAuB,CAAC,KAAK,EAAE,CAAC,CAAC;YAC5C,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;SAC3B;QAED,OAAO,IAAI,4BAA4B,CAAC;YACtC,SAAS,EAAE,KAAK;YAChB,QAAQ;SACT,CAAC,CAAC;IACL,CAAC;CACF"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=Withdrawal.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Withdrawal.d.ts","sourceRoot":"","sources":["../../../src/settlement/messages/Withdrawal.ts"],"names":[],"mappings":""}
@@ -0,0 +1,3 @@
1
+ export {};
2
+ // TODO Remove
3
+ //# sourceMappingURL=Withdrawal.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Withdrawal.js","sourceRoot":"","sources":["../../../src/settlement/messages/Withdrawal.ts"],"names":[],"mappings":";AAGA,cAAc"}
@@ -0,0 +1,25 @@
1
+ import { AccountUpdate, Bool, Field, FlexibleProvablePure, PublicKey } from "o1js";
2
+ import { NoConfig } from "@proto-kit/common";
3
+ import { ProtocolModule } from "../../protocol/ProtocolModule";
4
+ export declare function outgoingMessageProcessor(): (target: import("@proto-kit/common").TypedClass<unknown>) => void;
5
+ export type MessageProcessorArgs = {
6
+ bridgeContract: {
7
+ publicKey: PublicKey;
8
+ tokenId: Field;
9
+ };
10
+ };
11
+ export declare abstract class OutgoingMessageProcessor<T, Config = NoConfig> extends ProtocolModule<Config> {
12
+ private status;
13
+ private statusMessage?;
14
+ assertTrue(b: Bool, msg?: string): void;
15
+ processMessage(message: T, args: MessageProcessorArgs): {
16
+ accountUpdates: AccountUpdate[];
17
+ status: Bool;
18
+ statusMessage?: string;
19
+ };
20
+ abstract type: FlexibleProvablePure<T>;
21
+ abstract messageType: string;
22
+ abstract dummy(): T;
23
+ abstract process(message: T, args: MessageProcessorArgs): AccountUpdate[];
24
+ }
25
+ //# sourceMappingURL=OutgoingMessageProcessor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OutgoingMessageProcessor.d.ts","sourceRoot":"","sources":["../../../src/settlement/modularity/OutgoingMessageProcessor.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,aAAa,EACb,IAAI,EACJ,KAAK,EACL,oBAAoB,EACpB,SAAS,EACV,MAAM,MAAM,CAAC;AACd,OAAO,EAAa,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAExD,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAE/D,wBAAgB,wBAAwB,sEAEvC;AAED,MAAM,MAAM,oBAAoB,GAAG;IACjC,cAAc,EAAE;QACd,SAAS,EAAE,SAAS,CAAC;QACrB,OAAO,EAAE,KAAK,CAAC;KAChB,CAAC;CACH,CAAC;AAEF,8BAAsB,wBAAwB,CAC5C,CAAC,EACD,MAAM,GAAG,QAAQ,CACjB,SAAQ,cAAc,CAAC,MAAM,CAAC;IAC9B,OAAO,CAAC,MAAM,CAAqB;IAEnC,OAAO,CAAC,aAAa,CAAC,CAAqB;IAEpC,UAAU,CAAC,CAAC,EAAE,IAAI,EAAE,GAAG,CAAC,EAAE,MAAM;IAOvC,cAAc,CACZ,OAAO,EAAE,CAAC,EACV,IAAI,EAAE,oBAAoB,GACzB;QACD,cAAc,EAAE,aAAa,EAAE,CAAC;QAChC,MAAM,EAAE,IAAI,CAAC;QACb,aAAa,CAAC,EAAE,MAAM,CAAC;KACxB;IAaD,QAAQ,CAAC,IAAI,EAAE,oBAAoB,CAAC,CAAC,CAAC,CAAC;IAEvC,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC;IAE7B,QAAQ,CAAC,KAAK,IAAI,CAAC;IAEnB,QAAQ,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,oBAAoB,GAAG,aAAa,EAAE;CAC1E"}
@@ -0,0 +1,30 @@
1
+ import { Bool, } from "o1js";
2
+ import { implement } from "@proto-kit/common";
3
+ import { ProtocolModule } from "../../protocol/ProtocolModule";
4
+ export function outgoingMessageProcessor() {
5
+ return implement("OutgoingMessageProcessor");
6
+ }
7
+ export class OutgoingMessageProcessor extends ProtocolModule {
8
+ constructor() {
9
+ super(...arguments);
10
+ this.status = Bool(false);
11
+ this.statusMessage = undefined;
12
+ }
13
+ assertTrue(b, msg) {
14
+ this.status = this.status.and(b);
15
+ if (this.statusMessage === undefined) {
16
+ this.statusMessage = msg;
17
+ }
18
+ }
19
+ processMessage(message, args) {
20
+ this.status = Bool(true);
21
+ this.statusMessage = undefined;
22
+ const accountUpdates = this.process(message, args);
23
+ return {
24
+ accountUpdates,
25
+ status: this.status,
26
+ statusMessage: this.statusMessage,
27
+ };
28
+ }
29
+ }
30
+ //# sourceMappingURL=OutgoingMessageProcessor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OutgoingMessageProcessor.js","sourceRoot":"","sources":["../../../src/settlement/modularity/OutgoingMessageProcessor.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,IAAI,GAIL,MAAM,MAAM,CAAC;AACd,OAAO,EAAE,SAAS,EAAY,MAAM,mBAAmB,CAAC;AAExD,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAE/D,MAAM,UAAU,wBAAwB;IACtC,OAAO,SAAS,CAAC,0BAA0B,CAAC,CAAC;AAC/C,CAAC;AASD,MAAM,OAAgB,wBAGpB,SAAQ,cAAsB;IAHhC;;QAIU,WAAM,GAAS,IAAI,CAAC,KAAK,CAAC,CAAC;QAE3B,kBAAa,GAAY,SAAS,CAAC;IAoC7C,CAAC;IAlCQ,UAAU,CAAC,CAAO,EAAE,GAAY;QACrC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACjC,IAAI,IAAI,CAAC,aAAa,KAAK,SAAS,EAAE;YACpC,IAAI,CAAC,aAAa,GAAG,GAAG,CAAC;SAC1B;IACH,CAAC;IAED,cAAc,CACZ,OAAU,EACV,IAA0B;QAM1B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC;QAE/B,MAAM,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;QAEnD,OAAO;YACL,cAAc;YACd,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,aAAa,EAAE,IAAI,CAAC,aAAa;SAClC,CAAC;IACJ,CAAC;CASF"}
@@ -0,0 +1,26 @@
1
+ import { Field, PublicKey, UInt32 } from "o1js";
2
+ import { InferProofBase } from "@proto-kit/common";
3
+ import { ProtocolModule } from "../../protocol/ProtocolModule";
4
+ import { NetworkState } from "../../model/network/NetworkState";
5
+ import type { BlockProof } from "../../prover/block/BlockProver";
6
+ import type { SettlementSmartContractBase } from "../contracts/SettlementSmartContract";
7
+ export type InputBlockProof = InferProofBase<BlockProof>;
8
+ export type SettlementStateRecord = {
9
+ sequencerKey: PublicKey;
10
+ lastSettlementL1BlockHeight: UInt32;
11
+ stateRoot: Field;
12
+ networkStateHash: Field;
13
+ blockHashRoot: Field;
14
+ };
15
+ export type SettlementHookInputs = {
16
+ blockProof: InputBlockProof;
17
+ fromNetworkState: NetworkState;
18
+ toNetworkState: NetworkState;
19
+ newPromisedMessagesHash: Field;
20
+ contractState: SettlementStateRecord;
21
+ currentL1BlockHeight: UInt32;
22
+ };
23
+ export declare abstract class ProvableSettlementHook<Config> extends ProtocolModule<Config> {
24
+ abstract beforeSettlement(smartContract: SettlementSmartContractBase, inputs: SettlementHookInputs): Promise<void>;
25
+ }
26
+ //# sourceMappingURL=ProvableSettlementHook.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProvableSettlementHook.d.ts","sourceRoot":"","sources":["../../../src/settlement/modularity/ProvableSettlementHook.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAEnD,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;AAChE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AACjE,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,sCAAsC,CAAC;AAExF,MAAM,MAAM,eAAe,GAAG,cAAc,CAAC,UAAU,CAAC,CAAC;AAEzD,MAAM,MAAM,qBAAqB,GAAG;IAClC,YAAY,EAAE,SAAS,CAAC;IACxB,2BAA2B,EAAE,MAAM,CAAC;IAEpC,SAAS,EAAE,KAAK,CAAC;IACjB,gBAAgB,EAAE,KAAK,CAAC;IACxB,aAAa,EAAE,KAAK,CAAC;CACtB,CAAC;AAEF,MAAM,MAAM,oBAAoB,GAAG;IACjC,UAAU,EAAE,eAAe,CAAC;IAC5B,gBAAgB,EAAE,YAAY,CAAC;IAC/B,cAAc,EAAE,YAAY,CAAC;IAC7B,uBAAuB,EAAE,KAAK,CAAC;IAC/B,aAAa,EAAE,qBAAqB,CAAC;IACrC,oBAAoB,EAAE,MAAM,CAAC;CAC9B,CAAC;AAEF,8BAAsB,sBAAsB,CAC1C,MAAM,CACN,SAAQ,cAAc,CAAC,MAAM,CAAC;aACd,gBAAgB,CAC9B,aAAa,EAAE,2BAA2B,EAC1C,MAAM,EAAE,oBAAoB,GAC3B,OAAO,CAAC,IAAI,CAAC;CACjB"}