Fix privacy for misskey
This commit is contained in:
parent
d031ade823
commit
7bcef0f8b2
5 changed files with 22 additions and 18 deletions
|
@ -130,14 +130,13 @@ class ActivityPub::TagManager
|
||||||
end
|
end
|
||||||
|
|
||||||
def cc_for_misskey(status)
|
def cc_for_misskey(status)
|
||||||
case status.visibility
|
if (status.account.user&.reject_unlisted_subscription? && status.visibility == 'unlisted') || (status.account.user&.reject_public_unlisted_subscription? && status.visibility == 'public_unlisted')
|
||||||
when 'unlisted'
|
cc = cc_private_visibility(status)
|
||||||
status.account.user&.reject_unlisted_subscription? ? cc_private_visibility(status) : cc(status)
|
cc << uri_for(status.reblog.account) if status.reblog?
|
||||||
when 'public_unlisted'
|
return cc
|
||||||
status.account.user&.reject_public_unlisted_subscription? ? cc_private_visibility(status) : cc(status)
|
|
||||||
else
|
|
||||||
cc(status)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
cc(status)
|
||||||
end
|
end
|
||||||
|
|
||||||
def cc_private_visibility(status)
|
def cc_private_visibility(status)
|
||||||
|
|
|
@ -122,6 +122,7 @@ class StatusPolicy < ApplicationPolicy
|
||||||
else
|
else
|
||||||
(@domain_block.detect_invalid_subscription && status.public_unlisted_visibility? && status.account.user&.reject_public_unlisted_subscription) ||
|
(@domain_block.detect_invalid_subscription && status.public_unlisted_visibility? && status.account.user&.reject_public_unlisted_subscription) ||
|
||||||
(@domain_block.detect_invalid_subscription && status.public_visibility? && status.account.user&.reject_unlisted_subscription)
|
(@domain_block.detect_invalid_subscription && status.public_visibility? && status.account.user&.reject_unlisted_subscription)
|
||||||
|
end
|
||||||
else
|
else
|
||||||
false
|
false
|
||||||
end
|
end
|
||||||
|
|
|
@ -4,14 +4,14 @@ class ActivityPub::ActivityPresenter < ActiveModelSerializers::Model
|
||||||
attributes :id, :type, :actor, :published, :to, :cc, :virtual_object
|
attributes :id, :type, :actor, :published, :to, :cc, :virtual_object
|
||||||
|
|
||||||
class << self
|
class << self
|
||||||
def from_status(status, allow_inlining: true)
|
def from_status(status, allow_inlining: true, for_misskey: false)
|
||||||
new.tap do |presenter|
|
new.tap do |presenter|
|
||||||
presenter.id = ActivityPub::TagManager.instance.activity_uri_for(status)
|
presenter.id = ActivityPub::TagManager.instance.activity_uri_for(status)
|
||||||
presenter.type = status.reblog? ? 'Announce' : 'Create'
|
presenter.type = status.reblog? ? 'Announce' : 'Create'
|
||||||
presenter.actor = ActivityPub::TagManager.instance.uri_for(status.account)
|
presenter.actor = ActivityPub::TagManager.instance.uri_for(status.account)
|
||||||
presenter.published = status.created_at
|
presenter.published = status.created_at
|
||||||
presenter.to = ActivityPub::TagManager.instance.to(status)
|
presenter.to = ActivityPub::TagManager.instance.to(status)
|
||||||
presenter.cc = ActivityPub::TagManager.instance.cc(status)
|
presenter.cc = for_misskey ? ActivityPub::TagManager.instance.cc_for_misskey(status) : ActivityPub::TagManager.instance.cc(status)
|
||||||
|
|
||||||
presenter.virtual_object = begin
|
presenter.virtual_object = begin
|
||||||
if status.reblog?
|
if status.reblog?
|
||||||
|
|
|
@ -31,13 +31,17 @@ class ActivityPub::DistributionWorker < ActivityPub::RawDistributionWorker
|
||||||
end
|
end
|
||||||
|
|
||||||
def payload_for_misskey
|
def payload_for_misskey
|
||||||
@payload ||= Oj.dump(serialize_payload(activity, ActivityPub::ActivityForMisskeySerializer, signer: @account))
|
@payload_for_misskey ||= Oj.dump(serialize_payload(activity_for_misskey, ActivityPub::ActivityForMisskeySerializer, signer: @account))
|
||||||
end
|
end
|
||||||
|
|
||||||
def activity
|
def activity
|
||||||
ActivityPub::ActivityPresenter.from_status(@status)
|
ActivityPub::ActivityPresenter.from_status(@status)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def activity_for_misskey
|
||||||
|
ActivityPub::ActivityPresenter.from_status(@status, for_misskey: true)
|
||||||
|
end
|
||||||
|
|
||||||
def options
|
def options
|
||||||
{ 'synchronize_followers' => @status.private_visibility? }
|
{ 'synchronize_followers' => @status.private_visibility? }
|
||||||
end
|
end
|
||||||
|
|
|
@ -23,16 +23,16 @@ class ActivityPub::RawDistributionWorker
|
||||||
protected
|
protected
|
||||||
|
|
||||||
def distribute!
|
def distribute!
|
||||||
return if inboxes.empty? && inboxes_for_misskey.empty?
|
unless inboxes.empty?
|
||||||
|
ActivityPub::DeliveryWorker.push_bulk(inboxes) do |inbox_url|
|
||||||
ActivityPub::DeliveryWorker.push_bulk(inboxes) do |inbox_url|
|
[payload, source_account_id, inbox_url, options]
|
||||||
[payload, source_account_id, inbox_url, options]
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
return if inboxes_for_misskey.empty?
|
unless inboxes_for_misskey.empty?
|
||||||
|
ActivityPub::DeliveryWorker.push_bulk(inboxes_for_misskey) do |inbox_url|
|
||||||
ActivityPub::DeliveryWorker.push_bulk(inboxes_for_misskey) do |inbox_url|
|
[payload_for_misskey, source_account_id, inbox_url, options]
|
||||||
[payload_for_misskey, source_account_id, inbox_url, options]
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue