|
@@ -15,6 +15,7 @@ class EmailBackend(BaseEmailBackend):
|
|
|
"""
|
|
|
def __init__(self, host=None, port=None, username=None, password=None,
|
|
|
use_tls=None, fail_silently=False, use_ssl=None, timeout=None,
|
|
|
+ ssl_keyfile=None, ssl_certfile=None,
|
|
|
**kwargs):
|
|
|
super(EmailBackend, self).__init__(fail_silently=fail_silently)
|
|
|
self.host = host or settings.EMAIL_HOST
|
|
@@ -24,6 +25,8 @@ class EmailBackend(BaseEmailBackend):
|
|
|
self.use_tls = settings.EMAIL_USE_TLS if use_tls is None else use_tls
|
|
|
self.use_ssl = settings.EMAIL_USE_SSL if use_ssl is None else use_ssl
|
|
|
self.timeout = timeout
|
|
|
+ self.ssl_keyfile = settings.EMAIL_SSL_KEYFILE if ssl_keyfile is None else ssl_keyfile
|
|
|
+ self.ssl_certfile = settings.EMAIL_SSL_CERTFILE if ssl_certfile is None else ssl_certfile
|
|
|
if self.use_ssl and self.use_tls:
|
|
|
raise ValueError(
|
|
|
"EMAIL_USE_TLS/EMAIL_USE_SSL are mutually exclusive, so only set "
|
|
@@ -46,6 +49,11 @@ class EmailBackend(BaseEmailBackend):
|
|
|
connection_params = {'local_hostname': DNS_NAME.get_fqdn()}
|
|
|
if self.timeout is not None:
|
|
|
connection_params['timeout'] = self.timeout
|
|
|
+ if self.use_ssl:
|
|
|
+ connection_params.update({
|
|
|
+ 'keyfile': self.ssl_keyfile,
|
|
|
+ 'certfile': self.ssl_certfile,
|
|
|
+ })
|
|
|
try:
|
|
|
self.connection = connection_class(self.host, self.port, **connection_params)
|
|
|
|
|
@@ -53,7 +61,7 @@ class EmailBackend(BaseEmailBackend):
|
|
|
# non-secure connections.
|
|
|
if not self.use_ssl and self.use_tls:
|
|
|
self.connection.ehlo()
|
|
|
- self.connection.starttls()
|
|
|
+ self.connection.starttls(keyfile=self.ssl_keyfile, certfile=self.ssl_certfile)
|
|
|
self.connection.ehlo()
|
|
|
if self.username and self.password:
|
|
|
self.connection.login(self.username, self.password)
|