-
Notifications
You must be signed in to change notification settings - Fork 5
/
AllOperationsPolicy.cs
42 lines (40 loc) · 1.58 KB
/
AllOperationsPolicy.cs
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
40
41
42
using System.Collections.Generic;
using System.Net;
using Microsoft.Net.Http.Headers;
using Oriflame.PolicyBuilder.Policies;
using Oriflame.PolicyBuilder.Policies.Builders;
using Oriflame.PolicyBuilder.Policies.Builders.Enums;
namespace Oriflame.PolicyBuilder.ApiExample.Policies
{
public class AllOperationsPolicy : AllOperationsPolicyBase
{
public AllOperationsPolicy(IPolicyBuilder policyBuilder) : base(policyBuilder)
{
}
public override void Create()
{
PolicyBuilder
.Inbound(builder => builder
.Base()
.ValidateJwt(jwtAttr => jwtAttr
.HeaderName(HeaderNames.Authorization)
.FailedValidationStatusCode(HttpStatusCode.Unauthorized)
.FailedValidationMessage("Unauthorized. Access token is missing or invalid.")
.Create(),
"http://contoso.com/.well-known/openid-configuration",
new List<string> { "http://contoso.com/" },
requiredClaimsBuilder => requiredClaimsBuilder
.SetClaimPolicy("scope", new[] { "forecast_api" }, RequiredClaimsMatch.All)
.Create()
)
.Create())
.Backend(builder => builder
.Base()
.Create())
.Outbound(builder => builder
.Base()
.Create()
);
}
}
}