Browse Source

Add support for non-public reblogs from ActivityPub (#9841)

Fix #9838
master
Eugen Rochko 5 years ago
committed by GitHub
parent
commit
31f396b57d
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 15 additions and 3 deletions
  1. +13
    -1
      app/lib/activitypub/activity/announce.rb
  2. +2
    -2
      app/models/status.rb

+ 13
- 1
app/lib/activitypub/activity/announce.rb View File

@@ -17,7 +17,7 @@ class ActivityPub::Activity::Announce < ActivityPub::Activity
uri: @json['id'],
created_at: @json['published'],
override_timestamps: @options[:override_timestamps],
visibility: original_status.visibility
visibility: visibility_from_audience
)

distribute(status)
@@ -26,6 +26,18 @@ class ActivityPub::Activity::Announce < ActivityPub::Activity

private

def visibility_from_audience
if equals_or_includes?(@json['to'], ActivityPub::TagManager::COLLECTIONS[:public])
:public
elsif equals_or_includes?(@json['cc'], ActivityPub::TagManager::COLLECTIONS[:public])
:unlisted
elsif equals_or_includes?(@json['to'], @account.followers_url)
:private
else
:direct
end
end

def announceable?(status)
status.account_id == @account.id || status.public_visibility? || status.unlisted_visibility?
end


+ 2
- 2
app/models/status.rb View File

@@ -478,7 +478,7 @@ class Status < ApplicationRecord
return if direct_visibility?

account&.increment_count!(:statuses_count)
reblog&.increment_count!(:reblogs_count) if reblog?
reblog&.increment_count!(:reblogs_count) if reblog? && (public_visibility? || unlisted_visibility?)
thread&.increment_count!(:replies_count) if in_reply_to_id.present? && (public_visibility? || unlisted_visibility?)
end

@@ -486,7 +486,7 @@ class Status < ApplicationRecord
return if direct_visibility? || marked_for_mass_destruction?

account&.decrement_count!(:statuses_count)
reblog&.decrement_count!(:reblogs_count) if reblog?
reblog&.decrement_count!(:reblogs_count) if reblog? && (public_visibility? || unlisted_visibility?)
thread&.decrement_count!(:replies_count) if in_reply_to_id.present? && (public_visibility? || unlisted_visibility?)
end



Loading…
Cancel
Save