mail_invite_member_task.py 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. import logging
  2. import time
  3. import click
  4. from celery import shared_task
  5. from flask import current_app
  6. from extensions.ext_mail import mail
  7. @shared_task(queue='mail')
  8. def send_invite_member_mail_task(to: str, token: str, inviter_name: str, workspace_id: str, workspace_name: str):
  9. """
  10. Async Send invite member mail
  11. :param to
  12. :param token
  13. :param inviter_name
  14. :param workspace_id
  15. :param workspace_name
  16. Usage: send_invite_member_mail_task.delay(to, token, inviter_name, workspace_id, 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. mail.send(
  25. to=to,
  26. subject="{} invited you to join {}".format(inviter_name, workspace_name),
  27. html="""<p>Hi there,</p>
  28. <p>{inviter_name} invited you to join {workspace_name}.</p>
  29. <p>Click <a href="{url}">here</a> to join.</p>
  30. <p>Thanks,</p>
  31. <p>Dify Team</p>""".format(inviter_name=inviter_name, workspace_name=workspace_name,
  32. url='{}/activate?workspace_id={}&email={}&token={}'.format(
  33. current_app.config.get("CONSOLE_WEB_URL"),
  34. workspace_id,
  35. to,
  36. token)
  37. )
  38. )
  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))