Source code for chat.models.chat

from __future__ import annotations

from onegov.core.orm import Base
from onegov.core.orm.mixins import TimestampMixin
from onegov.core.orm.types import UUID
from onegov.user import User
from sqlalchemy import Column, ForeignKey
from sqlalchemy import Text, Boolean
from sqlalchemy.orm import relationship
from sqlalchemy.dialects.postgresql import JSONB
from uuid import uuid4


from typing import Any, TYPE_CHECKING
if TYPE_CHECKING:
    import uuid


[docs] class Chat(Base, TimestampMixin): """ A chat. """
[docs] __tablename__ = 'chats'
#: the type of the item, this can be used to create custom polymorphic #: subclasses of this class. See #: `<https://docs.sqlalchemy.org/en/improve_toc/\ #: orm/extensions/declarative/inheritance.html>`_.
[docs] type: Column[str] = Column( Text, nullable=False, default=lambda: 'generic' )
[docs] __mapper_args__ = { 'polymorphic_on': type, 'polymorphic_identity': 'generic', }
#: the unique id, part of the url
[docs] id: Column[uuid.UUID] = Column( UUID, # type:ignore[arg-type] primary_key=True, default=uuid4 )
[docs] user_id: Column[uuid.UUID | None] = Column( UUID, # type:ignore[arg-type] ForeignKey('users.id'), nullable=True )
[docs] user: relationship[User | None] = relationship(User)
[docs] customer_name: Column[str] = Column(Text, nullable=False)
[docs] email: Column[str] = Column(Text, nullable=False)
[docs] topic: Column[str] = Column(Text, nullable=False)
[docs] active: Column[bool] = Column(Boolean, nullable=False, default=True)
[docs] chat_history: Column[list[dict[str, Any]]] = Column( JSONB, # type:ignore[arg-type] nullable=False, default=list )