45 lines
1.7 KiB
Python
45 lines
1.7 KiB
Python
from ..extensions import db
|
|
from .user import User, Tenant
|
|
from .document import Embedding
|
|
|
|
|
|
class ChatSession(db.Model):
|
|
id = db.Column(db.Integer, primary_key=True)
|
|
user_id = db.Column(db.Integer, db.ForeignKey(User.id), nullable=True)
|
|
session_id = db.Column(db.String(36), nullable=True)
|
|
session_start = db.Column(db.DateTime, nullable=False)
|
|
session_end = db.Column(db.DateTime, nullable=True)
|
|
|
|
# Relations
|
|
interactions = db.relationship('Interaction', backref='chat_session', lazy=True)
|
|
|
|
def __repr__(self):
|
|
return f"<ChatSession {self.id} by {self.user_id}>"
|
|
|
|
|
|
class Interaction(db.Model):
|
|
id = db.Column(db.Integer, primary_key=True)
|
|
chat_session_id = db.Column(db.Integer, db.ForeignKey(ChatSession.id), nullable=False)
|
|
question = db.Column(db.Text, nullable=False)
|
|
detailed_question = db.Column(db.Text, nullable=True)
|
|
answer = db.Column(db.Text, nullable=True)
|
|
algorithm_used = db.Column(db.String(20), nullable=True)
|
|
language = db.Column(db.String(2), nullable=False)
|
|
appreciation = db.Column(db.Integer, nullable=True)
|
|
|
|
# Timing information
|
|
question_at = db.Column(db.DateTime, nullable=False)
|
|
detailed_question_at = db.Column(db.DateTime, nullable=True)
|
|
answer_at = db.Column(db.DateTime, nullable=True)
|
|
|
|
# Relations
|
|
embeddings = db.relationship('InteractionEmbedding', backref='interaction', lazy=True)
|
|
|
|
def __repr__(self):
|
|
return f"<Interaction {self.id}>"
|
|
|
|
|
|
class InteractionEmbedding(db.Model):
|
|
interaction_id = db.Column(db.Integer, db.ForeignKey(Interaction.id, ondelete='CASCADE'), primary_key=True)
|
|
embedding_id = db.Column(db.Integer, db.ForeignKey(Embedding.id, ondelete='CASCADE'), primary_key=True)
|