@proto-kit/protocol 0.1.1-develop.191 → 0.1.1-develop.2024
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.
- package/dist/Constants.js +1 -0
- package/dist/Constants.js.map +1 -0
- package/dist/hashing/mina-prefixes.d.ts +10 -0
- package/dist/hashing/mina-prefixes.d.ts.map +1 -0
- package/dist/hashing/mina-prefixes.js +10 -0
- package/dist/hashing/mina-prefixes.js.map +1 -0
- package/dist/hashing/protokit-prefixes.d.ts +10 -0
- package/dist/hashing/protokit-prefixes.d.ts.map +1 -0
- package/dist/hashing/protokit-prefixes.js +24 -0
- package/dist/hashing/protokit-prefixes.js.map +1 -0
- package/dist/hooks/AccountStateHook.d.ts +56 -0
- package/dist/hooks/AccountStateHook.d.ts.map +1 -0
- package/dist/hooks/AccountStateHook.js +62 -0
- package/dist/hooks/AccountStateHook.js.map +1 -0
- package/dist/hooks/BlockHeightHook.d.ts +7 -0
- package/dist/hooks/BlockHeightHook.d.ts.map +1 -0
- package/dist/hooks/BlockHeightHook.js +16 -0
- package/dist/hooks/BlockHeightHook.js.map +1 -0
- package/dist/hooks/LastStateRootBlockHook.d.ts +7 -0
- package/dist/hooks/LastStateRootBlockHook.d.ts.map +1 -0
- package/dist/hooks/LastStateRootBlockHook.js +16 -0
- package/dist/hooks/LastStateRootBlockHook.js.map +1 -0
- package/dist/hooks/NoopBlockHook.d.ts +8 -0
- package/dist/hooks/NoopBlockHook.d.ts.map +1 -0
- package/dist/hooks/NoopBlockHook.js +10 -0
- package/dist/hooks/NoopBlockHook.js.map +1 -0
- package/dist/hooks/NoopSettlementHook.d.ts +6 -0
- package/dist/hooks/NoopSettlementHook.d.ts.map +1 -0
- package/dist/{prover/statetransition/StateTransitionWitnessProvider.js → hooks/NoopSettlementHook.js} +8 -7
- package/dist/hooks/NoopSettlementHook.js.map +1 -0
- package/dist/hooks/NoopTransactionHook.d.ts +6 -0
- package/dist/hooks/NoopTransactionHook.d.ts.map +1 -0
- package/dist/hooks/NoopTransactionHook.js +11 -0
- package/dist/hooks/NoopTransactionHook.js.map +1 -0
- package/dist/index.d.ts +59 -9
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +60 -9
- package/dist/index.js.map +1 -0
- package/dist/model/AppliedStateTransitionBatch.d.ts +114 -0
- package/dist/model/AppliedStateTransitionBatch.d.ts.map +1 -0
- package/dist/model/AppliedStateTransitionBatch.js +16 -0
- package/dist/model/AppliedStateTransitionBatch.js.map +1 -0
- package/dist/model/MethodPublicOutput.d.ts +83 -28
- package/dist/model/MethodPublicOutput.d.ts.map +1 -1
- package/dist/model/MethodPublicOutput.js +4 -1
- package/dist/model/MethodPublicOutput.js.map +1 -0
- package/dist/model/Option.d.ts +70 -46
- package/dist/model/Option.d.ts.map +1 -1
- package/dist/model/Option.js +62 -57
- package/dist/model/Option.js.map +1 -0
- package/dist/model/Path.d.ts +4 -3
- package/dist/model/Path.d.ts.map +1 -1
- package/dist/model/Path.js +6 -5
- package/dist/model/Path.js.map +1 -0
- package/dist/model/RuntimeLike.d.ts +11 -0
- package/dist/model/RuntimeLike.d.ts.map +1 -0
- package/dist/model/RuntimeLike.js +2 -0
- package/dist/model/RuntimeLike.js.map +1 -0
- package/dist/model/StateTransition.d.ts +58 -18
- package/dist/model/StateTransition.d.ts.map +1 -1
- package/dist/model/StateTransition.js +13 -4
- package/dist/model/StateTransition.js.map +1 -0
- package/dist/model/StateTransitionProvableBatch.d.ts +389 -16
- package/dist/model/StateTransitionProvableBatch.d.ts.map +1 -1
- package/dist/model/StateTransitionProvableBatch.js +87 -10
- package/dist/model/StateTransitionProvableBatch.js.map +1 -0
- package/dist/model/network/NetworkState.d.ts +105 -9
- package/dist/model/network/NetworkState.d.ts.map +1 -1
- package/dist/model/network/NetworkState.js +22 -2
- package/dist/model/network/NetworkState.js.map +1 -0
- package/dist/model/transaction/AuthorizedTransaction.d.ts +122 -0
- package/dist/model/transaction/AuthorizedTransaction.d.ts.map +1 -0
- package/dist/model/transaction/AuthorizedTransaction.js +39 -0
- package/dist/model/transaction/AuthorizedTransaction.js.map +1 -0
- package/dist/model/transaction/RuntimeTransaction.d.ts +94 -34
- package/dist/model/transaction/RuntimeTransaction.d.ts.map +1 -1
- package/dist/model/transaction/RuntimeTransaction.js +72 -11
- package/dist/model/transaction/RuntimeTransaction.js.map +1 -0
- package/dist/model/transaction/SignedTransaction.d.ts +110 -0
- package/dist/model/transaction/SignedTransaction.d.ts.map +1 -0
- package/dist/model/transaction/SignedTransaction.js +34 -0
- package/dist/model/transaction/SignedTransaction.js.map +1 -0
- package/dist/model/transaction/ValueOption.d.ts +187 -0
- package/dist/model/transaction/ValueOption.d.ts.map +1 -0
- package/dist/model/transaction/ValueOption.js +25 -0
- package/dist/model/transaction/ValueOption.js.map +1 -0
- package/dist/protocol/Protocol.d.ts +47 -21
- package/dist/protocol/Protocol.d.ts.map +1 -1
- package/dist/protocol/Protocol.js +127 -26
- package/dist/protocol/Protocol.js.map +1 -0
- package/dist/protocol/ProtocolEnvironment.d.ts +9 -0
- package/dist/protocol/ProtocolEnvironment.d.ts.map +1 -0
- package/dist/protocol/ProtocolEnvironment.js +2 -0
- package/dist/protocol/ProtocolEnvironment.js.map +1 -0
- package/dist/protocol/ProtocolModule.d.ts +7 -7
- package/dist/protocol/ProtocolModule.d.ts.map +1 -1
- package/dist/protocol/ProtocolModule.js +10 -7
- package/dist/protocol/ProtocolModule.js.map +1 -0
- package/dist/protocol/ProvableBlockHook.d.ts +29 -0
- package/dist/protocol/ProvableBlockHook.d.ts.map +1 -0
- package/dist/protocol/ProvableBlockHook.js +20 -0
- package/dist/protocol/ProvableBlockHook.js.map +1 -0
- package/dist/protocol/ProvableTransactionHook.d.ts +35 -0
- package/dist/protocol/ProvableTransactionHook.d.ts.map +1 -0
- package/dist/protocol/ProvableTransactionHook.js +28 -0
- package/dist/protocol/ProvableTransactionHook.js.map +1 -0
- package/dist/protocol/TransitioningProtocolModule.d.ts +10 -0
- package/dist/protocol/TransitioningProtocolModule.d.ts.map +1 -0
- package/dist/protocol/TransitioningProtocolModule.js +9 -0
- package/dist/protocol/TransitioningProtocolModule.js.map +1 -0
- package/dist/prover/accumulators/AppliedBatchHashList.d.ts +18 -0
- package/dist/prover/accumulators/AppliedBatchHashList.d.ts.map +1 -0
- package/dist/prover/accumulators/AppliedBatchHashList.js +25 -0
- package/dist/prover/accumulators/AppliedBatchHashList.js.map +1 -0
- package/dist/prover/accumulators/BlockHashList.d.ts +263 -0
- package/dist/prover/accumulators/BlockHashList.d.ts.map +1 -0
- package/dist/prover/accumulators/BlockHashList.js +97 -0
- package/dist/prover/accumulators/BlockHashList.js.map +1 -0
- package/dist/prover/accumulators/StateTransitionReductionList.d.ts +12 -0
- package/dist/prover/accumulators/StateTransitionReductionList.d.ts.map +1 -0
- package/dist/prover/accumulators/StateTransitionReductionList.js +64 -0
- package/dist/prover/accumulators/StateTransitionReductionList.js.map +1 -0
- package/dist/prover/accumulators/TransactionHashList.d.ts +6 -0
- package/dist/prover/accumulators/TransactionHashList.d.ts.map +1 -0
- package/dist/prover/accumulators/TransactionHashList.js +8 -0
- package/dist/prover/accumulators/TransactionHashList.js.map +1 -0
- package/dist/prover/accumulators/WitnessedRootHashList.d.ts +123 -0
- package/dist/prover/accumulators/WitnessedRootHashList.d.ts.map +1 -0
- package/dist/prover/accumulators/WitnessedRootHashList.js +51 -0
- package/dist/prover/accumulators/WitnessedRootHashList.js.map +1 -0
- package/dist/prover/block/BlockProvable.d.ts +565 -96
- package/dist/prover/block/BlockProvable.d.ts.map +1 -1
- package/dist/prover/block/BlockProvable.js +196 -12
- package/dist/prover/block/BlockProvable.js.map +1 -0
- package/dist/prover/block/BlockProver.d.ts +52 -37
- package/dist/prover/block/BlockProver.d.ts.map +1 -1
- package/dist/prover/block/BlockProver.js +327 -107
- package/dist/prover/block/BlockProver.js.map +1 -0
- package/dist/prover/block/accummulators/BlockHashMerkleTree.d.ts +106 -0
- package/dist/prover/block/accummulators/BlockHashMerkleTree.d.ts.map +1 -0
- package/dist/prover/block/accummulators/BlockHashMerkleTree.js +25 -0
- package/dist/prover/block/accummulators/BlockHashMerkleTree.js.map +1 -0
- package/dist/prover/block/accummulators/RuntimeVerificationKeyTree.d.ts +139 -0
- package/dist/prover/block/accummulators/RuntimeVerificationKeyTree.d.ts.map +1 -0
- package/dist/prover/block/accummulators/RuntimeVerificationKeyTree.js +21 -0
- package/dist/prover/block/accummulators/RuntimeVerificationKeyTree.js.map +1 -0
- package/dist/prover/block/services/RuntimeVerificationKeyRootService.d.ts +7 -0
- package/dist/prover/block/services/RuntimeVerificationKeyRootService.d.ts.map +1 -0
- package/dist/prover/{statetransition/StateTransitionWitnessProviderReference.js → block/services/RuntimeVerificationKeyRootService.js} +11 -8
- package/dist/prover/block/services/RuntimeVerificationKeyRootService.js.map +1 -0
- package/dist/prover/statetransition/StateTransitionProvable.d.ts +137 -48
- package/dist/prover/statetransition/StateTransitionProvable.d.ts.map +1 -1
- package/dist/prover/statetransition/StateTransitionProvable.js +10 -5
- package/dist/prover/statetransition/StateTransitionProvable.js.map +1 -0
- package/dist/prover/statetransition/StateTransitionProver.d.ts +29 -17
- package/dist/prover/statetransition/StateTransitionProver.d.ts.map +1 -1
- package/dist/prover/statetransition/StateTransitionProver.js +171 -73
- package/dist/prover/statetransition/StateTransitionProver.js.map +1 -0
- package/dist/prover/transaction/TransactionProvable.d.ts +626 -0
- package/dist/prover/transaction/TransactionProvable.d.ts.map +1 -0
- package/dist/prover/transaction/TransactionProvable.js +87 -0
- package/dist/prover/transaction/TransactionProvable.js.map +1 -0
- package/dist/prover/transaction/TransactionProver.d.ts +68 -0
- package/dist/prover/transaction/TransactionProver.d.ts.map +1 -0
- package/dist/prover/transaction/TransactionProver.js +301 -0
- package/dist/prover/transaction/TransactionProver.js.map +1 -0
- package/dist/prover/utils.d.ts +19 -0
- package/dist/prover/utils.d.ts.map +1 -0
- package/dist/prover/utils.js +67 -0
- package/dist/prover/utils.js.map +1 -0
- package/dist/settlement/ContractArgsRegistry.d.ts +13 -0
- package/dist/settlement/ContractArgsRegistry.d.ts.map +1 -0
- package/dist/settlement/ContractArgsRegistry.js +53 -0
- package/dist/settlement/ContractArgsRegistry.js.map +1 -0
- package/dist/settlement/ContractModule.d.ts +16 -0
- package/dist/settlement/ContractModule.d.ts.map +1 -0
- package/dist/settlement/ContractModule.js +12 -0
- package/dist/settlement/ContractModule.js.map +1 -0
- package/dist/settlement/SettlementContractModule.d.ts +47 -0
- package/dist/settlement/SettlementContractModule.d.ts.map +1 -0
- package/dist/settlement/SettlementContractModule.js +81 -0
- package/dist/settlement/SettlementContractModule.js.map +1 -0
- package/dist/settlement/contracts/BridgeContract.d.ts +119 -0
- package/dist/settlement/contracts/BridgeContract.d.ts.map +1 -0
- package/dist/settlement/contracts/BridgeContract.js +269 -0
- package/dist/settlement/contracts/BridgeContract.js.map +1 -0
- package/dist/settlement/contracts/BridgeContractProtocolModule.d.ts +18 -0
- package/dist/settlement/contracts/BridgeContractProtocolModule.d.ts.map +1 -0
- package/dist/settlement/contracts/BridgeContractProtocolModule.js +42 -0
- package/dist/settlement/contracts/BridgeContractProtocolModule.js.map +1 -0
- package/dist/settlement/contracts/BridgingSettlementContractModule.d.ts +21 -0
- package/dist/settlement/contracts/BridgingSettlementContractModule.d.ts.map +1 -0
- package/dist/settlement/contracts/BridgingSettlementContractModule.js +81 -0
- package/dist/settlement/contracts/BridgingSettlementContractModule.js.map +1 -0
- package/dist/settlement/contracts/DispatchContractProtocolModule.d.ts +23 -0
- package/dist/settlement/contracts/DispatchContractProtocolModule.d.ts.map +1 -0
- package/dist/settlement/contracts/DispatchContractProtocolModule.js +55 -0
- package/dist/settlement/contracts/DispatchContractProtocolModule.js.map +1 -0
- package/dist/settlement/contracts/DispatchSmartContract.d.ts +50 -0
- package/dist/settlement/contracts/DispatchSmartContract.d.ts.map +1 -0
- package/dist/settlement/contracts/DispatchSmartContract.js +234 -0
- package/dist/settlement/contracts/DispatchSmartContract.js.map +1 -0
- package/dist/settlement/contracts/SettlementContractProtocolModule.d.ts +21 -0
- package/dist/settlement/contracts/SettlementContractProtocolModule.d.ts.map +1 -0
- package/dist/settlement/contracts/SettlementContractProtocolModule.js +84 -0
- package/dist/settlement/contracts/SettlementContractProtocolModule.js.map +1 -0
- package/dist/settlement/contracts/SettlementSmartContract.d.ts +123 -0
- package/dist/settlement/contracts/SettlementSmartContract.d.ts.map +1 -0
- package/dist/settlement/contracts/SettlementSmartContract.js +310 -0
- package/dist/settlement/contracts/SettlementSmartContract.js.map +1 -0
- package/dist/settlement/contracts/SettlementSmartContractModule.d.ts +20 -0
- package/dist/settlement/contracts/SettlementSmartContractModule.d.ts.map +1 -0
- package/dist/settlement/contracts/SettlementSmartContractModule.js +56 -0
- package/dist/settlement/contracts/SettlementSmartContractModule.js.map +1 -0
- package/dist/settlement/contracts/TokenBridgeTree.d.ts +228 -0
- package/dist/settlement/contracts/TokenBridgeTree.d.ts.map +1 -0
- package/dist/settlement/contracts/TokenBridgeTree.js +60 -0
- package/dist/settlement/contracts/TokenBridgeTree.js.map +1 -0
- package/dist/settlement/contracts/authorizations/ContractAuthorization.d.ts +10 -0
- package/dist/settlement/contracts/authorizations/ContractAuthorization.d.ts.map +1 -0
- package/dist/settlement/contracts/authorizations/ContractAuthorization.js +2 -0
- package/dist/settlement/contracts/authorizations/ContractAuthorization.js.map +1 -0
- package/dist/settlement/contracts/authorizations/TokenBridgeDeploymentAuth.d.ts +85 -0
- package/dist/settlement/contracts/authorizations/TokenBridgeDeploymentAuth.d.ts.map +1 -0
- package/dist/settlement/contracts/authorizations/TokenBridgeDeploymentAuth.js +11 -0
- package/dist/settlement/contracts/authorizations/TokenBridgeDeploymentAuth.js.map +1 -0
- package/dist/settlement/contracts/authorizations/UpdateMessagesHashAuth.d.ts +79 -0
- package/dist/settlement/contracts/authorizations/UpdateMessagesHashAuth.d.ts.map +1 -0
- package/dist/settlement/contracts/authorizations/UpdateMessagesHashAuth.js +11 -0
- package/dist/settlement/contracts/authorizations/UpdateMessagesHashAuth.js.map +1 -0
- package/dist/settlement/contracts/settlement/BridgingSettlementContract.d.ts +107 -0
- package/dist/settlement/contracts/settlement/BridgingSettlementContract.d.ts.map +1 -0
- package/dist/settlement/contracts/settlement/BridgingSettlementContract.js +188 -0
- package/dist/settlement/contracts/settlement/BridgingSettlementContract.js.map +1 -0
- package/dist/settlement/contracts/settlement/SettlementBase.d.ts +41 -0
- package/dist/settlement/contracts/settlement/SettlementBase.d.ts.map +1 -0
- package/dist/settlement/contracts/settlement/SettlementBase.js +105 -0
- package/dist/settlement/contracts/settlement/SettlementBase.js.map +1 -0
- package/dist/settlement/contracts/settlement/SettlementContract.d.ts +15 -0
- package/dist/settlement/contracts/settlement/SettlementContract.d.ts.map +1 -0
- package/dist/settlement/contracts/settlement/SettlementContract.js +72 -0
- package/dist/settlement/contracts/settlement/SettlementContract.js.map +1 -0
- package/dist/settlement/messages/Deposit.d.ts +77 -0
- package/dist/settlement/messages/Deposit.d.ts.map +1 -0
- package/dist/settlement/messages/Deposit.js +8 -0
- package/dist/settlement/messages/Deposit.js.map +1 -0
- package/dist/settlement/messages/OutgoingMessage.d.ts +67 -0
- package/dist/settlement/messages/OutgoingMessage.d.ts.map +1 -0
- package/dist/settlement/messages/OutgoingMessage.js +7 -0
- package/dist/settlement/messages/OutgoingMessage.js.map +1 -0
- package/dist/settlement/messages/OutgoingMessageArgument.d.ts +494 -0
- package/dist/settlement/messages/OutgoingMessageArgument.d.ts.map +1 -0
- package/dist/settlement/messages/OutgoingMessageArgument.js +40 -0
- package/dist/settlement/messages/OutgoingMessageArgument.js.map +1 -0
- package/dist/settlement/messages/Withdrawal.d.ts +2 -0
- package/dist/settlement/messages/Withdrawal.d.ts.map +1 -0
- package/dist/settlement/messages/Withdrawal.js +3 -0
- package/dist/settlement/messages/Withdrawal.js.map +1 -0
- package/dist/settlement/modularity/OutgoingMessageProcessor.d.ts +25 -0
- package/dist/settlement/modularity/OutgoingMessageProcessor.d.ts.map +1 -0
- package/dist/settlement/modularity/OutgoingMessageProcessor.js +30 -0
- package/dist/settlement/modularity/OutgoingMessageProcessor.js.map +1 -0
- package/dist/settlement/modularity/ProvableSettlementHook.d.ts +26 -0
- package/dist/settlement/modularity/ProvableSettlementHook.d.ts.map +1 -0
- package/dist/settlement/modularity/ProvableSettlementHook.js +4 -0
- package/dist/settlement/modularity/ProvableSettlementHook.js.map +1 -0
- package/dist/settlement/modularity/types.d.ts +9 -0
- package/dist/settlement/modularity/types.d.ts.map +1 -0
- package/dist/settlement/modularity/types.js +2 -0
- package/dist/settlement/modularity/types.js.map +1 -0
- package/dist/settlement/modules/NetworkStateSettlementModule.d.ts +11 -0
- package/dist/settlement/modules/NetworkStateSettlementModule.d.ts.map +1 -0
- package/dist/settlement/modules/NetworkStateSettlementModule.js +15 -0
- package/dist/settlement/modules/NetworkStateSettlementModule.js.map +1 -0
- package/dist/state/SimpleAsyncStateService.d.ts +6 -0
- package/dist/state/SimpleAsyncStateService.d.ts.map +1 -0
- package/dist/state/SimpleAsyncStateService.js +2 -0
- package/dist/state/SimpleAsyncStateService.js.map +1 -0
- package/dist/state/State.d.ts +68 -0
- package/dist/state/State.d.ts.map +1 -0
- package/dist/state/State.js +141 -0
- package/dist/state/State.js.map +1 -0
- package/dist/state/StateMap.d.ts +37 -0
- package/dist/state/StateMap.d.ts.map +1 -0
- package/dist/state/StateMap.js +56 -0
- package/dist/state/StateMap.js.map +1 -0
- package/dist/state/StateService.d.ts +6 -0
- package/dist/state/StateService.d.ts.map +1 -0
- package/dist/state/StateService.js +2 -0
- package/dist/state/StateService.js.map +1 -0
- package/dist/state/StateServiceProvider.d.ts +8 -0
- package/dist/state/StateServiceProvider.d.ts.map +1 -0
- package/dist/state/StateServiceProvider.js +37 -0
- package/dist/state/StateServiceProvider.js.map +1 -0
- package/dist/state/WitnessBlockContext.d.ts +5 -0
- package/dist/state/WitnessBlockContext.d.ts.map +1 -0
- package/dist/state/WitnessBlockContext.js +42 -0
- package/dist/state/WitnessBlockContext.js.map +1 -0
- package/dist/state/assert/assert.d.ts +12 -0
- package/dist/state/assert/assert.d.ts.map +1 -0
- package/dist/state/assert/assert.js +33 -0
- package/dist/state/assert/assert.js.map +1 -0
- package/dist/state/context/RuntimeMethodExecutionContext.d.ts +193 -0
- package/dist/state/context/RuntimeMethodExecutionContext.d.ts.map +1 -0
- package/dist/state/context/RuntimeMethodExecutionContext.js +138 -0
- package/dist/state/context/RuntimeMethodExecutionContext.js.map +1 -0
- package/dist/state/context/TransitionMethodExecutionContext.d.ts +23 -0
- package/dist/state/context/TransitionMethodExecutionContext.d.ts.map +1 -0
- package/dist/state/context/TransitionMethodExecutionContext.js +6 -0
- package/dist/state/context/TransitionMethodExecutionContext.js.map +1 -0
- package/dist/state/protocol/ProtocolState.d.ts +13 -0
- package/dist/state/protocol/ProtocolState.d.ts.map +1 -0
- package/dist/state/protocol/ProtocolState.js +58 -0
- package/dist/state/protocol/ProtocolState.js.map +1 -0
- package/dist/utils/FieldOptions.d.ts +62 -0
- package/dist/utils/FieldOptions.d.ts.map +1 -0
- package/dist/utils/FieldOptions.js +13 -0
- package/dist/utils/FieldOptions.js.map +1 -0
- package/dist/utils/MinaPrefixedProvableHashList.d.ts +20 -0
- package/dist/utils/MinaPrefixedProvableHashList.d.ts.map +1 -0
- package/dist/utils/MinaPrefixedProvableHashList.js +49 -0
- package/dist/utils/MinaPrefixedProvableHashList.js.map +1 -0
- package/dist/utils/PrefixedProvableHashList.d.ts +3 -2
- package/dist/utils/PrefixedProvableHashList.d.ts.map +1 -1
- package/dist/utils/PrefixedProvableHashList.js +5 -1
- package/dist/utils/PrefixedProvableHashList.js.map +1 -0
- package/dist/utils/ProvableHashList.d.ts +27 -4
- package/dist/utils/ProvableHashList.d.ts.map +1 -1
- package/dist/utils/ProvableHashList.js +51 -3
- package/dist/utils/ProvableHashList.js.map +1 -0
- package/dist/utils/ProvableReductionHashList.d.ts +18 -0
- package/dist/utils/ProvableReductionHashList.d.ts.map +1 -0
- package/dist/utils/ProvableReductionHashList.js +54 -0
- package/dist/utils/ProvableReductionHashList.js.map +1 -0
- package/dist/utils/StateTransitionReductionList.d.ts +11 -0
- package/dist/utils/StateTransitionReductionList.d.ts.map +1 -0
- package/dist/utils/StateTransitionReductionList.js +61 -0
- package/dist/utils/StateTransitionReductionList.js.map +1 -0
- package/dist/utils/utils.d.ts +11 -5
- package/dist/utils/utils.d.ts.map +1 -1
- package/dist/utils/utils.js +13 -13
- package/dist/utils/utils.js.map +1 -0
- package/jest.config.cjs +12 -1
- package/package.json +11 -9
- package/src/hashing/mina-prefixes.ts +10 -0
- package/src/hashing/protokit-prefixes.ts +37 -0
- package/src/hooks/AccountStateHook.ts +80 -0
- package/src/hooks/BlockHeightHook.ts +17 -0
- package/src/hooks/LastStateRootBlockHook.ts +25 -0
- package/src/hooks/NoopBlockHook.ts +24 -0
- package/src/hooks/NoopSettlementHook.ts +20 -0
- package/src/hooks/NoopTransactionHook.ts +13 -0
- package/src/index.ts +59 -9
- package/src/model/AppliedStateTransitionBatch.ts +16 -0
- package/src/model/MethodPublicOutput.ts +3 -1
- package/src/model/Option.ts +99 -73
- package/src/model/Path.ts +9 -5
- package/src/model/RuntimeLike.ts +12 -0
- package/src/model/StateTransition.ts +19 -5
- package/src/model/StateTransitionProvableBatch.ts +114 -12
- package/src/model/Transaction.ts +3 -1
- package/src/model/network/NetworkState.ts +22 -2
- package/src/model/transaction/AuthorizedTransaction.ts +50 -0
- package/src/model/transaction/RuntimeTransaction.ts +86 -15
- package/src/model/transaction/ValueOption.ts +28 -0
- package/src/protocol/Protocol.ts +201 -69
- package/src/protocol/ProtocolEnvironment.ts +10 -0
- package/src/protocol/ProtocolModule.ts +16 -15
- package/src/protocol/ProvableBlockHook.ts +67 -0
- package/src/protocol/ProvableTransactionHook.ts +96 -0
- package/src/protocol/TransitioningProtocolModule.ts +12 -0
- package/src/prover/accumulators/AppliedBatchHashList.ts +32 -0
- package/src/prover/accumulators/BlockHashList.ts +117 -0
- package/src/prover/accumulators/StateTransitionReductionList.ts +92 -0
- package/src/prover/accumulators/TransactionHashList.ts +9 -0
- package/src/prover/accumulators/WitnessedRootHashList.ts +62 -0
- package/src/prover/block/BlockProvable.ts +360 -28
- package/src/prover/block/BlockProver.ts +721 -186
- package/src/prover/block/accummulators/BlockHashMerkleTree.ts +24 -0
- package/src/prover/block/accummulators/RuntimeVerificationKeyTree.ts +24 -0
- package/src/prover/block/services/RuntimeVerificationKeyRootService.ts +20 -0
- package/src/prover/statetransition/StateTransitionProvable.ts +26 -19
- package/src/prover/statetransition/StateTransitionProver.ts +337 -126
- package/src/prover/transaction/TransactionProvable.ts +183 -0
- package/src/prover/transaction/TransactionProver.ts +561 -0
- package/src/prover/utils.ts +108 -0
- package/src/settlement/ContractArgsRegistry.ts +60 -0
- package/src/settlement/ContractModule.ts +31 -0
- package/src/settlement/SettlementContractModule.ts +150 -0
- package/src/settlement/contracts/BridgeContract.ts +385 -0
- package/src/settlement/contracts/BridgeContractProtocolModule.ts +49 -0
- package/src/settlement/contracts/BridgingSettlementContractModule.ts +116 -0
- package/src/settlement/contracts/DispatchContractProtocolModule.ts +77 -0
- package/src/settlement/contracts/DispatchSmartContract.ts +359 -0
- package/src/settlement/contracts/SettlementSmartContractModule.ts +79 -0
- package/src/settlement/contracts/TokenBridgeTree.ts +73 -0
- package/src/settlement/contracts/authorizations/ContractAuthorization.ts +11 -0
- package/src/settlement/contracts/authorizations/TokenBridgeDeploymentAuth.ts +16 -0
- package/src/settlement/contracts/authorizations/UpdateMessagesHashAuth.ts +16 -0
- package/src/settlement/contracts/settlement/BridgingSettlementContract.ts +283 -0
- package/src/settlement/contracts/settlement/SettlementBase.ts +249 -0
- package/src/settlement/contracts/settlement/SettlementContract.ts +75 -0
- package/src/settlement/messages/Deposit.ts +7 -0
- package/src/settlement/messages/OutgoingMessage.ts +17 -0
- package/src/settlement/messages/OutgoingMessageArgument.ts +53 -0
- package/src/settlement/modularity/OutgoingMessageProcessor.ts +65 -0
- package/src/settlement/modularity/ProvableSettlementHook.ts +36 -0
- package/src/settlement/modularity/types.ts +23 -0
- package/src/settlement/modules/NetworkStateSettlementModule.ts +42 -0
- package/src/state/State.ts +190 -0
- package/src/state/StateMap.ts +73 -0
- package/src/state/StateService.ts +6 -0
- package/src/state/StateServiceProvider.ts +37 -0
- package/src/state/WitnessBlockContext.ts +50 -0
- package/src/state/assert/assert.ts +38 -0
- package/src/state/context/RuntimeMethodExecutionContext.ts +181 -0
- package/src/state/context/TransitionMethodExecutionContext.ts +26 -0
- package/src/state/protocol/ProtocolState.ts +98 -0
- package/src/utils/FieldOptions.ts +13 -0
- package/src/utils/MinaPrefixedProvableHashList.ts +70 -0
- package/src/utils/PrefixedProvableHashList.ts +6 -2
- package/src/utils/ProvableHashList.ts +109 -4
- package/src/utils/ProvableReductionHashList.ts +77 -0
- package/src/utils/utils.ts +21 -16
- package/test/BlockProver.test.ts +161 -74
- package/test/Protocol.test.ts +20 -10
- package/test/State.test.ts +45 -0
- package/test/StateTransition.test.ts +57 -65
- package/test/TestingProtocol.ts +36 -0
- package/test/compiling/types.ts +28 -0
- package/test/model/Option.test.ts +72 -0
- package/test/model/StateTransitionProvableBatch.test.ts +137 -0
- package/test/modularity/types.ts +35 -0
- package/test/prover/block/BlockProver.test.ts +18 -0
- package/test/prover/statetransition/StateTransitionProver.test.ts +261 -0
- package/test/state/assert/assert.test.ts +56 -0
- package/test/tsconfig.json +7 -0
- package/test/utils/ProvableHashList.test.ts +44 -0
- package/test/utils/ProvableReductionHashList.test.ts +117 -0
- package/test/utils.test.ts +0 -3
- package/LICENSE.md +0 -201
- package/dist/model/transaction/ProtocolTransaction.d.ts +0 -70
- package/dist/model/transaction/ProtocolTransaction.d.ts.map +0 -1
- package/dist/model/transaction/ProtocolTransaction.js +0 -18
- package/dist/prover/statetransition/StateTransitionWitnessProvider.d.ts +0 -16
- package/dist/prover/statetransition/StateTransitionWitnessProvider.d.ts.map +0 -1
- package/dist/prover/statetransition/StateTransitionWitnessProviderReference.d.ts +0 -7
- package/dist/prover/statetransition/StateTransitionWitnessProviderReference.d.ts.map +0 -1
- package/dist/utils/merkletree/InMemoryMerkleTreeStorage.d.ts +0 -25
- package/dist/utils/merkletree/InMemoryMerkleTreeStorage.d.ts.map +0 -1
- package/dist/utils/merkletree/InMemoryMerkleTreeStorage.js +0 -77
- package/dist/utils/merkletree/MerkleTreeStore.d.ts +0 -11
- package/dist/utils/merkletree/MerkleTreeStore.d.ts.map +0 -1
- package/dist/utils/merkletree/MerkleTreeStore.js +0 -1
- package/dist/utils/merkletree/RollupMerkleTree.d.ts +0 -130
- package/dist/utils/merkletree/RollupMerkleTree.d.ts.map +0 -1
- package/dist/utils/merkletree/RollupMerkleTree.js +0 -244
- package/src/model/Option.test.ts +0 -21
- package/src/model/transaction/ProtocolTransaction.ts +0 -25
- package/src/prover/statetransition/StateTransitionWitnessProvider.ts +0 -24
- package/src/prover/statetransition/StateTransitionWitnessProviderReference.ts +0 -17
- package/src/utils/merkletree/InMemoryMerkleTreeStorage.ts +0 -106
- package/src/utils/merkletree/MerkleTreeStore.ts +0 -15
- package/src/utils/merkletree/RollupMerkleTree.ts +0 -255
- package/src/utils/merkletree/VirtualMerkleTreeStore.ts +0 -21
- package/tsconfig.test.json +0 -9
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { PublicKey, Struct, UInt64 } from "o1js";
|
|
2
|
+
import { injectable } from "tsyringe";
|
|
3
|
+
import { noop } from "@proto-kit/common";
|
|
4
|
+
|
|
5
|
+
import { StateMap } from "../state/StateMap";
|
|
6
|
+
import { state } from "../state/protocol/ProtocolState";
|
|
7
|
+
import {
|
|
8
|
+
ProvableTransactionHook,
|
|
9
|
+
BeforeTransactionHookArguments,
|
|
10
|
+
} from "../protocol/ProvableTransactionHook";
|
|
11
|
+
import { assert } from "../state/assert/assert";
|
|
12
|
+
|
|
13
|
+
export class AccountState extends Struct({
|
|
14
|
+
nonce: UInt64,
|
|
15
|
+
}) {}
|
|
16
|
+
|
|
17
|
+
export type AccountStateHookConfig = {
|
|
18
|
+
maximumNonceLookahead?: number;
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
@injectable()
|
|
22
|
+
export class AccountStateHook extends ProvableTransactionHook<AccountStateHookConfig> {
|
|
23
|
+
@state() public accountState = StateMap.from<PublicKey, AccountState>(
|
|
24
|
+
PublicKey,
|
|
25
|
+
AccountState
|
|
26
|
+
);
|
|
27
|
+
|
|
28
|
+
public async beforeTransaction({
|
|
29
|
+
transaction: { transaction },
|
|
30
|
+
}: BeforeTransactionHookArguments) {
|
|
31
|
+
const sender = transaction.sender.value;
|
|
32
|
+
|
|
33
|
+
const aso = await this.accountState.get(sender);
|
|
34
|
+
|
|
35
|
+
const accountState = aso.orElse(new AccountState({ nonce: UInt64.zero }));
|
|
36
|
+
|
|
37
|
+
const currentNonce = accountState.nonce;
|
|
38
|
+
|
|
39
|
+
// Either the nonce matches or the tx is a message, in which case we don't care
|
|
40
|
+
assert(
|
|
41
|
+
currentNonce
|
|
42
|
+
.equals(transaction.nonce.value)
|
|
43
|
+
.or(transaction.sender.isSome.not()),
|
|
44
|
+
() =>
|
|
45
|
+
`Nonce not matching: tx sent ${transaction.nonce.value.toString()}, onchain value is ${currentNonce.toString()}`
|
|
46
|
+
);
|
|
47
|
+
|
|
48
|
+
// Optimized version of transaction.sender.isSome ? currentNonce.add(1) : Field(0)
|
|
49
|
+
// Bcs Bool(true).toField() == 1
|
|
50
|
+
// TODO Think about if we want to rangecheck this. If not, we should store it as Field
|
|
51
|
+
const newNonce = UInt64.Unsafe.fromField(
|
|
52
|
+
currentNonce.value.add(1).mul(transaction.sender.isSome.toField())
|
|
53
|
+
);
|
|
54
|
+
|
|
55
|
+
await this.accountState.set(sender, new AccountState({ nonce: newNonce }));
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
public async afterTransaction() {
|
|
59
|
+
noop();
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
// Under these conditions we want the tx removed from the mempool.
|
|
63
|
+
public async removeTransactionWhen({
|
|
64
|
+
transaction: { transaction },
|
|
65
|
+
}: BeforeTransactionHookArguments): Promise<boolean> {
|
|
66
|
+
const sender = transaction.sender.value;
|
|
67
|
+
|
|
68
|
+
const aso = await this.accountState.get(sender);
|
|
69
|
+
|
|
70
|
+
const accountState = aso.orElse(new AccountState({ nonce: UInt64.zero }));
|
|
71
|
+
|
|
72
|
+
const currentNonce = accountState.nonce;
|
|
73
|
+
|
|
74
|
+
const exceedsMaximumLookahead = transaction.nonce.value.greaterThan(
|
|
75
|
+
currentNonce.add(this.config.maximumNonceLookahead ?? 10)
|
|
76
|
+
);
|
|
77
|
+
const nonceIsInPast = transaction.nonce.value.lessThan(currentNonce);
|
|
78
|
+
return nonceIsInPast.or(exceedsMaximumLookahead).toBoolean();
|
|
79
|
+
}
|
|
80
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { NetworkState } from "../model/network/NetworkState";
|
|
2
|
+
import { ProvableBlockHook } from "../protocol/ProvableBlockHook";
|
|
3
|
+
|
|
4
|
+
export class BlockHeightHook extends ProvableBlockHook<Record<string, never>> {
|
|
5
|
+
public async afterBlock(networkState: NetworkState): Promise<NetworkState> {
|
|
6
|
+
return new NetworkState({
|
|
7
|
+
block: {
|
|
8
|
+
height: networkState.block.height.add(1),
|
|
9
|
+
},
|
|
10
|
+
previous: networkState.previous,
|
|
11
|
+
});
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
public async beforeBlock(networkState: NetworkState): Promise<NetworkState> {
|
|
15
|
+
return networkState;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import {
|
|
2
|
+
AfterBlockHookArguments,
|
|
3
|
+
ProvableBlockHook,
|
|
4
|
+
} from "../protocol/ProvableBlockHook";
|
|
5
|
+
import { NetworkState } from "../model/network/NetworkState";
|
|
6
|
+
|
|
7
|
+
export class LastStateRootBlockHook extends ProvableBlockHook<
|
|
8
|
+
Record<string, never>
|
|
9
|
+
> {
|
|
10
|
+
public async afterBlock(
|
|
11
|
+
networkState: NetworkState,
|
|
12
|
+
{ stateRoot }: AfterBlockHookArguments
|
|
13
|
+
): Promise<NetworkState> {
|
|
14
|
+
return new NetworkState({
|
|
15
|
+
block: networkState.block,
|
|
16
|
+
previous: {
|
|
17
|
+
rootHash: stateRoot,
|
|
18
|
+
},
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
public async beforeBlock(networkState: NetworkState): Promise<NetworkState> {
|
|
23
|
+
return networkState;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { NoConfig } from "@proto-kit/common";
|
|
2
|
+
|
|
3
|
+
import {
|
|
4
|
+
AfterBlockHookArguments,
|
|
5
|
+
BeforeBlockHookArguments,
|
|
6
|
+
ProvableBlockHook,
|
|
7
|
+
} from "../protocol/ProvableBlockHook";
|
|
8
|
+
import { NetworkState } from "../model/network/NetworkState";
|
|
9
|
+
|
|
10
|
+
export class NoopBlockHook extends ProvableBlockHook<NoConfig> {
|
|
11
|
+
public async afterBlock(
|
|
12
|
+
networkState: NetworkState,
|
|
13
|
+
state: AfterBlockHookArguments
|
|
14
|
+
): Promise<NetworkState> {
|
|
15
|
+
return networkState;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
public async beforeBlock(
|
|
19
|
+
networkState: NetworkState,
|
|
20
|
+
state: BeforeBlockHookArguments
|
|
21
|
+
): Promise<NetworkState> {
|
|
22
|
+
return networkState;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { injectable } from "tsyringe";
|
|
2
|
+
import { noop } from "@proto-kit/common";
|
|
3
|
+
|
|
4
|
+
import {
|
|
5
|
+
ProvableSettlementHook,
|
|
6
|
+
SettlementHookInputs,
|
|
7
|
+
} from "../settlement/modularity/ProvableSettlementHook";
|
|
8
|
+
import { SettlementContractType } from "../settlement/contracts/settlement/SettlementBase";
|
|
9
|
+
|
|
10
|
+
@injectable()
|
|
11
|
+
export class NoopSettlementHook extends ProvableSettlementHook<
|
|
12
|
+
Record<string, never>
|
|
13
|
+
> {
|
|
14
|
+
public async beforeSettlement(
|
|
15
|
+
contract: SettlementContractType,
|
|
16
|
+
state: SettlementHookInputs
|
|
17
|
+
) {
|
|
18
|
+
noop();
|
|
19
|
+
}
|
|
20
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { noop } from "@proto-kit/common";
|
|
2
|
+
|
|
3
|
+
import { ProvableTransactionHook } from "../protocol/ProvableTransactionHook";
|
|
4
|
+
|
|
5
|
+
export class NoopTransactionHook extends ProvableTransactionHook {
|
|
6
|
+
public async beforeTransaction() {
|
|
7
|
+
noop();
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
public async afterTransaction() {
|
|
11
|
+
noop();
|
|
12
|
+
}
|
|
13
|
+
}
|
package/src/index.ts
CHANGED
|
@@ -1,23 +1,73 @@
|
|
|
1
|
-
export * from "./
|
|
1
|
+
export * from "./hooks/AccountStateHook";
|
|
2
|
+
export * from "./hooks/BlockHeightHook";
|
|
3
|
+
export * from "./hooks/LastStateRootBlockHook";
|
|
2
4
|
export * from "./model/StateTransition";
|
|
3
5
|
export * from "./model/StateTransitionProvableBatch";
|
|
4
6
|
export * from "./model/Option";
|
|
5
7
|
export * from "./model/Path";
|
|
6
8
|
export * from "./model/network/NetworkState";
|
|
7
|
-
export * from "./model/transaction/
|
|
9
|
+
export * from "./model/transaction/AuthorizedTransaction";
|
|
8
10
|
export * from "./model/transaction/RuntimeTransaction";
|
|
9
|
-
export * from "./
|
|
11
|
+
export * from "./model/transaction/ValueOption";
|
|
12
|
+
export * from "./model/MethodPublicOutput";
|
|
13
|
+
export * from "./model/RuntimeLike";
|
|
14
|
+
export * from "./model/AppliedStateTransitionBatch";
|
|
15
|
+
export * from "./utils/ProvableHashList";
|
|
16
|
+
export * from "./utils/PrefixedProvableHashList";
|
|
17
|
+
export * from "./utils/MinaPrefixedProvableHashList";
|
|
18
|
+
export * from "./utils/ProvableReductionHashList";
|
|
10
19
|
export * from "./utils/utils";
|
|
20
|
+
export * from "./utils/FieldOptions";
|
|
21
|
+
export * from "./prover/accumulators/StateTransitionReductionList";
|
|
22
|
+
export * from "./prover/accumulators/AppliedBatchHashList";
|
|
23
|
+
export * from "./prover/accumulators/WitnessedRootHashList";
|
|
24
|
+
export * from "./prover/accumulators/TransactionHashList";
|
|
25
|
+
export * from "./prover/accumulators/BlockHashList";
|
|
11
26
|
export * from "./prover/block/BlockProver";
|
|
12
27
|
export * from "./prover/block/BlockProvable";
|
|
28
|
+
export * from "./prover/block/accummulators/RuntimeVerificationKeyTree";
|
|
29
|
+
export * from "./prover/block/accummulators/BlockHashMerkleTree";
|
|
30
|
+
export * from "./prover/block/services/RuntimeVerificationKeyRootService";
|
|
13
31
|
export * from "./prover/statetransition/StateTransitionProver";
|
|
14
32
|
export * from "./prover/statetransition/StateTransitionProvable";
|
|
15
|
-
export * from "./prover/
|
|
16
|
-
export * from "./
|
|
17
|
-
export * from "./utils
|
|
18
|
-
export * from "./utils/merkletree/RollupMerkleTree";
|
|
19
|
-
export * from "./model/MethodPublicOutput";
|
|
20
|
-
export * from "./prover/statetransition/StateTransitionWitnessProviderReference";
|
|
33
|
+
export * from "./prover/transaction/TransactionProver";
|
|
34
|
+
export * from "./prover/transaction/TransactionProvable";
|
|
35
|
+
export * from "./prover/utils";
|
|
21
36
|
export * from "./protocol/Protocol";
|
|
22
37
|
export * from "./protocol/ProtocolModule";
|
|
38
|
+
export * from "./protocol/ProtocolEnvironment";
|
|
39
|
+
export * from "./protocol/ProvableTransactionHook";
|
|
40
|
+
export * from "./protocol/ProvableBlockHook";
|
|
41
|
+
export * from "./state/context/TransitionMethodExecutionContext";
|
|
42
|
+
export * from "./state/context/RuntimeMethodExecutionContext";
|
|
43
|
+
export * from "./state/protocol/ProtocolState";
|
|
44
|
+
export * from "./state/State";
|
|
45
|
+
export * from "./state/StateMap";
|
|
46
|
+
export * from "./state/StateService";
|
|
47
|
+
export * from "./state/StateServiceProvider";
|
|
48
|
+
export * from "./state/assert/assert";
|
|
49
|
+
export * from "./settlement/contracts/authorizations/ContractAuthorization";
|
|
50
|
+
export * from "./settlement/contracts/authorizations/UpdateMessagesHashAuth";
|
|
51
|
+
export * from "./settlement/contracts/authorizations/TokenBridgeDeploymentAuth";
|
|
52
|
+
export * from "./settlement/contracts/settlement/SettlementBase";
|
|
53
|
+
export * from "./settlement/contracts/settlement/SettlementContract";
|
|
54
|
+
export * from "./settlement/contracts/settlement/BridgingSettlementContract";
|
|
55
|
+
export * from "./settlement/contracts/BridgingSettlementContractModule";
|
|
56
|
+
export * from "./settlement/contracts/SettlementSmartContractModule";
|
|
57
|
+
export * from "./settlement/contracts/DispatchSmartContract";
|
|
58
|
+
export * from "./settlement/contracts/DispatchContractProtocolModule";
|
|
59
|
+
export * from "./settlement/contracts/BridgeContract";
|
|
60
|
+
export * from "./settlement/contracts/BridgeContractProtocolModule";
|
|
61
|
+
export * from "./settlement/contracts/TokenBridgeTree";
|
|
62
|
+
export * from "./settlement/SettlementContractModule";
|
|
63
|
+
export * from "./settlement/ContractModule";
|
|
64
|
+
export * from "./settlement/modularity/ProvableSettlementHook";
|
|
65
|
+
export * from "./settlement/modularity/OutgoingMessageProcessor";
|
|
66
|
+
export * from "./settlement/messages/OutgoingMessageArgument";
|
|
67
|
+
export * from "./settlement/messages/OutgoingMessage";
|
|
68
|
+
export * from "./settlement/modules/NetworkStateSettlementModule";
|
|
69
|
+
export * from "./settlement/messages/Deposit";
|
|
70
|
+
export * from "./settlement/ContractArgsRegistry";
|
|
23
71
|
export { constants as ProtocolConstants } from "./Constants";
|
|
72
|
+
export * from "./hashing/protokit-prefixes";
|
|
73
|
+
export * from "./hashing/mina-prefixes";
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { Bool, Field, Poseidon, Provable, Struct } from "o1js";
|
|
2
|
+
|
|
3
|
+
export class AppliedStateTransitionBatch extends Struct({
|
|
4
|
+
batchHash: Field,
|
|
5
|
+
applied: Bool,
|
|
6
|
+
}) {}
|
|
7
|
+
|
|
8
|
+
export class AppliedStateTransitionBatchState extends Struct({
|
|
9
|
+
batchHash: Field,
|
|
10
|
+
root: Field,
|
|
11
|
+
}) {
|
|
12
|
+
public hashOrZero(): Field {
|
|
13
|
+
const hash = Poseidon.hash(AppliedStateTransitionBatchState.toFields(this));
|
|
14
|
+
return Provable.if(this.batchHash.equals(0), Field(0), hash);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Bool, Field, Struct } from "
|
|
1
|
+
import { Bool, Field, Struct } from "o1js";
|
|
2
2
|
|
|
3
3
|
/**
|
|
4
4
|
* Public input used to link in-circuit execution with
|
|
@@ -9,4 +9,6 @@ export class MethodPublicOutput extends Struct({
|
|
|
9
9
|
status: Bool,
|
|
10
10
|
transactionHash: Field,
|
|
11
11
|
networkStateHash: Field,
|
|
12
|
+
isMessage: Bool,
|
|
13
|
+
eventsHash: Field,
|
|
12
14
|
}) {}
|
package/src/model/Option.ts
CHANGED
|
@@ -4,8 +4,9 @@ import {
|
|
|
4
4
|
type FlexibleProvablePure,
|
|
5
5
|
Poseidon,
|
|
6
6
|
Provable,
|
|
7
|
+
ProvablePure,
|
|
7
8
|
Struct,
|
|
8
|
-
} from "
|
|
9
|
+
} from "o1js";
|
|
9
10
|
|
|
10
11
|
export class ProvableOption extends Struct({
|
|
11
12
|
isSome: Bool,
|
|
@@ -17,10 +18,70 @@ export class ProvableOption extends Struct({
|
|
|
17
18
|
}
|
|
18
19
|
}
|
|
19
20
|
|
|
21
|
+
export abstract class OptionBase {
|
|
22
|
+
protected constructor(
|
|
23
|
+
public isSome: Bool,
|
|
24
|
+
public isForcedSome: Bool
|
|
25
|
+
) {}
|
|
26
|
+
|
|
27
|
+
protected abstract encodeValueToFields(): Field[];
|
|
28
|
+
|
|
29
|
+
protected abstract clone(): OptionBase;
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* @returns Tree representation of the current value
|
|
33
|
+
*/
|
|
34
|
+
public get treeValue() {
|
|
35
|
+
const treeValue = Poseidon.hash(this.encodeValueToFields());
|
|
36
|
+
|
|
37
|
+
return Provable.if(
|
|
38
|
+
this.isSome.and(this.isForcedSome.not()),
|
|
39
|
+
treeValue,
|
|
40
|
+
Field(0)
|
|
41
|
+
);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
public forceSome() {
|
|
45
|
+
this.isForcedSome = Provable.if(this.isSome, Bool(false), Bool(true));
|
|
46
|
+
this.isSome = Bool(true);
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
/**
|
|
50
|
+
* Returns the `to`-value as decoded as a list of fields
|
|
51
|
+
* Not in circuit
|
|
52
|
+
*/
|
|
53
|
+
public toFields(): Field[] {
|
|
54
|
+
if (this.isSome.toBoolean()) {
|
|
55
|
+
return this.encodeValueToFields();
|
|
56
|
+
}
|
|
57
|
+
return [Field(0)];
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
/**
|
|
61
|
+
* @returns Provable representation of the current option.
|
|
62
|
+
*/
|
|
63
|
+
public toProvable() {
|
|
64
|
+
return new ProvableOption({
|
|
65
|
+
isSome: this.isSome,
|
|
66
|
+
value: this.treeValue,
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
public toJSON() {
|
|
71
|
+
const value = this.encodeValueToFields().map((field) => field.toString());
|
|
72
|
+
|
|
73
|
+
return {
|
|
74
|
+
isSome: this.isSome.toBoolean(),
|
|
75
|
+
isForcedSome: this.isForcedSome.toBoolean(),
|
|
76
|
+
value,
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
|
|
20
81
|
/**
|
|
21
82
|
* Option facilitating in-circuit values that may or may not exist.
|
|
22
83
|
*/
|
|
23
|
-
export class Option<Value> {
|
|
84
|
+
export class Option<Value> extends OptionBase {
|
|
24
85
|
/**
|
|
25
86
|
* Creates a new Option from the provided parameters
|
|
26
87
|
*
|
|
@@ -58,89 +119,54 @@ export class Option<Value> {
|
|
|
58
119
|
return new Option(Bool(false), Field(0), Field);
|
|
59
120
|
}
|
|
60
121
|
|
|
61
|
-
public static dummyValueFields<Value>(
|
|
62
|
-
valueType: FlexibleProvablePure<Value>
|
|
63
|
-
): Field[] {
|
|
64
|
-
const length = valueType.sizeInFields();
|
|
65
|
-
return Array.from({ length }, () => Field(0));
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
/**
|
|
69
|
-
* Computes a dummy value for the given value type.
|
|
70
|
-
*
|
|
71
|
-
* @param valueType - Value type to generate the dummy value for
|
|
72
|
-
* @returns Dummy value for the given value type
|
|
73
|
-
*/
|
|
74
|
-
public static dummyValue<Value>(
|
|
75
|
-
valueType: FlexibleProvablePure<Value>
|
|
76
|
-
): Value {
|
|
77
|
-
const fields = Option.dummyValueFields(valueType);
|
|
78
|
-
|
|
79
|
-
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
|
|
80
|
-
return valueType.fromFields(fields) as Value;
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
public isForcedSome = Bool(false);
|
|
84
|
-
|
|
85
122
|
public constructor(
|
|
86
|
-
|
|
123
|
+
isSome: Bool,
|
|
87
124
|
public value: Value,
|
|
88
|
-
public valueType: FlexibleProvablePure<Value
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
return new Option(this.isSome, this.value, this.valueType);
|
|
125
|
+
public valueType: FlexibleProvablePure<Value>,
|
|
126
|
+
isForcedSome = Bool(false)
|
|
127
|
+
) {
|
|
128
|
+
super(isSome, isForcedSome);
|
|
93
129
|
}
|
|
94
130
|
|
|
95
|
-
public
|
|
96
|
-
this.
|
|
97
|
-
this.isSome = Bool(true);
|
|
131
|
+
public encodeValueToFields(): Field[] {
|
|
132
|
+
return this.valueType.toFields(this.value);
|
|
98
133
|
}
|
|
99
134
|
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
return Provable.if(
|
|
107
|
-
this.isSome.and(this.isForcedSome.not()),
|
|
108
|
-
treeValue,
|
|
109
|
-
Field(0)
|
|
135
|
+
public clone(): Option<Value> {
|
|
136
|
+
return new Option(
|
|
137
|
+
this.isSome,
|
|
138
|
+
this.value,
|
|
139
|
+
this.valueType,
|
|
140
|
+
this.isForcedSome
|
|
110
141
|
);
|
|
111
142
|
}
|
|
112
143
|
|
|
113
144
|
/**
|
|
114
|
-
* Returns the
|
|
115
|
-
*
|
|
145
|
+
* @returns Returns the value of this option if it isSome,
|
|
146
|
+
* otherwise returns the given defaultValue
|
|
116
147
|
*/
|
|
117
|
-
public
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
/**
|
|
125
|
-
* @returns Provable representation of the current option.
|
|
126
|
-
*/
|
|
127
|
-
public toProvable() {
|
|
128
|
-
return new ProvableOption({
|
|
129
|
-
isSome: this.isSome,
|
|
130
|
-
value: this.treeValue,
|
|
131
|
-
});
|
|
148
|
+
public orElse(defaultValue: Value): Value {
|
|
149
|
+
return Provable.if<Value>(
|
|
150
|
+
this.isSome,
|
|
151
|
+
this.valueType,
|
|
152
|
+
this.value,
|
|
153
|
+
defaultValue
|
|
154
|
+
);
|
|
132
155
|
}
|
|
133
156
|
|
|
134
|
-
public
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
.map((field) => field.
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
157
|
+
public toConstant() {
|
|
158
|
+
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions
|
|
159
|
+
const valueConstant = (this.valueType as ProvablePure<Value>).fromFields(
|
|
160
|
+
this.valueType.toFields(this.value).map((field) => field.toConstant())
|
|
161
|
+
);
|
|
162
|
+
const boolConstant = (bool: Bool) =>
|
|
163
|
+
Bool.fromFields([bool.toField().toConstant()]);
|
|
164
|
+
|
|
165
|
+
return new Option(
|
|
166
|
+
boolConstant(this.isSome),
|
|
167
|
+
valueConstant,
|
|
168
|
+
this.valueType,
|
|
169
|
+
boolConstant(this.isForcedSome)
|
|
170
|
+
);
|
|
145
171
|
}
|
|
146
172
|
}
|
package/src/model/Path.ts
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
import { Field, type FlexibleProvablePure, Poseidon } from "snarkyjs";
|
|
1
|
+
import { Field, type FlexibleProvablePure, Poseidon } from "o1js";
|
|
2
|
+
import { hashWithPrefix } from "@proto-kit/common";
|
|
4
3
|
|
|
5
4
|
import { stringToField } from "../utils/utils";
|
|
6
5
|
|
|
@@ -23,10 +22,15 @@ export class Path {
|
|
|
23
22
|
*
|
|
24
23
|
* @param className
|
|
25
24
|
* @param propertyKey
|
|
25
|
+
* @param prefix
|
|
26
26
|
* @returns Field representation of class name + property name
|
|
27
27
|
*/
|
|
28
|
-
public static fromProperty(
|
|
29
|
-
|
|
28
|
+
public static fromProperty(
|
|
29
|
+
className: string,
|
|
30
|
+
propertyKey: string,
|
|
31
|
+
prefix: string
|
|
32
|
+
): Field {
|
|
33
|
+
return hashWithPrefix(prefix, [
|
|
30
34
|
Path.toField(className),
|
|
31
35
|
Path.toField(propertyKey),
|
|
32
36
|
Field(0),
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export type RuntimeMethodInvocationType = "INCOMING_MESSAGE" | "SIGNATURE";
|
|
2
|
+
|
|
3
|
+
export type RuntimeMethodIdMapping = Record<
|
|
4
|
+
`${string}.${string}`,
|
|
5
|
+
{ methodId: bigint; type: RuntimeMethodInvocationType }
|
|
6
|
+
>;
|
|
7
|
+
|
|
8
|
+
export interface RuntimeLike {
|
|
9
|
+
get methodIdResolver(): {
|
|
10
|
+
methodIdMap: () => RuntimeMethodIdMapping;
|
|
11
|
+
};
|
|
12
|
+
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { Field, Struct } from "
|
|
1
|
+
import { Field, Struct } from "o1js";
|
|
2
2
|
|
|
3
|
-
import { Option, ProvableOption } from "./Option
|
|
3
|
+
import { Option, ProvableOption } from "./Option";
|
|
4
4
|
|
|
5
5
|
/**
|
|
6
6
|
* Provable representation of a State Transition, used to
|
|
@@ -23,6 +23,12 @@ export class ProvableStateTransition extends Struct({
|
|
|
23
23
|
to: Option.none().toProvable(),
|
|
24
24
|
});
|
|
25
25
|
}
|
|
26
|
+
|
|
27
|
+
public static isDummy(stateTransition: ProvableStateTransition) {
|
|
28
|
+
return stateTransition.path
|
|
29
|
+
.equals(0)
|
|
30
|
+
.and(stateTransition.from.isSome.not());
|
|
31
|
+
}
|
|
26
32
|
}
|
|
27
33
|
|
|
28
34
|
/**
|
|
@@ -44,7 +50,7 @@ export class StateTransition<Value> {
|
|
|
44
50
|
|
|
45
51
|
public constructor(
|
|
46
52
|
public path: Field,
|
|
47
|
-
public fromValue: Option<
|
|
53
|
+
public fromValue: Option<Value>,
|
|
48
54
|
public toValue: Option<Field> | Option<Value>
|
|
49
55
|
) {}
|
|
50
56
|
|
|
@@ -73,8 +79,16 @@ export class StateTransition<Value> {
|
|
|
73
79
|
public toJSON() {
|
|
74
80
|
return {
|
|
75
81
|
path: this.path.toString(),
|
|
76
|
-
from: this.
|
|
77
|
-
to: this.
|
|
82
|
+
from: this.fromValue.toJSON(),
|
|
83
|
+
to: this.toValue.toJSON(),
|
|
78
84
|
};
|
|
79
85
|
}
|
|
86
|
+
|
|
87
|
+
public toConstant(): StateTransition<Value> {
|
|
88
|
+
return new StateTransition<Value>(
|
|
89
|
+
this.path.toConstant(),
|
|
90
|
+
this.fromValue.toConstant(),
|
|
91
|
+
this.toValue.toConstant()
|
|
92
|
+
);
|
|
93
|
+
}
|
|
80
94
|
}
|