From bbc6c135b2f17ffd5ce82442cc0df8c4f0df6b89 Mon Sep 17 00:00:00 2001 From: Mattia Giupponi Date: Mon, 15 Mar 2021 15:17:16 +0100 Subject: [PATCH] Task: #39: bugfix PA facet, adding custom resource_count --- rndt/templates/search/_pa_filter.html | 18 +++----------- rndt/views.py | 35 ++++++++++++++++++++++++--- 2 files changed, 36 insertions(+), 17 deletions(-) diff --git a/rndt/templates/search/_pa_filter.html b/rndt/templates/search/_pa_filter.html index e471f73..68840e5 100644 --- a/rndt/templates/search/_pa_filter.html +++ b/rndt/templates/search/_pa_filter.html @@ -2,22 +2,12 @@ \ No newline at end of file diff --git a/rndt/views.py b/rndt/views.py index 1760785..b1e9ded 100644 --- a/rndt/views.py +++ b/rndt/views.py @@ -1,16 +1,43 @@ +import json +import time + +from django.core.serializers.json import DjangoJSONEncoder +from geonode.api.api import TypeFilteredResource +from geonode.api.authorization import ApiLockdownAuthorization +from geonode.layers.models import Layer from tastypie.constants import ALL -from tastypie.resources import ModelResource +from tastypie.serializers import Serializer from rndt.models import PubblicaAmministrazione -class PubblicaAmministrazioneResource(ModelResource): +class PACountJSONSerializer(Serializer): + + def get_resources_counts(self, options): + counts = dict() + for pa in PubblicaAmministrazione.objects.all(): + layer_with_ipa = Layer.objects.filter(uuid__startswith=pa.ipa).count() + counts[pa.id] = layer_with_ipa + return counts + + def to_json(self, data, options=None): + options = options or {} + data = self.to_simple(data, options) + counts = self.get_resources_counts(options) + if 'objects' in data: + for item in data['objects']: + item['count'] = counts.get(item['id'], 0) + # Add in the current time. + data['requested_time'] = time.time() + + return json.dumps(data, cls=DjangoJSONEncoder, sort_keys=True) +class PubblicaAmministrazioneResource(TypeFilteredResource): """PA api""" def serialize(self, request, data, format, options=None): if options is None: options = {} - options['count_type'] = 'pubblica_amministrazione' + options['count_type'] = 'id' return super(PubblicaAmministrazioneResource, self).serialize(request, data, format, options) @@ -22,3 +49,5 @@ class Meta: 'ipa': ALL, 'name': ALL } + serializer = PACountJSONSerializer() + authorization = ApiLockdownAuthorization()