IdentityService.cs 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. // Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
  2. //
  3. // 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
  4. //
  5. // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
  6. using System.Security.Claims;
  7. namespace Admin.NET.Core.Service;
  8. /// <summary>
  9. /// 权限验证
  10. /// </summary>
  11. public class IdentityService : ITransient
  12. {
  13. private readonly IHttpContextAccessor _context;
  14. private readonly List<APIJSON_Role> _roles;
  15. public IdentityService(IHttpContextAccessor context, IOptions<APIJSONOptions> roles)
  16. {
  17. _context = context ?? throw new ArgumentNullException(nameof(context));
  18. _roles = roles.Value.Roles;
  19. }
  20. /// <summary>
  21. /// 获取当前用户Id
  22. /// </summary>
  23. /// <returns></returns>
  24. public string GetUserIdentity()
  25. {
  26. return _context.HttpContext.User.FindFirstValue(ClaimTypes.NameIdentifier);
  27. }
  28. /// <summary>
  29. /// 获取当前用户权限名称
  30. /// </summary>
  31. /// <returns></returns>
  32. public string GetUserRoleName()
  33. {
  34. return _context.HttpContext.User.FindFirstValue(ClaimTypes.Role);
  35. }
  36. /// <summary>
  37. /// 获取当前用户权限
  38. /// </summary>
  39. /// <returns></returns>
  40. public APIJSON_Role GetRole()
  41. {
  42. var role = string.IsNullOrEmpty(GetUserRoleName())
  43. ? _roles.FirstOrDefault()
  44. : _roles.FirstOrDefault(it => it.RoleName.Equals(GetUserRoleName(), StringComparison.CurrentCultureIgnoreCase));
  45. return role;
  46. }
  47. /// <summary>
  48. /// 获取当前表的可查询字段
  49. /// </summary>
  50. /// <param name="table"></param>
  51. /// <returns></returns>
  52. public (bool, string) GetSelectRole(string table)
  53. {
  54. var role = GetRole();
  55. if (role == null || role.Select == null || role.Select.Table == null)
  56. return (false, $"appsettings.json权限配置不正确!");
  57. var tablerole = role.Select.Table.FirstOrDefault(it => it == "*" || it.Equals(table, StringComparison.CurrentCultureIgnoreCase));
  58. if (string.IsNullOrEmpty(tablerole))
  59. return (false, $"表名{table}没权限查询!");
  60. var index = Array.IndexOf(role.Select.Table, tablerole);
  61. var selectrole = role.Select.Column[index];
  62. return (true, selectrole);
  63. }
  64. /// <summary>
  65. /// 当前列是否在角色里面
  66. /// </summary>
  67. /// <param name="col"></param>
  68. /// <param name="selectrole"></param>
  69. /// <returns></returns>
  70. public bool ColIsRole(string col, string[] selectrole)
  71. {
  72. if (selectrole.Contains("*")) return true;
  73. if (col.Contains('(') && col.Contains(')'))
  74. {
  75. var reg = new Regex(@"\(([^)]*)\)");
  76. var match = reg.Match(col);
  77. return selectrole.Contains(match.Result("$1"), StringComparer.CurrentCultureIgnoreCase);
  78. }
  79. else
  80. {
  81. return selectrole.Contains(col, StringComparer.CurrentCultureIgnoreCase);
  82. }
  83. }
  84. }