2019-10-13 14:18:29 +00:00
|
|
|
|
using System;
|
2020-10-08 03:45:54 +00:00
|
|
|
|
using System.Net.Http;
|
2020-10-08 03:55:07 +00:00
|
|
|
|
using IdentityServer4.Extensions;
|
2019-10-13 14:18:29 +00:00
|
|
|
|
using Microsoft.AspNetCore.Builder;
|
2019-05-01 21:41:28 +00:00
|
|
|
|
using Microsoft.AspNetCore.Hosting;
|
2020-09-24 14:46:58 +00:00
|
|
|
|
using Microsoft.AspNetCore.Http;
|
2019-05-01 21:41:28 +00:00
|
|
|
|
using Microsoft.AspNetCore.Identity;
|
|
|
|
|
using Microsoft.AspNetCore.Mvc;
|
|
|
|
|
using Microsoft.EntityFrameworkCore;
|
|
|
|
|
using Microsoft.Extensions.Configuration;
|
|
|
|
|
using Microsoft.Extensions.DependencyInjection;
|
2019-09-26 15:10:51 +00:00
|
|
|
|
using Microsoft.Extensions.Hosting;
|
2020-10-03 16:38:01 +00:00
|
|
|
|
using IdentityServer4.Services;
|
2020-10-08 13:45:17 +00:00
|
|
|
|
using Microsoft.AspNetCore.HttpOverrides;
|
2020-10-08 03:45:54 +00:00
|
|
|
|
using SteamOpenIdConnectProvider.Database;
|
|
|
|
|
using SteamOpenIdConnectProvider.Profile;
|
2019-05-01 21:41:28 +00:00
|
|
|
|
|
2019-10-13 14:18:29 +00:00
|
|
|
|
namespace SteamOpenIdConnectProvider
|
2019-05-01 21:41:28 +00:00
|
|
|
|
{
|
|
|
|
|
public class Startup
|
|
|
|
|
{
|
|
|
|
|
public Startup(IConfiguration configuration)
|
|
|
|
|
{
|
|
|
|
|
Configuration = configuration;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public IConfiguration Configuration { get; }
|
|
|
|
|
|
|
|
|
|
public void ConfigureServices(IServiceCollection services)
|
|
|
|
|
{
|
2019-09-26 15:10:51 +00:00
|
|
|
|
services.AddControllers()
|
|
|
|
|
.SetCompatibilityVersion(CompatibilityVersion.Version_3_0);
|
2020-10-08 03:55:07 +00:00
|
|
|
|
|
2020-10-08 03:45:54 +00:00
|
|
|
|
services.AddSingleton(Configuration);
|
2020-10-08 03:55:07 +00:00
|
|
|
|
services.AddDbContext<AppInMemoryDbContext>(options =>
|
2019-09-26 15:10:51 +00:00
|
|
|
|
options.UseInMemoryDatabase("default"));
|
2019-05-01 21:41:28 +00:00
|
|
|
|
|
2019-09-27 13:16:47 +00:00
|
|
|
|
services.AddIdentity<IdentityUser, IdentityRole>(options =>
|
|
|
|
|
{
|
|
|
|
|
options.User.AllowedUserNameCharacters = null;
|
|
|
|
|
})
|
2019-05-01 21:41:28 +00:00
|
|
|
|
.AddEntityFrameworkStores<AppInMemoryDbContext>()
|
|
|
|
|
.AddDefaultTokenProviders();
|
|
|
|
|
|
|
|
|
|
services.AddIdentityServer(options =>
|
|
|
|
|
{
|
|
|
|
|
options.UserInteraction.LoginUrl = "/ExternalLogin";
|
|
|
|
|
})
|
|
|
|
|
.AddAspNetIdentity<IdentityUser>()
|
2019-12-26 21:26:50 +00:00
|
|
|
|
.AddInMemoryClients(IdentityServerConfig.GetClients(
|
2020-10-08 03:55:07 +00:00
|
|
|
|
Configuration["OpenID:ClientID"],
|
|
|
|
|
Configuration["OpenID:ClientSecret"],
|
|
|
|
|
Configuration["OpenID:RedirectUri"],
|
2019-12-26 21:26:50 +00:00
|
|
|
|
Configuration["OpenID:PostLogoutRedirectUri"]))
|
2019-05-01 21:41:28 +00:00
|
|
|
|
.AddInMemoryPersistedGrants()
|
2019-05-01 22:09:56 +00:00
|
|
|
|
.AddDeveloperSigningCredential(true)
|
2019-05-01 21:41:28 +00:00
|
|
|
|
.AddInMemoryIdentityResources(IdentityServerConfig.GetIdentityResources());
|
2020-10-08 03:55:07 +00:00
|
|
|
|
|
2020-10-08 03:45:54 +00:00
|
|
|
|
services.AddHttpClient<IProfileService, SteamProfileService>();
|
2019-05-01 21:41:28 +00:00
|
|
|
|
|
|
|
|
|
services.AddAuthentication()
|
2020-09-24 14:46:58 +00:00
|
|
|
|
.AddCookie(options =>
|
|
|
|
|
{
|
|
|
|
|
options.Cookie.SameSite = SameSiteMode.Strict;
|
|
|
|
|
options.Cookie.IsEssential = true;
|
|
|
|
|
})
|
2019-05-01 21:41:28 +00:00
|
|
|
|
.AddSteam(options =>
|
|
|
|
|
{
|
|
|
|
|
options.ApplicationKey = Configuration["Authentication:Steam:ApplicationKey"];
|
|
|
|
|
});
|
2019-10-13 14:18:29 +00:00
|
|
|
|
|
|
|
|
|
services.AddHealthChecks()
|
|
|
|
|
.AddUrlGroup(new Uri("https://steamcommunity.com/openid"), "Steam");
|
2019-05-01 21:41:28 +00:00
|
|
|
|
}
|
|
|
|
|
|
2019-09-26 15:10:51 +00:00
|
|
|
|
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
|
2019-05-01 21:41:28 +00:00
|
|
|
|
{
|
|
|
|
|
if (env.IsDevelopment())
|
|
|
|
|
{
|
|
|
|
|
app.UseDeveloperExceptionPage();
|
|
|
|
|
}
|
|
|
|
|
|
2019-12-26 21:26:50 +00:00
|
|
|
|
if (!string.IsNullOrEmpty(Configuration["Hosting:PathBase"]))
|
|
|
|
|
{
|
|
|
|
|
app.UsePathBase(Configuration["Hosting:PathBase"]);
|
|
|
|
|
}
|
|
|
|
|
|
2020-10-08 03:55:07 +00:00
|
|
|
|
app.UseCookiePolicy();
|
|
|
|
|
app.Use(async (ctx, next) =>
|
|
|
|
|
{
|
|
|
|
|
var origin = Configuration["Hosting:PublicOrigin"];
|
|
|
|
|
if (!string.IsNullOrEmpty(origin))
|
|
|
|
|
{
|
|
|
|
|
ctx.SetIdentityServerOrigin(origin);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
await next();
|
|
|
|
|
});
|
|
|
|
|
|
2020-10-08 13:45:17 +00:00
|
|
|
|
var forwardOptions = new ForwardedHeadersOptions
|
|
|
|
|
{
|
|
|
|
|
ForwardedHeaders = ForwardedHeaders.XForwardedFor | ForwardedHeaders.XForwardedProto,
|
|
|
|
|
RequireHeaderSymmetry = false
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
forwardOptions.KnownNetworks.Clear();
|
|
|
|
|
forwardOptions.KnownProxies.Clear();
|
|
|
|
|
|
|
|
|
|
app.UseForwardedHeaders(forwardOptions);
|
2019-09-26 15:10:51 +00:00
|
|
|
|
app.UseRouting();
|
2019-05-01 21:41:28 +00:00
|
|
|
|
app.UseIdentityServer();
|
2019-09-26 15:10:51 +00:00
|
|
|
|
app.UseEndpoints(endpoints =>
|
|
|
|
|
{
|
|
|
|
|
endpoints.MapControllers();
|
2019-10-13 14:18:29 +00:00
|
|
|
|
endpoints.MapHealthChecks("/health");
|
2019-09-26 15:10:51 +00:00
|
|
|
|
});
|
2019-05-01 21:41:28 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|