2009-11-03 20:53:26 +08:00
|
|
|
"""
|
|
|
|
Email backend that writes messages to console instead of sending them.
|
|
|
|
"""
|
|
|
|
import sys
|
|
|
|
import threading
|
|
|
|
|
|
|
|
from django.core.mail.backends.base import BaseEmailBackend
|
|
|
|
|
2013-11-03 04:12:09 +08:00
|
|
|
|
2009-11-03 20:53:26 +08:00
|
|
|
class EmailBackend(BaseEmailBackend):
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
|
|
self.stream = kwargs.pop("stream", sys.stdout)
|
|
|
|
self._lock = threading.RLock()
|
2017-01-21 21:13:44 +08:00
|
|
|
super().__init__(*args, **kwargs)
|
2009-11-03 20:53:26 +08:00
|
|
|
|
2013-12-31 06:45:43 +08:00
|
|
|
def write_message(self, message):
|
2013-12-31 06:54:12 +08:00
|
|
|
msg = message.message()
|
|
|
|
msg_data = msg.as_bytes()
|
2016-12-01 18:38:01 +08:00
|
|
|
charset = (
|
|
|
|
msg.get_charset().get_output_charset() if msg.get_charset() else "utf-8"
|
2022-02-04 03:24:19 +08:00
|
|
|
)
|
2016-12-01 18:38:01 +08:00
|
|
|
msg_data = msg_data.decode(charset)
|
2013-12-31 06:54:12 +08:00
|
|
|
self.stream.write("%s\n" % msg_data)
|
2013-12-31 06:45:43 +08:00
|
|
|
self.stream.write("-" * 79)
|
|
|
|
self.stream.write("\n")
|
|
|
|
|
2009-11-03 20:53:26 +08:00
|
|
|
def send_messages(self, email_messages):
|
|
|
|
"""Write all messages to the stream in a thread-safe way."""
|
|
|
|
if not email_messages:
|
|
|
|
return
|
2013-04-04 10:42:31 +08:00
|
|
|
msg_count = 0
|
2012-06-23 23:11:15 +08:00
|
|
|
with self._lock:
|
|
|
|
try:
|
|
|
|
stream_created = self.open()
|
|
|
|
for message in email_messages:
|
2013-12-31 06:45:43 +08:00
|
|
|
self.write_message(message)
|
2012-06-23 23:11:15 +08:00
|
|
|
self.stream.flush() # flush after each message
|
2013-04-04 10:42:31 +08:00
|
|
|
msg_count += 1
|
2012-06-23 23:11:15 +08:00
|
|
|
if stream_created:
|
|
|
|
self.close()
|
2013-09-30 23:55:14 +08:00
|
|
|
except Exception:
|
2012-06-23 23:11:15 +08:00
|
|
|
if not self.fail_silently:
|
|
|
|
raise
|
2013-04-04 10:42:31 +08:00
|
|
|
return msg_count
|