mirror of
https://git.teknik.io/Teknikode/Teknik.git
synced 2023-08-02 14:16:22 +02:00
40 lines
1.6 KiB
C#
40 lines
1.6 KiB
C#
using Microsoft.AspNetCore.Mvc;
|
|
using Microsoft.AspNetCore.Mvc.Filters;
|
|
|
|
namespace Teknik.IdentityServer.Security
|
|
{
|
|
public class SecurityHeadersAttribute : ActionFilterAttribute
|
|
{
|
|
public override void OnResultExecuting(ResultExecutingContext context)
|
|
{
|
|
var result = context.Result;
|
|
if (result is ViewResult)
|
|
{
|
|
if (!context.HttpContext.Response.Headers.ContainsKey("X-Content-Type-Options"))
|
|
{
|
|
context.HttpContext.Response.Headers.Add("X-Content-Type-Options", "nosniff");
|
|
}
|
|
if (!context.HttpContext.Response.Headers.ContainsKey("X-Frame-Options"))
|
|
{
|
|
context.HttpContext.Response.Headers.Add("X-Frame-Options", "SAMEORIGIN");
|
|
}
|
|
|
|
var csp = "default-src 'self';";
|
|
// an example if you need client images to be displayed from twitter
|
|
//var csp = "default-src 'self'; img-src 'self' https://pbs.twimg.com";
|
|
|
|
// once for standards compliant browsers
|
|
if (!context.HttpContext.Response.Headers.ContainsKey("Content-Security-Policy"))
|
|
{
|
|
context.HttpContext.Response.Headers.Add("Content-Security-Policy", csp);
|
|
}
|
|
// and once again for IE
|
|
if (!context.HttpContext.Response.Headers.ContainsKey("X-Content-Security-Policy"))
|
|
{
|
|
context.HttpContext.Response.Headers.Add("X-Content-Security-Policy", csp);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|