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

82 lines
2.5 KiB
C#
Raw Normal View History

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;
2019-05-28 15:05:20 +00:00
2019-05-29 15:19:36 +00:00
using ASC.Api.Core;
2019-05-28 15:05:20 +00:00
using ASC.Common.Logging;
using ASC.Web.Api.Handlers;
2019-05-27 09:46:04 +00:00
using ASC.Web.Api.Middleware;
2019-05-29 15:19:36 +00:00
using System.Linq;
using System.Reflection;
using System.IO;
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 Startup(IConfiguration configuration)
{
Configuration = configuration;
}
public void ConfigureServices(IServiceCollection services)
{
services.AddControllers()
2019-05-27 09:46:04 +00:00
.AddNewtonsoftJson(s=> s.UseCamelCasing(true))
.AddXmlSerializerFormatters();
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 TypeFilterAttribute(typeof(FormatFilter)));
config.Filters.Add(new AuthorizeFilter(policy));
});
2019-05-28 15:05:20 +00:00
2019-05-29 15:19:36 +00:00
var assemblies = Directory.GetFiles(Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location), "*.dll")
.Select(Assembly.LoadFrom)
.Where(r => r.GetCustomAttribute<CustomApiAttribute>() != null);
foreach (var a in assemblies) {
builder.AddApplicationPart(a);
}
2019-05-28 15:24:38 +00:00
services.AddLogManager(Configuration);
}
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
app.UseCors(builder => builder.AllowAnyOrigin());
app.UseRouting();
app.UseAuthentication();
2019-05-27 09:46:04 +00:00
app.UseResponseWrapper();
app.UseEndpoints(endpoints =>
{
endpoints.MapControllers();
});
}
}
}