IdentityService.cs 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. // 麻省理工学院许可证
  2. //
  3. // 版权所有 (c) 2021-2023 zuohuaijun,大名科技(天津)有限公司 联系电话/微信:18020030720 QQ:515096995
  4. //
  5. // 特此免费授予获得本软件的任何人以处理本软件的权利,但须遵守以下条件:在所有副本或重要部分的软件中必须包括上述版权声明和本许可声明。
  6. //
  7. // 软件按“原样”提供,不提供任何形式的明示或暗示的保证,包括但不限于对适销性、适用性和非侵权的保证。
  8. // 在任何情况下,作者或版权持有人均不对任何索赔、损害或其他责任负责,无论是因合同、侵权或其他方式引起的,与软件或其使用或其他交易有关。
  9. using System.Security.Claims;
  10. namespace Admin.NET.Core.Service;
  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 = new APIJSON_Role();
  43. if (string.IsNullOrEmpty(GetUserRoleName())) // 若没登录默认取第一个
  44. {
  45. role = _roles.FirstOrDefault();
  46. }
  47. else
  48. {
  49. role = _roles.FirstOrDefault(it => it.RoleName.Equals(GetUserRoleName(), StringComparison.CurrentCultureIgnoreCase));
  50. }
  51. return role;
  52. }
  53. /// <summary>
  54. /// 获取当前表的可查询字段
  55. /// </summary>
  56. /// <param name="table"></param>
  57. /// <returns></returns>
  58. public (bool, string) GetSelectRole(string table)
  59. {
  60. var role = GetRole();
  61. if (role == null || role.Select == null || role.Select.Table == null)
  62. {
  63. return (false, $"appsettings.json权限配置不正确!");
  64. }
  65. string tablerole = role.Select.Table.FirstOrDefault(it => it == "*" || it.Equals(table, StringComparison.CurrentCultureIgnoreCase));
  66. if (string.IsNullOrEmpty(tablerole))
  67. {
  68. return (false, $"表名{table}没权限查询!");
  69. }
  70. int index = Array.IndexOf(role.Select.Table, tablerole);
  71. string selectrole = role.Select.Column[index];
  72. return (true, selectrole);
  73. }
  74. /// <summary>
  75. /// 当前列是否在角色里面
  76. /// </summary>
  77. /// <param name="col"></param>
  78. /// <param name="selectrole"></param>
  79. /// <returns></returns>
  80. public bool ColIsRole(string col, string[] selectrole)
  81. {
  82. if (selectrole.Contains("*"))
  83. {
  84. return true;
  85. }
  86. else
  87. {
  88. if (col.Contains("(") && col.Contains(")"))
  89. {
  90. Regex reg = new Regex(@"\(([^)]*)\)");
  91. Match m = reg.Match(col);
  92. return selectrole.Contains(m.Result("$1"), StringComparer.CurrentCultureIgnoreCase);
  93. }
  94. else
  95. {
  96. return selectrole.Contains(col, StringComparer.CurrentCultureIgnoreCase);
  97. }
  98. }
  99. }
  100. }