2018-10-10 12:00:53 +00:00
|
|
|
"""
|
|
|
|
src/class_smtpDeliver.py
|
|
|
|
========================
|
|
|
|
"""
|
|
|
|
# pylint: disable=unused-variable
|
|
|
|
|
2016-06-30 10:27:36 +00:00
|
|
|
import smtplib
|
|
|
|
import sys
|
|
|
|
import urlparse
|
2018-10-10 12:00:53 +00:00
|
|
|
from email.header import Header
|
|
|
|
from email.mime.text import MIMEText
|
2016-06-30 10:27:36 +00:00
|
|
|
|
2017-02-08 12:41:56 +00:00
|
|
|
import queues
|
2017-01-14 22:20:15 +00:00
|
|
|
import state
|
2018-10-10 12:00:53 +00:00
|
|
|
from bmconfigparser import BMConfigParser
|
|
|
|
from debug import logger
|
|
|
|
from helper_threading import StoppableThread
|
2016-06-30 10:27:36 +00:00
|
|
|
|
|
|
|
SMTPDOMAIN = "bmaddr.lan"
|
|
|
|
|
2018-10-10 12:00:53 +00:00
|
|
|
|
2019-08-01 11:37:26 +00:00
|
|
|
class smtpDeliver(StoppableThread):
|
2018-10-10 12:00:53 +00:00
|
|
|
"""SMTP client thread for delivery"""
|
2019-08-01 11:37:26 +00:00
|
|
|
name = "smtpDeliver"
|
2016-06-30 10:27:36 +00:00
|
|
|
_instance = None
|
|
|
|
|
|
|
|
def stopThread(self):
|
|
|
|
try:
|
2018-10-10 12:00:53 +00:00
|
|
|
queues.UISignallerQueue.put(("stopThread", "data")) # pylint: disable=no-member
|
2016-06-30 10:27:36 +00:00
|
|
|
except:
|
|
|
|
pass
|
|
|
|
super(smtpDeliver, self).stopThread()
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def get(cls):
|
2018-10-10 12:00:53 +00:00
|
|
|
"""(probably) Singleton functionality"""
|
2016-06-30 10:27:36 +00:00
|
|
|
if not cls._instance:
|
2017-02-20 19:53:50 +00:00
|
|
|
cls._instance = smtpDeliver()
|
2016-06-30 10:27:36 +00:00
|
|
|
return cls._instance
|
|
|
|
|
|
|
|
def run(self):
|
2018-10-10 12:00:53 +00:00
|
|
|
# pylint: disable=too-many-branches,too-many-statements,too-many-locals
|
2017-01-14 22:20:15 +00:00
|
|
|
while state.shutdown == 0:
|
2017-02-08 12:41:56 +00:00
|
|
|
command, data = queues.UISignalQueue.get()
|
2016-06-30 10:27:36 +00:00
|
|
|
if command == 'writeNewAddressToTable':
|
|
|
|
label, address, streamNumber = data
|
|
|
|
elif command == 'updateStatusBar':
|
|
|
|
pass
|
|
|
|
elif command == 'updateSentItemStatusByToAddress':
|
|
|
|
toAddress, message = data
|
|
|
|
elif command == 'updateSentItemStatusByAckdata':
|
|
|
|
ackData, message = data
|
|
|
|
elif command == 'displayNewInboxMessage':
|
|
|
|
inventoryHash, toAddress, fromAddress, subject, body = data
|
2017-01-11 13:27:19 +00:00
|
|
|
dest = BMConfigParser().safeGet("bitmessagesettings", "smtpdeliver", '')
|
2016-06-30 13:19:58 +00:00
|
|
|
if dest == '':
|
2016-06-30 10:27:36 +00:00
|
|
|
continue
|
|
|
|
try:
|
|
|
|
u = urlparse.urlparse(dest)
|
|
|
|
to = urlparse.parse_qs(u.query)['to']
|
|
|
|
client = smtplib.SMTP(u.hostname, u.port)
|
|
|
|
msg = MIMEText(body, 'plain', 'utf-8')
|
2016-07-09 07:58:01 +00:00
|
|
|
msg['Subject'] = Header(subject, 'utf-8')
|
2016-06-30 10:27:36 +00:00
|
|
|
msg['From'] = fromAddress + '@' + SMTPDOMAIN
|
2018-10-10 12:00:53 +00:00
|
|
|
toLabel = map( # pylint: disable=deprecated-lambda
|
|
|
|
lambda y: BMConfigParser().safeGet(y, "label"),
|
|
|
|
filter( # pylint: disable=deprecated-lambda
|
|
|
|
lambda x: x == toAddress, BMConfigParser().addresses())
|
|
|
|
)
|
|
|
|
if toLabel:
|
2016-07-09 07:58:01 +00:00
|
|
|
msg['To'] = "\"%s\" <%s>" % (Header(toLabel[0], 'utf-8'), toAddress + '@' + SMTPDOMAIN)
|
|
|
|
else:
|
|
|
|
msg['To'] = toAddress + '@' + SMTPDOMAIN
|
2016-06-30 10:27:36 +00:00
|
|
|
client.ehlo()
|
|
|
|
client.starttls()
|
|
|
|
client.ehlo()
|
|
|
|
client.sendmail(msg['From'], [to], msg.as_string())
|
|
|
|
logger.info("Delivered via SMTP to %s through %s:%i ...", to, u.hostname, u.port)
|
|
|
|
client.quit()
|
|
|
|
except:
|
|
|
|
logger.error("smtp delivery error", exc_info=True)
|
|
|
|
elif command == 'displayNewSentMessage':
|
|
|
|
toAddress, fromLabel, fromAddress, subject, message, ackdata = data
|
|
|
|
elif command == 'updateNetworkStatusTab':
|
|
|
|
pass
|
|
|
|
elif command == 'updateNumberOfMessagesProcessed':
|
|
|
|
pass
|
|
|
|
elif command == 'updateNumberOfPubkeysProcessed':
|
|
|
|
pass
|
|
|
|
elif command == 'updateNumberOfBroadcastsProcessed':
|
|
|
|
pass
|
|
|
|
elif command == 'setStatusIcon':
|
|
|
|
pass
|
|
|
|
elif command == 'changedInboxUnread':
|
|
|
|
pass
|
|
|
|
elif command == 'rerenderMessagelistFromLabels':
|
|
|
|
pass
|
|
|
|
elif command == 'rerenderMessagelistToLabels':
|
|
|
|
pass
|
|
|
|
elif command == 'rerenderAddressBook':
|
|
|
|
pass
|
|
|
|
elif command == 'rerenderSubscriptions':
|
|
|
|
pass
|
|
|
|
elif command == 'rerenderBlackWhiteList':
|
|
|
|
pass
|
|
|
|
elif command == 'removeInboxRowByMsgid':
|
|
|
|
pass
|
|
|
|
elif command == 'newVersionAvailable':
|
|
|
|
pass
|
|
|
|
elif command == 'alert':
|
|
|
|
title, text, exitAfterUserClicksOk = data
|
|
|
|
elif command == 'stopThread':
|
|
|
|
break
|
|
|
|
else:
|
|
|
|
sys.stderr.write(
|
|
|
|
'Command sent to smtpDeliver not recognized: %s\n' % command)
|