* Zhipu sdk update 适配最新的智谱SDK,支持GLM4v (#1502) * 适配 google gemini 优化为从用户input中提取文件 * 适配最新的智谱SDK、支持glm-4v * requirements.txt fix * pending history check --------- Co-authored-by: binary-husky <qingxu.fu@outlook.com> * Update "生成多种Mermaid图表" plugin: Separate out the file reading function (#1520) * Update crazy_functional.py with new functionality deal with PDF * Update crazy_functional.py and Mermaid.py for plugin_kwargs * Update crazy_functional.py with new chart type: mind map * Update SELECT_PROMPT and i_say_show_user messages * Update ArgsReminder message in get_crazy_functions() function * Update with read md file and update PROMPTS * Return the PROMPTS as the test found that the initial version worked best * Update Mermaid chart generation function * version 3.71 * 解决issues #1510 * Remove unnecessary text from sys_prompt in 解析历史输入 function * Remove sys_prompt message in 解析历史输入 function * Update bridge_all.py: supports gpt-4-turbo-preview (#1517) * Update bridge_all.py: supports gpt-4-turbo-preview supports gpt-4-turbo-preview * Update bridge_all.py --------- Co-authored-by: binary-husky <96192199+binary-husky@users.noreply.github.com> * Update config.py: supports gpt-4-turbo-preview (#1516) * Update config.py: supports gpt-4-turbo-preview supports gpt-4-turbo-preview * Update config.py --------- Co-authored-by: binary-husky <96192199+binary-husky@users.noreply.github.com> * Refactor 解析历史输入 function to handle file input * Update Mermaid chart generation functionality * rename files and functions --------- Co-authored-by: binary-husky <qingxu.fu@outlook.com> Co-authored-by: hongyi-zhao <hongyi.zhao@gmail.com> Co-authored-by: binary-husky <96192199+binary-husky@users.noreply.github.com> * 接入mathpix ocr功能 (#1468) * Update Latex输出PDF结果.py 借助mathpix实现了PDF翻译中文并重新编译PDF * Update config.py add mathpix appid & appkey * Add 'PDF翻译中文并重新编译PDF' feature to plugins. --------- Co-authored-by: binary-husky <96192199+binary-husky@users.noreply.github.com> * fix zhipuai * check picture * remove glm-4 due to bug * 修改config * 检查MATHPIX_APPID * Remove unnecessary code and update function_plugins dictionary * capture non-standard token overflow * bug fix #1524 * change mermaid style * 支持mermaid 滚动放大缩小重置,鼠标滚动和拖拽 (#1530) * 支持mermaid 滚动放大缩小重置,鼠标滚动和拖拽 * 微调未果 先stage一下 * update --------- Co-authored-by: binary-husky <qingxu.fu@outlook.com> Co-authored-by: binary-husky <96192199+binary-husky@users.noreply.github.com> * ver 3.72 * change live2d * save the status of ``clear btn` in cookie * 前端选择保持 * js ui bug fix * reset btn bug fix * update live2d tips * fix missing get_token_num method * fix live2d toggle switch * fix persistent custom btn with cookie * fix zhipuai feedback with core functionality * Refactor button update and clean up functions * tailing space removal * Fix missing MATHPIX_APPID and MATHPIX_APPKEY configuration * Prompt fix、脑图提示词优化 (#1537) * 适配 google gemini 优化为从用户input中提取文件 * 脑图提示词优化 * Fix missing MATHPIX_APPID and MATHPIX_APPKEY configuration --------- Co-authored-by: binary-husky <qingxu.fu@outlook.com> * 优化“PDF翻译中文并重新编译PDF”插件 (#1602) * Add gemini_endpoint to API_URL_REDIRECT (#1560) * Add gemini_endpoint to API_URL_REDIRECT * Update gemini-pro and gemini-pro-vision model_info endpoints * Update to support new claude models (#1606) * Add anthropic library and update claude models * 更新bridge_claude.py文件,添加了对图片输入的支持。修复了一些bug。 * 添加Claude_3_Models变量以限制图片数量 * Refactor code to improve readability and maintainability * minor claude bug fix * more flexible one-api support * reformat config * fix one-api new access bug * dummy * compat non-standard api * version 3.73 --------- Co-authored-by: XIao <46100050+Kilig947@users.noreply.github.com> Co-authored-by: Menghuan1918 <menghuan2003@outlook.com> Co-authored-by: hongyi-zhao <hongyi.zhao@gmail.com> Co-authored-by: Hao Ma <893017927@qq.com> Co-authored-by: zeyuan huang <599012428@qq.com>
82 lines
2.5 KiB
Python
82 lines
2.5 KiB
Python
import re
|
||
import os
|
||
from functools import wraps, lru_cache
|
||
from shared_utils.advanced_markdown_format import format_io
|
||
from shared_utils.config_loader import get_conf as get_conf
|
||
|
||
|
||
pj = os.path.join
|
||
default_user_name = 'default_user'
|
||
|
||
|
||
def is_openai_api_key(key):
|
||
CUSTOM_API_KEY_PATTERN = get_conf('CUSTOM_API_KEY_PATTERN')
|
||
if len(CUSTOM_API_KEY_PATTERN) != 0:
|
||
API_MATCH_ORIGINAL = re.match(CUSTOM_API_KEY_PATTERN, key)
|
||
else:
|
||
API_MATCH_ORIGINAL = re.match(r"sk-[a-zA-Z0-9]{48}$|sess-[a-zA-Z0-9]{40}$", key)
|
||
return bool(API_MATCH_ORIGINAL)
|
||
|
||
|
||
def is_azure_api_key(key):
|
||
API_MATCH_AZURE = re.match(r"[a-zA-Z0-9]{32}$", key)
|
||
return bool(API_MATCH_AZURE)
|
||
|
||
|
||
def is_api2d_key(key):
|
||
API_MATCH_API2D = re.match(r"fk[a-zA-Z0-9]{6}-[a-zA-Z0-9]{32}$", key)
|
||
return bool(API_MATCH_API2D)
|
||
|
||
|
||
def is_any_api_key(key):
|
||
if ',' in key:
|
||
keys = key.split(',')
|
||
for k in keys:
|
||
if is_any_api_key(k): return True
|
||
return False
|
||
else:
|
||
return is_openai_api_key(key) or is_api2d_key(key) or is_azure_api_key(key)
|
||
|
||
|
||
def what_keys(keys):
|
||
avail_key_list = {'OpenAI Key': 0, "Azure Key": 0, "API2D Key": 0}
|
||
key_list = keys.split(',')
|
||
|
||
for k in key_list:
|
||
if is_openai_api_key(k):
|
||
avail_key_list['OpenAI Key'] += 1
|
||
|
||
for k in key_list:
|
||
if is_api2d_key(k):
|
||
avail_key_list['API2D Key'] += 1
|
||
|
||
for k in key_list:
|
||
if is_azure_api_key(k):
|
||
avail_key_list['Azure Key'] += 1
|
||
|
||
return f"检测到: OpenAI Key {avail_key_list['OpenAI Key']} 个, Azure Key {avail_key_list['Azure Key']} 个, API2D Key {avail_key_list['API2D Key']} 个"
|
||
|
||
|
||
def select_api_key(keys, llm_model):
|
||
import random
|
||
avail_key_list = []
|
||
key_list = keys.split(',')
|
||
|
||
if llm_model.startswith('gpt-') or llm_model.startswith('one-api-'):
|
||
for k in key_list:
|
||
if is_openai_api_key(k): avail_key_list.append(k)
|
||
|
||
if llm_model.startswith('api2d-'):
|
||
for k in key_list:
|
||
if is_api2d_key(k): avail_key_list.append(k)
|
||
|
||
if llm_model.startswith('azure-'):
|
||
for k in key_list:
|
||
if is_azure_api_key(k): avail_key_list.append(k)
|
||
|
||
if len(avail_key_list) == 0:
|
||
raise RuntimeError(f"您提供的api-key不满足要求,不包含任何可用于{llm_model}的api-key。您可能选择了错误的模型或请求源(右下角更换模型菜单中可切换openai,azure,claude,api2d等请求源)。")
|
||
|
||
api_key = random.choice(avail_key_list) # 随机负载均衡
|
||
return api_key
|