using System; using System.IO; using System.Reflection; using Microsoft.AspNetCore.Builder; using Microsoft.AspNetCore.Hosting; using Microsoft.Extensions.Configuration; using Microsoft.Extensions.DependencyInjection; using System.Text.Json.Serialization; using BlueWest.Tools; using BlueWest.WebApi.Interceptors; using BlueWest.WebApi.Interfaces; using BlueWest.WebApi.Tools; using Microsoft.AspNetCore.Mvc; using Microsoft.Extensions.Logging; using Microsoft.OpenApi.Models; namespace BlueWest.WebApi { /// /// Startup class for the API. /// public class Startup { private readonly IConfiguration _configuration; private readonly IWebHostEnvironment _environment; private readonly string MyAllowSpecificOrigins = Constants.CorsPolicyName; /// /// Startup configuration of the API /// public Startup(IConfiguration configuration, IWebHostEnvironment hostEnvironment) { _configuration = configuration; _environment = hostEnvironment; } /// /// Configure Services /// /// Dependency injection public void ConfigureServices(IServiceCollection services) { services.AddCors(options => { options.AddPolicy(name: MyAllowSpecificOrigins, builder => { builder.WithOrigins("http://localhost:5173/", "http://localhost:5173", "http://127.0.0.1:5173", "localhost:5173") .AllowAnyMethod() .AllowAnyHeader() .AllowCredentials(); }); }); services .AddResponseCaching() .AddControllers(options => { options.CacheProfiles.Add("Default30", new CacheProfile() { Duration = 30 }); }) .AddJsonOptions(options => options.JsonSerializerOptions.ReferenceHandler = ReferenceHandler.Preserve); services.AddLogging(builder => { builder.AddSimpleConsole(); }); services.AddSession(options => { options.Cookie.Domain = "http://localhost:5173"; options.Cookie.HttpOnly = true; }); services .AddSwaggerGen(options => { options.SchemaFilter(); options.SwaggerDoc("v1", new OpenApiInfo { Title = "BlueWest.Api.App", Version = "v1" }); // Set the comments path for the Swagger JSON and UI. var xmlFile = $"{Assembly.GetExecutingAssembly().GetName().Name}.xml"; var xmlPath = Path.Combine(AppContext.BaseDirectory, xmlFile); options.IncludeXmlComments(xmlPath); options.AddSecurityDefinition("Bearer", new OpenApiSecurityScheme { Description = "JWT Authorization header using the Bearer scheme (Example: 'Bearer 12345abcdef')", Name = "Authorization", In = ParameterLocation.Header, Type = SecuritySchemeType.ApiKey, Scheme = "Bearer" }); options.AddSecurityRequirement(new OpenApiSecurityRequirement { { new OpenApiSecurityScheme { Reference = new OpenApiReference { Type = ReferenceType.SecurityScheme, Id = "Bearer" } }, Array.Empty() } }); }); services.AddGrpc(options => { options.Interceptors.Add(); }); services.AddSingleton(); /* services.AddSingleton( new PhysicalFileProvider( Path.Combine(Directory.GetCurrentDirectory(), "wwwroot/ImageFiles") ) ); */ IConfigurationRoot configuration = new ConfigurationBuilder() .AddJsonFile("config.json") .Build(); var allowedDatabase = configuration["database"]; services .AddSingleton(); services.AddAuthServerServices( _configuration, _environment); services.AddScoped(); switch (allowedDatabase) { case "mysql": services.PrepareMySqlDatabasePool(_configuration, _environment); break; case "sqlite": services.PrepareSqlLiteDatabasePool(_configuration, _environment); break; default: throw new InvalidOperationException("config.json doesn't specify a valid database. Use mysql or sqlite."); } } /// /// This method gets called by the runtime. Use this method to configure the HTTP request pipeline. /// /// Object with the necessary data to configure an application's request pipeline /// Provides information about the web hosting environment an application is running in. public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { //app.UseStaticFiles(); app.UseSwagger(); app.UseSwaggerUI(c => { c.RoutePrefix = "swagger"; c.SwaggerEndpoint("/swagger/v1/swagger.json", "BlueWest.Api v1"); }); app.UseStaticFiles(); //app.UseHttpsRedirection(); app.UseRouting(); app.UseCors(MyAllowSpecificOrigins); app.UseAuthentication(); app.UseAuthorization(); app.UseEndpoints(endpoints => { endpoints.MapControllers(); // endpoints.MapGrpcService(); }); } } }