| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 | from typing import Optional, Unionfrom extensions.ext_database import dbfrom libs.infinite_scroll_pagination import InfiniteScrollPaginationfrom models.account import Accountfrom models.model import App, EndUserfrom models.web import SavedMessagefrom services.message_service import MessageServiceclass 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()
 |