using System.Linq; using System.Collections.Generic; using Microsoft.AspNetCore.Authentication; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Builder; using Microsoft.AspNetCore.Hosting; 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 ASC.Common.Logging; using ASC.Web.Api.Handlers; using ASC.Api.Core.Middleware; using ASC.Common.Utils; using ASC.Common.DependencyInjection; using ASC.Web.Core; using ASC.Data.Storage.Configuration; using Autofac; using ASC.MessagingSystem; using ASC.Data.Reassigns; namespace ASC.Web.Api { public class Startup { public IConfiguration Configuration { get; } public Startup(IConfiguration configuration) { Configuration = configuration; } public void ConfigureServices(IServiceCollection services) { services.AddControllers() .AddNewtonsoftJson(s=> s.UseCamelCasing(true)) .AddXmlSerializerFormatters(); services.AddMemoryCache(); services.AddDistributedMemoryCache(); services.AddSession(); services.AddHttpContextAccessor(); services.AddAuthentication("cookie").AddScheme("cookie", a=> { }); var builder = services.AddMvc(config => { var policy = new AuthorizationPolicyBuilder().RequireAuthenticatedUser().Build(); config.Filters.Add(new AuthorizeFilter(policy)); config.Filters.Add(new CustomResponseFilterAttribute()); config.Filters.Add(new CustomExceptionFilterAttribute()); config.Filters.Add(new TypeFilterAttribute(typeof(FormatFilter))); }); var container = services.AddAutofac(Configuration); var assemblies = container.Resolve>().Select(r=> r.GetType().Assembly).Distinct(); foreach (var a in assemblies) { builder.AddApplicationPart(a); } services.AddLogManager() .AddStorage() .AddWebItemManager() .AddScoped() .AddScoped() .AddScoped(); } public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); } app.UseCors(builder => builder .AllowAnyOrigin() .AllowAnyHeader() .AllowAnyMethod()); app.UseRouting(); app.UseSession(); app.UseAuthentication(); app.UseEndpoints(endpoints => { endpoints.MapControllers(); }); CommonServiceProvider.Init(app.ApplicationServices); ConfigurationManager.Init(app.ApplicationServices); app.UseWebItemManager(); } } }