mail_invite_member_task.py 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  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_name: str):
  9. """
  10. Async Send invite member mail
  11. :param to
  12. :param token
  13. :param inviter_name
  14. :param workspace_name
  15. Usage: send_invite_member_mail_task.delay(to, token, inviter_name, workspace_name)
  16. """
  17. if not mail.is_inited():
  18. return
  19. logging.info(click.style('Start send invite member mail to {} in workspace {}'.format(to, workspace_name),
  20. fg='green'))
  21. start_at = time.perf_counter()
  22. try:
  23. mail.send(
  24. to=to,
  25. subject="{} invited you to join {}".format(inviter_name, workspace_name),
  26. html="""<p>Hi there,</p>
  27. <p>{inviter_name} invited you to join {workspace_name}.</p>
  28. <p>Click <a href="{url}">here</a> to join.</p>
  29. <p>Thanks,</p>
  30. <p>Dify Team</p>""".format(inviter_name=inviter_name, workspace_name=workspace_name,
  31. url=f'{current_app.config.get("CONSOLE_WEB_URL")}/activate?token={token}')
  32. )
  33. end_at = time.perf_counter()
  34. logging.info(
  35. click.style('Send invite member mail to {} succeeded: latency: {}'.format(to, end_at - start_at),
  36. fg='green'))
  37. except Exception:
  38. logging.exception("Send invite member mail to {} failed".format(to))