module Quaderno::Behavior::Payment::InstanceMethods

Public Instance Methods

add_payment(params = {}) click to toggle source
# File lib/quaderno-ruby/behavior/payment.rb, line 11
def add_payment(params = {})
  if (params.keys.map(&:to_s) & %w(auth_token access_token api_url mode api_model)).any?
    self.authentication_data = get_authentication(params.merge(api_model: api_model))
    params = params.dup.delete_if { |k, _| %w(auth_token access_token api_url mode api_model).include? k.to_s }
  end

  response = api_model.post("#{authentication_data[:url]}#{api_model.api_path}/#{id}/payments.json",
    body: params,
    basic_auth: authentication_data[:basic_auth],
    headers: self.class.default_headers.merge(authentication_data[:headers])
  )

  api_model.check_exception_for(response, { rate_limit: true, subdomain_or_token: true, required_fields: true })

  instance = Quaderno::Payment.new(response.parsed_response)
  self.payments << instance

  instance.rate_limit_info = response

  instance
end
remove_payment(payment_id, options = nil) click to toggle source
# File lib/quaderno-ruby/behavior/payment.rb, line 33
def remove_payment(payment_id, options = nil)
  self.authentication_data = get_authentication(options.merge(api_model: api_model)) if options.is_a?(Hash)

  response = HTTParty.delete("#{authentication_data[:url]}#{api_model.api_path}/#{id}/payments/#{payment_id}.json",
    basic_auth: authentication_data[:basic_auth],
    headers: self.class.default_headers.merge(authentication_data[:headers])
  )

  api_model.check_exception_for(response, { rate_limit: true, subdomain_or_token: true, id: true })

  self.payments.delete_if { |payment| payment.id == payment_id }

  hash = { deleted: true, id: payment_id}

  object = Quaderno::Payment.new(hash)
  object.rate_limit_info = response

  object
end