UnisKB/apps/common/auth/handle/impl/application_key.py

44 lines
2.0 KiB
Python
Raw Normal View History

2025-07-10 11:16:47 +00:00
# coding=utf-8
"""
@project: MaxKB
@Author虎虎
@file application_key.py
@date2025/7/10 03:02
@desc: 应用api key认证
"""
from django.db.models import QuerySet
from django.utils.translation import gettext_lazy as _
from application.models import ApplicationApiKey, ChatUserType
from common.auth.handle.auth_base_handle import AuthBaseHandle
from common.constants.permission_constants import Permission, Group, Operate, RoleConstants, ChatAuth
from common.database_model_manage.database_model_manage import DatabaseModelManage
from common.exception.app_exception import AppAuthenticationFailed
class ApplicationKey(AuthBaseHandle):
def handle(self, request, token: str, get_token_details):
application_api_key = QuerySet(ApplicationApiKey).filter(secret_key=token).first()
if application_api_key is None:
raise AppAuthenticationFailed(500, _('Secret key is invalid'))
if not application_api_key.is_active:
raise AppAuthenticationFailed(500, _('Secret key is invalid'))
application_setting_model = DatabaseModelManage.get_model("application_setting")
if application_setting_model is not None:
application_setting = QuerySet(application_setting_model).filter(
application_id=application_api_key.application_id).first()
if application_setting.authentication:
if application_setting.authentication != 'password':
raise AppAuthenticationFailed(1002, _('Authentication information is incorrect'))
return None, ChatAuth(
current_role_list=[RoleConstants.CHAT_ANONYMOUS_USER],
permission_list=[
Permission(group=Group.APPLICATION,
operate=Operate.READ)],
application_id=application_api_key.application_id,
chat_user_id=str(application_api_key.id),
chat_user_type=ChatUserType.ANONYMOUS_USER.value)
def support(self, request, token: str, get_token_details):
return str(token).startswith("application-")