Commit 8807d9fe by David Baumgold

Integrate JsonResponse into lms/djangoapps/instructor/views/api.py

parent aa0cda96
...@@ -7,12 +7,13 @@ Many of these GETs may become PUTs in the future. ...@@ -7,12 +7,13 @@ Many of these GETs may become PUTs in the future.
""" """
import re import re
import json
import logging import logging
from django_future.csrf import ensure_csrf_cookie from django_future.csrf import ensure_csrf_cookie
from django.views.decorators.cache import cache_control from django.views.decorators.cache import cache_control
from django.core.urlresolvers import reverse from django.core.urlresolvers import reverse
from django.http import HttpResponse, HttpResponseBadRequest, HttpResponseForbidden from django.utils.translation import ugettext as _
from django.http import HttpResponseBadRequest, HttpResponseForbidden
from util.json_request import JsonResponse
from courseware.access import has_access from courseware.access import has_access
from courseware.courses import get_course_with_access, get_course_by_id from courseware.courses import get_course_with_access, get_course_by_id
...@@ -41,13 +42,23 @@ def common_exceptions_400(func): ...@@ -41,13 +42,23 @@ def common_exceptions_400(func):
Catches common exceptions and renders matching 400 errors. Catches common exceptions and renders matching 400 errors.
(decorator without arguments) (decorator without arguments)
""" """
def wrapped(*args, **kwargs): # pylint: disable=C0111 def wrapped(request, *args, **kwargs): # pylint: disable=C0111
use_json = (request.is_ajax() or
request.META.get("HTTP_ACCEPT", "").startswith("application/json"))
try: try:
return func(*args, **kwargs) return func(request, *args, **kwargs)
except User.DoesNotExist: except User.DoesNotExist:
return HttpResponseBadRequest("User does not exist.") message = "User does not exist."
if use_json:
return JsonResponse({"error": _(message)}, 400)
else:
return HttpResponseBadRequest(_(message))
except AlreadyRunningError: except AlreadyRunningError:
return HttpResponseBadRequest("Task already running.") message = "Task is already running."
if use_json:
return JsonResponse({"error": _(message)}, 400)
else:
return HttpResponseBadRequest(_(message))
return wrapped return wrapped
...@@ -82,10 +93,7 @@ def require_query_params(*args, **kwargs): ...@@ -82,10 +93,7 @@ def require_query_params(*args, **kwargs):
error_response_data['info'][param] = extra error_response_data['info'][param] = extra
if len(error_response_data['parameters']) > 0: if len(error_response_data['parameters']) > 0:
return HttpResponseBadRequest( return JsonResponse(error_response_data, status=400)
json.dumps(error_response_data),
mimetype="application/json",
)
else: else:
return func(*args, **kwargs) return func(*args, **kwargs)
return wrapped return wrapped
...@@ -194,10 +202,7 @@ def students_update_enrollment(request, course_id): ...@@ -194,10 +202,7 @@ def students_update_enrollment(request, course_id):
'results': results, 'results': results,
'auto_enroll': auto_enroll, 'auto_enroll': auto_enroll,
} }
response = HttpResponse( return JsonResponse(response_payload)
json.dumps(response_payload), content_type="application/json"
)
return response
@ensure_csrf_cookie @ensure_csrf_cookie
...@@ -255,10 +260,7 @@ def modify_access(request, course_id): ...@@ -255,10 +260,7 @@ def modify_access(request, course_id):
'action': action, 'action': action,
'success': 'yes', 'success': 'yes',
} }
response = HttpResponse( return JsonResponse(response_payload)
json.dumps(response_payload), content_type="application/json"
)
return response
@ensure_csrf_cookie @ensure_csrf_cookie
...@@ -308,10 +310,7 @@ def list_course_role_members(request, course_id): ...@@ -308,10 +310,7 @@ def list_course_role_members(request, course_id):
course, rolename course, rolename
)), )),
} }
response = HttpResponse( return JsonResponse(response_payload)
json.dumps(response_payload), content_type="application/json"
)
return response
@ensure_csrf_cookie @ensure_csrf_cookie
...@@ -330,10 +329,7 @@ def get_grading_config(request, course_id): ...@@ -330,10 +329,7 @@ def get_grading_config(request, course_id):
'course_id': course_id, 'course_id': course_id,
'grading_config_summary': grading_config_summary, 'grading_config_summary': grading_config_summary,
} }
response = HttpResponse( return JsonResponse(response_payload)
json.dumps(response_payload), content_type="application/json"
)
return response
@ensure_csrf_cookie @ensure_csrf_cookie
...@@ -362,10 +358,7 @@ def get_students_features(request, course_id, csv=False): # pylint: disable=W06 ...@@ -362,10 +358,7 @@ def get_students_features(request, course_id, csv=False): # pylint: disable=W06
'queried_features': query_features, 'queried_features': query_features,
'available_features': available_features, 'available_features': available_features,
} }
response = HttpResponse( return JsonResponse(response_payload)
json.dumps(response_payload), content_type="application/json"
)
return response
else: else:
header, datarows = analytics.csvs.format_dictlist(student_data, query_features) header, datarows = analytics.csvs.format_dictlist(student_data, query_features)
return analytics.csvs.create_csv_response("enrolled_profiles.csv", header, datarows) return analytics.csvs.create_csv_response("enrolled_profiles.csv", header, datarows)
...@@ -417,10 +410,7 @@ def get_distribution(request, course_id): ...@@ -417,10 +410,7 @@ def get_distribution(request, course_id):
if p_dist.type == 'EASY_CHOICE': if p_dist.type == 'EASY_CHOICE':
response_payload['feature_results']['choices_display_names'] = p_dist.choices_display_names response_payload['feature_results']['choices_display_names'] = p_dist.choices_display_names
response = HttpResponse( return JsonResponse(response_payload)
json.dumps(response_payload), content_type="application/json"
)
return response
@ensure_csrf_cookie @ensure_csrf_cookie
...@@ -449,10 +439,7 @@ def get_student_progress_url(request, course_id): ...@@ -449,10 +439,7 @@ def get_student_progress_url(request, course_id):
'course_id': course_id, 'course_id': course_id,
'progress_url': progress_url, 'progress_url': progress_url,
} }
response = HttpResponse( return JsonResponse(response_payload)
json.dumps(response_payload), content_type="application/json"
)
return response
@ensure_csrf_cookie @ensure_csrf_cookie
...@@ -521,10 +508,7 @@ def reset_student_attempts(request, course_id): ...@@ -521,10 +508,7 @@ def reset_student_attempts(request, course_id):
else: else:
return HttpResponseBadRequest() return HttpResponseBadRequest()
response = HttpResponse( return JsonResponse(response_payload)
json.dumps(response_payload), content_type="application/json"
)
return response
@ensure_csrf_cookie @ensure_csrf_cookie
...@@ -572,10 +556,7 @@ def rescore_problem(request, course_id): ...@@ -572,10 +556,7 @@ def rescore_problem(request, course_id):
else: else:
return HttpResponseBadRequest() return HttpResponseBadRequest()
response = HttpResponse( return JsonResponse(response_payload)
json.dumps(response_payload), content_type="application/json"
)
return response
@ensure_csrf_cookie @ensure_csrf_cookie
...@@ -618,10 +599,7 @@ def list_instructor_tasks(request, course_id): ...@@ -618,10 +599,7 @@ def list_instructor_tasks(request, course_id):
response_payload = { response_payload = {
'tasks': map(extract_task_features, tasks), 'tasks': map(extract_task_features, tasks),
} }
response = HttpResponse( return JsonResponse(response_payload)
json.dumps(response_payload), content_type="application/json"
)
return response
@ensure_csrf_cookie @ensure_csrf_cookie
...@@ -680,10 +658,7 @@ def list_forum_members(request, course_id): ...@@ -680,10 +658,7 @@ def list_forum_members(request, course_id):
'course_id': course_id, 'course_id': course_id,
rolename: map(extract_user_info, users), rolename: map(extract_user_info, users),
} }
response = HttpResponse( return JsonResponse(response_payload)
json.dumps(response_payload), content_type="application/json"
)
return response
@ensure_csrf_cookie @ensure_csrf_cookie
...@@ -747,10 +722,7 @@ def update_forum_role_membership(request, course_id): ...@@ -747,10 +722,7 @@ def update_forum_role_membership(request, course_id):
'course_id': course_id, 'course_id': course_id,
'action': action, 'action': action,
} }
response = HttpResponse( return JsonResponse(response_payload)
json.dumps(response_payload), content_type="application/json"
)
return response
def _split_input_list(str_list): def _split_input_list(str_list):
...@@ -782,6 +754,6 @@ def _msk_from_problem_urlname(course_id, urlname): ...@@ -782,6 +754,6 @@ def _msk_from_problem_urlname(course_id, urlname):
urlname = "problem/" + urlname urlname = "problem/" + urlname
(org, course_name, _) = course_id.split("/") (org, course_name, __) = course_id.split("/")
module_state_key = "i4x://" + org + "/" + course_name + "/" + urlname module_state_key = "i4x://" + org + "/" + course_name + "/" + urlname
return module_state_key return module_state_key
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment