blob: 0bfd007b51e0f6a3ec82f227c89cb852b390494a (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
using System.Net.Http.Headers;
using Microsoft.AspNetCore.Mvc.Filters;
namespace IOL.GreatOffice.Api.Utilities;
public class BasicAuthenticationAttribute : TypeFilterAttribute
{
public BasicAuthenticationAttribute(string claimPermission) : base(typeof(BasicAuthenticationFilter)) {
Arguments = new object[] {
new Claim(claimPermission, "True")
};
}
}
public class BasicAuthenticationFilter : IAuthorizationFilter
{
private readonly Claim _claim;
public BasicAuthenticationFilter(Claim claim) {
_claim = claim;
}
public void OnAuthorization(AuthorizationFilterContext context) {
if (!context.HttpContext.Request.Headers.ContainsKey("Authorization")) return;
try {
var authHeader = AuthenticationHeaderValue.Parse(context.HttpContext.Request.Headers["Authorization"]);
if (authHeader.Parameter is null) {
context.Result = new ForbidResult(AppConstants.BASIC_AUTH_SCHEME);
}
var hasClaim = context.HttpContext.User.Claims.Any(c => c.Type == _claim.Type && c.Value == _claim.Value);
if (!hasClaim) {
context.Result = new ForbidResult(AppConstants.BASIC_AUTH_SCHEME);
}
} catch {
// ignore
}
}
}
|