|
|
@ -260,24 +260,14 @@ class Email(object):
|
|
|
|
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
@classmethod
|
|
|
|
def resolve_destination(cls, localpart, domain_name, ignore_forward_keep=False):
|
|
|
|
def resolve_destination(cls, localpart, domain_name, ignore_forward_keep=False):
|
|
|
|
localpart_stripped = None
|
|
|
|
localpart_maybe_split = localpart
|
|
|
|
stripped_alias = None
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if os.environ.get('RECIPIENT_DELIMITER') in localpart:
|
|
|
|
if os.environ.get('RECIPIENT_DELIMITER') in localpart:
|
|
|
|
localpart_stripped = localpart.rsplit(os.environ.get('RECIPIENT_DELIMITER'), 1)[0]
|
|
|
|
localpart_maybe_split = localpart.rsplit(os.environ.get('RECIPIENT_DELIMITER'), 1)[0]
|
|
|
|
|
|
|
|
|
|
|
|
pure_alias = Alias.resolve(localpart, domain_name)
|
|
|
|
alias = Alias.resolve(localpart_maybe_split, domain_name)
|
|
|
|
has_wildcard = pure_alias and '%' in pure_alias.email and pure_alias.wildcard
|
|
|
|
|
|
|
|
stripped_alias = Alias.resolve(localpart_stripped, domain_name)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if pure_alias and not has_wildcard:
|
|
|
|
if alias:
|
|
|
|
return pure_alias.destination
|
|
|
|
return alias.destination
|
|
|
|
elif not pure_alias and stripped_alias:
|
|
|
|
|
|
|
|
return stripped_alias.destination
|
|
|
|
|
|
|
|
elif has_wildcard and localpart_stripped and stripped_alias:
|
|
|
|
|
|
|
|
return stripped_alias.destination
|
|
|
|
|
|
|
|
elif pure_alias:
|
|
|
|
|
|
|
|
return pure_alias.destination
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
user = User.query.get('{}@{}'.format(localpart, domain_name))
|
|
|
|
user = User.query.get('{}@{}'.format(localpart, domain_name))
|
|
|
|
if not user and localpart_stripped:
|
|
|
|
if not user and localpart_stripped:
|
|
|
|