Restructure into full project layout

This commit is contained in:
2026-06-16 23:06:16 -06:00
parent de4862b2d1
commit 57765496a6
74 changed files with 4441 additions and 3 deletions
View File
+29
View File
@@ -0,0 +1,29 @@
from pydantic import BaseModel
class CollectionCardOut(BaseModel):
id: int
card_name: str
set_code: str
collector_number: str
quantity: int
foil_quantity: int
scryfall_id: str
scryfall_data: dict | None
model_config = {"from_attributes": True}
class CollectionStatsOut(BaseModel):
total_cards: int
unique_cards: int
foil_cards: int
estimated_value: float | None
class PaginatedCollection(BaseModel):
items: list[CollectionCardOut]
total: int
page: int
page_size: int
pages: int
+87
View File
@@ -0,0 +1,87 @@
from datetime import datetime
from pydantic import BaseModel
from app.models.deck import DeckMode, CardSlot
class DeckConstraints(BaseModel):
prefer_owned: bool = False
budget_enabled: bool = False
budget_amount: float | None = None
budget_scope: str = "purchase"
class ExistingCard(BaseModel):
card_name: str
slot: str | None = None
quantity: int = 1
class GenerateRequest(BaseModel):
commander: str
playstyle: str | None = None
name: str | None = None
description: str | None = None
constraints: DeckConstraints = DeckConstraints()
class CompleteRequest(BaseModel):
commander: str
playstyle: str | None = None
name: str | None = None
existing_cards: list[ExistingCard]
constraints: DeckConstraints = DeckConstraints()
class CullRequest(BaseModel):
commander: str
name: str | None = None
existing_cards: list[ExistingCard]
target_count: int = 99
constraints: DeckConstraints = DeckConstraints()
class DeckCardOut(BaseModel):
id: int
deck_id: int
card_name: str
slot: CardSlot
quantity: int
is_owned: bool
is_commander: bool
ai_reasoning: str | None
scryfall_id: str
scryfall_data: dict | None
model_config = {"from_attributes": True}
class DeckOut(BaseModel):
id: int
owner_id: int
name: str
commander: str
description: str | None
mode: DeckMode
playstyle: str | None
prefer_owned: bool
budget_enabled: bool
budget_amount: float | None
budget_scope: str
ai_reasoning: dict | None
created_at: datetime
updated_at: datetime
cards: list[DeckCardOut] = []
model_config = {"from_attributes": True}
class DeckSummaryOut(BaseModel):
id: int
name: str
commander: str
mode: DeckMode
playstyle: str | None
created_at: datetime
card_count: int | None = None
model_config = {"from_attributes": True}
+45
View File
@@ -0,0 +1,45 @@
from datetime import datetime
from pydantic import BaseModel, EmailStr
from app.models.user import UserRole
class UserRegister(BaseModel):
email: EmailStr
password: str
display_name: str | None = None
class UserLogin(BaseModel):
email: EmailStr
password: str
class UserUpdate(BaseModel):
display_name: str | None = None
password: str | None = None
class UserOut(BaseModel):
id: int
email: str
display_name: str | None
role: UserRole
is_active: bool
created_at: datetime
model_config = {"from_attributes": True}
class TokenOut(BaseModel):
access_token: str
refresh_token: str
token_type: str = "bearer"
class RefreshRequest(BaseModel):
refresh_token: str
class AdminUserUpdate(BaseModel):
role: UserRole | None = None
is_active: bool | None = None