From: Guillaume Pellerin Date: Fri, 19 Jan 2018 15:26:45 +0000 (+0100) Subject: Merge branch 'dev' into tc202 X-Git-Url: https://git.parisson.com/?a=commitdiff_plain;h=4de030135e4a1438dd1da861e3b76204eb1db942;p=teleforma.git Merge branch 'dev' into tc202 --- 4de030135e4a1438dd1da861e3b76204eb1db942 diff --cc teleforma/views/core.py index 8b54250d,7f91d9d3..53051517 --- a/teleforma/views/core.py +++ b/teleforma/views/core.py @@@ -746,38 -747,30 +746,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 = 'http://' + 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 ClassGroupView(View): + class WebClassGroupView(View): @jsonrpc_method('teleforma.get_class_group_list') def get_class_group_list(request):