Compare commits
2 Commits
88934bbbcc
...
4708c89c25
| Author | SHA1 | Date | |
|---|---|---|---|
| 4708c89c25 | |||
| dd14b103e3 |
|
|
@ -9,6 +9,7 @@ import (
|
||||||
"net"
|
"net"
|
||||||
"net/http"
|
"net/http"
|
||||||
"net/url"
|
"net/url"
|
||||||
|
"strings"
|
||||||
|
|
||||||
"linkheader"
|
"linkheader"
|
||||||
|
|
||||||
|
|
@ -24,10 +25,12 @@ type Endpoints struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
type TokenResponse struct {
|
type TokenResponse struct {
|
||||||
Me string `json:"me"`
|
Me string `json:"me"`
|
||||||
AccessToken string `json:"access_token"`
|
AccessToken string `json:"access_token"`
|
||||||
TokenType string `json:"token_type"`
|
TokenType string `json:"token_type"`
|
||||||
Scope string `json:"scope"`
|
Scope string `json:"scope"`
|
||||||
|
Error string `json:"error"`
|
||||||
|
ErrorDescription string `json:"error_description"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func GetEndpoints(me *url.URL) (Endpoints, error) {
|
func GetEndpoints(me *url.URL) (Endpoints, error) {
|
||||||
|
|
@ -151,18 +154,53 @@ func Authorize(me *url.URL, endpoints Endpoints, clientID, scope string) (TokenR
|
||||||
reqValues.Add("client_id", clientID)
|
reqValues.Add("client_id", clientID)
|
||||||
reqValues.Add("me", me.String())
|
reqValues.Add("me", me.String())
|
||||||
|
|
||||||
res, err := http.PostForm(endpoints.TokenEndpoint, reqValues)
|
req, err := http.NewRequest(http.MethodPost, endpoints.TokenEndpoint, strings.NewReader(reqValues.Encode()))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return tokenResponse, err
|
return tokenResponse, err
|
||||||
}
|
}
|
||||||
|
req.Header.Add("Content-Type", "application/x-www-form-urlencoded")
|
||||||
|
req.Header.Add("Accept", "application/json")
|
||||||
|
|
||||||
defer res.Body.Close()
|
res, err := http.DefaultClient.Do(req)
|
||||||
|
|
||||||
dec := json.NewDecoder(res.Body)
|
|
||||||
err = dec.Decode(&tokenResponse)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return tokenResponse, err
|
return tokenResponse, err
|
||||||
}
|
}
|
||||||
|
defer res.Body.Close()
|
||||||
|
|
||||||
|
if res.StatusCode != 200 {
|
||||||
|
return TokenResponse{}, fmt.Errorf("status code %d, instead of 200", res.StatusCode)
|
||||||
|
}
|
||||||
|
|
||||||
|
if strings.HasPrefix(res.Header.Get("content-type"), "application/json") {
|
||||||
|
dec := json.NewDecoder(res.Body)
|
||||||
|
err = dec.Decode(&tokenResponse)
|
||||||
|
if err != nil {
|
||||||
|
return tokenResponse, fmt.Errorf("error while parsing response body with content-type %s as json: %s", res.Header.Get("content-type"), err)
|
||||||
|
}
|
||||||
|
if tokenResponse.Me == "" && tokenResponse.Error != "" {
|
||||||
|
return tokenResponse, fmt.Errorf("received error from endpoint: %s, %s", tokenResponse.Error, tokenResponse.ErrorDescription)
|
||||||
|
}
|
||||||
|
} else if strings.HasPrefix(res.Header.Get("content-type"), "application/x-www-form-urlencoded") {
|
||||||
|
body, err := ioutil.ReadAll(res.Body)
|
||||||
|
if err != nil {
|
||||||
|
return tokenResponse, fmt.Errorf("error while reading response body with content-type %s: %s", res.Header.Get("content-type"), err)
|
||||||
|
}
|
||||||
|
|
||||||
|
values, err := url.ParseQuery(string(body))
|
||||||
|
if err != nil {
|
||||||
|
return tokenResponse, fmt.Errorf("error while parsing response body with content-type %s as application/x-www-form-urlencoded: %s\nbody was: %q\n", res.Header.Get("content-type"), err, body)
|
||||||
|
}
|
||||||
|
|
||||||
|
if values.Get("me") == "" {
|
||||||
|
if errTxt := values.Get("error"); errTxt != "" {
|
||||||
|
return tokenResponse, fmt.Errorf("received error from endpoint: %s, %s", errTxt, values.Get("error_description"))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
tokenResponse.Me = values.Get("me")
|
||||||
|
tokenResponse.AccessToken = values.Get("token")
|
||||||
|
tokenResponse.TokenType = values.Get("token_type")
|
||||||
|
tokenResponse.Scope = values.Get("scope")
|
||||||
|
}
|
||||||
|
|
||||||
return tokenResponse, nil
|
return tokenResponse, nil
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user