from optparse import make_option from django.core.management.base import BaseCommand from zephyr.models import Realm, UserProfile, Message from zephyr.lib.time import datetime_to_timestamp, timestamp_to_datetime import simplejson def dump(): pointers = [] for u in UserProfile.objects.select_related("user__email").all(): pointer = u.pointer if pointer != -1: pub_date = Message.objects.get(id=pointer).pub_date pointers.append((u.user.email, datetime_to_timestamp(pub_date))) else: pointers.append((u.user.email, -1)) file("dumped-pointers", "w").write(simplejson.dumps(pointers) + "\n") def restore(change): for (email, timestamp) in simplejson.loads(file("dumped-pointers").read()): u = UserProfile.objects.get(user__email__iexact=email) if timestamp == -1: pointer = -1 else: pointer = Message.objects.filter( pub_date__gte=timestamp_to_datetime(timestamp)).order_by("id")[0].id print "%s: pointer %s => %s" % (email, u.pointer, pointer) if change: u.pointer = pointer u.save() class Command(BaseCommand): option_list = BaseCommand.option_list + ( make_option('--restore', default=False, action='store_true'), make_option('--dry-run', '-n', default=False, action='store_true'),) def handle(self, *args, **options): if options["restore"]: restore(change=not options['dry_run']) else: dump()