Class: Dependabot::Dependency
- Inherits:
-
Object
- Object
- Dependabot::Dependency
- Extended by:
- T::Sig
- Defined in:
- lib/dependabot/dependency.rb
Instance Attribute Summary collapse
-
#attribution_directory ⇒ Object
Returns the value of attribute attribution_directory.
-
#attribution_selection_reason ⇒ Object
Returns the value of attribute attribution_selection_reason.
-
#attribution_source_group ⇒ Object
Returns the value of attribute attribution_source_group.
-
#attribution_timestamp ⇒ Object
Returns the value of attribute attribution_timestamp.
-
#directory ⇒ Object
Returns the value of attribute directory.
-
#metadata ⇒ Object
readonly
Returns the value of attribute metadata.
-
#name ⇒ Object
readonly
Returns the value of attribute name.
-
#package_manager ⇒ Object
readonly
Returns the value of attribute package_manager.
-
#previous_requirements ⇒ Object
readonly
Returns the value of attribute previous_requirements.
-
#previous_version ⇒ Object
readonly
Returns the value of attribute previous_version.
-
#requirements ⇒ Object
readonly
Returns the value of attribute requirements.
-
#subdependency_metadata ⇒ Object
readonly
Returns the value of attribute subdependency_metadata.
-
#version ⇒ Object
readonly
Returns the value of attribute version.
Class Method Summary collapse
- .display_name_builder_for_package_manager(package_manager) ⇒ Object
- .humanized_previous_version_builder_for_package_manager(package_manager) ⇒ Object
- .name_normaliser_for_package_manager(package_manager) ⇒ Object
- .production_check_for_package_manager(package_manager) ⇒ Object
- .register_display_name_builder(package_manager, name_builder) ⇒ Object
- .register_humanized_previous_version_builder(package_manager, builder) ⇒ Object
- .register_name_normaliser(package_manager, name_builder) ⇒ Object
- .register_production_check(package_manager, production_check) ⇒ Object
Instance Method Summary collapse
- #==(other) ⇒ Object
- #all_sources ⇒ Object
- #all_versions ⇒ Object
- #appears_in_lockfile? ⇒ Boolean
- #display_name ⇒ Object
- #docker_digest_from_reqs(requirements) ⇒ Object
- #eql?(other) ⇒ Boolean
- #hash ⇒ Object
- #humanized_previous_version ⇒ Object
- #humanized_version ⇒ Object
- #informational_only? ⇒ Boolean
-
#initialize(name:, requirements:, package_manager:, version: nil, previous_version: nil, previous_requirements: nil, directory: nil, subdependency_metadata: [], removed: false, metadata: {}) ⇒ Dependency
constructor
A new instance of Dependency.
- #new_ref ⇒ Object
- #numeric_version ⇒ Object
- #previous_ref ⇒ Object
- #production? ⇒ Boolean
- #ref_changed? ⇒ Boolean
- #removed? ⇒ Boolean
- #requirement_class ⇒ Object
- #requirements_changed? ⇒ Boolean
- #source_details(allowed_types: nil) ⇒ Object
- #source_type ⇒ Object
- #specific_requirements ⇒ Object
- #subdependency_production_check ⇒ Object
- #to_h ⇒ Object
- #top_level? ⇒ Boolean
- #version_class ⇒ Object
Constructor Details
#initialize(name:, requirements:, package_manager:, version: nil, previous_version: nil, previous_requirements: nil, directory: nil, subdependency_metadata: [], removed: false, metadata: {}) ⇒ Dependency
Returns a new instance of Dependency.
144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 |
# File 'lib/dependabot/dependency.rb', line 144 def initialize( name:, requirements:, package_manager:, version: nil, previous_version: nil, previous_requirements: nil, directory: nil, subdependency_metadata: [], removed: false, metadata: {} ) @name = name @version = T.let( case version when Dependabot::Version then version.to_s when String then version end, T.nilable(String) ) @version = nil if @version == "" @requirements = T.let( requirements.map { |req| DependencyRequirement.create(req) }, T::Array[Dependabot::DependencyRequirement] ) @previous_version = previous_version @previous_version = nil if @previous_version == "" @previous_requirements = T.let( previous_requirements&.map { |req| DependencyRequirement.create(req) }, T.nilable(T::Array[Dependabot::DependencyRequirement]) ) @package_manager = package_manager @directory = directory unless top_level? || == [] @subdependency_metadata = T.let( &.map { |h| symbolize_keys(h) }, T.nilable(T::Array[T::Hash[Symbol, T.untyped]]) ) end @removed = removed @metadata = T.let(symbolize_keys( || {}), T::Hash[Symbol, T.untyped]) check_values end |
Instance Attribute Details
#attribution_directory ⇒ Object
Returns the value of attribute attribution_directory.
123 124 125 |
# File 'lib/dependabot/dependency.rb', line 123 def attribution_directory @attribution_directory end |
#attribution_selection_reason ⇒ Object
Returns the value of attribute attribution_selection_reason.
120 121 122 |
# File 'lib/dependabot/dependency.rb', line 120 def attribution_selection_reason @attribution_selection_reason end |
#attribution_source_group ⇒ Object
Returns the value of attribute attribution_source_group.
117 118 119 |
# File 'lib/dependabot/dependency.rb', line 117 def attribution_source_group @attribution_source_group end |
#attribution_timestamp ⇒ Object
Returns the value of attribute attribution_timestamp.
126 127 128 |
# File 'lib/dependabot/dependency.rb', line 126 def @attribution_timestamp end |
#directory ⇒ Object
Returns the value of attribute directory.
107 108 109 |
# File 'lib/dependabot/dependency.rb', line 107 def directory @directory end |
#metadata ⇒ Object (readonly)
Returns the value of attribute metadata.
113 114 115 |
# File 'lib/dependabot/dependency.rb', line 113 def @metadata end |
#name ⇒ Object (readonly)
Returns the value of attribute name.
89 90 91 |
# File 'lib/dependabot/dependency.rb', line 89 def name @name end |
#package_manager ⇒ Object (readonly)
Returns the value of attribute package_manager.
98 99 100 |
# File 'lib/dependabot/dependency.rb', line 98 def package_manager @package_manager end |
#previous_requirements ⇒ Object (readonly)
Returns the value of attribute previous_requirements.
104 105 106 |
# File 'lib/dependabot/dependency.rb', line 104 def previous_requirements @previous_requirements end |
#previous_version ⇒ Object (readonly)
Returns the value of attribute previous_version.
101 102 103 |
# File 'lib/dependabot/dependency.rb', line 101 def previous_version @previous_version end |
#requirements ⇒ Object (readonly)
Returns the value of attribute requirements.
95 96 97 |
# File 'lib/dependabot/dependency.rb', line 95 def requirements @requirements end |
#subdependency_metadata ⇒ Object (readonly)
Returns the value of attribute subdependency_metadata.
110 111 112 |
# File 'lib/dependabot/dependency.rb', line 110 def @subdependency_metadata end |
#version ⇒ Object (readonly)
Returns the value of attribute version.
92 93 94 |
# File 'lib/dependabot/dependency.rb', line 92 def version @version end |
Class Method Details
.display_name_builder_for_package_manager(package_manager) ⇒ Object
45 46 47 |
# File 'lib/dependabot/dependency.rb', line 45 def self.display_name_builder_for_package_manager(package_manager) @display_name_builders[package_manager] end |
.humanized_previous_version_builder_for_package_manager(package_manager) ⇒ Object
74 75 76 |
# File 'lib/dependabot/dependency.rb', line 74 def self.humanized_previous_version_builder_for_package_manager(package_manager) @humanized_previous_version_builders[package_manager] end |
.name_normaliser_for_package_manager(package_manager) ⇒ Object
55 56 57 |
# File 'lib/dependabot/dependency.rb', line 55 def self.name_normaliser_for_package_manager(package_manager) @name_normalisers[package_manager] || ->(name) { name } end |
.production_check_for_package_manager(package_manager) ⇒ Object
26 27 28 29 30 31 |
# File 'lib/dependabot/dependency.rb', line 26 def self.production_check_for_package_manager(package_manager) production_check = @production_checks[package_manager] return production_check if production_check raise "Unsupported package_manager #{package_manager}" end |
.register_display_name_builder(package_manager, name_builder) ⇒ Object
50 51 52 |
# File 'lib/dependabot/dependency.rb', line 50 def self.register_display_name_builder(package_manager, name_builder) @display_name_builders[package_manager] = name_builder end |
.register_humanized_previous_version_builder(package_manager, builder) ⇒ Object
84 85 86 |
# File 'lib/dependabot/dependency.rb', line 84 def self.register_humanized_previous_version_builder(package_manager, builder) @humanized_previous_version_builders[package_manager] = builder end |
.register_name_normaliser(package_manager, name_builder) ⇒ Object
65 66 67 |
# File 'lib/dependabot/dependency.rb', line 65 def self.register_name_normaliser(package_manager, name_builder) @name_normalisers[package_manager] = name_builder end |
.register_production_check(package_manager, production_check) ⇒ Object
40 41 42 |
# File 'lib/dependabot/dependency.rb', line 40 def self.register_production_check(package_manager, production_check) @production_checks[package_manager] = production_check end |
Instance Method Details
#==(other) ⇒ Object
326 327 328 329 330 331 332 333 |
# File 'lib/dependabot/dependency.rb', line 326 def ==(other) case other when Dependency to_h == other.to_h else false end end |
#all_sources ⇒ Object
388 389 390 391 392 393 394 395 396 |
# File 'lib/dependabot/dependency.rb', line 388 def all_sources if top_level? requirements.map { |requirement| requirement.fetch(:source) } elsif T.must().filter_map { |data| data[:source] } else [] end end |
#all_versions ⇒ Object
310 311 312 313 314 315 |
# File 'lib/dependabot/dependency.rb', line 310 def all_versions all_versions = [:all_versions] return [version].compact unless all_versions all_versions.filter_map(&:version) end |
#appears_in_lockfile? ⇒ Boolean
222 223 224 |
# File 'lib/dependabot/dependency.rb', line 222 def appears_in_lockfile? !!(previous_version || (version && previous_requirements.nil?)) end |
#display_name ⇒ Object
243 244 245 246 247 248 249 |
# File 'lib/dependabot/dependency.rb', line 243 def display_name display_name_builder = self.class.display_name_builder_for_package_manager(package_manager) return name unless display_name_builder display_name_builder.call(name) end |
#docker_digest_from_reqs(requirements) ⇒ Object
278 279 280 281 282 |
# File 'lib/dependabot/dependency.rb', line 278 def docker_digest_from_reqs(requirements) requirements .filter_map { |r| r.dig(:source, "digest") || r.dig(:source, :digest) } .first end |
#eql?(other) ⇒ Boolean
341 342 343 |
# File 'lib/dependabot/dependency.rb', line 341 def eql?(other) self == other end |
#hash ⇒ Object
336 337 338 |
# File 'lib/dependabot/dependency.rb', line 336 def hash to_h.hash end |
#humanized_previous_version ⇒ Object
252 253 254 255 256 257 |
# File 'lib/dependabot/dependency.rb', line 252 def humanized_previous_version custom_version = custom_humanized_previous_version return custom_version if custom_version default_humanized_previous_version end |
#humanized_version ⇒ Object
260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 |
# File 'lib/dependabot/dependency.rb', line 260 def humanized_version return "removed" if removed? return nil if version.nil? if T.must(version).match?(/^[0-9a-f]{40}/) return new_ref if ref_changed? && new_ref "`#{T.must(version)[0..6]}`" elsif version == previous_version && package_manager == "docker" digest = docker_digest_from_reqs(requirements) "`#{T.must(T.must(digest).split(':').last)[0..6]}`" else version end end |
#informational_only? ⇒ Boolean
321 322 323 |
# File 'lib/dependabot/dependency.rb', line 321 def informational_only? [:information_only] end |
#new_ref ⇒ Object
295 296 297 298 299 300 |
# File 'lib/dependabot/dependency.rb', line 295 def new_ref new_refs = requirements.filter_map do |r| r.dig(:source, "ref") || r.dig(:source, :ref) end.uniq new_refs.first if new_refs.one? end |
#numeric_version ⇒ Object
200 201 202 203 204 |
# File 'lib/dependabot/dependency.rb', line 200 def numeric_version return unless version && version_class.correct?(version) @numeric_version ||= T.let(version_class.new(T.must(version)), T.nilable(Dependabot::Version)) end |
#previous_ref ⇒ Object
285 286 287 288 289 290 291 292 |
# File 'lib/dependabot/dependency.rb', line 285 def previous_ref return nil if previous_requirements.nil? previous_refs = T.must(previous_requirements).filter_map do |r| r.dig(:source, "ref") || r.dig(:source, :ref) end.uniq previous_refs.first if previous_refs.one? end |
#production? ⇒ Boolean
227 228 229 230 231 232 233 234 235 |
# File 'lib/dependabot/dependency.rb', line 227 def production? return subdependency_production_check unless top_level? groups = requirements.flat_map { |r| r.fetch(:groups).map(&:to_s) } self.class .production_check_for_package_manager(package_manager) .call(groups) end |
#ref_changed? ⇒ Boolean
303 304 305 |
# File 'lib/dependabot/dependency.rb', line 303 def ref_changed? previous_ref != new_ref end |
#removed? ⇒ Boolean
195 196 197 |
# File 'lib/dependabot/dependency.rb', line 195 def removed? @removed end |
#requirement_class ⇒ Object
351 352 353 |
# File 'lib/dependabot/dependency.rb', line 351 def requirement_class Utils.requirement_class_for_package_manager(package_manager) end |
#requirements_changed? ⇒ Boolean
399 400 401 |
# File 'lib/dependabot/dependency.rb', line 399 def requirements_changed? (requirements - T.must(previous_requirements)).any? end |
#source_details(allowed_types: nil) ⇒ Object
366 367 368 369 370 371 372 373 374 375 376 377 |
# File 'lib/dependabot/dependency.rb', line 366 def source_details(allowed_types: nil) sources = all_sources.uniq.compact sources.select! { |source| allowed_types.include?(source[:type].to_s) } if allowed_types git = allowed_types == ["git"] if (git && sources.map { |s| s[:url] }.uniq.count > 1) || (!git && sources.count > 1) raise "Multiple sources! #{sources.join(', ')}" end sources.first end |
#source_type ⇒ Object
380 381 382 383 384 385 |
# File 'lib/dependabot/dependency.rb', line 380 def source_type details = source_details return "default" if details.nil? details[:type] || details.fetch("type") end |
#specific_requirements ⇒ Object
346 347 348 |
# File 'lib/dependabot/dependency.rb', line 346 def specific_requirements requirements.select { |r| requirement_class.new(r.requirement).specific? } end |
#subdependency_production_check ⇒ Object
238 239 240 |
# File 'lib/dependabot/dependency.rb', line 238 def subdependency_production_check !&.all? { |h| h[:production] == false } end |
#to_h ⇒ Object
207 208 209 210 211 212 213 214 215 216 217 218 219 |
# File 'lib/dependabot/dependency.rb', line 207 def to_h { "name" => name, "version" => version, "requirements" => requirements, "previous_version" => previous_version, "previous_requirements" => previous_requirements, "directory" => directory, "package_manager" => package_manager, "subdependency_metadata" => , "removed" => removed? || nil }.compact end |
#top_level? ⇒ Boolean
190 191 192 |
# File 'lib/dependabot/dependency.rb', line 190 def top_level? requirements.any? end |
#version_class ⇒ Object
356 357 358 |
# File 'lib/dependabot/dependency.rb', line 356 def version_class Utils.version_class_for_package_manager(package_manager) end |