diff options
author | Étienne Loks <etienne.loks@iggdrasil.net> | 2019-09-06 20:22:55 +0200 |
---|---|---|
committer | Étienne Loks <etienne.loks@iggdrasil.net> | 2019-09-06 20:22:55 +0200 |
commit | 821961208036c05310f65a94d740cca38436e7eb (patch) | |
tree | 1e4e3653789d36146acc02cc5838ac54f95a2e28 /archaeological_operations/serializers.py | |
parent | e05ed38b423957d0a6a842c62cb29b6b77cd611d (diff) | |
download | Ishtar-821961208036c05310f65a94d740cca38436e7eb.tar.bz2 Ishtar-821961208036c05310f65a94d740cca38436e7eb.zip |
Serialization: warehouse filter
Diffstat (limited to 'archaeological_operations/serializers.py')
-rw-r--r-- | archaeological_operations/serializers.py | 47 |
1 files changed, 46 insertions, 1 deletions
diff --git a/archaeological_operations/serializers.py b/archaeological_operations/serializers.py index 4dd6f106b..3093bf50a 100644 --- a/archaeological_operations/serializers.py +++ b/archaeological_operations/serializers.py @@ -1,3 +1,5 @@ +from django.db.models import Q + from ishtar_common.serializers import generic_get_results, archive_serialization from archaeological_operations import models @@ -10,10 +12,50 @@ OPERATION_MODEL_LIST = [ # TODO: administrativ acts, associated documents +def generate_warehouse_queryset(ids): + base_query_key = "context_record__base_finds__find" + + q_archaeological_site, q_operation, q_record_relation = None, None, None + + for container_key in ("container", "container_ref"): + for warehouse_key in ("location", "responsible"): + q_s = Q(** + {"operations__{}__{}__{}__id__in".format( + base_query_key, container_key, warehouse_key): ids}) + q_o = Q(** + {"{}__{}__{}__id__in".format( + base_query_key, container_key, warehouse_key): ids}) + q_r = Q(** + {"left_record__{}__{}__{}__id__in".format( + base_query_key, container_key, warehouse_key): ids, + "right_record__{}__{}__{}__id__in".format( + base_query_key, container_key, warehouse_key): ids}) + if not q_archaeological_site: + q_archaeological_site = q_s + q_operation = q_o + q_record_relation = q_r + else: + q_archaeological_site |= q_s + q_operation |= q_o + q_record_relation |= q_r + + result_queryset = { + models.ArchaeologicalSite.__name__: + models.ArchaeologicalSite.objects.filter( + q_archaeological_site + ), + models.Operation.__name__: models.Operation.objects.filter( + q_operation), + models.RecordRelations.__name__: + models.RecordRelations.objects.filter(q_record_relation), + } + return result_queryset + + def operation_serialization(archive=False, return_empty_types=False, archive_name=None, operation_queryset=None, site_queryset=None, cr_queryset=None, - find_queryset=None): + find_queryset=None, warehouse_queryset=None): result_queryset = {} if operation_queryset: operation_ids = operation_queryset.values_list("id", flat=True) @@ -72,6 +114,9 @@ def operation_serialization(archive=False, return_empty_types=False, find_ids, ), } + elif warehouse_queryset: + warehouse_ids = warehouse_queryset.values_list("id", flat=True) + result_queryset = generate_warehouse_queryset(warehouse_ids) result = generic_get_results(OPERATION_MODEL_LIST, "operations", result_queryset=result_queryset) |