Spaces:
Sleeping
Sleeping
from datetime import datetime | |
from typing import Any, Dict, List | |
from sqlalchemy import ForeignKey | |
from sqlalchemy.sql import expression as sql | |
from sqlalchemy.orm import relationship, Mapped, mapped_column | |
from sqlalchemy.ext.asyncio import AsyncSession | |
from sqlalchemy.dialects.postgresql import JSON | |
from app.model.base import BaseModel | |
from app.engine.postgresdb import Base | |
from app.schema.index import IncomeStatement as IncomeStatementSchema | |
class IncomeStatement(Base, BaseModel): | |
__tablename__ = "income_statement" | |
date_from: Mapped[datetime] | |
date_to: Mapped[datetime] | |
income: Mapped[Dict] = mapped_column(JSON, nullable=True) | |
expenses: Mapped[Dict] = mapped_column(JSON, nullable=True) | |
user_id: Mapped[int] = mapped_column(ForeignKey("users.id")) | |
user = relationship("User", back_populates="income_statements") | |
def __str__(self) -> str: | |
return f"IncomeStatement(id={self.id}, user_id={self.user_id}, date_from={self.date_from}, date_to={self.date_to}, income={self.income}, expenses={self.expenses})" | |
async def create(cls: "type[IncomeStatement]", db: AsyncSession, **kwargs: IncomeStatementSchema) -> "IncomeStatement": | |
income_statement = cls(**kwargs) | |
db.add(income_statement) | |
await db.commit() | |
await db.refresh(income_statement) | |
return income_statement | |
async def get_by_user(cls: "type[IncomeStatement]", db: AsyncSession, user_id: int) -> "List[IncomeStatement]": | |
query = sql.select(cls).where(cls.user_id == user_id) | |
income_statements = await db.scalars(query) | |
return income_statements.all() | |
async def get(cls: "type[IncomeStatement]", db: AsyncSession, id: int) -> "IncomeStatement": | |
query = sql.select(cls).where(cls.id == id) | |
income_statement = await db.scalar(query) | |
return income_statement | |