class CartController < BaseController before_action :check_authorization def populate order = current_order(true) cart_service = CartService.new(order) cart_service.populate(params.slice(:variants, :quantity)) if cart_service.valid? order.cap_quantity_at_stock! order.recreate_all_fees! variant_ids = order.line_items.pluck(:variant_id) render json: { error: false, stock_levels: VariantsStockLevels.new.call(order, variant_ids) }, status: :ok else render json: { error: cart_service.errors.full_messages.join(",") }, status: :precondition_failed end end private def check_authorization session[:access_token] ||= params[:token] order = Spree::Order.find_by(number: params[:id]) || current_order if order authorize! :edit, order, session[:access_token] else authorize! :create, Spree::Order end end end