Sha256: aac8e2f68947045442c8eea812f178d6010bfa4b72d1a1c45cb1bf3ef89cae4b

Contents?: true

Size: 1.14 KB

Versions: 14

Compression:

Stored size: 1.14 KB

Contents

module CMSScanner
  # Interesting Headers
  class Headers < InterestingFinding
    # @return [ Hash ] The headers
    def entries
      res = NS::Browser.get(url)
      return [] unless res && res.headers
      res.headers
    end

    # @return [ Array<String> ] The interesting headers detected
    def interesting_entries
      results = []

      entries.each do |header, value|
        next if known_headers.include?(header.downcase)

        results << "#{header}: #{[*value].join(', ')}"
      end
      results
    end

    # @return [ Array<String> ] Downcased known headers
    def known_headers
      %w(
        age accept-ranges cache-control content-encoding content-length content-type connection date
        etag expires keep-alive location last-modified link pragma set-cookie strict-transport-security
        transfer-encoding vary x-cache x-content-security-policy x-content-type-options
        x-frame-options x-language x-permitted-cross-domain-policies x-pingback x-varnish
        x-webkit-csp x-xss-protection
      )
    end

    def eql?(other)
      super(other) && interesting_entries == other.interesting_entries
    end
  end
end

Version data entries

14 entries across 14 versions & 1 rubygems

Version Path
cms_scanner-0.0.37.9 app/models/headers.rb
cms_scanner-0.0.37.8 app/models/headers.rb
cms_scanner-0.0.37.7 app/models/headers.rb
cms_scanner-0.0.37.6 app/models/headers.rb
cms_scanner-0.0.37.5 app/models/headers.rb
cms_scanner-0.0.37.4 app/models/headers.rb
cms_scanner-0.0.37.3 app/models/headers.rb
cms_scanner-0.0.37.2 app/models/headers.rb
cms_scanner-0.0.37.1 app/models/headers.rb
cms_scanner-0.0.37 app/models/headers.rb
cms_scanner-0.0.36 app/models/headers.rb
cms_scanner-0.0.35.1 app/models/headers.rb
cms_scanner-0.0.35 app/models/headers.rb
cms_scanner-0.0.34 app/models/headers.rb