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

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'lib/gitlab/usage/metrics/instrumentations/count_snippets_metric.rb')
-rw-r--r--lib/gitlab/usage/metrics/instrumentations/count_snippets_metric.rb35
1 files changed, 35 insertions, 0 deletions
diff --git a/lib/gitlab/usage/metrics/instrumentations/count_snippets_metric.rb b/lib/gitlab/usage/metrics/instrumentations/count_snippets_metric.rb
new file mode 100644
index 00000000000..342ba802fd8
--- /dev/null
+++ b/lib/gitlab/usage/metrics/instrumentations/count_snippets_metric.rb
@@ -0,0 +1,35 @@
+# frozen_string_literal: true
+
+module Gitlab
+ module Usage
+ module Metrics
+ module Instrumentations
+ class CountSnippetsMetric < DatabaseMetric
+ operation :count
+ # Relation and operation are not used, but are included to satisfy expectations
+ # of other metric generation logic.
+ relation { Snippet }
+
+ def value
+ count(project_snippet_relation) + count(personal_snippet_relation)
+ end
+
+ def project_snippet_relation
+ ProjectSnippet.where(time_constraints)
+ end
+
+ def personal_snippet_relation
+ PersonalSnippet.where(time_constraints)
+ end
+
+ def to_sql
+ project_snippet_relation_sql = Gitlab::Usage::Metrics::Query.for(:count, project_snippet_relation)
+ personal_snippet_relation_sql = Gitlab::Usage::Metrics::Query.for(:count, personal_snippet_relation)
+
+ "SELECT (#{project_snippet_relation_sql}) + (#{personal_snippet_relation_sql})"
+ end
+ end
+ end
+ end
+ end
+end