using System.Text; using ASC.Api.Core.Auth; using ASC.Api.Core.Core; using ASC.Api.Core.Middleware; using ASC.Api.Documents; using ASC.Common; using ASC.Common.DependencyInjection; using ASC.Common.Logging; using ASC.Web.Files; using ASC.Web.Files.HttpHandlers; using Microsoft.AspNetCore.Authentication; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Builder; using Microsoft.AspNetCore.Hosting; 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; using Microsoft.Extensions.Options; namespace ASC.Files { public class Startup { public IConfiguration Configuration { get; } public IHostEnvironment HostEnvironment { get; } public Startup(IConfiguration configuration, IHostEnvironment hostEnvironment) { Configuration = configuration; HostEnvironment = hostEnvironment; } public void ConfigureServices(IServiceCollection services) { Encoding.RegisterProvider(CodePagesEncodingProvider.Instance); services.AddHttpContextAccessor(); services.AddControllers() .AddNewtonsoftJson() .AddXmlSerializerFormatters(); services.AddTransient, CustomJsonOptionsWrapper>(); services.AddMemoryCache(); services.AddAuthentication("cookie") .AddScheme("cookie", a => { }); var builder = services.AddMvcCore(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))); config.Filters.Add(new TypeFilterAttribute(typeof(IpSecurityFilter))); config.Filters.Add(new TypeFilterAttribute(typeof(ProductSecurityFilter))); config.Filters.Add(new CustomResponseFilterAttribute()); config.Filters.Add(new CustomExceptionFilterAttribute()); config.Filters.Add(new TypeFilterAttribute(typeof(FormatFilter))); config.OutputFormatters.RemoveType(); config.OutputFormatters.Add(new XmlOutputFormatter()); }); var diHelper = new DIHelper(services); diHelper .AddCookieAuthHandler() .AddCultureMiddleware() .AddIpSecurityFilter() .AddPaymentFilter() .AddProductSecurityFilter() .AddTenantStatusFilter(); diHelper.AddNLogManager("ASC.Files"); diHelper .AddDocumentsControllerService() .AddEncryptionControllerService() .AddFileHandlerService() .AddChunkedUploaderHandlerService() .AddThirdPartyAppHandlerService() .AddDocuSignHandlerService(); services.AddAutofac(Configuration, HostEnvironment.ContentRootPath); } public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); } app.UseForwardedHeaders(new ForwardedHeadersOptions { ForwardedHeaders = ForwardedHeaders.XForwardedFor | ForwardedHeaders.XForwardedProto }); app.UseCors(builder => builder .AllowAnyOrigin() .AllowAnyHeader() .AllowAnyMethod()); app.UseRouting(); app.UseAuthentication(); app.UseAuthorization(); app.UseCultureMiddleware(); app.UseDisposeMiddleware(); app.UseEndpoints(endpoints => { endpoints.MapControllers(); endpoints.MapCustom(); }); app.MapWhen( context => context.Request.Path.ToString().EndsWith("httphandlers/filehandler.ashx"), appBranch => { appBranch.UseFileHandler(); }); app.MapWhen( context => context.Request.Path.ToString().EndsWith("ChunkedUploader.ashx"), appBranch => { appBranch.UseChunkedUploaderHandler(); }); app.MapWhen( context => context.Request.Path.ToString().EndsWith("ThirdPartyAppHandler.ashx"), appBranch => { appBranch.UseThirdPartyAppHandler(); }); app.MapWhen( context => context.Request.Path.ToString().EndsWith("DocuSignHandler.ashx"), appBranch => { appBranch.UseDocuSignHandler(); }); app.UseStaticFiles(); } } }