-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathcontroller.go
109 lines (92 loc) · 2.42 KB
/
controller.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
package user_http
import (
"errors"
"net/http"
"app/adapter/featureflags"
"app/authn/authn_http"
"app/authz/authz_http"
"app/user"
"github.com/go-playground/validator/v10"
"github.com/gofiber/fiber/v2"
)
func NewController(
validator *validator.Validate,
authn *authn_http.AuthMiddleware,
authnz *authz_http.Middleware,
service *user.Service,
) *Controller {
return &Controller{
validator: validator,
authn: authn,
authz: authnz,
service: service,
}
}
type Controller struct {
validator *validator.Validate
authn *authn_http.AuthMiddleware
authz *authz_http.Middleware
service *user.Service
}
func (controller *Controller) Register(app *fiber.App) {
users := app.Group("/users")
users.Get("/", controller.List)
app.Group(
"/users/:userID",
controller.authn.RequireUser,
controller.middlewareGetUser,
featureflags.Middleware,
).
Get(
"/",
controller.authz.RequireParamPermission("user:userID", user.PermRead),
controller.Get,
).
Delete(
"/",
controller.authz.RequireParamPermission("user:userID", user.PermDelete),
controller.Delete,
).
Get(
"/feature",
controller.authz.RequireParamPermission("user:userID", user.PermReadFeatures),
controller.GetFeature,
)
}
func (controller *Controller) List(ctx *fiber.Ctx) error {
users, err := controller.service.List(ctx.UserContext())
if err != nil {
return ctx.SendStatus(http.StatusInternalServerError)
}
return ctx.JSON(users)
}
func (controller *Controller) Get(ctx *fiber.Ctx) error {
return ctx.JSON(ctx.Locals("user"))
}
func (controller *Controller) GetFeature(ctx *fiber.Ctx) error {
return ctx.JSON(ctx.Locals("flags"))
}
func (controller *Controller) Delete(ctx *fiber.Ctx) error {
foundUser := ctx.Locals("user").(user.User)
if err := controller.service.Remove(ctx.UserContext(), foundUser); err != nil {
return ctx.SendStatus(http.StatusInternalServerError)
}
return ctx.SendStatus(http.StatusOK)
}
func (controller *Controller) middlewareGetUser(ctx *fiber.Ctx) error {
userID := ctx.Params("userID")
ctx.AllParams()
if userID == "" {
return ctx.SendStatus(http.StatusBadRequest)
}
userFound, err := controller.service.FindByID(ctx.UserContext(), userID)
if err != nil {
if errors.Is(err, user.ErrNotFound) {
return ctx.SendStatus(http.StatusNotFound)
} else {
return ctx.SendStatus(http.StatusInternalServerError)
}
}
ctx.Locals("user", userFound)
return ctx.Next()
}