test-project-856u96/schemas/contact_form.py

63 lines
2.1 KiB
Python

from pydantic import BaseModel, EmailStr, Field
from datetime import datetime
from uuid import UUID
from pydantic import validator
# Base schema for ContactForm, used for inheritance
class ContactFormBase(BaseModel):
name: str = Field(..., description="Contact's name")
email: EmailStr = Field(..., description="Contact's email address")
message: str = Field(..., description="Contact message")
@validator('name')
def name_must_not_be_empty(cls, v):
if not v.strip():
raise ValueError('Name cannot be empty')
return v
@validator('message')
def message_must_not_be_empty(cls, v):
if not v.strip():
raise ValueError('Message cannot be empty')
return v
# Schema for creating a new ContactForm
class ContactFormCreate(ContactFormBase):
pass
# Schema for updating an existing ContactForm (all fields required based on change summary)
class ContactFormUpdate(BaseModel):
name: str = Field(..., description="Contact's name")
email: EmailStr = Field(..., description="Contact's email address")
message: str = Field(..., description="Contact message")
@validator('name')
def name_must_not_be_empty(cls, v):
if not v.strip():
raise ValueError('Name cannot be empty')
return v
@validator('message')
def message_must_not_be_empty(cls, v):
if not v.strip():
raise ValueError('Message cannot be empty')
return v
# Schema for representing a ContactForm in responses
class ContactFormSchema(ContactFormBase):
id: UUID
created_at: datetime
updated_at: datetime
class Config:
orm_mode = True
schema_extra = {
"example": {
"id": "f47ac10b-58cc-4372-a567-0e02b2c3d479",
"name": "John Doe",
"email": "john.doe@example.com",
"message": "I would like more information about your services.",
"created_at": "2023-01-01T12:00:00",
"updated_at": "2023-01-01T12:00:00"
}
}