X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/5d96da3b67561285ce3806f46ec085d941949ee5..e774e1619c238e87942851b59461ae91f9256102:/config/initializers/sanitize.rb diff --git a/config/initializers/sanitize.rb b/config/initializers/sanitize.rb index 6f2e30852..a6cce19a9 100644 --- a/config/initializers/sanitize.rb +++ b/config/initializers/sanitize.rb @@ -1,8 +1,16 @@ -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| + env[:node].remove_class + env[:node].kwattr_remove("style", nil) + env[:node].add_class("table table-sm w-auto") if env[:node_name] == "table" -Sanitize::Config::OSM[:elements] -= %w[div style] -Sanitize::Config::OSM[:add_attributes] = { "a" => { "rel" => "nofollow noopener noreferrer" } } -Sanitize::Config::OSM[:remove_contents] = %w[script style] -Sanitize::Config::OSM[:transformers] = lambda do |env| - env[:node].add_class("table table-sm w-auto") if env[:node_name] == "table" -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 +)