/
ws_auth.go
113 lines (96 loc) · 2.69 KB
/
ws_auth.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
package main
import (
"bytes"
"compress/gzip"
"crypto/hmac"
"crypto/sha256"
"encoding/base64"
"fmt"
"io/ioutil"
"net/url"
"strings"
"time"
"github.com/gorilla/websocket"
)
func readLoop(conn *websocket.Conn) {
for conn != nil {
msgType, buf, err := conn.ReadMessage()
if err != nil {
fmt.Printf("Read error: %s", err)
continue
}
var message string
if msgType == websocket.BinaryMessage {
message, err = gzipDecompress(buf)
if err != nil {
fmt.Printf("UnGZip data error: %s", err)
continue
}
} else if msgType == websocket.TextMessage {
message = string(buf)
}
fmt.Println(message)
}
}
func sign(sk string, method string, host string, path string, parameters string) string {
var sb strings.Builder
sb.WriteString(method)
sb.WriteString("\n")
sb.WriteString(host)
sb.WriteString("\n")
sb.WriteString(path)
sb.WriteString("\n")
sb.WriteString(parameters)
fmt.Println("sign parameters:", parameters)
payload := sb.String()
hash := hmac.New(sha256.New, []byte(sk))
hash.Write([]byte(payload))
result := base64.StdEncoding.EncodeToString(hash.Sum(nil))
return result
}
func sendAuth(conn *websocket.Conn, host string, path string, accessKey string, secretKey string) bool {
timestamp := time.Now().UTC().Format("2006-01-02T15:04:05")
urls := url.Values{}
urls.Add("AccessKeyId", accessKey)
urls.Add("SignatureMethod", "HmacSHA256")
urls.Add("SignatureVersion", "2")
urls.Add("Timestamp", timestamp)
signature := sign(secretKey, "GET", host, path, urls.Encode())
fmt.Println("signature:", signature)
auth := fmt.Sprintf("{\"op\":\"auth\", \"type\":\"api\",\"AccessKeyId\":\"%s\", \"SignatureMethod\":\"HmacSHA256\", \"SignatureVersion\":\"2\", \"Timestamp\":\"%s\", \"Signature\":\"%s\"}", accessKey, timestamp, signature)
fmt.Println("send auth:", auth)
jdata := []byte(auth)
conn.WriteMessage(websocket.TextMessage, jdata)
return true
}
func gzipDecompress(input []byte) (string, error) {
buf := bytes.NewBuffer(input)
reader, gzipErr := gzip.NewReader(buf)
if gzipErr != nil {
return "", gzipErr
}
defer reader.Close()
result, readErr := ioutil.ReadAll(reader)
if readErr != nil {
return "", readErr
}
return string(result), nil
}
func main() {
host := "api.hbdm.com"
path := "/swap-notification"
ak := "x-x-x-x"
sk := "x-x-x-x"
url := fmt.Sprintf("wss://%s%s", host, path)
fmt.Println("url:", url)
//head := http.Header{"Host": {host + ":8080"}}
//conn, _, err := websocket.DefaultDialer.Dial(url, head)
conn, _, err := websocket.DefaultDialer.Dial(url, nil)
if err != nil {
fmt.Println("WebSocket connected error: %s", err)
} else {
//fmt.Println("WebSocket connected")
sendAuth(conn, host, path, ak, sk)
readLoop(conn)
}
}