@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
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BlockProvable.d.ts","sourceRoot":"","sources":["../../../src/prover/block/BlockProvable.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"BlockProvable.d.ts","sourceRoot":"","sources":["../../../src/prover/block/BlockProvable.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,20 +1,204 @@
|
|
|
1
|
-
import { Field, Struct } from "
|
|
2
|
-
import { ProtocolTransaction } from "../../model/transaction/ProtocolTransaction";
|
|
1
|
+
import { Bool, Field, Poseidon, Provable, Struct } from "o1js";
|
|
3
2
|
import { NetworkState } from "../../model/network/NetworkState";
|
|
4
|
-
|
|
3
|
+
import { TransactionHashList } from "../accumulators/TransactionHashList";
|
|
4
|
+
import { MinaActionsHashList } from "../../utils/MinaPrefixedProvableHashList";
|
|
5
|
+
import { AppliedBatchHashList } from "../accumulators/AppliedBatchHashList";
|
|
6
|
+
import { WitnessedRootHashList, WitnessedRootWitness, } from "../accumulators/WitnessedRootHashList";
|
|
7
|
+
import { BundleHashList, FieldTransition } from "../accumulators/BlockHashList";
|
|
8
|
+
import { BlockHashMerkleTreeWitness } from "./accummulators/BlockHashMerkleTree";
|
|
9
|
+
export const BLOCK_ARGUMENT_BATCH_SIZE = 4;
|
|
10
|
+
export class BlockArguments extends Struct({
|
|
11
|
+
afterBlockRootWitness: WitnessedRootWitness,
|
|
5
12
|
transactionsHash: Field,
|
|
6
|
-
|
|
7
|
-
|
|
13
|
+
pendingSTBatchesHash: FieldTransition,
|
|
14
|
+
witnessedRootsHash: FieldTransition,
|
|
15
|
+
isDummy: Bool,
|
|
8
16
|
}) {
|
|
17
|
+
static noop(state, stateRoot) {
|
|
18
|
+
return new BlockArguments({
|
|
19
|
+
afterBlockRootWitness: {
|
|
20
|
+
witnessedRoot: stateRoot,
|
|
21
|
+
},
|
|
22
|
+
transactionsHash: Field(0),
|
|
23
|
+
pendingSTBatchesHash: {
|
|
24
|
+
from: state.pendingSTBatches.commitment,
|
|
25
|
+
to: state.pendingSTBatches.commitment,
|
|
26
|
+
},
|
|
27
|
+
witnessedRootsHash: {
|
|
28
|
+
from: state.witnessedRoots.commitment,
|
|
29
|
+
to: state.witnessedRoots.commitment,
|
|
30
|
+
},
|
|
31
|
+
isDummy: Bool(true),
|
|
32
|
+
});
|
|
33
|
+
}
|
|
9
34
|
}
|
|
10
|
-
export class
|
|
11
|
-
|
|
12
|
-
stateRoot: Field,
|
|
35
|
+
export class BlockArgumentsBatch extends Struct({
|
|
36
|
+
batch: Provable.Array(BlockArguments, BLOCK_ARGUMENT_BATCH_SIZE),
|
|
13
37
|
}) {
|
|
14
38
|
}
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
39
|
+
const BlockProverStateBaseFields = {
|
|
40
|
+
eternalTransactionsHash: Field,
|
|
41
|
+
incomingMessagesHash: Field,
|
|
42
|
+
stateRoot: Field,
|
|
43
|
+
blockHashRoot: Field,
|
|
44
|
+
blockNumber: Field,
|
|
45
|
+
networkStateHash: Field,
|
|
46
|
+
};
|
|
47
|
+
export class BlockProverPublicInput extends Struct({
|
|
48
|
+
// Tracker of the current block prover state
|
|
49
|
+
proverStateRemainder: Field,
|
|
50
|
+
...BlockProverStateBaseFields,
|
|
19
51
|
}) {
|
|
52
|
+
equals(input) {
|
|
53
|
+
const output2 = BlockProverPublicInput.toFields(input);
|
|
54
|
+
const output1 = BlockProverPublicInput.toFields(this);
|
|
55
|
+
return output1
|
|
56
|
+
.map((value1, index) => value1.equals(output2[index]))
|
|
57
|
+
.reduce((a, b) => a.and(b));
|
|
58
|
+
}
|
|
59
|
+
clone() {
|
|
60
|
+
return new BlockProverPublicInput(BlockProverPublicInput.fromFields(BlockProverPublicInput.toFields(this)));
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
export const BlockProverStateCommitments = {
|
|
64
|
+
remainders: {
|
|
65
|
+
// Commitment to the list of unprocessed (pending) batches of STs that need to be proven
|
|
66
|
+
pendingSTBatchesHash: Field,
|
|
67
|
+
witnessedRootsHash: Field,
|
|
68
|
+
bundlesHash: Field,
|
|
69
|
+
witnessedRootsPreimage: Field,
|
|
70
|
+
},
|
|
71
|
+
...BlockProverStateBaseFields,
|
|
72
|
+
};
|
|
73
|
+
export class BlockProverStateInput extends Struct(BlockProverStateCommitments) {
|
|
74
|
+
hash() {
|
|
75
|
+
return Poseidon.hash(BlockProverStateInput.toFields(this));
|
|
76
|
+
}
|
|
77
|
+
static fromPublicInput(input) {
|
|
78
|
+
return new BlockProverStateInput({
|
|
79
|
+
remainders: {
|
|
80
|
+
bundlesHash: Field(0),
|
|
81
|
+
pendingSTBatchesHash: Field(0),
|
|
82
|
+
witnessedRootsHash: Field(0),
|
|
83
|
+
witnessedRootsPreimage: Field(0),
|
|
84
|
+
},
|
|
85
|
+
eternalTransactionsHash: input.eternalTransactionsHash,
|
|
86
|
+
incomingMessagesHash: input.incomingMessagesHash,
|
|
87
|
+
stateRoot: input.stateRoot,
|
|
88
|
+
blockHashRoot: input.blockHashRoot,
|
|
89
|
+
blockNumber: input.blockNumber,
|
|
90
|
+
networkStateHash: input.networkStateHash,
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
finalize(condition) {
|
|
94
|
+
condition
|
|
95
|
+
.implies(this.remainders.bundlesHash
|
|
96
|
+
.equals(0)
|
|
97
|
+
.and(this.remainders.pendingSTBatchesHash.equals(0))
|
|
98
|
+
.and(this.remainders.witnessedRootsHash.equals(0)))
|
|
99
|
+
.assertTrue("Remainers not fully removed");
|
|
100
|
+
return new BlockProverPublicInput({
|
|
101
|
+
proverStateRemainder: Field(0),
|
|
102
|
+
eternalTransactionsHash: this.eternalTransactionsHash,
|
|
103
|
+
incomingMessagesHash: this.incomingMessagesHash,
|
|
104
|
+
stateRoot: this.stateRoot,
|
|
105
|
+
blockHashRoot: this.blockHashRoot,
|
|
106
|
+
blockNumber: this.blockNumber,
|
|
107
|
+
networkStateHash: this.networkStateHash,
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
export class BlockProverPublicOutput extends BlockProverPublicInput {
|
|
112
|
+
}
|
|
113
|
+
export class BlockProverState {
|
|
114
|
+
constructor(args) {
|
|
115
|
+
this.bundleList = args.bundleList;
|
|
116
|
+
this.eternalTransactionsList = args.eternalTransactionsList;
|
|
117
|
+
this.pendingSTBatches = args.pendingSTBatches;
|
|
118
|
+
this.stateRoot = args.stateRoot;
|
|
119
|
+
this.blockHashRoot = args.blockHashRoot;
|
|
120
|
+
this.blockNumber = args.blockNumber;
|
|
121
|
+
this.networkState = args.networkState;
|
|
122
|
+
this.blockWitness = args.blockWitness;
|
|
123
|
+
this.witnessedRoots = args.witnessedRoots;
|
|
124
|
+
this.incomingMessages = args.incomingMessages;
|
|
125
|
+
}
|
|
126
|
+
toCommitments() {
|
|
127
|
+
return new BlockProverStateInput({
|
|
128
|
+
remainders: {
|
|
129
|
+
bundlesHash: this.bundleList.commitment,
|
|
130
|
+
pendingSTBatchesHash: this.pendingSTBatches.commitment,
|
|
131
|
+
witnessedRootsHash: this.witnessedRoots.commitment,
|
|
132
|
+
witnessedRootsPreimage: this.witnessedRoots.preimage,
|
|
133
|
+
},
|
|
134
|
+
eternalTransactionsHash: this.eternalTransactionsList.commitment,
|
|
135
|
+
incomingMessagesHash: this.incomingMessages.commitment,
|
|
136
|
+
stateRoot: this.stateRoot,
|
|
137
|
+
blockHashRoot: this.blockHashRoot,
|
|
138
|
+
blockNumber: this.blockNumber,
|
|
139
|
+
networkStateHash: this.networkState.hash(),
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
static blockProverFromCommitments(stateInput, networkState, blockWitness) {
|
|
143
|
+
return new BlockProverState({
|
|
144
|
+
bundleList: new BundleHashList(stateInput.remainders.bundlesHash),
|
|
145
|
+
eternalTransactionsList: new TransactionHashList(stateInput.eternalTransactionsHash),
|
|
146
|
+
incomingMessages: new MinaActionsHashList(stateInput.incomingMessagesHash),
|
|
147
|
+
pendingSTBatches: new AppliedBatchHashList(stateInput.remainders.pendingSTBatchesHash),
|
|
148
|
+
witnessedRoots: new WitnessedRootHashList(stateInput.remainders.witnessedRootsHash, stateInput.remainders.witnessedRootsPreimage),
|
|
149
|
+
stateRoot: stateInput.stateRoot,
|
|
150
|
+
blockHashRoot: stateInput.blockHashRoot,
|
|
151
|
+
blockNumber: stateInput.blockNumber,
|
|
152
|
+
networkState,
|
|
153
|
+
blockWitness,
|
|
154
|
+
});
|
|
155
|
+
}
|
|
156
|
+
copy() {
|
|
157
|
+
return BlockProverState.fromFields(this.toFields());
|
|
158
|
+
}
|
|
159
|
+
toFields() {
|
|
160
|
+
return [
|
|
161
|
+
this.bundleList.commitment,
|
|
162
|
+
this.eternalTransactionsList.commitment,
|
|
163
|
+
this.pendingSTBatches.commitment,
|
|
164
|
+
this.incomingMessages.commitment,
|
|
165
|
+
this.witnessedRoots.commitment,
|
|
166
|
+
this.witnessedRoots.preimage,
|
|
167
|
+
this.stateRoot,
|
|
168
|
+
this.blockHashRoot,
|
|
169
|
+
this.blockNumber,
|
|
170
|
+
...NetworkState.toFields(this.networkState),
|
|
171
|
+
...BlockHashMerkleTreeWitness.toFields(this.blockWitness),
|
|
172
|
+
];
|
|
173
|
+
}
|
|
174
|
+
// TODO Unit test
|
|
175
|
+
static fromFields(fields) {
|
|
176
|
+
return new BlockProverState({
|
|
177
|
+
bundleList: new BundleHashList(fields[0]),
|
|
178
|
+
eternalTransactionsList: new TransactionHashList(fields[1]),
|
|
179
|
+
pendingSTBatches: new AppliedBatchHashList(fields[2]),
|
|
180
|
+
incomingMessages: new MinaActionsHashList(fields[3]),
|
|
181
|
+
witnessedRoots: new WitnessedRootHashList(fields[4], fields[5]),
|
|
182
|
+
stateRoot: fields[6],
|
|
183
|
+
blockHashRoot: fields[7],
|
|
184
|
+
blockNumber: fields[8],
|
|
185
|
+
networkState: new NetworkState(NetworkState.fromFields(fields.slice(9))),
|
|
186
|
+
blockWitness: new BlockHashMerkleTreeWitness(BlockHashMerkleTreeWitness.fromFields(fields.slice(9 + NetworkState.sizeInFields()))),
|
|
187
|
+
});
|
|
188
|
+
}
|
|
189
|
+
static choose(condition, a, b) {
|
|
190
|
+
return new BlockProverState({
|
|
191
|
+
bundleList: new BundleHashList(Provable.if(condition, a.bundleList.commitment, b.bundleList.commitment)),
|
|
192
|
+
eternalTransactionsList: new TransactionHashList(Provable.if(condition, a.eternalTransactionsList.commitment, b.eternalTransactionsList.commitment)),
|
|
193
|
+
pendingSTBatches: new AppliedBatchHashList(Provable.if(condition, a.pendingSTBatches.commitment, b.pendingSTBatches.commitment)),
|
|
194
|
+
incomingMessages: new MinaActionsHashList(Provable.if(condition, a.incomingMessages.commitment, b.incomingMessages.commitment)),
|
|
195
|
+
witnessedRoots: new WitnessedRootHashList(Provable.if(condition, a.witnessedRoots.commitment, b.witnessedRoots.commitment), Provable.if(condition, a.witnessedRoots.preimage, b.witnessedRoots.preimage)),
|
|
196
|
+
stateRoot: Provable.if(condition, a.stateRoot, b.stateRoot),
|
|
197
|
+
blockHashRoot: Provable.if(condition, a.blockHashRoot, b.blockHashRoot),
|
|
198
|
+
blockWitness: new BlockHashMerkleTreeWitness(Provable.if(condition, BlockHashMerkleTreeWitness, a.blockWitness, b.blockWitness)),
|
|
199
|
+
blockNumber: Provable.if(condition, a.blockNumber, b.blockNumber),
|
|
200
|
+
networkState: new NetworkState(Provable.if(condition, NetworkState, a.networkState, b.networkState)),
|
|
201
|
+
});
|
|
202
|
+
}
|
|
20
203
|
}
|
|
204
|
+
//# sourceMappingURL=BlockProvable.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BlockProvable.js","sourceRoot":"","sources":["../../../src/prover/block/BlockProvable.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,48 +1,63 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { PlainZkProgram, WithZkProgrammable, ZkProgrammable } from "@proto-kit/common";
|
|
3
|
-
import { MethodPublicOutput } from "../../model/MethodPublicOutput";
|
|
1
|
+
import { Bool, Field } from "o1js";
|
|
2
|
+
import { AreProofsEnabled, CompilableModule, CompileArtifact, CompileRegistry, PlainZkProgram, WithZkProgrammable, ZkProgrammable } from "@proto-kit/common";
|
|
4
3
|
import { ProtocolModule } from "../../protocol/ProtocolModule";
|
|
5
|
-
import { StateTransitionProof, StateTransitionProverPublicInput, StateTransitionProverPublicOutput } from "../statetransition/StateTransitionProvable";
|
|
6
|
-
import {
|
|
7
|
-
|
|
8
|
-
|
|
4
|
+
import { StateTransitionProof, StateTransitionProvable, StateTransitionProverPublicInput, StateTransitionProverPublicOutput } from "../statetransition/StateTransitionProvable";
|
|
5
|
+
import { AfterBlockHookArguments, BeforeBlockHookArguments, ProvableBlockHook } from "../../protocol/ProvableBlockHook";
|
|
6
|
+
import { NetworkState } from "../../model/network/NetworkState";
|
|
7
|
+
import { StateServiceProvider } from "../../state/StateServiceProvider";
|
|
8
|
+
import { TransactionProof, TransactionProvable, TransactionProverPublicInput, TransactionProverPublicOutput } from "../transaction/TransactionProvable";
|
|
9
|
+
import { BlockArgumentsBatch, BlockProof, BlockProvable, BlockProverPublicInput, BlockProverPublicOutput, BlockProverStateInput } from "./BlockProvable";
|
|
10
|
+
import { BlockHashMerkleTreeWitness } from "./accummulators/BlockHashMerkleTree";
|
|
11
|
+
type BlockHookArgument<T extends "before" | "after"> = T extends "before" ? BeforeBlockHookArguments : AfterBlockHookArguments;
|
|
12
|
+
export declare class BlockProverProgrammable extends ZkProgrammable<BlockProverPublicInput, BlockProverPublicOutput> {
|
|
13
|
+
private readonly prover;
|
|
14
|
+
readonly stateTransitionProver: ZkProgrammable<StateTransitionProverPublicInput, StateTransitionProverPublicOutput>;
|
|
15
|
+
readonly transactionProver: ZkProgrammable<TransactionProverPublicInput, TransactionProverPublicOutput>;
|
|
16
|
+
private readonly blockHooks;
|
|
17
|
+
private readonly stateServiceProvider;
|
|
18
|
+
constructor(prover: BlockProver, stateTransitionProver: ZkProgrammable<StateTransitionProverPublicInput, StateTransitionProverPublicOutput>, transactionProver: ZkProgrammable<TransactionProverPublicInput, TransactionProverPublicOutput>, blockHooks: ProvableBlockHook<unknown>[], stateServiceProvider: StateServiceProvider);
|
|
19
|
+
name: string;
|
|
20
|
+
get areProofsEnabled(): AreProofsEnabled | undefined;
|
|
21
|
+
executeBlockHooks<T extends "before" | "after">(type: T, hook: (module: ProvableBlockHook<unknown>, networkState: NetworkState, args: BlockHookArgument<T>) => Promise<NetworkState>, hookArguments: BlockHookArgument<T>, inputNetworkState: NetworkState, isDummy: Bool): Promise<{
|
|
22
|
+
batch: import("../..").AppliedStateTransitionBatch;
|
|
23
|
+
result: NetworkState;
|
|
24
|
+
rawStatus: import("o1js/dist/node/lib/provable/bool").Bool;
|
|
25
|
+
}>;
|
|
26
|
+
includeSTProof(stateTransitionProof: StateTransitionProof, apply: Bool, stateRoot: Field, pendingSTBatchesHash: Field, witnessedRootsHash: Field): {
|
|
27
|
+
stateRoot: Field;
|
|
28
|
+
pendingSTBatchesHash: Field;
|
|
29
|
+
witnessedRootsHash: Field;
|
|
30
|
+
};
|
|
31
|
+
private verifySTProof;
|
|
32
|
+
private verifyTransactionProof;
|
|
33
|
+
private parseState;
|
|
34
|
+
private computeOutput;
|
|
35
|
+
proveBlockBatchNoProofs(publicInput: BlockProverPublicInput, stateWitness: BlockProverStateInput, networkState: NetworkState, blockWitness: BlockHashMerkleTreeWitness, batch: BlockArgumentsBatch, finalize: Bool): Promise<BlockProverPublicOutput>;
|
|
36
|
+
proveBlockBatchWithProofs(publicInput: BlockProverPublicInput, stateWitness: BlockProverStateInput, networkState: NetworkState, blockWitness: BlockHashMerkleTreeWitness, batch: BlockArgumentsBatch, deferSTProof: Bool, deferTransactionProof: Bool, stateTransitionProof: StateTransitionProof, transactionProof: TransactionProof): Promise<BlockProverPublicOutput>;
|
|
37
|
+
proveBlockBatch(doProofVerification: boolean, publicInput: BlockProverPublicInput, stateWitness: BlockProverStateInput, networkState: NetworkState, blockWitness: BlockHashMerkleTreeWitness, batch: BlockArgumentsBatch, deferSTProof: Bool, deferTransactionProof: Bool, finalize: Bool, stateTransitionProof?: StateTransitionProof, transactionProof?: TransactionProof): Promise<BlockProverPublicOutput>;
|
|
38
|
+
private proveBlock;
|
|
39
|
+
merge(publicInput: BlockProverPublicInput, proof1: BlockProof, proof2: BlockProof): Promise<BlockProverPublicOutput>;
|
|
9
40
|
/**
|
|
10
|
-
*
|
|
11
|
-
*
|
|
12
|
-
|
|
13
|
-
transactionsHash: Field;
|
|
14
|
-
/**
|
|
15
|
-
* The network state which gives access to values such as blockHeight
|
|
16
|
-
* This value is the same for the whole batch (L2 block)
|
|
41
|
+
* Creates the BlockProver ZkProgram.
|
|
42
|
+
* Recursive linking of proofs is done via the previously
|
|
43
|
+
* injected StateTransitionProver and the required AppChainProof class
|
|
17
44
|
*/
|
|
18
|
-
|
|
45
|
+
zkProgramFactory(): PlainZkProgram<BlockProverPublicInput, BlockProverPublicOutput>[];
|
|
19
46
|
}
|
|
20
47
|
/**
|
|
21
48
|
* BlockProver class, which aggregates a AppChainProof and
|
|
22
49
|
* a StateTransitionProof into a single BlockProof, that can
|
|
23
50
|
* then be merged to be committed to the base-layer contract
|
|
24
51
|
*/
|
|
25
|
-
export declare class BlockProver extends ProtocolModule
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
* @param stateTransitionProof
|
|
35
|
-
* @param appProof
|
|
36
|
-
* @returns The new BlockProver-state to be used as public output
|
|
37
|
-
*/
|
|
38
|
-
applyTransaction(state: BlockProverState, stateTransitionProof: Proof<StateTransitionProverPublicInput, StateTransitionProverPublicOutput>, appProof: Proof<void, MethodPublicOutput>, { transaction, networkState }: BlockProverExecutionData): BlockProverState;
|
|
39
|
-
proveTransaction(publicInput: BlockProverPublicInput, stateProof: StateTransitionProof, appProof: Proof<void, MethodPublicOutput>, executionData: BlockProverExecutionData): BlockProverPublicOutput;
|
|
40
|
-
merge(publicInput: BlockProverPublicInput, proof1: BlockProverProof, proof2: BlockProverProof): BlockProverPublicOutput;
|
|
41
|
-
/**
|
|
42
|
-
* Creates the BlockProver ZkProgram.
|
|
43
|
-
* Recursive linking of proofs is done via the previously
|
|
44
|
-
* injected StateTransitionProver and the required AppChainProof class
|
|
45
|
-
*/
|
|
46
|
-
zkProgramFactory(): PlainZkProgram<BlockProverPublicInput, BlockProverPublicOutput>;
|
|
52
|
+
export declare class BlockProver extends ProtocolModule implements BlockProvable, CompilableModule {
|
|
53
|
+
readonly stateTransitionProver: WithZkProgrammable<StateTransitionProverPublicInput, StateTransitionProverPublicOutput> & StateTransitionProvable;
|
|
54
|
+
readonly transactionProver: WithZkProgrammable<TransactionProverPublicInput, TransactionProverPublicOutput> & TransactionProvable;
|
|
55
|
+
zkProgrammable: BlockProverProgrammable;
|
|
56
|
+
constructor(stateTransitionProver: WithZkProgrammable<StateTransitionProverPublicInput, StateTransitionProverPublicOutput> & StateTransitionProvable, transactionProver: WithZkProgrammable<TransactionProverPublicInput, TransactionProverPublicOutput> & TransactionProvable, blockHooks: ProvableBlockHook<unknown>[], stateServiceProvider: StateServiceProvider);
|
|
57
|
+
compile(registry: CompileRegistry): Promise<Record<string, CompileArtifact> | undefined>;
|
|
58
|
+
proveBlockBatchNoProofs(publicInput: BlockProverPublicInput, stateWitness: BlockProverStateInput, networkState: NetworkState, blockWitness: BlockHashMerkleTreeWitness, batch: BlockArgumentsBatch, finalize: Bool): Promise<BlockProverPublicOutput>;
|
|
59
|
+
proveBlockBatchWithProofs(publicInput: BlockProverPublicInput, stateWitness: BlockProverStateInput, networkState: NetworkState, blockWitness: BlockHashMerkleTreeWitness, batch: BlockArgumentsBatch, deferSTProof: Bool, deferTransactionProof: Bool, stateTransitionProof: StateTransitionProof, transactionProof: TransactionProof): Promise<BlockProverPublicOutput>;
|
|
60
|
+
merge(publicInput: BlockProverPublicInput, proof1: BlockProof, proof2: BlockProof): Promise<BlockProverPublicOutput>;
|
|
47
61
|
}
|
|
62
|
+
export {};
|
|
48
63
|
//# sourceMappingURL=BlockProver.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BlockProver.d.ts","sourceRoot":"","sources":["../../../src/prover/block/BlockProver.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"BlockProver.d.ts","sourceRoot":"","sources":["../../../src/prover/block/BlockProver.ts"],"names":[],"mappings":"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"}
|