-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathtranslator.go
53 lines (47 loc) · 1.13 KB
/
translator.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
package l9l4gfuzz
import (
"crypto/hmac"
"encoding/hex"
"encoding/json"
"errors"
"fmt"
"hash/fnv"
"time"
)
type TokenTranslator struct {
Secret []byte
}
type Token struct {
SourceUrl string
PayloadSource string
IssueDate time.Time
}
var ErrInvalidToken = errors.New("invalid token")
var ErrTokenValidationFailed = errors.New("token validation faild")
func (tt *TokenTranslator) GetTokenFromHash(input string) (*Token, error) {
data, err := hex.DecodeString(input)
if err != nil {
return nil, ErrInvalidToken
}
if len(data) < 20 {
return nil, ErrInvalidToken
}
unsignedData := data[0 : len(data)-16]
currentHash := data[len(data)-16:]
h := hmac.New(fnv.New128, tt.Secret)
h.Write(unsignedData)
verifyHash := h.Sum(nil)
if !hmac.Equal(currentHash, verifyHash) {
return nil, ErrTokenValidationFailed
}
var token Token
err = json.Unmarshal(unsignedData, &token)
return &token, err
}
func (tt *TokenTranslator) GetHashFromToken(token Token) string {
h := hmac.New(fnv.New128, tt.Secret)
payload, _ := json.Marshal(token)
h.Write(payload)
payload = append(payload, h.Sum(nil)...)
return fmt.Sprintf("%x", payload)
}