Skip to content
Permalink
Browse files
Add more thorough check for CSP violations
  • Loading branch information
markelog committed Nov 7, 2013
1 parent c66a5e7 commit ee0d0e6
Show file tree
Hide file tree
Showing 5 changed files with 27 additions and 22 deletions.
@@ -0,0 +1,3 @@
<?php
file_put_contents("csp.log", "", LOCK_EX);
?>
@@ -0,0 +1,3 @@
<?php
file_put_contents("csp.log", "error", LOCK_EX);
?>
Empty file.
@@ -1,12 +1,7 @@
<?php
# Support: Firefox
header("X-Content-Security-Policy: default-src 'self';");

# Support: Webkit, Safari 5
# http://stackoverflow.com/questions/13663302/why-does-my-content-security-policy-work-everywhere-but-safari
header("X-WebKit-CSP: script-src " . $_SERVER["HTTP_HOST"] . " 'self'");

header("Content-Security-Policy: default-src 'self'");
# This test page checkes CSP only for browsers with "Content-Security-Policy" header support
# i.e. no old WebKit or old Firefox
header("Content-Security-Policy: default-src 'self'; report-uri csp-log.php");
?>
<!DOCTYPE html>
<html>
@@ -30,6 +30,24 @@ if ( jQuery.css ) {
});
}


// This test checkes CSP only for browsers with "Content-Security-Policy" header support
// i.e. no old WebKit or old Firefox
testIframeWithCallback( "Check CSP (https://developer.mozilla.org/en-US/docs/Security/CSP) restrictions",
"support/csp.php",
function( support ) {
expect( 2 );
deepEqual( jQuery.extend( {}, support ), computedSupport, "No violations of CSP polices" );

stop();

supportjQuery.get( "data/support/csp.log" ).done(function( data ) {

This comment has been minimized.

Copy link
@gibson042

gibson042 Nov 7, 2013

Member

IE<11 seems not to process this done callback. We might want to try making it an always and/or update supportjQuery from 1.9.1.

This comment has been minimized.

Copy link
@markelog

markelog Nov 7, 2013

Author Member

Yeah, i noticed, but didn't have an internet for couple of hours, it looks like IE requires full version of jQuery 1.9.1 to work properly in this case, so i will update it

equal( data, "", "No log request should be sent" );
supportjQuery.get( "data/support/csp-clean.php" ).done( start );
});
}
);

(function() {
var expected, version,
userAgent = window.navigator.userAgent;
@@ -175,17 +193,3 @@ if ( jQuery.css ) {
}

})();

// Support: Safari 5.1
// Shameless browser-sniff, but Safari 5.1 mishandles CSP
if ( !( typeof navigator !== "undefined" &&
(/ AppleWebKit\/\d.*? Version\/(\d+)/.exec(navigator.userAgent) || [])[1] < 6 ) ) {

testIframeWithCallback( "Check CSP (https://developer.mozilla.org/en-US/docs/Security/CSP) restrictions",
"support/csp.php",
function( support ) {
expect( 1 );
deepEqual( jQuery.extend( {}, support ), computedSupport, "No violations of CSP polices" );
}
);
}

0 comments on commit ee0d0e6

Please sign in to comment.