key1_beacon_api/ARW.Service/System/SysPermissionService.cs
2023-06-02 21:15:33 +08:00

69 lines
2.0 KiB
C#

using Infrastructure;
using Infrastructure.Attribute;
using System;
using System.Collections.Generic;
using System.Text;
using ARW.Model.System;
using ARW.Service.System.IService;
namespace ARW.Service.System
{
/// <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 List<string>();
// 管理员拥有所有权限
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;
}
}
}