This is a first stage for removing the LegacyWaffle* classes. LegacyWaffleFlag usage replaced with WaffleFlag; LegacyWaffleSwitche usage replaced with WaffleSwitch; New CourseWaffleFlag added to the temporary module __future__ as FutureCourseWaffleFlag; Updated all the imports to use CourseWaffleFlag from the __future__ module; BREAKING CHANGE: A number of toggle related constants (e.g. ENABLE_ACCESSIBILITY_POLICY_PAGE) changed types. They were strings, and are now toggle instances (e.g. WaffleSwitch). Although the entire refactor should be self-contained in edx-platform, if any plugins or dependencies were directly using these constants, they will break. If this is the case, try to find a better publicized way of exposing those toggles.
81 lines
2.4 KiB
Python
81 lines
2.4 KiB
Python
"""
|
|
Public views
|
|
"""
|
|
|
|
from urllib.parse import quote_plus
|
|
|
|
from django.conf import settings
|
|
from django.http.response import Http404
|
|
from django.shortcuts import redirect
|
|
|
|
from common.djangoapps.edxmako.shortcuts import render_to_response
|
|
|
|
from ..config.waffle import ENABLE_ACCESSIBILITY_POLICY_PAGE
|
|
|
|
__all__ = [
|
|
'register_redirect_to_lms', 'login_redirect_to_lms', 'howitworks', 'accessibility',
|
|
'redirect_to_lms_login_for_admin',
|
|
]
|
|
|
|
|
|
def register_redirect_to_lms(request):
|
|
"""
|
|
This view redirects to the LMS register view. It is used to temporarily keep the old
|
|
Studio signup url alive.
|
|
"""
|
|
register_url = '{register_url}{params}'.format(
|
|
register_url=settings.FRONTEND_REGISTER_URL,
|
|
params=_build_next_param(request),
|
|
)
|
|
return redirect(register_url, permanent=True)
|
|
|
|
|
|
def login_redirect_to_lms(request):
|
|
"""
|
|
This view redirects to the LMS login view. It is used for Django's LOGIN_URL
|
|
setting, which is where unauthenticated requests to protected endpoints are redirected.
|
|
"""
|
|
login_url = '{login_url}{params}'.format(
|
|
login_url=settings.FRONTEND_LOGIN_URL,
|
|
params=_build_next_param(request),
|
|
)
|
|
return redirect(login_url)
|
|
|
|
|
|
def redirect_to_lms_login_for_admin(request):
|
|
"""
|
|
This view redirect the admin/login url to the site's login page.
|
|
"""
|
|
return redirect('/login?next=/admin')
|
|
|
|
|
|
def _build_next_param(request):
|
|
""" Returns the next param to be used with login or register. """
|
|
next_url = request.GET.get('next')
|
|
next_url = next_url if next_url else settings.LOGIN_REDIRECT_URL
|
|
if next_url:
|
|
# Warning: do not use `build_absolute_uri` when `next_url` is empty because `build_absolute_uri` would
|
|
# build use the login url for the next url, which would cause a login redirect loop.
|
|
absolute_next_url = request.build_absolute_uri(next_url)
|
|
return '?next=' + quote_plus(absolute_next_url)
|
|
return ''
|
|
|
|
|
|
def howitworks(request):
|
|
"Proxy view"
|
|
if request.user.is_authenticated:
|
|
return redirect('/home/')
|
|
else:
|
|
return render_to_response('howitworks.html', {})
|
|
|
|
|
|
def accessibility(request):
|
|
"""
|
|
Display the accessibility accommodation form.
|
|
"""
|
|
if ENABLE_ACCESSIBILITY_POLICY_PAGE.is_enabled():
|
|
return render_to_response('accessibility.html', {
|
|
'language_code': request.LANGUAGE_CODE
|
|
})
|
|
raise Http404
|