D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
opt
/
saltstack
/
salt
/
lib
/
python3.10
/
site-packages
/
salt
/
utils
/
Filename :
smtp.py
back
Copy
""" Return salt data via email The following fields can be set in the minion conf file: smtp.from (required) smtp.to (required) smtp.host (required) smtp.port (optional, defaults to 25) smtp.username (optional) smtp.password (optional) smtp.tls (optional, defaults to False) smtp.subject (optional, but helpful) smtp.gpgowne' (optional) smtp.fields (optional) smtp.content (optional) There are a few things to keep in mind: * If a username is used, a password is also required. It is recommended (but not required) to use the TLS setting when authenticating. * You should at least declare a subject, but you don't have to. * The use of encryption, i.e. setting gpgowner in your settings, requires python-gnupg to be installed. * The field gpgowner specifies a user's ~/.gpg directory. This must contain a gpg public key matching the address the mail is sent to. If left unset, no encryption will be used. """ import logging import os import smtplib from email.utils import formatdate try: import gnupg HAS_GNUPG = True except ImportError: HAS_GNUPG = False log = logging.getLogger(__name__) def send(kwargs, opts): """ Send an email with the data """ opt_keys = ( "smtp.to", "smtp.from", "smtp.host", "smtp.port", "smtp.tls", "smtp.username", "smtp.password", "smtp.subject", "smtp.gpgowner", "smtp.content", ) config = {} for key in opt_keys: config[key] = opts.get(key, "") config.update(kwargs) if not config["smtp.port"]: config["smtp.port"] = 25 log.debug("SMTP port has been set to %s", config["smtp.port"]) log.debug("smtp_return: Subject is '%s'", config["smtp.subject"]) if HAS_GNUPG and config["smtp.gpgowner"]: gpg = gnupg.GPG( gnupghome=os.path.expanduser("~{}/.gnupg".format(config["smtp.gpgowner"])), options=["--trust-model always"], ) encrypted_data = gpg.encrypt(config["smtp.content"], config["smtp.to"]) if encrypted_data.ok: log.debug("smtp_return: Encryption successful") config["smtp.content"] = str(encrypted_data) else: log.error("SMTP: Encryption failed, only an error message will be sent") config[ "smtp.content" ] = "Encryption failed, the return data was not sent.\r\n\r\n{}\r\n{}".format( encrypted_data.status, encrypted_data.stderr ) message = "From: {}\r\nTo: {}\r\nDate: {}\r\nSubject: {}\r\n\r\n{}".format( config["smtp.from"], config["smtp.to"], formatdate(localtime=True), config["smtp.subject"], config["smtp.content"], ) log.debug("smtp_return: Connecting to the server...") server = smtplib.SMTP(config["smtp.host"], int(config["smtp.port"])) if config["smtp.tls"] is True: server.starttls() log.debug("smtp_return: TLS enabled") if config["smtp.username"] and config["smtp.password"]: server.login(config["smtp.username"], config["smtp.password"]) log.debug("smtp_return: Authenticated") server.sendmail(config["smtp.from"], config["smtp.to"], message) log.debug("smtp_return: Message sent.") server.quit()