Migrate to motor for DB interaction
This commit is contained in:
0
api/schemas/__init__.py
Normal file
0
api/schemas/__init__.py
Normal file
103
api/schemas/flight.py
Normal file
103
api/schemas/flight.py
Normal file
@@ -0,0 +1,103 @@
|
||||
import datetime
|
||||
from typing import Optional, Annotated, Any
|
||||
|
||||
from bson import ObjectId
|
||||
from pydantic import BaseModel, Field
|
||||
from pydantic_core import core_schema
|
||||
|
||||
PositiveInt = Annotated[int, Field(default=0, ge=0)]
|
||||
PositiveFloat = Annotated[float, Field(default=0., ge=0)]
|
||||
PositiveFloatNullable = Annotated[float, Field(ge=0)]
|
||||
|
||||
|
||||
class PyObjectId(str):
|
||||
@classmethod
|
||||
def __get_pydantic_core_schema__(
|
||||
cls, _source_type: Any, _handler: Any
|
||||
) -> core_schema.CoreSchema:
|
||||
return core_schema.json_or_python_schema(
|
||||
json_schema=core_schema.str_schema(),
|
||||
python_schema=core_schema.union_schema([
|
||||
core_schema.is_instance_schema(ObjectId),
|
||||
core_schema.chain_schema([
|
||||
core_schema.str_schema(),
|
||||
core_schema.no_info_plain_validator_function(cls.validate),
|
||||
])
|
||||
]),
|
||||
serialization=core_schema.plain_serializer_function_ser_schema(
|
||||
lambda x: str(x)
|
||||
),
|
||||
)
|
||||
|
||||
@classmethod
|
||||
def validate(cls, value) -> ObjectId:
|
||||
if not ObjectId.is_valid(value):
|
||||
raise ValueError("Invalid ObjectId")
|
||||
|
||||
return ObjectId(value)
|
||||
|
||||
|
||||
class FlightCreateSchema(BaseModel):
|
||||
date: datetime.date
|
||||
aircraft: Optional[str] = None
|
||||
waypoint_from: Optional[str] = None
|
||||
waypoint_to: Optional[str] = None
|
||||
route: Optional[str] = None
|
||||
|
||||
hobbs_start: Optional[PositiveFloatNullable] = None
|
||||
hobbs_end: Optional[PositiveFloatNullable] = None
|
||||
tach_start: Optional[PositiveFloatNullable] = None
|
||||
tach_end: Optional[PositiveFloatNullable] = None
|
||||
|
||||
time_start: Optional[datetime.datetime] = None
|
||||
time_off: Optional[datetime.datetime] = None
|
||||
time_down: Optional[datetime.datetime] = None
|
||||
time_stop: Optional[datetime.datetime] = None
|
||||
|
||||
time_total: PositiveFloat
|
||||
time_pic: PositiveFloat
|
||||
time_sic: PositiveFloat
|
||||
time_night: PositiveFloat
|
||||
time_solo: PositiveFloat
|
||||
|
||||
time_xc: PositiveFloat
|
||||
dist_xc: PositiveFloat
|
||||
|
||||
takeoffs_day: PositiveInt
|
||||
landings_day: PositiveInt
|
||||
takeoffs_night: PositiveInt
|
||||
landings_all: PositiveInt
|
||||
|
||||
time_instrument: PositiveFloat
|
||||
time_sim_instrument: PositiveFloat
|
||||
holds_instrument: PositiveFloat
|
||||
|
||||
dual_given: PositiveFloat
|
||||
dual_recvd: PositiveFloat
|
||||
time_sim: PositiveFloat
|
||||
time_ground: PositiveFloat
|
||||
|
||||
tags: list[str] = []
|
||||
|
||||
pax: list[str] = []
|
||||
crew: list[str] = []
|
||||
|
||||
comments: Optional[str] = None
|
||||
|
||||
|
||||
class FlightDisplaySchema(FlightCreateSchema):
|
||||
id: PyObjectId
|
||||
|
||||
|
||||
class FlightConciseSchema(BaseModel):
|
||||
user: PyObjectId
|
||||
id: PyObjectId
|
||||
|
||||
date: datetime.date
|
||||
aircraft: str
|
||||
waypoint_from: Optional[str] = None
|
||||
waypoint_to: Optional[str] = None
|
||||
|
||||
time_total: PositiveFloat
|
||||
|
||||
comments: Optional[str] = None
|
99
api/schemas/user.py
Normal file
99
api/schemas/user.py
Normal file
@@ -0,0 +1,99 @@
|
||||
from enum import Enum
|
||||
from typing import Optional
|
||||
|
||||
from pydantic import BaseModel, Field, validator, field_validator
|
||||
|
||||
|
||||
def validate_username(value: str):
|
||||
length = len(value)
|
||||
if length < 4 or length > 32:
|
||||
raise ValueError("Username must be between 4 and 32 characters long")
|
||||
if any(not (x.isalnum() or x == "_" or x == " ") for x in value):
|
||||
raise ValueError("Username must only contain letters, numbers, underscores, and dashes")
|
||||
return value
|
||||
|
||||
|
||||
def validate_password(value: str):
|
||||
length = len(value)
|
||||
if length < 8 or length > 16:
|
||||
raise ValueError("Password must be between 8 and 16 characters long")
|
||||
return value
|
||||
|
||||
|
||||
class AuthLevel(Enum):
|
||||
GUEST = 0
|
||||
USER = 1
|
||||
ADMIN = 2
|
||||
|
||||
def __lt__(self, other):
|
||||
if self.__class__ is other.__class__:
|
||||
return self.value < other.value
|
||||
return NotImplemented
|
||||
|
||||
def __gt__(self, other):
|
||||
if self.__class__ is other.__class__:
|
||||
return self.value > other.value
|
||||
return NotImplemented
|
||||
|
||||
def __eq__(self, other):
|
||||
if self.__class__ is other.__class__:
|
||||
return self.value == other.value
|
||||
return NotImplemented
|
||||
|
||||
|
||||
class UserBaseSchema(BaseModel):
|
||||
username: str
|
||||
|
||||
|
||||
class UserLoginSchema(UserBaseSchema):
|
||||
password: str
|
||||
|
||||
|
||||
class UserCreateSchema(UserBaseSchema):
|
||||
password: str
|
||||
level: AuthLevel = Field(AuthLevel.USER)
|
||||
|
||||
@field_validator("username")
|
||||
@classmethod
|
||||
def _valid_username(cls, value):
|
||||
validate_username(value)
|
||||
|
||||
@field_validator("password")
|
||||
@classmethod
|
||||
def _valid_password(cls, value):
|
||||
validate_password(value)
|
||||
|
||||
|
||||
class UserUpdateSchema(BaseModel):
|
||||
username: Optional[str] = None
|
||||
password: Optional[str] = None
|
||||
level: Optional[AuthLevel] = AuthLevel.USER
|
||||
|
||||
@field_validator("username")
|
||||
@classmethod
|
||||
def _valid_username(cls, value):
|
||||
validate_username(value)
|
||||
|
||||
@field_validator("password")
|
||||
@classmethod
|
||||
def _valid_password(cls, value):
|
||||
validate_password(value)
|
||||
|
||||
|
||||
class UserDisplaySchema(UserBaseSchema):
|
||||
id: str
|
||||
level: AuthLevel
|
||||
|
||||
|
||||
class UserSystemSchema(UserDisplaySchema):
|
||||
password: str
|
||||
|
||||
|
||||
class TokenSchema(BaseModel):
|
||||
access_token: str
|
||||
refresh_token: str
|
||||
|
||||
|
||||
class TokenPayload(BaseModel):
|
||||
sub: Optional[str]
|
||||
exp: Optional[int]
|
Reference in New Issue
Block a user