Sha256: 88a721db5b90218be13b87bf2814ca32b1d0f38a8612efa0fe22b9e3e17e0792

Contents?: true

Size: 1.01 KB

Versions: 72

Compression:

Stored size: 1.01 KB

Contents

require 'brakeman/checks/base_check'

class Brakeman::CheckPermitAttributes < Brakeman::BaseCheck
  Brakeman::Checks.add self

  @description = "Warn on potentially dangerous attributes whitelisted via permit"

  SUSPICIOUS_KEYS = {
    admin: :high,
    account_id: :high,
    role: :medium,
    banned: :medium,
  }

  def run_check
    tracker.find_call(:method => :permit).each do |result|
      check_permit result
    end
  end

  def check_permit result
    return unless original? result

    call = result[:call]

    call.each_arg do |arg|
      if symbol? arg
        if SUSPICIOUS_KEYS.key? arg.value
          warn_on_permit_key result, arg
        end
      end
    end
  end

  def warn_on_permit_key result, key, confidence = nil
    warn :result => result,
      :warning_type => "Mass Assignment",
      :warning_code => :dangerous_permit_key,
      :message => "Potentially dangerous key allowed for mass assignment",
      :confidence => (confidence || SUSPICIOUS_KEYS[key.value]),
      :user_input => key
  end
end

Version data entries

72 entries across 58 versions & 4 rubygems

Version Path
brakeman-4.8.2 lib/brakeman/checks/check_permit_attributes.rb
brakeman-lib-4.8.2 lib/brakeman/checks/check_permit_attributes.rb
brakeman-min-4.8.2 lib/brakeman/checks/check_permit_attributes.rb
brakeman-4.8.1 lib/brakeman/checks/check_permit_attributes.rb
brakeman-lib-4.8.1 lib/brakeman/checks/check_permit_attributes.rb
brakeman-min-4.8.1 lib/brakeman/checks/check_permit_attributes.rb
brakeman-4.8.0 lib/brakeman/checks/check_permit_attributes.rb
brakeman-lib-4.8.0 lib/brakeman/checks/check_permit_attributes.rb
brakeman-min-4.8.0 lib/brakeman/checks/check_permit_attributes.rb
zuora_connect_ui-0.10.0 vendor/ruby/2.6.0/gems/brakeman-4.7.0/lib/brakeman/checks/check_permit_attributes.rb
zuora_connect_ui-0.10.0 vendor/ruby/2.6.0/gems/brakeman-4.7.1/lib/brakeman/checks/check_permit_attributes.rb
zuora_connect_ui-0.10.0 vendor/ruby/2.6.0/gems/brakeman-4.6.1/lib/brakeman/checks/check_permit_attributes.rb
zuora_connect_ui-0.10.0 vendor/ruby/2.6.0/gems/brakeman-4.7.2/lib/brakeman/checks/check_permit_attributes.rb
zuora_connect_ui-0.10.0 vendor/ruby/2.6.0/gems/brakeman-4.5.1/lib/brakeman/checks/check_permit_attributes.rb
brakeman-4.7.2 lib/brakeman/checks/check_permit_attributes.rb
brakeman-lib-4.7.2 lib/brakeman/checks/check_permit_attributes.rb
brakeman-min-4.7.2 lib/brakeman/checks/check_permit_attributes.rb
zuora_connect_ui-0.9.2 vendor/ruby/2.6.0/gems/brakeman-4.6.1/lib/brakeman/checks/check_permit_attributes.rb
zuora_connect_ui-0.9.2 vendor/ruby/2.6.0/gems/brakeman-4.5.1/lib/brakeman/checks/check_permit_attributes.rb
zuora_connect_ui-0.9.2 vendor/ruby/2.6.0/gems/brakeman-4.7.0/lib/brakeman/checks/check_permit_attributes.rb