diff --git a/src/app/modules/admin/controller/sys/role.ts b/src/app/modules/admin/controller/sys/role.ts index a8449f5..15ec244 100644 --- a/src/app/modules/admin/controller/sys/role.ts +++ b/src/app/modules/admin/controller/sys/role.ts @@ -1,5 +1,6 @@ import { Provide } from '@midwayjs/decorator'; import { CoolController, BaseController } from 'midwayjs-cool-core'; +import { Context } from 'vm'; import { AdminSysRoleEntity } from '../../entity/sys/role'; /** @@ -11,9 +12,13 @@ import { AdminSysRoleEntity } from '../../entity/sys/role'; entity: AdminSysRoleEntity, pageQueryOp: { keyWordLikeFields: ['name', 'label'], - where: (async () => { + where: (async (ctx: Context) => { + const { userId, roleIds, role } = ctx.admin; return [ + // 超级管理员的角色不展示 ['label != :label', { label: 'admin' }], + // 如果不是超管,只能看到自己新建的或者自己有的角色 + ['(userId=:userId or id in (:roleIds))', { userId, roleIds }, role != 'admin'] ] }) }