mirror of
https://github.com/maybe-finance/maybe.git
synced 2025-08-07 22:45:20 +02:00
Breaks our Plaid sync process out into more manageable classes. Notably, this moves the sync process to a distinct, 2-step flow: 1. Import stage - we first make API calls and import Plaid data to "mirror" tables 2. Processing stage - read the raw data, apply business rules, build internal domain models and sync balances This provides several benefits: - Plaid syncs can now be "replayed" without fetching API data again - Mirror tables provide better audit and debugging capabilities - Eliminates the "all or nothing" sync behavior that is currently in place, which is brittle
25 lines
526 B
Ruby
25 lines
526 B
Ruby
class PlaidAccount::Liabilities::CreditProcessor
|
|
def initialize(plaid_account)
|
|
@plaid_account = plaid_account
|
|
end
|
|
|
|
def process
|
|
return unless credit_data.present?
|
|
|
|
account.credit_card.update!(
|
|
minimum_payment: credit_data.dig("minimum_payment_amount"),
|
|
apr: credit_data.dig("aprs", 0, "apr_percentage")
|
|
)
|
|
end
|
|
|
|
private
|
|
attr_reader :plaid_account
|
|
|
|
def account
|
|
plaid_account.account
|
|
end
|
|
|
|
def credit_data
|
|
plaid_account.raw_liabilities_payload["credit"]
|
|
end
|
|
end
|