summaryrefslogtreecommitdiff
path: root/src/meetingtools/apps/room
diff options
context:
space:
mode:
Diffstat (limited to 'src/meetingtools/apps/room')
-rw-r--r--src/meetingtools/apps/room/views.py70
1 files changed, 28 insertions, 42 deletions
diff --git a/src/meetingtools/apps/room/views.py b/src/meetingtools/apps/room/views.py
index 059df69..cf79c92 100644
--- a/src/meetingtools/apps/room/views.py
+++ b/src/meetingtools/apps/room/views.py
@@ -238,62 +238,48 @@ def _import_room(request,acc,r):
modified = False
room = None
+ #if abs(room.lastupdate() - time.time()) < IMPORT_TTL:
+ # return room
+
+ if r.has_key('urlpath'):
+ r['urlpath'] = r['urlpath'].strip('/')
+
try:
room = Room.objects.get(sco_id=r['sco_id'],acc=acc)
+ for key in ('sco_id','name','source_sco_id','urlpath','description','user_count','host_count'):
+ if r.has_key(key) and hasattr(room,key):
+ rv = getattr(room,key)
+ if rv != r[key] and r[key] != None and r[key]:
+ setattr(room,key,r[key])
+ modified = True
+
+ if modified:
+ logging.debug("+++ saving room ... %s" % pformat(room))
+ room.save()
+
except ObjectDoesNotExist:
if r['folder_sco_id']:
try:
- room = Room.objects.create(sco_id=r['sco_id'],acc=acc,creator=request.user,folder_sco_id=r['folder_sco_id'])
+ room = Room.objects.create(sco_id=r['sco_id'],
+ source_sco_id=r['source_sco_id'],
+ acc=acc,
+ name=r['name'],
+ urlpath=r['urlpath'],
+ description=r['description'],
+ creator=request.user,
+ folder_sco_id=r['folder_sco_id'])
except Exception,e:
room = None
pass
- logging.debug("+++ after object create")
- logging.debug(room)
- if not room:
- return None
-
- logging.debug("+++ room timers")
- logging.debug(room.lastupdate())
- logging.debug(room.lastupdate() - time.time())
- if abs(room.lastupdate() - time.time()) < IMPORT_TTL:
- return room
-
logging.debug("+++ looking at user counts")
api = ac_api_client(request,acc)
userlist = api.request('meeting-usermanager-user-list',{'sco-id': room.sco_id},False)
- r['user_count'] = 0
- r['host_count'] = 0
if userlist.status_code() == 'ok':
- r['user_count'] = int(userlist.et.xpath("count(.//userdetails)"))
- r['host_count'] = int(userlist.et.xpath("count(.//userdetails/role[text() = 'host'])"))
- modified = True
-
- logging.debug("+++ room before merge")
- logging.debug(pformat(room))
- logging.debug(pformat(r))
-
- if r.has_key('urlpath'):
- r['urlpath'] = r['urlpath'].strip('/')
-
- for key in ('sco_id','name','source_sco_id','urlpath','description','user_count','host_count'):
- if r.has_key(key) and hasattr(room,key):
- rv = getattr(room,key)
- if rv != r[key] and r[key] != None and r[key]:
- setattr(room,key,r[key])
- modified = True
-
- logging.debug("+++ room after merge")
- logging.debug(pformat(room))
-
- if not room.name:
- room.delete()
- return None
-
- if modified:
- logging.debug("+++ saving room ... %s" % pformat(room))
+ room.user_count = int(userlist.et.xpath("count(.//userdetails)"))
+ room.host_count = int(userlist.et.xpath("count(.//userdetails/role[text() = 'host'])"))
room.save()
-
+
return room
@login_required