mail_invite_member_task.py 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. import logging
  2. import time
  3. import click
  4. from celery import shared_task
  5. from extensions.ext_mail import mail
  6. from flask import current_app, render_template
  7. @shared_task(queue='mail')
  8. def send_invite_member_mail_task(language: str, to: str, token: str, inviter_name: str, workspace_name: str):
  9. """
  10. Async Send invite member mail
  11. :param language
  12. :param to
  13. :param token
  14. :param inviter_name
  15. :param workspace_name
  16. Usage: send_invite_member_mail_task.delay(langauge, to, token, inviter_name, workspace_name)
  17. """
  18. if not mail.is_inited():
  19. return
  20. logging.info(click.style('Start send invite member mail to {} in workspace {}'.format(to, workspace_name),
  21. fg='green'))
  22. start_at = time.perf_counter()
  23. try:
  24. url = f'{current_app.config.get("CONSOLE_WEB_URL")}/activate?token={token}'
  25. if language == 'zh-CN':
  26. html_content = render_template('invite_member_mail_template_zh-CN.html',
  27. to=to,
  28. inviter_name=inviter_name,
  29. workspace_name=workspace_name,
  30. url=url)
  31. mail.send(to=to, subject="立即加入 Dify 工作空间", html=html_content)
  32. else:
  33. html_content = render_template('invite_member_mail_template_en-US.html',
  34. to=to,
  35. inviter_name=inviter_name,
  36. workspace_name=workspace_name,
  37. url=url)
  38. mail.send(to=to, subject="Join Dify Workspace Now", html=html_content)
  39. end_at = time.perf_counter()
  40. logging.info(
  41. click.style('Send invite member mail to {} succeeded: latency: {}'.format(to, end_at - start_at),
  42. fg='green'))
  43. except Exception:
  44. logging.exception("Send invite member mail to {} failed".format(to))