4df3b7cb06
Conflicts: - app/controllers/settings/follower_domains_controller.rb Removed upstream. Did the same here. Maybe we should not have? - config/locales/en.yml Upstream removed the “Authorized followers” page and associated translations. This is too close in the file to our glitch-soc-specific “flavour” string. No actual conflict. - config/locales/ja.yml Same as above. - config/locales/pl.yml Same as above. - config/navigation.rb No real conflict. New route added too close to the glitch-soc-specific “flavours” one. - config/webpack/configuration.js Upstream refactored the webpack(er) configuration quite a bit. Tried to keep up. - config/webpack/loaders/babel.js Upstream refactored the webpack(er) configuration quite a bit. Tried to keep up. The contents of this file have been moved to package.json. - config/webpack/shared.js Upstream refactored the webpack(er) configuration quite a bit. Tried to keep up. - config/webpacker.yml Upstream refactored the webpack(er) configuration quite a bit. Tried to keep up. - jest.config.js The contents of this file have been moved to package.json. - package.json Upstream refactored the webpack(er) configuration quite a bit. Tried to keep up. - yarn.lock Upstream refactored the webpack(er) configuration quite a bit. Tried to keep up.
64 lines
2.2 KiB
Ruby
64 lines
2.2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class ReblogService < BaseService
|
|
include Authorization
|
|
include StreamEntryRenderer
|
|
|
|
# Reblog a status and notify its remote author
|
|
# @param [Account] account Account to reblog from
|
|
# @param [Status] reblogged_status Status to be reblogged
|
|
# @param [Hash] options
|
|
# @return [Status]
|
|
def call(account, reblogged_status, options = {})
|
|
reblogged_status = reblogged_status.reblog if reblogged_status.reblog?
|
|
|
|
authorize_with account, reblogged_status, :reblog?
|
|
|
|
reblog = account.statuses.find_by(reblog: reblogged_status)
|
|
|
|
return reblog unless reblog.nil?
|
|
|
|
reblog = account.statuses.create!(reblog: reblogged_status, text: '', visibility: options[:visibility] || account.user&.setting_default_privacy)
|
|
|
|
DistributionWorker.perform_async(reblog.id)
|
|
|
|
unless reblogged_status.local_only?
|
|
Pubsubhubbub::DistributionWorker.perform_async(reblog.stream_entry.id)
|
|
ActivityPub::DistributionWorker.perform_async(reblog.id)
|
|
end
|
|
|
|
create_notification(reblog)
|
|
bump_potential_friendship(account, reblog)
|
|
|
|
reblog
|
|
end
|
|
|
|
private
|
|
|
|
def create_notification(reblog)
|
|
reblogged_status = reblog.reblog
|
|
|
|
if reblogged_status.account.local?
|
|
LocalNotificationWorker.perform_async(reblogged_status.account_id, reblog.id, reblog.class.name)
|
|
elsif reblogged_status.account.ostatus?
|
|
NotificationWorker.perform_async(stream_entry_to_xml(reblog.stream_entry), reblog.account_id, reblogged_status.account_id)
|
|
elsif reblogged_status.account.activitypub? && !reblogged_status.account.following?(reblog.account)
|
|
ActivityPub::DeliveryWorker.perform_async(build_json(reblog), reblog.account_id, reblogged_status.account.inbox_url)
|
|
end
|
|
end
|
|
|
|
def bump_potential_friendship(account, reblog)
|
|
ActivityTracker.increment('activity:interactions')
|
|
return if account.following?(reblog.reblog.account_id)
|
|
PotentialFriendshipTracker.record(account.id, reblog.reblog.account_id, :reblog)
|
|
end
|
|
|
|
def build_json(reblog)
|
|
Oj.dump(ActivityPub::LinkedDataSignature.new(ActiveModelSerializers::SerializableResource.new(
|
|
reblog,
|
|
serializer: ActivityPub::ActivitySerializer,
|
|
adapter: ActivityPub::Adapter
|
|
).as_json).sign!(reblog.account))
|
|
end
|
|
end
|