gitlab-org--gitlab-foss/app/policies/project_snippet_policy.rb

21 lines
481 B
Ruby
Raw Normal View History

2016-08-16 16:08:14 -04:00
class ProjectSnippetPolicy < BasePolicy
def rules
can! :read_project_snippet if @subject.public?
return unless @user
if @user && (@subject.author == @user || @user.admin?)
2016-08-16 16:08:14 -04:00
can! :read_project_snippet
can! :update_project_snippet
can! :admin_project_snippet
end
if @subject.internal? && !@user.external?
can! :read_project_snippet
end
if @subject.project.team.member?(@user)
2016-08-16 16:08:14 -04:00
can! :read_project_snippet
end
end
end