forked from TrueCloudLab/lego
75 lines
1.9 KiB
Go
75 lines
1.9 KiB
Go
|
package vegadns2client
|
||
|
|
||
|
import (
|
||
|
"encoding/json"
|
||
|
"errors"
|
||
|
"fmt"
|
||
|
"io/ioutil"
|
||
|
"log"
|
||
|
"net/http"
|
||
|
"net/url"
|
||
|
"strings"
|
||
|
"time"
|
||
|
)
|
||
|
|
||
|
// Token - struct to hold token information
|
||
|
type Token struct {
|
||
|
Token string `json:"access_token"`
|
||
|
TokenType string `json:"token_type"`
|
||
|
ExpiresIn int `json:"expires_in"`
|
||
|
ExpiresAt time.Time
|
||
|
}
|
||
|
|
||
|
func (t Token) valid() error {
|
||
|
if time.Now().UTC().After(t.ExpiresAt) {
|
||
|
return errors.New("Token Expired")
|
||
|
}
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (vega *VegaDNSClient) getBearer() string {
|
||
|
if vega.token.valid() != nil {
|
||
|
vega.getAuthToken()
|
||
|
}
|
||
|
return vega.token.formatBearer()
|
||
|
}
|
||
|
|
||
|
func (t Token) formatBearer() string {
|
||
|
return fmt.Sprintf("Bearer %s", t.Token)
|
||
|
}
|
||
|
|
||
|
func (vega *VegaDNSClient) getAuthToken() {
|
||
|
tokenEndpoint := vega.getURL("token")
|
||
|
v := url.Values{}
|
||
|
v.Set("grant_type", "client_credentials")
|
||
|
|
||
|
req, err := http.NewRequest("POST", tokenEndpoint, strings.NewReader(v.Encode()))
|
||
|
if err != nil {
|
||
|
log.Fatalf("Error forming POST to getAuthToken: %s", err)
|
||
|
}
|
||
|
req.SetBasicAuth(vega.APIKey, vega.APISecret)
|
||
|
req.Header.Set("Content-Type", "application/x-www-form-urlencoded")
|
||
|
|
||
|
issueTime := time.Now().UTC()
|
||
|
resp, err := vega.client.Do(req)
|
||
|
if err != nil {
|
||
|
log.Fatalf("Error sending POST to getAuthToken: %s", err)
|
||
|
}
|
||
|
defer resp.Body.Close()
|
||
|
body, err := ioutil.ReadAll(resp.Body)
|
||
|
if err != nil {
|
||
|
log.Fatalf("Error reading response from POST to getAuthToken: %s", err)
|
||
|
}
|
||
|
if resp.StatusCode != http.StatusOK {
|
||
|
log.Fatalf("Got bad answer from VegaDNS on getAuthToken. Code: %d. Message: %s", resp.StatusCode, string(body))
|
||
|
}
|
||
|
if err := json.Unmarshal(body, &vega.token); err != nil {
|
||
|
log.Fatalf("Error unmarshalling body of POST to getAuthToken: %s", err)
|
||
|
}
|
||
|
|
||
|
if vega.token.TokenType != "bearer" {
|
||
|
log.Fatal("We don't support anything except bearer tokens")
|
||
|
}
|
||
|
vega.token.ExpiresAt = issueTime.Add(time.Duration(vega.token.ExpiresIn) * time.Second)
|
||
|
}
|