Lorem ipsum dolor ...
' class SanitizeHtml URL_ELEMENTS_WITH_URL_ATTRIBUTE = { 'a' => :href, 'img' => :src }.freeze private_constant :URL_ELEMENTS_WITH_URL_ATTRIBUTE def initialize(value, env) @value = value @channel_url = env[:config].url end ## # - uses the {https://github.com/rgrove/sanitize sanitize gem} # - uses the config {https://github.com/rgrove/sanitize#sanitizeconfigrelaxed Sanitize::Config::RELAXED} # - adds rel="nofollow noopener noreferrer" to a elements # - adds target="_blank" to a elements # @return [String] def get Sanitize.fragment(@value, sanitize_config).to_s.split.join(' ') end private def sanitize_config Sanitize::Config.merge( Sanitize::Config::RELAXED, attributes: { all: %w[dir lang alt title translate] }, add_attributes: { 'a' => { 'rel' => 'nofollow noopener noreferrer', 'target' => '_blank' }, 'img' => { 'referrer-policy' => 'no-referrer' } }, transformers: [transform_urls_to_absolute_ones, wrap_img_in_a] ) end def transform_urls_to_absolute_ones lambda do |env| return unless URL_ELEMENTS_WITH_URL_ATTRIBUTE.key?(env[:node_name]) url_attribute = URL_ELEMENTS_WITH_URL_ATTRIBUTE[env[:node_name]] url = env[:node][url_attribute] return if URI(url).absolute? absolute_url = Html2rss::Utils.build_absolute_url_from_relative(url, @channel_url) env[:node][url_attribute] = absolute_url end end def wrap_img_in_a lambda do |env| return if env[:node_name] != 'img' img = env[:node] return if img.parent.name == 'a' anchor = Nokogiri::XML::Node.new('a', img) anchor[:href] = img[:src] anchor.add_child img.dup img.replace(anchor) end end end end end