颐和api

PermissionRequirement.cs 1.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. using Microsoft.AspNetCore.Authorization;
  2. using Microsoft.IdentityModel.Tokens;
  3. using System;
  4. using System.Collections.Generic;
  5. namespace Api.SignToken
  6. {
  7. /// <summary>
  8. /// 必要参数类
  9. /// </summary>
  10. public class PermissionRequirement : IAuthorizationRequirement
  11. {
  12. /// <summary>
  13. /// 无权限action
  14. /// </summary>
  15. public string DeniedAction { get; set; }
  16. /// <summary>
  17. /// 认证授权类型
  18. /// </summary>
  19. public string ClaimType { internal get; set; }
  20. /// <summary>
  21. /// 请求路径
  22. /// </summary>
  23. public string LoginPath { get; set; } = "/Api/Login";
  24. /// <summary>
  25. /// 发行人
  26. /// </summary>
  27. public string Issuer { get; set; }
  28. /// <summary>
  29. /// 订阅人
  30. /// </summary>
  31. public string Audience { get; set; }
  32. /// <summary>
  33. /// 过期时间
  34. /// </summary>
  35. public TimeSpan Expiration { get; set; }
  36. /// <summary>
  37. /// 签名验证
  38. /// </summary>
  39. public SigningCredentials SigningCredentials { get; set; }
  40. /// <summary>
  41. /// 构造
  42. /// </summary>
  43. /// <param name="deniedAction">拒约请求的url</param>
  44. /// <param name="claimType">声明类型</param>
  45. /// <param name="issuer">发行人</param>
  46. /// <param name="audience">订阅人</param>
  47. /// <param name="signingCredentials">签名验证实体</param>
  48. public PermissionRequirement(string deniedAction, string claimType, string issuer, string audience, SigningCredentials signingCredentials, TimeSpan expiration)
  49. {
  50. ClaimType = claimType;
  51. DeniedAction = deniedAction;
  52. Issuer = issuer;
  53. Audience = audience;
  54. Expiration = expiration;
  55. SigningCredentials = signingCredentials;
  56. }
  57. }
  58. }