mirror of
https://source.quilibrium.com/quilibrium/ceremonyclient.git
synced 2024-12-26 08:35:17 +00:00
45 lines
883 B
Go
45 lines
883 B
Go
package crypto
|
|
|
|
import "source.quilibrium.com/quilibrium/monorepo/node/protobufs"
|
|
|
|
type InclusionCommitment struct {
|
|
TypeUrl string
|
|
Data []byte
|
|
Commitment []byte
|
|
}
|
|
|
|
type InclusionAggregateProof struct {
|
|
InclusionCommitments []*InclusionCommitment
|
|
AggregateCommitment []byte
|
|
Proof []byte
|
|
}
|
|
|
|
type InclusionProver interface {
|
|
Commit(
|
|
data []byte,
|
|
typeUrl string,
|
|
) (*InclusionCommitment, error)
|
|
ProveAggregate(commits []*InclusionCommitment) (
|
|
*InclusionAggregateProof,
|
|
error,
|
|
)
|
|
VerifyAggregate(proof *InclusionAggregateProof) (bool, error)
|
|
VerifyFrame(frame *protobufs.ClockFrame) error
|
|
CommitRaw(
|
|
data []byte,
|
|
polySize uint64,
|
|
) ([]byte, error)
|
|
ProveRaw(
|
|
data []byte,
|
|
index int,
|
|
polySize uint64,
|
|
) ([]byte, error)
|
|
VerifyRaw(
|
|
data []byte,
|
|
commit []byte,
|
|
index int,
|
|
proof []byte,
|
|
polySize uint64,
|
|
) (bool, error)
|
|
}
|