From 4f6d76a0053dbfdaa799729f92fbddb7890a49c5 Mon Sep 17 00:00:00 2001 From: siddharth Date: Sat, 9 Oct 2021 16:58:24 -0400 Subject: lib: add MPPadding --- lib/sha1.go | 41 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 41 insertions(+) (limited to 'lib') diff --git a/lib/sha1.go b/lib/sha1.go index 34f5f37..559d515 100644 --- a/lib/sha1.go +++ b/lib/sha1.go @@ -234,3 +234,44 @@ func (s *Sha1) MacVerify(secret, msg, mac []byte) bool { } return false } + +// Returns Merkle–Damgård padding in bytes for message `m` +func MDPadding(m []byte) []byte { + l := len(m) * 8 // msg size in bits + + // Reckon value of `k` + k := 0 + for ((l + 1 + k) % 512) != 448 { + k += 1 + } + + // Initialize padding bytes + pbs := make([]byte, 0) + + // Add bit `1` as byte block. + pbs = append(pbs, 0x80) + f := 7 // unclaimed bits in last byte of `pbs` + + // Add `k` bit `0`s + for i := 0; i < k; i++ { + if f == 0 { + pbs = append(pbs, 0x0) + f = 8 + } + f = f - 1 + } + + // Add `l` in a 64 bit block in `pbs` + l64 := uint64(l) + b64 := make([]byte, 8) // last 64-bits + for i := 7; i >= 0; i-- { + // Get 8 last bits. + b64[i] = byte(l64 & 0xFF) + + // Get rid of the last 8 bits. + l64 = l64 >> 8 + } + pbs = append(pbs, b64...) + + return pbs +} -- cgit v1.2.3