aboutsummaryrefslogtreecommitdiffstats
path: root/code/api/Program.cs
blob: f093a4588bf8512b2cded81307337a988648e15b (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
global using Microsoft.AspNetCore.Mvc;
global using Microsoft.Extensions.Localization;
global using Microsoft.AspNetCore.Authorization;
global using Microsoft.AspNetCore.Mvc.RazorPages;
global using Microsoft.EntityFrameworkCore;
global using System.Security.Claims;
global using System.Text.Json;
global using System.ComponentModel.DataAnnotations;
global using MR.AspNetCore.Pagination;
global using MR.EntityFrameworkCore.KeysetPagination;
global using IOL.Helpers;
global using Quality.Storage.Api.Database;
global using Quality.Storage.Api.Database.Models;
global using Quality.Storage.Api.Enums;
global using Quality.Storage.Api.Models;
global using Quality.Storage.Api.Statics;
global using Quality.Storage.Api.Services.Admin;
global using Quality.Storage.Api.Services.System;
global using Quality.Storage.Api.Utilities;
global using Quality.Storage.Api.Resources;
using System.Globalization;
using Microsoft.AspNetCore.Authentication.Cookies;
using Microsoft.AspNetCore.Localization;
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.Options;
using Quality.Storage.Api.Utilities;

var builder = WebApplication.CreateBuilder(args);

builder.Services.AddAuthentication(CookieAuthenticationDefaults.AuthenticationScheme)
	   .AddCookie(o => {
		   o.Cookie.Name = "storage_session";
		   o.Cookie.HttpOnly = true;
		   o.SlidingExpiration = true;
		   o.Events.OnRedirectToAccessDenied =
				   o.Events.OnRedirectToLogin = c => {
					   c.Response.StatusCode = StatusCodes.Status401Unauthorized;
					   return Task.FromResult<object>(null);
				   };
	   });
builder.Services.AddLocalization();
builder.Services.AddRequestLocalization(o => {
	o.DefaultRequestCulture = new RequestCulture("en");
	var cultures = new CultureInfo[] {
			new("en"),
			new("no")
	};
	o.SupportedCultures = cultures;
	o.SupportedUICultures = cultures;
});
builder.Services.AddScoped<UserService>();
builder.Services.AddScoped<StorageService>();
builder.Services.AddScoped<ShareService>();
builder.Services.AddScoped<DefaultResourceService>();
builder.Services.AddDbContext<AppDatabase>(o => {
	o.UseNpgsql(builder.Configuration.GetAppDbConnectionString(),
				b => {
					b.UseQuerySplittingBehavior(QuerySplittingBehavior.SplitQuery);
					b.EnableRetryOnFailure(3);
				});
	o.UseSnakeCaseNamingConvention();
});
builder.Services.AddPagination();
builder.Services.AddRazorPages().AddRazorRuntimeCompilation();
builder.Services.AddControllers();

var app = builder.Build();

app.UseStaticFiles();
app.UseStatusCodePages();
app.UseAuthentication();
app.UseAuthorization();
app.MapRazorPages();
app.MapControllers();
app.UseRequestLocalization(app.Services.GetService<IOptions<RequestLocalizationOptions>>().Value);
app.Run();