Blocked URI missing/empty in log entries

Created on 15 May 2014, almost 11 years ago
Updated 9 April 2023, almost 2 years ago

When I turn on CSP logging, I get reports similar to this one:

CSP: Directive style-src *.mydomain.com fonts.googleapis.com violated.
Blocked URI: .
Data: stdClass Object
(
[document-uri] => http://mydomain.com/admin/config/system/seckit
[referrer] => http://mydomain.com/admin/config/system/seckit
[violated-directive] => style-src *.mydomain.com fonts.googleapis.com
[original-policy] => default-src *.mydomain.com; script-src *.mydomain.com maps.googleapis.com; style-src *.mydomain.com fonts.googleapis.com; report-uri /admin/config/system/seckit/csp-report
[blocked-uri] =>
[source-file] => http://mydomain.com/sites/all/modules/jquery_update/replace/jquery/1.5/j...
[line-number] => 16
[column-number] => 17400
[status-code] => 200
)

Because the blocked URI value is empty, I can't tell what's triggering the violation. I've looked through the source of the page in question, and I think I've got the proper rules in place to whitelist approved third-party sources. However, I keep getting these reports.

πŸ› Bug report
Status

Closed: works as designed

Version

1.9

Component

Code

Created by

πŸ‡ΊπŸ‡ΈUnited States bsnav

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

  • πŸ‡ΊπŸ‡ΈUnited States brad.bulger

    I am seeing a bunch of entries saying the img-src directive was violated reporting blocked-uri as "data" - the literal word

    is that this same issue - that this is somehow what was in the request?

  • πŸ‡³πŸ‡ΏNew Zealand jweowu

    That sounds like https://stackoverflow.com/questions/18447970

    I.e. you want to add data: with the trailing colon as one of your permitted img-src values.

  • πŸ‡ΊπŸ‡ΈUnited States brad.bulger

    When the blocked-uri value is just "data" or "blob" - not "data:" - I don't know if that is supposed to be a hostname or if it is in fact the schema of that name. If blocked-uri should always be a URI - always have a schema - I guess that would tell me.

    This is information coming from the requester, is that correct? It's what's in the HTTP request from the client?

  • πŸ‡³πŸ‡ΏNew Zealand jweowu

    > This is information coming from the requester, is that correct? It's what's in the HTTP request from the client?

    Correct. The web site merely tells the user agent what the rules are, but it's the user agent which enforces the rules (and optionally reports any would-be violations that it suppressed). Drupal is then logging the content of the violation-report requests.

Production build 0.71.5 2024