Sha256: 4c84afc2dffcbdea6dc21b2c7454e0e77e1b78b2f5627edd2db5daf7b42a5259

Contents?: true

Size: 990 Bytes

Versions: 5

Compression:

Stored size: 990 Bytes

Contents

=begin
    Copyright 2010-2015 Tasos Laskos <tasos.laskos@arachni-scanner.com>

    This file is part of the Arachni Framework project and is subject to
    redistribution and commercial restrictions. Please see the Arachni Framework
    web site for more information on licensing and terms of use.
=end

module Arachni
module Platform::Fingerprinters

# Identifies Rails resources.
#
# @author Tasos "Zapotek" Laskos <tasos.laskos@arachni-scanner.com>
# @version 0.1.1
class Rails < Platform::Fingerprinter

    IDs = %w(rails)

    def run
        headers.keys.each do |header|
            return update_platforms if header.start_with?( 'x-rails' )
        end

        IDs.each do |id|
            next if !server_or_powered_by_include? id

            return update_platforms
        end

        if cookies.include?( '_rails_admin_session' )
            update_platforms
        end
    end

    def update_platforms
        platforms << :ruby << :rack << :rails
    end

end

end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
arachni-1.3.2 components/fingerprinters/frameworks/rails.rb
arachni-1.3.1 components/fingerprinters/frameworks/rails.rb
arachni-1.3 components/fingerprinters/frameworks/rails.rb
arachni-1.2.1 components/fingerprinters/frameworks/rails.rb
arachni-1.2 components/fingerprinters/frameworks/rails.rb