| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 | 
							- import logging
 
- import time
 
- import click
 
- from celery import shared_task
 
- from flask import current_app
 
- from extensions.ext_mail import mail
 
- @shared_task(queue='mail')
 
- def send_invite_member_mail_task(to: str, token: str, inviter_name: str, workspace_name: str):
 
-     """
 
-     Async Send invite member mail
 
-     :param to
 
-     :param token
 
-     :param inviter_name
 
-     :param workspace_name
 
-     Usage: send_invite_member_mail_task.delay(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()
 
-     try:
 
-         mail.send(
 
-             to=to,
 
-             subject="{} invited you to join {}".format(inviter_name, workspace_name),
 
-             html="""<p>Hi there,</p>
 
- <p>{inviter_name} invited you to join {workspace_name}.</p>
 
- <p>Click <a href="{url}">here</a> to join.</p>
 
- <p>Thanks,</p>
 
- <p>Dify Team</p>""".format(inviter_name=inviter_name, workspace_name=workspace_name,
 
-                            url=f'{current_app.config.get("CONSOLE_WEB_URL")}/activate?token={token}')
 
-         )
 
-         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))
 
 
  |