-
Notifications
You must be signed in to change notification settings - Fork 83
Why does HTTPSB allow all javascript in Chromium settings?!?
When HTTP Switchboard is installed and active, if you look at Chromium Settings/Privacy/Content settings/Javascript/Manage exceptions, you will notice two entries (created by HTTPSB):
http://* allow
https://* allow
Do not panic.
HTTPSB uses a different and more reliable mechanism than other blockers (at the time of writing) on the Chromium platform to enforce the blocking of javascript. There are two ways in which javascript must be blocked:
- External javascript
- Inline javascript
For external javascript, this is trivial with the Chromium platform using the webRequest API to prevent the downloading of javascript files. If the file is not downloaded, obviously the javascript content can not be executed.
For inline javascript however, it is a bit more complicated.
Usually javascript blockers on the Chromium platform use (or try to) the contentSettings API, but this has proven challenging as the calls to create/delete rules in order to allow/block javascript are not synchronous, meaning they take effect at some point in the future. This is problematic when it comes to allow/block inline javascript in a realtime manner. There used to be a long standing issue in HTTPSB related to this problem.
To complicate the matter further, whether javascript is blocked or allowed in HTTPSB may depend on the scope of the rules (ex.: "allow javascript from facebook.com
only when visiting https://www.facebook.com
"), in which case the built-in whitelist/blacklist mechanism in Chromium just doesn't work.
So HTTPSB had to find another way to block javascript, and this mechanism is the Content Security Policy directive to control whether javascript can run on any particular page. It is a very reliable mechanism and it fits perfectly HTTPSB model of selectively allowing/blocking javascript depending on the scope.
However the Content Security Policy directive works by assuming that when the directive is not present, javascript is allowed to run by default. Hence to enforce this definition, HTTPSB has to be sure that all javascript is allowed to run by default and to bypass any existing rules by the users which could interfere with the expected behavior of Content Security Policy directive usage.