/
requests.go
129 lines (114 loc) · 4.03 KB
/
requests.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
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
package credentials
import (
"github.com/gophercloud/gophercloud"
"github.com/gophercloud/gophercloud/pagination"
)
// ListOptsBuilder allows extensions to add additional parameters to
// the List request
type ListOptsBuilder interface {
ToCredentialListQuery() (string, error)
}
// ListOpts provides options to filter the List results.
type ListOpts struct {
// UserID filters the response by a credential user_id
UserID string `q:"user_id"`
// Type filters the response by a credential type
Type string `q:"type"`
}
// ToCredentialListQuery formats a ListOpts into a query string.
func (opts ListOpts) ToCredentialListQuery() (string, error) {
q, err := gophercloud.BuildQueryString(opts)
return q.String(), err
}
// List enumerates the Credentials to which the current token has access.
func List(client *gophercloud.ServiceClient, opts ListOptsBuilder) pagination.Pager {
url := listURL(client)
if opts != nil {
query, err := opts.ToCredentialListQuery()
if err != nil {
return pagination.Pager{Err: err}
}
url += query
}
return pagination.NewPager(client, url, func(r pagination.PageResult) pagination.Page {
return CredentialPage{pagination.LinkedPageBase{PageResult: r}}
})
}
// Get retrieves details on a single user, by ID.
func Get(client *gophercloud.ServiceClient, id string) (r GetResult) {
resp, err := client.Get(getURL(client, id), &r.Body, nil)
_, r.Header, r.Err = gophercloud.ParseResponse(resp, err)
return
}
// CreateOptsBuilder allows extensions to add additional parameters to
// the Create request.
type CreateOptsBuilder interface {
ToCredentialCreateMap() (map[string]interface{}, error)
}
// CreateOpts provides options used to create a credential.
type CreateOpts struct {
// Serialized blob containing the credentials
Blob string `json:"blob" required:"true"`
// ID of the project.
ProjectID string `json:"project_id,omitempty"`
// The type of the credential.
Type string `json:"type" required:"true"`
// ID of the user who owns the credential.
UserID string `json:"user_id" required:"true"`
}
// ToCredentialCreateMap formats a CreateOpts into a create request.
func (opts CreateOpts) ToCredentialCreateMap() (map[string]interface{}, error) {
return gophercloud.BuildRequestBody(opts, "credential")
}
// Create creates a new Credential.
func Create(client *gophercloud.ServiceClient, opts CreateOptsBuilder) (r CreateResult) {
b, err := opts.ToCredentialCreateMap()
if err != nil {
r.Err = err
return
}
resp, err := client.Post(createURL(client), &b, &r.Body, &gophercloud.RequestOpts{
OkCodes: []int{201},
})
_, r.Header, r.Err = gophercloud.ParseResponse(resp, err)
return
}
// Delete deletes a credential.
func Delete(client *gophercloud.ServiceClient, id string) (r DeleteResult) {
resp, err := client.Delete(deleteURL(client, id), nil)
_, r.Header, r.Err = gophercloud.ParseResponse(resp, err)
return
}
// UpdateOptsBuilder allows extensions to add additional parameters to
// the Update request.
type UpdateOptsBuilder interface {
ToCredentialsUpdateMap() (map[string]interface{}, error)
}
// UpdateOpts represents parameters to update a credential.
type UpdateOpts struct {
// Serialized blob containing the credentials.
Blob string `json:"blob,omitempty"`
// ID of the project.
ProjectID string `json:"project_id,omitempty"`
// The type of the credential.
Type string `json:"type,omitempty"`
// ID of the user who owns the credential.
UserID string `json:"user_id,omitempty"`
}
// ToUpdateCreateMap formats a UpdateOpts into an update request.
func (opts UpdateOpts) ToCredentialsUpdateMap() (map[string]interface{}, error) {
return gophercloud.BuildRequestBody(opts, "credential")
}
// Update modifies the attributes of a Credential.
func Update(client *gophercloud.ServiceClient, id string, opts UpdateOptsBuilder) (r UpdateResult) {
b, err := opts.ToCredentialsUpdateMap()
if err != nil {
r.Err = err
return
}
resp, err := client.Patch(updateURL(client, id), b, &r.Body, &gophercloud.RequestOpts{
OkCodes: []int{200},
})
_, r.Header, r.Err = gophercloud.ParseResponse(resp, err)
return
}