mirror of
https://github.com/we-promise/sure.git
synced 2026-04-07 14:31:25 +00:00
* refactor: rename `raw_investments_payload` to `raw_holdings_payload` - Update references and models to use consistent naming. - Adjust migrations, tests, and encryption setup accordingly. * fix: improve safety when accessing raw_holdings_payload keys - Use `dig` with safe navigation to prevent potential nil errors. - Add support for decryption from the old column name `raw_investments_payload`. - Adjust related methods and calculations for consistency. --------- Co-authored-by: luckyPipewrench <luckypipewrench@proton.me>
75 lines
2.2 KiB
Ruby
75 lines
2.2 KiB
Ruby
class PlaidAccount < ApplicationRecord
|
|
include Encryptable
|
|
|
|
# Encrypt raw payloads if ActiveRecord encryption is configured
|
|
if encryption_ready?
|
|
encrypts :raw_payload
|
|
encrypts :raw_transactions_payload
|
|
# Support reading data encrypted under the old column name after rename
|
|
encrypts :raw_holdings_payload, previous: { attribute: :raw_investments_payload }
|
|
encrypts :raw_liabilities_payload
|
|
end
|
|
|
|
belongs_to :plaid_item
|
|
|
|
# Legacy association via foreign key (will be removed after migration)
|
|
has_one :account, dependent: :nullify, foreign_key: :plaid_account_id
|
|
# New association through account_providers
|
|
has_one :account_provider, as: :provider, dependent: :destroy
|
|
has_one :linked_account, through: :account_provider, source: :account
|
|
|
|
validates :name, :plaid_type, :currency, presence: true
|
|
validate :has_balance
|
|
|
|
# Helper to get account using new system first, falling back to legacy
|
|
def current_account
|
|
linked_account || account
|
|
end
|
|
|
|
def upsert_plaid_snapshot!(account_snapshot)
|
|
assign_attributes(
|
|
current_balance: account_snapshot.balances.current,
|
|
available_balance: account_snapshot.balances.available,
|
|
currency: account_snapshot.balances.iso_currency_code,
|
|
plaid_type: account_snapshot.type,
|
|
plaid_subtype: account_snapshot.subtype,
|
|
name: account_snapshot.name,
|
|
mask: account_snapshot.mask,
|
|
raw_payload: account_snapshot
|
|
)
|
|
|
|
save!
|
|
end
|
|
|
|
def upsert_plaid_transactions_snapshot!(transactions_snapshot)
|
|
assign_attributes(
|
|
raw_transactions_payload: transactions_snapshot
|
|
)
|
|
|
|
save!
|
|
end
|
|
|
|
def upsert_plaid_holdings_snapshot!(holdings_snapshot)
|
|
assign_attributes(
|
|
raw_holdings_payload: holdings_snapshot
|
|
)
|
|
|
|
save!
|
|
end
|
|
|
|
def upsert_plaid_liabilities_snapshot!(liabilities_snapshot)
|
|
assign_attributes(
|
|
raw_liabilities_payload: liabilities_snapshot
|
|
)
|
|
|
|
save!
|
|
end
|
|
|
|
private
|
|
# Plaid guarantees at least one of these. This validation is a sanity check for that guarantee.
|
|
def has_balance
|
|
return if current_balance.present? || available_balance.present?
|
|
errors.add(:base, "Plaid account must have either current or available balance")
|
|
end
|
|
end
|