/
checksum.go
46 lines (43 loc) · 927 Bytes
/
checksum.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
package onionbuffer
import (
"bufio"
"bytes"
"crypto/md5"
"crypto/subtle"
"encoding/hex"
"io"
"syscall"
)
func (b *OnionBuffer) GetChecksum() (string, error) {
b.Lock()
var count int
var err error
hash := md5.New()
reader := bufio.NewReader(bytes.NewReader(b.Bytes))
chunk := make([]byte, 1)
if err := syscall.Mlock(chunk); err != nil { // Lock memory allotted to chunk from being used in SWAP
return "", err
}
for {
if count, err = reader.Read(chunk); err != nil {
break
}
_, err := hash.Write(chunk[:count])
if err != nil {
return "", err
}
}
if err != io.EOF {
return "", err
}
b.Unlock()
hashInBytes := hash.Sum(nil)[:16]
return hex.EncodeToString(hashInBytes), nil
}
func (b *OnionBuffer) ValidateChecksum() (bool, error) {
chksm, err := b.GetChecksum()
if err != nil {
return false, err
}
return subtle.ConstantTimeCompare([]byte(b.Checksum), []byte(chksm)) == 1, nil
}