diff options
author | David Yip <yipdw@member.fsf.org> | 2018-01-09 14:16:45 -0600 |
---|---|---|
committer | David Yip <yipdw@member.fsf.org> | 2018-01-09 14:16:45 -0600 |
commit | 991371af5f22ba85199f3f66bab5f70b404de95f (patch) | |
tree | 3e5652e1d90596c57b70d2afac72b17f183b8734 /app/lib | |
parent | e780d5951b7eb743a718d9b34a46cd8fa5561636 (diff) | |
parent | 35b84985a8b9e57cfd3ffac8a0e3937d3c7a1167 (diff) |
Merge remote-tracking branch 'origin/master' into merge-upstream
Conflicts: db/schema.rb
Diffstat (limited to 'app/lib')
-rw-r--r-- | app/lib/activitypub/activity/announce.rb | 6 | ||||
-rw-r--r-- | app/lib/ostatus/activity/creation.rb | 3 |
2 files changed, 8 insertions, 1 deletions
diff --git a/app/lib/activitypub/activity/announce.rb b/app/lib/activitypub/activity/announce.rb index b84098933..abf2b9b80 100644 --- a/app/lib/activitypub/activity/announce.rb +++ b/app/lib/activitypub/activity/announce.rb @@ -5,7 +5,7 @@ class ActivityPub::Activity::Announce < ActivityPub::Activity original_status = status_from_uri(object_uri) original_status ||= fetch_remote_original_status - return if original_status.nil? || delete_arrived_first?(@json['id']) + return if original_status.nil? || delete_arrived_first?(@json['id']) || !announceable?(original_status) status = Status.find_by(account: @account, reblog: original_status) @@ -33,4 +33,8 @@ class ActivityPub::Activity::Announce < ActivityPub::Activity ::FetchRemoteStatusService.new.call(@object['url']) end end + + def announceable?(status) + status.public_visibility? || status.unlisted_visibility? + end end diff --git a/app/lib/ostatus/activity/creation.rb b/app/lib/ostatus/activity/creation.rb index f210e134a..b38407cd3 100644 --- a/app/lib/ostatus/activity/creation.rb +++ b/app/lib/ostatus/activity/creation.rb @@ -26,6 +26,9 @@ class OStatus::Activity::Creation < OStatus::Activity::Base cached_reblog = reblog status = nil + # Skip if the reblogged status is not public + return if cached_reblog && !(cached_reblog.public_visibility? || cached_reblog.unlisted_visibility?) + media_attachments = save_media ApplicationRecord.transaction do |