Refactor api/v1/notifications controller (#3470)
parent
6237abaaa3
commit
7b8b5b9f1e
|
@ -3,40 +3,81 @@
|
||||||
class Api::V1::NotificationsController < ApiController
|
class Api::V1::NotificationsController < ApiController
|
||||||
before_action -> { doorkeeper_authorize! :read }
|
before_action -> { doorkeeper_authorize! :read }
|
||||||
before_action :require_user!
|
before_action :require_user!
|
||||||
|
after_action :insert_pagination_headers, only: :index
|
||||||
|
|
||||||
respond_to :json
|
respond_to :json
|
||||||
|
|
||||||
DEFAULT_NOTIFICATIONS_LIMIT = 15
|
DEFAULT_NOTIFICATIONS_LIMIT = 15
|
||||||
|
|
||||||
def index
|
def index
|
||||||
@notifications = Notification.where(account: current_account).browserable(exclude_types).paginate_by_max_id(limit_param(DEFAULT_NOTIFICATIONS_LIMIT), params[:max_id], params[:since_id])
|
@notifications = load_notifications
|
||||||
@notifications = cache_collection(@notifications, Notification)
|
set_maps_for_notification_target_statuses
|
||||||
statuses = @notifications.select { |n| !n.target_status.nil? }.map(&:target_status)
|
|
||||||
|
|
||||||
set_maps(statuses)
|
|
||||||
|
|
||||||
next_path = api_v1_notifications_url(pagination_params(max_id: @notifications.last.id)) unless @notifications.empty?
|
|
||||||
prev_path = api_v1_notifications_url(pagination_params(since_id: @notifications.first.id)) unless @notifications.empty?
|
|
||||||
|
|
||||||
set_pagination_headers(next_path, prev_path)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def show
|
def show
|
||||||
@notification = Notification.where(account: current_account).find(params[:id])
|
@notification = current_account.notifications.find(params[:id])
|
||||||
end
|
end
|
||||||
|
|
||||||
def clear
|
def clear
|
||||||
Notification.where(account: current_account).delete_all
|
current_account.notifications.delete_all
|
||||||
render_empty
|
render_empty
|
||||||
end
|
end
|
||||||
|
|
||||||
def dismiss
|
def dismiss
|
||||||
Notification.find_by!(account: current_account, id: params[:id]).destroy!
|
current_account.notifications.find_by!(id: params[:id]).destroy!
|
||||||
render_empty
|
render_empty
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
|
def load_notifications
|
||||||
|
cache_collection paginated_notifications, Notification
|
||||||
|
end
|
||||||
|
|
||||||
|
def paginated_notifications
|
||||||
|
browserable_account_notifications.paginate_by_max_id(
|
||||||
|
limit_param(DEFAULT_NOTIFICATIONS_LIMIT),
|
||||||
|
params[:max_id],
|
||||||
|
params[:since_id]
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
|
def browserable_account_notifications
|
||||||
|
current_account.notifications.browserable(exclude_types)
|
||||||
|
end
|
||||||
|
|
||||||
|
def set_maps_for_notification_target_statuses
|
||||||
|
set_maps target_statuses_from_notifications
|
||||||
|
end
|
||||||
|
|
||||||
|
def target_statuses_from_notifications
|
||||||
|
@notifications.select { |notification| !notification.target_status.nil? }.map(&:target_status)
|
||||||
|
end
|
||||||
|
|
||||||
|
def insert_pagination_headers
|
||||||
|
set_pagination_headers(next_path, prev_path)
|
||||||
|
end
|
||||||
|
|
||||||
|
def next_path
|
||||||
|
unless @notifications.empty?
|
||||||
|
api_v1_notifications_url pagination_params(max_id: pagination_max_id)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def prev_path
|
||||||
|
unless @notifications.empty?
|
||||||
|
api_v1_notifications_url pagination_params(since_id: pagination_since_id)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def pagination_max_id
|
||||||
|
@notifications.last.id
|
||||||
|
end
|
||||||
|
|
||||||
|
def pagination_since_id
|
||||||
|
@notifications.first.id
|
||||||
|
end
|
||||||
|
|
||||||
def exclude_types
|
def exclude_types
|
||||||
val = params.permit(exclude_types: [])[:exclude_types] || []
|
val = params.permit(exclude_types: [])[:exclude_types] || []
|
||||||
val = [val] unless val.is_a?(Enumerable)
|
val = [val] unless val.is_a?(Enumerable)
|
||||||
|
|
Loading…
Reference in New Issue