-
Notifications
You must be signed in to change notification settings - Fork 0
/
hashing.go
68 lines (50 loc) · 1.37 KB
/
hashing.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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
package utils
import (
"bytes"
"crypto/rand"
"crypto/sha256"
"encoding/hex"
"fmt"
"github.com/go-park-mail-ru/2023_2_Rabotyagi/pkg/my_logger"
"github.com/go-park-mail-ru/2023_2_Rabotyagi/pkg/myerrors"
"golang.org/x/crypto/argon2"
)
const (
saltLen = 8
timeHash = 1
memory = 64 * 1024
threads = 4
keyLen = 32
)
func HashPass(plainPassword string) (string, error) {
logger, err := my_logger.Get()
if err != nil {
return "", fmt.Errorf(myerrors.ErrTemplate, err)
}
salt := make([]byte, saltLen)
_, err = rand.Read(salt)
if err != nil {
logger.Errorln(err)
return "", fmt.Errorf(myerrors.ErrTemplate, err)
}
return hex.EncodeToString(hashPassWithSalt(salt, plainPassword)), nil
}
func hashPassWithSalt(salt []byte, plainPassword string) []byte {
hashedPass := argon2.IDKey([]byte(plainPassword), salt, timeHash, memory, threads, keyLen)
return append(salt, hashedPass...)
}
func ComparePassAndHash(passHash []byte, plainPassword string) bool {
passHashCopy := make([]byte, len(passHash))
copy(passHashCopy, passHash)
salt := passHashCopy[0:saltLen]
userPassHash := hashPassWithSalt(salt[:saltLen], plainPassword)
return bytes.Equal(userPassHash, passHash)
}
func Hash256(content []byte) (string, error) {
hasher := sha256.New()
_, err := hasher.Write(content)
if err != nil {
return "", err
}
return hex.EncodeToString(hasher.Sum(nil)), nil
}