-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhasher.go
116 lines (101 loc) · 3.2 KB
/
hasher.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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
/*
* File: hasher.go
* Project: mrsign
* Created Date: Tuesday, October 19th 2021, 12:16:54 pm
* Authors: Marcello Russo, Fabio Zito
* -----
* Last Modified:
* Modified By:
* -----
* MIT License
*
* Copyright (c) 2021 MR&&Z
*
* Permission is hereby granted, free of charge, to any person obtaining a copy of
* this software and associated documentation files (the "Software"), to deal in
* the Software without restriction, including without limitation the rights to
* use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
* of the Software, and to permit persons to whom the Software is furnished to do
* so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
* -----
* HISTORY:
* Date By Comments
* ---------- --- ----------------------------------------------------------
*/
package main
import (
"bytes"
"crypto/hmac"
"crypto/md5"
"encoding/binary"
"fmt"
"strings"
)
type avID uint16
const (
avIDMsvAvEOL avID = iota
avIDMsvAvTimestamp
)
var _hasherZBlob = []byte{1, 1, 0, 0}
var _hasherZReserved = []byte{0, 0, 0, 0}
type ChallengeFields struct {
HasherZ [16]byte
Blob [4]byte
Reserved [4]byte
Timestamp [8]byte
ClientChallenge [_clientChallengeLen]byte
}
type HasherZ struct {
Field ChallengeFields
}
func NewHasherZ() *HasherZ {
return &HasherZ{}
}
func (z *HasherZ) Parse(data []byte) error {
r := bytes.NewReader(data)
err := binary.Read(r, binary.LittleEndian, &z.Field)
if err != nil {
return err
}
return nil
}
func (z *HasherZ) CreateHash(key []byte, userName string, hostName string, folderName string) []byte {
data := toUnicode(strings.ToUpper(userName) + strings.ToUpper(hostName) + folderName)
return z.hmacMd5(key, data)
}
func (z *HasherZ) CreateResponse(hash, serverChallenge []byte, clientChallenge []byte, timestamp []byte) []byte {
var temp []byte
//z.printData("serverChallenge", serverChallenge)
//z.printData("clientChallenge", clientChallenge)
//z.printData("timestamp", timestamp)
temp = append(temp, _hasherZBlob...)
temp = append(temp, _hasherZReserved...)
temp = append(temp, timestamp...)
temp = append(temp, clientChallenge...)
temp = append(temp, _hasherZReserved...)
res := z.hmacMd5(hash, serverChallenge, temp)
return append(res, temp...)
}
func (z *HasherZ) hmacMd5(key []byte, data ...[]byte) []byte {
mac := hmac.New(md5.New, key)
for _, d := range data {
mac.Write(d)
}
return mac.Sum(nil)
}
func (z *HasherZ) printData(id string, buffer []byte) {
fmt.Printf("----- %s --------------------------\n", id)
fmt.Printf("%x\n", buffer)
fmt.Printf("-----------------------------------\n")
}