44 lines
1.0 KiB
Ruby
44 lines
1.0 KiB
Ruby
|
# frozen_string_literal: true
|
||
|
|
||
|
class Api::V1::ListsController < Api::BaseController
|
||
|
before_action -> { doorkeeper_authorize! :read, :'read:lists' }, only: [:index, :show]
|
||
|
before_action -> { doorkeeper_authorize! :write, :'write:lists' }, except: [:index, :show]
|
||
|
|
||
|
before_action :require_user!
|
||
|
before_action :set_list, except: [:index, :create]
|
||
|
|
||
|
def index
|
||
|
@lists = List.where(account: current_account).all
|
||
|
render json: @lists, each_serializer: REST::ListSerializer
|
||
|
end
|
||
|
|
||
|
def show
|
||
|
render json: @list, serializer: REST::ListSerializer
|
||
|
end
|
||
|
|
||
|
def create
|
||
|
@list = List.create!(list_params.merge(account: current_account))
|
||
|
render json: @list, serializer: REST::ListSerializer
|
||
|
end
|
||
|
|
||
|
def update
|
||
|
@list.update!(list_params)
|
||
|
render json: @list, serializer: REST::ListSerializer
|
||
|
end
|
||
|
|
||
|
def destroy
|
||
|
@list.destroy!
|
||
|
render_empty
|
||
|
end
|
||
|
|
||
|
private
|
||
|
|
||
|
def set_list
|
||
|
@list = List.where(account: current_account).find(params[:id])
|
||
|
end
|
||
|
|
||
|
def list_params
|
||
|
params.permit(:title)
|
||
|
end
|
||
|
end
|