Слияние кода завершено, страница обновится автоматически
using Infrastructure;
using Infrastructure.Attribute;
using ZR.Model.System;
namespace ZR.ServiceCore.Services
{
/// <summary>
/// 角色权限
/// </summary>
[AppService(ServiceType = typeof(ISysPermissionService), ServiceLifetime = LifeTime.Transient)]
public class SysPermissionService : ISysPermissionService
{
private readonly ISysRoleService SysRoleService;
private readonly ISysMenuService SysMenuService;
public SysPermissionService(
ISysRoleService sysRoleService,
ISysMenuService sysMenuService)
{
SysRoleService = sysRoleService;
SysMenuService = sysMenuService;
}
/// <summary>
/// 获取角色数据权限
/// </summary>
/// <param name="user">用户信息</param>
/// <returns>角色权限信息</returns>
public List<string> GetRolePermission(SysUser user)
{
List<string> roles = new();
// 管理员拥有所有权限
if (user.IsAdmin)
{
roles.Add("admin");
}
else
{
roles.AddRange(SysRoleService.SelectUserRoleKeys(user.UserId));
}
return roles;
}
/// <summary>
/// 获取菜单数据权限
/// </summary>
/// <param name="user">用户信息</param>
/// <returns>菜单权限信息</returns>
public List<string> GetMenuPermission(SysUser user)
{
List<string> perms = new();
// 管理员拥有所有权限
if (user.IsAdmin || GetRolePermission(user).Exists(f => f.Equals(GlobalConstant.AdminRole)))
{
perms.Add(GlobalConstant.AdminPerm);
}
else
{
perms.AddRange(SysMenuService.SelectMenuPermsByUserId(user.UserId));
}
return perms;
}
}
}
Вы можете оставить комментарий после Вход в систему
Неприемлемый контент может быть отображен здесь и не будет показан на странице. Вы можете проверить и изменить его с помощью соответствующей функции редактирования.
Если вы подтверждаете, что содержание не содержит непристойной лексики/перенаправления на рекламу/насилия/вульгарной порнографии/нарушений/пиратства/ложного/незначительного или незаконного контента, связанного с национальными законами и предписаниями, вы можете нажать «Отправить» для подачи апелляции, и мы обработаем ее как можно скорее.
Комментарий ( 0 )