| | 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() |
| |
|