class Finicity::V1::Request::InteractiveRefreshAccountWithMfa

Attributes

account_id[RW]

Attributes

customer_id[RW]

Attributes

mfa_credentials[RW]

Attributes

mfa_session[RW]

Attributes

token[RW]

Attributes

Public Class Methods

new(token, mfa_session, customer_id, account_id, mfa_credentials) click to toggle source

Instance Methods

# File lib/finicity/v1/request/interactive_refresh_account_with_mfa.rb, line 22
def initialize(token, mfa_session, customer_id, account_id, mfa_credentials)
  @account_id = account_id
  @customer_id = customer_id
  @mfa_credentials = mfa_credentials
  @mfa_session = mfa_session
  @token = token
end

Public Instance Methods

body() click to toggle source
# File lib/finicity/v1/request/interactive_refresh_account_with_mfa.rb, line 34
def body
  builder = ::Nokogiri::XML::Builder.new do |xml|
    xml.mfaChallenges {
      xml.questions {
        mfa_credentials.each do |mfa_credential|
          xml.question {
            xml.text_(mfa_credential[:text])
            xml.answer(mfa_credential[:answer])
          }
        end
      }
    }
  end

  builder.to_xml
end
headers() click to toggle source
# File lib/finicity/v1/request/interactive_refresh_account_with_mfa.rb, line 51
def headers
  {
    'Finicity-App-Key' => ::Finicity.config.app_key,
    'Finicity-App-Token' => token,
    'MFA-Session' => mfa_session,
    'Content-Type' => 'application/xml'
  }
end
interactive_refresh_account_with_mfa() click to toggle source
# File lib/finicity/v1/request/interactive_refresh_account_with_mfa.rb, line 30
def interactive_refresh_account_with_mfa
  http_client.post(url, body, headers)
end
url() click to toggle source
# File lib/finicity/v1/request/interactive_refresh_account_with_mfa.rb, line 60
def url
  ::URI.join(
    ::Finicity.config.base_url,
    'v1/',
    'customers/',
    "#{customer_id}/",
    'accounts/',
    "#{account_id}/",
    'mfa'
  )
end