Files
PIbd-24_EredavkinRA_TheAvto…/AvtoTazWebApi/Program.cs
2025-04-09 17:25:02 +04:00

117 lines
4.5 KiB
C#

using AutoTazBusinessLogic.implementations;
using AvtoTAZContratcs.AdapterContracts;
using AvtoTAZContratcs.BusinessLogicsContracts;
using AvtoTAZContratcs.Infrastructure;
using AvtoTAZContratcs.StoragesContracts;
using AvtoTAZDatabase;
using AvtoTAZDatabase.Implementations;
using AvtoTazWebApi;
using AvtoTazWebApi.Adapters;
using AvtoTazWebApi.Infrastructure;
using Microsoft.AspNetCore.Authentication.JwtBearer;
using Microsoft.EntityFrameworkCore;
using Microsoft.IdentityModel.Tokens;
using Serilog;
using System.IdentityModel.Tokens.Jwt;
using System.Security.Claims;
using TheAvtoTazDatabase.Implementations;
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
builder.Services.AddControllers();
using var loggerFactory = new LoggerFactory();
loggerFactory.AddSerilog(new LoggerConfiguration().ReadFrom.Configuration(builder.Configuration).CreateLogger());
builder.Services.AddSingleton(loggerFactory.CreateLogger("Any"));
builder.Services.AddAuthorization();
builder.Services.AddAuthentication(JwtBearerDefaults.AuthenticationScheme)
.AddJwtBearer(options =>
{
object AuthOptoins = null;
options.TokenValidationParameters = new TokenValidationParameters
{
// óêàçûâàåò, áóäåò ëè âàëèäèðîâàòüñÿ èçäàòåëü ïðè âàëèäàöèè òîêåíà
ValidateIssuer = true,
// ñòðîêà, ïðåäñòàâëÿþùàÿ èçäàòåëÿ
ValidIssuer = AuthOptions.ISSUER,
// áóäåò ëè âàëèäèðîâàòüñÿ ïîòðåáèòåëü òîêåíà
ValidateAudience = true,
// óñòàíîâêà ïîòðåáèòåëÿ òîêåíà
ValidAudience = AuthOptions.AUDIENCE,
// áóäåò ëè âàëèäèðîâàòüñÿ âðåìÿ ñóùåñòâîâàíèÿ
ValidateLifetime = true,
// óñòàíîâêà êëþ÷à áåçîïàñíîñòè
IssuerSigningKey = AuthOptions.GetSymmetricSecurityKey(),
// âàëèäàöèÿ êëþ÷à áåçîïàñíîñòè
ValidateIssuerSigningKey = true,
};
});
builder.Services.AddSingleton<IConfigurationDatabase, ConfigurationDatabase>();
builder.Services.AddTransient<IAccesoriesBusinessLogicContract, AccessoriesBusinessLogicContract>();
builder.Services.AddTransient<ICarAssemblyBussinessLogicContract, CarAssemblyBussinessLogicContract>();
builder.Services.AddTransient<IPostBusinessLogicContract, PostBusinessLogicContract>();
builder.Services.AddTransient<IDealerBusinessLogicContract, DealerBusinessLogicContract>();
builder.Services.AddTransient<ISalaryBusinessLogicContract, SalaryBusinessLogicContract>();
builder.Services.AddTransient<IShipmentBusinessLogicContract, ShipmentBussinesLogicContract>();
builder.Services.AddTransient<IWorkerBusinessLogicContract, WorkerBusinessLogicContract>();
builder.Services.AddTransient<AvtoTAZDbContext>();
builder.Services.AddTransient<IAccessoriesStorageContact, AccessoriesStorageContract>();
builder.Services.AddTransient<ICarAssemblyStorageContact, CarAssemblyStorageContract>();
builder.Services.AddTransient<IDealerStorageContact, DealerStorageContract>();
builder.Services.AddTransient<IPostStorageContact, PostStorageContract>();
builder.Services.AddTransient<ISalaryStorageContract, SalaryStorageContract>();
builder.Services.AddTransient<IShipmentStorageContact, ShipmentStorageContract>();
builder.Services.AddTransient<IWorkerStorageContact, WorkerStorageContract>();
builder.Services.AddTransient<IDealerAdapter, DealerAdapter>();
builder.Services.AddTransient<IPostAdapter, PostAdapter>();
builder.Services.AddTransient<IAccessoriesAdapter, AccessoriesAdapter>();
builder.Services.AddTransient<ISalaryAdapter, SalaryAdapter>();
// Learn more about configuring OpenAPI at https://aka.ms/aspnet/openapi
builder.Services.AddOpenApi();
var app = builder.Build();
// Configure the HTTP request pipeline.
if (app.Environment.IsDevelopment())
{
app.MapOpenApi();
}
if (app.Environment.IsProduction())
{
var dbContext = app.Services.GetRequiredService<AvtoTAZDbContext>();
if (dbContext.Database.CanConnect())
{
dbContext.Database.EnsureCreated();
dbContext.Database.Migrate();
}
}
app.UseHttpsRedirection();
app.UseAuthentication();
app.UseAuthorization();
app.Map("/login/{username}", (string username) =>
{
return new JwtSecurityTokenHandler().WriteToken(new JwtSecurityToken(
issuer: AuthOptions.ISSUER,
audience: AuthOptions.AUDIENCE,
claims: [new(ClaimTypes.Name, username)],
expires: DateTime.UtcNow.Add(TimeSpan.FromMinutes(10)),
signingCredentials: new SigningCredentials(AuthOptions.GetSymmetricSecurityKey(), SecurityAlgorithms.HmacSha256)));
});
app.MapControllers();
app.Run();