summaryrefslogtreecommitdiff
path: root/archaeological_operations/serializers.py
diff options
context:
space:
mode:
authorÉtienne Loks <etienne.loks@iggdrasil.net>2019-09-05 17:14:06 +0200
committerÉtienne Loks <etienne.loks@iggdrasil.net>2019-09-05 17:14:06 +0200
commitd99e961414c0c15812bbc583253008550079ccc8 (patch)
tree00d9853a5541ae76f0ceb406bdebad8ae497bc99 /archaeological_operations/serializers.py
parent773bd68f6d5dd96ffe35cc717d3b051f89af43c5 (diff)
downloadIshtar-d99e961414c0c15812bbc583253008550079ccc8.tar.bz2
Ishtar-d99e961414c0c15812bbc583253008550079ccc8.zip
Serializers: filter by finds
Diffstat (limited to 'archaeological_operations/serializers.py')
-rw-r--r--archaeological_operations/serializers.py20
1 files changed, 19 insertions, 1 deletions
diff --git a/archaeological_operations/serializers.py b/archaeological_operations/serializers.py
index a480f307a..4dd6f106b 100644
--- a/archaeological_operations/serializers.py
+++ b/archaeological_operations/serializers.py
@@ -12,7 +12,8 @@ OPERATION_MODEL_LIST = [
def operation_serialization(archive=False, return_empty_types=False,
archive_name=None, operation_queryset=None,
- site_queryset=None, cr_queryset=None):
+ site_queryset=None, cr_queryset=None,
+ find_queryset=None):
result_queryset = {}
if operation_queryset:
operation_ids = operation_queryset.values_list("id", flat=True)
@@ -54,6 +55,23 @@ def operation_serialization(archive=False, return_empty_types=False,
right_record__context_record__id__in=cr_ids,
),
}
+ elif find_queryset:
+ find_ids = find_queryset.values_list("id", flat=True)
+ result_queryset = {
+ models.ArchaeologicalSite.__name__:
+ models.ArchaeologicalSite.objects.filter(
+ operations__context_record__base_finds__find__id__in
+ =find_ids),
+ models.Operation.__name__: models.Operation.objects.filter(
+ context_record__base_finds__find__id__in=find_ids),
+ models.RecordRelations.__name__:
+ models.RecordRelations.objects.filter(
+ left_record__context_record__base_finds__find__id__in=
+ find_ids,
+ right_record__context_record__base_finds__find__id__in=
+ find_ids,
+ ),
+ }
result = generic_get_results(OPERATION_MODEL_LIST, "operations",
result_queryset=result_queryset)