Sha256: c006074b5b5892c711e03d88b97316c8c3b707243a1f85dc9bb643abd6fd94eb

Contents?: true

Size: 1.73 KB

Versions: 31

Compression:

Stored size: 1.73 KB

Contents

require 'date'
require 'brakeman/checks/base_check'

# Not used directly - base check for EOLRails and EOLRuby
class Brakeman::EOLCheck < Brakeman::BaseCheck
  def check_eol_version library, eol_dates
    version = case library
              when :rails
                tracker.config.rails_version
              when :ruby
                tracker.config.ruby_version
              else
                raise 'Implement using tracker.config.gem_version'
              end

    eol_dates.each do |(start_version, end_version), eol_date|
      if version_between? start_version, end_version, version
        case
        when Date.today >= eol_date
          warn_about_unsupported_version library, eol_date, version
        when (Date.today + 30) >= eol_date
          warn_about_soon_unsupported_version library, eol_date, version, :medium
        when (Date.today + 60) >= eol_date
          warn_about_soon_unsupported_version library, eol_date, version, :low
        end

        break
      end
    end
  end

  def warn_about_soon_unsupported_version library, eol_date, version, confidence
    warn warning_type: 'Unmaintained Dependency',
      warning_code: :"pending_eol_#{library}",
      message: msg("Support for ", msg_version(version, library.capitalize), " ends on #{eol_date}"),
      confidence: confidence,
      gem_info: gemfile_or_environment(library),
      :cwe_id => [1104]
  end

  def warn_about_unsupported_version library, eol_date, version
    warn warning_type: 'Unmaintained Dependency',
      warning_code: :"eol_#{library}",
      message: msg("Support for ", msg_version(version, library.capitalize), " ended on #{eol_date}"),
      confidence: :high,
      gem_info: gemfile_or_environment(library),
      :cwe_id => [1104]
  end
end

Version data entries

31 entries across 31 versions & 3 rubygems

Version Path
brakeman-7.0.0 lib/brakeman/checks/eol_check.rb
brakeman-lib-7.0.0 lib/brakeman/checks/eol_check.rb
brakeman-min-7.0.0 lib/brakeman/checks/eol_check.rb
brakeman-6.2.2 lib/brakeman/checks/eol_check.rb
brakeman-lib-6.2.2 lib/brakeman/checks/eol_check.rb
brakeman-min-6.2.2 lib/brakeman/checks/eol_check.rb
brakeman-6.2.2.rc1 lib/brakeman/checks/eol_check.rb
brakeman-min-6.2.1 lib/brakeman/checks/eol_check.rb
brakeman-lib-6.2.1 lib/brakeman/checks/eol_check.rb
brakeman-6.2.1 lib/brakeman/checks/eol_check.rb
brakeman-6.2.0 lib/brakeman/checks/eol_check.rb
brakeman-lib-6.2.0 lib/brakeman/checks/eol_check.rb
brakeman-min-6.2.0 lib/brakeman/checks/eol_check.rb
brakeman-6.1.2 lib/brakeman/checks/eol_check.rb
brakeman-lib-6.1.2 lib/brakeman/checks/eol_check.rb
brakeman-min-6.1.2 lib/brakeman/checks/eol_check.rb
brakeman-min-6.1.1 lib/brakeman/checks/eol_check.rb
brakeman-lib-6.1.1 lib/brakeman/checks/eol_check.rb
brakeman-6.1.1 lib/brakeman/checks/eol_check.rb
brakeman-6.1.0 lib/brakeman/checks/eol_check.rb