679789ee93
Also make sure pipeline would also check against tag as well
17 lines
409 B
Ruby
17 lines
409 B
Ruby
module Ci
|
|
class PipelinePolicy < BasePolicy
|
|
delegate { @subject.project }
|
|
|
|
condition(:user_cannot_update) do
|
|
access = ::Gitlab::UserAccess.new(@user, project: @subject.project)
|
|
|
|
if @subject.tag?
|
|
!access.can_create_tag?(@subject.ref)
|
|
else
|
|
!access.can_update_branch?(@subject.ref)
|
|
end
|
|
end
|
|
|
|
rule { user_cannot_update }.prevent :update_pipeline
|
|
end
|
|
end
|