-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathAuthenticationExceptionFilterAttribute.cs
More file actions
34 lines (32 loc) · 1.27 KB
/
AuthenticationExceptionFilterAttribute.cs
File metadata and controls
34 lines (32 loc) · 1.27 KB
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
using System.Diagnostics.CodeAnalysis;
using System.Net;
using System.Net.Http;
using System.Security.Authentication;
using System.Web.Http;
using System.Web.Http.Filters;
namespace MyWebsite
{
[ExcludeFromCodeCoverage]
public class AuthenticationExceptionFilterAttribute : ExceptionFilterAttribute
{
public override void OnException(HttpActionExecutedContext actionExecutedContext)
{
if (actionExecutedContext.Exception is AuthenticationException)
{
actionExecutedContext.Response = GetResponse(HttpStatusCode.Unauthorized, actionExecutedContext.Exception.Message);
} else if (actionExecutedContext.Exception is AuthorizationException)
{
actionExecutedContext.Response = GetResponse(HttpStatusCode.Forbidden, actionExecutedContext.Exception.Message);
}
}
private HttpResponseMessage GetResponse(HttpStatusCode status, string message)
{
return new HttpResponseMessage
{
StatusCode = status,
Content = new ObjectContent(typeof(ErrorResponse),
new ErrorResponse {ErrorMessage = message}, GlobalConfiguration.Configuration.Formatters.JsonFormatter)
};
}
}
}