/
permission_space_impl.go
116 lines (92 loc) · 3.85 KB
/
permission_space_impl.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
package internal
import (
"context"
"fmt"
model "github.com/ctreminiom/go-atlassian/pkg/infra/models"
"github.com/ctreminiom/go-atlassian/service"
"github.com/ctreminiom/go-atlassian/service/confluence"
"net/http"
)
func NewSpacePermissionService(client service.Connector) *SpacePermissionService {
return &SpacePermissionService{
internalClient: &internalSpacePermissionImpl{c: client},
}
}
type SpacePermissionService struct {
internalClient confluence.SpacePermissionConnector
}
// Add adds new permission to space.
//
// If the permission to be added is a group permission, the group can be identified by its group name or group id.
//
// Note: Apps cannot access this REST resource - including when utilizing user impersonation.
//
// POST /wiki/rest/api/space/{spaceKey}/permission
//
// https://docs.go-atlassian.io/confluence-cloud/space/permissions#add-new-permission-to-space
func (s *SpacePermissionService) Add(ctx context.Context, spaceKey string, payload *model.SpacePermissionPayloadScheme) (*model.SpacePermissionV2Scheme, *model.ResponseScheme, error) {
return s.internalClient.Add(ctx, spaceKey, payload)
}
// Bulk adds new custom content permission to space.
//
// If the permission to be added is a group permission, the group can be identified by its group name or group id.
//
// Note: Only apps can access this REST resource and only make changes to the respective app permissions.
//
// POST /wiki/rest/api/space/{spaceKey}/permission/custom-content
//
// https://docs.go-atlassian.io/confluence-cloud/space/permissions#add-new-custom-content-permission-to-space
func (s *SpacePermissionService) Bulk(ctx context.Context, spaceKey string, payload *model.SpacePermissionArrayPayloadScheme) (*model.ResponseScheme, error) {
return s.internalClient.Bulk(ctx, spaceKey, payload)
}
// Remove removes a space permission.
//
// Note that removing Read Space permission for a user or group will remove all the space permissions for that user or group.
//
// DELETE /wiki/rest/api/space/{spaceKey}/permission/{id}
//
// https://docs.go-atlassian.io/confluence-cloud/space/permissions#remove-a-space-permission
func (s *SpacePermissionService) Remove(ctx context.Context, spaceKey string, permissionID int) (*model.ResponseScheme, error) {
return s.internalClient.Remove(ctx, spaceKey, permissionID)
}
type internalSpacePermissionImpl struct {
c service.Connector
}
func (i *internalSpacePermissionImpl) Add(ctx context.Context, spaceKey string, payload *model.SpacePermissionPayloadScheme) (*model.SpacePermissionV2Scheme, *model.ResponseScheme, error) {
if spaceKey == "" {
return nil, nil, model.ErrNoSpaceKeyError
}
endpoint := fmt.Sprintf("wiki/rest/api/space/%v/permission", spaceKey)
request, err := i.c.NewRequest(ctx, http.MethodPost, endpoint, "", payload)
if err != nil {
return nil, nil, err
}
permission := new(model.SpacePermissionV2Scheme)
response, err := i.c.Call(request, permission)
if err != nil {
return nil, response, err
}
return permission, response, nil
}
func (i *internalSpacePermissionImpl) Bulk(ctx context.Context, spaceKey string, payload *model.SpacePermissionArrayPayloadScheme) (*model.ResponseScheme, error) {
if spaceKey == "" {
return nil, model.ErrNoSpaceKeyError
}
endpoint := fmt.Sprintf("wiki/rest/api/space/%v/permission/custom-content", spaceKey)
request, err := i.c.NewRequest(ctx, http.MethodPost, endpoint, "", payload)
if err != nil {
return nil, err
}
return i.c.Call(request, nil)
}
func (i *internalSpacePermissionImpl) Remove(ctx context.Context, spaceKey string, permissionID int) (*model.ResponseScheme, error) {
if spaceKey == "" {
return nil, model.ErrNoSpaceKeyError
}
endpoint := fmt.Sprintf("wiki/rest/api/space/%v/permission/%v", spaceKey, permissionID)
request, err := i.c.NewRequest(ctx, http.MethodDelete, endpoint, "", nil)
if err != nil {
return nil, err
}
return i.c.Call(request, nil)
}