Sha256: bbf83c26330f04f8802206d481c125bfb7b02b8cd233fca737cb71ab7ff7de07

Contents?: true

Size: 1.86 KB

Versions: 14

Compression:

Stored size: 1.86 KB

Contents

# frozen_string_literal: true

require_relative "rails/html/sanitizer/version"

require "loofah"

require_relative "rails/html/scrubbers"
require_relative "rails/html/sanitizer"

module Rails
  Html = HTML # :nodoc:
end

module ActionView
  module Helpers
    module SanitizeHelper
      module ClassMethods
        # Replaces the allowed tags for the +sanitize+ helper.
        #
        #   class Application < Rails::Application
        #     config.action_view.sanitized_allowed_tags = 'table', 'tr', 'td'
        #   end
        #
        def sanitized_allowed_tags=(tags)
          sanitizer_vendor.safe_list_sanitizer.allowed_tags = tags
        end

        # Replaces the allowed HTML attributes for the +sanitize+ helper.
        #
        #   class Application < Rails::Application
        #     config.action_view.sanitized_allowed_attributes = ['onclick', 'longdesc']
        #   end
        #
        def sanitized_allowed_attributes=(attributes)
          sanitizer_vendor.safe_list_sanitizer.allowed_attributes = attributes
        end

        [:protocol_separator,
         :uri_attributes,
         :bad_tags,
         :allowed_css_properties,
         :allowed_css_keywords,
         :shorthand_css_properties,
         :allowed_protocols].each do |meth|
          meth_name = "sanitized_#{meth}"

          define_method(meth_name) { deprecate_option(meth_name) }
          define_method("#{meth_name}=") { |_| deprecate_option("#{meth_name}=") }
        end

        private
          def deprecate_option(name)
            ActiveSupport::Deprecation.warn "The #{name} option is deprecated " \
              "and has no effect. Until Rails 5 the old behavior can still be " \
              "installed. To do this add the `rails-deprecated-sanitizer` to " \
              "your Gemfile. Consult the Rails 4.2 upgrade guide for more information."
          end
      end
    end
  end
end

Version data entries

14 entries across 13 versions & 7 rubygems

Version Path
trusty-cms-7.0.9.1 vendor/bundle/ruby/3.1.0/gems/rails-html-sanitizer-1.6.0/lib/rails-html-sanitizer.rb
trusty-cms-7.0.9.1 vendor/bundle/ruby/3.3.0/gems/rails-html-sanitizer-1.6.2/lib/rails-html-sanitizer.rb
minato_ruby_api_client-0.2.2 vendor/bundle/ruby/3.2.0/gems/rails-html-sanitizer-1.6.0/lib/rails-html-sanitizer.rb
rails-html-sanitizer-1.6.2 lib/rails-html-sanitizer.rb
rails-html-sanitizer-1.6.1 lib/rails-html-sanitizer.rb
blacklight-spotlight-3.6.0.beta8 vendor/bundle/ruby/3.2.0/gems/rails-html-sanitizer-1.6.0/lib/rails-html-sanitizer.rb
cm-admin-1.5.22 vendor/bundle/ruby/3.3.0/gems/rails-html-sanitizer-1.6.0/lib/rails-html-sanitizer.rb
cm-admin-1.5.21 vendor/bundle/ruby/3.3.0/gems/rails-html-sanitizer-1.6.0/lib/rails-html-sanitizer.rb
cm-admin-1.5.20 vendor/bundle/ruby/3.3.0/gems/rails-html-sanitizer-1.6.0/lib/rails-html-sanitizer.rb
katalyst-govuk-formbuilder-1.9.2 vendor/bundle/ruby/3.3.0/gems/rails-html-sanitizer-1.6.0/lib/rails-html-sanitizer.rb
tinymce-rails-7.1.2 vendor/bundle/ruby/3.3.0/gems/rails-html-sanitizer-1.6.0/lib/rails-html-sanitizer.rb
rails-html-sanitizer-1.6.0 lib/rails-html-sanitizer.rb
rails-html-sanitizer-1.6.0.rc2 lib/rails-html-sanitizer.rb
rails-html-sanitizer-1.6.0.rc1 lib/rails-html-sanitizer.rb