Roles and permissions view completed
This commit is contained in:
@@ -3,20 +3,19 @@ package roles
|
||||
import (
|
||||
"context"
|
||||
"net/http"
|
||||
"strconv"
|
||||
|
||||
"fr.latosa-escrima/core"
|
||||
"fr.latosa-escrima/core/models"
|
||||
"github.com/google/uuid"
|
||||
)
|
||||
|
||||
func HandleAddPermission(w http.ResponseWriter, r *http.Request) {
|
||||
ctx := context.Background()
|
||||
role_id := r.PathValue("role_uuid")
|
||||
permission_id := r.PathValue("permission_id")
|
||||
resource := r.PathValue("resource")
|
||||
action := r.PathValue("action")
|
||||
var permission models.Permission
|
||||
count, err := core.DB.NewSelect().Model(&permission).
|
||||
Where("id = ?", permission_id).
|
||||
Where("resource = ? AND action = ?", resource, action).
|
||||
Limit(1).ScanAndCount(ctx)
|
||||
if count == 0 {
|
||||
core.JSONError{
|
||||
@@ -39,11 +38,9 @@ func HandleAddPermission(w http.ResponseWriter, r *http.Request) {
|
||||
return
|
||||
}
|
||||
|
||||
pid, err := strconv.Atoi(permission_id)
|
||||
rid, err := uuid.Parse(role_id)
|
||||
permissionRole := models.PermissionToRole{
|
||||
PermissionID: pid,
|
||||
RoleID: rid,
|
||||
PermissionID: permission.ID,
|
||||
RoleID: role.ID,
|
||||
}
|
||||
_, err = core.DB.NewInsert().Model(&permissionRole).Ignore().
|
||||
Exec(ctx)
|
||||
|
||||
Reference in New Issue
Block a user