Class: Dependabot::Gradle::UpdateChecker::VersionFinder

Inherits:
Object
  • Object
show all
Defined in:
lib/dependabot/gradle/update_checker/version_finder.rb

Constant Summary collapse

GOOGLE_MAVEN_REPO =
"https://maven.google.com"
GRADLE_PLUGINS_REPO =
"https://plugins.gradle.org/m2"
TYPE_SUFFICES =
%w(jre android java).freeze

Instance Method Summary collapse

Constructor Details

#initialize(dependency:, dependency_files:, ignored_versions:, security_advisories:) ⇒ VersionFinder

Returns a new instance of VersionFinder.



18
19
20
21
22
23
24
# File 'lib/dependabot/gradle/update_checker/version_finder.rb', line 18

def initialize(dependency:, dependency_files:, ignored_versions:,
               security_advisories:)
  @dependency          = dependency
  @dependency_files    = dependency_files
  @ignored_versions    = ignored_versions
  @security_advisories = security_advisories
end

Instance Method Details

#latest_version_detailsObject



26
27
28
29
30
31
32
33
34
35
# File 'lib/dependabot/gradle/update_checker/version_finder.rb', line 26

def latest_version_details
  possible_versions = versions

  possible_versions = filter_prereleases(possible_versions)
  possible_versions = filter_date_based_versions(possible_versions)
  possible_versions = filter_version_types(possible_versions)
  possible_versions = filter_ignored_versions(possible_versions)

  possible_versions.last
end

#lowest_security_fix_version_detailsObject



37
38
39
40
41
42
43
44
45
46
47
48
# File 'lib/dependabot/gradle/update_checker/version_finder.rb', line 37

def lowest_security_fix_version_details
  possible_versions = versions

  possible_versions = filter_prereleases(possible_versions)
  possible_versions = filter_date_based_versions(possible_versions)
  possible_versions = filter_version_types(possible_versions)
  possible_versions = filter_ignored_versions(possible_versions)
  possible_versions = filter_vulnerable_versions(possible_versions)
  possible_versions = filter_lower_versions(possible_versions)

  possible_versions.first
end

#versionsObject



50
51
52
53
54
55
56
57
58
59
60
61
62
# File 'lib/dependabot/gradle/update_checker/version_finder.rb', line 50

def versions
  version_details =
    repository_urls.map do |url|
      next google_version_details if url == GOOGLE_MAVEN_REPO

      (url).css("versions > version").
        select { |node| version_class.correct?(node.content) }.
        map { |node| version_class.new(node.content) }.
        map { |version| { version: version, source_url: url } }
    end.flatten.compact

  version_details.sort_by { |details| details.fetch(:version) }
end