Update StatusPolicy to check current_account for local_only? toots.

StatusPolicy#account was renamed to StatusPolicy#current_account in
upstream.  This commit renames the local-only changes to match and
augments the #show? policy spec with what we expect for local-only
toots.
lolsob-rspec
David Yip 2017-11-17 09:07:21 -06:00
parent ff4e474bcd
commit bcdd0f8b9d
2 changed files with 7 additions and 1 deletions

View File

@ -6,7 +6,7 @@ class StatusPolicy < ApplicationPolicy
end
def show?
return false if local_only? && account.nil?
return false if local_only? && current_account.nil?
if direct?
owned? || record.mentions.where(account: current_account).exists?

View File

@ -71,6 +71,12 @@ RSpec.describe StatusPolicy, type: :model do
expect(subject).to_not permit(viewer, status)
end
it 'denies access when local-only and the viewer is not logged in' do
allow(status).to receive(:local_only?) { true }
expect(subject).to_not permit(nil, status)
end
end
permissions :reblog? do