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.Extensions; using BlueWest.WebApi.Interfaces; namespace BlueWest.WebApi { /// /// Startup class for the API. /// public class Startup { private readonly IConfiguration _configuration; private readonly IWebHostEnvironment _environment; private readonly string MyAllowSpecificOrigins = "_myAllowSpecificOrigins"; /// /// 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", "http://127.0.0.1", "http://localhost:3000", "http://127.0.0.1:3000", "localhost:3000", "127.0.0.1:3000") .AllowAnyHeader().AllowAnyMethod(); });*/ }); services .AddControllers() .AddJsonOptions(options => options.JsonSerializerOptions.ReferenceHandler = ReferenceHandler.Preserve); services .AddSwaggerGen(options => options.ConfigureSwaggerOptions()); services .AddSingleton() .PrepareDatabasePool(_configuration, _environment) .AddScoped(); // services.AddGrpc(); } /// /// 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.UseDeveloperExceptionPage(); app.UseSwagger(); app.UseSwaggerUI(c => { c.RoutePrefix = "swagger"; c.SwaggerEndpoint("/swagger/v1/swagger.json", "BlueWest.Api v1"); }); //app.UseHttpsRedirection(); app.UseRouting(); app.UseCors(MyAllowSpecificOrigins); app.UseAuthorization(); app.UseEndpoints(endpoints => { endpoints.MapControllers(); // endpoints.MapGrpcService(); }); } } }