@proto-kit/protocol 0.1.1-develop.1086

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 (251) hide show
  1. package/LICENSE.md +201 -0
  2. package/README.md +45 -0
  3. package/dist/Constants.d.ts +4 -0
  4. package/dist/Constants.d.ts.map +1 -0
  5. package/dist/Constants.js +3 -0
  6. package/dist/hooks/AccountStateHook.d.ts +52 -0
  7. package/dist/hooks/AccountStateHook.d.ts.map +1 -0
  8. package/dist/hooks/AccountStateHook.js +47 -0
  9. package/dist/hooks/BlockHeightHook.d.ts +7 -0
  10. package/dist/hooks/BlockHeightHook.d.ts.map +1 -0
  11. package/dist/hooks/BlockHeightHook.js +15 -0
  12. package/dist/hooks/LastStateRootBlockHook.d.ts +8 -0
  13. package/dist/hooks/LastStateRootBlockHook.d.ts.map +1 -0
  14. package/dist/hooks/LastStateRootBlockHook.js +15 -0
  15. package/dist/hooks/NoopBlockHook.d.ts +9 -0
  16. package/dist/hooks/NoopBlockHook.d.ts.map +1 -0
  17. package/dist/hooks/NoopBlockHook.js +9 -0
  18. package/dist/hooks/NoopSettlementHook.d.ts +6 -0
  19. package/dist/hooks/NoopSettlementHook.d.ts.map +1 -0
  20. package/dist/hooks/NoopSettlementHook.js +17 -0
  21. package/dist/hooks/NoopTransactionHook.d.ts +6 -0
  22. package/dist/hooks/NoopTransactionHook.d.ts.map +1 -0
  23. package/dist/hooks/NoopTransactionHook.js +7 -0
  24. package/dist/index.d.ts +54 -0
  25. package/dist/index.d.ts.map +1 -0
  26. package/dist/index.js +53 -0
  27. package/dist/model/MethodPublicOutput.d.ts +113 -0
  28. package/dist/model/MethodPublicOutput.d.ts.map +1 -0
  29. package/dist/model/MethodPublicOutput.js +14 -0
  30. package/dist/model/Option.d.ts +122 -0
  31. package/dist/model/Option.d.ts.map +1 -0
  32. package/dist/model/Option.js +110 -0
  33. package/dist/model/Path.d.ts +31 -0
  34. package/dist/model/Path.d.ts.map +1 -0
  35. package/dist/model/Path.js +42 -0
  36. package/dist/model/RuntimeLike.d.ts +11 -0
  37. package/dist/model/RuntimeLike.d.ts.map +1 -0
  38. package/dist/model/RuntimeLike.js +1 -0
  39. package/dist/model/StateTransition.d.ts +135 -0
  40. package/dist/model/StateTransition.d.ts.map +1 -0
  41. package/dist/model/StateTransition.js +68 -0
  42. package/dist/model/StateTransitionProvableBatch.d.ts +172 -0
  43. package/dist/model/StateTransitionProvableBatch.d.ts.map +1 -0
  44. package/dist/model/StateTransitionProvableBatch.js +85 -0
  45. package/dist/model/network/NetworkState.d.ts +160 -0
  46. package/dist/model/network/NetworkState.d.ts.map +1 -0
  47. package/dist/model/network/NetworkState.js +31 -0
  48. package/dist/model/transaction/RuntimeTransaction.d.ts +122 -0
  49. package/dist/model/transaction/RuntimeTransaction.d.ts.map +1 -0
  50. package/dist/model/transaction/RuntimeTransaction.js +86 -0
  51. package/dist/model/transaction/SignedTransaction.d.ts +107 -0
  52. package/dist/model/transaction/SignedTransaction.d.ts.map +1 -0
  53. package/dist/model/transaction/SignedTransaction.js +33 -0
  54. package/dist/model/transaction/ValueOption.d.ts +173 -0
  55. package/dist/model/transaction/ValueOption.d.ts.map +1 -0
  56. package/dist/model/transaction/ValueOption.js +24 -0
  57. package/dist/protocol/Protocol.d.ts +43 -0
  58. package/dist/protocol/Protocol.d.ts.map +1 -0
  59. package/dist/protocol/Protocol.js +95 -0
  60. package/dist/protocol/ProtocolEnvironment.d.ts +9 -0
  61. package/dist/protocol/ProtocolEnvironment.d.ts.map +1 -0
  62. package/dist/protocol/ProtocolEnvironment.js +1 -0
  63. package/dist/protocol/ProtocolModule.d.ts +9 -0
  64. package/dist/protocol/ProtocolModule.d.ts.map +1 -0
  65. package/dist/protocol/ProtocolModule.js +12 -0
  66. package/dist/protocol/ProvableBlockHook.d.ts +8 -0
  67. package/dist/protocol/ProvableBlockHook.d.ts.map +1 -0
  68. package/dist/protocol/ProvableBlockHook.js +4 -0
  69. package/dist/protocol/ProvableTransactionHook.d.ts +7 -0
  70. package/dist/protocol/ProvableTransactionHook.d.ts.map +1 -0
  71. package/dist/protocol/ProvableTransactionHook.js +3 -0
  72. package/dist/protocol/TransitioningProtocolModule.d.ts +10 -0
  73. package/dist/protocol/TransitioningProtocolModule.d.ts.map +1 -0
  74. package/dist/protocol/TransitioningProtocolModule.js +8 -0
  75. package/dist/prover/block/BlockProvable.d.ts +395 -0
  76. package/dist/prover/block/BlockProvable.d.ts.map +1 -0
  77. package/dist/prover/block/BlockProvable.js +45 -0
  78. package/dist/prover/block/BlockProver.d.ts +92 -0
  79. package/dist/prover/block/BlockProver.d.ts.map +1 -0
  80. package/dist/prover/block/BlockProver.js +472 -0
  81. package/dist/prover/block/accummulators/BlockHashMerkleTree.d.ts +64 -0
  82. package/dist/prover/block/accummulators/BlockHashMerkleTree.d.ts.map +1 -0
  83. package/dist/prover/block/accummulators/BlockHashMerkleTree.js +16 -0
  84. package/dist/prover/block/accummulators/RuntimeVerificationKeyTree.d.ts +139 -0
  85. package/dist/prover/block/accummulators/RuntimeVerificationKeyTree.d.ts.map +1 -0
  86. package/dist/prover/block/accummulators/RuntimeVerificationKeyTree.js +20 -0
  87. package/dist/prover/block/services/RuntimeVerificationKeyRootService.d.ts +7 -0
  88. package/dist/prover/block/services/RuntimeVerificationKeyRootService.d.ts.map +1 -0
  89. package/dist/prover/block/services/RuntimeVerificationKeyRootService.js +22 -0
  90. package/dist/prover/statetransition/StateTransitionProvable.d.ts +174 -0
  91. package/dist/prover/statetransition/StateTransitionProvable.d.ts.map +1 -0
  92. package/dist/prover/statetransition/StateTransitionProvable.js +15 -0
  93. package/dist/prover/statetransition/StateTransitionProver.d.ts +51 -0
  94. package/dist/prover/statetransition/StateTransitionProver.d.ts.map +1 -0
  95. package/dist/prover/statetransition/StateTransitionProver.js +188 -0
  96. package/dist/prover/statetransition/StateTransitionWitnessProvider.d.ts +16 -0
  97. package/dist/prover/statetransition/StateTransitionWitnessProvider.d.ts.map +1 -0
  98. package/dist/prover/statetransition/StateTransitionWitnessProvider.js +16 -0
  99. package/dist/prover/statetransition/StateTransitionWitnessProviderReference.d.ts +7 -0
  100. package/dist/prover/statetransition/StateTransitionWitnessProviderReference.d.ts.map +1 -0
  101. package/dist/prover/statetransition/StateTransitionWitnessProviderReference.js +19 -0
  102. package/dist/settlement/ContractModule.d.ts +15 -0
  103. package/dist/settlement/ContractModule.d.ts.map +1 -0
  104. package/dist/settlement/ContractModule.js +11 -0
  105. package/dist/settlement/SettlementContractModule.d.ts +40 -0
  106. package/dist/settlement/SettlementContractModule.d.ts.map +1 -0
  107. package/dist/settlement/SettlementContractModule.js +71 -0
  108. package/dist/settlement/contracts/DispatchContractProtocolModule.d.ts +12 -0
  109. package/dist/settlement/contracts/DispatchContractProtocolModule.d.ts.map +1 -0
  110. package/dist/settlement/contracts/DispatchContractProtocolModule.js +35 -0
  111. package/dist/settlement/contracts/DispatchSmartContract.d.ts +22 -0
  112. package/dist/settlement/contracts/DispatchSmartContract.d.ts.map +1 -0
  113. package/dist/settlement/contracts/DispatchSmartContract.js +110 -0
  114. package/dist/settlement/contracts/SettlementContractProtocolModule.d.ts +19 -0
  115. package/dist/settlement/contracts/SettlementContractProtocolModule.d.ts.map +1 -0
  116. package/dist/settlement/contracts/SettlementContractProtocolModule.js +44 -0
  117. package/dist/settlement/contracts/SettlementSmartContract.d.ts +42 -0
  118. package/dist/settlement/contracts/SettlementSmartContract.d.ts.map +1 -0
  119. package/dist/settlement/contracts/SettlementSmartContract.js +241 -0
  120. package/dist/settlement/messages/Deposit.d.ts +64 -0
  121. package/dist/settlement/messages/Deposit.d.ts.map +1 -0
  122. package/dist/settlement/messages/Deposit.js +6 -0
  123. package/dist/settlement/messages/OutgoingMessageArgument.d.ts +189 -0
  124. package/dist/settlement/messages/OutgoingMessageArgument.d.ts.map +1 -0
  125. package/dist/settlement/messages/OutgoingMessageArgument.js +32 -0
  126. package/dist/settlement/messages/Withdrawal.d.ts +65 -0
  127. package/dist/settlement/messages/Withdrawal.d.ts.map +1 -0
  128. package/dist/settlement/messages/Withdrawal.js +13 -0
  129. package/dist/settlement/modularity/ProvableSettlementHook.d.ts +24 -0
  130. package/dist/settlement/modularity/ProvableSettlementHook.d.ts.map +1 -0
  131. package/dist/settlement/modularity/ProvableSettlementHook.js +3 -0
  132. package/dist/settlement/modules/NetworkStateSettlementModule.d.ts +11 -0
  133. package/dist/settlement/modules/NetworkStateSettlementModule.d.ts.map +1 -0
  134. package/dist/settlement/modules/NetworkStateSettlementModule.js +14 -0
  135. package/dist/state/State.d.ts +68 -0
  136. package/dist/state/State.d.ts.map +1 -0
  137. package/dist/state/State.js +129 -0
  138. package/dist/state/StateMap.d.ts +37 -0
  139. package/dist/state/StateMap.d.ts.map +1 -0
  140. package/dist/state/StateMap.js +55 -0
  141. package/dist/state/StateService.d.ts +6 -0
  142. package/dist/state/StateService.d.ts.map +1 -0
  143. package/dist/state/StateService.js +1 -0
  144. package/dist/state/StateServiceProvider.d.ts +8 -0
  145. package/dist/state/StateServiceProvider.d.ts.map +1 -0
  146. package/dist/state/StateServiceProvider.js +36 -0
  147. package/dist/state/assert/assert.d.ts +12 -0
  148. package/dist/state/assert/assert.d.ts.map +1 -0
  149. package/dist/state/assert/assert.js +30 -0
  150. package/dist/state/context/ProtocolMethodExecutionContext.d.ts +22 -0
  151. package/dist/state/context/ProtocolMethodExecutionContext.d.ts.map +1 -0
  152. package/dist/state/context/ProtocolMethodExecutionContext.js +28 -0
  153. package/dist/state/context/RuntimeMethodExecutionContext.d.ts +193 -0
  154. package/dist/state/context/RuntimeMethodExecutionContext.d.ts.map +1 -0
  155. package/dist/state/context/RuntimeMethodExecutionContext.js +135 -0
  156. package/dist/state/context/TransitionMethodExecutionContext.d.ts +23 -0
  157. package/dist/state/context/TransitionMethodExecutionContext.d.ts.map +1 -0
  158. package/dist/state/context/TransitionMethodExecutionContext.js +5 -0
  159. package/dist/state/protocol/ProtocolState.d.ts +7 -0
  160. package/dist/state/protocol/ProtocolState.d.ts.map +1 -0
  161. package/dist/state/protocol/ProtocolState.js +39 -0
  162. package/dist/utils/MinaPrefixedProvableHashList.d.ts +24 -0
  163. package/dist/utils/MinaPrefixedProvableHashList.d.ts.map +1 -0
  164. package/dist/utils/MinaPrefixedProvableHashList.js +52 -0
  165. package/dist/utils/PrefixedProvableHashList.d.ts +8 -0
  166. package/dist/utils/PrefixedProvableHashList.d.ts.map +1 -0
  167. package/dist/utils/PrefixedProvableHashList.js +12 -0
  168. package/dist/utils/ProvableHashList.d.ts +27 -0
  169. package/dist/utils/ProvableHashList.d.ts.map +1 -0
  170. package/dist/utils/ProvableHashList.js +43 -0
  171. package/dist/utils/ProvableReductionHashList.d.ts +14 -0
  172. package/dist/utils/ProvableReductionHashList.d.ts.map +1 -0
  173. package/dist/utils/ProvableReductionHashList.js +50 -0
  174. package/dist/utils/StateTransitionReductionList.d.ts +11 -0
  175. package/dist/utils/StateTransitionReductionList.d.ts.map +1 -0
  176. package/dist/utils/StateTransitionReductionList.js +60 -0
  177. package/dist/utils/utils.d.ts +11 -0
  178. package/dist/utils/utils.d.ts.map +1 -0
  179. package/dist/utils/utils.js +44 -0
  180. package/jest.config.cjs +1 -0
  181. package/package.json +36 -0
  182. package/src/Constants.ts +3 -0
  183. package/src/hooks/AccountStateHook.ts +48 -0
  184. package/src/hooks/BlockHeightHook.ts +17 -0
  185. package/src/hooks/LastStateRootBlockHook.ts +26 -0
  186. package/src/hooks/NoopBlockHook.ts +21 -0
  187. package/src/hooks/NoopSettlementHook.ts +20 -0
  188. package/src/hooks/NoopTransactionHook.ts +10 -0
  189. package/src/index.ts +53 -0
  190. package/src/model/MethodPublicOutput.ts +14 -0
  191. package/src/model/Option.ts +172 -0
  192. package/src/model/Path.ts +50 -0
  193. package/src/model/RuntimeLike.ts +12 -0
  194. package/src/model/StateTransition.ts +88 -0
  195. package/src/model/StateTransitionProvableBatch.ts +125 -0
  196. package/src/model/Transaction.ts +31 -0
  197. package/src/model/network/NetworkState.ts +33 -0
  198. package/src/model/transaction/RuntimeTransaction.ts +105 -0
  199. package/src/model/transaction/SignedTransaction.ts +47 -0
  200. package/src/model/transaction/ValueOption.ts +28 -0
  201. package/src/protocol/Protocol.ts +197 -0
  202. package/src/protocol/ProtocolEnvironment.ts +10 -0
  203. package/src/protocol/ProtocolModule.ts +27 -0
  204. package/src/protocol/ProvableBlockHook.ts +19 -0
  205. package/src/protocol/ProvableTransactionHook.ts +13 -0
  206. package/src/protocol/TransitioningProtocolModule.ts +12 -0
  207. package/src/prover/block/BlockProvable.ts +99 -0
  208. package/src/prover/block/BlockProver.ts +954 -0
  209. package/src/prover/block/accummulators/BlockHashMerkleTree.ts +16 -0
  210. package/src/prover/block/accummulators/RuntimeVerificationKeyTree.ts +24 -0
  211. package/src/prover/block/services/RuntimeVerificationKeyRootService.ts +20 -0
  212. package/src/prover/statetransition/StateTransitionProvable.ts +44 -0
  213. package/src/prover/statetransition/StateTransitionProver.ts +371 -0
  214. package/src/prover/statetransition/StateTransitionWitnessProvider.ts +23 -0
  215. package/src/prover/statetransition/StateTransitionWitnessProviderReference.ts +17 -0
  216. package/src/settlement/ContractModule.ts +24 -0
  217. package/src/settlement/SettlementContractModule.ts +132 -0
  218. package/src/settlement/contracts/DispatchContractProtocolModule.ts +39 -0
  219. package/src/settlement/contracts/DispatchSmartContract.ts +136 -0
  220. package/src/settlement/contracts/SettlementContractProtocolModule.ts +67 -0
  221. package/src/settlement/contracts/SettlementSmartContract.ts +344 -0
  222. package/src/settlement/messages/Deposit.ts +6 -0
  223. package/src/settlement/messages/OutgoingMessageArgument.ts +42 -0
  224. package/src/settlement/messages/Withdrawal.ts +14 -0
  225. package/src/settlement/modularity/ProvableSettlementHook.ts +33 -0
  226. package/src/settlement/modules/NetworkStateSettlementModule.ts +42 -0
  227. package/src/state/State.ts +175 -0
  228. package/src/state/StateMap.ts +73 -0
  229. package/src/state/StateService.ts +6 -0
  230. package/src/state/StateServiceProvider.ts +37 -0
  231. package/src/state/assert/assert.ts +35 -0
  232. package/src/state/context/RuntimeMethodExecutionContext.ts +174 -0
  233. package/src/state/context/TransitionMethodExecutionContext.ts +26 -0
  234. package/src/state/protocol/ProtocolState.ts +61 -0
  235. package/src/utils/MinaPrefixedProvableHashList.ts +73 -0
  236. package/src/utils/PrefixedProvableHashList.ts +21 -0
  237. package/src/utils/ProvableHashList.ts +50 -0
  238. package/src/utils/ProvableReductionHashList.ts +68 -0
  239. package/src/utils/StateTransitionReductionList.ts +89 -0
  240. package/src/utils/utils.ts +75 -0
  241. package/test/BlockProver.test.ts +211 -0
  242. package/test/Protocol.test.ts +37 -0
  243. package/test/State.test.ts +45 -0
  244. package/test/StateTransition.test.ts +174 -0
  245. package/test/TestingProtocol.ts +47 -0
  246. package/test/model/Option.test.ts +72 -0
  247. package/test/state/assert/assert.test.ts +56 -0
  248. package/test/tsconfig.json +7 -0
  249. package/test/utils/ProvableReductionHashList.test.ts +117 -0
  250. package/test/utils.test.ts +27 -0
  251. package/tsconfig.json +8 -0
@@ -0,0 +1,139 @@
1
+ import { VerificationKey } from "o1js";
2
+ export declare const treeFeeHeight = 10;
3
+ declare const VKTree_base: import("@proto-kit/common").AbstractMerkleTreeClass;
4
+ export declare class VKTree extends VKTree_base {
5
+ }
6
+ export declare class VKTreeWitness extends VKTree.WITNESS {
7
+ }
8
+ declare const RuntimeVerificationKeyAttestation_base: (new (value: {
9
+ verificationKey: VerificationKey;
10
+ witness: VKTreeWitness;
11
+ }) => {
12
+ verificationKey: VerificationKey;
13
+ witness: VKTreeWitness;
14
+ }) & {
15
+ _isStruct: true;
16
+ } & import("o1js/dist/node/lib/provable/provable").Provable<{
17
+ verificationKey: VerificationKey;
18
+ witness: VKTreeWitness;
19
+ }, {
20
+ verificationKey: {
21
+ data: string;
22
+ hash: bigint;
23
+ };
24
+ witness: {
25
+ path: bigint[];
26
+ isLeft: boolean[];
27
+ };
28
+ }> & {
29
+ fromValue: (value: {
30
+ verificationKey: VerificationKey | {
31
+ data: string;
32
+ hash: import("o1js/dist/node/lib/provable/field").Field;
33
+ } | {
34
+ data: string;
35
+ hash: bigint;
36
+ };
37
+ witness: VKTreeWitness | {
38
+ path: import("o1js/dist/node/lib/provable/field").Field[] | bigint[];
39
+ isLeft: import("o1js/dist/node/lib/provable/bool").Bool[] | boolean[];
40
+ };
41
+ }) => {
42
+ verificationKey: VerificationKey;
43
+ witness: VKTreeWitness;
44
+ };
45
+ toInput: (x: {
46
+ verificationKey: VerificationKey;
47
+ witness: VKTreeWitness;
48
+ }) => {
49
+ fields?: import("o1js/dist/node/lib/provable/field").Field[] | undefined;
50
+ packed?: [import("o1js/dist/node/lib/provable/field").Field, number][] | undefined;
51
+ };
52
+ toJSON: (x: {
53
+ verificationKey: VerificationKey;
54
+ witness: VKTreeWitness;
55
+ }) => {
56
+ verificationKey: string;
57
+ witness: {
58
+ path: string[];
59
+ isLeft: boolean[];
60
+ };
61
+ };
62
+ fromJSON: (x: {
63
+ verificationKey: string;
64
+ witness: {
65
+ path: string[];
66
+ isLeft: boolean[];
67
+ };
68
+ }) => {
69
+ verificationKey: VerificationKey;
70
+ witness: VKTreeWitness;
71
+ };
72
+ empty: () => {
73
+ verificationKey: VerificationKey;
74
+ witness: VKTreeWitness;
75
+ };
76
+ };
77
+ export declare class RuntimeVerificationKeyAttestation extends RuntimeVerificationKeyAttestation_base {
78
+ }
79
+ declare const MethodVKConfigData_base: (new (value: {
80
+ methodId: import("o1js/dist/node/lib/provable/field").Field;
81
+ vkHash: import("o1js/dist/node/lib/provable/field").Field;
82
+ }) => {
83
+ methodId: import("o1js/dist/node/lib/provable/field").Field;
84
+ vkHash: import("o1js/dist/node/lib/provable/field").Field;
85
+ }) & {
86
+ _isStruct: true;
87
+ } & Omit<import("o1js/dist/node/lib/provable/types/provable-intf").Provable<{
88
+ methodId: import("o1js/dist/node/lib/provable/field").Field;
89
+ vkHash: import("o1js/dist/node/lib/provable/field").Field;
90
+ }, {
91
+ methodId: bigint;
92
+ vkHash: bigint;
93
+ }>, "fromFields"> & {
94
+ fromFields: (fields: import("o1js/dist/node/lib/provable/field").Field[]) => {
95
+ methodId: import("o1js/dist/node/lib/provable/field").Field;
96
+ vkHash: import("o1js/dist/node/lib/provable/field").Field;
97
+ };
98
+ } & {
99
+ fromValue: (value: {
100
+ methodId: string | number | bigint | import("o1js/dist/node/lib/provable/field").Field;
101
+ vkHash: string | number | bigint | import("o1js/dist/node/lib/provable/field").Field;
102
+ }) => {
103
+ methodId: import("o1js/dist/node/lib/provable/field").Field;
104
+ vkHash: import("o1js/dist/node/lib/provable/field").Field;
105
+ };
106
+ toInput: (x: {
107
+ methodId: import("o1js/dist/node/lib/provable/field").Field;
108
+ vkHash: import("o1js/dist/node/lib/provable/field").Field;
109
+ }) => {
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: {
114
+ methodId: import("o1js/dist/node/lib/provable/field").Field;
115
+ vkHash: import("o1js/dist/node/lib/provable/field").Field;
116
+ }) => {
117
+ methodId: string;
118
+ vkHash: string;
119
+ };
120
+ fromJSON: (x: {
121
+ methodId: string;
122
+ vkHash: string;
123
+ }) => {
124
+ methodId: import("o1js/dist/node/lib/provable/field").Field;
125
+ vkHash: import("o1js/dist/node/lib/provable/field").Field;
126
+ };
127
+ empty: () => {
128
+ methodId: import("o1js/dist/node/lib/provable/field").Field;
129
+ vkHash: import("o1js/dist/node/lib/provable/field").Field;
130
+ };
131
+ };
132
+ export declare class MethodVKConfigData extends MethodVKConfigData_base {
133
+ hash(): import("o1js/dist/node/lib/provable/field").Field;
134
+ }
135
+ export interface MinimalVKTreeService {
136
+ getRoot: () => bigint;
137
+ }
138
+ export {};
139
+ //# sourceMappingURL=RuntimeVerificationKeyTree.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RuntimeVerificationKeyTree.d.ts","sourceRoot":"","sources":["../../../../src/prover/block/accummulators/RuntimeVerificationKeyTree.ts"],"names":[],"mappings":"AACA,OAAO,EAA2B,eAAe,EAAE,MAAM,MAAM,CAAC;AAEhE,eAAO,MAAM,aAAa,KAAK,CAAC;;AAChC,qBAAa,MAAO,SAAQ,WAA+B;CAAG;AAC9D,qBAAa,aAAc,SAAQ,MAAM,CAAC,OAAO;CAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEpD,qBAAa,iCAAkC,SAAQ,sCAGrD;CAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEL,qBAAa,kBAAmB,SAAQ,uBAGtC;IACO,IAAI;CAGZ;AAED,MAAM,WAAW,oBAAoB;IACnC,OAAO,EAAE,MAAM,MAAM,CAAC;CACvB"}
@@ -0,0 +1,20 @@
1
+ import { createMerkleTree } from "@proto-kit/common";
2
+ import { Field, Poseidon, Struct, VerificationKey } from "o1js";
3
+ export const treeFeeHeight = 10;
4
+ export class VKTree extends createMerkleTree(treeFeeHeight) {
5
+ }
6
+ export class VKTreeWitness extends VKTree.WITNESS {
7
+ }
8
+ export class RuntimeVerificationKeyAttestation extends Struct({
9
+ verificationKey: VerificationKey,
10
+ witness: VKTreeWitness,
11
+ }) {
12
+ }
13
+ export class MethodVKConfigData extends Struct({
14
+ methodId: Field,
15
+ vkHash: Field,
16
+ }) {
17
+ hash() {
18
+ return Poseidon.hash(MethodVKConfigData.toFields(this));
19
+ }
20
+ }
@@ -0,0 +1,7 @@
1
+ import { MinimalVKTreeService } from "../accummulators/RuntimeVerificationKeyTree";
2
+ export declare class RuntimeVerificationKeyRootService implements MinimalVKTreeService {
3
+ private injectedRoot?;
4
+ setRoot(root: bigint): void;
5
+ getRoot(): bigint;
6
+ }
7
+ //# sourceMappingURL=RuntimeVerificationKeyRootService.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RuntimeVerificationKeyRootService.d.ts","sourceRoot":"","sources":["../../../../src/prover/block/services/RuntimeVerificationKeyRootService.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,oBAAoB,EAAE,MAAM,6CAA6C,CAAC;AAEnF,qBAEa,iCAAkC,YAAW,oBAAoB;IAC5E,OAAO,CAAC,YAAY,CAAC,CAAS;IAEvB,OAAO,CAAC,IAAI,EAAE,MAAM;IAIpB,OAAO;CAMf"}
@@ -0,0 +1,22 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ import { injectable, Lifecycle, scoped } from "tsyringe";
8
+ export let RuntimeVerificationKeyRootService = class RuntimeVerificationKeyRootService {
9
+ setRoot(root) {
10
+ this.injectedRoot = root;
11
+ }
12
+ getRoot() {
13
+ if (this.injectedRoot === undefined) {
14
+ throw new Error("VKTree root not set");
15
+ }
16
+ return this.injectedRoot;
17
+ }
18
+ };
19
+ RuntimeVerificationKeyRootService = __decorate([
20
+ injectable(),
21
+ scoped(Lifecycle.ContainerScoped)
22
+ ], RuntimeVerificationKeyRootService);
@@ -0,0 +1,174 @@
1
+ import { Proof } from "o1js";
2
+ import { WithZkProgrammable } from "@proto-kit/common";
3
+ import { StateTransitionProvableBatch } from "../../model/StateTransitionProvableBatch";
4
+ import { StateTransitionWitnessProviderReference } from "./StateTransitionWitnessProviderReference";
5
+ declare const StateTransitionProverPublicInput_base: (new (value: {
6
+ stateTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
7
+ protocolTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
8
+ stateRoot: import("o1js/dist/node/lib/provable/field").Field;
9
+ protocolStateRoot: import("o1js/dist/node/lib/provable/field").Field;
10
+ }) => {
11
+ stateTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
12
+ protocolTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
13
+ stateRoot: import("o1js/dist/node/lib/provable/field").Field;
14
+ protocolStateRoot: import("o1js/dist/node/lib/provable/field").Field;
15
+ }) & {
16
+ _isStruct: true;
17
+ } & Omit<import("o1js/dist/node/lib/provable/types/provable-intf").Provable<{
18
+ stateTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
19
+ protocolTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
20
+ stateRoot: import("o1js/dist/node/lib/provable/field").Field;
21
+ protocolStateRoot: import("o1js/dist/node/lib/provable/field").Field;
22
+ }, {
23
+ stateTransitionsHash: bigint;
24
+ protocolTransitionsHash: bigint;
25
+ stateRoot: bigint;
26
+ protocolStateRoot: bigint;
27
+ }>, "fromFields"> & {
28
+ fromFields: (fields: import("o1js/dist/node/lib/provable/field").Field[]) => {
29
+ stateTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
30
+ protocolTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
31
+ stateRoot: import("o1js/dist/node/lib/provable/field").Field;
32
+ protocolStateRoot: import("o1js/dist/node/lib/provable/field").Field;
33
+ };
34
+ } & {
35
+ fromValue: (value: {
36
+ stateTransitionsHash: string | number | bigint | import("o1js/dist/node/lib/provable/field").Field;
37
+ protocolTransitionsHash: string | number | bigint | import("o1js/dist/node/lib/provable/field").Field;
38
+ stateRoot: string | number | bigint | import("o1js/dist/node/lib/provable/field").Field;
39
+ protocolStateRoot: string | number | bigint | import("o1js/dist/node/lib/provable/field").Field;
40
+ }) => {
41
+ stateTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
42
+ protocolTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
43
+ stateRoot: import("o1js/dist/node/lib/provable/field").Field;
44
+ protocolStateRoot: import("o1js/dist/node/lib/provable/field").Field;
45
+ };
46
+ toInput: (x: {
47
+ stateTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
48
+ protocolTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
49
+ stateRoot: import("o1js/dist/node/lib/provable/field").Field;
50
+ protocolStateRoot: import("o1js/dist/node/lib/provable/field").Field;
51
+ }) => {
52
+ fields?: import("o1js/dist/node/lib/provable/field").Field[] | undefined;
53
+ packed?: [import("o1js/dist/node/lib/provable/field").Field, number][] | undefined;
54
+ };
55
+ toJSON: (x: {
56
+ stateTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
57
+ protocolTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
58
+ stateRoot: import("o1js/dist/node/lib/provable/field").Field;
59
+ protocolStateRoot: import("o1js/dist/node/lib/provable/field").Field;
60
+ }) => {
61
+ stateTransitionsHash: string;
62
+ protocolTransitionsHash: string;
63
+ stateRoot: string;
64
+ protocolStateRoot: string;
65
+ };
66
+ fromJSON: (x: {
67
+ stateTransitionsHash: string;
68
+ protocolTransitionsHash: string;
69
+ stateRoot: string;
70
+ protocolStateRoot: string;
71
+ }) => {
72
+ stateTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
73
+ protocolTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
74
+ stateRoot: import("o1js/dist/node/lib/provable/field").Field;
75
+ protocolStateRoot: import("o1js/dist/node/lib/provable/field").Field;
76
+ };
77
+ empty: () => {
78
+ stateTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
79
+ protocolTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
80
+ stateRoot: import("o1js/dist/node/lib/provable/field").Field;
81
+ protocolStateRoot: import("o1js/dist/node/lib/provable/field").Field;
82
+ };
83
+ };
84
+ export declare class StateTransitionProverPublicInput extends StateTransitionProverPublicInput_base {
85
+ }
86
+ declare const StateTransitionProverPublicOutput_base: (new (value: {
87
+ stateTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
88
+ protocolTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
89
+ stateRoot: import("o1js/dist/node/lib/provable/field").Field;
90
+ protocolStateRoot: import("o1js/dist/node/lib/provable/field").Field;
91
+ }) => {
92
+ stateTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
93
+ protocolTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
94
+ stateRoot: import("o1js/dist/node/lib/provable/field").Field;
95
+ protocolStateRoot: import("o1js/dist/node/lib/provable/field").Field;
96
+ }) & {
97
+ _isStruct: true;
98
+ } & Omit<import("o1js/dist/node/lib/provable/types/provable-intf").Provable<{
99
+ stateTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
100
+ protocolTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
101
+ stateRoot: import("o1js/dist/node/lib/provable/field").Field;
102
+ protocolStateRoot: import("o1js/dist/node/lib/provable/field").Field;
103
+ }, {
104
+ stateTransitionsHash: bigint;
105
+ protocolTransitionsHash: bigint;
106
+ stateRoot: bigint;
107
+ protocolStateRoot: bigint;
108
+ }>, "fromFields"> & {
109
+ fromFields: (fields: import("o1js/dist/node/lib/provable/field").Field[]) => {
110
+ stateTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
111
+ protocolTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
112
+ stateRoot: import("o1js/dist/node/lib/provable/field").Field;
113
+ protocolStateRoot: import("o1js/dist/node/lib/provable/field").Field;
114
+ };
115
+ } & {
116
+ fromValue: (value: {
117
+ stateTransitionsHash: string | number | bigint | import("o1js/dist/node/lib/provable/field").Field;
118
+ protocolTransitionsHash: string | number | bigint | import("o1js/dist/node/lib/provable/field").Field;
119
+ stateRoot: string | number | bigint | import("o1js/dist/node/lib/provable/field").Field;
120
+ protocolStateRoot: string | number | bigint | import("o1js/dist/node/lib/provable/field").Field;
121
+ }) => {
122
+ stateTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
123
+ protocolTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
124
+ stateRoot: import("o1js/dist/node/lib/provable/field").Field;
125
+ protocolStateRoot: import("o1js/dist/node/lib/provable/field").Field;
126
+ };
127
+ toInput: (x: {
128
+ stateTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
129
+ protocolTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
130
+ stateRoot: import("o1js/dist/node/lib/provable/field").Field;
131
+ protocolStateRoot: import("o1js/dist/node/lib/provable/field").Field;
132
+ }) => {
133
+ fields?: import("o1js/dist/node/lib/provable/field").Field[] | undefined;
134
+ packed?: [import("o1js/dist/node/lib/provable/field").Field, number][] | undefined;
135
+ };
136
+ toJSON: (x: {
137
+ stateTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
138
+ protocolTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
139
+ stateRoot: import("o1js/dist/node/lib/provable/field").Field;
140
+ protocolStateRoot: import("o1js/dist/node/lib/provable/field").Field;
141
+ }) => {
142
+ stateTransitionsHash: string;
143
+ protocolTransitionsHash: string;
144
+ stateRoot: string;
145
+ protocolStateRoot: string;
146
+ };
147
+ fromJSON: (x: {
148
+ stateTransitionsHash: string;
149
+ protocolTransitionsHash: string;
150
+ stateRoot: string;
151
+ protocolStateRoot: string;
152
+ }) => {
153
+ stateTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
154
+ protocolTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
155
+ stateRoot: import("o1js/dist/node/lib/provable/field").Field;
156
+ protocolStateRoot: import("o1js/dist/node/lib/provable/field").Field;
157
+ };
158
+ empty: () => {
159
+ stateTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
160
+ protocolTransitionsHash: import("o1js/dist/node/lib/provable/field").Field;
161
+ stateRoot: import("o1js/dist/node/lib/provable/field").Field;
162
+ protocolStateRoot: import("o1js/dist/node/lib/provable/field").Field;
163
+ };
164
+ };
165
+ export declare class StateTransitionProverPublicOutput extends StateTransitionProverPublicOutput_base {
166
+ }
167
+ export type StateTransitionProof = Proof<StateTransitionProverPublicInput, StateTransitionProverPublicOutput>;
168
+ export interface StateTransitionProvable extends WithZkProgrammable<StateTransitionProverPublicInput, StateTransitionProverPublicOutput> {
169
+ witnessProviderReference: StateTransitionWitnessProviderReference;
170
+ runBatch: (publicInput: StateTransitionProverPublicInput, batch: StateTransitionProvableBatch) => Promise<StateTransitionProverPublicOutput>;
171
+ merge: (publicInput: StateTransitionProverPublicInput, proof1: StateTransitionProof, proof2: StateTransitionProof) => Promise<StateTransitionProverPublicOutput>;
172
+ }
173
+ export {};
174
+ //# sourceMappingURL=StateTransitionProvable.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StateTransitionProvable.d.ts","sourceRoot":"","sources":["../../../src/prover/statetransition/StateTransitionProvable.ts"],"names":[],"mappings":"AAAA,OAAO,EAAS,KAAK,EAAU,MAAM,MAAM,CAAC;AAC5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAEvD,OAAO,EAAE,4BAA4B,EAAE,MAAM,0CAA0C,CAAC;AAExF,OAAO,EAAE,uCAAuC,EAAE,MAAM,2CAA2C,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEpG,qBAAa,gCAAiC,SAAQ,qCAKpD;CAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEL,qBAAa,iCAAkC,SAAQ,sCAKrD;CAAG;AAEL,MAAM,MAAM,oBAAoB,GAAG,KAAK,CACtC,gCAAgC,EAChC,iCAAiC,CAClC,CAAC;AAEF,MAAM,WAAW,uBACf,SAAQ,kBAAkB,CACxB,gCAAgC,EAChC,iCAAiC,CAClC;IACD,wBAAwB,EAAE,uCAAuC,CAAC;IAElE,QAAQ,EAAE,CACR,WAAW,EAAE,gCAAgC,EAC7C,KAAK,EAAE,4BAA4B,KAChC,OAAO,CAAC,iCAAiC,CAAC,CAAC;IAEhD,KAAK,EAAE,CACL,WAAW,EAAE,gCAAgC,EAC7C,MAAM,EAAE,oBAAoB,EAC5B,MAAM,EAAE,oBAAoB,KACzB,OAAO,CAAC,iCAAiC,CAAC,CAAC;CACjD"}
@@ -0,0 +1,15 @@
1
+ import { Field, Struct } from "o1js";
2
+ export class StateTransitionProverPublicInput extends Struct({
3
+ stateTransitionsHash: Field,
4
+ protocolTransitionsHash: Field,
5
+ stateRoot: Field,
6
+ protocolStateRoot: Field,
7
+ }) {
8
+ }
9
+ export class StateTransitionProverPublicOutput extends Struct({
10
+ stateTransitionsHash: Field,
11
+ protocolTransitionsHash: Field,
12
+ stateRoot: Field,
13
+ protocolStateRoot: Field,
14
+ }) {
15
+ }
@@ -0,0 +1,51 @@
1
+ import { AreProofsEnabled, PlainZkProgram, ZkProgrammable } from "@proto-kit/common";
2
+ import { Field } from "o1js";
3
+ import { ProvableStateTransition } from "../../model/StateTransition";
4
+ import { ProvableStateTransitionType, StateTransitionProvableBatch } from "../../model/StateTransitionProvableBatch";
5
+ import { StateTransitionProverType } from "../../protocol/Protocol";
6
+ import { ProtocolModule } from "../../protocol/ProtocolModule";
7
+ import { ProvableHashList } from "../../utils/ProvableHashList";
8
+ import { StateTransitionProof, StateTransitionProvable, StateTransitionProverPublicInput, StateTransitionProverPublicOutput } from "./StateTransitionProvable";
9
+ import { StateTransitionWitnessProviderReference } from "./StateTransitionWitnessProviderReference";
10
+ interface StateTransitionProverExecutionState {
11
+ stateRoot: Field;
12
+ protocolStateRoot: Field;
13
+ stateTransitionList: ProvableHashList<ProvableStateTransition>;
14
+ protocolTransitionList: ProvableHashList<ProvableStateTransition>;
15
+ }
16
+ /**
17
+ * StateTransitionProver is the prover that proves the application of some state
18
+ * transitions and checks and updates their merkle-tree entries
19
+ */
20
+ export declare class StateTransitionProverProgrammable extends ZkProgrammable<StateTransitionProverPublicInput, StateTransitionProverPublicOutput> {
21
+ private readonly stateTransitionProver;
22
+ readonly witnessProviderReference: StateTransitionWitnessProviderReference;
23
+ constructor(stateTransitionProver: StateTransitionProver, witnessProviderReference: StateTransitionWitnessProviderReference);
24
+ get appChain(): AreProofsEnabled | undefined;
25
+ zkProgramFactory(): PlainZkProgram<StateTransitionProverPublicInput, StateTransitionProverPublicOutput>[];
26
+ private get witnessProvider();
27
+ /**
28
+ * Applies the state transitions to the current stateRoot
29
+ * and returns the new prover state
30
+ */
31
+ applyTransitions(stateRoot: Field, protocolStateRoot: Field, stateTransitionCommitmentFrom: Field, protocolTransitionCommitmentFrom: Field, transitionBatch: StateTransitionProvableBatch): StateTransitionProverExecutionState;
32
+ /**
33
+ * Applies a single state transition to the given state
34
+ * and mutates it in place
35
+ */
36
+ applyTransition(state: StateTransitionProverExecutionState, transition: ProvableStateTransition, type: ProvableStateTransitionType, index?: number): void;
37
+ /**
38
+ * Applies a whole batch of StateTransitions at once
39
+ */
40
+ runBatch(publicInput: StateTransitionProverPublicInput, batch: StateTransitionProvableBatch): Promise<StateTransitionProverPublicOutput>;
41
+ merge(publicInput: StateTransitionProverPublicInput, proof1: StateTransitionProof, proof2: StateTransitionProof): Promise<StateTransitionProverPublicOutput>;
42
+ }
43
+ export declare class StateTransitionProver extends ProtocolModule implements StateTransitionProvable, StateTransitionProverType {
44
+ readonly witnessProviderReference: StateTransitionWitnessProviderReference;
45
+ zkProgrammable: StateTransitionProverProgrammable;
46
+ constructor(witnessProviderReference: StateTransitionWitnessProviderReference);
47
+ runBatch(publicInput: StateTransitionProverPublicInput, batch: StateTransitionProvableBatch): Promise<StateTransitionProverPublicOutput>;
48
+ merge(publicInput: StateTransitionProverPublicInput, proof1: StateTransitionProof, proof2: StateTransitionProof): Promise<StateTransitionProverPublicOutput>;
49
+ }
50
+ export {};
51
+ //# sourceMappingURL=StateTransitionProver.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StateTransitionProver.d.ts","sourceRoot":"","sources":["../../../src/prover/statetransition/StateTransitionProver.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,gBAAgB,EAChB,cAAc,EAGd,cAAc,EACf,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,KAAK,EAAkC,MAAM,MAAM,CAAC;AAI7D,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AACtE,OAAO,EACL,2BAA2B,EAC3B,4BAA4B,EAC7B,MAAM,0CAA0C,CAAC;AAClD,OAAO,EAAE,yBAAyB,EAAE,MAAM,yBAAyB,CAAC;AACpE,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAEL,gBAAgB,EACjB,MAAM,8BAA8B,CAAC;AAEtC,OAAO,EACL,oBAAoB,EACpB,uBAAuB,EACvB,gCAAgC,EAChC,iCAAiC,EAClC,MAAM,2BAA2B,CAAC;AAEnC,OAAO,EAAE,uCAAuC,EAAE,MAAM,2CAA2C,CAAC;AAepG,UAAU,mCAAmC;IAC3C,SAAS,EAAE,KAAK,CAAC;IACjB,iBAAiB,EAAE,KAAK,CAAC;IACzB,mBAAmB,EAAE,gBAAgB,CAAC,uBAAuB,CAAC,CAAC;IAC/D,sBAAsB,EAAE,gBAAgB,CAAC,uBAAuB,CAAC,CAAC;CACnE;AAOD;;;GAGG;AACH,qBAAa,iCAAkC,SAAQ,cAAc,CACnE,gCAAgC,EAChC,iCAAiC,CAClC;IAEG,OAAO,CAAC,QAAQ,CAAC,qBAAqB;aACtB,wBAAwB,EAAE,uCAAuC;gBADhE,qBAAqB,EAAE,qBAAqB,EAC7C,wBAAwB,EAAE,uCAAuC;IAKnF,IAAW,QAAQ,IAAI,gBAAgB,GAAG,SAAS,CAElD;IAEM,gBAAgB,IAAI,cAAc,CACvC,gCAAgC,EAChC,iCAAiC,CAClC,EAAE;IAuDH,OAAO,KAAK,eAAe,GAM1B;IAED;;;OAGG;IACI,gBAAgB,CACrB,SAAS,EAAE,KAAK,EAChB,iBAAiB,EAAE,KAAK,EACxB,6BAA6B,EAAE,KAAK,EACpC,gCAAgC,EAAE,KAAK,EACvC,eAAe,EAAE,4BAA4B,GAC5C,mCAAmC;IA6BtC;;;OAGG;IACI,eAAe,CACpB,KAAK,EAAE,mCAAmC,EAC1C,UAAU,EAAE,uBAAuB,EACnC,IAAI,EAAE,2BAA2B,EACjC,KAAK,SAAI;IAiDX;;OAEG;IAEU,QAAQ,CACnB,WAAW,EAAE,gCAAgC,EAC7C,KAAK,EAAE,4BAA4B,GAClC,OAAO,CAAC,iCAAiC,CAAC;IAkBhC,KAAK,CAChB,WAAW,EAAE,gCAAgC,EAC7C,MAAM,EAAE,oBAAoB,EAC5B,MAAM,EAAE,oBAAoB,GAC3B,OAAO,CAAC,iCAAiC,CAAC;CAqE9C;AAED,qBACa,qBACX,SAAQ,cACR,YAAW,uBAAuB,EAAE,yBAAyB;aAM3C,wBAAwB,EAAE,uCAAuC;IAJ5E,cAAc,EAAE,iCAAiC,CAAC;gBAIvC,wBAAwB,EAAE,uCAAuC;IAS5E,QAAQ,CACb,WAAW,EAAE,gCAAgC,EAC7C,KAAK,EAAE,4BAA4B,GAClC,OAAO,CAAC,iCAAiC,CAAC;IAItC,KAAK,CACV,WAAW,EAAE,gCAAgC,EAC7C,MAAM,EAAE,oBAAoB,EAC5B,MAAM,EAAE,oBAAoB,GAC3B,OAAO,CAAC,iCAAiC,CAAC;CAG9C"}
@@ -0,0 +1,188 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ var __metadata = (this && this.__metadata) || function (k, v) {
8
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
9
+ };
10
+ import { provableMethod, RollupMerkleTreeWitness, ZkProgrammable, } from "@proto-kit/common";
11
+ import { Field, Provable, SelfProof, ZkProgram } from "o1js";
12
+ import { injectable } from "tsyringe";
13
+ import { constants } from "../../Constants";
14
+ import { ProvableStateTransition } from "../../model/StateTransition";
15
+ import { StateTransitionProvableBatch, } from "../../model/StateTransitionProvableBatch";
16
+ import { ProtocolModule } from "../../protocol/ProtocolModule";
17
+ import { DefaultProvableHashList, } from "../../utils/ProvableHashList";
18
+ import { StateTransitionProverPublicInput, StateTransitionProverPublicOutput, } from "./StateTransitionProvable";
19
+ import { StateTransitionWitnessProviderReference } from "./StateTransitionWitnessProviderReference";
20
+ const errors = {
21
+ propertyNotMatching: (property, step) => `${property} not matching ${step}`,
22
+ merkleWitnessNotCorrect: (index, type) => `MerkleWitness not valid for StateTransition (${index}, type ${type})`,
23
+ noWitnessProviderSet: () => new Error("WitnessProvider not set, set it before you use StateTransitionProvider"),
24
+ };
25
+ const StateTransitionSelfProofClass = (SelfProof);
26
+ /**
27
+ * StateTransitionProver is the prover that proves the application of some state
28
+ * transitions and checks and updates their merkle-tree entries
29
+ */
30
+ export class StateTransitionProverProgrammable extends ZkProgrammable {
31
+ constructor(stateTransitionProver, witnessProviderReference) {
32
+ super();
33
+ this.stateTransitionProver = stateTransitionProver;
34
+ this.witnessProviderReference = witnessProviderReference;
35
+ }
36
+ get appChain() {
37
+ return this.stateTransitionProver.appChain;
38
+ }
39
+ zkProgramFactory() {
40
+ const instance = this;
41
+ const program = ZkProgram({
42
+ name: "StateTransitionProver",
43
+ publicInput: StateTransitionProverPublicInput,
44
+ publicOutput: StateTransitionProverPublicOutput,
45
+ methods: {
46
+ proveBatch: {
47
+ privateInputs: [StateTransitionProvableBatch],
48
+ async method(publicInput, batch) {
49
+ return await instance.runBatch(publicInput, batch);
50
+ },
51
+ },
52
+ merge: {
53
+ privateInputs: [
54
+ StateTransitionSelfProofClass,
55
+ StateTransitionSelfProofClass,
56
+ ],
57
+ async method(publicInput, proof1, proof2) {
58
+ return await instance.merge(publicInput, proof1, proof2);
59
+ },
60
+ },
61
+ },
62
+ });
63
+ const methods = {
64
+ proveBatch: program.proveBatch.bind(program),
65
+ merge: program.merge.bind(program),
66
+ };
67
+ const SelfProofClass = ZkProgram.Proof(program);
68
+ return [
69
+ {
70
+ compile: program.compile.bind(program),
71
+ verify: program.verify.bind(program),
72
+ analyzeMethods: program.analyzeMethods.bind(program),
73
+ Proof: SelfProofClass,
74
+ methods,
75
+ },
76
+ ];
77
+ }
78
+ get witnessProvider() {
79
+ const provider = this.witnessProviderReference.getWitnessProvider();
80
+ if (provider === undefined) {
81
+ throw errors.noWitnessProviderSet();
82
+ }
83
+ return provider;
84
+ }
85
+ /**
86
+ * Applies the state transitions to the current stateRoot
87
+ * and returns the new prover state
88
+ */
89
+ applyTransitions(stateRoot, protocolStateRoot, stateTransitionCommitmentFrom, protocolTransitionCommitmentFrom, transitionBatch) {
90
+ const state = {
91
+ stateRoot,
92
+ protocolStateRoot,
93
+ stateTransitionList: new DefaultProvableHashList(ProvableStateTransition, stateTransitionCommitmentFrom),
94
+ protocolTransitionList: new DefaultProvableHashList(ProvableStateTransition, protocolTransitionCommitmentFrom),
95
+ };
96
+ const transitions = transitionBatch.batch;
97
+ const types = transitionBatch.transitionTypes;
98
+ for (let index = 0; index < constants.stateTransitionProverBatchSize; index++) {
99
+ this.applyTransition(state, transitions[index], types[index], index);
100
+ }
101
+ return state;
102
+ }
103
+ /**
104
+ * Applies a single state transition to the given state
105
+ * and mutates it in place
106
+ */
107
+ applyTransition(state, transition, type, index = 0) {
108
+ const witness = Provable.witness(RollupMerkleTreeWitness, () => this.witnessProvider.getWitness(transition.path));
109
+ const membershipValid = witness.checkMembership(state.stateRoot, transition.path, transition.from.value);
110
+ membershipValid
111
+ .or(transition.from.isSome.not())
112
+ .assertTrue(errors.merkleWitnessNotCorrect(index, type.isNormal().toBoolean() ? "normal" : "protocol"));
113
+ const newRoot = witness.calculateRoot(transition.to.value);
114
+ state.stateRoot = Provable.if(transition.to.isSome, newRoot, state.stateRoot);
115
+ // Only update protocol state root if ST is also of type protocol
116
+ // Since protocol STs are all at the start of the batch, this works
117
+ state.protocolStateRoot = Provable.if(transition.to.isSome.and(type.isProtocol()), newRoot, state.protocolStateRoot);
118
+ const isNotDummy = transition.path.equals(Field(0)).not();
119
+ state.stateTransitionList.pushIf(transition, isNotDummy.and(type.isNormal()));
120
+ state.protocolTransitionList.pushIf(transition, isNotDummy.and(type.isProtocol()));
121
+ }
122
+ /**
123
+ * Applies a whole batch of StateTransitions at once
124
+ */
125
+ async runBatch(publicInput, batch) {
126
+ const result = this.applyTransitions(publicInput.stateRoot, publicInput.protocolStateRoot, publicInput.stateTransitionsHash, publicInput.protocolTransitionsHash, batch);
127
+ return new StateTransitionProverPublicOutput({
128
+ stateRoot: result.stateRoot,
129
+ stateTransitionsHash: result.stateTransitionList.commitment,
130
+ protocolTransitionsHash: result.protocolTransitionList.commitment,
131
+ protocolStateRoot: result.protocolStateRoot,
132
+ });
133
+ }
134
+ async merge(publicInput, proof1, proof2) {
135
+ proof1.verify();
136
+ proof2.verify();
137
+ // Check state
138
+ publicInput.stateRoot.assertEquals(proof1.publicInput.stateRoot, errors.propertyNotMatching("stateRoot", "publicInput.from -> proof1.from"));
139
+ proof1.publicOutput.stateRoot.assertEquals(proof2.publicInput.stateRoot, errors.propertyNotMatching("stateRoot", "proof1.to -> proof2.from"));
140
+ // Check ST list
141
+ publicInput.stateTransitionsHash.assertEquals(proof1.publicInput.stateTransitionsHash, errors.propertyNotMatching("stateTransitionsHash", "publicInput.from -> proof1.from"));
142
+ proof1.publicOutput.stateTransitionsHash.assertEquals(proof2.publicInput.stateTransitionsHash, errors.propertyNotMatching("stateTransitionsHash", "proof1.to -> proof2.from"));
143
+ // Check Protocol ST list
144
+ publicInput.protocolTransitionsHash.assertEquals(proof1.publicInput.protocolTransitionsHash, errors.propertyNotMatching("protocolTransitionsHash", "publicInput.from -> proof1.from"));
145
+ proof1.publicOutput.protocolTransitionsHash.assertEquals(proof2.publicInput.protocolTransitionsHash, errors.propertyNotMatching("protocolTransitionsHash", "proof1.to -> proof2.from"));
146
+ // Check protocol state root
147
+ publicInput.protocolStateRoot.assertEquals(proof1.publicInput.protocolStateRoot, errors.propertyNotMatching("protocolStateRoot", "publicInput.from -> proof1.from"));
148
+ proof1.publicOutput.protocolStateRoot.assertEquals(proof2.publicInput.protocolStateRoot, errors.propertyNotMatching("protocolStateRoot", "proof1.to -> proof2.from"));
149
+ return new StateTransitionProverPublicInput({
150
+ stateRoot: proof2.publicOutput.stateRoot,
151
+ stateTransitionsHash: proof2.publicOutput.stateTransitionsHash,
152
+ protocolTransitionsHash: proof2.publicOutput.protocolTransitionsHash,
153
+ protocolStateRoot: proof2.publicOutput.protocolStateRoot,
154
+ });
155
+ }
156
+ }
157
+ __decorate([
158
+ provableMethod(),
159
+ __metadata("design:type", Function),
160
+ __metadata("design:paramtypes", [StateTransitionProverPublicInput,
161
+ StateTransitionProvableBatch]),
162
+ __metadata("design:returntype", Promise)
163
+ ], StateTransitionProverProgrammable.prototype, "runBatch", null);
164
+ __decorate([
165
+ provableMethod(),
166
+ __metadata("design:type", Function),
167
+ __metadata("design:paramtypes", [StateTransitionProverPublicInput, Object, Object]),
168
+ __metadata("design:returntype", Promise)
169
+ ], StateTransitionProverProgrammable.prototype, "merge", null);
170
+ export let StateTransitionProver = class StateTransitionProver extends ProtocolModule {
171
+ constructor(
172
+ // Injected
173
+ witnessProviderReference) {
174
+ super();
175
+ this.witnessProviderReference = witnessProviderReference;
176
+ this.zkProgrammable = new StateTransitionProverProgrammable(this, witnessProviderReference);
177
+ }
178
+ runBatch(publicInput, batch) {
179
+ return this.zkProgrammable.runBatch(publicInput, batch);
180
+ }
181
+ merge(publicInput, proof1, proof2) {
182
+ return this.zkProgrammable.merge(publicInput, proof1, proof2);
183
+ }
184
+ };
185
+ StateTransitionProver = __decorate([
186
+ injectable(),
187
+ __metadata("design:paramtypes", [StateTransitionWitnessProviderReference])
188
+ ], StateTransitionProver);