2023-03-08 20:04:30 +07:00
|
|
|
############################################################
|
|
|
|
# Convenience wrapper where KzgSettings is a global variable
|
|
|
|
############################################################
|
|
|
|
|
|
|
|
import
|
|
|
|
stew/results,
|
|
|
|
./kzg
|
|
|
|
|
|
|
|
export
|
|
|
|
results,
|
|
|
|
kzg
|
|
|
|
|
|
|
|
type
|
|
|
|
Kzg* = object
|
|
|
|
|
|
|
|
when (NimMajor, NimMinor) < (1, 4):
|
|
|
|
{.push raises: [Defect].}
|
|
|
|
else:
|
|
|
|
{.push raises: [].}
|
|
|
|
|
|
|
|
##############################################################
|
|
|
|
# Private helpers
|
|
|
|
##############################################################
|
|
|
|
|
2023-03-21 09:30:50 +07:00
|
|
|
var gCtx = KzgCtx(nil)
|
2023-03-08 20:04:30 +07:00
|
|
|
|
|
|
|
const
|
2023-03-21 09:30:50 +07:00
|
|
|
TrustedSetupNotLoadedErr = "Trusted setup not loaded."
|
|
|
|
TrustedSetupAlreadyLoadedErr =
|
|
|
|
"Trusted setup is already loaded. Free it before loading a new one."
|
2023-03-08 20:04:30 +07:00
|
|
|
|
|
|
|
template setupCtx(body: untyped): untyped =
|
2023-03-21 09:30:50 +07:00
|
|
|
if not gCtx.isNil:
|
|
|
|
return err(TrustedSetupAlreadyLoadedErr)
|
2023-03-08 20:04:30 +07:00
|
|
|
let res = body
|
|
|
|
if res.isErr:
|
|
|
|
return err(res.error)
|
|
|
|
gCtx = res.get
|
|
|
|
ok()
|
|
|
|
|
|
|
|
template verifyCtx(body: untyped): untyped =
|
|
|
|
{.gcsafe.}:
|
|
|
|
if gCtx.isNil:
|
2023-03-21 09:30:50 +07:00
|
|
|
return err(TrustedSetupNotLoadedErr)
|
2023-03-08 20:04:30 +07:00
|
|
|
body
|
|
|
|
|
|
|
|
##############################################################
|
|
|
|
# Public functions
|
|
|
|
##############################################################
|
|
|
|
|
|
|
|
proc loadTrustedSetup*(_: type Kzg,
|
|
|
|
input: File): Result[void, string] =
|
|
|
|
setupCtx:
|
|
|
|
kzg.loadTrustedSetup(input)
|
|
|
|
|
|
|
|
proc loadTrustedSetup*(_: type Kzg,
|
|
|
|
fileName: string): Result[void, string] =
|
|
|
|
setupCtx:
|
|
|
|
kzg.loadTrustedSetup(fileName)
|
|
|
|
|
|
|
|
proc loadTrustedSetup*(_: type Kzg, g1: openArray[G1Data],
|
|
|
|
g2: openArray[G2Data]):
|
|
|
|
Result[void, string] =
|
|
|
|
setupCtx:
|
|
|
|
kzg.loadTrustedSetup(g1, g2)
|
|
|
|
|
|
|
|
proc loadTrustedSetupFromString*(_: type Kzg,
|
|
|
|
input: string): Result[void, string] =
|
|
|
|
setupCtx:
|
|
|
|
kzg.loadTrustedSetupFromString(input)
|
|
|
|
|
2023-03-21 09:30:50 +07:00
|
|
|
proc freeTrustedSetup*(_: type Kzg): Result[void, string] =
|
|
|
|
verifyCtx:
|
|
|
|
gCtx.freeTrustedSetup()
|
|
|
|
gCtx = nil
|
|
|
|
ok()
|
|
|
|
|
2023-03-08 20:04:30 +07:00
|
|
|
proc toCommitment*(blob: KzgBlob):
|
|
|
|
Result[KzgCommitment, string] {.gcsafe.} =
|
|
|
|
verifyCtx:
|
|
|
|
gCtx.toCommitment(blob)
|
|
|
|
|
|
|
|
proc computeProof*(blob: KzgBlob,
|
|
|
|
z: KzgBytes32): Result[KzgProofAndY, string] {.gcsafe.} =
|
|
|
|
verifyCtx:
|
|
|
|
gCtx.computeProof(blob, z)
|
|
|
|
|
|
|
|
proc computeProof*(blob: KzgBlob,
|
|
|
|
commitmentBytes: KzgBytes48):
|
|
|
|
Result[KzgProof, string] {.gcsafe.} =
|
|
|
|
verifyCtx:
|
|
|
|
gCtx.computeProof(blob, commitmentBytes)
|
|
|
|
|
|
|
|
proc verifyProof*(commitment: KzgBytes48,
|
|
|
|
z: KzgBytes32, # Input Point
|
|
|
|
y: KzgBytes32, # Claimed Value
|
|
|
|
proof: KzgBytes48): Result[bool, string] {.gcsafe.} =
|
|
|
|
verifyCtx:
|
|
|
|
gCtx.verifyProof(commitment, z, y, proof)
|
|
|
|
|
|
|
|
proc verifyProof*(blob: KzgBlob,
|
|
|
|
commitment: KzgBytes48,
|
|
|
|
proof: KzgBytes48): Result[bool, string] {.gcsafe.} =
|
|
|
|
verifyCtx:
|
|
|
|
gCtx.verifyProof(blob, commitment, proof)
|
|
|
|
|
|
|
|
proc verifyProofs*(blobs: openArray[KzgBlob],
|
|
|
|
commitments: openArray[KzgBytes48],
|
|
|
|
proofs: openArray[KzgBytes48]): Result[bool, string] {.gcsafe.} =
|
|
|
|
verifyCtx:
|
|
|
|
gCtx.verifyProofs(blobs, commitments, proofs)
|
|
|
|
|
|
|
|
##############################################################
|
|
|
|
# Zero overhead aliases that match the spec
|
|
|
|
##############################################################
|
|
|
|
|
|
|
|
template loadTrustedSetupFile*(T: type Kzg, input: File | string): untyped =
|
|
|
|
loadTrustedSetup(T, input)
|
|
|
|
|
|
|
|
template blobToKzgCommitment*(blob: KzgBlob): untyped =
|
|
|
|
toCommitment(blob)
|
|
|
|
|
|
|
|
template computeKzgProof*(blob: KzgBlob, z: KzgBytes32): untyped =
|
|
|
|
computeProof(blob, z)
|
|
|
|
|
|
|
|
template computeBlobKzgProof*(blob: KzgBlob,
|
|
|
|
commitmentBytes: KzgBytes48): untyped =
|
|
|
|
computeProof(blob, commitmentBytes)
|
|
|
|
|
|
|
|
template verifyKzgProof*(commitment: KzgBytes48,
|
|
|
|
z: KzgBytes32, # Input Point
|
|
|
|
y: KzgBytes32, # Claimed Value
|
|
|
|
proof: KzgBytes48): untyped =
|
|
|
|
verifyProof(commitment, z, y, proof)
|
|
|
|
|
|
|
|
template verifyBlobKzgProof*(blob: KzgBlob,
|
|
|
|
commitment: KzgBytes48,
|
|
|
|
proof: KzgBytes48): untyped =
|
|
|
|
verifyProof(blob, commitment, proof)
|
|
|
|
|
|
|
|
template verifyBlobKzgProofBatch*(blobs: openArray[KzgBlob],
|
|
|
|
commitments: openArray[KzgBytes48],
|
|
|
|
proofs: openArray[KzgBytes48]): untyped =
|
|
|
|
verifyProofs(blobs, commitments, proofs)
|
|
|
|
|
|
|
|
{. pop .}
|