138 lines
4.8 KiB
Go
138 lines
4.8 KiB
Go
|
|
package handler
|
||
|
|
|
||
|
|
import (
|
||
|
|
"context"
|
||
|
|
"net/http"
|
||
|
|
|
||
|
|
"eslogad-be/internal/contract"
|
||
|
|
|
||
|
|
"github.com/gin-gonic/gin"
|
||
|
|
"github.com/google/uuid"
|
||
|
|
)
|
||
|
|
|
||
|
|
type RBACService interface {
|
||
|
|
CreatePermission(ctx context.Context, req *contract.CreatePermissionRequest) (*contract.PermissionResponse, error)
|
||
|
|
UpdatePermission(ctx context.Context, id uuid.UUID, req *contract.UpdatePermissionRequest) (*contract.PermissionResponse, error)
|
||
|
|
DeletePermission(ctx context.Context, id uuid.UUID) error
|
||
|
|
ListPermissions(ctx context.Context) (*contract.ListPermissionsResponse, error)
|
||
|
|
|
||
|
|
CreateRole(ctx context.Context, req *contract.CreateRoleRequest) (*contract.RoleWithPermissionsResponse, error)
|
||
|
|
UpdateRole(ctx context.Context, id uuid.UUID, req *contract.UpdateRoleRequest) (*contract.RoleWithPermissionsResponse, error)
|
||
|
|
DeleteRole(ctx context.Context, id uuid.UUID) error
|
||
|
|
ListRoles(ctx context.Context) (*contract.ListRolesResponse, error)
|
||
|
|
}
|
||
|
|
|
||
|
|
type RBACHandler struct{ svc RBACService }
|
||
|
|
|
||
|
|
func NewRBACHandler(svc RBACService) *RBACHandler { return &RBACHandler{svc: svc} }
|
||
|
|
|
||
|
|
func (h *RBACHandler) CreatePermission(c *gin.Context) {
|
||
|
|
var req contract.CreatePermissionRequest
|
||
|
|
if err := c.ShouldBindJSON(&req); err != nil {
|
||
|
|
c.JSON(http.StatusBadRequest, &contract.ErrorResponse{Error: "invalid body", Code: http.StatusBadRequest})
|
||
|
|
return
|
||
|
|
}
|
||
|
|
resp, err := h.svc.CreatePermission(c.Request.Context(), &req)
|
||
|
|
if err != nil {
|
||
|
|
c.JSON(http.StatusInternalServerError, &contract.ErrorResponse{Error: err.Error(), Code: 500})
|
||
|
|
return
|
||
|
|
}
|
||
|
|
c.JSON(http.StatusCreated, contract.BuildSuccessResponse(resp))
|
||
|
|
}
|
||
|
|
|
||
|
|
func (h *RBACHandler) UpdatePermission(c *gin.Context) {
|
||
|
|
id, err := uuid.Parse(c.Param("id"))
|
||
|
|
if err != nil {
|
||
|
|
c.JSON(http.StatusBadRequest, &contract.ErrorResponse{Error: "invalid id", Code: 400})
|
||
|
|
return
|
||
|
|
}
|
||
|
|
var req contract.UpdatePermissionRequest
|
||
|
|
if err := c.ShouldBindJSON(&req); err != nil {
|
||
|
|
c.JSON(http.StatusBadRequest, &contract.ErrorResponse{Error: "invalid body", Code: 400})
|
||
|
|
return
|
||
|
|
}
|
||
|
|
resp, err := h.svc.UpdatePermission(c.Request.Context(), id, &req)
|
||
|
|
if err != nil {
|
||
|
|
c.JSON(http.StatusInternalServerError, &contract.ErrorResponse{Error: err.Error(), Code: 500})
|
||
|
|
return
|
||
|
|
}
|
||
|
|
c.JSON(http.StatusOK, contract.BuildSuccessResponse(resp))
|
||
|
|
}
|
||
|
|
|
||
|
|
func (h *RBACHandler) DeletePermission(c *gin.Context) {
|
||
|
|
id, err := uuid.Parse(c.Param("id"))
|
||
|
|
if err != nil {
|
||
|
|
c.JSON(http.StatusBadRequest, &contract.ErrorResponse{Error: "invalid id", Code: 400})
|
||
|
|
return
|
||
|
|
}
|
||
|
|
if err := h.svc.DeletePermission(c.Request.Context(), id); err != nil {
|
||
|
|
c.JSON(http.StatusInternalServerError, &contract.ErrorResponse{Error: err.Error(), Code: 500})
|
||
|
|
return
|
||
|
|
}
|
||
|
|
c.JSON(http.StatusOK, &contract.SuccessResponse{Message: "deleted"})
|
||
|
|
}
|
||
|
|
|
||
|
|
func (h *RBACHandler) ListPermissions(c *gin.Context) {
|
||
|
|
resp, err := h.svc.ListPermissions(c.Request.Context())
|
||
|
|
if err != nil {
|
||
|
|
c.JSON(http.StatusInternalServerError, &contract.ErrorResponse{Error: err.Error(), Code: 500})
|
||
|
|
return
|
||
|
|
}
|
||
|
|
c.JSON(http.StatusOK, contract.BuildSuccessResponse(resp))
|
||
|
|
}
|
||
|
|
|
||
|
|
func (h *RBACHandler) CreateRole(c *gin.Context) {
|
||
|
|
var req contract.CreateRoleRequest
|
||
|
|
if err := c.ShouldBindJSON(&req); err != nil {
|
||
|
|
c.JSON(http.StatusBadRequest, &contract.ErrorResponse{Error: "invalid body", Code: 400})
|
||
|
|
return
|
||
|
|
}
|
||
|
|
resp, err := h.svc.CreateRole(c.Request.Context(), &req)
|
||
|
|
if err != nil {
|
||
|
|
c.JSON(http.StatusInternalServerError, &contract.ErrorResponse{Error: err.Error(), Code: 500})
|
||
|
|
return
|
||
|
|
}
|
||
|
|
c.JSON(http.StatusCreated, contract.BuildSuccessResponse(resp))
|
||
|
|
}
|
||
|
|
|
||
|
|
func (h *RBACHandler) UpdateRole(c *gin.Context) {
|
||
|
|
id, err := uuid.Parse(c.Param("id"))
|
||
|
|
if err != nil {
|
||
|
|
c.JSON(http.StatusBadRequest, &contract.ErrorResponse{Error: "invalid id", Code: 400})
|
||
|
|
return
|
||
|
|
}
|
||
|
|
var req contract.UpdateRoleRequest
|
||
|
|
if err := c.ShouldBindJSON(&req); err != nil {
|
||
|
|
c.JSON(http.StatusBadRequest, &contract.ErrorResponse{Error: "invalid body", Code: 400})
|
||
|
|
return
|
||
|
|
}
|
||
|
|
resp, err := h.svc.UpdateRole(c.Request.Context(), id, &req)
|
||
|
|
if err != nil {
|
||
|
|
c.JSON(http.StatusInternalServerError, &contract.ErrorResponse{Error: err.Error(), Code: 500})
|
||
|
|
return
|
||
|
|
}
|
||
|
|
c.JSON(http.StatusOK, contract.BuildSuccessResponse(resp))
|
||
|
|
}
|
||
|
|
|
||
|
|
func (h *RBACHandler) DeleteRole(c *gin.Context) {
|
||
|
|
id, err := uuid.Parse(c.Param("id"))
|
||
|
|
if err != nil {
|
||
|
|
c.JSON(http.StatusBadRequest, &contract.ErrorResponse{Error: "invalid id", Code: 400})
|
||
|
|
return
|
||
|
|
}
|
||
|
|
if err := h.svc.DeleteRole(c.Request.Context(), id); err != nil {
|
||
|
|
c.JSON(http.StatusInternalServerError, &contract.ErrorResponse{Error: err.Error(), Code: 500})
|
||
|
|
return
|
||
|
|
}
|
||
|
|
c.JSON(http.StatusOK, &contract.SuccessResponse{Message: "deleted"})
|
||
|
|
}
|
||
|
|
|
||
|
|
func (h *RBACHandler) ListRoles(c *gin.Context) {
|
||
|
|
resp, err := h.svc.ListRoles(c.Request.Context())
|
||
|
|
if err != nil {
|
||
|
|
c.JSON(http.StatusInternalServerError, &contract.ErrorResponse{Error: err.Error(), Code: 500})
|
||
|
|
return
|
||
|
|
}
|
||
|
|
c.JSON(http.StatusOK, contract.BuildSuccessResponse(resp))
|
||
|
|
}
|