Skip to content
This repository has been archived by the owner on Jun 29, 2022. It is now read-only.

Add support for Content-Security-Policy #367

Open
4 tasks
SamMousa opened this issue Jun 3, 2019 · 14 comments
Open
4 tasks

Add support for Content-Security-Policy #367

SamMousa opened this issue Jun 3, 2019 · 14 comments

Comments

@SamMousa
Copy link
Contributor

SamMousa commented Jun 3, 2019

We should add advanced support for Content-Security-Policy directives:

  • Sign inline scripts using a hash.
  • Only allow scripts that are included via registerJs, registerJsFile.
  • Research what else we should support (CSP has options for framing as well as font loading).
  • Support CSP for asset bundles
@samdark
Copy link
Member

samdark commented Jun 3, 2019

Any good reading on the subject?

@terabytesoftw
Copy link
Member

I think it could be done in two ways via .htaccess and via Html :: tag ('meta')

@SamMousa
Copy link
Contributor Author

SamMousa commented Jun 3, 2019

https://websec.be/blog/cspstrictdynamic/

@terabytesoftw as a PHP framework .htaccess is not part of our stack.
CSP can be set via Meta tag and via headers.

@samdark
Copy link
Member

samdark commented Jun 15, 2019

@SamMousa I've checked it. Seems what's proposed with hashes still require extensive fallback usage. While hashes could be automated, I'm not sure about fallback.

If it could be done in a universal way, I am all for implementing it as part of assets concept.

@terabytesoftw
Copy link
Member

in Yiisoft/Web in SapiEmiter.php in emit you can add:

$response = $response
    ->withHeader('Access-Control-Allow-Credentials', 'true')

and the remaining headers.

@samdark
Copy link
Member

samdark commented Aug 24, 2019

No, that is not the place to do it. SapiEmitter is just "echoing" what is contained in the response object as is. If you need extra headers, these should be added in a middleware.

@SamMousa
Copy link
Contributor Author

Since this is the view component, would it make sense to always use a meta tag?
(That way we can keep the whole implementation local to view rendering)

Regarding script src verification, we could use a random nonce for every request; this would be really simple to implement.

@SamMousa
Copy link
Contributor Author

@samdark
Copy link
Member

samdark commented Aug 24, 2019

Since this is the view component, would it make sense to always use a meta tag?
(That way we can keep the whole implementation local to view rendering)

OK.

Regarding script src verification, we could use a random nonce for every request; this would be really simple to implement.

Fine.

@samdark samdark transferred this issue from yiisoft/view Jun 7, 2021
@roxblnfk
Copy link
Member

roxblnfk commented Jun 7, 2021

We have the ForceSecureConnection middleware with CSP policy support

@samdark
Copy link
Member

samdark commented Jun 7, 2021

@roxblnfk that doesn't include external file hashes.

@roxblnfk
Copy link
Member

roxblnfk commented Jun 7, 2021

@roxblnfk that doesn't include external file hashes.

yes.
more precisely, you can define them there, but you will not be able to do this, because middleware is preconfigurable.

@SamMousa
Copy link
Contributor Author

SamMousa commented Jun 9, 2021

We have the ForceSecureConnection middleware with CSP policy support

To be honest, looking at the code in ForceSecureConnection, to me it seems like it is already taking on too much responsibility.

The class header Redirects insecure requests from HTTP to HTTPS, and adds headers necessary to enhance security policy. already hints at this.

Why not have a trivial RedirectToHTTPS middleware, that does exactly what it says and only that?

Furthermore, an HSTS header is added to normal HTTP requests, but that will always be ignored: https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Strict-Transport-Security

For me CSP is a subject totally unrelated to HTTPS redirects and HSTS headers...

Since the CSP support that would best fit the framework is a dynamically generated one, it makes more sense to have a middleware later in the chain that gathers (or receives) parts from application services (like the view).

Since at the end of the request we know which inline and external scripts we have etc we can then decide calculate the final CSP header.

@roxblnfk
Copy link
Member

roxblnfk commented Jun 9, 2021

We have the ForceSecureConnection middleware with CSP policy support

This is just notice, not solution.

The ForceSecureConnection middleware was created without considering this issue and only for general CSP rules like this.

If we will create a detailed solution with CSP, taking into account assets and so on, it will be cool. Then it will be possible to remove unnecessary responsibility from this middleware.

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants