diff options
Diffstat (limited to 'ishtar_common/management/commands/dump_towns.py')
-rw-r--r-- | ishtar_common/management/commands/dump_towns.py | 116 |
1 files changed, 116 insertions, 0 deletions
diff --git a/ishtar_common/management/commands/dump_towns.py b/ishtar_common/management/commands/dump_towns.py new file mode 100644 index 000000000..31465aa13 --- /dev/null +++ b/ishtar_common/management/commands/dump_towns.py @@ -0,0 +1,116 @@ +#!/usr/bin/env python +# -*- coding: utf-8 -*- +# Copyright (C) 2025 Étienne Loks <etienne.loks_AT_peacefrogsDOTnet> + +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU Affero General Public License as +# published by the Free Software Foundation, either version 3 of the +# License, or (at your option) any later version. + +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU Affero General Public License for more details. + +# You should have received a copy of the GNU Affero General Public License +# along with this program. If not, see <http://www.gnu.org/licenses/>. + +# See the file COPYING for details. + +import datetime +import json +import sys + +from django.core.management.base import BaseCommand +from django.db import transaction + +from ishtar_common.utils import BColors, get_progress +from ishtar_common.models import Town + + +class Command(BaseCommand): + help = 'Export towns fixtures' + + def add_arguments(self, parser): + parser.add_argument( + '--query', type=str, default="", dest='query', + help='Limit exported towns to query. Query is a valid Django query dict with ' + ' " for quotes. Example: --query=\'{"numero_insee__startswith": "35"}') + parser.add_argument( + '--quiet', dest='quiet', action='store_true', + help='Quiet output') + + @transaction.atomic + def handle(self, *args, **options): + quiet = options['quiet'] + query = options["query"] + q = Town.objects.filter(main_geodata__isnull=False, main_geodata__multi_polygon__isnull=False) + if query: + try: + query = json.loads(query) + except json.JSONDecodeError: + sys.stdout.write(f"\n{BColors.FAIL}Bad query{BColors.ENDC}\n") + return + q = q.filter(**query) + nb_lines = q.count() + started = datetime.datetime.now() + result = [] + for idx, town in enumerate(q.all()): + if not quiet: + sys.stdout.write( + get_progress("processing town", idx, nb_lines, started) + ) + sys.stdout.flush() + geo = town.main_geodata + town_dct = { + "model": "ishtar_common.town", + "fields": { + "name": town.name, + "surface": town.surface, + "numero_insee": town.numero_insee, + "notice": town.notice, + "year": town.year, + "cached_label": town.cached_label, + "main_geodata": [ + "ishtar_common", + "town", + town.numero_insee + ], + "geodata": [ + ["ishtar_common", "town", town.numero_insee] + ], + "children": [ + t.numero_insee + for t in town.children.filter(numero_insee__isnull=False).all() + ] + } + } + geo_dct = { + "model": "ishtar_common.geovectordata", + "fields": { + "name": geo.name, + "source_content_type": [ + "ishtar_common", + "town" + ], + "source": town.numero_insee, + "data_type": [ + "town-limit" + ], + "provider": geo.provider.txt_idx, + "comment": geo.comment, + "cached_x": geo.cached_x, + "cached_y": geo.cached_y, + "spatial_reference_system": None, + "multi_polygon": geo.multi_polygon.wkt + } + } + result.append(geo_dct) + result.append(town_dct) + today = datetime.date.today() + result_file = f"ishtar-towns-{today.strftime('%Y-%m-%d')}.json" + with open(result_file, "w") as r: + r.write(json.dumps(result, indent=4)) + if quiet: + return + sys.stdout.write(f"\n{BColors.WARNING}{result_file}{BColors.ENDC}\n") |