CAT-SOOP is a flexible, programmable learning management system based on the Python programming language. https://catsoop.mit.edu
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

61 lines
1.8 KiB

  1. # This file is part of CAT-SOOP
  2. # Copyright (c) 2011-2017 Adam Hartz <hartz@mit.edu>
  3. #
  4. # This program is free software: you can redistribute it and/or modify it under
  5. # the terms of the GNU Affero General Public License as published by the Free
  6. # Software Foundation, either version 3 of the License, or (at your option) any
  7. # later version.
  8. #
  9. # This program is distributed in the hope that it will be useful, but WITHOUT
  10. # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
  11. # FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
  12. # details.
  13. #
  14. # You should have received a copy of the GNU Affero General Public License
  15. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  16. import json
  17. api_token = cs_form.get('api_token', None)
  18. path = cs_form.get('path', None)
  19. section = cs_form.get('section', None)
  20. groups = cs_form.get('groups', None)
  21. error = None
  22. if api_token is None:
  23. error = "api_token is required"
  24. elif groups is None:
  25. error = "groups (JSON) is required"
  26. try:
  27. path = opath = json.loads(path)
  28. course, path = path[0], path[1:]
  29. except:
  30. error = "invalid path: %s" % path
  31. if error is None:
  32. output = csm_api.get_user_information(globals(), api_token=api_token, course=course)
  33. if output['ok']:
  34. uinfo = output['user_info']
  35. if 'groups' not in uinfo['permissions'] and 'admin' not in uinfo['permissions']:
  36. error = 'Permission Denied'
  37. try:
  38. groups = json.loads(groups)
  39. except:
  40. error = "error loading groups JSON" + str(groups)
  41. if error is None:
  42. ctx = csm_loader.spoof_early_load(opath)
  43. error = csm_groups.overwrite_groups(ctx, course, path, section, groups)
  44. if error is not None:
  45. output = {'ok': False, 'error': error}
  46. else:
  47. output = {'ok': True}
  48. cs_handler = 'raw_response'
  49. content_type = 'application/json'
  50. response = json.dumps(output)