From antigravity-awesome-skills
Creates Pydantic models using multi-model pattern (Base, Create, Update, Response, InDB) for API contracts, camelCase aliases, and DB docs.
npx claudepluginhub sickn33/antigravity-awesome-skillsThis skill uses the workspace's default tool permissions.
Create Pydantic models following the multi-model pattern for clean API contracts.
Creates Pydantic models using multi-model pattern (Base, Create, Update, Response, InDB) for API contracts, camelCase aliases, and DB docs.
Generates Pydantic v2 models with Base, Create, Update, Response, and InDB variants for API request/response schemas, database models, and data validation in Python apps.
Guides Pydantic v2 model definition with BaseModel, ConfigDict, field/model validators, computed fields, serialization, TypeAdapter, env config, and v1-to-v2 migration.
Share bugs, ideas, or general feedback.
Create Pydantic models following the multi-model pattern for clean API contracts.
Copy the template from assets/template.py and replace placeholders:
{{ResourceName}} → PascalCase name (e.g., Project){{resource_name}} → snake_case name (e.g., project)| Model | Purpose |
|---|---|
Base | Common fields shared across models |
Create | Request body for creation (required fields) |
Update | Request body for updates (all optional) |
Response | API response with all fields |
InDB | Database document with doc_type |
class MyModel(BaseModel):
workspace_id: str = Field(..., alias="workspaceId")
created_at: datetime = Field(..., alias="createdAt")
class Config:
populate_by_name = True # Accept both snake_case and camelCase
class MyUpdate(BaseModel):
"""All fields optional for PATCH requests."""
name: Optional[str] = Field(None, min_length=1)
description: Optional[str] = None
class MyInDB(MyResponse):
"""Adds doc_type for Cosmos DB queries."""
doc_type: str = "my_resource"
src/backend/app/models/src/backend/app/models/__init__.pyThis skill is applicable to execute the workflow or actions described in the overview.