2025-06-20 17:13:51 +08:00
|
|
|
package service
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"context"
|
|
|
|
|
|
2025-06-20 22:03:38 +00:00
|
|
|
"blazing/cool"
|
|
|
|
|
|
|
|
|
|
"blazing/modules/base/model"
|
|
|
|
|
|
2025-06-20 17:13:51 +08:00
|
|
|
"github.com/gogf/gf/v2/container/garray"
|
|
|
|
|
"github.com/gogf/gf/v2/database/gdb"
|
|
|
|
|
"github.com/gogf/gf/v2/frame/g"
|
|
|
|
|
"github.com/gogf/gf/v2/util/gconv"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
var baseSysUserRole = model.NewBaseSysUserRole()
|
|
|
|
|
|
|
|
|
|
type BaseSysRoleService struct {
|
|
|
|
|
*cool.Service
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ModifyAfter modify after
|
|
|
|
|
func (s *BaseSysRoleService) ModifyAfter(ctx context.Context, method string, param g.MapStrAny) (err error) {
|
|
|
|
|
if param["id"] != nil {
|
|
|
|
|
err = s.updatePerms(ctx, gconv.Uint(param["id"]), gconv.SliceUint(param["menuIdList"]), gconv.SliceUint(param["departmentIdList"]))
|
|
|
|
|
}
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// updatePerms(roleId, menuIdList?, departmentIds = [])
|
|
|
|
|
func (s *BaseSysRoleService) updatePerms(ctx context.Context, roleId uint, menuIdList, departmentIds []uint) (err error) {
|
|
|
|
|
// 更新菜单权限
|
2025-07-11 03:36:42 +08:00
|
|
|
cool.DBM(model.NewBaseSysRoleMenu()).Where("roleId", roleId).Delete()
|
2025-06-20 17:13:51 +08:00
|
|
|
if len(menuIdList) > 0 {
|
|
|
|
|
roleMenuList := make([]g.MapStrAny, len(menuIdList))
|
|
|
|
|
for i, menuId := range menuIdList {
|
|
|
|
|
roleMenuList[i] = g.MapStrAny{
|
|
|
|
|
"roleId": roleId,
|
|
|
|
|
"menuId": menuId,
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
cool.DBM(model.NewBaseSysRoleMenu()).Data(roleMenuList).Insert()
|
|
|
|
|
}
|
|
|
|
|
// 更新部门权限
|
2025-07-11 03:36:42 +08:00
|
|
|
cool.DBM(model.NewBaseSysRoleDepartment()).Where("roleId", roleId).Delete()
|
2025-06-20 17:13:51 +08:00
|
|
|
if len(departmentIds) > 0 {
|
|
|
|
|
roleDepartmentList := make([]g.MapStrAny, len(departmentIds))
|
|
|
|
|
for i, departmentId := range departmentIds {
|
|
|
|
|
roleDepartmentList[i] = g.MapStrAny{
|
|
|
|
|
"roleId": roleId,
|
|
|
|
|
"departmentId": departmentId,
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
cool.DBM(model.NewBaseSysRoleDepartment()).Data(roleDepartmentList).Insert()
|
|
|
|
|
}
|
|
|
|
|
// 刷新权限
|
2025-07-11 03:36:42 +08:00
|
|
|
userRoles, err := cool.DBM(model.NewBaseSysUserRole()).Where("roleId", roleId).All()
|
2025-06-20 17:13:51 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
baseSysPermsService := NewBaseSysPermsService()
|
|
|
|
|
for _, v := range userRoles {
|
|
|
|
|
vmap := v.Map()
|
|
|
|
|
if vmap["userId"] != nil {
|
|
|
|
|
baseSysPermsService.RefreshPerms(ctx, gconv.Uint(vmap["userId"]))
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// GetByUser get array roleId by userId
|
|
|
|
|
func (s *BaseSysRoleService) GetByUser(userId uint) []string {
|
|
|
|
|
var (
|
|
|
|
|
roles []string
|
|
|
|
|
)
|
2025-07-11 02:21:12 +08:00
|
|
|
res, _ := cool.DBM(baseSysUserRole).Where("userId", userId).Array("roleId")
|
2025-06-20 17:13:51 +08:00
|
|
|
for _, v := range res {
|
2026-03-02 23:59:15 +08:00
|
|
|
roles = append(roles, v.String())
|
2025-06-20 17:13:51 +08:00
|
|
|
}
|
|
|
|
|
return roles
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// BaseSysRoleService Info 方法重构
|
|
|
|
|
func (s *BaseSysRoleService) ServiceInfo(ctx context.Context, req *cool.InfoReq) (data interface{}, err error) {
|
2025-07-11 03:36:42 +08:00
|
|
|
info, err := cool.DBM(s.Model).Where("id", req.Id).One()
|
2025-06-20 17:13:51 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
if !info.IsEmpty() {
|
|
|
|
|
var menus gdb.Result
|
|
|
|
|
if req.Id == 1 {
|
|
|
|
|
menus, err = cool.DBM(model.NewBaseSysMenu()).All()
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
} else {
|
2025-07-11 03:36:42 +08:00
|
|
|
menus, err = cool.DBM(model.NewBaseSysRoleMenu()).Where("roleId", req.Id).All()
|
2025-06-20 17:13:51 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
menuIdList := garray.NewIntArray()
|
|
|
|
|
for _, v := range menus {
|
|
|
|
|
menuIdList.Append(gconv.Int(v["menuId"]))
|
|
|
|
|
}
|
|
|
|
|
var departments gdb.Result
|
|
|
|
|
if req.Id == 1 {
|
|
|
|
|
departments, err = cool.DBM(model.NewBaseSysRoleDepartment()).All()
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
} else {
|
2025-07-11 03:36:42 +08:00
|
|
|
departments, err = cool.DBM(model.NewBaseSysRoleDepartment()).Where("roleId", req.Id).All()
|
2025-06-20 17:13:51 +08:00
|
|
|
if err != nil {
|
|
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
departmentIdList := garray.NewIntArray()
|
|
|
|
|
for _, v := range departments {
|
|
|
|
|
departmentIdList.Append(gconv.Int(v["departmentId"]))
|
|
|
|
|
}
|
|
|
|
|
result := gconv.Map(info)
|
|
|
|
|
result["menuIdList"] = menuIdList.Slice()
|
|
|
|
|
result["departmentIdList"] = departmentIdList.Slice()
|
|
|
|
|
data = result
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
data = g.Map{}
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// NewBaseSysRoleService create a new BaseSysRoleService
|
|
|
|
|
func NewBaseSysRoleService() *BaseSysRoleService {
|
|
|
|
|
return &BaseSysRoleService{
|
|
|
|
|
Service: &cool.Service{
|
|
|
|
|
Model: model.NewBaseSysRole(),
|
|
|
|
|
ListQueryOp: &cool.QueryOp{
|
|
|
|
|
Where: func(ctx context.Context) [][]interface{} {
|
2026-04-01 20:10:29 +08:00
|
|
|
return [][]interface{}{
|
|
|
|
|
{"label != ?", g.Slice{"admin"}, true},
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
Extend: func(ctx g.Ctx, m *gdb.Model) *gdb.Model {
|
2025-06-20 17:13:51 +08:00
|
|
|
var (
|
|
|
|
|
admin = cool.GetAdmin(ctx)
|
|
|
|
|
userId = admin.UserId
|
|
|
|
|
roleIds = garray.NewIntArrayFromCopy(gconv.Ints(admin.RoleIds))
|
|
|
|
|
)
|
2026-04-01 20:10:29 +08:00
|
|
|
if roleIds.Contains(1) {
|
|
|
|
|
return m
|
|
|
|
|
}
|
|
|
|
|
if roleIds.Len() == 0 {
|
|
|
|
|
return m.Where("userId", userId)
|
2025-06-20 17:13:51 +08:00
|
|
|
}
|
2026-04-01 20:10:29 +08:00
|
|
|
return m.Wheref("(userId = ? or id in (?))", userId, admin.RoleIds)
|
2025-06-20 17:13:51 +08:00
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
PageQueryOp: &cool.QueryOp{
|
|
|
|
|
KeyWordField: []string{"name", "label"},
|
|
|
|
|
AddOrderby: map[string]string{},
|
|
|
|
|
Where: func(ctx context.Context) [][]interface{} {
|
2026-04-01 20:10:29 +08:00
|
|
|
return [][]interface{}{
|
|
|
|
|
{"label != ?", g.Slice{"admin"}, true},
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
Extend: func(ctx g.Ctx, m *gdb.Model) *gdb.Model {
|
2025-06-20 17:13:51 +08:00
|
|
|
var (
|
|
|
|
|
admin = cool.GetAdmin(ctx)
|
|
|
|
|
userId = admin.UserId
|
|
|
|
|
roleIds = garray.NewIntArrayFromCopy(gconv.Ints(admin.RoleIds))
|
|
|
|
|
)
|
2026-04-01 20:10:29 +08:00
|
|
|
if roleIds.Contains(1) {
|
|
|
|
|
return m
|
|
|
|
|
}
|
|
|
|
|
if roleIds.Len() == 0 {
|
|
|
|
|
return m.Where("userid", gconv.String(userId))
|
2025-06-20 17:13:51 +08:00
|
|
|
}
|
2026-04-01 20:10:29 +08:00
|
|
|
return m.Wheref("(userid = ? or id in (?))", gconv.String(userId), admin.RoleIds)
|
2025-06-20 17:13:51 +08:00
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
InsertParam: func(ctx context.Context) map[string]interface{} {
|
2025-10-31 00:53:22 +08:00
|
|
|
return g.Map{`"userid"`: cool.GetAdmin(ctx).UserId}
|
2025-06-20 17:13:51 +08:00
|
|
|
},
|
|
|
|
|
UniqueKey: map[string]string{
|
|
|
|
|
"name": "角色名称不能重复",
|
|
|
|
|
"label": "角色标识不能重复",
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
}
|