forked from contentful-labs/contentful-go
-
-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathaccess_token.go
110 lines (87 loc) · 2.49 KB
/
access_token.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
101
102
103
104
105
106
107
108
109
110
package contentful
import (
"bytes"
"encoding/json"
"fmt"
"net/url"
"strconv"
)
// AccessTokensService service
type AccessTokensService service
// AccessToken model
type AccessToken struct {
Sys *Sys `json:"sys,omitempty"`
Name string `json:"name,omitempty"`
RevokedAt string `json:"revokedAt,omitempty"`
Scopes []string `json:"scopes,omitempty"`
}
// GetVersion returns entity version
func (accessToken *AccessToken) GetVersion() int {
version := 1
if accessToken.Sys != nil {
version = accessToken.Sys.Version
}
return version
}
// List returns an access tokens collection
func (service *AccessTokensService) List() *Collection {
path := fmt.Sprint("/users/me/access_tokens")
method := "GET"
req, err := service.c.newRequest(method, path, nil, nil)
if err != nil {
return &Collection{}
}
col := NewCollection(&CollectionOptions{})
col.c = service.c
col.req = req
return col
}
// Get returns a single access token
func (service *AccessTokensService) Get(accessTokenID string) (*AccessToken, error) {
path := fmt.Sprintf("/users/me/access_tokens/%s", accessTokenID)
query := url.Values{}
method := "GET"
req, err := service.c.newRequest(method, path, query, nil)
if err != nil {
return &AccessToken{}, err
}
var accessToken AccessToken
req.Header.Set("X-Contentful-Version", strconv.Itoa(accessToken.GetVersion()))
if ok := service.c.do(req, &accessToken); ok != nil {
return nil, err
}
return &accessToken, err
}
// Create creates a new access token
func (service *AccessTokensService) Create(accessToken *AccessToken) error {
bytesArray, err := json.Marshal(accessToken)
if err != nil {
return err
}
path := fmt.Sprint("/users/me/access_tokens")
method := "POST"
req, err := service.c.newRequest(method, path, nil, bytes.NewReader(bytesArray))
if err != nil {
return err
}
req.Header.Set("X-Contentful-Version", strconv.Itoa(accessToken.GetVersion()))
return service.c.do(req, accessToken)
}
// Revoke revokes a personal access token
func (service *AccessTokensService) Revoke(accessToken *AccessToken) error {
bytesArray, err := json.Marshal(accessToken)
if err != nil {
return err
}
var path string
var method string
if accessToken.Sys != nil && accessToken.Sys.CreatedAt != "" {
path = fmt.Sprintf("/users/me/access_tokens/%s/revoked", accessToken.Sys.ID)
method = "PUT"
}
req, err := service.c.newRequest(method, path, nil, bytes.NewReader(bytesArray))
if err != nil {
return err
}
return service.c.do(req, accessToken)
}