Files
Pibd-21_Semin_D.A._SmallSof…/SmallSoftwareProject/SmallSoftwareWebApi/Program.cs
2025-04-10 09:07:45 +04:00

114 lines
4.5 KiB
C#

using Microsoft.AspNetCore.Authentication.JwtBearer;
using Microsoft.EntityFrameworkCore;
using Microsoft.IdentityModel.Tokens;
using Serilog;
using SmallSoftwareBusinessLogic.Implementations;
using SmallSoftwareContracts.AdapterContracts;
using SmallSoftwareContracts.BusinessLogicsContracts;
using SmallSoftwareContracts.Infrastructure;
using SmallSoftwareContracts.StoragesContracts;
using SmallSoftwareDatabase;
using SmallSoftwareDatabase.Implementations;
using SmallSoftwareWebApi;
using SmallSoftwareWebApi.Adapters;
using SmallSoftwareWebApi.Infrastructure;
using System.IdentityModel.Tokens.Jwt;
using System.Security.Claims;
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 =>
{
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<IManufacturerBusinessLogicContract, ManufacturerBusinessLogicContract>();
builder.Services.AddTransient<IPostBusinessLogicContract, PostBusinessLogicContract>();
builder.Services.AddTransient<ISoftwareBusinessLogicContract, SoftwareBusinessLogicContract>();
builder.Services.AddTransient<ISalaryBusinessLogicContract, SalaryBusinessLogicContract>();
builder.Services.AddTransient<IRequestBusinessLogicContract, RequestBusinessLogicContract>();
builder.Services.AddTransient<IWorkerBusinessLogicContract, WorkerBusinessLogicContract>();
builder.Services.AddTransient<SmallSoftwareDbContext>();
builder.Services.AddTransient<IManufacturerStorageContract, ManufacturerStorageContract>();
builder.Services.AddTransient<IPostStorageContract, PostStorageContract>();
builder.Services.AddTransient<ISoftwareStorageContract, SoftwareStorageContract>();
builder.Services.AddTransient<ISalaryStorageContract, SalaryStorageContract>();
builder.Services.AddTransient<IRequestStorageContract, RequestStorageContract>();
builder.Services.AddTransient<IWorkerStorageContract, WorkerStorageContract>();
builder.Services.AddTransient<IManufacturerAdapter, ManufacturerAdapter>();
builder.Services.AddTransient<IPostAdapter, PostAdapter>();
builder.Services.AddTransient<ISoftwareAdapter, SoftwareAdapter>();
builder.Services.AddTransient<IRequestAdapter, RequestAdapter>();
builder.Services.AddTransient<IWorkerAdapter, WorkerAdapter>();
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<SmallSoftwareDbContext>();
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(2)),
signingCredentials: new SigningCredentials(AuthOptions.GetSymmetricSecurityKey(),
SecurityAlgorithms.HmacSha256)));
});
app.MapControllers();
app.Run();