summaryrefslogtreecommitdiff
path: root/meetingtools/apps/room
diff options
context:
space:
mode:
authorJohan Lundberg <lundberg@nordu.net>2014-04-14 13:35:21 +0200
committerJohan Lundberg <lundberg@nordu.net>2014-04-14 13:35:21 +0200
commit4ae116f4091623f89df8a382694c301ffb712432 (patch)
tree33ee658c6f3b5261b29c41757e24e401a18cd66b /meetingtools/apps/room
parente25b7d32251e5c255b1d7c133158b287c505e35a (diff)
Spread the full import to fewer months at a time.
Diffstat (limited to 'meetingtools/apps/room')
-rw-r--r--meetingtools/apps/room/tasks.py35
1 files changed, 18 insertions, 17 deletions
diff --git a/meetingtools/apps/room/tasks.py b/meetingtools/apps/room/tasks.py
index 4fc0c74..518669b 100644
--- a/meetingtools/apps/room/tasks.py
+++ b/meetingtools/apps/room/tasks.py
@@ -314,25 +314,26 @@ def clean_old_rooms():
send_message.apply_async([room.creator,"You have an unused meetingroom at %s" % acc.name ,"Do you still need %s (%s)?" % (room.name,room.permalink())])
-
#@periodic_task(run_every=crontab(hour="3", minute="0", day_of_week="*"))
def timed_full_import():
years = [2009, 2010, 2011, 2012, 2013, 2014]
+ months = [(1, 3), (4, 7), (8, 10), (9, 12)]
for acc in ACCluster.objects.all():
for year in years:
- begin = datetime(year=year, month=1, day=1)
- end = datetime(year=year, month=12, day=31)
- with ac_api_client(acc) as api:
- r = api.request('report-bulk-objects', {'filter-type': 'meeting',
- 'filter-gte-date-modified': begin.isoformat(),
- 'filter-lte-date-modified': end.isoformat()})
- nr = 0
- ne = 0
- for row in r.et.xpath("//row"):
- try:
- _import_one_room(acc, api, row)
- nr += 1
- except Exception, ex:
- logging.error(ex)
- ne += 1
- logging.info("%s: Imported %d rooms and got %d errors" % (acc, nr, ne)) \ No newline at end of file
+ for month in months:
+ begin = datetime(year=year, month=month[0], day=1)
+ end = datetime(year=year, month=month[1], day=31)
+ with ac_api_client(acc) as api:
+ r = api.request('report-bulk-objects', {'filter-type': 'meeting',
+ 'filter-gte-date-modified': begin.isoformat(),
+ 'filter-lte-date-modified': end.isoformat()})
+ nr = 0
+ ne = 0
+ for row in r.et.xpath("//row"):
+ try:
+ _import_one_room(acc, api, row)
+ nr += 1
+ except Exception, ex:
+ logging.error(ex)
+ ne += 1
+ logging.info("%s: Imported %d rooms and got %d errors" % (acc, nr, ne)) \ No newline at end of file