feat(phase-18): add in-app notification system (T-128, T-129)

This commit is contained in:
2026-02-09 13:52:04 +01:00
parent cda59de426
commit fb7f340038
16 changed files with 7577 additions and 2 deletions

View File

@@ -0,0 +1,39 @@
"""Notification model — in-app notifications for user actions."""
import uuid
from datetime import datetime
from sqlalchemy import Column, String, Text, Boolean, DateTime, ForeignKey, Index
from sqlalchemy.dialects.postgresql import UUID
from sqlalchemy.orm import relationship
from app.database import Base
class Notification(Base):
"""
In-app notification for alerting users when they need to act.
Types include: test_assigned, validation_needed, test_rejected,
test_validated, test_state_changed, etc.
"""
__tablename__ = "notifications"
id = Column(UUID(as_uuid=True), primary_key=True, default=uuid.uuid4)
user_id = Column(UUID(as_uuid=True), ForeignKey("users.id"), nullable=False)
type = Column(String, nullable=False)
title = Column(String, nullable=False)
message = Column(Text, nullable=True)
entity_type = Column(String, nullable=True)
entity_id = Column(UUID(as_uuid=True), nullable=True)
read = Column(Boolean, default=False)
created_at = Column(DateTime, default=datetime.utcnow)
# Relationships
user = relationship("User")
__table_args__ = (
Index("ix_notifications_user_id", "user_id"),
Index("ix_notifications_read", "read"),
Index("ix_notifications_created_at", "created_at"),
)