Merge pull request #814 from Nebukadneza/fix_delimiter_alias

Deliver mails to alias-stripped-of-delimeter, even if catchall exists
master
mergify[bot] 6 years ago committed by GitHub
commit 278bcfb13a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -268,14 +268,20 @@ 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_stripped = None
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_stripped = localpart.rsplit(os.environ.get('RECIPIENT_DELIMITER'), 1)[0]
alias = Alias.resolve(localpart, domain_name) pure_alias = Alias.resolve(localpart, domain_name)
if not alias and localpart_stripped: stripped_alias = Alias.resolve(localpart_stripped, domain_name)
alias = Alias.resolve(localpart_stripped, domain_name)
if alias: if pure_alias and not pure_alias.wildcard:
return alias.destination return pure_alias.destination
elif 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:

Loading…
Cancel
Save