2022-08-07 23:42:45 +08:00
|
|
|
// Copyright 2022 The Casdoor Authors. All Rights Reserved.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
package controllers
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
2023-12-20 11:41:54 +08:00
|
|
|
"fmt"
|
2022-08-07 23:42:45 +08:00
|
|
|
|
|
|
|
"github.com/casdoor/casdoor/object"
|
2023-05-12 21:39:57 +08:00
|
|
|
"github.com/casdoor/casdoor/util"
|
2022-08-07 23:42:45 +08:00
|
|
|
)
|
|
|
|
|
2023-06-04 17:19:58 +08:00
|
|
|
// Enforce
|
|
|
|
// @Title Enforce
|
2024-01-15 23:35:40 +08:00
|
|
|
// @Tag Enforcer API
|
2023-06-04 17:19:58 +08:00
|
|
|
// @Description Call Casbin Enforce API
|
2023-12-29 15:12:40 +08:00
|
|
|
// @Param body body []string true "Casbin request"
|
2023-06-04 17:19:58 +08:00
|
|
|
// @Param permissionId query string false "permission id"
|
|
|
|
// @Param modelId query string false "model id"
|
|
|
|
// @Param resourceId query string false "resource id"
|
2024-01-05 14:12:59 +07:00
|
|
|
// @Param owner query string false "owner"
|
2023-06-04 17:19:58 +08:00
|
|
|
// @Success 200 {object} controllers.Response The Response object
|
|
|
|
// @router /enforce [post]
|
2022-08-07 23:42:45 +08:00
|
|
|
func (c *ApiController) Enforce() {
|
2023-05-12 21:32:48 +08:00
|
|
|
permissionId := c.Input().Get("permissionId")
|
2023-05-12 21:39:57 +08:00
|
|
|
modelId := c.Input().Get("modelId")
|
2023-05-18 15:36:03 +07:00
|
|
|
resourceId := c.Input().Get("resourceId")
|
2023-07-31 00:20:53 +08:00
|
|
|
enforcerId := c.Input().Get("enforcerId")
|
2024-01-05 14:12:59 +07:00
|
|
|
owner := c.Input().Get("owner")
|
2023-05-12 21:32:48 +08:00
|
|
|
|
2023-10-13 23:29:37 +08:00
|
|
|
if len(c.Ctx.Input.RequestBody) == 0 {
|
|
|
|
c.ResponseError("The request body should not be empty")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-12-29 15:12:40 +08:00
|
|
|
var request []string
|
2023-05-12 21:32:48 +08:00
|
|
|
err := json.Unmarshal(c.Ctx.Input.RequestBody, &request)
|
2022-08-07 23:42:45 +08:00
|
|
|
if err != nil {
|
2022-08-20 21:09:32 +08:00
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
2022-08-07 23:42:45 +08:00
|
|
|
}
|
|
|
|
|
2023-07-31 00:20:53 +08:00
|
|
|
if enforcerId != "" {
|
2023-08-11 12:31:49 +08:00
|
|
|
enforcer, err := object.GetInitializedEnforcer(enforcerId)
|
2023-07-31 00:20:53 +08:00
|
|
|
if err != nil {
|
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-12-20 11:41:54 +08:00
|
|
|
res := []bool{}
|
|
|
|
keyRes := []string{}
|
|
|
|
|
2023-12-29 15:12:40 +08:00
|
|
|
// type transformation
|
|
|
|
interfaceRequest := util.StringToInterfaceArray(request)
|
|
|
|
|
|
|
|
enforceResult, err := enforcer.Enforce(interfaceRequest...)
|
2023-07-31 00:20:53 +08:00
|
|
|
if err != nil {
|
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-12-20 11:41:54 +08:00
|
|
|
res = append(res, enforceResult)
|
|
|
|
keyRes = append(keyRes, enforcer.GetModelAndAdapter())
|
|
|
|
|
|
|
|
c.ResponseOk(res, keyRes)
|
2023-07-31 00:20:53 +08:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-05-12 21:39:57 +08:00
|
|
|
if permissionId != "" {
|
2023-06-23 23:30:43 +07:00
|
|
|
permission, err := object.GetPermission(permissionId)
|
2023-06-04 17:29:34 +08:00
|
|
|
if err != nil {
|
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
|
|
|
}
|
2023-12-20 11:41:54 +08:00
|
|
|
if permission == nil {
|
2024-02-16 01:13:34 +08:00
|
|
|
c.ResponseError(fmt.Sprintf(c.T("permission:The permission: \"%s\" doesn't exist"), permissionId))
|
2023-12-20 11:41:54 +08:00
|
|
|
return
|
|
|
|
}
|
2023-06-04 17:29:34 +08:00
|
|
|
|
|
|
|
res := []bool{}
|
2023-12-20 11:41:54 +08:00
|
|
|
keyRes := []string{}
|
2023-06-23 23:30:43 +07:00
|
|
|
|
2023-12-29 15:12:40 +08:00
|
|
|
enforceResult, err := object.Enforce(permission, request)
|
2023-12-20 11:41:54 +08:00
|
|
|
if err != nil {
|
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
2023-06-23 23:30:43 +07:00
|
|
|
}
|
|
|
|
|
2023-12-20 11:41:54 +08:00
|
|
|
res = append(res, enforceResult)
|
|
|
|
keyRes = append(keyRes, permission.GetModelAndAdapter())
|
|
|
|
|
|
|
|
c.ResponseOk(res, keyRes)
|
2023-05-18 15:36:03 +07:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-06-04 17:19:58 +08:00
|
|
|
permissions := []*object.Permission{}
|
2023-05-18 15:36:03 +07:00
|
|
|
if modelId != "" {
|
2023-05-12 21:39:57 +08:00
|
|
|
owner, modelName := util.GetOwnerAndNameFromId(modelId)
|
2023-05-30 15:49:39 +08:00
|
|
|
permissions, err = object.GetPermissionsByModel(owner, modelName)
|
|
|
|
if err != nil {
|
2023-06-04 17:19:58 +08:00
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
2023-05-30 15:49:39 +08:00
|
|
|
}
|
2023-06-04 17:19:58 +08:00
|
|
|
} else if resourceId != "" {
|
2023-05-30 15:49:39 +08:00
|
|
|
permissions, err = object.GetPermissionsByResource(resourceId)
|
|
|
|
if err != nil {
|
2023-06-04 17:19:58 +08:00
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
2023-05-30 15:49:39 +08:00
|
|
|
}
|
2024-01-05 14:12:59 +07:00
|
|
|
} else if owner != "" {
|
|
|
|
permissions, err = object.GetPermissions(owner)
|
2024-02-01 23:06:12 +08:00
|
|
|
if err != nil {
|
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
|
|
|
}
|
2023-06-04 17:19:58 +08:00
|
|
|
} else {
|
|
|
|
c.ResponseError(c.T("general:Missing parameter"))
|
|
|
|
return
|
2023-05-18 15:36:03 +07:00
|
|
|
}
|
2023-05-12 21:39:57 +08:00
|
|
|
|
2023-06-04 17:19:58 +08:00
|
|
|
res := []bool{}
|
2023-12-20 11:41:54 +08:00
|
|
|
keyRes := []string{}
|
2023-06-22 16:45:24 +07:00
|
|
|
listPermissionIdMap := object.GroupPermissionsByModelAdapter(permissions)
|
2023-12-20 11:41:54 +08:00
|
|
|
for key, permissionIds := range listPermissionIdMap {
|
2023-06-23 23:30:43 +07:00
|
|
|
firstPermission, err := object.GetPermission(permissionIds[0])
|
|
|
|
if err != nil {
|
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-12-29 15:12:40 +08:00
|
|
|
enforceResult, err := object.Enforce(firstPermission, request, permissionIds...)
|
2023-06-04 17:29:34 +08:00
|
|
|
if err != nil {
|
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
res = append(res, enforceResult)
|
2023-12-20 11:41:54 +08:00
|
|
|
keyRes = append(keyRes, key)
|
2023-05-12 21:39:57 +08:00
|
|
|
}
|
2023-06-22 16:45:24 +07:00
|
|
|
|
2023-12-20 11:41:54 +08:00
|
|
|
c.ResponseOk(res, keyRes)
|
2022-08-07 23:42:45 +08:00
|
|
|
}
|
|
|
|
|
2023-06-04 17:19:58 +08:00
|
|
|
// BatchEnforce
|
|
|
|
// @Title BatchEnforce
|
2024-01-15 23:35:40 +08:00
|
|
|
// @Tag Enforcer API
|
2023-06-04 17:19:58 +08:00
|
|
|
// @Description Call Casbin BatchEnforce API
|
2023-12-29 15:12:40 +08:00
|
|
|
// @Param body body []string true "array of casbin requests"
|
2023-06-04 17:19:58 +08:00
|
|
|
// @Param permissionId query string false "permission id"
|
|
|
|
// @Param modelId query string false "model id"
|
2024-01-05 14:12:59 +07:00
|
|
|
// @Param owner query string false "owner"
|
2023-06-04 17:19:58 +08:00
|
|
|
// @Success 200 {object} controllers.Response The Response object
|
|
|
|
// @router /batch-enforce [post]
|
2022-08-07 23:42:45 +08:00
|
|
|
func (c *ApiController) BatchEnforce() {
|
2023-05-12 21:32:48 +08:00
|
|
|
permissionId := c.Input().Get("permissionId")
|
2023-05-12 21:39:57 +08:00
|
|
|
modelId := c.Input().Get("modelId")
|
2023-07-31 00:20:53 +08:00
|
|
|
enforcerId := c.Input().Get("enforcerId")
|
2024-01-05 14:12:59 +07:00
|
|
|
owner := c.Input().Get("owner")
|
2023-05-12 21:32:48 +08:00
|
|
|
|
2023-12-29 15:12:40 +08:00
|
|
|
var requests [][]string
|
2023-05-12 21:32:48 +08:00
|
|
|
err := json.Unmarshal(c.Ctx.Input.RequestBody, &requests)
|
2022-08-07 23:42:45 +08:00
|
|
|
if err != nil {
|
2023-06-04 17:19:58 +08:00
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
2022-08-07 23:42:45 +08:00
|
|
|
}
|
|
|
|
|
2023-07-31 00:20:53 +08:00
|
|
|
if enforcerId != "" {
|
2023-08-11 12:31:49 +08:00
|
|
|
enforcer, err := object.GetInitializedEnforcer(enforcerId)
|
2023-07-31 00:20:53 +08:00
|
|
|
if err != nil {
|
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-12-20 11:41:54 +08:00
|
|
|
res := [][]bool{}
|
|
|
|
keyRes := []string{}
|
|
|
|
|
2023-12-29 15:12:40 +08:00
|
|
|
// type transformation
|
|
|
|
interfaceRequests := util.StringToInterfaceArray2d(requests)
|
|
|
|
|
|
|
|
enforceResult, err := enforcer.BatchEnforce(interfaceRequests)
|
2023-07-31 00:20:53 +08:00
|
|
|
if err != nil {
|
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-12-20 11:41:54 +08:00
|
|
|
res = append(res, enforceResult)
|
|
|
|
keyRes = append(keyRes, enforcer.GetModelAndAdapter())
|
|
|
|
|
|
|
|
c.ResponseOk(res, keyRes)
|
2023-07-31 00:20:53 +08:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-05-12 21:39:57 +08:00
|
|
|
if permissionId != "" {
|
2023-06-23 23:30:43 +07:00
|
|
|
permission, err := object.GetPermission(permissionId)
|
2023-06-04 17:29:34 +08:00
|
|
|
if err != nil {
|
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
|
|
|
}
|
2023-12-20 11:41:54 +08:00
|
|
|
if permission == nil {
|
2024-02-16 01:13:34 +08:00
|
|
|
c.ResponseError(fmt.Sprintf(c.T("permission:The permission: \"%s\" doesn't exist"), permissionId))
|
2023-12-20 11:41:54 +08:00
|
|
|
return
|
|
|
|
}
|
2023-06-04 17:29:34 +08:00
|
|
|
|
|
|
|
res := [][]bool{}
|
2023-12-20 11:41:54 +08:00
|
|
|
keyRes := []string{}
|
2023-06-23 23:30:43 +07:00
|
|
|
|
2023-12-29 15:12:40 +08:00
|
|
|
enforceResult, err := object.BatchEnforce(permission, requests)
|
2023-12-20 11:41:54 +08:00
|
|
|
if err != nil {
|
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
2023-06-23 23:30:43 +07:00
|
|
|
}
|
|
|
|
|
2023-12-20 11:41:54 +08:00
|
|
|
res = append(res, enforceResult)
|
|
|
|
keyRes = append(keyRes, permission.GetModelAndAdapter())
|
|
|
|
|
|
|
|
c.ResponseOk(res, keyRes)
|
2023-06-04 17:19:58 +08:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
permissions := []*object.Permission{}
|
|
|
|
if modelId != "" {
|
2023-05-12 21:39:57 +08:00
|
|
|
owner, modelName := util.GetOwnerAndNameFromId(modelId)
|
2023-06-04 17:19:58 +08:00
|
|
|
permissions, err = object.GetPermissionsByModel(owner, modelName)
|
2023-05-30 15:49:39 +08:00
|
|
|
if err != nil {
|
2023-06-04 17:19:58 +08:00
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
2023-05-12 21:39:57 +08:00
|
|
|
}
|
2024-01-05 14:12:59 +07:00
|
|
|
} else if owner != "" {
|
|
|
|
permissions, err = object.GetPermissions(owner)
|
2024-02-01 23:06:12 +08:00
|
|
|
if err != nil {
|
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
|
|
|
}
|
2023-06-04 17:19:58 +08:00
|
|
|
} else {
|
|
|
|
c.ResponseError(c.T("general:Missing parameter"))
|
|
|
|
return
|
|
|
|
}
|
2023-05-30 15:49:39 +08:00
|
|
|
|
2023-06-04 17:19:58 +08:00
|
|
|
res := [][]bool{}
|
2023-12-20 11:41:54 +08:00
|
|
|
keyRes := []string{}
|
2023-06-22 16:45:24 +07:00
|
|
|
listPermissionIdMap := object.GroupPermissionsByModelAdapter(permissions)
|
2023-06-22 13:40:09 +07:00
|
|
|
for _, permissionIds := range listPermissionIdMap {
|
2023-06-23 23:30:43 +07:00
|
|
|
firstPermission, err := object.GetPermission(permissionIds[0])
|
|
|
|
if err != nil {
|
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-12-29 15:12:40 +08:00
|
|
|
enforceResult, err := object.BatchEnforce(firstPermission, requests, permissionIds...)
|
2023-06-04 17:29:34 +08:00
|
|
|
if err != nil {
|
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
res = append(res, enforceResult)
|
2023-12-20 11:41:54 +08:00
|
|
|
keyRes = append(keyRes, firstPermission.GetModelAndAdapter())
|
2023-05-12 21:39:57 +08:00
|
|
|
}
|
2023-06-22 13:40:09 +07:00
|
|
|
|
2023-12-20 11:41:54 +08:00
|
|
|
c.ResponseOk(res, keyRes)
|
2022-08-07 23:42:45 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func (c *ApiController) GetAllObjects() {
|
2024-01-13 18:03:40 +08:00
|
|
|
userId := c.Input().Get("userId")
|
2022-08-07 23:42:45 +08:00
|
|
|
if userId == "" {
|
2024-01-13 18:03:40 +08:00
|
|
|
userId = c.GetSessionUsername()
|
|
|
|
if userId == "" {
|
|
|
|
c.ResponseError(c.T("general:Please login first"))
|
|
|
|
return
|
|
|
|
}
|
2022-08-07 23:42:45 +08:00
|
|
|
}
|
|
|
|
|
2023-12-02 15:26:52 +08:00
|
|
|
objects, err := object.GetAllObjects(userId)
|
|
|
|
if err != nil {
|
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
c.ResponseOk(objects)
|
2022-08-07 23:42:45 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func (c *ApiController) GetAllActions() {
|
2024-01-13 18:03:40 +08:00
|
|
|
userId := c.Input().Get("userId")
|
2022-08-07 23:42:45 +08:00
|
|
|
if userId == "" {
|
2024-01-13 18:03:40 +08:00
|
|
|
userId = c.GetSessionUsername()
|
|
|
|
if userId == "" {
|
|
|
|
c.ResponseError(c.T("general:Please login first"))
|
|
|
|
return
|
|
|
|
}
|
2022-08-07 23:42:45 +08:00
|
|
|
}
|
|
|
|
|
2023-12-02 15:26:52 +08:00
|
|
|
actions, err := object.GetAllActions(userId)
|
|
|
|
if err != nil {
|
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
c.ResponseOk(actions)
|
2022-08-07 23:42:45 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func (c *ApiController) GetAllRoles() {
|
2024-01-13 18:03:40 +08:00
|
|
|
userId := c.Input().Get("userId")
|
2022-08-07 23:42:45 +08:00
|
|
|
if userId == "" {
|
2024-01-13 18:03:40 +08:00
|
|
|
userId = c.GetSessionUsername()
|
|
|
|
if userId == "" {
|
|
|
|
c.ResponseError(c.T("general:Please login first"))
|
|
|
|
return
|
|
|
|
}
|
2022-08-07 23:42:45 +08:00
|
|
|
}
|
|
|
|
|
2023-12-02 15:26:52 +08:00
|
|
|
roles, err := object.GetAllRoles(userId)
|
|
|
|
if err != nil {
|
|
|
|
c.ResponseError(err.Error())
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
c.ResponseOk(roles)
|
2022-08-07 23:42:45 +08:00
|
|
|
}
|