22 lines
738 B
Ruby
22 lines
738 B
Ruby
|
module Ci
|
||
|
class ProjectListBuilder
|
||
|
def execute(current_user, search = nil)
|
||
|
projects = current_user.authorized_projects
|
||
|
projects = projects.search(search) if search
|
||
|
|
||
|
projects.
|
||
|
joins("LEFT JOIN ci_projects ON projects.id = ci_projects.gitlab_id
|
||
|
LEFT JOIN #{last_commit_subquery} AS last_commit ON #{Ci::Project.table_name}.id = last_commit.project_id").
|
||
|
reorder("ci_projects.id is NULL ASC,
|
||
|
CASE WHEN last_commit.committed_at IS NULL THEN 1 ELSE 0 END,
|
||
|
last_commit.committed_at DESC")
|
||
|
end
|
||
|
|
||
|
private
|
||
|
|
||
|
def last_commit_subquery
|
||
|
"(SELECT project_id, MAX(committed_at) committed_at FROM #{Ci::Commit.table_name} GROUP BY project_id)"
|
||
|
end
|
||
|
end
|
||
|
end
|