Allow extended characters in ID of email address (#693)

pull/698/head
Chris Caron 2022-10-13 19:53:32 -04:00 committed by GitHub
parent cb7f51d82a
commit b989427215
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
9 changed files with 37 additions and 10 deletions

View File

@ -129,7 +129,8 @@ class NotifyForm(NotifyBase):
}, },
} }
def __init__(self, headers=None, method=None, payload=None, params=None, **kwargs): def __init__(self, headers=None, method=None, payload=None, params=None,
**kwargs):
""" """
Initialize Form Object Initialize Form Object

View File

@ -136,7 +136,8 @@ class NotifyXML(NotifyBase):
}, },
} }
def __init__(self, headers=None, method=None, payload=None, params=None, **kwargs): def __init__(self, headers=None, method=None, payload=None, params=None,
**kwargs):
""" """
Initialize XML Object Initialize XML Object

View File

@ -153,10 +153,10 @@ URL_DETAILS_RE = re.compile(
# - user@example.com # - user@example.com
# - label+user@example.com # - label+user@example.com
GET_EMAIL_RE = re.compile( GET_EMAIL_RE = re.compile(
r'(([\s"\']+)?(?P<name>[^:<"\']+)?[:<\s"\']+)?' r'(([\s"\']+)?(?P<name>[^:<\'"]+)?[:<\s\'"]+)?'
r'(?P<full_email>((?P<label>[^+]+)\+)?' r'(?P<full_email>((?P<label>[^+]+)\+)?'
r'(?P<email>(?P<userid>[a-z0-9$%=_~-]+' r'(?P<email>(?P<userid>[a-z0-9_!#$%&*/=?%`{|}~^-]+'
r'(?:\.[a-z0-9$%+=_~-]+)' r'(?:\.[a-z0-9_!#$%&\'*/=?%`{|}~^-]+)'
r'*)@(?P<domain>(' r'*)@(?P<domain>('
r'(?:[a-z0-9](?:[a-z0-9_-]*[a-z0-9])?\.)+' r'(?:[a-z0-9](?:[a-z0-9_-]*[a-z0-9])?\.)+'
r'[a-z0-9](?:[a-z0-9_-]*[a-z0-9]))|' r'[a-z0-9](?:[a-z0-9_-]*[a-z0-9]))|'
@ -188,7 +188,7 @@ URL_DETECTION_RE = re.compile(
EMAIL_DETECTION_RE = re.compile( EMAIL_DETECTION_RE = re.compile(
r'[\s,]*([^@]+@.*?)(?=$|[\s,]+' r'[\s,]*([^@]+@.*?)(?=$|[\s,]+'
+ r'(?:[^:<]+?[:<\s]+?)?' r'(?:[^:<]+?[:<\s]+?)?'
r'[^@\s,]+@[^\s,]+)', r'[^@\s,]+@[^\s,]+)',
re.IGNORECASE) re.IGNORECASE)

View File

@ -1361,6 +1361,30 @@ def test_is_email():
assert utils.is_email("Just A Name") is False assert utils.is_email("Just A Name") is False
assert utils.is_email("Name <bademail>") is False assert utils.is_email("Name <bademail>") is False
# Extended valid emails
#
# The first + denotes our label, so this test really validates
# that there is a correct split and parsing of our email
results = utils.is_email('a-z0-9_!#$%&*+/=?%`{|}~^.-@gmail.com')
assert '' == results['name']
assert 'a-z0-9_!#$%&*' == results['label']
assert '/=?%`{|}~^.-@gmail.com' == results['email']
assert 'a-z0-9_!#$%&*+/=?%`{|}~^.-@gmail.com' == results['full_email']
assert 'gmail.com' == results['domain']
assert '/=?%`{|}~^.-' == results['user']
# A similar test without '+' (use of a label)
# The first + denotes our label, so this test really validates
# that there is a correct split and parsing of our email
results = utils.is_email('a-z0-9_!#$%&*/=?%`{|}~^.-@gmail.com')
assert '' == results['name']
assert '' == results['label']
assert 'a-z0-9_!#$%&*/=?%`{|}~^.-@gmail.com' == results['email']
assert 'a-z0-9_!#$%&*/=?%`{|}~^.-@gmail.com' == results['full_email']
assert 'gmail.com' == results['domain']
assert 'a-z0-9_!#$%&*/=?%`{|}~^.-' == results['user']
def test_is_call_sign_no(): def test_is_call_sign_no():
""" """

View File

@ -504,6 +504,7 @@ urls:
- invalid: test - invalid: test
- sns://T1JJ3T3L2/: - sns://T1JJ3T3L2/:
- invalid: test - invalid: test
- _invalid: Token can not start with an underscore
# some strangeness # some strangeness
- -

View File

@ -191,7 +191,7 @@ TEST_URLS = (
'response': False, 'response': False,
}), }),
# Valid URL, but can't structure a proper email # Valid URL, but can't structure a proper email
('mailtos://nuxref.com?user=%20!&pass=.', { ('mailtos://nuxref.com?user=%20"&pass=.', {
'instance': TypeError, 'instance': TypeError,
}), }),
# Invalid From (and To) Address # Invalid From (and To) Address

View File

@ -58,7 +58,7 @@ apprise_url_tests = (
'instance': TypeError, 'instance': TypeError,
}), }),
# Invalid from email address # Invalid from email address
('mailgun://!@localhost.localdomain/{}-{}-{}'.format( ('mailgun://"@localhost.localdomain/{}-{}-{}'.format(
'a' * 32, 'b' * 8, 'c' * 8), { 'a' * 32, 'b' * 8, 'c' * 8), {
'instance': TypeError, 'instance': TypeError,
}), }),

View File

@ -58,7 +58,7 @@ apprise_url_tests = (
'instance': TypeError, 'instance': TypeError,
}), }),
# Invalid from email address # Invalid from email address
('smtp2go://!@localhost.localdomain/{}-{}-{}'.format( ('smtp2go://"@localhost.localdomain/{}-{}-{}'.format(
'a' * 32, 'b' * 8, 'c' * 8), { 'a' * 32, 'b' * 8, 'c' * 8), {
'instance': TypeError, 'instance': TypeError,
}), }),

View File

@ -59,7 +59,7 @@ apprise_url_tests = (
'instance': TypeError, 'instance': TypeError,
}), }),
# Invalid from email address # Invalid from email address
('sparkpost://!@localhost.localdomain/{}'.format('b' * 32), { ('sparkpost://"@localhost.localdomain/{}'.format('b' * 32), {
'instance': TypeError, 'instance': TypeError,
}), }),
# No To email address, but everything else is valid # No To email address, but everything else is valid