aboutsummaryrefslogtreecommitdiff
path: root/cmd/sigsum-debug/hashleaf
diff options
context:
space:
mode:
authorRasmus Dahlberg <rasmus@mullvad.net>2022-04-13 16:10:43 +0200
committerRasmus Dahlberg <rasmus@mullvad.net>2022-04-13 16:10:43 +0200
commit8fee6561fbc21bd44f67dff9f365aa14da293d99 (patch)
treee1f27b545439a7cb47254342cfbff6121bf41f6b /cmd/sigsum-debug/hashleaf
parent8a4f764a7304ecbff07d451a21926bdc1a7fb3d4 (diff)
clean-up sigsum-debug structure
Diffstat (limited to 'cmd/sigsum-debug/hashleaf')
-rw-r--r--cmd/sigsum-debug/hashleaf/hashleaf.go38
1 files changed, 38 insertions, 0 deletions
diff --git a/cmd/sigsum-debug/hashleaf/hashleaf.go b/cmd/sigsum-debug/hashleaf/hashleaf.go
new file mode 100644
index 0000000..00f8bbb
--- /dev/null
+++ b/cmd/sigsum-debug/hashleaf/hashleaf.go
@@ -0,0 +1,38 @@
+package hashleaf
+
+import (
+ "crypto/ed25519"
+ "fmt"
+
+ "git.sigsum.org/sigsum-go/pkg/hex"
+ "git.sigsum.org/sigsum-go/pkg/types"
+ "git.sigsum.org/sigsum-tools-go/internal/util"
+)
+
+func Main(_ []string, optPriv string, optShardHint uint64) error {
+ data, err := util.BytesFromStdin()
+ if err != nil {
+ return fmt.Errorf("sign: %v", err)
+ }
+ priv, err := util.SignerFromHex(optPriv)
+ if err != nil {
+ return fmt.Errorf("sign: %v", err)
+ }
+ stm := types.Statement{
+ ShardHint: optShardHint,
+ Checksum: *types.HashFn(data),
+ }
+ sig, err := stm.Sign(priv)
+ if err != nil {
+ fmt.Errorf("sign: %v", err)
+ }
+ leaf := types.Leaf{
+ Statement: stm,
+ Signature: *sig,
+ KeyHash: *types.HashFn(priv.Public().(ed25519.PublicKey)[:]),
+ }
+ lh := types.LeafHash(leaf.ToBinary())
+
+ fmt.Printf("%s\n", hex.Serialize(lh[:]))
+ return nil
+}