diff options
Diffstat (limited to 'app/policies/personal_snippet_policy.rb')
-rw-r--r-- | app/policies/personal_snippet_policy.rb | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/app/policies/personal_snippet_policy.rb b/app/policies/personal_snippet_policy.rb index 205dad6ea5f..7ee258f962a 100644 --- a/app/policies/personal_snippet_policy.rb +++ b/app/policies/personal_snippet_policy.rb @@ -4,6 +4,7 @@ class PersonalSnippetPolicy < BasePolicy condition(:public_snippet, scope: :subject) { @subject.public? } condition(:is_author) { @user && @subject.author == @user } condition(:internal_snippet, scope: :subject) { @subject.internal? } + condition(:hidden, scope: :subject) { @subject.hidden_due_to_author_ban? } rule { public_snippet }.policy do enable :read_snippet @@ -29,5 +30,13 @@ class PersonalSnippetPolicy < BasePolicy rule { can?(:create_note) }.enable :award_emoji + rule { hidden & ~can?(:read_all_resources) }.policy do + prevent :read_snippet + prevent :update_snippet + prevent :admin_snippet + prevent :read_note + prevent :create_note + end + rule { can?(:read_all_resources) }.enable :read_snippet end |