diff options
author | Rasmus Dahlberg <rasmus@mullvad.net> | 2022-05-21 20:31:09 +0200 |
---|---|---|
committer | Rasmus Dahlberg <rasmus@mullvad.net> | 2022-06-21 19:46:54 +0200 |
commit | cb6485bb6075179dc2521b8e82db961deae74faf (patch) | |
tree | bf05c3d83686cc056b3ef41b90a37a07b4269833 /cmd/sigsum-debug/leaf/inclusion/inclusion.go | |
parent | bbd6591c4f87b3f2c3e870b6418c6234d90a82e6 (diff) |
add proof verification to sigsum-debug
Diffstat (limited to 'cmd/sigsum-debug/leaf/inclusion/inclusion.go')
-rw-r--r-- | cmd/sigsum-debug/leaf/inclusion/inclusion.go | 28 |
1 files changed, 27 insertions, 1 deletions
diff --git a/cmd/sigsum-debug/leaf/inclusion/inclusion.go b/cmd/sigsum-debug/leaf/inclusion/inclusion.go index f9aeb68..e70b3eb 100644 --- a/cmd/sigsum-debug/leaf/inclusion/inclusion.go +++ b/cmd/sigsum-debug/leaf/inclusion/inclusion.go @@ -1,9 +1,35 @@ package inclusion import ( + "bytes" "fmt" + + "git.sigsum.org/sigsum-go/internal/fmtio" + "git.sigsum.org/sigsum-go/pkg/types" ) func Main(args []string, optLeafHash, optRootHash string, optTreeSize uint64) error { - return fmt.Errorf("TODO") + if len(args) != 0 { + return fmt.Errorf("trailing arguments: %v", args) + } + b, err := fmtio.BytesFromStdin() + if err != nil { + return fmt.Errorf("read: %w", err) + } + var proof types.InclusionProof + if err := proof.FromASCII(bytes.NewBuffer(b), optTreeSize); err != nil { + return fmt.Errorf("parse proof: %w", err) + } + leafHash, err := fmtio.HashFromHex(optLeafHash) + if err != nil { + return fmt.Errorf("parse leaf hash: %w", err) + } + rootHash, err := fmtio.HashFromHex(optRootHash) + if err != nil { + return fmt.Errorf("parse root hash: %w", err) + } + if err := proof.Verify(&leafHash, &rootHash); err != nil { + return fmt.Errorf("verify: %w", err) + } + return nil } |