summaryrefslogtreecommitdiffstats
path: root/Lib/logging/handlers.py
diff options
context:
space:
mode:
authorVinay Sajip <vinay_sajip@yahoo.co.uk>2009-12-06 18:05:04 (GMT)
committerVinay Sajip <vinay_sajip@yahoo.co.uk>2009-12-06 18:05:04 (GMT)
commit25fcd22057ed5822ae20ec34231bf4f98dd90043 (patch)
treeea0f9954facbcf4600ebf9a4b07c19b8200203a6 /Lib/logging/handlers.py
parent540f21529460a7c289021fb5026b4b8ef5ce8976 (diff)
downloadcpython-25fcd22057ed5822ae20ec34231bf4f98dd90043.zip
cpython-25fcd22057ed5822ae20ec34231bf4f98dd90043.tar.gz
cpython-25fcd22057ed5822ae20ec34231bf4f98dd90043.tar.bz2
logging: Improved support for SMTP over TLS.
Diffstat (limited to 'Lib/logging/handlers.py')
-rw-r--r--Lib/logging/handlers.py15
1 files changed, 9 insertions, 6 deletions
diff --git a/Lib/logging/handlers.py b/Lib/logging/handlers.py
index d722e21..fb48344 100644
--- a/Lib/logging/handlers.py
+++ b/Lib/logging/handlers.py
@@ -804,7 +804,7 @@ class SMTPHandler(logging.Handler):
A handler class which sends an SMTP email for each logging event.
"""
def __init__(self, mailhost, fromaddr, toaddrs, subject,
- credentials=None, secure=False):
+ credentials=None, secure=None):
"""
Initialize the handler.
@@ -812,9 +812,12 @@ class SMTPHandler(logging.Handler):
line of the email. To specify a non-standard SMTP port, use the
(host, port) tuple format for the mailhost argument. To specify
authentication credentials, supply a (username, password) tuple
- for the credentials argument. To specify the use of a secure
- protocol (TLS), pass in True for the secure argument. This will
- only be used when authentication credentials are supplied.
+ for the credentials argument. To specify the use of a secure
+ protocol (TLS), pass in a tuple for the secure argument. This will
+ only be used when authentication credentials are supplied. The tuple
+ will be either an empty tuple, or a single-value tuple with the name
+ of a keyfile, or a 2-value tuple with the names of the keyfile and
+ certificate file. (This tuple is passed to the `starttls` method).
"""
logging.Handler.__init__(self)
if isinstance(mailhost, tuple):
@@ -882,9 +885,9 @@ class SMTPHandler(logging.Handler):
self.getSubject(record),
formatdate(), msg)
if self.username:
- if self.secure:
+ if self.secure is not None:
smtp.ehlo()
- smtp.starttls()
+ smtp.starttls(*self.secure)
smtp.ehlo()
smtp.login(self.username, self.password)
smtp.sendmail(self.fromaddr, self.toaddrs, msg)