diff options
author | crupest <crupest@outlook.com> | 2020-11-12 21:38:43 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2020-11-12 21:38:43 +0800 |
commit | ee1b2b5b100268aa510257a1a2cd4cd03f9fc72b (patch) | |
tree | 221a2af5008e180e180f5400f127a0d404ed5158 /BackEnd/Timeline/Auth/PermissionPolicyProvider.cs | |
parent | 2c6b812382e04956793d90ba4148dd4aa7da3b70 (diff) | |
download | timeline-ee1b2b5b100268aa510257a1a2cd4cd03f9fc72b.tar.gz timeline-ee1b2b5b100268aa510257a1a2cd4cd03f9fc72b.tar.bz2 timeline-ee1b2b5b100268aa510257a1a2cd4cd03f9fc72b.zip |
...
Diffstat (limited to 'BackEnd/Timeline/Auth/PermissionPolicyProvider.cs')
-rw-r--r-- | BackEnd/Timeline/Auth/PermissionPolicyProvider.cs | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/BackEnd/Timeline/Auth/PermissionPolicyProvider.cs b/BackEnd/Timeline/Auth/PermissionPolicyProvider.cs new file mode 100644 index 00000000..12a4fcd5 --- /dev/null +++ b/BackEnd/Timeline/Auth/PermissionPolicyProvider.cs @@ -0,0 +1,35 @@ +using Microsoft.AspNetCore.Authorization;
+using Microsoft.AspNetCore.Authorization.Infrastructure;
+using System;
+using System.Threading.Tasks;
+
+namespace Timeline.Auth
+{
+ public class PermissionPolicyProvider : IAuthorizationPolicyProvider
+ {
+ public const string PolicyPrefix = "Permission-";
+
+ public Task<AuthorizationPolicy> GetDefaultPolicyAsync()
+ {
+ return Task.FromResult(new AuthorizationPolicyBuilder(AuthenticationConstants.Scheme).RequireAuthenticatedUser().Build());
+ }
+
+ public Task<AuthorizationPolicy?> GetFallbackPolicyAsync()
+ {
+ return Task.FromResult<AuthorizationPolicy?>(null);
+ }
+
+ public Task<AuthorizationPolicy?> GetPolicyAsync(string policyName)
+ {
+ if (policyName.StartsWith(PolicyPrefix, StringComparison.OrdinalIgnoreCase))
+ {
+ var permissions = policyName[PolicyPrefix.Length..].Split(',');
+
+ var policy = new AuthorizationPolicyBuilder(AuthenticationConstants.Scheme);
+ policy.AddRequirements(new ClaimsAuthorizationRequirement(AuthenticationConstants.PermissionClaimName, permissions));
+ return Task.FromResult<AuthorizationPolicy?>(policy.Build());
+ }
+ return Task.FromResult<AuthorizationPolicy?>(null);
+ }
+ }
+}
|