Welcome to mirror list, hosted at ThFree Co, Russian Federation.

project_list_builder.rb « ci « lib - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: da26f9a9f47f8840d51ca2ed853673de6f678c5e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
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