mirror of
https://github.com/creyD/creyPY.git
synced 2026-04-12 19:30:30 +02:00
29 lines
867 B
Python
29 lines
867 B
Python
import uuid
|
|
from datetime import datetime
|
|
|
|
from sqlalchemy import Column, DateTime, String
|
|
from sqlalchemy.dialects.postgresql import UUID
|
|
from sqlalchemy.ext.declarative import declared_attr
|
|
from sqlalchemy.orm import as_declarative
|
|
from sqlalchemy.sql import func
|
|
|
|
|
|
@as_declarative()
|
|
class Base:
|
|
__abstract__ = True
|
|
# Primary key as uuid
|
|
id = Column(UUID(as_uuid=True), primary_key=True, default=uuid.uuid4)
|
|
created_at = Column(DateTime(timezone=True), server_default=func.now())
|
|
updated_at = Column(DateTime, default=datetime.utcnow, onupdate=datetime.utcnow)
|
|
created_by_id = Column(String)
|
|
|
|
__name__: str
|
|
|
|
# TODO: Add default representation string
|
|
# TODO: Add automated foreign key resolution
|
|
|
|
# Generate __tablename__ automatically
|
|
@declared_attr
|
|
def __tablename__(cls) -> str:
|
|
return cls.__name__.lower()
|