Spaces:
Sleeping
Sleeping
feat: 新增显示当前api_key的余额 (#372)
Browse files* feat: 支持显示余额
* fix: 修复余额解析错误
* perf: 优化展示效果;优化获取使用情况的方法
* 优化显示样式
* style: 统一变量名;文字靠左对齐
* Update ChuanhuChatbot.py
* perf: 更新key时自动更新API使用情况
* chore: 微调usage_display样式
---------
Co-authored-by: mzlegion <[email protected]>
Co-authored-by: Chuan Hu <[email protected]>
Co-authored-by: Keldos <[email protected]>
- ChuanhuChatbot.py +7 -2
- assets/custom.css +11 -0
- modules/openai_func.py +71 -0
- modules/presets.py +1 -0
- modules/utils.py +2 -1
ChuanhuChatbot.py
CHANGED
@@ -9,6 +9,7 @@ from modules.utils import *
|
|
9 |
from modules.presets import *
|
10 |
from modules.overwrites import *
|
11 |
from modules.chat_func import *
|
|
|
12 |
|
13 |
logging.basicConfig(
|
14 |
level=logging.DEBUG,
|
@@ -101,6 +102,8 @@ with gr.Blocks(css=customCSS, theme=small_and_beautiful_theme) as demo:
|
|
101 |
visible=not HIDE_MY_KEY,
|
102 |
label="API-Key",
|
103 |
)
|
|
|
|
|
104 |
model_select_dropdown = gr.Dropdown(
|
105 |
label="选择模型", choices=MODELS, multiselect=False, value=MODELS[0]
|
106 |
)
|
@@ -260,11 +263,13 @@ with gr.Blocks(css=customCSS, theme=small_and_beautiful_theme) as demo:
|
|
260 |
fn=transfer_input, inputs=[user_input], outputs=[user_question, user_input, submitBtn, cancelBtn], show_progress=True
|
261 |
)
|
262 |
|
263 |
-
keyTxt.submit(submit_key, keyTxt, [user_api_key, status_display])
|
264 |
-
keyTxt.change(submit_key, keyTxt, [user_api_key, status_display])
|
265 |
# Chatbot
|
266 |
cancelBtn.click(cancel_outputing, [], [])
|
267 |
|
|
|
|
|
268 |
user_input.submit(**transfer_input_args).then(**chatgpt_predict_args).then(**end_outputing_args)
|
269 |
|
270 |
submitBtn.click(**transfer_input_args).then(**chatgpt_predict_args).then(**end_outputing_args)
|
|
|
9 |
from modules.presets import *
|
10 |
from modules.overwrites import *
|
11 |
from modules.chat_func import *
|
12 |
+
from modules.openai_func import get_usage
|
13 |
|
14 |
logging.basicConfig(
|
15 |
level=logging.DEBUG,
|
|
|
102 |
visible=not HIDE_MY_KEY,
|
103 |
label="API-Key",
|
104 |
)
|
105 |
+
usageTxt = gr.Markdown(get_usage(my_api_key), elem_id="usage_display")
|
106 |
+
usageUpdateBtn = gr.Button("🔄 更新API使用情况")
|
107 |
model_select_dropdown = gr.Dropdown(
|
108 |
label="选择模型", choices=MODELS, multiselect=False, value=MODELS[0]
|
109 |
)
|
|
|
263 |
fn=transfer_input, inputs=[user_input], outputs=[user_question, user_input, submitBtn, cancelBtn], show_progress=True
|
264 |
)
|
265 |
|
266 |
+
keyTxt.submit(submit_key, keyTxt, [user_api_key, status_display, usageTxt])
|
267 |
+
keyTxt.change(submit_key, keyTxt, [user_api_key, status_display, usageTxt])
|
268 |
# Chatbot
|
269 |
cancelBtn.click(cancel_outputing, [], [])
|
270 |
|
271 |
+
usageUpdateBtn.click(get_usage, [user_api_key], [usageTxt], show_progress=True)
|
272 |
+
|
273 |
user_input.submit(**transfer_input_args).then(**chatgpt_predict_args).then(**end_outputing_args)
|
274 |
|
275 |
submitBtn.click(**transfer_input_args).then(**chatgpt_predict_args).then(**end_outputing_args)
|
assets/custom.css
CHANGED
@@ -19,6 +19,17 @@
|
|
19 |
#chuanhu_chatbot, #status_display {
|
20 |
transition: all 0.6s;
|
21 |
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
22 |
/* list */
|
23 |
ol:not(.options), ul:not(.options) {
|
24 |
padding-inline-start: 2em !important;
|
|
|
19 |
#chuanhu_chatbot, #status_display {
|
20 |
transition: all 0.6s;
|
21 |
}
|
22 |
+
|
23 |
+
/* usage_display */
|
24 |
+
#usage_display {
|
25 |
+
height: 1em;
|
26 |
+
}
|
27 |
+
#usage_display p{
|
28 |
+
padding: 0 1em;
|
29 |
+
font-size: .85em;
|
30 |
+
font-family: monospace;
|
31 |
+
color: var(--body-text-color-subdued);
|
32 |
+
}
|
33 |
/* list */
|
34 |
ol:not(.options), ul:not(.options) {
|
35 |
padding-inline-start: 2em !important;
|
modules/openai_func.py
ADDED
@@ -0,0 +1,71 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import requests
|
2 |
+
import logging
|
3 |
+
from modules.presets import timeout_all, BALANCE_API_URL,standard_error_msg,connection_timeout_prompt,error_retrieve_prompt,read_timeout_prompt
|
4 |
+
from modules import shared
|
5 |
+
import os
|
6 |
+
|
7 |
+
|
8 |
+
def get_usage_response(openai_api_key):
|
9 |
+
headers = {
|
10 |
+
"Content-Type": "application/json",
|
11 |
+
"Authorization": f"Bearer {openai_api_key}",
|
12 |
+
}
|
13 |
+
|
14 |
+
timeout = timeout_all
|
15 |
+
|
16 |
+
# 获取环境变量中的代理设置
|
17 |
+
http_proxy = os.environ.get("HTTP_PROXY") or os.environ.get("http_proxy")
|
18 |
+
https_proxy = os.environ.get(
|
19 |
+
"HTTPS_PROXY") or os.environ.get("https_proxy")
|
20 |
+
|
21 |
+
# 如果存在代理设置,使用它们
|
22 |
+
proxies = {}
|
23 |
+
if http_proxy:
|
24 |
+
logging.info(f"使用 HTTP 代理: {http_proxy}")
|
25 |
+
proxies["http"] = http_proxy
|
26 |
+
if https_proxy:
|
27 |
+
logging.info(f"使用 HTTPS 代理: {https_proxy}")
|
28 |
+
proxies["https"] = https_proxy
|
29 |
+
|
30 |
+
# 如果有代理,使用代理发送请求,否则使用默认设置发送请求
|
31 |
+
"""
|
32 |
+
暂不支持修改
|
33 |
+
if shared.state.balance_api_url != BALANCE_API_URL:
|
34 |
+
logging.info(f"使用自定义BALANCE API URL: {shared.state.balance_api_url}")
|
35 |
+
"""
|
36 |
+
if proxies:
|
37 |
+
response = requests.get(
|
38 |
+
BALANCE_API_URL,
|
39 |
+
headers=headers,
|
40 |
+
timeout=timeout,
|
41 |
+
proxies=proxies,
|
42 |
+
)
|
43 |
+
else:
|
44 |
+
response = requests.get(
|
45 |
+
BALANCE_API_URL,
|
46 |
+
headers=headers,
|
47 |
+
timeout=timeout,
|
48 |
+
)
|
49 |
+
return response
|
50 |
+
|
51 |
+
def get_usage(openai_api_key):
|
52 |
+
try:
|
53 |
+
response=get_usage_response(openai_api_key=openai_api_key)
|
54 |
+
print(response.json())
|
55 |
+
try:
|
56 |
+
balance = response.json().get("total_available") if response.json().get(
|
57 |
+
"total_available") else 0
|
58 |
+
total_used = response.json().get("total_used") if response.json().get(
|
59 |
+
"total_used") else 0
|
60 |
+
except Exception as e:
|
61 |
+
logging.error(f"API使用情况解析失败:"+str(e))
|
62 |
+
balance = 0
|
63 |
+
total_used=0
|
64 |
+
return f"**API使用情况**(已用/余额)\u3000{total_used}$ / {balance}$"
|
65 |
+
except requests.exceptions.ConnectTimeout:
|
66 |
+
status_text = standard_error_msg + connection_timeout_prompt + error_retrieve_prompt
|
67 |
+
return status_text
|
68 |
+
except requests.exceptions.ReadTimeout:
|
69 |
+
status_text = standard_error_msg + read_timeout_prompt + error_retrieve_prompt
|
70 |
+
return status_text
|
71 |
+
|
modules/presets.py
CHANGED
@@ -4,6 +4,7 @@ import gradio as gr
|
|
4 |
# ChatGPT 设置
|
5 |
initial_prompt = "You are a helpful assistant."
|
6 |
API_URL = "https://api.openai.com/v1/chat/completions"
|
|
|
7 |
HISTORY_DIR = "history"
|
8 |
TEMPLATES_DIR = "templates"
|
9 |
|
|
|
4 |
# ChatGPT 设置
|
5 |
initial_prompt = "You are a helpful assistant."
|
6 |
API_URL = "https://api.openai.com/v1/chat/completions"
|
7 |
+
BALANCE_API_URL="https://api.openai.com/dashboard/billing/credit_grants"
|
8 |
HISTORY_DIR = "history"
|
9 |
TEMPLATES_DIR = "templates"
|
10 |
|
modules/utils.py
CHANGED
@@ -22,6 +22,7 @@ from pygments.formatters import HtmlFormatter
|
|
22 |
|
23 |
from modules.presets import *
|
24 |
import modules.shared as shared
|
|
|
25 |
|
26 |
logging.basicConfig(
|
27 |
level=logging.INFO,
|
@@ -349,7 +350,7 @@ def submit_key(key):
|
|
349 |
key = key.strip()
|
350 |
msg = f"API密钥更改为了{hide_middle_chars(key)}"
|
351 |
logging.info(msg)
|
352 |
-
return key, msg
|
353 |
|
354 |
|
355 |
def sha1sum(filename):
|
|
|
22 |
|
23 |
from modules.presets import *
|
24 |
import modules.shared as shared
|
25 |
+
from modules.openai_func import get_usage
|
26 |
|
27 |
logging.basicConfig(
|
28 |
level=logging.INFO,
|
|
|
350 |
key = key.strip()
|
351 |
msg = f"API密钥更改为了{hide_middle_chars(key)}"
|
352 |
logging.info(msg)
|
353 |
+
return key, msg, get_usage(key)
|
354 |
|
355 |
|
356 |
def sha1sum(filename):
|