summaryrefslogtreecommitdiff
path: root/app/services/metrics/dashboard/default_embed_service.rb
blob: 0967c5bcfebe49be66ec00edd60d2163c8c252bc (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
56
57
58
59
60
61
62
63
# frozen_string_literal: true

# Responsible for returning a filtered system dashboard
# containing only the default embedded metrics. In future,
# this class may be updated to support filtering to
# alternate metrics/panels.
#
# Why isn't this filtering in a processing stage? By filtering
# here, we ensure the dynamically-determined dashboard is cached.
#
# Use Gitlab::Metrics::Dashboard::Finder to retrive dashboards.
module Metrics
  module Dashboard
    class DefaultEmbedService < ::Metrics::Dashboard::BaseService
      # For the default filtering for embedded metrics,
      # uses the 'id' key in dashboard-yml definition for
      # identification.
      DEFAULT_EMBEDDED_METRICS_IDENTIFIERS = %w(
        system_metrics_kubernetes_container_memory_total
        system_metrics_kubernetes_container_cores_total
      ).freeze

      # Returns a new dashboard with only the matching
      # metrics from the system dashboard, stripped of groups.
      # @return [Hash]
      def raw_dashboard
        panels = panel_groups.each_with_object([]) do |group, panels|
          matched_panels = group['panels'].select { |panel| matching_panel?(panel) }

          panels.concat(matched_panels)
        end

        { 'panel_groups' => [{ 'panels' => panels }] }
      end

      def cache_key
        "dynamic_metrics_dashboard_#{metric_identifiers.join('_')}"
      end

      private

      # Returns an array of the panels groups on the
      # system dashboard
      def panel_groups
        ::Metrics::Dashboard::SystemDashboardService
          .new(project, nil)
          .raw_dashboard['panel_groups']
      end

      # Identifies a panel as "matching" if any metric ids in
      # the panel is in the list of identifiers to collect.
      def matching_panel?(panel)
        panel['metrics'].any? do |metric|
          metric_identifiers.include?(metric['id'])
        end
      end

      def metric_identifiers
        DEFAULT_EMBEDDED_METRICS_IDENTIFIERS
      end
    end
  end
end