aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorÖzgür Kesim <oec@codeblau.de>2024-11-11 18:05:25 +0100
committerÖzgür Kesim <oec@codeblau.de>2024-11-11 18:05:25 +0100
commit7813100e5429ca486d6310f8a04d7a0d11325f2e (patch)
treed7bd0aad9a1e2557aafd129c285c132bae9dcd12
parent08ca372b0a95025a5ab49ccb4ee51af1aa1185ff (diff)
refactor struct names
-rw-r--r--auction.go10
-rw-r--r--auction_test.go61
-rw-r--r--nizk/commit/commit.go65
-rw-r--r--nizk/commit/commit_test.go24
4 files changed, 110 insertions, 50 deletions
diff --git a/auction.go b/auction.go
index 9dd7da5..053acdd 100644
--- a/auction.go
+++ b/auction.go
@@ -123,15 +123,17 @@ type auction struct {
log *slog.Logger
}
+// Start must be called by the bidder or observer,
+// when they receive a start signal from the dashboard
func (a *auction) Start() error {
- return errors.New("Start not implemented")
+ return fmt.Errorf("auction.Start not fully implemented")
}
func (a *auction) Cancel() error {
return errors.New("Cancel not implemented")
}
-// Message is called by the Bidder or Observer
+// Message is called by the bidder's or observer's code
// whenever a message came in for the auction via the dashboard
// or other means of communication.
func (a *auction) Message(msg Message) error {
@@ -142,9 +144,9 @@ const MAXBITLENGTH = 64
// Bidder is the interface that the Auction engine uses to interact
type Bidder interface {
- Broadcast([]byte) error
+ Broadcast(Message) error
Result(Result)
- Start()
+ Start() error
}
func Join(
diff --git a/auction_test.go b/auction_test.go
index 04c2590..5f2b3e1 100644
--- a/auction_test.go
+++ b/auction_test.go
@@ -2,7 +2,11 @@ package seal
import (
"encoding/json"
+ "fmt"
+ "log/slog"
+ "math/rand"
"strings"
+ "sync"
"testing"
"time"
)
@@ -34,3 +38,60 @@ func TestParseDescription(t *testing.T) {
t.Fatalf("expected bitlength %d, but got: %d", 8, d.Bitlength)
}
}
+
+type bidder struct {
+ bid uint64
+}
+
+func (b *bidder) Broadcast(m Message) error {
+ return fmt.Errorf("Broadcast not implemented")
+}
+
+func (b *bidder) Result(r Result) {
+ fmt.Printf("got result: %v\n", r)
+}
+
+func (b *bidder) Start() error {
+ return fmt.Errorf("bidder start not fully implemented")
+}
+
+func TestAuction(t *testing.T) {
+ var bidders [10]struct {
+ b bidder
+ a Auction
+ }
+ d := Description{
+ Start: time.Now(),
+ End: time.Now().Add(time.Hour),
+ Timeout: Duration(time.Minute),
+ Bitlength: 8,
+ Type: TypHighest,
+ Seller: nil,
+ }
+
+ for i := range bidders {
+ bidders[i].b.bid = rand.Uint64() & 0xFF
+ a, e := Join(&bidders[i].b, &d)
+ if e != nil {
+ t.Fatal(e)
+ }
+ if e != nil {
+ t.Fatal(e)
+ }
+ bidders[i].a = a
+ }
+
+ var wg sync.WaitGroup
+
+ wg.Add(len(bidders))
+ for i, b := range bidders {
+ go func() {
+ e := b.a.Start()
+ if e != nil {
+ (b.a.(*auction)).log.Error(e.Error(), slog.Int("id", i), slog.Uint64("bid", b.b.bid))
+ }
+ wg.Done()
+ }()
+ }
+ wg.Wait()
+}
diff --git a/nizk/commit/commit.go b/nizk/commit/commit.go
index 1fa653e..49690f2 100644
--- a/nizk/commit/commit.go
+++ b/nizk/commit/commit.go
@@ -6,42 +6,41 @@ import (
)
// This is a construction of a proof of a statement of the form
-// [(C = g^(ab)) && (A = g^a) && (Β = g^b)]
-// || [(C = g^(ab+1)) && (A = g^a) && (Β = g^b)]
+// [(C = g^(αβ)) && (A = g^α) && (Β = g^β)]
+// || [(C = g^(αβ+1)) && (A = g^α) && (Β = g^β)]
//
// for given C, A and B
-type Statement struct {
+type Bid struct {
bitSet bool
- a *Scalar
- b *Scalar
+ α *Scalar
+ β *Scalar
Commitment
}
type Commitment struct {
- C *Point
- A *Point
- B *Point
- Proof *Proof
+ A *Point // g^α
+ B *Point // g^β
+ C *Point // g^(ab)g^(bitSet)
}
-func NewStatement(bitSet bool) *Statement {
- a, b := Curve.RandomScalar(), Curve.RandomScalar()
- return NewStatementFromScalars(bitSet, a, b)
+func NewBid(bitSet bool) *Bid {
+ α, β := Curve.RandomScalar(), Curve.RandomScalar()
+ return NewBidFromScalars(bitSet, α, β)
}
-func NewStatementFromScalars(bitSet bool, a, b *Scalar) *Statement {
- return &Statement{
- a: a,
- b: b,
+func NewBidFromScalars(bitSet bool, α, β *Scalar) *Bid {
+ return &Bid{
+ α: α,
+ β: β,
bitSet: bitSet,
- Commitment: commitment(a, b, bitSet),
+ Commitment: commitment(α, β, bitSet),
}
}
-func commitment(a, b *Scalar, bitSet bool) Commitment {
+func commitment(α, β *Scalar, bitSet bool) Commitment {
var C *Point
- c := a.Mul(b)
+ c := α.Mul(β)
if bitSet {
C = G.Exp(c.Add(One))
@@ -50,27 +49,26 @@ func commitment(a, b *Scalar, bitSet bool) Commitment {
}
return Commitment{
C: C,
- A: G.Exp(a),
- B: G.Exp(b),
+ A: G.Exp(α),
+ B: G.Exp(β),
}
}
-func (s *Statement) Commit(id Bytes) *Commitment {
- s.Commitment.Proof = s.Proof(id)
- return &s.Commitment
+func (s *Bid) Commit(id Bytes) (*Commitment, *Proof) {
+ return &s.Commitment, s.Proof(id)
}
type Proof struct {
Id Bytes
- A *schnorr.Proof // Proof for knowledge of a in A = G^a
- B *schnorr.Proof // Proof for knowledge of b in B = G^b
+ A *schnorr.Proof // Proof for knowledge of α in A = G^α
+ B *schnorr.Proof // Proof for knowledge of β in B = G^β
C struct { // Proof for knowledge of statement above
Ch [2]*Scalar
R [2]*Scalar
}
}
-func (s *Statement) Proof(id Bytes) *Proof {
+func (s *Bid) Proof(id Bytes) *Proof {
var e [2][2]*Point
var r1, r2, w *Scalar
r1 = Curve.RandomScalar()
@@ -95,23 +93,22 @@ func (s *Statement) Proof(id Bytes) *Proof {
if s.bitSet {
pr.C.Ch[0] = w
pr.C.Ch[1] = ch.Sub(w)
- pr.C.R[0] = r1.Sub(s.a.Mul(pr.C.Ch[0]))
- pr.C.R[1] = r2.Sub(s.a.Mul(pr.C.Ch[1]))
+ pr.C.R[0] = r1.Sub(s.α.Mul(pr.C.Ch[0]))
+ pr.C.R[1] = r2.Sub(s.α.Mul(pr.C.Ch[1]))
} else {
pr.C.Ch[0] = ch.Sub(w)
pr.C.Ch[1] = w
- pr.C.R[0] = r1.Sub(s.a.Mul(pr.C.Ch[0]))
+ pr.C.R[0] = r1.Sub(s.α.Mul(pr.C.Ch[0]))
pr.C.R[1] = r2
}
- pr.A = (*schnorr.Statement)(s.a).Proof(id)
- pr.B = (*schnorr.Statement)(s.b).Proof(id)
+ pr.A = (*schnorr.Statement)(s.α).Proof(id)
+ pr.B = (*schnorr.Statement)(s.β).Proof(id)
return pr
}
-func (c *Commitment) Verify() bool {
+func (c *Commitment) Verify(p *Proof) bool {
var e [2][2]*Point
- p := c.Proof
e[0][0] = G.Exp(p.C.R[0]).Mul(c.A.Exp(p.C.Ch[0]))
e[0][1] = c.B.Exp(p.C.R[0]).Mul(c.C.Exp(p.C.Ch[0]))
diff --git a/nizk/commit/commit_test.go b/nizk/commit/commit_test.go
index 4ea5964..111ab68 100644
--- a/nizk/commit/commit_test.go
+++ b/nizk/commit/commit_test.go
@@ -10,18 +10,18 @@ func TestStatement(t *testing.T) {
id := Curve.RandomScalar()
Id := G.Exp(id)
- st1, st2 := NewStatement(true), NewStatement(false)
- c1, c2 := st1.Commit(Id), st2.Commit(Id)
- if !c1.Verify() {
+ st1, st2 := NewBid(true), NewBid(false)
+ c1, p1 := st1.Commit(Id)
+ c2, p2 := st2.Commit(Id)
+ if !c1.Verify(p1) {
t.Fatal("Could not verify st1 with c1, plus=true case")
}
- if !c2.Verify() {
+ if !c2.Verify(p2) {
t.Fatal("Could not verify st2 with c2, plus=false case")
}
// Use the wrong proof
- c2.Proof = c1.Proof
- if c2.Verify() {
+ if c2.Verify(p1) {
t.Fatal("Verify with wrong proof should have failed!")
}
}
@@ -31,18 +31,18 @@ func TestStatementFromScalar(t *testing.T) {
Id := G.Exp(id)
- st1, st2 := NewStatementFromScalars(true, α, β), NewStatementFromScalars(false, α, β)
- c1, c2 := st1.Commit(Id), st2.Commit(Id)
- if !c1.Verify() {
+ st1, st2 := NewBidFromScalars(true, α, β), NewBidFromScalars(false, α, β)
+ c1, p1 := st1.Commit(Id)
+ c2, p2 := st2.Commit(Id)
+ if !c1.Verify(p1) {
t.Fatal("Could not verify st1 with c1, plus=true case")
}
- if !c2.Verify() {
+ if !c2.Verify(p2) {
t.Fatal("Could not verify st2 with c2, plus=false case")
}
// Use the wrong proof
- c2.Proof = c1.Proof
- if c2.Verify() {
+ if c2.Verify(p1) {
t.Fatal("Verify with wrong proof should have failed!")
}
}