* Generate common/djangoapps import shims for LMS * Generate common/djangoapps import shims for Studio * Stop appending project root to sys.path * Stop appending common/djangoapps to sys.path * Import from common.djangoapps.course_action_state instead of course_action_state * Import from common.djangoapps.course_modes instead of course_modes * Import from common.djangoapps.database_fixups instead of database_fixups * Import from common.djangoapps.edxmako instead of edxmako * Import from common.djangoapps.entitlements instead of entitlements * Import from common.djangoapps.pipline_mako instead of pipeline_mako * Import from common.djangoapps.static_replace instead of static_replace * Import from common.djangoapps.student instead of student * Import from common.djangoapps.terrain instead of terrain * Import from common.djangoapps.third_party_auth instead of third_party_auth * Import from common.djangoapps.track instead of track * Import from common.djangoapps.util instead of util * Import from common.djangoapps.xblock_django instead of xblock_django * Add empty common/djangoapps/__init__.py to fix pytest collection * Fix pylint formatting violations * Exclude import_shims/ directory tree from linting
39 lines
1.3 KiB
Python
39 lines
1.3 KiB
Python
"""
|
|
Certificate tool in the student support app.
|
|
"""
|
|
|
|
|
|
from django.utils.decorators import method_decorator
|
|
from django.views.generic import View
|
|
from six.moves.urllib.parse import quote_plus, unquote
|
|
|
|
from common.djangoapps.edxmako.shortcuts import render_to_response
|
|
from lms.djangoapps.support.decorators import require_support_permission
|
|
|
|
|
|
class CertificatesSupportView(View):
|
|
"""
|
|
View for viewing and regenerating certificates for users.
|
|
|
|
This is used by the support team to re-issue certificates
|
|
to users if something went wrong during the initial certificate generation,
|
|
such as:
|
|
|
|
* The user's name was spelled incorrectly.
|
|
* The user later earned a higher grade and wants it on their certificate and dashboard.
|
|
* The user accidentally received an honor code certificate because their
|
|
verification expired before certs were generated.
|
|
|
|
Most of the heavy lifting is performed client-side through API
|
|
calls directly to the certificates app.
|
|
"""
|
|
|
|
@method_decorator(require_support_permission)
|
|
def get(self, request):
|
|
"""Render the certificates support view. """
|
|
context = {
|
|
"user_filter": unquote(quote_plus(request.GET.get("user", ""))),
|
|
"course_filter": request.GET.get("course_id", "")
|
|
}
|
|
return render_to_response("support/certificates.html", context)
|