mirror of
https://github.com/status-im/nim-dagger.git
synced 2025-01-27 15:05:47 +00:00
2cf892c467
* Smart contracts update: Groth16Proof instead of bytes * Use dummy verifier for now, until we can create ZK proofs * Fix tests: submit proof only when slot is filled * Submit dummy proofs for now * More detailed log when proof submission failed * Use dummy verifier for integration tests For now at least * Fix mistake in blanket renaming to ethProvider * Update to latest codex-contracts-eth * feat: zkey-hash from chain * Fix zkeyHash --------- Co-authored-by: Adam Uhlíř <adam@uhlir.dev>
74 lines
2.5 KiB
Nim
74 lines
2.5 KiB
Nim
import pkg/contractabi
|
|
import pkg/ethers/fields
|
|
import pkg/questionable/results
|
|
|
|
export contractabi
|
|
|
|
type
|
|
MarketplaceConfig* = object
|
|
collateral*: CollateralConfig
|
|
proofs*: ProofConfig
|
|
CollateralConfig* = object
|
|
repairRewardPercentage*: uint8 # percentage of remaining collateral slot has after it has been freed
|
|
maxNumberOfSlashes*: uint8 # frees slot when the number of slashes reaches this value
|
|
slashCriterion*: uint16 # amount of proofs missed that lead to slashing
|
|
slashPercentage*: uint8 # percentage of the collateral that is slashed
|
|
ProofConfig* = object
|
|
period*: UInt256 # proofs requirements are calculated per period (in seconds)
|
|
timeout*: UInt256 # mark proofs as missing before the timeout (in seconds)
|
|
downtime*: uint8 # ignore this much recent blocks for proof requirements
|
|
zkeyHash*: string # hash of the zkey file which is linked to the verifier
|
|
|
|
|
|
func fromTuple(_: type ProofConfig, tupl: tuple): ProofConfig =
|
|
ProofConfig(
|
|
period: tupl[0],
|
|
timeout: tupl[1],
|
|
downtime: tupl[2],
|
|
zkeyHash: tupl[3]
|
|
)
|
|
|
|
func fromTuple(_: type CollateralConfig, tupl: tuple): CollateralConfig =
|
|
CollateralConfig(
|
|
repairRewardPercentage: tupl[0],
|
|
maxNumberOfSlashes: tupl[1],
|
|
slashCriterion: tupl[2],
|
|
slashPercentage: tupl[3]
|
|
)
|
|
|
|
func fromTuple(_: type MarketplaceConfig, tupl: tuple): MarketplaceConfig =
|
|
MarketplaceConfig(
|
|
collateral: tupl[0],
|
|
proofs: tupl[1]
|
|
)
|
|
|
|
func solidityType*(_: type ProofConfig): string =
|
|
solidityType(ProofConfig.fieldTypes)
|
|
|
|
func solidityType*(_: type CollateralConfig): string =
|
|
solidityType(CollateralConfig.fieldTypes)
|
|
|
|
func solidityType*(_: type MarketplaceConfig): string =
|
|
solidityType(CollateralConfig.fieldTypes)
|
|
|
|
func encode*(encoder: var AbiEncoder, slot: ProofConfig) =
|
|
encoder.write(slot.fieldValues)
|
|
|
|
func encode*(encoder: var AbiEncoder, slot: CollateralConfig) =
|
|
encoder.write(slot.fieldValues)
|
|
|
|
func encode*(encoder: var AbiEncoder, slot: MarketplaceConfig) =
|
|
encoder.write(slot.fieldValues)
|
|
|
|
func decode*(decoder: var AbiDecoder, T: type ProofConfig): ?!T =
|
|
let tupl = ?decoder.read(ProofConfig.fieldTypes)
|
|
success ProofConfig.fromTuple(tupl)
|
|
|
|
func decode*(decoder: var AbiDecoder, T: type CollateralConfig): ?!T =
|
|
let tupl = ?decoder.read(CollateralConfig.fieldTypes)
|
|
success CollateralConfig.fromTuple(tupl)
|
|
|
|
func decode*(decoder: var AbiDecoder, T: type MarketplaceConfig): ?!T =
|
|
let tupl = ?decoder.read(MarketplaceConfig.fieldTypes)
|
|
success MarketplaceConfig.fromTuple(tupl)
|