add exception filter when user not connected
This commit is contained in:
parent
f4c564748a
commit
51d66eafca
@ -34,11 +34,6 @@ namespace Website.Controllers
|
|||||||
return View(new ShowLinkViewModel(link, new CommentLinkCommand(id), comments));
|
return View(new ShowLinkViewModel(link, new CommentLinkCommand(id), comments));
|
||||||
}
|
}
|
||||||
|
|
||||||
public IActionResult Create()
|
|
||||||
{
|
|
||||||
return View(new AddLinkCommand());
|
|
||||||
}
|
|
||||||
|
|
||||||
[HttpPost("{controller}/{id:guid}/vote")]
|
[HttpPost("{controller}/{id:guid}/vote")]
|
||||||
[ValidateAntiForgeryToken]
|
[ValidateAntiForgeryToken]
|
||||||
public async Task<IActionResult> Vote(Guid id, string url, VoteType type, string redirectTo)
|
public async Task<IActionResult> Vote(Guid id, string url, VoteType type, string redirectTo)
|
||||||
@ -49,8 +44,14 @@ namespace Website.Controllers
|
|||||||
return Redirect(redirectTo);
|
return Redirect(redirectTo);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public IActionResult Create()
|
||||||
|
{
|
||||||
|
return View(new AddLinkCommand());
|
||||||
|
}
|
||||||
|
|
||||||
[HttpPost]
|
[HttpPost]
|
||||||
[ValidateAntiForgeryToken]
|
[ValidateAntiForgeryToken]
|
||||||
|
|
||||||
public async Task<IActionResult> Create(AddLinkCommand command)
|
public async Task<IActionResult> Create(AddLinkCommand command)
|
||||||
{
|
{
|
||||||
if (!ModelState.IsValid)
|
if (!ModelState.IsValid)
|
||||||
|
|||||||
16
Apps/Website/CustomExceptionFilter.cs
Normal file
16
Apps/Website/CustomExceptionFilter.cs
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
using Microsoft.AspNetCore.Mvc;
|
||||||
|
using Microsoft.AspNetCore.Mvc.Filters;
|
||||||
|
|
||||||
|
namespace Website
|
||||||
|
{
|
||||||
|
public sealed class CustomExceptionFilter : IExceptionFilter
|
||||||
|
{
|
||||||
|
public void OnException(ExceptionContext context)
|
||||||
|
{
|
||||||
|
if (context.Exception is UserNotConnected)
|
||||||
|
{
|
||||||
|
context.Result = new UnauthorizedResult();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -19,7 +19,14 @@ namespace Website
|
|||||||
|
|
||||||
public Guid GetCurrentUserId()
|
public Guid GetCurrentUserId()
|
||||||
{
|
{
|
||||||
return Guid.Parse(_userManager.GetUserId(_httpContextAccessor.HttpContext.User));
|
var uid = _userManager.GetUserId(_httpContextAccessor.HttpContext.User);
|
||||||
|
|
||||||
|
if (!Guid.TryParse(uid, out Guid result))
|
||||||
|
{
|
||||||
|
throw new UserNotConnected();
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -58,6 +58,7 @@ namespace Website
|
|||||||
|
|
||||||
services.AddControllersWithViews(o =>
|
services.AddControllersWithViews(o =>
|
||||||
{
|
{
|
||||||
|
o.Filters.Add<CustomExceptionFilter>();
|
||||||
o.Filters.Add(new AuthorizeFilter()); // Nécessite l'authentification par défaut
|
o.Filters.Add(new AuthorizeFilter()); // Nécessite l'authentification par défaut
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -82,6 +83,19 @@ namespace Website
|
|||||||
|
|
||||||
app.UseRouting();
|
app.UseRouting();
|
||||||
|
|
||||||
|
// Permet de rediriger selon les codes d'erreurs retournés, notamment par notre CustomExceptionFilter
|
||||||
|
app.UseStatusCodePages(context =>
|
||||||
|
{
|
||||||
|
var request = context.HttpContext.Request;
|
||||||
|
var response = context.HttpContext.Response;
|
||||||
|
if (response.StatusCode == (int)System.Net.HttpStatusCode.Unauthorized)
|
||||||
|
{
|
||||||
|
response.Redirect("/accounts/login");
|
||||||
|
}
|
||||||
|
|
||||||
|
return System.Threading.Tasks.Task.CompletedTask;
|
||||||
|
});
|
||||||
|
|
||||||
app.UseAuthentication();
|
app.UseAuthentication();
|
||||||
app.UseAuthorization();
|
app.UseAuthorization();
|
||||||
|
|
||||||
|
|||||||
12
Apps/Website/UserNotConnected.cs
Normal file
12
Apps/Website/UserNotConnected.cs
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
using System;
|
||||||
|
|
||||||
|
namespace Website
|
||||||
|
{
|
||||||
|
public sealed class UserNotConnected : Exception
|
||||||
|
{
|
||||||
|
public UserNotConnected() : base("User not connected!")
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
x
Reference in New Issue
Block a user