Commit 0a1160cb authored by Mikolaj Wawrzyniak's avatar Mikolaj Wawrzyniak

Append logs_path based on user entitlements

To avoid presenting un reachable links to users with to low
entitlement level we should check user permissions before
logs_path link is appended.
parent 63c48c56
---
title: Remove unreachable link from embded dashboard context menu
merge_request: 25892
author:
type: fixed
...@@ -45,9 +45,9 @@ module EE ...@@ -45,9 +45,9 @@ module EE
"validate-query-path" => validate_query_project_prometheus_metrics_path(project), "validate-query-path" => validate_query_project_prometheus_metrics_path(project),
"custom-metrics-available" => "#{custom_metrics_available?(project)}", "custom-metrics-available" => "#{custom_metrics_available?(project)}",
"alerts-endpoint" => project_prometheus_alerts_path(project, environment_id: environment.id, format: :json), "alerts-endpoint" => project_prometheus_alerts_path(project, environment_id: environment.id, format: :json),
"prometheus-alerts-available" => "#{can?(current_user, :read_prometheus_alerts, project)}", "prometheus-alerts-available" => "#{can?(current_user, :read_prometheus_alerts, project)}"
"logs_path" => project_logs_path(project, environment_name: environment.name)
} }
ee_metrics_data["logs_path"] = project_logs_path(project, environment_name: environment.name) if can?(current_user, :read_pod_logs, project)
super.merge(ee_metrics_data) super.merge(ee_metrics_data)
end end
......
...@@ -10,6 +10,7 @@ describe EnvironmentsHelper do ...@@ -10,6 +10,7 @@ describe EnvironmentsHelper do
describe '#metrics_data' do describe '#metrics_data' do
subject { helper.metrics_data(project, environment) } subject { helper.metrics_data(project, environment) }
context 'user has all accesses' do
before do before do
allow(helper).to receive(:current_user).and_return(user) allow(helper).to receive(:current_user).and_return(user)
allow(helper).to receive(:can?) allow(helper).to receive(:can?)
...@@ -18,6 +19,9 @@ describe EnvironmentsHelper do ...@@ -18,6 +19,9 @@ describe EnvironmentsHelper do
allow(helper).to receive(:can?) allow(helper).to receive(:can?)
.with(user, :admin_project, project) .with(user, :admin_project, project)
.and_return(true) .and_return(true)
allow(helper).to receive(:can?)
.with(user, :read_pod_logs, project)
.and_return(true)
end end
it 'returns additional configuration' do it 'returns additional configuration' do
...@@ -32,6 +36,26 @@ describe EnvironmentsHelper do ...@@ -32,6 +36,26 @@ describe EnvironmentsHelper do
end end
end end
context 'user does not have access to pod logs' do
before do
allow(helper).to receive(:current_user).and_return(user)
allow(helper).to receive(:can?)
.with(user, :read_prometheus_alerts, project)
.and_return(true)
allow(helper).to receive(:can?)
.with(user, :admin_project, project)
.and_return(true)
allow(helper).to receive(:can?)
.with(user, :read_pod_logs, project)
.and_return(false)
end
it 'returns additional configuration' do
expect(subject.keys).not_to include('logs_path')
end
end
end
describe '#environment_logs_data' do describe '#environment_logs_data' do
subject { helper.environment_logs_data(project, environment) } subject { helper.environment_logs_data(project, environment) }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment