feat: add auth system, boss pokemon details, moves/abilities API, and run ownership
Add user authentication with login/signup/protected routes, boss pokemon detail fields and result team tracking, moves and abilities selector components and API, run ownership and visibility controls, and various UI improvements across encounters, run list, and journal pages. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -4,6 +4,16 @@ from app.schemas.base import CamelModel
|
||||
from app.schemas.pokemon import PokemonResponse
|
||||
|
||||
|
||||
class MoveRef(CamelModel):
|
||||
id: int
|
||||
name: str
|
||||
|
||||
|
||||
class AbilityRef(CamelModel):
|
||||
id: int
|
||||
name: str
|
||||
|
||||
|
||||
class BossPokemonResponse(CamelModel):
|
||||
id: int
|
||||
pokemon_id: int
|
||||
@@ -11,6 +21,19 @@ class BossPokemonResponse(CamelModel):
|
||||
order: int
|
||||
condition_label: str | None
|
||||
pokemon: PokemonResponse
|
||||
# Detail fields
|
||||
ability_id: int | None = None
|
||||
ability: AbilityRef | None = None
|
||||
held_item: str | None = None
|
||||
nature: str | None = None
|
||||
move1_id: int | None = None
|
||||
move2_id: int | None = None
|
||||
move3_id: int | None = None
|
||||
move4_id: int | None = None
|
||||
move1: MoveRef | None = None
|
||||
move2: MoveRef | None = None
|
||||
move3: MoveRef | None = None
|
||||
move4: MoveRef | None = None
|
||||
|
||||
|
||||
class BossBattleResponse(CamelModel):
|
||||
@@ -31,6 +54,12 @@ class BossBattleResponse(CamelModel):
|
||||
pokemon: list[BossPokemonResponse] = []
|
||||
|
||||
|
||||
class BossResultTeamMemberResponse(CamelModel):
|
||||
id: int
|
||||
encounter_id: int
|
||||
level: int
|
||||
|
||||
|
||||
class BossResultResponse(CamelModel):
|
||||
id: int
|
||||
run_id: int
|
||||
@@ -38,6 +67,7 @@ class BossResultResponse(CamelModel):
|
||||
result: str
|
||||
attempts: int
|
||||
completed_at: datetime | None
|
||||
team: list[BossResultTeamMemberResponse] = []
|
||||
|
||||
|
||||
# --- Input schemas ---
|
||||
@@ -78,12 +108,26 @@ class BossPokemonInput(CamelModel):
|
||||
level: int
|
||||
order: int
|
||||
condition_label: str | None = None
|
||||
# Detail fields
|
||||
ability_id: int | None = None
|
||||
held_item: str | None = None
|
||||
nature: str | None = None
|
||||
move1_id: int | None = None
|
||||
move2_id: int | None = None
|
||||
move3_id: int | None = None
|
||||
move4_id: int | None = None
|
||||
|
||||
|
||||
class BossResultTeamMemberInput(CamelModel):
|
||||
encounter_id: int
|
||||
level: int
|
||||
|
||||
|
||||
class BossResultCreate(CamelModel):
|
||||
boss_battle_id: int
|
||||
result: str
|
||||
attempts: int = 1
|
||||
team: list[BossResultTeamMemberInput] = []
|
||||
|
||||
|
||||
class BossReorderItem(CamelModel):
|
||||
|
||||
@@ -1,15 +1,23 @@
|
||||
from datetime import datetime
|
||||
from uuid import UUID
|
||||
|
||||
from app.models.nuzlocke_run import RunVisibility
|
||||
from app.schemas.base import CamelModel
|
||||
from app.schemas.encounter import EncounterDetailResponse
|
||||
from app.schemas.game import GameResponse
|
||||
|
||||
|
||||
class OwnerResponse(CamelModel):
|
||||
id: UUID
|
||||
display_name: str | None = None
|
||||
|
||||
|
||||
class RunCreate(CamelModel):
|
||||
game_id: int
|
||||
name: str
|
||||
rules: dict = {}
|
||||
naming_scheme: str | None = None
|
||||
visibility: RunVisibility = RunVisibility.PUBLIC
|
||||
|
||||
|
||||
class RunUpdate(CamelModel):
|
||||
@@ -18,6 +26,7 @@ class RunUpdate(CamelModel):
|
||||
rules: dict | None = None
|
||||
hof_encounter_ids: list[int] | None = None
|
||||
naming_scheme: str | None = None
|
||||
visibility: RunVisibility | None = None
|
||||
|
||||
|
||||
class RunResponse(CamelModel):
|
||||
@@ -28,6 +37,8 @@ class RunResponse(CamelModel):
|
||||
rules: dict
|
||||
hof_encounter_ids: list[int] | None = None
|
||||
naming_scheme: str | None = None
|
||||
visibility: RunVisibility
|
||||
owner: OwnerResponse | None = None
|
||||
started_at: datetime
|
||||
completed_at: datetime | None
|
||||
|
||||
|
||||
Reference in New Issue
Block a user