| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 | import loggingimport timeimport clickfrom celery import shared_task  # type: ignorefrom flask import render_templatefrom configs import dify_configfrom extensions.ext_mail import mail@shared_task(queue="mail")def send_invite_member_mail_task(language: str, to: str, token: str, inviter_name: str, workspace_name: str):    """    Async Send invite member mail    :param language    :param to    :param token    :param inviter_name    :param workspace_name    Usage: send_invite_member_mail_task.delay(language, 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()    # send invite member mail using different languages    try:        url = f"{dify_config.CONSOLE_WEB_URL}/activate?token={token}"        if language == "zh-Hans":            html_content = render_template(                "invite_member_mail_template_zh-CN.html",                to=to,                inviter_name=inviter_name,                workspace_name=workspace_name,                url=url,            )            mail.send(to=to, subject="立即加入 Dify 工作空间", html=html_content)        else:            html_content = render_template(                "invite_member_mail_template_en-US.html",                to=to,                inviter_name=inviter_name,                workspace_name=workspace_name,                url=url,            )            mail.send(to=to, subject="Join Dify Workspace Now", html=html_content)        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))
 |