Kevin Hu
commited on
Commit
·
59250e8
1
Parent(s):
63eb0ad
refine API token application (#2847)
Browse files### What problem does this PR solve?
#2846
### Type of change
- [x] New Feature (non-breaking change which adds functionality)
- api/apps/sdk/session.py +15 -15
- api/apps/system_app.py +46 -2
- api/db/db_models.py +7 -0
api/apps/sdk/session.py
CHANGED
@@ -24,9 +24,10 @@ from api.utils import get_uuid
|
|
24 |
from api.utils.api_utils import get_error_data_result
|
25 |
from api.utils.api_utils import get_result, token_required
|
26 |
|
|
|
27 |
@manager.route('/chat/<chat_id>/session', methods=['POST'])
|
28 |
@token_required
|
29 |
-
def create(tenant_id,chat_id):
|
30 |
req = request.json
|
31 |
req["dialog_id"] = chat_id
|
32 |
dia = DialogService.query(tenant_id=tenant_id, id=req["dialog_id"], status=StatusEnum.VALID.value)
|
@@ -50,17 +51,14 @@ def create(tenant_id,chat_id):
|
|
50 |
del conv["reference"]
|
51 |
return get_result(data=conv)
|
52 |
|
|
|
53 |
@manager.route('/chat/<chat_id>/session/<session_id>', methods=['PUT'])
|
54 |
@token_required
|
55 |
-
def update(tenant_id,chat_id,session_id):
|
56 |
req = request.json
|
57 |
-
if "dialog_id" in req and req.get("dialog_id") != chat_id:
|
58 |
-
return get_error_data_result(retmsg="Can't change chat_id")
|
59 |
-
if "chat_id" in req and req.get("chat_id") != chat_id:
|
60 |
-
return get_error_data_result(retmsg="Can't change chat_id")
|
61 |
req["dialog_id"] = chat_id
|
62 |
conv_id = session_id
|
63 |
-
conv = ConversationService.query(id=conv_id,dialog_id=chat_id)
|
64 |
if not conv:
|
65 |
return get_error_data_result(retmsg="Session does not exist")
|
66 |
if not DialogService.query(id=chat_id, tenant_id=tenant_id, status=StatusEnum.VALID.value):
|
@@ -78,14 +76,14 @@ def update(tenant_id,chat_id,session_id):
|
|
78 |
|
79 |
@manager.route('/chat/<chat_id>/session/<session_id>/completion', methods=['POST'])
|
80 |
@token_required
|
81 |
-
def completion(tenant_id,chat_id,session_id):
|
82 |
req = request.json
|
83 |
# req = {"conversation_id": "9aaaca4c11d311efa461fa163e197198", "messages": [
|
84 |
# {"role": "user", "content": "上海有吗?"}
|
85 |
# ]}
|
86 |
if not req.get("question"):
|
87 |
return get_error_data_result(retmsg="Please input your question.")
|
88 |
-
conv = ConversationService.query(id=session_id,dialog_id=chat_id)
|
89 |
if not conv:
|
90 |
return get_error_data_result(retmsg="Session does not exist")
|
91 |
conv = conv[0]
|
@@ -125,7 +123,7 @@ def completion(tenant_id,chat_id,session_id):
|
|
125 |
try:
|
126 |
for ans in chat(dia, msg, **req):
|
127 |
fillin_conv(ans)
|
128 |
-
yield "data:" + json.dumps({"code": 0,
|
129 |
ConversationService.update_by_id(conv.id, conv.to_dict())
|
130 |
except Exception as e:
|
131 |
yield "data:" + json.dumps({"code": 500, "message": str(e),
|
@@ -150,14 +148,15 @@ def completion(tenant_id,chat_id,session_id):
|
|
150 |
break
|
151 |
return get_result(data=answer)
|
152 |
|
|
|
153 |
@manager.route('/chat/<chat_id>/session', methods=['GET'])
|
154 |
@token_required
|
155 |
-
def list(chat_id,tenant_id):
|
156 |
if not DialogService.query(tenant_id=tenant_id, id=chat_id, status=StatusEnum.VALID.value):
|
157 |
return get_error_data_result(retmsg=f"You don't own the assistant {chat_id}.")
|
158 |
id = request.args.get("id")
|
159 |
name = request.args.get("name")
|
160 |
-
session = ConversationService.query(id=id,name=name,dialog_id=chat_id)
|
161 |
if not session:
|
162 |
return get_error_data_result(retmsg="The session doesn't exist")
|
163 |
page_number = int(request.args.get("page", 1))
|
@@ -167,7 +166,7 @@ def list(chat_id,tenant_id):
|
|
167 |
desc = False
|
168 |
else:
|
169 |
desc = True
|
170 |
-
convs = ConversationService.get_list(chat_id,page_number,items_per_page,orderby,desc,id,name)
|
171 |
if not convs:
|
172 |
return get_result(data=[])
|
173 |
for conv in convs:
|
@@ -202,16 +201,17 @@ def list(chat_id,tenant_id):
|
|
202 |
del conv["reference"]
|
203 |
return get_result(data=convs)
|
204 |
|
|
|
205 |
@manager.route('/chat/<chat_id>/session', methods=["DELETE"])
|
206 |
@token_required
|
207 |
-
def delete(tenant_id,chat_id):
|
208 |
if not DialogService.query(id=chat_id, tenant_id=tenant_id, status=StatusEnum.VALID.value):
|
209 |
return get_error_data_result(retmsg="You don't own the chat")
|
210 |
ids = request.json.get("ids")
|
211 |
if not ids:
|
212 |
return get_error_data_result(retmsg="`ids` is required in deleting operation")
|
213 |
for id in ids:
|
214 |
-
conv = ConversationService.query(id=id,dialog_id=chat_id)
|
215 |
if not conv:
|
216 |
return get_error_data_result(retmsg="The chat doesn't own the session")
|
217 |
ConversationService.delete_by_id(id)
|
|
|
24 |
from api.utils.api_utils import get_error_data_result
|
25 |
from api.utils.api_utils import get_result, token_required
|
26 |
|
27 |
+
|
28 |
@manager.route('/chat/<chat_id>/session', methods=['POST'])
|
29 |
@token_required
|
30 |
+
def create(tenant_id, chat_id):
|
31 |
req = request.json
|
32 |
req["dialog_id"] = chat_id
|
33 |
dia = DialogService.query(tenant_id=tenant_id, id=req["dialog_id"], status=StatusEnum.VALID.value)
|
|
|
51 |
del conv["reference"]
|
52 |
return get_result(data=conv)
|
53 |
|
54 |
+
|
55 |
@manager.route('/chat/<chat_id>/session/<session_id>', methods=['PUT'])
|
56 |
@token_required
|
57 |
+
def update(tenant_id, chat_id, session_id):
|
58 |
req = request.json
|
|
|
|
|
|
|
|
|
59 |
req["dialog_id"] = chat_id
|
60 |
conv_id = session_id
|
61 |
+
conv = ConversationService.query(id=conv_id, dialog_id=chat_id)
|
62 |
if not conv:
|
63 |
return get_error_data_result(retmsg="Session does not exist")
|
64 |
if not DialogService.query(id=chat_id, tenant_id=tenant_id, status=StatusEnum.VALID.value):
|
|
|
76 |
|
77 |
@manager.route('/chat/<chat_id>/session/<session_id>/completion', methods=['POST'])
|
78 |
@token_required
|
79 |
+
def completion(tenant_id, chat_id, session_id):
|
80 |
req = request.json
|
81 |
# req = {"conversation_id": "9aaaca4c11d311efa461fa163e197198", "messages": [
|
82 |
# {"role": "user", "content": "上海有吗?"}
|
83 |
# ]}
|
84 |
if not req.get("question"):
|
85 |
return get_error_data_result(retmsg="Please input your question.")
|
86 |
+
conv = ConversationService.query(id=session_id, dialog_id=chat_id)
|
87 |
if not conv:
|
88 |
return get_error_data_result(retmsg="Session does not exist")
|
89 |
conv = conv[0]
|
|
|
123 |
try:
|
124 |
for ans in chat(dia, msg, **req):
|
125 |
fillin_conv(ans)
|
126 |
+
yield "data:" + json.dumps({"code": 0, "data": ans}, ensure_ascii=False) + "\n\n"
|
127 |
ConversationService.update_by_id(conv.id, conv.to_dict())
|
128 |
except Exception as e:
|
129 |
yield "data:" + json.dumps({"code": 500, "message": str(e),
|
|
|
148 |
break
|
149 |
return get_result(data=answer)
|
150 |
|
151 |
+
|
152 |
@manager.route('/chat/<chat_id>/session', methods=['GET'])
|
153 |
@token_required
|
154 |
+
def list(chat_id, tenant_id):
|
155 |
if not DialogService.query(tenant_id=tenant_id, id=chat_id, status=StatusEnum.VALID.value):
|
156 |
return get_error_data_result(retmsg=f"You don't own the assistant {chat_id}.")
|
157 |
id = request.args.get("id")
|
158 |
name = request.args.get("name")
|
159 |
+
session = ConversationService.query(id=id, name=name, dialog_id=chat_id)
|
160 |
if not session:
|
161 |
return get_error_data_result(retmsg="The session doesn't exist")
|
162 |
page_number = int(request.args.get("page", 1))
|
|
|
166 |
desc = False
|
167 |
else:
|
168 |
desc = True
|
169 |
+
convs = ConversationService.get_list(chat_id, page_number, items_per_page, orderby, desc, id, name)
|
170 |
if not convs:
|
171 |
return get_result(data=[])
|
172 |
for conv in convs:
|
|
|
201 |
del conv["reference"]
|
202 |
return get_result(data=convs)
|
203 |
|
204 |
+
|
205 |
@manager.route('/chat/<chat_id>/session', methods=["DELETE"])
|
206 |
@token_required
|
207 |
+
def delete(tenant_id, chat_id):
|
208 |
if not DialogService.query(id=chat_id, tenant_id=tenant_id, status=StatusEnum.VALID.value):
|
209 |
return get_error_data_result(retmsg="You don't own the chat")
|
210 |
ids = request.json.get("ids")
|
211 |
if not ids:
|
212 |
return get_error_data_result(retmsg="`ids` is required in deleting operation")
|
213 |
for id in ids:
|
214 |
+
conv = ConversationService.query(id=id, dialog_id=chat_id)
|
215 |
if not conv:
|
216 |
return get_error_data_result(retmsg="The chat doesn't own the session")
|
217 |
ConversationService.delete_by_id(id)
|
api/apps/system_app.py
CHANGED
@@ -14,12 +14,17 @@
|
|
14 |
# limitations under the License
|
15 |
#
|
16 |
import json
|
|
|
17 |
|
18 |
-
from flask_login import login_required
|
19 |
|
|
|
|
|
20 |
from api.db.services.knowledgebase_service import KnowledgebaseService
|
|
|
21 |
from api.settings import DATABASE_TYPE
|
22 |
-
from api.utils
|
|
|
23 |
from api.versions import get_rag_version
|
24 |
from rag.settings import SVR_QUEUE_NAME
|
25 |
from rag.utils.es_conn import ELASTICSEARCH
|
@@ -88,3 +93,42 @@ def status():
|
|
88 |
res["task_executor"] = {"status": "red", "error": str(e)}
|
89 |
|
90 |
return get_json_result(data=res)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
14 |
# limitations under the License
|
15 |
#
|
16 |
import json
|
17 |
+
from datetime import datetime
|
18 |
|
19 |
+
from flask_login import login_required, current_user
|
20 |
|
21 |
+
from api.apps.api_app import generate_confirmation_token
|
22 |
+
from api.db.services.api_service import APITokenService
|
23 |
from api.db.services.knowledgebase_service import KnowledgebaseService
|
24 |
+
from api.db.services.user_service import UserTenantService
|
25 |
from api.settings import DATABASE_TYPE
|
26 |
+
from api.utils import current_timestamp, datetime_format
|
27 |
+
from api.utils.api_utils import get_json_result, request, get_data_error_result, server_error_response
|
28 |
from api.versions import get_rag_version
|
29 |
from rag.settings import SVR_QUEUE_NAME
|
30 |
from rag.utils.es_conn import ELASTICSEARCH
|
|
|
93 |
res["task_executor"] = {"status": "red", "error": str(e)}
|
94 |
|
95 |
return get_json_result(data=res)
|
96 |
+
|
97 |
+
|
98 |
+
@manager.route('/new_token', methods=['POST'])
|
99 |
+
@login_required
|
100 |
+
def new_token():
|
101 |
+
try:
|
102 |
+
tenants = UserTenantService.query(user_id=current_user.id)
|
103 |
+
if not tenants:
|
104 |
+
return get_data_error_result(retmsg="Tenant not found!")
|
105 |
+
|
106 |
+
tenant_id = tenants[0].tenant_id
|
107 |
+
obj = {"tenant_id": tenant_id, "token": generate_confirmation_token(tenant_id),
|
108 |
+
"create_time": current_timestamp(),
|
109 |
+
"create_date": datetime_format(datetime.now()),
|
110 |
+
"update_time": None,
|
111 |
+
"update_date": None
|
112 |
+
}
|
113 |
+
|
114 |
+
if not APITokenService.save(**obj):
|
115 |
+
return get_data_error_result(retmsg="Fail to new a dialog!")
|
116 |
+
|
117 |
+
return get_json_result(data=obj)
|
118 |
+
except Exception as e:
|
119 |
+
return server_error_response(e)
|
120 |
+
|
121 |
+
|
122 |
+
@manager.route('/token_list', methods=['GET'])
|
123 |
+
@login_required
|
124 |
+
def token_list():
|
125 |
+
try:
|
126 |
+
tenants = UserTenantService.query(user_id=current_user.id)
|
127 |
+
if not tenants:
|
128 |
+
return get_data_error_result(retmsg="Tenant not found!")
|
129 |
+
|
130 |
+
objs = APITokenService.query(tenant_id=tenants[0].tenant_id)
|
131 |
+
return get_json_result(data=[o.to_dict() for o in objs])
|
132 |
+
except Exception as e:
|
133 |
+
return server_error_response(e)
|
134 |
+
|
api/db/db_models.py
CHANGED
@@ -1052,4 +1052,11 @@ def migrate_db():
|
|
1052 |
)
|
1053 |
except Exception as e:
|
1054 |
pass
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1055 |
|
|
|
1052 |
)
|
1053 |
except Exception as e:
|
1054 |
pass
|
1055 |
+
try:
|
1056 |
+
migrate(
|
1057 |
+
migrator.alter_column_type('api_token', 'dialog_id',
|
1058 |
+
CharField(max_length=32, null=True, index=True))
|
1059 |
+
)
|
1060 |
+
except Exception as e:
|
1061 |
+
pass
|
1062 |
|