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/pkg/biz" "mayfly-go/pkg/req" "mayfly-go/pkg/utils/anyx" "mayfly-go/pkg/utils/collx" "strconv" "strings" ) type Role struct { RoleApp application.Role `inject:""` ResourceApp application.Resource `inject:""` } func (r *Role) Roles(rc *req.Ctx) { cond, pageParam := req.BindQueryAndPage(rc, new(entity.RoleQuery)) notIdsStr := rc.Query("notIds") if notIdsStr != "" { cond.NotIds = collx.ArrayMap[string, uint64](strings.Split(notIdsStr, ","), func(val string) uint64 { return uint64(anyx.ConvInt(val)) }) } res, err := r.RoleApp.GetPageList(cond, pageParam, new([]entity.Role)) biz.ErrIsNil(err) rc.ResData = res } // 保存角色信息 func (r *Role) SaveRole(rc *req.Ctx) { form := &form.RoleForm{} role := req.BindJsonAndCopyTo(rc, form, new(entity.Role)) 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 { value, err := strconv.Atoi(v) biz.ErrIsNilAppendErr(err, "string类型转换为int异常: %s") r.RoleApp.DeleteRole(rc.MetaCtx, uint64(value)) } } // 获取角色关联的资源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) { var form form.RoleResourceForm req.BindJsonAndValid(rc, &form) rc.ReqParam = form // 将,拼接的字符串进行切割并转换 newIds := collx.ArrayMap[string, uint64](strings.Split(form.ResourceIds, ","), func(val string) uint64 { id, _ := strconv.Atoi(val) return uint64(id) }) r.RoleApp.SaveRoleResource(rc.MetaCtx, form.Id, newIds) } // 查看角色关联的用户 func (r *Role) RoleAccount(rc *req.Ctx) { cond, pageParam := req.BindQueryAndPage[*entity.RoleAccountQuery](rc, new(entity.RoleAccountQuery)) cond.RoleId = uint64(rc.PathParamInt("id")) var accounts []*vo.AccountRoleVO res, err := r.RoleApp.GetRoleAccountPage(cond, pageParam, &accounts) biz.ErrIsNil(err) rc.ResData = res }