|
|
|
@ -12,7 +12,7 @@ class ActivityPub::CollectionsController < ActivityPub::BaseController |
|
|
|
|
|
|
|
|
|
def show |
|
|
|
|
expires_in 3.minutes, public: public_fetch_mode? |
|
|
|
|
render_with_cache json: collection_presenter, content_type: 'application/activity+json', serializer: ActivityPub::CollectionSerializer, adapter: ActivityPub::Adapter, skip_activities: true |
|
|
|
|
render_with_cache json: collection_presenter, content_type: 'application/activity+json', serializer: ActivityPub::CollectionSerializer, adapter: ActivityPub::Adapter |
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
private |
|
|
|
@ -20,17 +20,9 @@ class ActivityPub::CollectionsController < ActivityPub::BaseController |
|
|
|
|
def set_items |
|
|
|
|
case params[:id] |
|
|
|
|
when 'featured' |
|
|
|
|
@items = begin |
|
|
|
|
# Because in public fetch mode we cache the response, there would be no |
|
|
|
|
# benefit from performing the check below, since a blocked account or domain |
|
|
|
|
# would likely be served the cache from the reverse proxy anyway |
|
|
|
|
|
|
|
|
|
if authorized_fetch_mode? && !signed_request_account.nil? && (@account.blocking?(signed_request_account) || (!signed_request_account.domain.nil? && @account.domain_blocking?(signed_request_account.domain))) |
|
|
|
|
[] |
|
|
|
|
else |
|
|
|
|
cache_collection(@account.pinned_statuses, Status) |
|
|
|
|
end |
|
|
|
|
end |
|
|
|
|
@items = for_signed_account { cache_collection(@account.pinned_statuses, Status) } |
|
|
|
|
when 'tags' |
|
|
|
|
@items = for_signed_account { @account.featured_tags } |
|
|
|
|
when 'devices' |
|
|
|
|
@items = @account.devices |
|
|
|
|
else |
|
|
|
@ -40,7 +32,7 @@ class ActivityPub::CollectionsController < ActivityPub::BaseController |
|
|
|
|
|
|
|
|
|
def set_size |
|
|
|
|
case params[:id] |
|
|
|
|
when 'featured', 'devices' |
|
|
|
|
when 'featured', 'devices', 'tags' |
|
|
|
|
@size = @items.size |
|
|
|
|
else |
|
|
|
|
not_found |
|
|
|
@ -51,7 +43,7 @@ class ActivityPub::CollectionsController < ActivityPub::BaseController |
|
|
|
|
case params[:id] |
|
|
|
|
when 'featured' |
|
|
|
|
@type = :ordered |
|
|
|
|
when 'devices' |
|
|
|
|
when 'devices', 'tags' |
|
|
|
|
@type = :unordered |
|
|
|
|
else |
|
|
|
|
not_found |
|
|
|
@ -66,4 +58,16 @@ class ActivityPub::CollectionsController < ActivityPub::BaseController |
|
|
|
|
items: @items |
|
|
|
|
) |
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
def for_signed_account |
|
|
|
|
# Because in public fetch mode we cache the response, there would be no |
|
|
|
|
# benefit from performing the check below, since a blocked account or domain |
|
|
|
|
# would likely be served the cache from the reverse proxy anyway |
|
|
|
|
|
|
|
|
|
if authorized_fetch_mode? && !signed_request_account.nil? && (@account.blocking?(signed_request_account) || (!signed_request_account.domain.nil? && @account.domain_blocking?(signed_request_account.domain))) |
|
|
|
|
[] |
|
|
|
|
else |
|
|
|
|
yield |
|
|
|
|
end |
|
|
|
|
end |
|
|
|
|
end |
|
|
|
|