aboutsummaryrefslogtreecommitdiffstats
path: root/code/api/src/Utilities/BasicAuthenticationAttribute.cs
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
		}
	}
}