summaryrefslogtreecommitdiff
path: root/app/helpers/ci/runners_helper.rb
blob: 432aad663e418c9e0a49d49897a46d0e44e9019d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
# frozen_string_literal: true

module Ci
  module RunnersHelper
    include IconsHelper

    def runner_status_icon(runner)
      status = runner.status
      case status
      when :not_connected
        content_tag(:span, title: "New runner. Has not connected yet") do
          sprite_icon("warning-solid", size: 24, css_class: "gl-vertical-align-bottom!")
        end

      when :online, :offline, :paused
        content_tag :i, nil,
                    class: "fa fa-circle runner-status-#{status}",
                    title: "Runner is #{status}, last contact was #{time_ago_in_words(runner.contacted_at)} ago"
      end
    end

    def runner_link(runner)
      display_name = truncate(runner.display_name, length: 15)
      id = "\##{runner.id}"

      if current_user && current_user.admin
        link_to admin_runner_path(runner) do
          display_name + id
        end
      else
        display_name + id
      end
    end

    # Due to inability of performing sorting of runners by cached "contacted_at" values we have to show uncached values if sorting by "contacted_asc" is requested.
    # Please refer to the following issue for more details: https://gitlab.com/gitlab-org/gitlab-foss/issues/55920
    def runner_contacted_at(runner)
      if params[:sort] == 'contacted_asc'
        runner.uncached_contacted_at
      else
        runner.contacted_at
      end
    end

    def group_shared_runners_settings_data(group)
      {
        update_path: api_v4_groups_path(id: group.id),
        shared_runners_availability: group.shared_runners_setting,
        parent_shared_runners_availability: group.parent&.shared_runners_setting
      }
    end
  end
end

Ci::RunnersHelper.prepend_if_ee('EE::Ci::RunnersHelper')