DocSpace-client/web/ASC.Web.Api/Startup.cs

124 lines
4.3 KiB
C#
Raw Normal View History

2019-07-09 10:29:53 +00:00
using System.Threading;
using ASC.Api.Core.Core;
using ASC.Api.Core.Middleware;
using ASC.Common.DependencyInjection;
using ASC.Common.Logging;
using ASC.Common.Utils;
using ASC.Core;
using ASC.Data.Reassigns;
using ASC.Data.Storage.Configuration;
using ASC.MessagingSystem;
using ASC.Web.Core;
using Microsoft.AspNetCore.Authentication;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
2019-07-12 14:28:14 +00:00
using Microsoft.AspNetCore.HttpOverrides;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.Authorization;
using Microsoft.AspNetCore.Mvc.Formatters;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
2019-05-28 15:05:20 +00:00
namespace ASC.Web.Api
{
public class Startup
{
2019-05-28 15:05:20 +00:00
public IConfiguration Configuration { get; }
public IHostEnvironment HostEnvironment { get; }
2019-05-28 15:05:20 +00:00
public Startup(IConfiguration configuration, IHostEnvironment hostEnvironment)
{
Configuration = configuration;
HostEnvironment = hostEnvironment;
}
public void ConfigureServices(IServiceCollection services)
{
services.AddControllers()
2019-05-27 09:46:04 +00:00
.AddNewtonsoftJson(s=> s.UseCamelCasing(true))
.AddXmlSerializerFormatters();
2019-06-06 13:34:46 +00:00
services.AddMemoryCache();
2019-06-07 08:59:07 +00:00
services.AddDistributedMemoryCache();
services.AddSession();
services.AddHttpContextAccessor();
services.AddAuthentication("cookie").AddScheme<AuthenticationSchemeOptions, CookieAuthHandler>("cookie", a=> { });
var builder = services.AddMvc(config =>
{
var policy = new AuthorizationPolicyBuilder().RequireAuthenticatedUser().Build();
config.Filters.Add(new AuthorizeFilter(policy));
config.Filters.Add(new TypeFilterAttribute(typeof(TenantStatusFilter)));
config.Filters.Add(new TypeFilterAttribute(typeof(PaymentFilter)));
2019-06-25 14:33:17 +00:00
config.Filters.Add(new TypeFilterAttribute(typeof(IpSecurityFilter)));
2019-06-25 07:34:27 +00:00
config.Filters.Add(new TypeFilterAttribute(typeof(ProductSecurityFilter)));
2019-06-13 12:12:21 +00:00
config.Filters.Add(new CustomResponseFilterAttribute());
config.Filters.Add(new CustomExceptionFilterAttribute());
config.Filters.Add(new TypeFilterAttribute(typeof(FormatFilter)));
});
2019-05-28 15:05:20 +00:00
var container = services.AddAutofac(Configuration, HostEnvironment.ContentRootPath);
2019-06-10 16:15:34 +00:00
services.AddLogManager()
2019-06-10 12:54:10 +00:00
.AddStorage()
2019-06-17 13:53:10 +00:00
.AddWebItemManager()
2019-06-21 12:42:27 +00:00
.AddScoped<MessageService>()
.AddScoped<QueueWorkerReassign>()
.AddScoped<QueueWorkerRemove>();
}
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
2019-07-12 14:28:14 +00:00
app.UseForwardedHeaders(new ForwardedHeadersOptions
{
ForwardedHeaders = ForwardedHeaders.XForwardedFor | ForwardedHeaders.XForwardedProto
});
2019-05-30 07:33:38 +00:00
app.UseCors(builder =>
builder
.AllowAnyOrigin()
.AllowAnyHeader()
.AllowAnyMethod());
app.UseRouting();
2019-06-07 08:59:07 +00:00
app.UseSession();
2019-05-30 14:57:15 +00:00
app.UseAuthentication();
2019-06-24 08:20:03 +00:00
app.Use(async (context, next) => {
if (SecurityContext.IsAuthenticated)
{
var user = CoreContext.UserManager.GetUsers(SecurityContext.CurrentAccount.ID);
var culture = user.GetCulture();
Thread.CurrentThread.CurrentCulture = user.GetCulture();
Thread.CurrentThread.CurrentCulture = user.GetCulture();
}
await next.Invoke();
});
app.UseEndpoints(endpoints =>
{
endpoints.MapControllers();
2019-06-25 10:46:10 +00:00
endpoints.MapCustom();
});
2019-06-06 08:44:38 +00:00
2019-06-24 08:20:03 +00:00
app.UseCSP();
app.UseCm();
app.UseWebItemManager();
}
}
}