django-bulk-hooks 0.1.182__tar.gz → 0.1.184__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of django-bulk-hooks might be problematic. Click here for more details.

Files changed (17) hide show
  1. {django_bulk_hooks-0.1.182 → django_bulk_hooks-0.1.184}/PKG-INFO +1 -1
  2. {django_bulk_hooks-0.1.182 → django_bulk_hooks-0.1.184}/django_bulk_hooks/queryset.py +38 -26
  3. {django_bulk_hooks-0.1.182 → django_bulk_hooks-0.1.184}/pyproject.toml +1 -1
  4. {django_bulk_hooks-0.1.182 → django_bulk_hooks-0.1.184}/LICENSE +0 -0
  5. {django_bulk_hooks-0.1.182 → django_bulk_hooks-0.1.184}/README.md +0 -0
  6. {django_bulk_hooks-0.1.182 → django_bulk_hooks-0.1.184}/django_bulk_hooks/__init__.py +0 -0
  7. {django_bulk_hooks-0.1.182 → django_bulk_hooks-0.1.184}/django_bulk_hooks/conditions.py +0 -0
  8. {django_bulk_hooks-0.1.182 → django_bulk_hooks-0.1.184}/django_bulk_hooks/constants.py +0 -0
  9. {django_bulk_hooks-0.1.182 → django_bulk_hooks-0.1.184}/django_bulk_hooks/context.py +0 -0
  10. {django_bulk_hooks-0.1.182 → django_bulk_hooks-0.1.184}/django_bulk_hooks/decorators.py +0 -0
  11. {django_bulk_hooks-0.1.182 → django_bulk_hooks-0.1.184}/django_bulk_hooks/engine.py +0 -0
  12. {django_bulk_hooks-0.1.182 → django_bulk_hooks-0.1.184}/django_bulk_hooks/enums.py +0 -0
  13. {django_bulk_hooks-0.1.182 → django_bulk_hooks-0.1.184}/django_bulk_hooks/handler.py +0 -0
  14. {django_bulk_hooks-0.1.182 → django_bulk_hooks-0.1.184}/django_bulk_hooks/manager.py +0 -0
  15. {django_bulk_hooks-0.1.182 → django_bulk_hooks-0.1.184}/django_bulk_hooks/models.py +0 -0
  16. {django_bulk_hooks-0.1.182 → django_bulk_hooks-0.1.184}/django_bulk_hooks/priority.py +0 -0
  17. {django_bulk_hooks-0.1.182 → django_bulk_hooks-0.1.184}/django_bulk_hooks/registry.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.3
2
2
  Name: django-bulk-hooks
3
- Version: 0.1.182
3
+ Version: 0.1.184
4
4
  Summary: Hook-style hooks for Django bulk operations like bulk_create and bulk_update.
5
5
  License: MIT
6
6
  Keywords: django,bulk,hooks
@@ -14,6 +14,7 @@ from django_bulk_hooks.constants import (
14
14
  VALIDATE_UPDATE,
15
15
  )
16
16
  from django_bulk_hooks.context import HookContext
17
+ from django.db.models import When, Value, Case
17
18
 
18
19
 
19
20
  class HookQuerySet(models.QuerySet):
@@ -554,35 +555,46 @@ class HookQuerySet(models.QuerySet):
554
555
  if not model_fields:
555
556
  continue
556
557
 
557
- # Get objects that have this model's fields
558
- model_objs = []
559
- for obj in objs:
560
- # Create a temporary object with just this model's fields
561
- temp_obj = model()
558
+ # For MTI, we need to handle parent links correctly
559
+ # The root model (first in chain) has its own PK
560
+ # Child models use the parent link to reference the root PK
561
+ if model == inheritance_chain[0]:
562
+ # Root model - use primary keys directly
563
+ pks = [obj.pk for obj in objs]
564
+ filter_field = 'pk'
565
+ else:
566
+ # Child model - use parent link field
567
+ parent_link = None
568
+ for parent_model in inheritance_chain:
569
+ if parent_model in model._meta.parents:
570
+ parent_link = model._meta.parents[parent_model]
571
+ break
562
572
 
563
- # Set the primary key properly using the model's pk field
564
- pk_field = model._meta.pk
565
- pk_value = obj.pk
566
- setattr(temp_obj, pk_field.attname, pk_value)
573
+ if parent_link is None:
574
+ # This shouldn't happen in proper MTI, but handle gracefully
575
+ continue
567
576
 
568
- # Also set the pk property for compatibility
569
- temp_obj.pk = pk_value
577
+ # Get the parent link values (these should be the same as the root PKs)
578
+ pks = [getattr(obj, parent_link.attname) for obj in objs]
579
+ filter_field = parent_link.attname
580
+
581
+ if pks:
582
+ base_qs = model._base_manager.using(self.db)
570
583
 
571
- # Mark the object as not being added (it's an existing object)
572
- temp_obj._state.adding = False
573
- temp_obj._state.db = self.db
574
-
575
- # Copy only the fields for this model
584
+ # Build CASE statements for each field
585
+ case_statements = {}
576
586
  for field_name in model_fields:
577
- if hasattr(obj, field_name):
578
- setattr(temp_obj, field_name, getattr(obj, field_name))
579
-
580
- model_objs.append(temp_obj)
581
-
582
- # Use Django's bulk_update for this model's table
583
- # This will automatically use batch_size from kwargs
584
- base_qs = model._base_manager.using(self.db)
585
- updated_count = base_qs.bulk_update(model_objs, model_fields, **kwargs)
586
- total_updated += updated_count
587
+ field = model._meta.get_field(field_name)
588
+ when_statements = []
589
+
590
+ for pk, obj in zip(pks, objs):
591
+ value = getattr(obj, field_name)
592
+ when_statements.append(When(**{filter_field: pk}, then=Value(value, output_field=field)))
593
+
594
+ case_statements[field_name] = Case(*when_statements, output_field=field)
595
+
596
+ # Execute the update using the appropriate filter field
597
+ updated_count = base_qs.filter(**{f"{filter_field}__in": pks}).update(**case_statements)
598
+ total_updated += updated_count
587
599
 
588
600
  return total_updated
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "django-bulk-hooks"
3
- version = "0.1.182"
3
+ version = "0.1.184"
4
4
  description = "Hook-style hooks for Django bulk operations like bulk_create and bulk_update."
5
5
  authors = ["Konrad Beck <konrad.beck@merchantcapital.co.za>"]
6
6
  readme = "README.md"