2025-06-06 14:28:21 +00:00
|
|
|
|
# coding=utf-8
|
|
|
|
|
|
"""
|
|
|
|
|
|
@project: MaxKB
|
|
|
|
|
|
@Author:虎虎
|
|
|
|
|
|
@file: ChatAuthentication.py
|
|
|
|
|
|
@date:2025/6/6 13:48
|
|
|
|
|
|
@desc:
|
|
|
|
|
|
"""
|
2025-06-23 03:19:20 +00:00
|
|
|
|
import uuid_utils.compat as uuid
|
2025-06-06 14:28:21 +00:00
|
|
|
|
|
|
|
|
|
|
from django.core import signing
|
|
|
|
|
|
from django.core.cache import cache
|
|
|
|
|
|
from django.db.models import QuerySet
|
|
|
|
|
|
from django.utils.translation import gettext_lazy as _
|
|
|
|
|
|
from rest_framework import serializers
|
|
|
|
|
|
|
2025-06-09 08:18:43 +00:00
|
|
|
|
from application.models import ApplicationAccessToken, ChatUserType, Application, ApplicationTypeChoices, \
|
2025-07-04 03:42:31 +00:00
|
|
|
|
ApplicationVersion
|
2025-06-06 14:28:21 +00:00
|
|
|
|
from application.serializers.application import ApplicationSerializerModel
|
|
|
|
|
|
from common.auth.common import ChatUserToken, ChatAuthentication
|
|
|
|
|
|
from common.constants.authentication_type import AuthenticationType
|
|
|
|
|
|
from common.constants.cache_version import Cache_Version
|
|
|
|
|
|
from common.database_model_manage.database_model_manage import DatabaseModelManage
|
2025-06-09 08:18:43 +00:00
|
|
|
|
from common.exception.app_exception import NotFound404, AppUnauthorizedFailed
|
2025-06-06 14:28:21 +00:00
|
|
|
|
|
|
|
|
|
|
|
2025-06-09 08:18:43 +00:00
|
|
|
|
class AnonymousAuthenticationSerializer(serializers.Serializer):
|
2025-06-06 14:28:21 +00:00
|
|
|
|
access_token = serializers.CharField(required=True, label=_("access_token"))
|
|
|
|
|
|
|
|
|
|
|
|
def auth(self, request, with_valid=True):
|
|
|
|
|
|
token = request.META.get('HTTP_AUTHORIZATION')
|
|
|
|
|
|
token_details = {}
|
|
|
|
|
|
try:
|
|
|
|
|
|
# 校验token
|
|
|
|
|
|
if token is not None:
|
2025-06-23 13:28:10 +00:00
|
|
|
|
token_details = signing.loads(token[7:])
|
2025-06-06 14:28:21 +00:00
|
|
|
|
except Exception as e:
|
|
|
|
|
|
pass
|
|
|
|
|
|
if with_valid:
|
|
|
|
|
|
self.is_valid(raise_exception=True)
|
|
|
|
|
|
access_token = self.data.get("access_token")
|
|
|
|
|
|
application_access_token = QuerySet(ApplicationAccessToken).filter(access_token=access_token).first()
|
|
|
|
|
|
if application_access_token is not None and application_access_token.is_active:
|
2025-06-23 03:19:20 +00:00
|
|
|
|
chat_user_id = token_details.get('chat_user_id') or str(uuid.uuid7())
|
2025-06-09 08:18:43 +00:00
|
|
|
|
_type = AuthenticationType.CHAT_ANONYMOUS_USER
|
|
|
|
|
|
return ChatUserToken(application_access_token.application_id, None, access_token, _type,
|
|
|
|
|
|
ChatUserType.ANONYMOUS_USER,
|
2025-06-09 08:57:04 +00:00
|
|
|
|
chat_user_id, ChatAuthentication(None)).to_token()
|
2025-06-06 14:28:21 +00:00
|
|
|
|
else:
|
|
|
|
|
|
raise NotFound404(404, _("Invalid access_token"))
|
|
|
|
|
|
|
|
|
|
|
|
|
2025-06-09 08:18:43 +00:00
|
|
|
|
class AuthProfileSerializer(serializers.Serializer):
|
|
|
|
|
|
access_token = serializers.CharField(required=True, label=_("access_token"))
|
|
|
|
|
|
|
|
|
|
|
|
def profile(self):
|
|
|
|
|
|
self.is_valid(raise_exception=True)
|
|
|
|
|
|
access_token = self.data.get("access_token")
|
|
|
|
|
|
application_access_token = QuerySet(ApplicationAccessToken).filter(access_token=access_token).first()
|
2025-07-14 06:09:31 +00:00
|
|
|
|
if application_access_token is None:
|
|
|
|
|
|
raise NotFound404(404, _("Invalid access_token"))
|
2025-06-09 08:18:43 +00:00
|
|
|
|
application_id = application_access_token.application_id
|
|
|
|
|
|
profile = {
|
|
|
|
|
|
'authentication': False
|
|
|
|
|
|
}
|
|
|
|
|
|
application_setting_model = DatabaseModelManage.get_model('application_setting')
|
|
|
|
|
|
if application_setting_model:
|
|
|
|
|
|
application_setting = QuerySet(application_setting_model).filter(application_id=application_id).first()
|
|
|
|
|
|
profile = {
|
|
|
|
|
|
'icon': application_setting.application.icon,
|
|
|
|
|
|
'application_name': application_setting.application.name,
|
|
|
|
|
|
'bg_icon': application_setting.chat_background,
|
2025-07-14 11:27:31 +00:00
|
|
|
|
'authentication': application_access_token.authentication,
|
|
|
|
|
|
'authentication_type': application_access_token.authentication_value.get(
|
2025-06-09 08:18:43 +00:00
|
|
|
|
'type', 'password'),
|
2025-07-14 11:27:31 +00:00
|
|
|
|
'login_value': application_access_token.authentication_value.get('login_value', [])
|
2025-06-09 08:18:43 +00:00
|
|
|
|
}
|
|
|
|
|
|
return profile
|
|
|
|
|
|
|
|
|
|
|
|
|
2025-06-06 14:28:21 +00:00
|
|
|
|
class ApplicationProfileSerializer(serializers.Serializer):
|
|
|
|
|
|
application_id = serializers.UUIDField(required=True, label=_("Application ID"))
|
|
|
|
|
|
|
2025-07-04 03:42:31 +00:00
|
|
|
|
@staticmethod
|
|
|
|
|
|
def reset_application(application, application_version):
|
|
|
|
|
|
update_field_dict = {
|
|
|
|
|
|
'application_name': 'name', 'desc': 'desc', 'prologue': 'prologue', 'dialogue_number': 'dialogue_number',
|
|
|
|
|
|
'user_id': 'user_id', 'model_id': 'model_id', 'knowledge_setting': 'knowledge_setting',
|
|
|
|
|
|
'model_setting': 'model_setting', 'model_params_setting': 'model_params_setting',
|
|
|
|
|
|
'tts_model_params_setting': 'tts_model_params_setting',
|
2025-07-10 09:49:07 +00:00
|
|
|
|
'problem_optimization': 'problem_optimization', 'work_flow': 'work_flow',
|
2025-07-04 03:42:31 +00:00
|
|
|
|
'problem_optimization_prompt': 'problem_optimization_prompt', 'tts_model_id': 'tts_model_id',
|
|
|
|
|
|
'stt_model_id': 'stt_model_id', 'tts_model_enable': 'tts_model_enable',
|
|
|
|
|
|
'stt_model_enable': 'stt_model_enable', 'tts_type': 'tts_type',
|
|
|
|
|
|
'tts_autoplay': 'tts_autoplay', 'stt_autosend': 'stt_autosend', 'file_upload_enable': 'file_upload_enable',
|
|
|
|
|
|
'file_upload_setting': 'file_upload_setting'
|
|
|
|
|
|
}
|
|
|
|
|
|
for (version_field, app_field) in update_field_dict.items():
|
|
|
|
|
|
_v = getattr(application_version, version_field)
|
|
|
|
|
|
if _v:
|
|
|
|
|
|
setattr(application, app_field, _v)
|
|
|
|
|
|
|
2025-06-06 14:28:21 +00:00
|
|
|
|
def profile(self, with_valid=True):
|
|
|
|
|
|
if with_valid:
|
|
|
|
|
|
self.is_valid()
|
|
|
|
|
|
application_id = self.data.get("application_id")
|
|
|
|
|
|
application = QuerySet(Application).get(id=application_id)
|
|
|
|
|
|
application_access_token = QuerySet(ApplicationAccessToken).filter(application_id=application.id).first()
|
|
|
|
|
|
if application_access_token is None:
|
|
|
|
|
|
raise AppUnauthorizedFailed(500, _("Illegal User"))
|
|
|
|
|
|
application_setting_model = DatabaseModelManage.get_model('application_setting')
|
2025-07-04 03:42:31 +00:00
|
|
|
|
application_version = QuerySet(ApplicationVersion).filter(application_id=application.id).order_by(
|
|
|
|
|
|
'-create_time')[0:1].first()
|
|
|
|
|
|
if application_version is not None:
|
|
|
|
|
|
self.reset_application(application, application_version)
|
2025-06-06 14:28:21 +00:00
|
|
|
|
license_is_valid = cache.get(Cache_Version.SYSTEM.get_key(key='license_is_valid'),
|
|
|
|
|
|
version=Cache_Version.SYSTEM.get_version())
|
|
|
|
|
|
application_setting_dict = {}
|
|
|
|
|
|
if application_setting_model is not None and license_is_valid:
|
|
|
|
|
|
application_setting = QuerySet(application_setting_model).filter(
|
|
|
|
|
|
application_id=application_access_token.application_id).first()
|
|
|
|
|
|
if application_setting is not None:
|
|
|
|
|
|
custom_theme = getattr(application_setting, 'custom_theme', {})
|
|
|
|
|
|
float_location = getattr(application_setting, 'float_location', {})
|
|
|
|
|
|
if not custom_theme:
|
|
|
|
|
|
application_setting.custom_theme = {
|
|
|
|
|
|
'theme_color': '',
|
|
|
|
|
|
'header_font_color': ''
|
|
|
|
|
|
}
|
|
|
|
|
|
if not float_location:
|
|
|
|
|
|
application_setting.float_location = {
|
|
|
|
|
|
'x': {'type': '', 'value': ''},
|
|
|
|
|
|
'y': {'type': '', 'value': ''}
|
|
|
|
|
|
}
|
|
|
|
|
|
application_setting_dict = {'show_source': application_access_token.show_source,
|
|
|
|
|
|
'show_history': application_setting.show_history,
|
|
|
|
|
|
'draggable': application_setting.draggable,
|
|
|
|
|
|
'show_guide': application_setting.show_guide,
|
|
|
|
|
|
'avatar': application_setting.avatar,
|
|
|
|
|
|
'show_avatar': application_setting.show_avatar,
|
|
|
|
|
|
'float_icon': application_setting.float_icon,
|
|
|
|
|
|
'disclaimer': application_setting.disclaimer,
|
|
|
|
|
|
'disclaimer_value': application_setting.disclaimer_value,
|
|
|
|
|
|
'custom_theme': application_setting.custom_theme,
|
|
|
|
|
|
'user_avatar': application_setting.user_avatar,
|
|
|
|
|
|
'show_user_avatar': application_setting.show_user_avatar,
|
2025-07-03 11:20:35 +00:00
|
|
|
|
'float_location': application_setting.float_location,
|
|
|
|
|
|
'chat_background': application_setting.chat_background}
|
2025-06-17 03:58:35 +00:00
|
|
|
|
base_node = [node for node in ((application.work_flow or {}).get('nodes', []) or []) if
|
|
|
|
|
|
node.get('id') == 'base-node']
|
2025-06-06 14:28:21 +00:00
|
|
|
|
return {**ApplicationSerializerModel(application).data,
|
|
|
|
|
|
'stt_model_id': application.stt_model_id,
|
|
|
|
|
|
'tts_model_id': application.tts_model_id,
|
|
|
|
|
|
'stt_model_enable': application.stt_model_enable,
|
|
|
|
|
|
'tts_model_enable': application.tts_model_enable,
|
|
|
|
|
|
'tts_type': application.tts_type,
|
|
|
|
|
|
'tts_autoplay': application.tts_autoplay,
|
|
|
|
|
|
'stt_autosend': application.stt_autosend,
|
|
|
|
|
|
'file_upload_enable': application.file_upload_enable,
|
|
|
|
|
|
'file_upload_setting': application.file_upload_setting,
|
2025-06-17 03:58:35 +00:00
|
|
|
|
'work_flow': {'nodes': base_node} if base_node else None,
|
2025-06-06 14:28:21 +00:00
|
|
|
|
'show_source': application_access_token.show_source,
|
2025-07-04 10:17:13 +00:00
|
|
|
|
'show_exec': application_access_token.show_exec,
|
2025-06-06 14:28:21 +00:00
|
|
|
|
'language': application_access_token.language,
|
|
|
|
|
|
**application_setting_dict}
|