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