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 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, "data": ans}, ensure_ascii=False) + "\n\n"
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.api_utils import get_json_result
 
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