diff options
Diffstat (limited to 'code/api/Program.cs')
| -rw-r--r-- | code/api/Program.cs | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/code/api/Program.cs b/code/api/Program.cs index e6281f7..5fde778 100644 --- a/code/api/Program.cs +++ b/code/api/Program.cs @@ -12,6 +12,7 @@ global using Microsoft.Extensions.Localization; global using I2R.Storage.Api.Statics; global using Microsoft.AspNetCore.Authorization; global using System.Security.Claims; +global using I2R.Storage.Api.Models; using Microsoft.AspNetCore.Authentication.Cookies; using Microsoft.AspNetCore.Localization; @@ -21,11 +22,13 @@ builder.Services.AddAuthentication(CookieAuthenticationDefaults.AuthenticationSc .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.AddAuthorization(o => { - o.AddPolicy("least_privileged", b => { b.RequireRole("least_privileged"); }); - o.AddPolicy("admin", b => { b.RequireRole("admin"); }); -}); builder.Services.AddLocalization(); builder.Services.AddRequestLocalization(o => { o.DefaultRequestCulture = new RequestCulture("en"); }); builder.Services.AddScoped<UserService>(); @@ -44,8 +47,8 @@ var app = builder.Build(); app.UseStaticFiles(); app.UseStatusCodePages(); app.UseRequestLocalization(); -app.UseAuthorization(); app.UseAuthentication(); +app.UseAuthorization(); app.MapRazorPages(); app.MapControllers(); app.Run();
\ No newline at end of file |
