From 8034d86038bea460d66820dabd63ddf83a167bca Mon Sep 17 00:00:00 2001 From: Olivier Leger Date: Thu, 16 Nov 2023 17:41:43 -0500 Subject: [PATCH] Ignore encrypted files for soft deletion when editing a submission --- .../commands/soft_delete_orphan_attachments_2_023_37c_fix.py | 3 +++ onadata/libs/utils/logger_tools.py | 1 + 2 files changed, 4 insertions(+) diff --git a/onadata/apps/logger/management/commands/soft_delete_orphan_attachments_2_023_37c_fix.py b/onadata/apps/logger/management/commands/soft_delete_orphan_attachments_2_023_37c_fix.py index 959174872..228fe21ff 100644 --- a/onadata/apps/logger/management/commands/soft_delete_orphan_attachments_2_023_37c_fix.py +++ b/onadata/apps/logger/management/commands/soft_delete_orphan_attachments_2_023_37c_fix.py @@ -46,6 +46,7 @@ def handle(self, *args, **kwargs): queryset = Attachment.all_objects.filter( Q(media_file_basename='audit.csv') + | Q(media_file_basename__endswith='.enc') | Q(media_file_basename__regex=r'^\d{10,}\.(m4a|amr)$'), deleted_at__isnull=False, ) @@ -58,6 +59,7 @@ def handle(self, *args, **kwargs): att_queryset = Attachment.all_objects.filter( Q(media_file_basename='audit.csv') + | Q(media_file_basename__endswith='.enc') | Q(media_file_basename__regex=r'^\d{10,}\.(m4a|amr)$') ) if not force: @@ -82,6 +84,7 @@ def handle(self, *args, **kwargs): ) Attachment.all_objects.filter( Q(media_file_basename='audit.csv') + | Q(media_file_basename__endswith='.enc') | Q(media_file_basename__regex=r'^\d+\.(m4a|amr)$'), instance_id=instance.pk, ).update(deleted_at=None) diff --git a/onadata/libs/utils/logger_tools.py b/onadata/libs/utils/logger_tools.py index d192862c0..7bf88bf66 100644 --- a/onadata/libs/utils/logger_tools.py +++ b/onadata/libs/utils/logger_tools.py @@ -738,6 +738,7 @@ def get_soft_deleted_attachments(instance: Instance) -> list[Attachment]: # Bug comes from `get_xform_media_question_xpaths()` queryset = Attachment.objects.filter(instance=instance).exclude( Q(media_file_basename__in=basenames) + | Q(media_file_basename__endswith='.enc') | Q(media_file_basename='audit.csv') | Q(media_file_basename__regex=r'^\d{10,}\.(m4a|amr)$') )