travis-api/lib/travis/api/v3/queries/repositories.rb
Piotr Sarnacki c9b93982c9 Add current_build to repositories payload
current_build is the most recent build that is either completed or
running
2016-05-11 16:55:47 +02:00

61 lines
2.5 KiB
Ruby

module Travis::API::V3
class Queries::Repositories < Query
params :active, :private, :starred, prefix: :repository
sortable_by :id, :github_id, :owner_name, :name, active: sort_condition(:active), :'default_branch.last_build' => 'builds.started_at', :current_build => "current_build.id %{order} NULLS LAST"
def for_member(user, **options)
all(user: user, **options).joins(:users).where(users: user_condition(user), invalidated_at: nil)
end
def for_owner(owner, **options)
filter(owner.repositories, **options)
end
def all(**options)
filter(Models::Repository, **options)
end
def filter(list, user: nil)
list = list.where(invalidated_at: nil)
list = list.where(active: bool(active)) unless active.nil?
list = list.where(private: bool(private)) unless private.nil?
list = list.includes(:owner) if includes? 'repository.owner'.freeze
if user and not starred.nil?
if bool(starred)
list = list.joins(:stars).where(stars: { user_id: user.id })
elsif user.starred_repository_ids.any?
list = list.where("repositories.id NOT IN (?)", user.starred_repository_ids)
end
end
if includes? 'repository.last_build'.freeze or includes? 'build'.freeze
list = list.includes(:last_build)
list = list.includes(last_build: :commit) if includes? 'build.commit'.freeze
end
list = list.includes(default_branch: :last_build)
list = list.includes(default_branch: { last_build: :commit }) if includes? 'build.commit'.freeze
sort add_current_build list
end
# this will add SQL needed to fetch current_build along with the
# repositories list. It will probably go away soon, once we test the current
# build and use current_build_id column, just as we do with last_build for
# branches
def add_current_build(list)
join = "
LEFT OUTER JOIN builds as %{column_alias}
ON %{column_alias}.repository_id = repositories.id AND
%{column_alias}.event_type IN ('api', 'push', 'cron') AND
%{column_alias}.state IN ('started', 'errored', 'passed', 'finished', 'canceled')"
list = list.joins(join % { column_alias: 'current_build' })
list = list.joins(join % { column_alias: 'older_builds' }+ " AND current_build.id < older_builds.id")
list = list.where("older_builds.id IS NULL")
list.select("repositories.*, current_build.id as current_build_id")
end
end
end