1
0
mirror of https://github.com/LaCasemate/fab-manager.git synced 2025-01-21 10:52:21 +01:00
fab-manager/app/controllers/api/coupons_controller.rb
2016-08-16 18:12:13 +02:00

88 lines
2.0 KiB
Ruby

class API::CouponsController < API::ApiController
before_action :authenticate_user!
before_action :set_coupon, only: [:show, :update, :destroy]
def index
@coupons = Coupon.all
end
def show
end
def create
authorize Coupon
@coupon = Coupon.new(coupon_params)
if @coupon.save
render :show, status: :created, location: @coupon
else
render json: @coupon.errors, status: :unprocessable_entity
end
end
def validate
@coupon = Coupon.find_by_code(params[:code])
if @coupon.nil?
render json: {status: 'rejected'}, status: :not_found
else
if !current_user.is_admin?
_user_id = current_user.id
else
_user_id = params[:user_id]
end
status = @coupon.status(_user_id)
if status != 'active'
render json: {status: status}, status: :unprocessable_entity
else
render :validate, status: :ok, location: @coupon
end
end
end
def update
authorize Coupon
if @coupon.update(coupon_editable_params)
render :show, status: :ok, location: @coupon
else
render json: @coupon.errors, status: :unprocessable_entity
end
end
def destroy
authorize Coupon
if @coupon.safe_destroy
head :no_content
else
head :unprocessable_entity
end
end
def send_to
authorize Coupon
@coupon = Coupon.find_by_code(params[:coupon_code])
if @coupon.nil?
render json: {error: "no coupon with code #{params[:coupon_code]}"}, status: :not_found
else
if @coupon.send_to(params[:user_id])
render :show, status: :ok, location: @coupon
else
render json: @coupon.errors, status: :unprocessable_entity
end
end
end
private
def set_coupon
@coupon = Coupon.find(params[:id])
end
def coupon_params
params.require(:coupon).permit(:name, :code, :percent_off, :validity_per_user, :valid_until, :max_usages, :active)
end
def coupon_editable_params
params.require(:coupon).permit(:name, :active)
end
end