Source code for app.model.wallet_transactions

"""Wallet transaction ledger model.

The ``transactionType`` column is a free-form string; the values used across
the system, and what each means, are::

    AssignPoints          Assignment of points to the wallet.
    ConvertPointsToCoins  Conversion of points to coins in the wallet.
    DepositCoins          Deposit of coins into the wallet.
    WithdrawCoins         Withdrawal of coins from the wallet.
    EarnRewards           Earning rewards (points or coins) for activities.
    RedeemRewards         Redemption of points for rewards or services.
    PurchaseWithPoints    Purchase of items or services using points.
    PurchaseWithCoins     Purchase of items or services using coins.
    RefundTransaction     Refund of a previous transaction.
    AdjustBalance         Manual adjustment of the balance (errors/fixes).
    TransferPoints        Transfer of points to another user.
    TransferCoins         Transfer of coins to another user.
    ExchangeCoins         Exchange of coins for another currency or asset.
    FeeDeduction          Deduction of fees or commissions from the balance.
    BonusPointsAward      Awarding of bonus points.
"""

from pydantic import ConfigDict
from sqlalchemy.dialects.postgresql import JSONB, UUID
from sqlmodel import Column, Field, Float, ForeignKey, Integer, String

from app.model.base_model import BaseModel


[docs] class WalletTransactions(BaseModel, table=True): """ Represents a transaction in a wallet. Attributes: transactionType (str): The type of transaction. points (int): The number of points involved in the transaction. coins (float): The number of coins involved in the transaction. data (dict): Additional data associated with the transaction. appliedConversionRate (float): The conversion rate applied to the transaction. walletId (str): The ID of the wallet associated with the transaction. """ transactionType: str = Field(sa_column=Column(String)) points: int = Field(sa_column=Column(Integer)) coins: float = Field(sa_column=Column(Float)) data: dict = Field(sa_column=Column(JSONB, nullable=True)) appliedConversionRate: float = Field(sa_column=Column(Float)) walletId: str = Field(sa_column=Column(UUID(as_uuid=True), ForeignKey("wallet.id"))) apiKey_used: str = Field( sa_column=Column(String, ForeignKey("apikey.apiKey"), nullable=True) ) model_config = ConfigDict(from_attributes=True) def __str__(self): return ( f"WalletTransactions: (id={self.id}, created_at={self.created_at}," f" updated_at={self.updated_at}, " f"transactionType={self.transactionType}, points={self.points}, " f"coins={self.coins}, data={self.data}, " f"appliedConversionRate={self.appliedConversionRate}, " f"walletId={self.walletId})" ) def __repr__(self): return ( f"WalletTransactions: (id={self.id}, created_at={self.created_at}," f" updated_at={self.updated_at}, " f"transactionType={self.transactionType}, points={self.points}, " f"coins={self.coins}, data={self.data}, " f"appliedConversionRate={self.appliedConversionRate}, " f"walletId={self.walletId})" ) def __eq__(self, other): return ( isinstance(other, WalletTransactions) and self.id == other.id and self.transactionType == other.transactionType and self.points == other.points and self.coins == other.coins and self.data == other.data and self.appliedConversionRate == other.appliedConversionRate and self.walletId == other.walletId )
[docs] def make_hashable(self, obj): """ Recursively convert a nested structure into a hashable form. Lists/tuples become tuples and dicts become sorted tuples of ``(key, value)`` pairs, so the JSON ``data`` field can be folded into ``__hash__``. Scalars are returned unchanged. Args: obj: The value (possibly nested list/dict) to make hashable. Returns: A hashable equivalent of ``obj``. """ if isinstance(obj, (tuple, list)): return tuple(self.make_hashable(e) for e in obj) elif isinstance(obj, dict): return tuple(sorted((k, self.make_hashable(v)) for k, v in obj.items())) else: return obj
def __hash__(self): data_as_hashable = self.make_hashable(self.data) return hash( ( self.transactionType, self.points, self.coins, data_as_hashable, self.appliedConversionRate, self.walletId, ) )