2016-11-15 17:56:29 +02:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2016-11-09 00:22:44 +02:00
|
|
|
class Api::V1::TimelinesController < ApiController
|
|
|
|
before_action -> { doorkeeper_authorize! :read }
|
|
|
|
before_action :require_user!, only: [:home, :mentions]
|
|
|
|
|
|
|
|
respond_to :json
|
|
|
|
|
|
|
|
def home
|
2017-01-24 05:22:10 +02:00
|
|
|
@statuses = Feed.new(:home, current_account).get(limit_param(DEFAULT_STATUSES_LIMIT), params[:max_id], params[:since_id])
|
2016-11-29 16:49:39 +02:00
|
|
|
@statuses = cache_collection(@statuses)
|
2016-11-09 18:48:44 +02:00
|
|
|
|
2016-11-09 00:22:44 +02:00
|
|
|
set_maps(@statuses)
|
2017-03-30 20:42:33 +03:00
|
|
|
# set_counters_maps(@statuses)
|
|
|
|
# set_account_counters_maps(@statuses.flat_map { |s| [s.account, s.reblog? ? s.reblog.account : nil] }.compact.uniq)
|
2016-11-09 18:48:44 +02:00
|
|
|
|
2017-02-25 04:34:37 +02:00
|
|
|
next_path = api_v1_home_timeline_url(max_id: @statuses.last.id) unless @statuses.empty?
|
2016-11-15 17:56:29 +02:00
|
|
|
prev_path = api_v1_home_timeline_url(since_id: @statuses.first.id) unless @statuses.empty?
|
2016-11-09 18:48:44 +02:00
|
|
|
|
|
|
|
set_pagination_headers(next_path, prev_path)
|
|
|
|
|
2016-11-09 00:22:44 +02:00
|
|
|
render action: :index
|
|
|
|
end
|
|
|
|
|
|
|
|
def public
|
2017-02-07 00:16:20 +02:00
|
|
|
@statuses = Status.as_public_timeline(current_account, params[:local]).paginate_by_max_id(limit_param(DEFAULT_STATUSES_LIMIT), params[:max_id], params[:since_id])
|
2016-11-29 16:49:39 +02:00
|
|
|
@statuses = cache_collection(@statuses)
|
2016-11-09 18:48:44 +02:00
|
|
|
|
2016-11-09 00:22:44 +02:00
|
|
|
set_maps(@statuses)
|
2017-03-30 20:42:33 +03:00
|
|
|
# set_counters_maps(@statuses)
|
|
|
|
# set_account_counters_maps(@statuses.flat_map { |s| [s.account, s.reblog? ? s.reblog.account : nil] }.compact.uniq)
|
2016-11-09 18:48:44 +02:00
|
|
|
|
2017-02-25 04:34:37 +02:00
|
|
|
next_path = api_v1_public_timeline_url(max_id: @statuses.last.id) unless @statuses.empty?
|
2016-11-15 17:56:29 +02:00
|
|
|
prev_path = api_v1_public_timeline_url(since_id: @statuses.first.id) unless @statuses.empty?
|
2016-11-09 18:48:44 +02:00
|
|
|
|
|
|
|
set_pagination_headers(next_path, prev_path)
|
|
|
|
|
2016-11-09 00:22:44 +02:00
|
|
|
render action: :index
|
|
|
|
end
|
|
|
|
|
|
|
|
def tag
|
2016-11-09 18:48:44 +02:00
|
|
|
@tag = Tag.find_by(name: params[:id].downcase)
|
2017-02-07 00:16:20 +02:00
|
|
|
@statuses = @tag.nil? ? [] : Status.as_tag_timeline(@tag, current_account, params[:local]).paginate_by_max_id(limit_param(DEFAULT_STATUSES_LIMIT), params[:max_id], params[:since_id])
|
2016-11-29 16:49:39 +02:00
|
|
|
@statuses = cache_collection(@statuses)
|
2016-11-09 18:48:44 +02:00
|
|
|
|
|
|
|
set_maps(@statuses)
|
2017-03-30 20:42:33 +03:00
|
|
|
# set_counters_maps(@statuses)
|
|
|
|
# set_account_counters_maps(@statuses.flat_map { |s| [s.account, s.reblog? ? s.reblog.account : nil] }.compact.uniq)
|
2016-11-09 18:48:44 +02:00
|
|
|
|
2017-02-25 04:34:37 +02:00
|
|
|
next_path = api_v1_hashtag_timeline_url(params[:id], max_id: @statuses.last.id) unless @statuses.empty?
|
2016-11-15 17:56:29 +02:00
|
|
|
prev_path = api_v1_hashtag_timeline_url(params[:id], since_id: @statuses.first.id) unless @statuses.empty?
|
2016-11-09 18:48:44 +02:00
|
|
|
|
|
|
|
set_pagination_headers(next_path, prev_path)
|
2016-11-09 00:22:44 +02:00
|
|
|
|
|
|
|
render action: :index
|
|
|
|
end
|
2016-11-23 09:34:35 +02:00
|
|
|
|
|
|
|
private
|
|
|
|
|
2016-11-29 16:49:39 +02:00
|
|
|
def cache_collection(raw)
|
|
|
|
super(raw, Status)
|
2016-11-23 09:34:35 +02:00
|
|
|
end
|
2016-11-09 00:22:44 +02:00
|
|
|
end
|