summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorcesartalves <cesartalvez@gmail.com>2021-05-04 10:59:05 -0300
committercesartalves <cesartalvez@gmail.com>2021-05-04 11:02:49 -0300
commit9f87d809e339d459aa29c6aa62f3033a7c978ee7 (patch)
tree8a517c8be9870d943aebbab4965eba8239b9dc55
parentdafa723b228ec80dfb66a112d495114d29b43e9d (diff)
Introduce Installment OrderCreator configuration
This adds both SolidusSubscriptions.configuration.order_creation_class and SolidusSubscriptions.configuration.order_creation_extra attributes, so that users can add attributes to each Installment Order at Checkout or even override how the Order is created
-rw-r--r--lib/generators/solidus_subscriptions/install/templates/initializer.rb14
-rw-r--r--lib/solidus_subscriptions.rb1
-rw-r--r--lib/solidus_subscriptions/checkout.rb12
-rw-r--r--lib/solidus_subscriptions/configuration.rb13
-rw-r--r--lib/solidus_subscriptions/order_creator.rb26
5 files changed, 53 insertions, 13 deletions
diff --git a/lib/generators/solidus_subscriptions/install/templates/initializer.rb b/lib/generators/solidus_subscriptions/install/templates/initializer.rb
index 3632f08..0abefc9 100644
--- a/lib/generators/solidus_subscriptions/install/templates/initializer.rb
+++ b/lib/generators/solidus_subscriptions/install/templates/initializer.rb
@@ -96,4 +96,18 @@ SolidusSubscriptions.configure do |config|
# with new subscription cycles by clearing any past failed installment when a new one is created
# config.clear_past_installments = true
+
+ # ==================================== Custom Order Creation =====================================
+ #
+ # This settings allows the customization of the creation of each Installment Order and / or
+ # adding additional attributes to the Order
+ #
+ # config.order_creation_class = 'SolidusSubscriptions::OrderCreator'
+ #
+ # this class is initialized and called on the creation of the Order for each Subscription Installment
+ # along with a customizable hash of extra attributes that can also be configured, like below:
+ # config.order_creation_extra_attributes = { channel: 'subscriptions' }
+ #
+ #
+ # config.order_creation_extra_attributes = { }
end
diff --git a/lib/solidus_subscriptions.rb b/lib/solidus_subscriptions.rb
index d5e3d73..9d6457f 100644
--- a/lib/solidus_subscriptions.rb
+++ b/lib/solidus_subscriptions.rb
@@ -26,6 +26,7 @@ require 'solidus_subscriptions/dispatcher/failure_dispatcher'
require 'solidus_subscriptions/dispatcher/out_of_stock_dispatcher'
require 'solidus_subscriptions/dispatcher/payment_failed_dispatcher'
require 'solidus_subscriptions/dispatcher/success_dispatcher'
+require 'solidus_subscriptions/order_creator'
module SolidusSubscriptions
class << self
diff --git a/lib/solidus_subscriptions/checkout.rb b/lib/solidus_subscriptions/checkout.rb
index b71a7b2..15f1a26 100644
--- a/lib/solidus_subscriptions/checkout.rb
+++ b/lib/solidus_subscriptions/checkout.rb
@@ -32,14 +32,8 @@ module SolidusSubscriptions
private
def create_order
- ::Spree::Order.create(
- user: installment.subscription.user,
- email: installment.subscription.user.email,
- store: installment.subscription.store || ::Spree::Store.default,
- subscription_order: true,
- subscription: installment.subscription,
- currency: installment.subscription.currency
- )
+ extra_attributes = SolidusSubscriptions.configuration.order_creation_extra_attributes
+ SolidusSubscriptions.configuration.order_creation_class.new(installment, extra_attributes).call
end
def populate_order(order)
@@ -61,7 +55,7 @@ module SolidusSubscriptions
order.payments.create(
payment_method: installment.subscription.payment_method_to_use,
source: installment.subscription.payment_source_to_use,
- amount: order.total,
+ amount: order.total
)
end
diff --git a/lib/solidus_subscriptions/configuration.rb b/lib/solidus_subscriptions/configuration.rb
index 2606272..5b9aed9 100644
--- a/lib/solidus_subscriptions/configuration.rb
+++ b/lib/solidus_subscriptions/configuration.rb
@@ -4,14 +4,14 @@ module SolidusSubscriptions
class Configuration
attr_accessor(
:maximum_total_skips, :maximum_reprocessing_time, :churn_buster_account_id,
- :churn_buster_api_key, :clear_past_installments, :processing_error_handler,
+ :churn_buster_api_key, :clear_past_installments, :processing_error_handler, :order_creation_extra_attributes
)
attr_writer(
:success_dispatcher_class, :failure_dispatcher_class, :payment_failed_dispatcher_class,
:out_of_stock_dispatcher, :maximum_successive_skips, :reprocessing_interval,
:minimum_cancellation_notice, :processing_queue, :subscription_line_item_attributes,
- :subscription_attributes, :subscribable_class,
+ :subscription_attributes, :subscribable_class, :order_creation_class
)
def success_dispatcher_class
@@ -57,7 +57,7 @@ module SolidusSubscriptions
:subscribable_id,
:interval_length,
:interval_units,
- :end_date,
+ :end_date
]
end
@@ -69,7 +69,7 @@ module SolidusSubscriptions
{
shipping_address_attributes: Spree::PermittedAttributes.address_attributes,
billing_address_attributes: Spree::PermittedAttributes.address_attributes
- },
+ }
]
end
@@ -81,5 +81,10 @@ module SolidusSubscriptions
def churn_buster?
churn_buster_account_id.present? && churn_buster_api_key.present?
end
+
+ def order_creation_class
+ @order_creation_class ||= 'SolidusSubscriptions::OrderCreator'
+ @order_creation_class.constantize
+ end
end
end
diff --git a/lib/solidus_subscriptions/order_creator.rb b/lib/solidus_subscriptions/order_creator.rb
new file mode 100644
index 0000000..97b858a
--- /dev/null
+++ b/lib/solidus_subscriptions/order_creator.rb
@@ -0,0 +1,26 @@
+# frozen_string_literal: true
+
+module SolidusSubscriptions
+ class OrderCreator
+ def initialize(installment, extra_attributes)
+ @installment = installment
+ @extra_attributes = (extra_attributes || {}).symbolize_keys
+ end
+
+ def call
+ ::Spree::Order.create(
+ user: installment.subscription.user,
+ email: installment.subscription.user.email,
+ store: installment.subscription.store || ::Spree::Store.default,
+ subscription_order: true,
+ subscription: installment.subscription,
+ currency: installment.subscription.currency,
+ **extra_attributes
+ )
+ end
+
+ protected
+
+ attr_reader :installment, :extra_attributes
+ end
+end