| import logging |
| import time |
|
|
| import click |
| from celery import shared_task |
| from flask import render_template |
|
|
| from extensions.ext_mail import mail |
|
|
|
|
| @shared_task(queue="mail") |
| def send_email_code_login_mail_task(language: str, to: str, code: str): |
| """ |
| Async Send email code login mail |
| :param language: Language in which the email should be sent (e.g., 'en', 'zh') |
| :param to: Recipient email address |
| :param code: Email code to be included in the email |
| """ |
| if not mail.is_inited(): |
| return |
|
|
| logging.info(click.style("Start email code login mail to {}".format(to), fg="green")) |
| start_at = time.perf_counter() |
|
|
| |
| try: |
| if language == "zh-Hans": |
| html_content = render_template("email_code_login_mail_template_zh-CN.html", to=to, code=code) |
| mail.send(to=to, subject="邮箱验证码", html=html_content) |
| else: |
| html_content = render_template("email_code_login_mail_template_en-US.html", to=to, code=code) |
| mail.send(to=to, subject="Email Code", html=html_content) |
|
|
| end_at = time.perf_counter() |
| logging.info( |
| click.style( |
| "Send email code login mail to {} succeeded: latency: {}".format(to, end_at - start_at), fg="green" |
| ) |
| ) |
| except Exception: |
| logging.exception("Send email code login mail to {} failed".format(to)) |
|
|