Skip to content
Snippets Groups Projects
subscribe_mail_lists.py 2.26 KiB
Newer Older
#!/usr/bin/env python
import json
import smtplib
from email.message import EmailMessage
from rc_rmq import RCRMQ
task = "subscribe_mail_list"

# Instantiate rabbitmq object
rc_rmq = RCRMQ({"exchange": "RegUsr", "exchange_type": "topic"})
logger = rc_util.get_logger()  # Define your callback function

def mail_list_subscription(ch, method, properties, body):

    # Retrieve message
    msg = json.loads(body)
    logger.info("Received msg {}".format(msg))
    username = msg["username"]
    fullname = msg["fullname"]
    email = msg["email"]
    mail_list_admin = rcfg.Sender_subscription
    mail_list = rcfg.Mail_list
    mail_list_bcc = rcfg.Mail_list_bcc
    server = rcfg.Mail_server
Bo-Chun Chen's avatar
Bo-Chun Chen committed
    listserv_cmd = (
        f"QUIET ADD hpc-announce {email} {fullname}\n"
        f"QUIET ADD hpc-users {email} {fullname}"
    )
    logger.info("Adding user{} to mail list".format(username))
    msg["success"] = False
    try:
        # Create a text/plain message
        email_msg = EmailMessage()

        email_msg["From"] = mail_list_admin
        email_msg["To"] = mail_list
        email_msg["Subject"] = ""
        email_msg["Bcc"] = mail_list_bcc

        # Create an smtp object and send email
        email_msg.set_content(listserv_cmd)
        if not args.dry_run:
            s.send_message(email_msg)
        logger.info(
            f"This email will add user {username} to listserv \n{email_msg}"
        )
        msg["task"] = task
        msg["success"] = True
    except Exception:
        logger.error("", exc_info=True)

    # Acknowledge message
    ch.basic_ack(delivery_tag=method.delivery_tag)

    # send confirm message
Ravi Tripathi's avatar
Ravi Tripathi committed
    logger.debug("rc_rmq.publish_msg()")
    rc_rmq.publish_msg(
        {"routing_key": "confirm." + msg["queuename"], "msg": msg}
    )
    logger.info("confirmation sent")

logger.info("Start listening to queue: {}".format(task))
rc_rmq.start_consume(
    {
        "queue": task,  # Define your Queue name
        "routing_key": "verify.*",  # Define your routing key
Bo-Chun Chen's avatar
Bo-Chun Chen committed
        "cb": mail_list_subscription,  # Pass callback function you just define