import logging import time import click from celery import shared_task from flask import current_app from extensions.ext_mail import mail @shared_task(queue='mail') def send_invite_member_mail_task(to: str, token: str, inviter_name: str, workspace_name: str): """ Async Send invite member mail :param to :param token :param inviter_name :param workspace_name Usage: send_invite_member_mail_task.delay(to, token, inviter_name, workspace_name) """ if not mail.is_inited(): return logging.info(click.style('Start send invite member mail to {} in workspace {}'.format(to, workspace_name), fg='green')) start_at = time.perf_counter() try: mail.send( to=to, subject="{} invited you to join {}".format(inviter_name, workspace_name), html="""

Hi there,

{inviter_name} invited you to join {workspace_name}.

Click here to join.

Thanks,

Dify Team

""".format(inviter_name=inviter_name, workspace_name=workspace_name, url=f'{current_app.config.get("CONSOLE_WEB_URL")}/activate?token={token}') ) end_at = time.perf_counter() logging.info( click.style('Send invite member mail to {} succeeded: latency: {}'.format(to, end_at - start_at), fg='green')) except Exception: logging.exception("Send invite member mail to {} failed".format(to))