Fixes: add unregistered addresses fix
This commit is contained in:
parent
8a00cd2bff
commit
e7836ebf90
2 changed files with 77 additions and 52 deletions
|
|
@ -19,6 +19,7 @@ from .models import (
|
||||||
AttributeValue,
|
AttributeValue,
|
||||||
Brand,
|
Brand,
|
||||||
Category,
|
Category,
|
||||||
|
CategoryTag,
|
||||||
Feedback,
|
Feedback,
|
||||||
Order,
|
Order,
|
||||||
OrderProduct,
|
OrderProduct,
|
||||||
|
|
@ -29,7 +30,7 @@ from .models import (
|
||||||
Promotion,
|
Promotion,
|
||||||
Stock,
|
Stock,
|
||||||
Vendor,
|
Vendor,
|
||||||
Wishlist, CategoryTag,
|
Wishlist,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,26 +1,50 @@
|
||||||
|
import logging
|
||||||
|
import traceback
|
||||||
|
|
||||||
from django.contrib import auth
|
from django.contrib import auth
|
||||||
from django.contrib.auth.base_user import BaseUserManager
|
from django.contrib.auth.base_user import BaseUserManager
|
||||||
from django.contrib.auth.hashers import make_password
|
from django.contrib.auth.hashers import make_password
|
||||||
|
|
||||||
from core.models import Order
|
from core.models import Address, Order
|
||||||
|
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
class UserManager(BaseUserManager):
|
class UserManager(BaseUserManager):
|
||||||
use_in_migrations = True
|
use_in_migrations = True
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def handle_unregistered_entities(user):
|
||||||
|
try:
|
||||||
|
orders = set()
|
||||||
|
for order in Order.objects.filter(attributes__icontains=user.email):
|
||||||
|
if not order.user:
|
||||||
|
order.user = user
|
||||||
|
order.save()
|
||||||
|
orders.add(order.uuid)
|
||||||
|
for order in Order.objects.filter(attributes__icontains=user.phone_number):
|
||||||
|
if not order.user:
|
||||||
|
order.user = user
|
||||||
|
order.save()
|
||||||
|
orders.add(order.uuid)
|
||||||
|
for address in Address.objects.filter(billing_address_order__in=orders):
|
||||||
|
if not address.user:
|
||||||
|
address.user = user
|
||||||
|
address.save()
|
||||||
|
for address in Address.objects.filter(shipping_address_order__in=orders):
|
||||||
|
if not address.user:
|
||||||
|
address.user = user
|
||||||
|
address.save()
|
||||||
|
except Exception as e:
|
||||||
|
logger.error(e)
|
||||||
|
logger.error(traceback.format_exc())
|
||||||
|
|
||||||
def _create_user(self, email, password, **extra_fields):
|
def _create_user(self, email, password, **extra_fields):
|
||||||
email = self.normalize_email(email)
|
email = self.normalize_email(email)
|
||||||
user = self.model(email=email, **extra_fields)
|
user = self.model(email=email, **extra_fields)
|
||||||
user.password = make_password(password)
|
user.password = make_password(password)
|
||||||
user.save(using=self._db)
|
user.save(using=self._db)
|
||||||
for order in Order.objects.filter(attributes__icontains=user.email):
|
self.handle_unregistered_entities(user)
|
||||||
if not order.user:
|
|
||||||
order.user = user
|
|
||||||
order.save()
|
|
||||||
for order in Order.objects.filter(attributes__icontains=user.phone_number):
|
|
||||||
if not order.user:
|
|
||||||
order.user = user
|
|
||||||
order.save()
|
|
||||||
return user
|
return user
|
||||||
|
|
||||||
def create_user(self, email=None, password=None, **extra_fields):
|
def create_user(self, email=None, password=None, **extra_fields):
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue