statuses_controller.rb 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. # frozen_string_literal: true
  2. class Api::V1::Filters::StatusesController < Api::BaseController
  3. before_action -> { doorkeeper_authorize! :read, :'read:filters' }, only: [:index, :show]
  4. before_action -> { doorkeeper_authorize! :write, :'write:filters' }, except: [:index, :show]
  5. before_action :require_user!
  6. before_action :set_status_filters, only: :index
  7. before_action :set_status_filter, only: [:show, :destroy]
  8. def index
  9. render json: @status_filters, each_serializer: REST::FilterStatusSerializer
  10. end
  11. def create
  12. @status_filter = current_account.custom_filters.find(params[:filter_id]).statuses.create!(resource_params)
  13. render json: @status_filter, serializer: REST::FilterStatusSerializer
  14. end
  15. def show
  16. render json: @status_filter, serializer: REST::FilterStatusSerializer
  17. end
  18. def destroy
  19. @status_filter.destroy!
  20. render_empty
  21. end
  22. private
  23. def set_status_filters
  24. filter = current_account.custom_filters.includes(:statuses).find(params[:filter_id])
  25. @status_filters = filter.statuses
  26. end
  27. def set_status_filter
  28. @status_filter = CustomFilterStatus.includes(:custom_filter).where(custom_filter: { account: current_account }).find(params[:id])
  29. end
  30. def resource_params
  31. params.permit(:status_id)
  32. end
  33. end