DamageAssessment_Backend/DamageAssesmentApi/DamageAssesment.Api.Employees/Program.cs

64 lines
1.9 KiB
C#
Raw Normal View History

2023-08-15 22:52:30 -05:00
using DamageAssesment.Api.Employees.Db;
using DamageAssesment.Api.Employees.Interfaces;
using DamageAssesment.Api.Employees.Providers;
using Microsoft.EntityFrameworkCore;
using System.Reflection;
2023-08-15 22:52:30 -05:00
var builder = WebApplication.CreateBuilder(args);
2023-11-10 14:09:43 -05:00
// CORS setup to allow requests from any origin.
builder.Services.AddCors(p => p.AddPolicy("DamageAppCorsPolicy", build => {
build.WithOrigins("*").AllowAnyMethod().AllowAnyHeader().AllowAnyOrigin();
}));
// Add services to the container.
2023-08-15 22:52:30 -05:00
builder.Services.AddControllers();
// Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
builder.Services.AddEndpointsApiExplorer();
2023-11-10 14:09:43 -05:00
// Add Swagger/OpenAPI documentation support.
builder.Services.AddSwaggerGen(c =>
{
// Include XML comments from your assembly
var xmlFile = $"{Assembly.GetExecutingAssembly().GetName().Name}.xml";
var xmlPath = Path.Combine(AppContext.BaseDirectory, xmlFile);
c.IncludeXmlComments(xmlPath);
});
2023-08-15 22:52:30 -05:00
builder.Services.AddScoped<IEmployeesProvider, EmployeesProvider>();
builder.Services.AddAutoMapper(AppDomain.CurrentDomain.GetAssemblies()); //4/30
builder.Services.AddDbContext<EmployeeDbContext>(option =>
{
2023-08-18 16:14:41 -05:00
option.UseSqlServer("EmployeeConnection");
2023-08-15 22:52:30 -05:00
});
builder.Services.AddCors(p => p.AddPolicy("DamageAppCorsPolicy", build => {
build.WithOrigins("*").AllowAnyMethod().AllowAnyHeader().AllowAnyOrigin();
}));
2023-08-15 22:52:30 -05:00
var app = builder.Build();
// Configure the HTTP request pipeline.
if (app.Environment.IsDevelopment())
{
app.UseSwagger();
app.UseSwaggerUI();
using (var serviceScope = app.Services.CreateScope())
{
var services = serviceScope.ServiceProvider;
var employeesProvider = services.GetRequiredService<IEmployeesProvider>();
employeesProvider.SeedData();
}
2023-08-15 22:52:30 -05:00
}
app.UseCors("DamageAppCorsPolicy");
2023-08-15 22:52:30 -05:00
2023-11-10 14:09:43 -05:00
// Enable CORS, authentication, and authorization middleware.
app.UseCors("DamageAppCorsPolicy");
2023-08-15 22:52:30 -05:00
app.UseAuthorization();
app.MapControllers();
app.Run();