mirror of
				https://github.com/langgenius/dify.git
				synced 2025-11-03 20:33:00 +00:00 
			
		
		
		
	Feat/user session id search (#6638)
This commit is contained in:
		
							parent
							
								
									47b5bd7243
								
							
						
					
					
						commit
						b347a2f839
					
				@ -22,7 +22,7 @@ from fields.conversation_fields import (
 | 
			
		||||
)
 | 
			
		||||
from libs.helper import datetime_string
 | 
			
		||||
from libs.login import login_required
 | 
			
		||||
from models.model import AppMode, Conversation, Message, MessageAnnotation
 | 
			
		||||
from models.model import AppMode, Conversation, EndUser, Message, MessageAnnotation
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class CompletionConversationApi(Resource):
 | 
			
		||||
@ -156,19 +156,31 @@ class ChatConversationApi(Resource):
 | 
			
		||||
        parser.add_argument('limit', type=int_range(1, 100), required=False, default=20, location='args')
 | 
			
		||||
        args = parser.parse_args()
 | 
			
		||||
 | 
			
		||||
        subquery = (
 | 
			
		||||
            db.session.query(
 | 
			
		||||
                Conversation.id.label('conversation_id'),
 | 
			
		||||
                EndUser.session_id.label('from_end_user_session_id')
 | 
			
		||||
            )
 | 
			
		||||
            .outerjoin(EndUser, Conversation.from_end_user_id == EndUser.id)
 | 
			
		||||
            .subquery()
 | 
			
		||||
        )
 | 
			
		||||
 | 
			
		||||
        query = db.select(Conversation).where(Conversation.app_id == app_model.id)
 | 
			
		||||
 | 
			
		||||
        if args['keyword']:
 | 
			
		||||
            keyword_filter = '%{}%'.format(args['keyword'])
 | 
			
		||||
            query = query.join(
 | 
			
		||||
                Message, Message.conversation_id == Conversation.id
 | 
			
		||||
                Message, Message.conversation_id == Conversation.id,
 | 
			
		||||
            ).join(
 | 
			
		||||
                subquery, subquery.c.conversation_id == Conversation.id
 | 
			
		||||
            ).filter(
 | 
			
		||||
                or_(
 | 
			
		||||
                    Message.query.ilike('%{}%'.format(args['keyword'])),
 | 
			
		||||
                    Message.answer.ilike('%{}%'.format(args['keyword'])),
 | 
			
		||||
                    Conversation.name.ilike('%{}%'.format(args['keyword'])),
 | 
			
		||||
                    Conversation.introduction.ilike('%{}%'.format(args['keyword'])),
 | 
			
		||||
                    Message.query.ilike(keyword_filter),
 | 
			
		||||
                    Message.answer.ilike(keyword_filter),
 | 
			
		||||
                    Conversation.name.ilike(keyword_filter),
 | 
			
		||||
                    Conversation.introduction.ilike(keyword_filter),
 | 
			
		||||
                    subquery.c.from_end_user_session_id.ilike(keyword_filter)
 | 
			
		||||
                ),
 | 
			
		||||
 | 
			
		||||
            )
 | 
			
		||||
 | 
			
		||||
        account = current_user
 | 
			
		||||
 | 
			
		||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user