Commit f8f43a8e authored by Robert's avatar Robert
Browse files

Refactor Gestalt.get_or_create

parent 2f45e4c8
......@@ -13,11 +13,17 @@ from core import colors
class GestaltQuerySet(models.QuerySet):
def get_by_email(self, email):
return self.get(user__email__iexact=email)
except self.model.DoesNotExist:
return self.get(user__emailaddress__email__iexact=email)
def get_or_create_by_email(self, email):
created = False
user = auth.get_user_model().objects.get(emailaddress__email=email)
except auth.get_user_model().DoesNotExist:
user = self.get_by_email(email).user
except self.model.DoesNotExist:
user, created = auth.get_user_model().objects.get_or_create(
if created:
......@@ -6,7 +6,6 @@ import re
import django.db.models.signals
import django_mailbox.signals
from django.conf import settings
from django.db.models.functions import Lower
from django.dispatch import receiver
import html2text
......@@ -17,7 +16,7 @@ from features.contributions import models
from features.contributions.signals import post_create
from features.conversations import models as conversations
from features.files import models as files
from features.gestalten import models as gestalten
from features.gestalten.models import Gestalt
from features.groups import models as groups
logger = logging.getLogger(__name__)
......@@ -32,18 +31,10 @@ class MailProcessingFailure(Exception):
def get_sender_gestalt(from_address):
gestalt = gestalten.Gestalt.objects.annotate(email=Lower('user__email')).get(
except gestalten.Gestalt.DoesNotExist:
gestalt = gestalten.Gestalt.objects.annotate(
except gestalten.Gestalt.DoesNotExist:
gestalt = None
return gestalt
return Gestalt.objects.get_by_email(from_address)
except Gestalt.DoesNotExist:
return None
def is_autoresponse(email_obj):
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment