mirror of
https://github.com/lunaisnotaboy/mastodon.git
synced 2024-11-04 22:14:34 +00:00
8cf7006d4e
* Move ActivityPub::FetchRemoteAccountService to ActivityPub::FetchRemoteActorService ActivityPub::FetchRemoteAccountService is kept as a wrapper for when the actor is specifically required to be an Account * Refactor SignatureVerification to allow non-Account actors * fixup! Move ActivityPub::FetchRemoteAccountService to ActivityPub::FetchRemoteActorService * Refactor ActivityPub::FetchRemoteKeyService to potentially return non-Account actors * Refactor inbound ActivityPub payload processing to accept non-Account actors * Refactor inbound ActivityPub processing to accept activities relayed through non-Account * Refactor how Account key URIs are built * Refactor Request and drop unused key_id_format parameter * Rename ActivityPub::Dereferencer `signature_account` to `signature_actor`
88 lines
2.2 KiB
Ruby
88 lines
2.2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class ActivityPub::OutboxesController < ActivityPub::BaseController
|
|
LIMIT = 20
|
|
|
|
include SignatureVerification
|
|
include AccountOwnedConcern
|
|
|
|
before_action :require_account_signature!, if: :authorized_fetch_mode?
|
|
before_action :set_statuses
|
|
before_action :set_cache_headers
|
|
|
|
def show
|
|
if page_requested?
|
|
expires_in(1.minute, public: public_fetch_mode? && signed_request_account.nil?)
|
|
else
|
|
expires_in(3.minutes, public: public_fetch_mode?)
|
|
end
|
|
render json: outbox_presenter, serializer: ActivityPub::OutboxSerializer, adapter: ActivityPub::Adapter, content_type: 'application/activity+json'
|
|
end
|
|
|
|
private
|
|
|
|
def outbox_presenter
|
|
if page_requested?
|
|
ActivityPub::CollectionPresenter.new(
|
|
id: outbox_url(**page_params),
|
|
type: :ordered,
|
|
part_of: outbox_url,
|
|
prev: prev_page,
|
|
next: next_page,
|
|
items: @statuses
|
|
)
|
|
else
|
|
ActivityPub::CollectionPresenter.new(
|
|
id: outbox_url,
|
|
type: :ordered,
|
|
size: @account.statuses_count,
|
|
first: outbox_url(page: true),
|
|
last: outbox_url(page: true, min_id: 0)
|
|
)
|
|
end
|
|
end
|
|
|
|
def outbox_url(**kwargs)
|
|
if params[:account_username].present?
|
|
account_outbox_url(@account, **kwargs)
|
|
else
|
|
instance_actor_outbox_url(**kwargs)
|
|
end
|
|
end
|
|
|
|
def next_page
|
|
outbox_url(page: true, max_id: @statuses.last.id) if @statuses.size == LIMIT
|
|
end
|
|
|
|
def prev_page
|
|
outbox_url(page: true, min_id: @statuses.first.id) unless @statuses.empty?
|
|
end
|
|
|
|
def set_statuses
|
|
return unless page_requested?
|
|
|
|
@statuses = cache_collection_paginated_by_id(
|
|
AccountStatusesFilter.new(@account, signed_request_account).results,
|
|
Status,
|
|
LIMIT,
|
|
params_slice(:max_id, :min_id, :since_id)
|
|
)
|
|
end
|
|
|
|
def page_requested?
|
|
truthy_param?(:page)
|
|
end
|
|
|
|
def page_params
|
|
{ page: true, max_id: params[:max_id], min_id: params[:min_id] }.compact
|
|
end
|
|
|
|
def set_account
|
|
@account = params[:account_username].present? ? Account.find_local!(username_param) : Account.representative
|
|
end
|
|
|
|
def set_cache_headers
|
|
response.headers['Vary'] = 'Signature' if authorized_fetch_mode? || page_requested?
|
|
end
|
|
end
|