/
permission_group.go
108 lines (86 loc) · 3.33 KB
/
permission_group.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
package edgeworkers
import (
"context"
"errors"
"fmt"
"net/http"
validation "github.com/go-ozzo/ozzo-validation/v4"
)
type (
// PermissionGroups is an edgeworkers permission groups API interface
PermissionGroups interface {
// GetPermissionGroup gets details on the capabilities enabled within a specified group
//
// See: https://techdocs.akamai.com/edgeworkers/reference/get-group
GetPermissionGroup(context.Context, GetPermissionGroupRequest) (*PermissionGroup, error)
// ListPermissionGroups lists groups and the associated permission capabilities
//
// See: https://techdocs.akamai.com/edgeworkers/reference/get-groups
ListPermissionGroups(context.Context) (*ListPermissionGroupsResponse, error)
}
// GetPermissionGroupRequest contains parameters used to get a permission group
GetPermissionGroupRequest struct {
GroupID string
}
// PermissionGroup represents a single permission group object
PermissionGroup struct {
ID int64 `json:"groupId"`
Name string `json:"groupName"`
Capabilities []string `json:"capabilities"`
}
// ListPermissionGroupsResponse represents a response object returned by ListPermissionGroups
ListPermissionGroupsResponse struct {
PermissionGroups []PermissionGroup `json:"groups"`
}
)
// Validate validates GetPermissionGroupRequest
func (g GetPermissionGroupRequest) Validate() error {
return validation.Errors{
"GroupID": validation.Validate(g.GroupID, validation.Required),
}.Filter()
}
var (
// ErrGetPermissionGroup is returned in case an error occurs on GetPermissionGroup operation
ErrGetPermissionGroup = errors.New("get a permission group")
// ErrListPermissionGroups is returned in case an error occurs on ListPermissionGroups operation
ErrListPermissionGroups = errors.New("list permission groups")
)
func (e *edgeworkers) GetPermissionGroup(ctx context.Context, params GetPermissionGroupRequest) (*PermissionGroup, error) {
logger := e.Log(ctx)
logger.Debug("GetPermissionGroup")
if err := params.Validate(); err != nil {
return nil, fmt.Errorf("%s: %w: %s", ErrGetPermissionGroup, ErrStructValidation, err)
}
uri := fmt.Sprintf("/edgeworkers/v1/groups/%s", params.GroupID)
req, err := http.NewRequestWithContext(ctx, http.MethodGet, uri, nil)
if err != nil {
return nil, fmt.Errorf("%w: failed to create request: %s", ErrGetPermissionGroup, err)
}
var result PermissionGroup
resp, err := e.Exec(req, &result)
if err != nil {
return nil, fmt.Errorf("%w: request failed: %s", ErrGetPermissionGroup, err)
}
if resp.StatusCode != http.StatusOK {
return nil, fmt.Errorf("%s: %w", ErrGetPermissionGroup, e.Error(resp))
}
return &result, nil
}
func (e *edgeworkers) ListPermissionGroups(ctx context.Context) (*ListPermissionGroupsResponse, error) {
logger := e.Log(ctx)
logger.Debug("ListPermissionGroups")
uri := fmt.Sprintf("/edgeworkers/v1/groups")
req, err := http.NewRequestWithContext(ctx, http.MethodGet, uri, nil)
if err != nil {
return nil, fmt.Errorf("%w: failed to create request: %s", ErrListPermissionGroups, err)
}
var result ListPermissionGroupsResponse
resp, err := e.Exec(req, &result)
if err != nil {
return nil, fmt.Errorf("%w: request failed: %s", ErrListPermissionGroups, err)
}
if resp.StatusCode != http.StatusOK {
return nil, fmt.Errorf("%s: %w", ErrListPermissionGroups, e.Error(resp))
}
return &result, nil
}