2019-07-31 22:56:46 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
# Searches a projects repository for a metrics dashboard and formats the output.
|
|
|
|
# Expects any custom dashboards will be located in `.gitlab/dashboards`
|
|
|
|
module Gitlab
|
|
|
|
module Metrics
|
|
|
|
module Dashboard
|
|
|
|
class BaseService < ::BaseService
|
2019-09-04 21:01:54 +05:30
|
|
|
PROCESSING_ERROR = Gitlab::Metrics::Dashboard::Stages::BaseStage::DashboardProcessingError
|
|
|
|
NOT_FOUND_ERROR = Gitlab::Template::Finders::RepoTemplateFinder::FileNotFoundError
|
2019-07-31 22:56:46 +05:30
|
|
|
|
|
|
|
def get_dashboard
|
2019-09-30 21:07:59 +05:30
|
|
|
return error('Insufficient permissions.', :unauthorized) unless allowed?
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
success(dashboard: process_dashboard)
|
2019-09-04 21:01:54 +05:30
|
|
|
rescue NOT_FOUND_ERROR
|
|
|
|
error("#{dashboard_path} could not be found.", :not_found)
|
|
|
|
rescue PROCESSING_ERROR => e
|
2019-07-31 22:56:46 +05:30
|
|
|
error(e.message, :unprocessable_entity)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Summary of all known dashboards for the service.
|
|
|
|
# @return [Array<Hash>] ex) [{ path: String, default: Boolean }]
|
2019-09-04 21:01:54 +05:30
|
|
|
def self.all_dashboard_paths(_project)
|
2019-07-31 22:56:46 +05:30
|
|
|
raise NotImplementedError
|
|
|
|
end
|
|
|
|
|
2019-09-30 21:07:59 +05:30
|
|
|
# Returns an un-processed dashboard from the cache.
|
|
|
|
def raw_dashboard
|
|
|
|
Gitlab::Metrics::Dashboard::Cache.fetch(cache_key) { get_raw_dashboard }
|
|
|
|
end
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
private
|
|
|
|
|
2019-09-30 21:07:59 +05:30
|
|
|
# Determines whether users should be able to view
|
|
|
|
# dashboards at all.
|
|
|
|
def allowed?
|
|
|
|
Ability.allowed?(current_user, :read_environment, project)
|
|
|
|
end
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
# Returns a new dashboard Hash, supplemented with DB info
|
|
|
|
def process_dashboard
|
|
|
|
Gitlab::Metrics::Dashboard::Processor
|
|
|
|
.new(project, params[:environment], raw_dashboard)
|
|
|
|
.process(insert_project_metrics: insert_project_metrics?)
|
|
|
|
end
|
|
|
|
|
|
|
|
# @return [String] Relative filepath of the dashboard yml
|
|
|
|
def dashboard_path
|
|
|
|
params[:dashboard_path]
|
|
|
|
end
|
|
|
|
|
|
|
|
# @return [Hash] an unmodified dashboard
|
|
|
|
def get_raw_dashboard
|
|
|
|
raise NotImplementedError
|
|
|
|
end
|
|
|
|
|
|
|
|
# @return [String]
|
|
|
|
def cache_key
|
|
|
|
raise NotImplementedError
|
|
|
|
end
|
|
|
|
|
|
|
|
# Determines whether custom metrics should be included
|
|
|
|
# in the processed output.
|
2019-09-30 21:07:59 +05:30
|
|
|
# @return [Boolean]
|
2019-07-31 22:56:46 +05:30
|
|
|
def insert_project_metrics?
|
|
|
|
false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|