Sha256: cef911d1b96162e1ecfb08dccf4f48941b09e5e3bc6c7cb6c131bb3f30cc3e20
Contents?: true
Size: 1.97 KB
Versions: 13
Compression:
Stored size: 1.97 KB
Contents
module Spree class PaymentMethod < Spree::Base acts_as_paranoid DISPLAY = [:both, :front_end, :back_end] default_scope -> { where(deleted_at: nil) } scope :production, -> { where(environment: 'production') } validates :name, presence: true has_many :payments, class_name: "Spree::Payment", inverse_of: :payment_method has_many :credit_cards, class_name: "Spree::CreditCard" def self.providers Rails.application.config.spree.payment_methods end def provider_class raise ::NotImplementedError, 'You must implement provider_class method for this gateway.' end # The class that will process payments for this payment type, used for @payment.source # e.g. CreditCard in the case of a the Gateway payment type # nil means the payment method doesn't require a source e.g. check def payment_source_class raise ::NotImplementedError, 'You must implement payment_source_class method for this gateway.' end def self.available(display_on = 'both') all.select do |p| p.active && (p.display_on == display_on.to_s || p.display_on.blank?) && (p.environment == Rails.env || p.environment.blank?) end end def self.active? where(type: self.to_s, environment: Rails.env, active: true).count > 0 end def method_type type.demodulize.downcase end def self.find_with_destroyed *args unscoped { find(*args) } end def payment_profiles_supported? false end def source_required? true end # Custom gateways should redefine this method. See Gateway implementation # as an example def reusable_sources(order) [] end def auto_capture? self.auto_capture.nil? ? Spree::Config[:auto_capture] : self.auto_capture end def supports?(source) true end def cancel(response) raise ::NotImplementedError, 'You must implement cancel method for this payment method.' end end end
Version data entries
13 entries across 13 versions & 1 rubygems