Class: Spree::Admin::PaymentsController
- Inherits:
-
BaseController
- Object
- BaseController
- BaseController
- Spree::Admin::PaymentsController
- Includes:
- Backend::Callbacks
- Defined in:
- app/controllers/spree/admin/payments_controller.rb
Instance Method Summary collapse
Instance Method Details
#create ⇒ Object
25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 |
# File 'app/controllers/spree/admin/payments_controller.rb', line 25 def create invoke_callbacks(:create, :before) begin if @payment_method.store_credit? Spree::Dependencies.checkout_add_store_credit_service.constantize.call(order: @order) payments = @order.payments.store_credits.valid else @payment ||= @order.payments.build(object_params) if @payment.payment_method.source_required? && params[:card].present? && params[:card] != 'new' @payment.source = @payment.payment_method.payment_source_class.find_by(id: params[:card]) end @payment.save payments = [@payment] end if payments && (saved_payments = payments.select &:persisted?).any? invoke_callbacks(:create, :after) # Transition order as far as it will go. while @order.next; end # If "@order.next" didn't trigger payment processing already (e.g. if the order was # already complete) then trigger it manually now saved_payments.each { |payment| payment.process! if payment.reload.checkout? && @order.complete? } flash[:success] = (saved_payments.first, :successfully_created) redirect_to admin_order_payments_path(@order) else @payment ||= @order.payments.build(object_params) invoke_callbacks(:create, :fails) flash[:error] = Spree.t(:payment_could_not_be_created) render :new end rescue Spree::Core::GatewayError => e invoke_callbacks(:create, :fails) flash[:error] = e..to_s redirect_to new_admin_order_payment_path(@order) end end |
#fire ⇒ Object
65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 |
# File 'app/controllers/spree/admin/payments_controller.rb', line 65 def fire return unless event = params[:e] and @payment.payment_source # Because we have a transition method also called void, we do this to avoid conflicts. event = 'void_transaction' if event == 'void' if @payment.send("#{event}!") flash[:success] = Spree.t(:payment_updated) else flash[:error] = Spree.t(:cannot_perform_operation) end rescue Spree::Core::GatewayError => ge flash[:error] = ge..to_s ensure redirect_to admin_order_payments_path(@order) end |
#index ⇒ Object
13 14 15 16 17 |
# File 'app/controllers/spree/admin/payments_controller.rb', line 13 def index @payments = @order.payments.includes(refunds: :reason) @refunds = @payments.flat_map(&:refunds) redirect_to new_admin_order_payment_url(@order) if @payments.empty? end |
#new ⇒ Object
19 20 21 22 23 |
# File 'app/controllers/spree/admin/payments_controller.rb', line 19 def new # Move order to payment state in order to capture tax generated on shipments @order.next if @order.can_go_to_state?('payment') @payment = @order.payments.build end |