Commit 7905e7d2 by Miles Steele

add csv & enrollment & access api tests, disallow instructors from…

add csv & enrollment & access api tests, disallow instructors from un-instructoring themselves, rename mode to action for access
parent fa0f56ec
...@@ -52,12 +52,12 @@ def revoke_access(course, user, level): ...@@ -52,12 +52,12 @@ def revoke_access(course, user, level):
_change_access(course, user, level, 'revoke') _change_access(course, user, level, 'revoke')
def _change_access(course, user, level, mode): def _change_access(course, user, level, action):
""" """
Change access of user. Change access of user.
level is one of ['instructor', 'staff', 'beta'] level is one of ['instructor', 'staff', 'beta']
mode is one of ['allow', 'revoke'] action is one of ['allow', 'revoke']
NOTE: will NOT create a group that does not yet exist. NOTE: will NOT create a group that does not yet exist.
""" """
...@@ -70,29 +70,29 @@ def _change_access(course, user, level, mode): ...@@ -70,29 +70,29 @@ def _change_access(course, user, level, mode):
raise ValueError("unrecognized level '{}'".format(level)) raise ValueError("unrecognized level '{}'".format(level))
group, _ = Group.objects.get_or_create(name=grpname) group, _ = Group.objects.get_or_create(name=grpname)
if mode == 'allow': if action == 'allow':
user.groups.add(group) user.groups.add(group)
elif mode == 'revoke': elif action == 'revoke':
user.groups.remove(group) user.groups.remove(group)
else: else:
raise ValueError("unrecognized mode '{}'".format(mode)) raise ValueError("unrecognized action '{}'".format(action))
def update_forum_role_membership(course_id, user, rolename, mode): def update_forum_role_membership(course_id, user, rolename, action):
""" """
Change forum access of user. Change forum access of user.
`rolename` is one of [FORUM_ROLE_ADMINISTRATOR, FORUM_ROLE_MODERATOR, FORUM_ROLE_COMMUNITY_TA] `rolename` is one of [FORUM_ROLE_ADMINISTRATOR, FORUM_ROLE_MODERATOR, FORUM_ROLE_COMMUNITY_TA]
`mode` is one of ['allow', 'revoke'] `action` is one of ['allow', 'revoke']
if `mode` is bad, raises ValueError if `action` is bad, raises ValueError
if `rolename` does not exist, raises Role.DoesNotExist if `rolename` does not exist, raises Role.DoesNotExist
""" """
role = Role.objects.get(course_id=course_id, name=rolename) role = Role.objects.get(course_id=course_id, name=rolename)
if mode == 'allow': if action == 'allow':
role.users.add(user) role.users.add(user)
elif mode == 'revoke': elif action == 'revoke':
role.users.remove(user) role.users.remove(user)
else: else:
raise ValueError("unrecognized mode '{}'".format(mode)) raise ValueError("unrecognized action '{}'".format(action))
...@@ -134,7 +134,7 @@ def students_update_enrollment(request, course_id): ...@@ -134,7 +134,7 @@ def students_update_enrollment(request, course_id):
Returns an analog to this JSON structure: { Returns an analog to this JSON structure: {
"action": "enroll", "action": "enroll",
"auto_enroll": false "auto_enroll": false,
"results": [ "results": [
{ {
"email": "testemail@test.org", "email": "testemail@test.org",
...@@ -202,17 +202,19 @@ def students_update_enrollment(request, course_id): ...@@ -202,17 +202,19 @@ def students_update_enrollment(request, course_id):
@require_query_params( @require_query_params(
email="user email", email="user email",
rolename="'instructor', 'staff', or 'beta'", rolename="'instructor', 'staff', or 'beta'",
mode="'allow' or 'revoke'" action="'allow' or 'revoke'"
) )
def modify_access(request, course_id): def modify_access(request, course_id):
""" """
Modify staff/instructor access. Modify staff/instructor access of other user.
Requires instructor access. Requires instructor access.
NOTE: instructors cannot remove their own instructor access.
Query parameters: Query parameters:
email is the target users email email is the target users email
rolename is one of ['instructor', 'staff', 'beta'] rolename is one of ['instructor', 'staff', 'beta']
mode is one of ['allow', 'revoke'] action is one of ['allow', 'revoke']
""" """
course = get_course_with_access( course = get_course_with_access(
request.user, course_id, 'instructor', depth=None request.user, course_id, 'instructor', depth=None
...@@ -220,7 +222,7 @@ def modify_access(request, course_id): ...@@ -220,7 +222,7 @@ def modify_access(request, course_id):
email = request.GET.get('email') email = request.GET.get('email')
rolename = request.GET.get('rolename') rolename = request.GET.get('rolename')
mode = request.GET.get('mode') action = request.GET.get('action')
if not rolename in ['instructor', 'staff', 'beta']: if not rolename in ['instructor', 'staff', 'beta']:
return HttpResponseBadRequest( return HttpResponseBadRequest(
...@@ -229,17 +231,23 @@ def modify_access(request, course_id): ...@@ -229,17 +231,23 @@ def modify_access(request, course_id):
user = User.objects.get(email=email) user = User.objects.get(email=email)
if mode == 'allow': # disallow instructors from removing their own instructor access.
if rolename == 'instructor' and user == request.user and action != 'allow':
return HttpResponseBadRequest(
"An instructor cannot remove their own instructor access."
)
if action == 'allow':
access.allow_access(course, user, rolename) access.allow_access(course, user, rolename)
elif mode == 'revoke': elif action == 'revoke':
access.revoke_access(course, user, rolename) access.revoke_access(course, user, rolename)
else: else:
raise ValueError("unrecognized mode '{}'".format(mode)) return HttpResponseBadRequest("unrecognized action '{}'".format(action))
response_payload = { response_payload = {
'email': email, 'email': email,
'rolename': rolename, 'rolename': rolename,
'mode': mode, 'action': action,
'success': 'yes', 'success': 'yes',
} }
response = HttpResponse( response = HttpResponse(
...@@ -258,6 +266,18 @@ def list_course_role_members(request, course_id): ...@@ -258,6 +266,18 @@ def list_course_role_members(request, course_id):
Requires instructor access. Requires instructor access.
rolename is one of ['instructor', 'staff', 'beta'] rolename is one of ['instructor', 'staff', 'beta']
Returns JSON of the form {
"course_id": "some/course/id",
"staff": [
{
"username": "staff1",
"email": "staff1@example.org",
"first_name": "Joe",
"last_name": "Shmoe",
}
]
}
""" """
course = get_course_with_access( course = get_course_with_access(
request.user, course_id, 'instructor', depth=None request.user, course_id, 'instructor', depth=None
...@@ -627,7 +647,7 @@ def list_forum_members(request, course_id): ...@@ -627,7 +647,7 @@ def list_forum_members(request, course_id):
@require_query_params( @require_query_params(
email="the target users email", email="the target users email",
rolename="the forum role", rolename="the forum role",
mode="'allow' or 'revoke'", action="'allow' or 'revoke'",
) )
@common_exceptions_400 @common_exceptions_400
def update_forum_role_membership(request, course_id): def update_forum_role_membership(request, course_id):
...@@ -637,24 +657,24 @@ def update_forum_role_membership(request, course_id): ...@@ -637,24 +657,24 @@ def update_forum_role_membership(request, course_id):
Query parameters: Query parameters:
email is the target users email email is the target users email
rolename is one of [FORUM_ROLE_ADMINISTRATOR, FORUM_ROLE_MODERATOR, FORUM_ROLE_COMMUNITY_TA] rolename is one of [FORUM_ROLE_ADMINISTRATOR, FORUM_ROLE_MODERATOR, FORUM_ROLE_COMMUNITY_TA]
mode is one of ['allow', 'revoke'] action is one of ['allow', 'revoke']
""" """
email = request.GET.get('email') email = request.GET.get('email')
rolename = request.GET.get('rolename') rolename = request.GET.get('rolename')
mode = request.GET.get('mode') action = request.GET.get('action')
if not rolename in [FORUM_ROLE_ADMINISTRATOR, FORUM_ROLE_MODERATOR, FORUM_ROLE_COMMUNITY_TA]: if not rolename in [FORUM_ROLE_ADMINISTRATOR, FORUM_ROLE_MODERATOR, FORUM_ROLE_COMMUNITY_TA]:
return HttpResponseBadRequest() return HttpResponseBadRequest()
try: try:
user = User.objects.get(email=email) user = User.objects.get(email=email)
access.update_forum_role_membership(course_id, user, rolename, mode) access.update_forum_role_membership(course_id, user, rolename, action)
except Role.DoesNotExist: except Role.DoesNotExist:
return HttpResponseBadRequest("Role does not exist.") return HttpResponseBadRequest("Role does not exist.")
response_payload = { response_payload = {
'course_id': course_id, 'course_id': course_id,
'mode': mode, 'action': action,
} }
response = HttpResponse( response = HttpResponse(
json.dumps(response_payload), content_type="application/json" json.dumps(response_payload), content_type="application/json"
......
...@@ -251,15 +251,15 @@ class AuthList ...@@ -251,15 +251,15 @@ class AuthList
# update the access of a user. # update the access of a user.
# (add or remove them from the list) # (add or remove them from the list)
# mode should be one of ['allow', 'revoke'] # action should be one of ['allow', 'revoke']
access_change: (email, mode, cb) -> access_change: (email, action, cb) ->
$.ajax $.ajax
dataType: 'json' dataType: 'json'
url: @$add_section.data 'endpoint' url: @$add_section.data 'endpoint'
data: data:
email: email email: email
rolename: @rolename rolename: @rolename
mode: mode action: action
success: (data) -> cb?(data) success: (data) -> cb?(data)
error: std_ajax_err => @$request_response_error.text "Error changing user's permissions." error: std_ajax_err => @$request_response_error.text "Error changing user's permissions."
......
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