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