forked from tunabay/go-bitarray
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbitarray_sha1.go
48 lines (39 loc) · 1.28 KB
/
bitarray_sha1.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
// Copyright (c) 2021 Hirotsuna Mizuno. All rights reserved.
// Use of this source code is governed by the MIT license that can be found in
// the LICENSE file.
package bitarray
import (
//nolint:gosec // intentionally provided option
_ "crypto/sha1" // block()
"encoding/binary"
_ "unsafe" // linkname
)
// SHA1 returns the SHA-1 checksum of the bit array. It treats the bit array as
// a bit-oriented message to compute the checksum as defined in RFC 3174.
func (ba *BitArray) SHA1() [20]byte {
nBits := ba.Len()
buf := NewBuffer((nBits + 1 + 64 + 511) &^ 511)
buf.PutBitArrayAt(0, ba)
buf.PutBitAt(nBits, 1)
binary.BigEndian.PutUint64(buf.b[len(buf.b)-8:], uint64(nBits))
d := &sha1Digest{}
sha1Reset(d)
sha1Block(d, buf.b)
var sha1 [20]byte
for i := 0; i < 5; i++ {
binary.BigEndian.PutUint32(sha1[i<<2:], d.h[i])
}
return sha1
}
// crypto/sha1.digest
// TODO: if possible, use crypto/sha1.digest directly
type sha1Digest struct {
h [5]uint32
x [64]byte //nolint:structcheck,unused // for Reset()
nx int //nolint:structcheck,unused // for Reset()
len uint64 //nolint:structcheck,unused // for Reset()
}
//go:linkname sha1Block crypto/sha1.block
func sha1Block(*sha1Digest, []byte)
//go:linkname sha1Reset crypto/sha1.(*digest).Reset
func sha1Reset(*sha1Digest)