Sha256: 1c28672c1f4ff34ab6ddb0466be37fca949279ee5bd54ba180fba361219429ec

Contents?: true

Size: 1.76 KB

Versions: 22

Compression:

Stored size: 1.76 KB

Contents

# frozen_string_literal: true

require "excon"
require "dependabot/metadata_finders/base"
require "dependabot/shared_helpers"

module Dependabot
  module MetadataFinders
    module Rust
      class Cargo < Dependabot::MetadataFinders::Base
        SOURCE_KEYS = %w(repository homepage documentation).freeze

        private

        def look_up_source
          case new_source_type
          when "default" then find_source_from_crates_listing
          when "git" then find_source_from_git_url
          else raise "Unexpected source type: #{new_source_type}"
          end
        end

        def new_source_type
          sources =
            dependency.requirements.map { |r| r.fetch(:source) }.uniq.compact

          return "default" if sources.empty?
          raise "Multiple sources! #{sources.join(', ')}" if sources.count > 1

          sources.first[:type] || sources.first.fetch("type")
        end

        def find_source_from_crates_listing
          potential_source_urls =
            SOURCE_KEYS.
            map { |key| crates_listing.dig("crate", key) }.
            compact

          source_url = potential_source_urls.find { |url| Source.from_url(url) }
          Source.from_url(source_url)
        end

        def find_source_from_git_url
          info = dependency.requirements.map { |r| r[:source] }.compact.first

          url = info[:url] || info.fetch("url")
          Source.from_url(url)
        end

        def crates_listing
          return @crates_listing unless @crates_listing.nil?

          response = Excon.get(
            "https://crates.io/api/v1/crates/#{dependency.name}",
            idempotent: true,
            **SharedHelpers.excon_defaults
          )

          @crates_listing = JSON.parse(response.body)
        end
      end
    end
  end
end

Version data entries

22 entries across 22 versions & 1 rubygems

Version Path
dependabot-core-0.80.1 lib/dependabot/metadata_finders/rust/cargo.rb
dependabot-core-0.80.0 lib/dependabot/metadata_finders/rust/cargo.rb
dependabot-core-0.79.4 lib/dependabot/metadata_finders/rust/cargo.rb
dependabot-core-0.79.3 lib/dependabot/metadata_finders/rust/cargo.rb
dependabot-core-0.79.2 lib/dependabot/metadata_finders/rust/cargo.rb
dependabot-core-0.79.1 lib/dependabot/metadata_finders/rust/cargo.rb
dependabot-core-0.79.0 lib/dependabot/metadata_finders/rust/cargo.rb
dependabot-core-0.78.0 lib/dependabot/metadata_finders/rust/cargo.rb
dependabot-core-0.77.2 lib/dependabot/metadata_finders/rust/cargo.rb
dependabot-core-0.77.1 lib/dependabot/metadata_finders/rust/cargo.rb
dependabot-core-0.77.0 lib/dependabot/metadata_finders/rust/cargo.rb
dependabot-core-0.76.11 lib/dependabot/metadata_finders/rust/cargo.rb
dependabot-core-0.76.10 lib/dependabot/metadata_finders/rust/cargo.rb
dependabot-core-0.76.9 lib/dependabot/metadata_finders/rust/cargo.rb
dependabot-core-0.76.8 lib/dependabot/metadata_finders/rust/cargo.rb
dependabot-core-0.76.7 lib/dependabot/metadata_finders/rust/cargo.rb
dependabot-core-0.76.6 lib/dependabot/metadata_finders/rust/cargo.rb
dependabot-core-0.76.5 lib/dependabot/metadata_finders/rust/cargo.rb
dependabot-core-0.76.4 lib/dependabot/metadata_finders/rust/cargo.rb
dependabot-core-0.76.3 lib/dependabot/metadata_finders/rust/cargo.rb