forked from maxxant/alor4go
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgetJWT.go
76 lines (60 loc) · 1.86 KB
/
getJWT.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
package alor4go
import (
"encoding/json"
"fmt"
"net/http"
"net/http/httputil"
"net/url"
"os"
)
func GetJWT() string {
refreshToken := os.Getenv("ALOR_REFRESH")
if refreshToken == "" {
//panic("empty refresh token")
return ""
}
//fmt.Println("refreshToken:", refreshToken)
/*
Механизм refresh token позволяет получать JWT с новым сроком жизни.
Для этого отправьте POST запрос на адрес
- https://oauthdev.alor.ru/refresh?token={refreshToken} (тестовый контур)
- или https://oauth.alor.ru/refresh?token={refreshToken} (боевой контур).
Если у refresh token не истек срок жизни и не он не был отозван, то в теле ответа в поле AccessToken вернётся свежий JWT токен.
Срок жизни refresh token, получаемого обычным способом — 1 месяц.
Срок жизни refresh token, получаемого самостоятельным выписыванием — год.
*/
apiUrl := "https://oauth.alor.ru"
resource := "/refresh"
u, _ := url.ParseRequestURI(apiUrl)
u.Path = resource
urlStr := u.String()
client := &http.Client{}
req, _ := http.NewRequest(http.MethodPost, urlStr, nil)
query := req.URL.Query()
query.Add("token", refreshToken)
req.URL.RawQuery = query.Encode()
if false {
dump, _ := httputil.DumpRequestOut(req, true)
fmt.Println(string(dump))
}
resp, err := client.Do(req)
if err != nil {
return ""
}
// fmt.Println(resp.Status)
defer resp.Body.Close()
type JSResp struct {
AccessToken string
}
decoder := json.NewDecoder(resp.Body)
var jsresp JSResp
{
err := decoder.Decode(&jsresp)
if err != nil {
// panic(err)
return ""
}
}
// fmt.Println("jsresp:", jsresp)
return jsresp.AccessToken
}