Sha256: f36d67d5b40fcb31bab32fa7fc01529173936b34922001374bbeaa68197afa8d
Contents?: true
Size: 1.43 KB
Versions: 1
Compression:
Stored size: 1.43 KB
Contents
require 'sanitize' require 'with_deep_merge' class Govspeak::HtmlSanitizer include WithDeepMerge class ImageSourceWhitelister def initialize(allowed_image_hosts) @allowed_image_hosts = allowed_image_hosts end def call(sanitize_context) return unless sanitize_context[:node_name] == "img" node = sanitize_context[:node] image_uri = URI.parse(node['src']) unless image_uri.relative? || @allowed_image_hosts.include?(image_uri.host) node.unlink # the node isn't sanitary. Remove it from the document. end end end def initialize(dirty_html, options = {}) @dirty_html = dirty_html @allowed_image_hosts = options[:allowed_image_hosts] end def sanitize transformers = [] if @allowed_image_hosts && @allowed_image_hosts.any? transformers << ImageSourceWhitelister.new(@allowed_image_hosts) end Sanitize.clean(@dirty_html, sanitize_config.merge(transformers: transformers)) end def sanitize_without_images config = sanitize_config config[:elements].delete('img') Sanitize.clean(@dirty_html, config) end def sanitize_config deep_merge(Sanitize::Config::RELAXED, { attributes: { :all => Sanitize::Config::RELAXED[:attributes][:all] + [ "id", "class" ], "a" => Sanitize::Config::RELAXED[:attributes]["a"] + [ "rel" ], }, elements: Sanitize::Config::RELAXED[:elements] + [ "div", "span" ], }) end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
govspeak-3.2.0 | lib/govspeak/html_sanitizer.rb |