diff options
Diffstat (limited to 'src/meetingtools/apps/room')
-rw-r--r-- | src/meetingtools/apps/room/models.py | 8 | ||||
-rw-r--r-- | src/meetingtools/apps/room/views.py | 70 |
2 files changed, 47 insertions, 31 deletions
diff --git a/src/meetingtools/apps/room/models.py b/src/meetingtools/apps/room/models.py index 90e5868..8167839 100644 --- a/src/meetingtools/apps/room/models.py +++ b/src/meetingtools/apps/room/models.py @@ -21,10 +21,16 @@ class Room(models.Model): self_cleaning = BooleanField(verbose_name="Clean-up when empty?") sco_id = IntegerField(verbose_name="Adobe Connect Room",blank=False) source_sco_id = IntegerField(verbose_name="Template",blank=True,null=True) + folder_sco_id = IntegerField(verbose_name="Adobe Connect Room Folder",editable=False) timecreated = models.DateTimeField(auto_now_add=True) lastupdated = models.DateTimeField(auto_now=True) lastvisited = models.DateTimeField(blank=True,null=True) def __unicode__(self): return "%s (sco_id=%d,source_sco_id=%d)" % (self.name,self.sco_id,self.source_sco_id) -
\ No newline at end of file + + def lastvisit(self): + if not self.lastvisited: + return 0 + else: + return self.lastvisited
\ No newline at end of file diff --git a/src/meetingtools/apps/room/views.py b/src/meetingtools/apps/room/views.py index b610bb8..6ef3aa1 100644 --- a/src/meetingtools/apps/room/views.py +++ b/src/meetingtools/apps/room/views.py @@ -113,13 +113,32 @@ def view(request,id): 'nusers': _nusers(session_info) }) -def _init_update_form(request,form,acc,my_meetings_sco_id): +def _init_update_form(request,form,acc,my_meetings_sco_id): form.fields['participants'].widget.choices = [('','-- anyone --')]+[(g,g) for g in groups(request)] form.fields['presenters'].widget.choices = [('','-- nobody --')]+[(g,g) for g in groups(request)] form.fields['hosts'].widget.choices = [('','-- nobody --')]+[(g,g) for g in groups(request)] form.fields['source_sco_id'].widget.choices = [('','-- select template --')]+[r for r in _user_templates(request,acc,my_meetings_sco_id)] -@login_required +@login_required +def _update_room(request, room): + api = ac_api_client(request, room.acc) + params = {'type':'meeting', + 'name':room.name, + 'folder-id': room.folder_sco_id, + 'source-sco-id': room.source_sco_id, + 'url-path':room.urlpath} + + if room.sco_id: + params['sco-id'] = room.sco_id + r = api.request('sco-update', params, raise_error=True) + + room.sco_id = r.et.find(".//sco").get('sco-id') + room.source_sco_id = r.et.find(".//sco").get('sco-source-id') + room.save() + #room = _import_room(params['sco-id'], params['name'], params['source-sco-id'], params['url-path'], request.user, acc) + return room + +@login_required def update(request,id=None): if id: room = get_object_or_404(Room,pk=id) @@ -129,48 +148,36 @@ def update(request,id=None): update = True else: acc = _acc_for_user(request.user) - room = Room(creator=request.user,acc=acc) + my_meetings_sco_id = _user_meeting_folder(request,acc) + room = Room(creator=request.user,acc=acc,folder_sco_id=my_meetings_sco_id) what = "Create" title = "Create a new room" update = False - my_meetings_sco_id = _user_meeting_folder(request,acc) - if request.method == 'POST': form = UpdateRoomForm(request.POST,instance=room) - _init_update_form(request, form, acc, my_meetings_sco_id) + _init_update_form(request, form, acc, room.folder_sco_id) if form.is_valid(): - api = ac_api_client(request,acc) - params = {'type':'meeting','name':room.name,'folder-id':my_meetings_sco_id,'sco-id':room.sco_id,'source-sco-id':room.source_sco_id,'url-path':room.urlpath} - if form.cleaned_data.has_key('source_sco_id'): - params['source-sco-id'] = form.cleaned_data['source_sco_id'] - - if form.cleaned_data.has_key('urlpath'): - params['url-path'] = form.cleaned_data['urlpath'] - - r = api.request('sco-update',params,raise_error=True) - params['sco-id'] = r.et.find(".//sco").get('sco-id') - params['sco-source-id'] = r.et.find(".//sco").get('sco-source-id') room = form.save() - room = _import_room(params['sco-id'],params['name'],params['source-sco-id'],params['url-path'],request.user,acc) + room = _update_room(request, room) return redirect_to("/rooms#%d" % room.id) else: form = UpdateRoomForm(instance=room) - _init_update_form(request, form, acc, my_meetings_sco_id) + _init_update_form(request, form, acc, room.folder_sco_id) if update: form.fields['urlpath'].widget.attrs['readonly'] = True return respond_to(request,{'text/html':'edit.html'},{'form':form,'formtitle': title,'submitname':'%s Room' % what}) -def _import_room(sco_id,name,source_sco_id,urlpath,user,acc): +def _import_room(request,acc,sco_id,source_sco_id,folder_sco_id,name,urlpath): modified = False - room,created = Room.objects.get_or_create(sco_id=sco_id,acc=acc,creator=user) + room,created = Room.objects.get_or_create(sco_id=sco_id,acc=acc,creator=request.user,folder_sco_id=folder_sco_id) if room.name != name: room.name = name modified = True - if not room.sco_id and sco_id: + if room.sco_id != sco_id: room.sco_id = sco_id modified = True @@ -199,7 +206,7 @@ def list(request): ar = [] for (sco_id,name,source_sco_id,urlpath) in user_rooms: - room = _import_room(sco_id,name,source_sco_id,urlpath,request.user,acc) + room = _import_room(request,acc,sco_id,source_sco_id,my_meetings_sco_id,name,urlpath) ar.append(int(sco_id)) #logging.debug(pformat(ar)) @@ -225,8 +232,11 @@ def delete(request,id): return respond_to(request,{'text/html':'edit.html'},{'form':form,'formtitle': 'Delete %s' % room.name,'submitname':'Delete Room'}) -def _clean(room): - pass +def _clean(request,room): + api = ac_api_client(request, room.acc) + api.request('sco-delete',{'sco-id':room.sco_id},raise_error=True) + room.sco_id = None + return _update_room(request, room) def go_by_id(request,id): room = get_object_or_404(Room,pk=id) @@ -237,18 +247,18 @@ def go_by_path(request,path): return goto(request,room) def goto(request,room): - client = ac_api_client(request, room.acc) - session_info = client.request('report-meeting-sessions',{'sco-id':room.sco_id}) + api = ac_api_client(request, room.acc) + session_info = api.request('report-meeting-sessions',{'sco-id':room.sco_id}) now = time.time() if room.self_cleaning: - if (_nusers(session_info) == 0) and (abs(room.lastvisited - now) > GRACE): - _clean(room) + if (_nusers(session_info) == 0) and (abs(room.lastvisit() - now) > GRACE): + room = _clean(request,room) room.lastvisited = datetime.now() room.save() - r = client.request('sco-info',{'sco-id':room.sco_id}) + r = api.request('sco-info',{'sco-id':room.sco_id}) urlpath = r.et.findtext('.//sco/url-path') return HttpResponseRedirect(room.acc.url+urlpath) #in this case we want the absolute URL
\ No newline at end of file |