swisspost-evoting-go-poc/pkg/mixnet/verifiable_shuffle.go
saymrwulf e8b6f30871 Swiss Post E-Voting Go PoC
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.
2026-02-13 19:53:09 +01:00

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)
}