* Update version to 3.74 * Add support for Yi Model API (#1635) * 更新以支持零一万物模型 * 删除newbing * 修改config --------- Co-authored-by: binary-husky <qingxu.fu@outlook.com> * Refactor function signatures in bridge files * fix qwen api change * rename and ref functions * rename and move some cookie functions * 增加haiku模型,新增endpoint配置说明 (#1626) * haiku added * 新增haiku,新增endpoint配置说明 * Haiku added * 将说明同步至最新Endpoint --------- Co-authored-by: binary-husky <qingxu.fu@outlook.com> * private_upload目录下进行文件鉴权 (#1596) * private_upload目录下进行文件鉴权 * minor fastapi adjustment * Add logging functionality to enable saving conversation records * waiting to fix username retrieve * support 2rd web path * allow accessing default user dir --------- Co-authored-by: binary-husky <qingxu.fu@outlook.com> * remove yaml deps * fix favicon * fix abs path auth problem * forget to write a return * add `dashscope` to deps * fix GHSA-v9q9-xj86-953p * 用户名重叠越权访问patch (#1681) * add cohere model api access * cohere + can_multi_thread * fix block user access(fail) * fix fastapi bug * change cohere api endpoint * explain version --------- Co-authored-by: Menghuan1918 <menghuan2003@outlook.com> Co-authored-by: Skyzayre <120616113+Skyzayre@users.noreply.github.com> Co-authored-by: XIao <46100050+Kilig947@users.noreply.github.com>
97 lines
4.0 KiB
Python
97 lines
4.0 KiB
Python
import time
|
||
import os
|
||
from toolbox import update_ui, get_conf, update_ui_lastest_msg, log_chat
|
||
from toolbox import check_packages, report_exception, have_any_recent_upload_image_files
|
||
from toolbox import ChatBotWithCookies
|
||
|
||
model_name = '智谱AI大模型'
|
||
zhipuai_default_model = 'glm-4'
|
||
|
||
def validate_key():
|
||
ZHIPUAI_API_KEY = get_conf("ZHIPUAI_API_KEY")
|
||
if ZHIPUAI_API_KEY == '': return False
|
||
return True
|
||
|
||
def make_media_input(inputs, image_paths):
|
||
for image_path in image_paths:
|
||
inputs = inputs + f'<br/><br/><div align="center"><img src="file={os.path.abspath(image_path)}"></div>'
|
||
return inputs
|
||
|
||
def predict_no_ui_long_connection(inputs:str, llm_kwargs:dict, history:list=[], sys_prompt:str="",
|
||
observe_window:list=[], console_slience:bool=False):
|
||
"""
|
||
⭐多线程方法
|
||
函数的说明请见 request_llms/bridge_all.py
|
||
"""
|
||
watch_dog_patience = 5
|
||
response = ""
|
||
|
||
if llm_kwargs["llm_model"] == "zhipuai":
|
||
llm_kwargs["llm_model"] = zhipuai_default_model
|
||
|
||
if validate_key() is False:
|
||
raise RuntimeError('请配置ZHIPUAI_API_KEY')
|
||
|
||
# 开始接收回复
|
||
from .com_zhipuglm import ZhipuChatInit
|
||
zhipu_bro_init = ZhipuChatInit()
|
||
for chunk, response in zhipu_bro_init.generate_chat(inputs, llm_kwargs, history, sys_prompt):
|
||
if len(observe_window) >= 1:
|
||
observe_window[0] = response
|
||
if len(observe_window) >= 2:
|
||
if (time.time() - observe_window[1]) > watch_dog_patience:
|
||
raise RuntimeError("程序终止。")
|
||
return response
|
||
|
||
|
||
def predict(inputs:str, llm_kwargs:dict, plugin_kwargs:dict, chatbot:ChatBotWithCookies,
|
||
history:list=[], system_prompt:str='', stream:bool=True, additional_fn:str=None):
|
||
"""
|
||
⭐单线程方法
|
||
函数的说明请见 request_llms/bridge_all.py
|
||
"""
|
||
chatbot.append([inputs, ""])
|
||
yield from update_ui(chatbot=chatbot, history=history)
|
||
|
||
# 尝试导入依赖,如果缺少依赖,则给出安装建议
|
||
try:
|
||
check_packages(["zhipuai"])
|
||
except:
|
||
yield from update_ui_lastest_msg(f"导入软件依赖失败。使用该模型需要额外依赖,安装方法```pip install --upgrade zhipuai```。",
|
||
chatbot=chatbot, history=history, delay=0)
|
||
return
|
||
|
||
if validate_key() is False:
|
||
yield from update_ui_lastest_msg(lastmsg="[Local Message] 请配置ZHIPUAI_API_KEY", chatbot=chatbot, history=history, delay=0)
|
||
return
|
||
|
||
if additional_fn is not None:
|
||
from core_functional import handle_core_functionality
|
||
inputs, history = handle_core_functionality(additional_fn, inputs, history, chatbot)
|
||
chatbot[-1] = [inputs, ""]
|
||
yield from update_ui(chatbot=chatbot, history=history)
|
||
|
||
if llm_kwargs["llm_model"] == "zhipuai":
|
||
llm_kwargs["llm_model"] = zhipuai_default_model
|
||
|
||
if llm_kwargs["llm_model"] in ["glm-4v"]:
|
||
have_recent_file, image_paths = have_any_recent_upload_image_files(chatbot)
|
||
if not have_recent_file:
|
||
chatbot.append((inputs, "没有检测到任何近期上传的图像文件,请上传jpg格式的图片,此外,请注意拓展名需要小写"))
|
||
yield from update_ui(chatbot=chatbot, history=history, msg="等待图片") # 刷新界面
|
||
return
|
||
if have_recent_file:
|
||
inputs = make_media_input(inputs, image_paths)
|
||
chatbot[-1] = [inputs, ""]
|
||
yield from update_ui(chatbot=chatbot, history=history)
|
||
|
||
|
||
# 开始接收回复
|
||
from .com_zhipuglm import ZhipuChatInit
|
||
zhipu_bro_init = ZhipuChatInit()
|
||
for chunk, response in zhipu_bro_init.generate_chat(inputs, llm_kwargs, history, system_prompt):
|
||
chatbot[-1] = [inputs, response]
|
||
yield from update_ui(chatbot=chatbot, history=history)
|
||
history.extend([inputs, response])
|
||
log_chat(llm_model=llm_kwargs["llm_model"], input_str=inputs, output_str=response)
|
||
yield from update_ui(chatbot=chatbot, history=history) |