-
Notifications
You must be signed in to change notification settings - Fork 0
/
firebase.go
93 lines (69 loc) · 1.96 KB
/
firebase.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
package firebase
import (
"bytes"
"encoding/json"
"fmt"
"io"
"net/http"
"time"
"github.com/golang-jwt/jwt/v4"
"github.com/spf13/viper"
)
type Token struct {
AccessToken string `json:"access_token"`
ExpiresIn string `json:"expires_in"`
TokenType string `json:"token_type"`
RefreshToken string `json:"refresh_token"`
IDToken string `json:"id_token"`
UserID string `json:"user_id"`
ProjectID string `json:"project_id"`
}
type RefreshTokenInput struct {
GrantType string `json:"grantType"`
RefreshToken string `json:"refreshToken"`
}
var (
FirebaseToken string
)
func ValidateToken(refreshToken string) error {
if viper.GetString("auth.method") == "token" {
token := viper.GetString("auth.token")
tokenExpired := false
if token != "" {
claims := jwt.MapClaims{}
jwt.ParseWithClaims(token, claims, func(token *jwt.Token) (interface{}, error) {
return nil, nil
})
if claims["exp"] == nil {
return fmt.Errorf("Provided token is invalid")
}
timeSec := time.Unix(int64(claims["exp"].(float64)), 0)
tokenExpired = time.Now().UTC().After(timeSec.UTC())
}
apiEndpoint := viper.GetString("api_url")
// if the access token has expired we have to renew it
if tokenExpired || token == "" {
payload, err := json.Marshal(RefreshTokenInput{"refresh_token", refreshToken})
if err != nil {
return err
}
res, err := http.Post(fmt.Sprintf("%s/rest/v1/firebase/refresh-token", apiEndpoint), "application/json", bytes.NewBuffer(payload))
if err != nil {
return err
}
if res.StatusCode != http.StatusOK {
return fmt.Errorf("Unexpected error trying to refreshing authentication token")
}
response, err := io.ReadAll(res.Body)
var newToken *Token
if err != nil {
return err
}
err = json.Unmarshal(response, &newToken)
viper.Set("auth.refresh_token", newToken.RefreshToken)
viper.Set("auth.token", newToken.AccessToken)
viper.WriteConfig()
}
}
return nil
}