/
glip.go
100 lines (84 loc) · 2.41 KB
/
glip.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
package glip
import (
"context"
"encoding/json"
"fmt"
"log"
"net/http"
"strings"
"github.com/grokify/goauth"
ro "github.com/grokify/goauth/ringcentral"
gostor "github.com/grokify/xgo/database/document"
"github.com/grokify/xgo/net/http/anyhttp"
"golang.org/x/oauth2"
)
const (
DefaultBotTokenPrefix = "rcBotExtId-" // #nosec G101
)
type RcOAuthManager struct {
client *http.Client
appCreds goauth.CredentialsOAuth2
gostorClient gostor.Client
TokenPrefix string
}
func NewRcOAuthManager(client *http.Client, appCreds goauth.CredentialsOAuth2) RcOAuthManager {
return RcOAuthManager{
client: client,
appCreds: appCreds}
}
func (h RcOAuthManager) HandleOAuthNetHTTP(res http.ResponseWriter, req *http.Request) {
h.HandleOAuthAny(anyhttp.NewResReqNetHTTP(res, req))
}
func (h RcOAuthManager) HandleOAuthAny(aRes anyhttp.Response, aReq anyhttp.Request) {
err := aReq.ParseForm()
if err != nil {
log.Print("E_CANNOT_PARSE_RC_OAUTH_FORM") // Warn
return
}
args := aReq.QueryArgs()
code := strings.TrimSpace(args.GetString("code"))
if len(code) == 0 {
log.Print("E_RC_OAUTH_FORM__NO_CODE") // Warn
return
}
log.Print(">>>CODE>>>\n" + code + "\n<<<CODE<<<\n")
rcToken, err := h.appCreds.Exchange(context.Background(), code, map[string][]string{})
if err != nil {
log.Print("E_CANNOT_EXCHANGE_CODE_FOR_TOKEN") // Warn
return
}
fmt.Printf("%v\n", rcToken)
//authEndpoints := ru.NewEndpoint()
ownerID := rcToken.Extra("owner_id").(string)
rcBotTokenKey := "rcBotId-" + ownerID // rcToken.OwnerID
err = h.StoreToken(rcBotTokenKey, *rcToken)
if err != nil {
log.Printf("cannot store token (%s)", err.Error()) // Warn
return
}
}
func (h RcOAuthManager) StoreToken(key string, rcToken oauth2.Token) error {
data, err := json.Marshal(rcToken)
if err != nil {
return err
}
return h.gostorClient.SetString(key, string(data))
}
func (h RcOAuthManager) GetToken(key string) (ro.RcToken, error) {
data := strings.TrimSpace(h.gostorClient.GetOrEmptyString(key))
if data == "" {
return ro.RcToken{}, fmt.Errorf("could not find token for key (%s)", key)
}
var tok ro.RcToken
return tok, json.Unmarshal([]byte(data), &tok)
}
/*
func HandleNetHTTPRingCentralCodeToToken(res http.ResponseWriter, req *http.Request) {
reqBodyBytes, err := io.ReadAll(req.Body)
if err != nil {
log.Warn(err)
}
log.Info(">>>BODY>>>\n" + string(reqBodyBytes) + "\n<<<BODY<<<\n")
res.WriteHeader(http.StatusOK)
}
*/