]> git.parisson.com Git - teleforma.git/commitdiff
Merge branch 'dev' into tc202
authorGuillaume Pellerin <guillaume.pellerin@ircam.fr>
Fri, 19 Jan 2018 15:26:45 +0000 (16:26 +0100)
committerGuillaume Pellerin <guillaume.pellerin@ircam.fr>
Fri, 19 Jan 2018 15:26:45 +0000 (16:26 +0100)
1  2 
teleforma/locale/fr/LC_MESSAGES/django.po
teleforma/models/core.py
teleforma/models/crfpa.py
teleforma/views/core.py

Simple merge
Simple merge
index 8b54250de330468d8750c84f4dd66c19270a7857,7f91d9d37bce001a05b63a7a0f5fdbe529a3e260..530515173f0a148645052dcc56d13fe856521a28
@@@ -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):