mirror of
https://github.com/jumpserver/jumpserver.git
synced 2025-10-21 07:49:45 +00:00
* fix: 【登录】第三方用户登录复核,拒绝状态,未真正拦截 * fix: 【登录日志】登录复核用户被拒绝,登录日志无登录日志记录】 * fix: 【登录日志】用户设置登录复核,登录。此时不处理工单,管理员全局组织下查看登录日志,日志无限新增,且无记录用户名】 Co-authored-by: huangzhiwen <zhiwen.huang@fit2cloud.com>
37 lines
1.2 KiB
Python
37 lines
1.2 KiB
Python
# -*- coding: utf-8 -*-
|
|
#
|
|
from rest_framework.response import Response
|
|
from rest_framework.views import APIView
|
|
from rest_framework.permissions import AllowAny
|
|
|
|
from common.utils import get_logger
|
|
from .. import errors, mixins
|
|
from django.contrib.auth import logout as auth_logout
|
|
|
|
|
|
__all__ = ['TicketStatusApi']
|
|
logger = get_logger(__name__)
|
|
|
|
|
|
class TicketStatusApi(mixins.AuthMixin, APIView):
|
|
permission_classes = (AllowAny,)
|
|
|
|
def get(self, request, *args, **kwargs):
|
|
try:
|
|
self.check_user_login_confirm()
|
|
self.request.session['auth_third_party_done'] = 1
|
|
return Response({"msg": "ok"})
|
|
except errors.LoginConfirmOtherError as e:
|
|
self.send_auth_signal(success=False, user=request.user, username=request.user.name, reason=e.as_data().get('msg'))
|
|
auth_logout(request)
|
|
return Response(e.as_data(), status=200)
|
|
except errors.NeedMoreInfoError as e:
|
|
return Response(e.as_data(), status=200)
|
|
|
|
def delete(self, request, *args, **kwargs):
|
|
ticket = self.get_ticket()
|
|
if ticket:
|
|
request.session.pop('auth_ticket_id', '')
|
|
ticket.close()
|
|
return Response('', status=200)
|