team-3/src/c3nav/mapdata/management/commands/clearmapcache.py

48 lines
2 KiB
Python
Raw Normal View History

2017-11-16 20:54:59 +01:00
import logging
2017-11-10 22:50:06 +01:00
import os
from django.conf import settings
2017-07-05 22:42:50 +02:00
from django.core.management.base import BaseCommand
from django.db import DatabaseError
from django.utils.translation import gettext_lazy as _
2017-07-05 22:42:50 +02:00
from c3nav.mapdata.tasks import process_map_updates
2017-07-05 22:42:50 +02:00
class Command(BaseCommand):
help = 'clear the mapdata cache'
2017-11-10 22:50:06 +01:00
def add_arguments(self, parser):
parser.add_argument('--include-history', action='store_const', const=True, default=False,
help=_('incluce all history as well'))
parser.add_argument('--include-geometries', action='store_const', const=True, default=False,
help=_('incluce all geometries as well'))
parser.add_argument('--no-process', action='store_const', const=True, default=False,
help=_('don\'t run processupdates if celery is not setup'))
2017-11-10 22:50:06 +01:00
2017-07-05 22:42:50 +02:00
def handle(self, *args, **options):
from c3nav.mapdata.models import MapUpdate
2017-11-16 20:54:59 +01:00
logger = logging.getLogger('c3nav')
MapUpdate.objects.create(type='management', geometries_changed=options['include_geometries'])
2017-11-16 20:54:59 +01:00
logger.info('New management update created.')
2017-11-10 22:50:06 +01:00
if options['include_history']:
2017-11-16 20:54:59 +01:00
logger.info('Deleting base history...')
for filename in os.listdir(settings.CACHE_ROOT):
2017-11-20 17:25:21 +01:00
if filename.startswith('history_base_'):
2017-11-16 20:54:59 +01:00
logger.info('Deleting %s...' % filename)
os.remove(settings.CACHE_ROOT / filename)
2017-11-16 20:54:59 +01:00
logger.info('Base history deleted.')
2017-11-10 22:50:06 +01:00
if not settings.HAS_CELERY and not options['no_process']:
print(_('You don\'t have celery installed, so we will run processupdates now...'))
try:
process_map_updates()
except DatabaseError:
logger.error('Didn\'t work, there is already map update processing in progress.')
if not settings.HAS_REAL_CACHE:
print(_('You have no external cache configured, so don\'t forget to restart your c3nav instance!'))