This completes the work started in https://github.com/edx/edx-platform/pull/19453 to use the LMS login and registration for Studio, rather than Studio providing its own implementation. LMS login/registration are being used for the following reasons: 1. LMS logistration properly handles all SSO integrations. 2. A single logistration is simpler to maintain and understand. 3. Allows Studio to work more like all other IDAs that use LMS logistration. The original switch to use LMS logistration for Studio also added the toggle `DISABLE_STUDIO_SSO_OVER_LMS` to provide the community some additional time for switching. This commit removes this toggle, which at this point means all deployments will use the LMS logistration. This change requires sharing cookies across LMS and Studio. Should that prove to be a problem for certain Open edX instances, there are discussions of possible alternative solutions. See https://github.com/edx/edx-platform/pull/19845#issuecomment-559154256 Detailed changes: * Fix some Studio links that still went to old Studio signin and signup. * Remove DISABLE_STUDIO_SSO_OVER_LMS feature toggle. * Remove old studio signin and signup pages and templates. * Fix url name "login", which had different meanings for Studio and LMS. * Use the following settings: LOGIN_URL, FRONTEND_LOGIN_URL, FRONTEND_LOGOUT_URL, and FRONTEND_REGISTER_URL. * Redirect /signin and /signup to the LMS logistration. * Add custom metric `uses_pattern_library`. * Add custom metric `student_activate_account`. * Add Django Settings to allow /signin, /signup, and /login_post to be disabled once ready. This work also relates to ARCH-218 and DEPR-6. ARCH-1253
69 lines
2.8 KiB
HTML
69 lines
2.8 KiB
HTML
<%page expression_filter="h"/>
|
|
<%namespace name='static' file='../static_content.html'/>
|
|
<%!
|
|
from django.conf import settings
|
|
from django.urls import reverse
|
|
from django.utils.translation import ugettext as _
|
|
from edx_django_utils.monitoring import set_custom_metric
|
|
from student.roles import GlobalStaff
|
|
%>
|
|
|
|
% if uses_pattern_library:
|
|
<%!
|
|
## TODO: Use metric to see if CMS ever uses pattern library or if this case can be deleted.
|
|
## NOTE: When removing, remove all references to `set_custom_metric`.
|
|
set_custom_metric('uses_pattern_library', True)
|
|
%>
|
|
<div class="wrapper-user-menu dropdown-menu-container logged-in js-header-user-menu">
|
|
<h3 class="title menu-title">
|
|
<span class="sr-only">${_("Currently signed in as:")}</span>
|
|
<span class="account-username" title="${ user.username }">${ user.username }</span>
|
|
</h3>
|
|
<button type="button" class="menu-button button-more has-dropdown js-dropdown-button" aria-haspopup="true" aria-expanded="false" aria-controls="${_("Usermenu")}">
|
|
<span class="icon-fallback icon-fallback-img">
|
|
<span class="icon icon-angle-down" aria-hidden="true"></span>
|
|
<span class="sr-only">${_("Usermenu dropdown")}</span>
|
|
</span>
|
|
</button>
|
|
<ul class="dropdown-menu list-divided is-hidden" id="${_("Usermenu")}" tabindex="-1">
|
|
<%block name="navigation_dropdown_menu_links" >
|
|
<li class="dropdown-item item has-block-link">
|
|
<a href="/">${_("{studio_name} Home").format(studio_name=settings.STUDIO_SHORT_NAME)}</a>
|
|
</li>
|
|
</%block>
|
|
<li class="dropdown-item item has-block-link">
|
|
<a class="action action-signout" href="${settings.FRONTEND_LOGOUT_URL}">${_("Sign Out")}</a>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
|
|
% else:
|
|
<%!
|
|
set_custom_metric('uses_pattern_library', False)
|
|
%>
|
|
<h3 class="title">
|
|
<span class="label">
|
|
<span class="label-prefix sr-only">${_("Currently signed in as:")}</span>
|
|
<span class="account-username" title="${ user.username }">${ user.username }</span>
|
|
</span>
|
|
<span class="icon fa fa-caret-down ui-toggle-dd" aria-hidden="true"></span>
|
|
</h3>
|
|
<div class="wrapper wrapper-nav-sub">
|
|
<div class="nav-sub">
|
|
<ul>
|
|
<li class="nav-item nav-account-dashboard">
|
|
<a href="/">${_("{studio_name} Home").format(studio_name=settings.STUDIO_SHORT_NAME)}</a>
|
|
</li>
|
|
% if GlobalStaff().has_user(user):
|
|
<li class="nav-item">
|
|
<a href="${reverse('maintenance:maintenance_index')}">${_("Maintenance")}</a>
|
|
</li>
|
|
% endif
|
|
<li class="nav-item nav-account-signout">
|
|
<a class="action action-signout" href="${settings.FRONTEND_LOGOUT_URL}">${_("Sign Out")}</a>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
% endif
|