// Copyright 2021 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" "github.com/beego/beego/utils/pagination" "github.com/casdoor/casdoor/object" "github.com/casdoor/casdoor/util" ) // GetPermissions // @Title GetPermissions // @Tag Permission API // @Description get permissions // @Param owner query string true "The owner of permissions" // @Success 200 {array} object.Permission The Response object // @router /get-permissions [get] func (c *ApiController) GetPermissions() { owner := c.Input().Get("owner") limit := c.Input().Get("pageSize") page := c.Input().Get("p") field := c.Input().Get("field") value := c.Input().Get("value") sortField := c.Input().Get("sortField") sortOrder := c.Input().Get("sortOrder") if limit == "" || page == "" { permissions, err := object.GetPermissions(owner) if err != nil { c.ResponseError(err.Error()) return } c.ResponseOk(permissions) } else { limit := util.ParseInt(limit) count, err := object.GetPermissionCount(owner, field, value) if err != nil { c.ResponseError(err.Error()) return } paginator := pagination.SetPaginator(c.Ctx, limit, count) permissions, err := object.GetPaginationPermissions(owner, paginator.Offset(), limit, field, value, sortField, sortOrder) if err != nil { c.ResponseError(err.Error()) return } c.ResponseOk(permissions, paginator.Nums()) } } // GetPermissionsBySubmitter // @Title GetPermissionsBySubmitter // @Tag Permission API // @Description get permissions by submitter // @Success 200 {array} object.Permission The Response object // @router /get-permissions-by-submitter [get] func (c *ApiController) GetPermissionsBySubmitter() { user, ok := c.RequireSignedInUser() if !ok { return } permissions, err := object.GetPermissionsBySubmitter(user.Owner, user.Name) if err != nil { c.ResponseError(err.Error()) return } c.ResponseOk(permissions, len(permissions)) } // GetPermissionsByRole // @Title GetPermissionsByRole // @Tag Permission API // @Description get permissions by role // @Param id query string true "The id ( owner/name ) of the role" // @Success 200 {array} object.Permission The Response object // @router /get-permissions-by-role [get] func (c *ApiController) GetPermissionsByRole() { id := c.Input().Get("id") permissions, err := object.GetPermissionsByRole(id) if err != nil { c.ResponseError(err.Error()) return } c.ResponseOk(permissions, len(permissions)) } // GetPermission // @Title GetPermission // @Tag Permission API // @Description get permission // @Param id query string true "The id ( owner/name ) of the permission" // @Success 200 {object} object.Permission The Response object // @router /get-permission [get] func (c *ApiController) GetPermission() { id := c.Input().Get("id") permission, err := object.GetPermission(id) if err != nil { c.ResponseError(err.Error()) return } c.ResponseOk(permission) } // UpdatePermission // @Title UpdatePermission // @Tag Permission API // @Description update permission // @Param id query string true "The id ( owner/name ) of the permission" // @Param body body object.Permission true "The details of the permission" // @Success 200 {object} controllers.Response The Response object // @router /update-permission [post] func (c *ApiController) UpdatePermission() { id := c.Input().Get("id") var permission object.Permission err := json.Unmarshal(c.Ctx.Input.RequestBody, &permission) if err != nil { c.ResponseError(err.Error()) return } c.Data["json"] = wrapActionResponse(object.UpdatePermission(id, &permission)) c.ServeJSON() } // AddPermission // @Title AddPermission // @Tag Permission API // @Description add permission // @Param body body object.Permission true "The details of the permission" // @Success 200 {object} controllers.Response The Response object // @router /add-permission [post] func (c *ApiController) AddPermission() { var permission object.Permission err := json.Unmarshal(c.Ctx.Input.RequestBody, &permission) if err != nil { c.ResponseError(err.Error()) return } c.Data["json"] = wrapActionResponse(object.AddPermission(&permission)) c.ServeJSON() } // DeletePermission // @Title DeletePermission // @Tag Permission API // @Description delete permission // @Param body body object.Permission true "The details of the permission" // @Success 200 {object} controllers.Response The Response object // @router /delete-permission [post] func (c *ApiController) DeletePermission() { var permission object.Permission err := json.Unmarshal(c.Ctx.Input.RequestBody, &permission) if err != nil { c.ResponseError(err.Error()) return } c.Data["json"] = wrapActionResponse(object.DeletePermission(&permission)) c.ServeJSON() }