mirror of
https://github.com/codex-storage/nim-codex.git
synced 2025-01-09 12:35:51 +00:00
25df599c08
1. use `ProviderError` to catch contract errors instaed of `JsonRpcProviderError`. 2. Add tests for `isProofRequired`, `willProofBeRequired`, and `getProofEnd` when slot is empty (and is call is reverted) 3. bump nim-ethers to branch that has new `reverts` API and `ProviderError` support. 4. Update to new `reverts` API.
69 lines
2.3 KiB
Nim
69 lines
2.3 KiB
Nim
import std/strutils
|
|
import pkg/ethers
|
|
import pkg/ethers/testing
|
|
import ../storageproofs/timing/proofs
|
|
import ./storage
|
|
|
|
export proofs
|
|
|
|
type
|
|
OnChainProofs* = ref object of Proofs
|
|
storage: Storage
|
|
pollInterval*: Duration
|
|
ProofsSubscription = proofs.Subscription
|
|
EventSubscription = ethers.Subscription
|
|
OnChainProofsSubscription = ref object of ProofsSubscription
|
|
eventSubscription: EventSubscription
|
|
|
|
const DefaultPollInterval = 3.seconds
|
|
|
|
proc new*(_: type OnChainProofs, storage: Storage): OnChainProofs =
|
|
OnChainProofs(storage: storage, pollInterval: DefaultPollInterval)
|
|
|
|
method periodicity*(proofs: OnChainProofs): Future[Periodicity] {.async.} =
|
|
let period = await proofs.storage.proofPeriod()
|
|
return Periodicity(seconds: period)
|
|
|
|
method isProofRequired*(proofs: OnChainProofs,
|
|
id: SlotId): Future[bool] {.async.} =
|
|
try:
|
|
return await proofs.storage.isProofRequired(id)
|
|
except ProviderError as e:
|
|
if e.revertReason.contains("Slot empty"):
|
|
return false
|
|
raise e
|
|
|
|
method willProofBeRequired*(proofs: OnChainProofs,
|
|
id: SlotId): Future[bool] {.async.} =
|
|
try:
|
|
return await proofs.storage.willProofBeRequired(id)
|
|
except ProviderError as e:
|
|
if e.revertReason.contains("Slot empty"):
|
|
return false
|
|
raise e
|
|
|
|
method getProofEnd*(proofs: OnChainProofs,
|
|
id: SlotId): Future[UInt256] {.async.} =
|
|
try:
|
|
return await proofs.storage.proofEnd(id)
|
|
except ProviderError as e:
|
|
if e.revertReason.contains("Slot empty"):
|
|
return 0.u256
|
|
raise e
|
|
|
|
method submitProof*(proofs: OnChainProofs,
|
|
id: SlotId,
|
|
proof: seq[byte]) {.async.} =
|
|
await proofs.storage.submitProof(id, proof)
|
|
|
|
method subscribeProofSubmission*(proofs: OnChainProofs,
|
|
callback: OnProofSubmitted):
|
|
Future[ProofsSubscription] {.async.} =
|
|
proc onEvent(event: ProofSubmitted) {.upraises: [].} =
|
|
callback(event.id, event.proof)
|
|
let subscription = await proofs.storage.subscribe(ProofSubmitted, onEvent)
|
|
return OnChainProofsSubscription(eventSubscription: subscription)
|
|
|
|
method unsubscribe*(subscription: OnChainProofsSubscription) {.async, upraises:[].} =
|
|
await subscription.eventSubscription.unsubscribe()
|