Sha256: a09dacf91ed47c046d2d1b2cf0172501e1a8de377dffe302a8999e0e843e022f

Contents?: true

Size: 1.38 KB

Versions: 5

Compression:

Stored size: 1.38 KB

Contents

# frozen_string_literal: true

module Spandx
  module Ruby
    class Gateway < ::Spandx::Core::Gateway
      # https://guides.rubygems.org/rubygems-org-api-v2/
      def initialize(http: Spandx.http)
        @http = http
      end

      def each
        response = http.get('https://index.rubygems.org/versions')
        return unless http.ok?(response)

        parse_each_from(StringIO.new(response.body)) do |item|
          yield item
        end
      end

      def licenses_for(dependency)
        licenses(dependency.name, dependency.version)
      end

      def licenses(name, version)
        details_on(name, version)['licenses'] || []
      end

      def matches?(dependency)
        dependency.package_manager == :rubygems
      end

      private

      attr_reader :http

      def parse_each_from(io)
        _created_at = io.readline
        _triple_dash = io.readline
        until io.eof?
          name, versions, _digest = io.readline.split(' ')
          versions.split(',').each do |version|
            yield({ name: name, version: version })
          end
        end
      end

      def details_on(name, version)
        url = "https://rubygems.org/api/v2/rubygems/#{name}/versions/#{version}.json"
        response = http.get(url, default: {})
        http.ok?(response) ? parse(response.body) : {}
      end

      def parse(json)
        Oj.load(json)
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
spandx-0.18.3 lib/spandx/ruby/gateway.rb
spandx-0.18.2 lib/spandx/ruby/gateway.rb
spandx-0.18.1 lib/spandx/ruby/gateway.rb
spandx-0.18.0 lib/spandx/ruby/gateway.rb
spandx-0.17.0 lib/spandx/ruby/gateway.rb