This repository has been archived by the owner on Aug 5, 2020. It is now read-only.
forked from okta/terraform-provider-okta
/
authorization_server_scopes.go
87 lines (74 loc) · 2.85 KB
/
authorization_server_scopes.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
package sdk
import (
"fmt"
"github.com/okta/okta-sdk-golang/okta"
"github.com/okta/okta-sdk-golang/okta/query"
)
type AuthorizationServerScope struct {
Name string `json:"name,omitempty"`
Id string `json:"id,omitempty"`
Description string `json:"description,omitempty"`
Consent string `json:"consent,omitempty"`
MetadataPublish string `json:"metadataPublish,omitempty"`
Default bool `json:"default"`
}
func (m *ApiSupplement) DeleteAuthorizationServerScope(authServerId, id string) (*okta.Response, error) {
url := fmt.Sprintf("/api/v1/authorizationServers/%s/scopes/%s", authServerId, id)
req, err := m.RequestExecutor.NewRequest("DELETE", url, nil)
if err != nil {
return nil, err
}
return m.RequestExecutor.Do(req, nil)
}
func (m *ApiSupplement) ListAuthorizationServerScopes(authServerId string) ([]*AuthorizationServerScope, *okta.Response, error) {
url := fmt.Sprintf("/api/v1/authorizationServers/%s/scopes", authServerId)
req, err := m.RequestExecutor.NewRequest("GET", url, nil)
if err != nil {
return nil, nil, err
}
var auth []*AuthorizationServerScope
resp, err := m.RequestExecutor.Do(req, &auth)
return auth, resp, err
}
func (m *ApiSupplement) CreateAuthorizationServerScope(authServerId string, body AuthorizationServerScope, qp *query.Params) (*AuthorizationServerScope, *okta.Response, error) {
url := fmt.Sprintf("/api/v1/authorizationServers/%s/scopes", authServerId)
if qp != nil {
url = url + qp.String()
}
req, err := m.RequestExecutor.NewRequest("POST", url, body)
if err != nil {
return nil, nil, err
}
authorizationServer := body
resp, err := m.RequestExecutor.Do(req, &authorizationServer)
return &authorizationServer, resp, err
}
func (m *ApiSupplement) UpdateAuthorizationServerScope(authServerId, id string, body AuthorizationServerScope, qp *query.Params) (*AuthorizationServerScope, *okta.Response, error) {
url := fmt.Sprintf("/api/v1/authorizationServers/%s/scopes/%s", authServerId, id)
if qp != nil {
url = url + qp.String()
}
req, err := m.RequestExecutor.NewRequest("PUT", url, body)
if err != nil {
return nil, nil, err
}
authorizationServer := body
resp, err := m.RequestExecutor.Do(req, &authorizationServer)
if err != nil {
return nil, resp, err
}
return &authorizationServer, resp, nil
}
func (m *ApiSupplement) GetAuthorizationServerScope(authServerId, id string, authorizationServerInstance AuthorizationServerScope) (*AuthorizationServerScope, *okta.Response, error) {
url := fmt.Sprintf("/api/v1/authorizationServers/%s/scopes/%s", authServerId, id)
req, err := m.RequestExecutor.NewRequest("GET", url, nil)
if err != nil {
return nil, nil, err
}
authorizationServer := authorizationServerInstance
resp, err := m.RequestExecutor.Do(req, &authorizationServer)
if err != nil {
return nil, resp, err
}
return &authorizationServer, resp, nil
}