Skip to content

Commit

Permalink
Add dependency table #282
Browse files Browse the repository at this point in the history
  • Loading branch information
andrew committed Jun 26, 2024
1 parent 97a7f3e commit 9475006
Show file tree
Hide file tree
Showing 5 changed files with 76 additions and 16 deletions.
2 changes: 2 additions & 0 deletions app/models/dependency.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
class Dependency < ApplicationRecord
end
54 changes: 39 additions & 15 deletions app/models/project.rb
Original file line number Diff line number Diff line change
Expand Up @@ -1272,23 +1272,47 @@ def self.sync_dependencies

dependencies.each do |(ecosystem, package_name), count|
puts "Checking #{ecosystem} #{package_name}"
if existing_packages.any?{|p| p['ecosystem'] == ecosystem && p['name'] == package_name }

dependency = Dependency.find_or_create_by(ecosystem: ecosystem, name: package_name)

dependency.update(count: count)

next if dependency.package.present?

existing_package = existing_packages.find{|p| p['ecosystem'] == ecosystem && p['name'] == package_name }

if existing_package.present?
puts " Already exists"
next
end
purl = "https://packages.ecosyste.ms/api/v1/packages/lookup?ecosystem=#{ecosystem}&package_name=#{package_name}"
conn = Faraday.new(url: purl) do |faraday|
faraday.response :follow_redirects
faraday.adapter Faraday.default_adapter
end

response = conn.get
puts " Response: #{response.status}"
next unless response.success?
package = JSON.parse(response.body)
puts " #{package['repository_url']}"
project = Project.create(url: package['repository_url'])
project.sync_async
project = Project.find_by(url: existing_package['repository_url'])

dependency.update(package: existing_package, repository_url: existing_package['repository_url'], project_id: project.try(:id), average_ranking: existing_package['rankings']['average'])
else
# TODO
# load it from the packages API
# purl = "https://packages.ecosyste.ms/api/v1/packages/lookup?ecosystem=#{ecosystem}&name=#{package_name}"

# puts " Fetching #{purl}"

# conn = Faraday.new(url: purl) do |faraday|
# faraday.response :follow_redirects
# faraday.adapter Faraday.default_adapter
# end

# response = conn.get
# puts " Response: #{response.status}"
# next unless response.success?
# packages = JSON.parse(response.body)
# package = packages.first
# next unless package.present?
# puts " #{package['repository_url']}"
# project = Project.create(url: package['repository_url'])
# project.sync_async

# dependency.update(package: package, repository_url: package['repository_url'], project_id: project.id, average_ranking: package['rankings']['average'])

end

end
end
end
15 changes: 15 additions & 0 deletions db/migrate/20240626125315_create_dependencies.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
class CreateDependencies < ActiveRecord::Migration[7.1]
def change
create_table :dependencies do |t|
t.string :ecosystem
t.string :name
t.integer :count
t.json :package, default: {}
t.string :repository_url
t.integer :project_id
t.float :average_ranking

t.timestamps
end
end
end
14 changes: 13 additions & 1 deletion db/schema.rb

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

7 changes: 7 additions & 0 deletions test/models/dependency_test.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
require "test_helper"

class DependencyTest < ActiveSupport::TestCase
# test "the truth" do
# assert true
# end
end

0 comments on commit 9475006

Please sign in to comment.