summaryrefslogtreecommitdiff
path: root/app/controllers/solidus_subscriptions/api/v1/subscriptions_controller.rb
diff options
context:
space:
mode:
Diffstat (limited to 'app/controllers/solidus_subscriptions/api/v1/subscriptions_controller.rb')
-rw-r--r--app/controllers/solidus_subscriptions/api/v1/subscriptions_controller.rb12
1 files changed, 12 insertions, 0 deletions
diff --git a/app/controllers/solidus_subscriptions/api/v1/subscriptions_controller.rb b/app/controllers/solidus_subscriptions/api/v1/subscriptions_controller.rb
index 4cd698e..0ff53ba 100644
--- a/app/controllers/solidus_subscriptions/api/v1/subscriptions_controller.rb
+++ b/app/controllers/solidus_subscriptions/api/v1/subscriptions_controller.rb
@@ -6,6 +6,18 @@ module SolidusSubscriptions
class SubscriptionsController < BaseController
protect_from_forgery unless: -> { request.format.json? }
+ def create
+ store = params[:store_id].nil? ? ::Spree::Store.default : ::Spree::Store.find(id: params[:store_id])
+ attributes = subscription_params.merge(user: current_api_user, store: store)
+ subscription = SolidusSubscriptions::Subscription.new(attributes)
+
+ if subscription.save
+ render json: subscription.to_json(include: [:line_items, :shipping_address, :billing_address])
+ else
+ render json: subscription.errors.to_json, status: :unprocessable_entity
+ end
+ end
+
def update
load_subscription