|
|
@ -1,5 +1,4 @@
|
|
|
|
using System;
|
|
|
|
using System;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
|
|
|
using System.Security.Claims;
|
|
|
|
using System.Security.Claims;
|
|
|
|
using System.Security.Principal;
|
|
|
|
using System.Security.Principal;
|
|
|
|
using System.Text;
|
|
|
|
using System.Text;
|
|
|
@ -9,24 +8,23 @@ using Microsoft.Extensions.Options;
|
|
|
|
using Microsoft.IdentityModel.Tokens;
|
|
|
|
using Microsoft.IdentityModel.Tokens;
|
|
|
|
using Ombi.Auth;
|
|
|
|
using Ombi.Auth;
|
|
|
|
using Ombi.Core.IdentityResolver;
|
|
|
|
using Ombi.Core.IdentityResolver;
|
|
|
|
using Ombi.Core.Models;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
namespace Ombi
|
|
|
|
namespace Ombi
|
|
|
|
{
|
|
|
|
{
|
|
|
|
public partial class Startup
|
|
|
|
public partial class Startup
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
public SymmetricSecurityKey signingKey;
|
|
|
|
public SymmetricSecurityKey SigningKey;
|
|
|
|
private void ConfigureAuth(IApplicationBuilder app)
|
|
|
|
private void ConfigureAuth(IApplicationBuilder app, IOptions<TokenAuthenticationOptions> options)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
|
var signingKey = new SymmetricSecurityKey(Encoding.ASCII.GetBytes("secretkey_secretkey123!"));
|
|
|
|
var signingKey = new SymmetricSecurityKey(Encoding.ASCII.GetBytes(options.Value.SecretKey));
|
|
|
|
|
|
|
|
|
|
|
|
var tokenProviderOptions = new TokenProviderOptions
|
|
|
|
var tokenProviderOptions = new TokenProviderOptions
|
|
|
|
{
|
|
|
|
{
|
|
|
|
Path = "/api/v1/token/",
|
|
|
|
Path = options.Value.TokenPath,
|
|
|
|
Audience = "DemoAudience",
|
|
|
|
Audience = options.Value.Audience,
|
|
|
|
Issuer = "DemoIssuer",
|
|
|
|
Issuer = options.Value.Issuer,
|
|
|
|
SigningCredentials = new SigningCredentials(signingKey, SecurityAlgorithms.HmacSha256),
|
|
|
|
SigningCredentials = new SigningCredentials(signingKey, SecurityAlgorithms.HmacSha256),
|
|
|
|
IdentityResolver = GetIdentity
|
|
|
|
IdentityResolver = GetIdentity
|
|
|
|
};
|
|
|
|
};
|
|
|
@ -38,10 +36,10 @@ namespace Ombi
|
|
|
|
IssuerSigningKey = signingKey,
|
|
|
|
IssuerSigningKey = signingKey,
|
|
|
|
// Validate the JWT Issuer (iss) claim
|
|
|
|
// Validate the JWT Issuer (iss) claim
|
|
|
|
ValidateIssuer = true,
|
|
|
|
ValidateIssuer = true,
|
|
|
|
ValidIssuer = "DemoIssuer",
|
|
|
|
ValidIssuer = options.Value.Issuer,
|
|
|
|
// Validate the JWT Audience (aud) claim
|
|
|
|
// Validate the JWT Audience (aud) claim
|
|
|
|
ValidateAudience = true,
|
|
|
|
ValidateAudience = true,
|
|
|
|
ValidAudience = "DemoAudience",
|
|
|
|
ValidAudience = options.Value.Audience,
|
|
|
|
// Validate the token expiry
|
|
|
|
// Validate the token expiry
|
|
|
|
ValidateLifetime = true,
|
|
|
|
ValidateLifetime = true,
|
|
|
|
// If you want to allow a certain amount of clock drift, set that here:
|
|
|
|
// If you want to allow a certain amount of clock drift, set that here:
|
|
|
|