2019-01-16 16:28:25 +01:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
# API Controller for resources of type Subscription
|
2016-03-23 18:39:41 +01:00
|
|
|
class API::SubscriptionsController < API::ApiController
|
|
|
|
include FablabConfiguration
|
|
|
|
|
2018-12-06 18:26:01 +01:00
|
|
|
before_action :set_subscription, only: %i[show edit update destroy]
|
2016-03-23 18:39:41 +01:00
|
|
|
before_action :authenticate_user!
|
|
|
|
|
|
|
|
def show
|
|
|
|
authorize @subscription
|
|
|
|
end
|
|
|
|
|
|
|
|
def create
|
|
|
|
if fablab_plans_deactivated?
|
|
|
|
head 403
|
|
|
|
else
|
2019-01-14 12:57:31 +01:00
|
|
|
method = current_user.admin? ? :local : :stripe
|
2019-06-05 07:58:49 +02:00
|
|
|
user_id = current_user.admin? ? params[:subscription][:user_id] : current_user.id
|
2018-12-06 18:26:01 +01:00
|
|
|
|
|
|
|
@subscription = Subscription.new(subscription_params)
|
2019-06-12 12:22:38 +02:00
|
|
|
is_subscribe = Subscriptions::Subscribe.new(current_user.invoicing_profile.id, user_id)
|
2018-12-10 17:20:23 +01:00
|
|
|
.pay_and_save(@subscription, method, coupon_params[:coupon_code], true)
|
2018-12-06 18:26:01 +01:00
|
|
|
|
2016-03-23 18:39:41 +01:00
|
|
|
if is_subscribe
|
|
|
|
render :show, status: :created, location: @subscription
|
|
|
|
else
|
2017-12-14 16:39:53 +01:00
|
|
|
render json: @subscription.errors, status: :unprocessable_entity
|
2016-03-23 18:39:41 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def update
|
|
|
|
authorize @subscription
|
|
|
|
|
2018-12-10 13:24:00 +01:00
|
|
|
free_days = params[:subscription][:free] || false
|
2016-03-23 18:39:41 +01:00
|
|
|
|
2019-06-12 12:22:38 +02:00
|
|
|
res = Subscriptions::Subscribe.new(current_user.invoicing_profile.id)
|
2018-12-11 17:27:25 +01:00
|
|
|
.extend_subscription(@subscription, subscription_update_params[:expired_at], free_days)
|
|
|
|
if res.is_a?(Subscription)
|
|
|
|
@subscription = res
|
|
|
|
render status: :created
|
|
|
|
elsif res
|
2016-03-23 18:39:41 +01:00
|
|
|
render status: :ok
|
|
|
|
else
|
|
|
|
render status: :unprocessable_entity
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
2018-12-06 18:26:01 +01:00
|
|
|
# Use callbacks to share common setup or constraints between actions.
|
|
|
|
def set_subscription
|
|
|
|
@subscription = Subscription.find(params[:id])
|
|
|
|
end
|
2016-03-23 18:39:41 +01:00
|
|
|
|
2018-12-06 18:26:01 +01:00
|
|
|
# Never trust parameters from the scary internet, only allow the white list through.
|
|
|
|
def subscription_params
|
2019-06-04 16:50:23 +02:00
|
|
|
params.require(:subscription).permit(:plan_id, :card_token)
|
2018-12-06 18:26:01 +01:00
|
|
|
end
|
2016-08-11 18:17:28 +02:00
|
|
|
|
2018-12-06 18:26:01 +01:00
|
|
|
def coupon_params
|
|
|
|
params.permit(:coupon_code)
|
|
|
|
end
|
2016-04-11 18:37:06 +02:00
|
|
|
|
2018-12-06 18:26:01 +01:00
|
|
|
def subscription_update_params
|
|
|
|
params.require(:subscription).permit(:expired_at)
|
|
|
|
end
|
|
|
|
|
2019-01-16 16:28:25 +01:00
|
|
|
# TODO, refactor subscriptions logic and move this in model/validator
|
2018-12-06 18:26:01 +01:00
|
|
|
def valid_card_token?(token)
|
|
|
|
Stripe::Token.retrieve(token)
|
|
|
|
rescue Stripe::InvalidRequestError => e
|
|
|
|
@subscription.errors[:card_token] << e.message
|
|
|
|
false
|
|
|
|
end
|
2016-03-23 18:39:41 +01:00
|
|
|
end
|