Skip to content

Commit

Permalink
escape semicolons by replacing them with spaces
Browse files Browse the repository at this point in the history
See #418
  • Loading branch information
oreoshake committed Jan 21, 2020
1 parent 2068ba7 commit 3c4b86e
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 3 deletions.
11 changes: 8 additions & 3 deletions lib/secure_headers/headers/content_security_policy.rb
Original file line number Diff line number Diff line change
Expand Up @@ -103,10 +103,15 @@ def build_media_type_list_directive(directive)
# Returns a string representing a directive.
def build_source_list_directive(directive)
source_list = @config.directive_value(directive)

if source_list != OPT_OUT && source_list && source_list.any?
normalized_source_list = minify_source_list(directive, source_list)
[symbol_to_hyphen_case(directive), normalized_source_list].join(" ")
minified_source_list = minify_source_list(directive, source_list).join(" ")

if minified_source_list.include?(";")
Kernel.warn("#{directive} contains a ; in '#{minified_source_list}' which will raise an error in future versions. It has been replaced with a blank space.")
end

escaped_source_list = minified_source_list.gsub(";", " ")
[symbol_to_hyphen_case(directive), escaped_source_list].join(" ").strip
end
end

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,11 @@ module SecureHeaders
expect(ContentSecurityPolicy.new.value).to eq("default-src https:; form-action 'self'; img-src https: data: 'self'; object-src 'none'; script-src https:; style-src 'self' 'unsafe-inline' https:")
end

it "deprecates and escapes semicolons in directive source lists" do
expect(Kernel).to receive(:warn).with("frame_ancestors contains a ; in 'google.com;script-src *;.;' which will raise an error in future versions. It has been replaced with a blank space.")
expect(ContentSecurityPolicy.new(frame_ancestors: %w(https://google.com;script-src https://*;.;)).value).to eq("frame-ancestors google.com script-src * .")
end

it "discards 'none' values if any other source expressions are present" do
csp = ContentSecurityPolicy.new(default_opts.merge(child_src: %w('self' 'none')))
expect(csp.value).not_to include("'none'")
Expand Down

0 comments on commit 3c4b86e

Please sign in to comment.