* 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
59 lines
1.9 KiB
Python
59 lines
1.9 KiB
Python
"""Views for debugging and diagnostics"""
|
|
|
|
|
|
import pprint
|
|
import traceback
|
|
|
|
from django.contrib.auth.decorators import login_required
|
|
from django.http import Http404, HttpResponse
|
|
from django.utils.html import escape
|
|
from django.views.decorators.csrf import ensure_csrf_cookie
|
|
|
|
from codejail.safe_exec import safe_exec
|
|
from common.djangoapps.edxmako.shortcuts import render_to_response
|
|
from openedx.core.djangolib.markup import HTML
|
|
|
|
|
|
@login_required
|
|
@ensure_csrf_cookie
|
|
def run_python(request):
|
|
"""
|
|
A page to allow testing the Python sandbox on a production server.
|
|
|
|
Runs in the override context "debug_run_python", so resource limits with come first from:
|
|
CODE_JAIL['limit_overrides']['debug_run_python']
|
|
and then from:
|
|
CODE_JAIL['limits']
|
|
"""
|
|
if not request.user.is_staff:
|
|
raise Http404
|
|
c = {}
|
|
c['code'] = ''
|
|
c['results'] = None
|
|
if request.method == 'POST':
|
|
py_code = c['code'] = request.POST.get('code')
|
|
g = {}
|
|
try:
|
|
safe_exec(
|
|
code=py_code,
|
|
globals_dict=g,
|
|
slug="debug_run_python",
|
|
limit_overrides_context="debug_run_python",
|
|
)
|
|
except Exception: # pylint: disable=broad-except
|
|
c['results'] = traceback.format_exc()
|
|
else:
|
|
c['results'] = pprint.pformat(g)
|
|
return render_to_response("debug/run_python_form.html", c)
|
|
|
|
|
|
@login_required
|
|
def show_parameters(request):
|
|
"""A page that shows what parameters were on the URL and post."""
|
|
html_list = []
|
|
for name, value in sorted(request.GET.items()):
|
|
html_list.append(escape(u"GET {}: {!r}".format(name, value)))
|
|
for name, value in sorted(request.POST.items()):
|
|
html_list.append(escape(u"POST {}: {!r}".format(name, value)))
|
|
return HttpResponse("\n".join(HTML("<p>{}</p>").format(h) for h in html_list))
|