File size: 2,739 Bytes
			
			| a8b3f00 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 | from typing import Optional, Union
from extensions.ext_database import db
from libs.infinite_scroll_pagination import InfiniteScrollPagination
from models.account import Account
from models.model import App, EndUser
from models.web import SavedMessage
from services.message_service import MessageService
class SavedMessageService:
    @classmethod
    def pagination_by_last_id(
        cls, app_model: App, user: Optional[Union[Account, EndUser]], last_id: Optional[str], limit: int
    ) -> InfiniteScrollPagination:
        saved_messages = (
            db.session.query(SavedMessage)
            .filter(
                SavedMessage.app_id == app_model.id,
                SavedMessage.created_by_role == ("account" if isinstance(user, Account) else "end_user"),
                SavedMessage.created_by == user.id,
            )
            .order_by(SavedMessage.created_at.desc())
            .all()
        )
        message_ids = [sm.message_id for sm in saved_messages]
        return MessageService.pagination_by_last_id(
            app_model=app_model, user=user, last_id=last_id, limit=limit, include_ids=message_ids
        )
    @classmethod
    def save(cls, app_model: App, user: Optional[Union[Account, EndUser]], message_id: str):
        saved_message = (
            db.session.query(SavedMessage)
            .filter(
                SavedMessage.app_id == app_model.id,
                SavedMessage.message_id == message_id,
                SavedMessage.created_by_role == ("account" if isinstance(user, Account) else "end_user"),
                SavedMessage.created_by == user.id,
            )
            .first()
        )
        if saved_message:
            return
        message = MessageService.get_message(app_model=app_model, user=user, message_id=message_id)
        saved_message = SavedMessage(
            app_id=app_model.id,
            message_id=message.id,
            created_by_role="account" if isinstance(user, Account) else "end_user",
            created_by=user.id,
        )
        db.session.add(saved_message)
        db.session.commit()
    @classmethod
    def delete(cls, app_model: App, user: Optional[Union[Account, EndUser]], message_id: str):
        saved_message = (
            db.session.query(SavedMessage)
            .filter(
                SavedMessage.app_id == app_model.id,
                SavedMessage.message_id == message_id,
                SavedMessage.created_by_role == ("account" if isinstance(user, Account) else "end_user"),
                SavedMessage.created_by == user.id,
            )
            .first()
        )
        if not saved_message:
            return
        db.session.delete(saved_message)
        db.session.commit()
 | 
