Module: Vpago::PaymentProcessable
- Included in:
- PaymentProcessor
- Defined in:
- app/services/vpago/payment_processable.rb
Instance Method Summary collapse
-
#available_actions ⇒ Object
To check available actions, see app/models/spree/vpago_payment_source.rb.
- #enqueue_capture_payment_if_available! ⇒ Object
- #enqueue_void_or_cancel_payment_if_available! ⇒ Object
- #extract_completer_failure_reason_code(error) ⇒ Object
- #failure(error) ⇒ Object
-
#log_process(method, *args) ⇒ Object
example.
- #success? ⇒ Boolean
- #user_informer ⇒ Object
Instance Method Details
#available_actions ⇒ Object
To check available actions, see app/models/spree/vpago_payment_source.rb
16 17 18 |
# File 'app/services/vpago/payment_processable.rb', line 16 def available_actions @payment.actions end |
#enqueue_capture_payment_if_available! ⇒ Object
3 4 5 |
# File 'app/services/vpago/payment_processable.rb', line 3 def enqueue_capture_payment_if_available! Vpago::PaymentCapturerJob.perform_later(@payment.id) if available_actions.include?('capture') end |
#enqueue_void_or_cancel_payment_if_available! ⇒ Object
7 8 9 10 11 12 13 |
# File 'app/services/vpago/payment_processable.rb', line 7 def enqueue_void_or_cancel_payment_if_available! if available_actions.include?('void') Vpago::PaymentVoiderJob.perform_later(@payment.id) elsif available_actions.include?('cancel') Vpago::PaymentCancelerJob.perform_later(@payment.id) end end |
#extract_completer_failure_reason_code(error) ⇒ Object
20 21 22 23 24 25 |
# File 'app/services/vpago/payment_processable.rb', line 20 def extract_completer_failure_reason_code(error) return :some_line_items_are_out_of_stock if error.respond_to?(:to_h) && error.to_h[:base]&.include?(Spree.t(:insufficient_stock_lines_present)) return :some_variants_are_discontinued if error.respond_to?(:to_h) && error.to_h[:base]&.include?(Spree.t(:discontinued_variants_present)) :unable_to_complete_order end |
#failure(error) ⇒ Object
48 49 50 |
# File 'app/services/vpago/payment_processable.rb', line 48 def failure(error) @error = error end |
#log_process(method, *args) ⇒ Object
example. Started Vpago::PaymentProcessor#process_payment! for payment_number: PX81YZX with args: {} Completed Vpago::PaymentProcessor#process_payment! for payment_number: PX81YZX in 2000ms
30 31 32 33 34 35 36 37 38 |
# File 'app/services/vpago/payment_processable.rb', line 30 def log_process(method, *args) start_time = Time.now Rails.logger.error("Started #{self.class}##{method} for payment_number: #{@payment.number} with args: #{args}") yield duration_ms = (Time.now - start_time) * 1000 Rails.logger.error("Completed #{self.class}##{method} for payment_number: #{@payment.number} in #{duration_ms}ms") end |
#success? ⇒ Boolean
44 45 46 |
# File 'app/services/vpago/payment_processable.rb', line 44 def success? @error.nil? end |
#user_informer ⇒ Object
40 41 42 |
# File 'app/services/vpago/payment_processable.rb', line 40 def user_informer @user_informer ||= ::Vpago::UserInformers::Firebase.new(@payment.order) end |