
- Set up project structure with FastAPI application - Implement SQLAlchemy models for users, services, projects, team members, contacts - Create API endpoints for website functionality - Implement JWT authentication system with user roles - Add file upload functionality for media - Configure CORS and health check endpoints - Add database migrations with Alembic - Create comprehensive README with setup instructions
44 lines
1.0 KiB
Python
44 lines
1.0 KiB
Python
from datetime import datetime
|
|
from typing import Optional
|
|
|
|
from pydantic import BaseModel, EmailStr, Field
|
|
|
|
|
|
# Shared properties
|
|
class TeamMemberBase(BaseModel):
|
|
name: Optional[str] = None
|
|
position: Optional[str] = None
|
|
bio: Optional[str] = None
|
|
photo: Optional[str] = None
|
|
email: Optional[EmailStr] = None
|
|
linkedin: Optional[str] = None
|
|
twitter: Optional[str] = None
|
|
is_active: Optional[bool] = True
|
|
order: Optional[int] = 0
|
|
|
|
|
|
# Properties to receive via API on creation
|
|
class TeamMemberCreate(TeamMemberBase):
|
|
name: str = Field(..., min_length=1, max_length=100)
|
|
position: str = Field(..., min_length=1, max_length=100)
|
|
|
|
|
|
# Properties to receive via API on update
|
|
class TeamMemberUpdate(TeamMemberBase):
|
|
pass
|
|
|
|
|
|
class TeamMemberInDBBase(TeamMemberBase):
|
|
id: int
|
|
name: str
|
|
position: str
|
|
created_at: datetime
|
|
updated_at: Optional[datetime] = None
|
|
|
|
class Config:
|
|
from_attributes = True
|
|
|
|
|
|
# Additional properties to return via API
|
|
class TeamMember(TeamMemberInDBBase):
|
|
pass |