steam-openid-connect-provider/src/Startup.cs

122 lines
4.3 KiB
C#
Raw Normal View History

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;
using Microsoft.AspNetCore.Builder;
2019-05-01 21:41:28 +00:00
using Microsoft.AspNetCore.Hosting;
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;
using SteamOpenIdConnectProvider.Services;
using SteamOpenIdConnectProvider.Models.IdentityServer;
using SteamOpenIdConnectProvider.Domains.Common;
using SteamOpenIdConnectProvider.Domains.IdentityServer;
using SteamOpenIdConnectProvider.Domains.Steam;
2019-05-01 21:41:28 +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
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();
var openIdConfig = Configuration.GetSection(OpenIdConfig.Key).Get<OpenIdConfig>();
2019-05-01 21:41:28 +00:00
services.AddIdentityServer(options =>
{
options.UserInteraction.LoginUrl = "/ExternalLogin";
})
.AddAspNetIdentity<IdentityUser>()
.AddInMemoryClients(IdentityServerConfigFactory.GetClients(openIdConfig))
2019-05-01 21:41:28 +00:00
.AddInMemoryPersistedGrants()
2019-05-01 22:09:56 +00:00
.AddDeveloperSigningCredential(true)
.AddInMemoryIdentityResources(IdentityServerConfigFactory.GetIdentityResources());
2020-10-08 03:55:07 +00:00
var steamConfig = Configuration.GetSection(SteamConfig.Key).Get<SteamConfig>();
services
.Configure<SteamConfig>(Configuration.GetSection(SteamConfig.Key))
.AddHttpClient<IProfileService, SteamProfileService>();
2019-05-01 21:41:28 +00:00
services.AddAuthentication()
.AddCookie(options =>
{
options.Cookie.SameSite = SameSiteMode.Strict;
options.Cookie.IsEssential = true;
})
2019-05-01 21:41:28 +00:00
.AddSteam(options =>
{
options.ApplicationKey = steamConfig.ApplicationKey;
2019-05-01 21:41:28 +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();
}
var hostingConfig = Configuration.GetSection(HostingConfig.Key).Get<HostingConfig>();
if (!string.IsNullOrEmpty(hostingConfig.BasePath))
{
app.UsePathBase(hostingConfig.BasePath);
}
2020-10-08 03:55:07 +00:00
app.UseCookiePolicy();
app.Use(async (ctx, next) =>
{
if (!string.IsNullOrEmpty(hostingConfig.PublicOrigin))
2020-10-08 03:55:07 +00:00
{
ctx.SetIdentityServerOrigin(hostingConfig.PublicOrigin);
2020-10-08 03:55:07 +00:00
}
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();
endpoints.MapHealthChecks("/health");
2019-09-26 15:10:51 +00:00
});
2019-05-01 21:41:28 +00:00
}
}
}