The code powering m.abunchtell.com https://m.abunchtell.com
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

64 lines
1.5 KiB

  1. # frozen_string_literal: true
  2. class Api::V1::Timelines::DirectController < Api::BaseController
  3. before_action -> { doorkeeper_authorize! :read, :'read:statuses' }, only: [:show]
  4. before_action :require_user!, only: [:show]
  5. after_action :insert_pagination_headers, unless: -> { @statuses.empty? }
  6. respond_to :json
  7. def show
  8. @statuses = load_statuses
  9. render json: @statuses, each_serializer: REST::StatusSerializer, relationships: StatusRelationshipsPresenter.new(@statuses, current_user&.account_id)
  10. end
  11. private
  12. def load_statuses
  13. cached_direct_statuses
  14. end
  15. def cached_direct_statuses
  16. cache_collection direct_statuses, Status
  17. end
  18. def direct_statuses
  19. direct_timeline_statuses
  20. end
  21. def direct_timeline_statuses
  22. # this query requires built in pagination.
  23. Status.as_direct_timeline(
  24. current_account,
  25. limit_param(DEFAULT_STATUSES_LIMIT),
  26. params[:max_id],
  27. params[:since_id],
  28. true # returns array of cache_ids object
  29. )
  30. end
  31. def insert_pagination_headers
  32. set_pagination_headers(next_path, prev_path)
  33. end
  34. def pagination_params(core_params)
  35. params.permit(:local, :limit).merge(core_params)
  36. end
  37. def next_path
  38. api_v1_timelines_direct_url pagination_params(max_id: pagination_max_id)
  39. end
  40. def prev_path
  41. api_v1_timelines_direct_url pagination_params(since_id: pagination_since_id)
  42. end
  43. def pagination_max_id
  44. @statuses.last.id
  45. end
  46. def pagination_since_id
  47. @statuses.first.id
  48. end
  49. end