forked from gophercloud/gophercloud
/
requests.go
130 lines (110 loc) · 3.86 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
130
package domains
import (
"github.com/yyf330/gophercloud"
"github.com/yyf330/gophercloud/pagination"
)
// ListOptsBuilder allows extensions to add additional parameters to
// the List request
type ListOptsBuilder interface {
ToDomainListQuery() (string, error)
}
// ListOpts provides options to filter the List results.
type ListOpts struct {
// Enabled filters the response by enabled domains.
Enabled *bool `q:"enabled"`
// Name filters the response by domain name.
Name string `q:"name"`
}
// ToDomainListQuery formats a ListOpts into a query string.
func (opts ListOpts) ToDomainListQuery() (string, error) {
q, err := gophercloud.BuildQueryString(opts)
return q.String(), err
}
// List enumerates the domains 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.ToDomainListQuery()
if err != nil {
return pagination.Pager{Err: err}
}
url += query
}
return pagination.NewPager(client, url, func(r pagination.PageResult) pagination.Page {
return DomainPage{pagination.LinkedPageBase{PageResult: r}}
})
}
// Get retrieves details on a single domain, 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 {
ToDomainCreateMap() (map[string]interface{}, error)
}
// CreateOpts provides options used to create a domain.
type CreateOpts struct {
// Name is the name of the new domain.
Name string `json:"name" required:"true"`
// Description is a description of the domain.
Description string `json:"description,omitempty"`
// Enabled sets the domain status to enabled or disabled.
Enabled *bool `json:"enabled,omitempty"`
}
// ToDomainCreateMap formats a CreateOpts into a create request.
func (opts CreateOpts) ToDomainCreateMap() (map[string]interface{}, error) {
return gophercloud.BuildRequestBody(opts, "domain")
}
// Create creates a new Domain.
func Create(client *gophercloud.ServiceClient, opts CreateOptsBuilder) (r CreateResult) {
b, err := opts.ToDomainCreateMap()
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 domain.
func Delete(client *gophercloud.ServiceClient, domainID string) (r DeleteResult) {
resp, err := client.Delete(deleteURL(client, domainID), nil)
_, r.Header, r.Err = gophercloud.ParseResponse(resp, err)
return
}
// UpdateOptsBuilder allows extensions to add additional parameters to
// the Update request.
type UpdateOptsBuilder interface {
ToDomainUpdateMap() (map[string]interface{}, error)
}
// UpdateOpts represents parameters to update a domain.
type UpdateOpts struct {
// Name is the name of the domain.
Name string `json:"name,omitempty"`
// Description is the description of the domain.
Description *string `json:"description,omitempty"`
// Enabled sets the domain status to enabled or disabled.
Enabled *bool `json:"enabled,omitempty"`
}
// ToUpdateCreateMap formats a UpdateOpts into an update request.
func (opts UpdateOpts) ToDomainUpdateMap() (map[string]interface{}, error) {
return gophercloud.BuildRequestBody(opts, "domain")
}
// Update modifies the attributes of a domain.
func Update(client *gophercloud.ServiceClient, id string, opts UpdateOptsBuilder) (r UpdateResult) {
b, err := opts.ToDomainUpdateMap()
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
}