-
Notifications
You must be signed in to change notification settings - Fork 0
/
opsRole.go
80 lines (71 loc) · 2.74 KB
/
opsRole.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
package wildlifenl
import (
"context"
"net/http"
"github.com/UtrechtUniversity/wildlifenl/models"
"github.com/UtrechtUniversity/wildlifenl/stores"
"github.com/danielgtaylor/huma/v2"
)
type RoleForUserUpdateInput struct {
Body *struct {
UserID string `json:"userID" format:"uuid" doc:"The ID of the user"`
RoleID int `json:"roleID" minimum:"1" doc:"The ID of the role"`
}
}
type RolesHolder struct {
Body []models.Role `json:"roles"`
}
type roleOperations Operations
func newRoleOperations() *roleOperations {
return &roleOperations{Endpoint: "role"}
}
func (o *roleOperations) RegisterGetAll(api huma.API) {
name := "Get All Roles"
description := "Retrieve all roles."
path := "/" + o.Endpoint + "s/"
scopes := []string{}
method := http.MethodGet
huma.Register(api, huma.Operation{
OperationID: name, Summary: name, Path: path, Method: method, Tags: []string{o.Endpoint}, Description: generateDescription(description, scopes), Security: []map[string][]string{{"auth": scopes}},
}, func(ctx context.Context, input *struct{}) (*RolesHolder, error) {
roles, err := stores.NewRoleStore(relationalDB).GetAll()
if err != nil {
return nil, handleError(err)
}
return &RolesHolder{Body: roles}, nil
})
}
func (o *roleOperations) RegisterAddRoleToUser(api huma.API) {
name := "Add a Role to a User"
description := "Add a specific role to a specific user."
path := "/" + o.Endpoint + "/"
scopes := []string{"administrator"}
method := http.MethodPost
huma.Register(api, huma.Operation{
OperationID: name, Summary: name, Path: path, Method: method, Tags: []string{o.Endpoint}, Description: generateDescription(description, scopes), Security: []map[string][]string{{"auth": scopes}},
}, func(ctx context.Context, input *RoleForUserUpdateInput) (*struct{}, error) {
err := stores.NewRoleStore(relationalDB).AddRoleToUser(input.Body.UserID, input.Body.RoleID)
if err != nil {
return nil, handleError(err)
}
flushSession(input.Body.UserID)
return nil, nil
})
}
func (o *roleOperations) RegisterRemoveRoleFromUser(api huma.API) {
name := "Remove a Role from a User"
description := "Remove a specific role from a specific user."
path := "/" + o.Endpoint + "/"
scopes := []string{"administrator"}
method := http.MethodPut
huma.Register(api, huma.Operation{
OperationID: name, Summary: name, Path: path, Method: method, Tags: []string{o.Endpoint}, Description: generateDescription(description, scopes), Security: []map[string][]string{{"auth": scopes}},
}, func(ctx context.Context, input *RoleForUserUpdateInput) (*struct{}, error) {
err := stores.NewRoleStore(relationalDB).RemoveRoleFromUser(input.Body.UserID, input.Body.RoleID)
if err != nil {
return nil, handleError(err)
}
flushSession(input.Body.UserID)
return nil, nil
})
}