mirror of
https://gitee.com/dromara/mayfly-go
synced 2025-11-10 11:20:24 +08:00
114 lines
3.1 KiB
Go
114 lines
3.1 KiB
Go
package api
|
||
|
||
import (
|
||
"mayfly-go/internal/sys/api/form"
|
||
"mayfly-go/internal/sys/api/vo"
|
||
"mayfly-go/internal/sys/application"
|
||
"mayfly-go/internal/sys/domain/entity"
|
||
"mayfly-go/internal/sys/imsg"
|
||
"mayfly-go/pkg/biz"
|
||
"mayfly-go/pkg/req"
|
||
"mayfly-go/pkg/utils/collx"
|
||
"strings"
|
||
|
||
"github.com/spf13/cast"
|
||
)
|
||
|
||
type Role struct {
|
||
roleApp application.Role `inject:"T"`
|
||
}
|
||
|
||
func (r *Role) ReqConfs() *req.Confs {
|
||
reqs := [...]*req.Conf{
|
||
req.NewGet("", r.Roles),
|
||
|
||
req.NewPost("", r.SaveRole).Log(req.NewLogSaveI(imsg.LogRoleSave)).RequiredPermissionCode("role:add"),
|
||
|
||
req.NewDelete(":id", r.DelRole).Log(req.NewLogSaveI(imsg.LogRoleDelete)).RequiredPermissionCode("role:del"),
|
||
|
||
req.NewGet(":id/resourceIds", r.RoleResourceIds),
|
||
|
||
req.NewGet(":id/resources", r.RoleResource),
|
||
|
||
req.NewPost(":id/resources", r.SaveResource).Log(req.NewLogSaveI(imsg.LogAssignRoleResource)).RequiredPermissionCode("role:saveResources"),
|
||
|
||
req.NewGet(":id/accounts", r.RoleAccount),
|
||
}
|
||
|
||
return req.NewConfs("sys/roles", reqs[:]...)
|
||
}
|
||
|
||
func (r *Role) Roles(rc *req.Ctx) {
|
||
cond := req.BindQuery[*entity.RoleQuery](rc)
|
||
|
||
notIdsStr := rc.Query("notIds")
|
||
if notIdsStr != "" {
|
||
cond.NotIds = collx.ArrayMap(strings.Split(notIdsStr, ","), func(val string) uint64 {
|
||
return cast.ToUint64(val)
|
||
})
|
||
}
|
||
ids := rc.Query("ids")
|
||
if ids != "" {
|
||
cond.Ids = collx.ArrayMap(strings.Split(ids, ","), func(val string) uint64 {
|
||
return cast.ToUint64(val)
|
||
})
|
||
}
|
||
|
||
res, err := r.roleApp.GetPageList(cond)
|
||
biz.ErrIsNil(err)
|
||
rc.ResData = res
|
||
}
|
||
|
||
// 保存角色信息
|
||
func (r *Role) SaveRole(rc *req.Ctx) {
|
||
form, role := req.BindJsonAndCopyTo[*form.RoleForm, *entity.Role](rc)
|
||
rc.ReqParam = form
|
||
|
||
r.roleApp.SaveRole(rc.MetaCtx, role)
|
||
}
|
||
|
||
// 删除角色及其资源关联关系
|
||
func (r *Role) DelRole(rc *req.Ctx) {
|
||
idsStr := rc.PathParam("id")
|
||
rc.ReqParam = collx.Kvs("ids", idsStr)
|
||
ids := strings.Split(idsStr, ",")
|
||
|
||
for _, v := range ids {
|
||
biz.ErrIsNil(r.roleApp.DeleteRole(rc.MetaCtx, cast.ToUint64(v)))
|
||
}
|
||
}
|
||
|
||
// 获取角色关联的资源id数组,用于分配资源时回显已拥有的资源
|
||
func (r *Role) RoleResourceIds(rc *req.Ctx) {
|
||
rc.ResData = r.roleApp.GetRoleResourceIds(uint64(rc.PathParamInt("id")))
|
||
}
|
||
|
||
// 查看角色关联的资源树信息
|
||
func (r *Role) RoleResource(rc *req.Ctx) {
|
||
var resources vo.ResourceManageVOList
|
||
r.roleApp.GetRoleResources(uint64(rc.PathParamInt("id")), &resources)
|
||
rc.ResData = resources.ToTrees(0)
|
||
}
|
||
|
||
// 保存角色资源
|
||
func (r *Role) SaveResource(rc *req.Ctx) {
|
||
form := req.BindJson[*form.RoleResourceForm](rc)
|
||
rc.ReqParam = form
|
||
|
||
// 将,拼接的字符串进行切割并转换
|
||
newIds := collx.ArrayMap[string, uint64](strings.Split(form.ResourceIds, ","), func(val string) uint64 {
|
||
return cast.ToUint64(val)
|
||
})
|
||
|
||
biz.ErrIsNilAppendErr(r.roleApp.SaveRoleResource(rc.MetaCtx, form.Id, newIds), "save role resource failed: %s")
|
||
}
|
||
|
||
// 查看角色关联的用户
|
||
func (r *Role) RoleAccount(rc *req.Ctx) {
|
||
cond := req.BindQuery[*entity.RoleAccountQuery](rc)
|
||
cond.RoleId = uint64(rc.PathParamInt("id"))
|
||
res, err := r.roleApp.GetRoleAccountPage(cond)
|
||
biz.ErrIsNil(err)
|
||
rc.ResData = res
|
||
}
|