diff options
author | Étienne Loks <etienne.loks@iggdrasil.net> | 2019-09-11 14:34:25 +0200 |
---|---|---|
committer | Étienne Loks <etienne.loks@iggdrasil.net> | 2019-09-11 14:35:02 +0200 |
commit | e87be285da2557f3a684418c9f91c9dc22139fda (patch) | |
tree | a22f1e8ce124fa48d218d040b7eaafb33915d84b /archaeological_finds/serializers.py | |
parent | 0a18b35422fd85f9cbb39796275bc90065c80689 (diff) | |
download | Ishtar-e87be285da2557f3a684418c9f91c9dc22139fda.tar.bz2 Ishtar-e87be285da2557f3a684418c9f91c9dc22139fda.zip |
Serialization - Import/Export: manage put an release of locks
Diffstat (limited to 'archaeological_finds/serializers.py')
-rw-r--r-- | archaeological_finds/serializers.py | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/archaeological_finds/serializers.py b/archaeological_finds/serializers.py index 7e79123e6..e130a0ef8 100644 --- a/archaeological_finds/serializers.py +++ b/archaeological_finds/serializers.py @@ -43,7 +43,8 @@ def find_serialization(archive=False, return_empty_types=False, archive_name=None, operation_queryset=None, site_queryset=None, cr_queryset=None, find_queryset=None, warehouse_queryset=None, - get_queryset=False, no_geo=True): + get_queryset=False, no_geo=True, + put_locks=False, lock_user=None): result_queryset = {} if operation_queryset: operation_ids = operation_queryset.values_list("id", flat=True) @@ -94,6 +95,15 @@ def find_serialization(archive=False, return_empty_types=False, result = generic_get_results(FIND_MODEL_LIST, "finds", result_queryset=result_queryset, no_geo=no_geo) + if put_locks: + for model in FIND_MODEL_LIST: + if not hasattr(model, "locked"): + continue + q = model.objects + if result_queryset and model.__name__ in result_queryset: + q = result_queryset[model.__name__] + q.update(locked=True, lock_user=lock_user) + full_archive = archive_serialization( result, archive_dir="operations", archive=archive, return_empty_types=return_empty_types, archive_name=archive_name, |