from sqlalchemy import Column, Integer, String, DateTime, Boolean, Text from sqlalchemy.sql import func from sqlalchemy.orm import relationship from app.db.base import Base class Organization(Base): __tablename__ = "organizations" id = Column(Integer, primary_key=True, index=True) name = Column(String(255), nullable=False, index=True) domain = Column(String(255), unique=True, nullable=False, index=True) subdomain = Column(String(100), unique=True, nullable=False, index=True) is_active = Column(Boolean, default=True) settings = Column(Text) created_at = Column(DateTime(timezone=True), server_default=func.now()) updated_at = Column(DateTime(timezone=True), onupdate=func.now()) users = relationship("User", back_populates="organization") audit_logs = relationship("AuditLog", back_populates="organization")