app.model.wallet_transactions module

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.
class app.model.wallet_transactions.WalletTransactions(*, id=<factory>, created_at=<factory>, updated_at=<factory>, apiKey_used, oauth_user_id=None, transactionType, points, coins, data, appliedConversionRate, walletId)[source]

Bases: BaseModel

Represents a transaction in a wallet.

Parameters:
  • id (Annotated[str, FieldInfoMetadata(primary_key=PydanticUndefined, nullable=PydanticUndefined, foreign_key=PydanticUndefined, ondelete=PydanticUndefined, unique=PydanticUndefined, index=PydanticUndefined, sa_type=UUID(), sa_column=PydanticUndefined, sa_column_args=PydanticUndefined, sa_column_kwargs={'primary_key': True, 'index': True})])

  • created_at (Annotated[datetime, FieldInfoMetadata(primary_key=PydanticUndefined, nullable=PydanticUndefined, foreign_key=PydanticUndefined, ondelete=PydanticUndefined, unique=PydanticUndefined, index=PydanticUndefined, sa_type=DateTime(timezone=True), sa_column=PydanticUndefined, sa_column_args=PydanticUndefined, sa_column_kwargs={'server_default': <sqlalchemy.sql.functions.now at 0x7fa8900484a0; now>})])

  • updated_at (Annotated[datetime, FieldInfoMetadata(primary_key=PydanticUndefined, nullable=PydanticUndefined, foreign_key=PydanticUndefined, ondelete=PydanticUndefined, unique=PydanticUndefined, index=PydanticUndefined, sa_type=DateTime(timezone=True), sa_column=PydanticUndefined, sa_column_args=PydanticUndefined, sa_column_kwargs={'server_default': <sqlalchemy.sql.functions.now at 0x7fa88fa2a840; now>, 'onupdate': <sqlalchemy.sql.functions.now at 0x7fa88fa2ad20; now>})])

transactionType

The type of transaction.

Type:

str

points

The number of points involved in the transaction.

Type:

int

coins

The number of coins involved in the transaction.

Type:

float

data

Additional data associated with the transaction.

Type:

dict

appliedConversionRate

The conversion rate applied to the transaction.

Type:

float

walletId

The ID of the wallet associated with the transaction.

Type:

str

model_config: ClassVar[ConfigDict] = {'from_attributes': True, 'read_from_attributes': True, 'read_with_orm_mode': True, 'registry': PydanticUndefined, 'table': True}

Configuration for the model, should be a dictionary conforming to [ConfigDict][pydantic.config.ConfigDict].

make_hashable(obj)[source]

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.

Parameters:

obj – The value (possibly nested list/dict) to make hashable.

Returns:

A hashable equivalent of obj.