Automated Action 54bf9880b9 Implement Small Business Inventory Management System
This commit implements a comprehensive inventory management system for small businesses using FastAPI and SQLAlchemy. Features include:
- Product and category management
- Inventory tracking across multiple locations
- Supplier management
- Purchase management
- Transaction tracking for inventory movements
- Complete API documentation

generated with BackendIM... (backend.im)
2025-05-12 12:55:31 +00:00

53 lines
1.3 KiB
Python

from typing import List, Optional
from pydantic import BaseModel, Field
from datetime import datetime
# Category schemas
class CategoryBase(BaseModel):
name: str
description: Optional[str] = None
class CategoryCreate(CategoryBase):
pass
class CategoryUpdate(CategoryBase):
name: Optional[str] = None
class CategoryInDB(CategoryBase):
id: int
created_at: datetime
updated_at: datetime
class Config:
from_attributes = True
# Product schemas
class ProductBase(BaseModel):
name: str
description: Optional[str] = None
sku: str = Field(..., description="Stock Keeping Unit, unique identifier")
price: float = Field(..., gt=0)
cost_price: float = Field(..., gt=0)
barcode: Optional[str] = None
category_id: Optional[int] = None
class ProductCreate(ProductBase):
pass
class ProductUpdate(BaseModel):
name: Optional[str] = None
description: Optional[str] = None
sku: Optional[str] = None
price: Optional[float] = Field(None, gt=0)
cost_price: Optional[float] = Field(None, gt=0)
barcode: Optional[str] = None
category_id: Optional[int] = None
class ProductInDB(ProductBase):
id: int
created_at: datetime
updated_at: datetime
category: Optional[CategoryInDB] = None
class Config:
from_attributes = True