From: Guillaume Pellerin Date: Mon, 21 Jan 2019 17:52:02 +0000 (+0100) Subject: Merge branch 'feature/webclass' into tc202-dev X-Git-Url: https://git.parisson.com/?a=commitdiff_plain;h=45105bff0f2f0fb509c979bd9187791179899c5d;p=teleforma.git Merge branch 'feature/webclass' into tc202-dev --- 45105bff0f2f0fb509c979bd9187791179899c5d diff --cc teleforma/views/core.py index d8a53bff,8acbf2ad..9f771107 --- a/teleforma/views/core.py +++ b/teleforma/views/core.py @@@ -791,38 -793,30 +792,38 @@@ class ProfessorListView(View) return [p.to_json_dict() for p in professors] def pull(request, host=None): - if host: - url = 'http://' + host + '/json/' - else: - url = 'http://' + settings.TELECASTER_MASTER_SERVER + '/json/' - s = ServiceProxy(url) - - remote_list = s.teleforma.get_professor_list() - for professor_dict in remote_list['result']: - user, c = User.objects.get_or_create(username=professor_dict['username']) - user.first_name = professor_dict['first_name'] - user.last_name = professor_dict['last_name'] - user.email = professor_dict['email'] - user.save() + from teleforma.models import Organization, Department + departments = Department.objects.all() + professors_old = Professor.objects.all() + professors_new = [] - professor, c = Professor.objects.get_or_create(user=user) - for course_code in professor_dict['courses']: - course = Course.objects.filter(code=course_code) - if course: - if not course[0] in professor.courses.all(): - professor.courses.add(course[0]) - professor.save() + for department in departments: + url = 'https://' + department.domain + '/json/' + s = ServiceProxy(url) + remote_list = s.teleforma.get_professor_list() + for professor_dict in remote_list['result']: + user, c = User.objects.get_or_create(username=professor_dict['username']) + user.first_name = professor_dict['first_name'] + user.last_name = professor_dict['last_name'] + user.email = professor_dict['email'] + user.save() + + professor, c = Professor.objects.get_or_create(user=user) + for course_code in professor_dict['courses']: + course = Course.objects.filter(code=course_code) + if course: + if not course[0] in professor.courses.all(): + professor.courses.add(course[0]) + professor.save() + professors_new.append(professor) + #print professor + + for professor in professors_old: + if not professor in professors_new: + professor.delete() - class WebClassGroupView(View): + class ClassGroupView(View): @jsonrpc_method('teleforma.get_class_group_list') def get_class_group_list(request):