X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/428f379eefd0d530ea79a892e6dc13751c274302..2f11b77309ee18aafb1bcce9dbe5bfc38a298bbb:/config/initializers/sanitize.rb diff --git a/config/initializers/sanitize.rb b/config/initializers/sanitize.rb index eb3039a13..c9d6a5dba 100644 --- a/config/initializers/sanitize.rb +++ b/config/initializers/sanitize.rb @@ -1,5 +1,28 @@ -Sanitize::Config::OSM = Sanitize::Config::RELAXED.dup +Sanitize::Config::OSM = Sanitize::Config.merge( + Sanitize::Config::RELAXED, + :elements => Sanitize::Config::RELAXED[:elements] - %w[div style], + :remove_contents => %w[script style], + :transformers => lambda do |env| + style = env[:node]["style"] || "" -Sanitize::Config::OSM[:elements] -= [ 'div', 'style' ] -Sanitize::Config::OSM[:add_attributes] = { 'a' => { 'rel' => 'nofollow' } } -Sanitize::Config::OSM[:remove_contents] = [ 'script', 'style' ] + env[:node].remove_class + env[:node].remove_attribute("style") + + env[:node].add_class("table table-sm w-auto") if env[:node_name] == "table" + + case style + when /\btext-align:\s+left\b/ + env[:node].add_class("text-start") + when /\btext-align:\s+center\b/ + env[:node].add_class("text-center") + when /\btext-align:\s+right\b/ + env[:node].add_class("text-end") + end + + if env[:node_name] == "a" + rel = env[:node]["rel"] || "" + + env[:node]["rel"] = rel.split.select { |r| r == "me" }.append("nofollow", "noopener", "noreferrer").sort.join(" ") + end + end +)