mirror of
https://github.com/saymrwulf/swisspost-evoting-go-poc.git
synced 2026-05-14 20:58:03 +00:00
Proof-of-concept reimplementation of the Swiss Post e-voting cryptographic protocol in Go. Single binary, 52 source files, 2 dependencies. Covers ElGamal encryption, Bayer-Groth verifiable shuffles, zero-knowledge proofs, return codes, and a full election ceremony demo.
53 lines
1.3 KiB
Go
53 lines
1.3 KiB
Go
package mixnet
|
|
|
|
import (
|
|
"github.com/user/evote/pkg/elgamal"
|
|
emath "github.com/user/evote/pkg/math"
|
|
)
|
|
|
|
// VerifiableShuffle holds the result of a verifiable shuffle.
|
|
type VerifiableShuffle struct {
|
|
ShuffledCiphertexts *elgamal.CiphertextVector
|
|
Argument ShuffleArgument
|
|
}
|
|
|
|
// GenVerifiableShuffle performs a shuffle and generates a proof.
|
|
func GenVerifiableShuffle(
|
|
C *elgamal.CiphertextVector,
|
|
pk elgamal.PublicKey,
|
|
group *emath.GqGroup,
|
|
) VerifiableShuffle {
|
|
// Determine matrix dimensions
|
|
N := C.Size()
|
|
_, n := GetMatrixDimensions(N)
|
|
|
|
// Generate commitment key of size n
|
|
ck := GenCommitmentKey(n, group)
|
|
|
|
// Perform shuffle
|
|
shuffle := GenShuffle(C, pk)
|
|
|
|
// Generate shuffle argument
|
|
arg := GenShuffleArgument(C, shuffle.Shuffled, shuffle.Perm, shuffle.Rho, pk, ck, group)
|
|
|
|
return VerifiableShuffle{
|
|
ShuffledCiphertexts: shuffle.Shuffled,
|
|
Argument: arg,
|
|
}
|
|
}
|
|
|
|
// VerifyShuffle verifies a verifiable shuffle.
|
|
func VerifyShuffle(
|
|
C *elgamal.CiphertextVector,
|
|
vs VerifiableShuffle,
|
|
pk elgamal.PublicKey,
|
|
group *emath.GqGroup,
|
|
) bool {
|
|
N := C.Size()
|
|
_, n := GetMatrixDimensions(N)
|
|
|
|
// Regenerate commitment key (deterministic from group)
|
|
ck := GenCommitmentKey(n, group)
|
|
|
|
return VerifyShuffleArgument(vs.Argument, C, vs.ShuffledCiphertexts, pk, ck, group)
|
|
}
|