2022-08-04 06:40:33 +00:00
|
|
|
from django.views import View
|
|
|
|
from django.conf import settings
|
2022-08-26 09:59:16 +00:00
|
|
|
from django.contrib import auth
|
2022-08-04 06:40:33 +00:00
|
|
|
from django.http import HttpResponseRedirect
|
|
|
|
from django.urls import reverse
|
|
|
|
from django.utils.http import urlencode
|
2024-03-06 06:49:20 +00:00
|
|
|
from django.utils.translation import gettext_lazy as _
|
2022-08-04 06:40:33 +00:00
|
|
|
|
|
|
|
from authentication.utils import build_absolute_uri
|
2024-03-06 06:49:20 +00:00
|
|
|
from authentication.views.mixins import FlashMessageMixin
|
2022-08-04 06:40:33 +00:00
|
|
|
from authentication.mixins import authenticate
|
2024-03-06 06:49:20 +00:00
|
|
|
from common.utils import get_logger
|
|
|
|
|
2022-08-04 06:40:33 +00:00
|
|
|
|
|
|
|
logger = get_logger(__file__)
|
|
|
|
|
|
|
|
|
|
|
|
class OAuth2AuthRequestView(View):
|
|
|
|
|
|
|
|
def get(self, request):
|
|
|
|
log_prompt = "Process OAuth2 GET requests: {}"
|
|
|
|
logger.debug(log_prompt.format('Start'))
|
|
|
|
|
|
|
|
query_dict = {
|
|
|
|
'client_id': settings.AUTH_OAUTH2_CLIENT_ID, 'response_type': 'code',
|
|
|
|
'scope': settings.AUTH_OAUTH2_SCOPE,
|
|
|
|
'redirect_uri': build_absolute_uri(
|
|
|
|
request, path=reverse(settings.AUTH_OAUTH2_AUTH_LOGIN_CALLBACK_URL_NAME)
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2022-12-13 13:57:17 +00:00
|
|
|
if '?' in settings.AUTH_OAUTH2_PROVIDER_AUTHORIZATION_ENDPOINT:
|
|
|
|
separator = '&'
|
|
|
|
else:
|
|
|
|
separator = '?'
|
|
|
|
redirect_url = '{url}{separator}{query}'.format(
|
2022-08-08 06:54:54 +00:00
|
|
|
url=settings.AUTH_OAUTH2_PROVIDER_AUTHORIZATION_ENDPOINT,
|
2022-12-13 13:57:17 +00:00
|
|
|
separator=separator,
|
2022-08-08 06:54:54 +00:00
|
|
|
query=urlencode(query_dict)
|
|
|
|
)
|
2022-08-04 06:40:33 +00:00
|
|
|
logger.debug(log_prompt.format('Redirect login url'))
|
|
|
|
return HttpResponseRedirect(redirect_url)
|
|
|
|
|
|
|
|
|
2024-03-06 06:49:20 +00:00
|
|
|
class OAuth2AuthCallbackView(View, FlashMessageMixin):
|
2022-08-04 06:40:33 +00:00
|
|
|
http_method_names = ['get', ]
|
|
|
|
|
|
|
|
def get(self, request):
|
|
|
|
""" Processes GET requests. """
|
|
|
|
log_prompt = "Process GET requests [OAuth2AuthCallbackView]: {}"
|
|
|
|
logger.debug(log_prompt.format('Start'))
|
|
|
|
callback_params = request.GET
|
|
|
|
|
|
|
|
if 'code' in callback_params:
|
|
|
|
logger.debug(log_prompt.format('Process authenticate'))
|
|
|
|
user = authenticate(code=callback_params['code'], request=request)
|
2024-03-06 06:49:20 +00:00
|
|
|
|
|
|
|
if err_msg := getattr(request, 'error_message', ''):
|
|
|
|
login_url = reverse('authentication:login') + '?admin=1'
|
|
|
|
return self.get_failed_response(login_url, title=_('Authentication failed'), msg=err_msg)
|
|
|
|
|
2022-08-04 06:40:33 +00:00
|
|
|
if user and user.is_valid:
|
|
|
|
logger.debug(log_prompt.format('Login: {}'.format(user)))
|
2022-08-26 09:59:16 +00:00
|
|
|
auth.login(self.request, user)
|
2022-08-04 06:40:33 +00:00
|
|
|
logger.debug(log_prompt.format('Redirect'))
|
|
|
|
return HttpResponseRedirect(
|
|
|
|
settings.AUTH_OAUTH2_AUTHENTICATION_REDIRECT_URI
|
|
|
|
)
|
|
|
|
|
|
|
|
logger.debug(log_prompt.format('Redirect'))
|
2022-10-11 10:37:49 +00:00
|
|
|
# OAuth2 服务端认证成功, 但是用户被禁用了, 这时候需要调用服务端的logout
|
|
|
|
redirect_url = settings.AUTH_OAUTH2_PROVIDER_END_SESSION_ENDPOINT
|
|
|
|
return HttpResponseRedirect(redirect_url)
|
2022-08-26 09:59:16 +00:00
|
|
|
|
|
|
|
|
|
|
|
class OAuth2EndSessionView(View):
|
|
|
|
http_method_names = ['get', 'post', ]
|
|
|
|
|
|
|
|
def get(self, request):
|
|
|
|
""" Processes GET requests. """
|
|
|
|
log_prompt = "Process GET requests [OAuth2EndSessionView]: {}"
|
|
|
|
logger.debug(log_prompt.format('Start'))
|
|
|
|
return self.post(request)
|
|
|
|
|
|
|
|
def post(self, request):
|
|
|
|
""" Processes POST requests. """
|
|
|
|
log_prompt = "Process POST requests [OAuth2EndSessionView]: {}"
|
|
|
|
logger.debug(log_prompt.format('Start'))
|
|
|
|
|
|
|
|
logout_url = settings.LOGOUT_REDIRECT_URL or '/'
|
|
|
|
|
|
|
|
# Log out the current user.
|
|
|
|
if request.user.is_authenticated:
|
|
|
|
logger.debug(log_prompt.format('Log out the current user: {}'.format(request.user)))
|
|
|
|
auth.logout(request)
|
|
|
|
|
2023-02-09 03:22:58 +00:00
|
|
|
logout_url = settings.AUTH_OAUTH2_PROVIDER_END_SESSION_ENDPOINT
|
|
|
|
if settings.AUTH_OAUTH2_LOGOUT_COMPLETELY and logout_url:
|
2022-08-26 09:59:16 +00:00
|
|
|
logger.debug(log_prompt.format('Log out OAUTH2 platform user session synchronously'))
|
2023-02-09 03:22:58 +00:00
|
|
|
return HttpResponseRedirect(logout_url)
|
2022-08-26 09:59:16 +00:00
|
|
|
|
|
|
|
logger.debug(log_prompt.format('Redirect'))
|
|
|
|
return HttpResponseRedirect(logout_url)
|