2019-01-16 16:28:25 +01:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
# API Controller for resources of type Credit
|
|
|
|
# Credits are used to give free reservations to users
|
2016-03-23 18:39:41 +01:00
|
|
|
class API::CreditsController < API::ApiController
|
|
|
|
before_action :authenticate_user!
|
2019-01-16 16:28:25 +01:00
|
|
|
before_action :set_credit, only: %i[show update destroy]
|
2016-03-23 18:39:41 +01:00
|
|
|
|
|
|
|
def index
|
|
|
|
authorize Credit
|
2019-01-16 16:28:25 +01:00
|
|
|
@credits = if params
|
|
|
|
Credit.includes(:creditable).where(params.permit(:creditable_type))
|
|
|
|
else
|
|
|
|
Credit.includes(:creditable).all
|
|
|
|
end
|
2016-03-23 18:39:41 +01:00
|
|
|
end
|
|
|
|
|
|
|
|
def create
|
|
|
|
authorize Credit
|
|
|
|
@credit = Credit.new(credit_params)
|
|
|
|
if @credit.save
|
|
|
|
render :show, status: :created, location: @credit
|
|
|
|
else
|
|
|
|
render json: @credit.errors, status: :unprocessable_entity
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def update
|
|
|
|
authorize Credit
|
|
|
|
if @credit.update(credit_params)
|
|
|
|
render :show, status: :ok, location: @credit
|
|
|
|
else
|
|
|
|
render json: @credit.errors, status: :unprocessable_entity
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def destroy
|
|
|
|
authorize Credit
|
|
|
|
@credit.destroy
|
|
|
|
head :no_content
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
2019-01-16 16:28:25 +01:00
|
|
|
def set_credit
|
|
|
|
@credit = Credit.find(params[:id])
|
|
|
|
end
|
|
|
|
|
|
|
|
def credit_params
|
|
|
|
params.require(:credit).permit!
|
|
|
|
end
|
2016-03-23 18:39:41 +01:00
|
|
|
end
|