mirror of
https://github.com/Mailu/Mailu.git
synced 2025-01-06 00:26:08 +02:00
Merge #1088
1088: Support domain literals (fix #1087) r=mergify[bot] a=hoellen ## What type of PR? bug-fix ## What does this PR do? This PR adds error handling for idna enocding. With telnet you now get a "Bad sender address syntax" message. ``` > telnet mail.example.com 25 Connected to example.com. Escape character is '^]'. 220 mail.example.com ESMTP ready EHLO dummy.example.com 250-mail.example.com 250 STARTTLS MAIL FROM: does-not-exist@[116.203.165.200] 250 2.0.0 OK RCPT TO: some-user@example.com 501 5.1.7 Bad sender address syntax Connection closed by foreign host. ``` ### Related issue(s) fix #1087 ## Prerequistes Before we can consider review and merge, please make sure the following list is done and checked. If an entry in not applicable, you can check it or remove it from the list. - [x] In case of feature or enhancement: documentation updated accordingly - [x] Unless it's docs or a minor change: add [changelog](https://mailu.io/master/contributors/guide.html#changelog) entry file. Co-authored-by: hoellen <dev@hoellen.eu>
This commit is contained in:
commit
47a40d17b7
@ -2,10 +2,13 @@ from mailu import models
|
|||||||
from mailu.internal import internal
|
from mailu.internal import internal
|
||||||
|
|
||||||
import flask
|
import flask
|
||||||
|
import re
|
||||||
|
|
||||||
|
|
||||||
@internal.route("/postfix/domain/<domain_name>")
|
@internal.route("/postfix/domain/<domain_name>")
|
||||||
def postfix_mailbox_domain(domain_name):
|
def postfix_mailbox_domain(domain_name):
|
||||||
|
if re.match("^\[.*\]$", domain_name):
|
||||||
|
return flask.abort(404)
|
||||||
domain = models.Domain.query.get(domain_name) or \
|
domain = models.Domain.query.get(domain_name) or \
|
||||||
models.Alternative.query.get(domain_name) or \
|
models.Alternative.query.get(domain_name) or \
|
||||||
flask.abort(404)
|
flask.abort(404)
|
||||||
@ -29,7 +32,7 @@ def postfix_alias_map(alias):
|
|||||||
|
|
||||||
@internal.route("/postfix/transport/<path:email>")
|
@internal.route("/postfix/transport/<path:email>")
|
||||||
def postfix_transport(email):
|
def postfix_transport(email):
|
||||||
if email == '*':
|
if email == '*' or re.match("(^|.*@)\[.*\]$", email):
|
||||||
return flask.abort(404)
|
return flask.abort(404)
|
||||||
localpart, domain_name = models.Email.resolve_domain(email)
|
localpart, domain_name = models.Email.resolve_domain(email)
|
||||||
relay = models.Relay.query.get(domain_name) or flask.abort(404)
|
relay = models.Relay.query.get(domain_name) or flask.abort(404)
|
||||||
|
1
towncrier/newsfragments/1087.bugfix
Normal file
1
towncrier/newsfragments/1087.bugfix
Normal file
@ -0,0 +1 @@
|
|||||||
|
Support domain literals
|
Loading…
Reference in New Issue
Block a user