Sha256: 039dbf7e53ffa299a36da9e8b6e9c9835b83751c576913d0d88454a45380d1ae
Contents?: true
Size: 1.74 KB
Versions: 3
Compression:
Stored size: 1.74 KB
Contents
require 'brakeman/checks/base_check' #Check calls to +render()+ for dangerous values class Brakeman::CheckRender < Brakeman::BaseCheck Brakeman::Checks.add self @description = "Finds calls to render that might allow file access" def run_check tracker.find_call(:target => nil, :method => :render).each do |result| process_render result end end def process_render result return unless node_type? result[:call], :render case result[:call].render_type when :partial, :template, :action, :file check_for_dynamic_path result when :inline when :js when :json when :text when :update when :xml end end #Check if path to action or file is determined dynamically def check_for_dynamic_path result view = result[:call][2] if sexp? view and not duplicate? result add_result result if input = has_immediate_user_input?(view) confidence = CONFIDENCE[:high] elsif input = include_user_input?(view) if node_type? view, :string_interp, :dstr confidence = CONFIDENCE[:med] else confidence = CONFIDENCE[:low] end else return end message = "Render path contains " case input.type when :params message << "parameter value" when :cookies message << "cookie value" when :request message << "request value" when :model #Skip models return else message << "user input value" end warn :result => result, :warning_type => "Dynamic Render Path", :warning_code => :dynamic_render_path, :message => message, :user_input => input.match, :confidence => confidence end end end
Version data entries
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
brakeman-1.9.5 | lib/brakeman/checks/check_render.rb |
brakeman-1.9.4 | lib/brakeman/checks/check_render.rb |
brakeman-1.9.3 | lib/brakeman/checks/check_render.rb |