2021-12-14 12:00:47 +01:00

75 lines
2.0 KiB
C#

using HackerNet.Application;
using HackerNet.Domain;
using HackerNet.Infrastructure.Repositories.Memory;
using HackerNet.Web.Filters;
var builder = WebApplication.CreateBuilder(args);
// Add services to the container.
var link = new Link("https://localhost:7050/", "Youhouuu");
var comment = new Comment(link.Id, "Wow!");
var linksRepository = new MemoryLinkRepository(link);
var commentsRepository = new MemoryCommentRepository(comment);
builder.Services.AddSingleton<ILinkRepository>(linksRepository);
builder.Services.AddSingleton<ICommentRepository>(commentsRepository);
builder.Services.AddSingleton<IReadStore>(new MemoryReadStore(linksRepository, commentsRepository));
builder.Services.AddSingleton<LinkService>();
builder.Services.AddControllersWithViews(o =>
{
o.Filters.Add<CustomExceptionFilter>();
});
var app = builder.Build();
// Configure the HTTP request pipeline.
if (!app.Environment.IsDevelopment())
{
app.UseExceptionHandler("/Home/Error");
// The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
app.UseHsts();
}
app.Use(async (ctx, next) =>
{
var logger = ctx.RequestServices.GetRequiredService<ILogger<Program>>();
logger.LogDebug(">>>>>>>>>>>>>> Début requête");
try
{
await next();
}
catch (Exception e)
{
// Envoi app insights ou autre
logger.LogError(e.Message);
throw e;
}
logger.LogDebug("<<<<<<<<<<<<<< Fin requête");
});
app.Use(async (ctx, next) =>
{
var logger = ctx.RequestServices.GetRequiredService<ILogger<Program>>();
logger.LogDebug(">>>>>>>>>>>>>> Début requête 2");
await next();
logger.LogDebug("<<<<<<<<<<<<<< Fin requête 2");
});
app.UseHttpsRedirection();
app.UseStaticFiles();
// app.UseStatusCodePages()
app.UseRouting();
// app.UseAuthentication();
app.UseAuthorization();
app.MapControllerRoute(
name: "default",
pattern: "{controller=Links}/{action=Index}/{id?}");
app.Run();