mirror of
https://github.com/ParisNeo/lollms-webui.git
synced 2025-01-11 07:23:05 +00:00
124 lines
6.0 KiB
Python
124 lines
6.0 KiB
Python
"""
|
|
project: lollms
|
|
file: lollms_generation_events.py
|
|
author: ParisNeo
|
|
description:
|
|
This module contains a set of Socketio routes that provide information about the Lord of Large Language and Multimodal Systems (LoLLMs) Web UI
|
|
application. These routes are specific to text generation operation
|
|
|
|
"""
|
|
from fastapi import APIRouter, Request
|
|
from fastapi import HTTPException
|
|
from pydantic import BaseModel
|
|
import pkg_resources
|
|
from lollms.server.elf_server import LOLLMSElfServer
|
|
from fastapi.responses import FileResponse
|
|
from lollms.binding import BindingBuilder, InstallOption
|
|
from ascii_colors import ASCIIColors
|
|
from lollms.personality import MSG_TYPE, AIPersonality
|
|
from lollms.types import MSG_TYPE, SENDER_TYPES
|
|
from lollms.utilities import load_config, trace_exception, gc
|
|
from lollms.utilities import find_first_available_file_index, convert_language_name
|
|
from lollms_webui import LOLLMSWebUI
|
|
from pathlib import Path
|
|
from typing import List
|
|
import socketio
|
|
import threading
|
|
import os
|
|
|
|
router = APIRouter()
|
|
lollmsElfServer = LOLLMSWebUI.get_instance()
|
|
|
|
|
|
# ----------------------------------- events -----------------------------------------
|
|
def add_events(sio:socketio):
|
|
@sio.on('generate_msg')
|
|
def handle_generate_msg(sid, data):
|
|
client_id = sid
|
|
lollmsElfServer.cancel_gen = False
|
|
lollmsElfServer.connections[client_id]["generated_text"]=""
|
|
lollmsElfServer.connections[client_id]["cancel_generation"]=False
|
|
lollmsElfServer.connections[client_id]["continuing"]=False
|
|
lollmsElfServer.connections[client_id]["first_chunk"]=True
|
|
|
|
|
|
|
|
if not lollmsElfServer.model:
|
|
ASCIIColors.error("Model not selected. Please select a model")
|
|
lollmsElfServer.error("Model not selected. Please select a model", client_id=client_id)
|
|
return
|
|
|
|
if not lollmsElfServer.busy:
|
|
if lollmsElfServer.connections[client_id]["current_discussion"] is None:
|
|
if lollmsElfServer.db.does_last_discussion_have_messages():
|
|
lollmsElfServer.connections[client_id]["current_discussion"] = lollmsElfServer.db.create_discussion()
|
|
else:
|
|
lollmsElfServer.connections[client_id]["current_discussion"] = lollmsElfServer.db.load_last_discussion()
|
|
|
|
prompt = data["prompt"]
|
|
ump = lollmsElfServer.config.discussion_prompt_separator +lollmsElfServer.config.user_name.strip() if lollmsElfServer.config.use_user_name_in_discussions else lollmsElfServer.personality.user_message_prefix
|
|
message = lollmsElfServer.connections[client_id]["current_discussion"].add_message(
|
|
message_type = MSG_TYPE.MSG_TYPE_FULL.value,
|
|
sender_type = SENDER_TYPES.SENDER_TYPES_USER.value,
|
|
sender = ump.replace(lollmsElfServer.config.discussion_prompt_separator,"").replace(":",""),
|
|
content=prompt,
|
|
metadata=None,
|
|
parent_message_id=lollmsElfServer.message_id
|
|
)
|
|
|
|
ASCIIColors.green("Starting message generation by "+lollmsElfServer.personality.name)
|
|
lollmsElfServer.connections[client_id]['generation_thread'] = threading.Thread(target=lollmsElfServer.start_message_generation, args=(message, message.id, client_id))
|
|
lollmsElfServer.connections[client_id]['generation_thread'].start()
|
|
|
|
# lollmsElfServer.sio.sleep(0.01)
|
|
ASCIIColors.info("Started generation task")
|
|
lollmsElfServer.busy=True
|
|
#tpe = threading.Thread(target=lollmsElfServer.start_message_generation, args=(message, message_id, client_id))
|
|
#tpe.start()
|
|
else:
|
|
lollmsElfServer.error("I am busy. Come back later.", client_id=client_id)
|
|
|
|
@sio.on('generate_msg_from')
|
|
def handle_generate_msg_from(sid, data):
|
|
client_id = sid
|
|
lollmsElfServer.cancel_gen = False
|
|
lollmsElfServer.connections[client_id]["continuing"]=False
|
|
lollmsElfServer.connections[client_id]["first_chunk"]=True
|
|
|
|
if lollmsElfServer.connections[client_id]["current_discussion"] is None:
|
|
ASCIIColors.warning("Please select a discussion")
|
|
lollmsElfServer.error("Please select a discussion first", client_id=client_id)
|
|
return
|
|
id_ = data['id']
|
|
generation_type = data.get('msg_type',None)
|
|
if id_==-1:
|
|
message = lollmsElfServer.connections[client_id]["current_discussion"].current_message
|
|
else:
|
|
message = lollmsElfServer.connections[client_id]["current_discussion"].load_message(id_)
|
|
if message is None:
|
|
return
|
|
lollmsElfServer.connections[client_id]['generation_thread'] = threading.Thread(target=lollmsElfServer.start_message_generation, args=(message, message.id, client_id, False, generation_type))
|
|
lollmsElfServer.connections[client_id]['generation_thread'].start()
|
|
|
|
@sio.on('continue_generate_msg_from')
|
|
def handle_continue_generate_msg_from(sid, data):
|
|
client_id = sid
|
|
lollmsElfServer.cancel_gen = False
|
|
lollmsElfServer.connections[client_id]["continuing"]=True
|
|
lollmsElfServer.connections[client_id]["first_chunk"]=True
|
|
|
|
if lollmsElfServer.connections[client_id]["current_discussion"] is None:
|
|
ASCIIColors.yellow("Please select a discussion")
|
|
lollmsElfServer.error("Please select a discussion", client_id=client_id)
|
|
return
|
|
id_ = data['id']
|
|
if id_==-1:
|
|
message = lollmsElfServer.connections[client_id]["current_discussion"].current_message
|
|
else:
|
|
message = lollmsElfServer.connections[client_id]["current_discussion"].load_message(id_)
|
|
|
|
lollmsElfServer.connections[client_id]["generated_text"]=message.content
|
|
lollmsElfServer.connections[client_id]['generation_thread'] = threading.Thread(target=lollmsElfServer.start_message_generation, args=(message, message.id, client_id, True))
|
|
lollmsElfServer.connections[client_id]['generation_thread'].start()
|
|
|