mirror of
https://github.com/zulip/zulip.git
synced 2025-11-10 00:46:03 +00:00
Add a `--dry-run` flag to send_custom_email management command in order to provide a mechanism to verify the emails of the recipients and the text of the email being sent before actually sending them. Add tests to: - Check that no emails are actually sent when we are in the dry-run mode. - Check if the emails are printed correctly when we are in the dry-run mode. Fixes #17767
73 lines
2.7 KiB
Python
73 lines
2.7 KiB
Python
from argparse import ArgumentParser
|
|
from typing import Any
|
|
|
|
from zerver.lib.management import CommandError, ZulipBaseCommand
|
|
from zerver.lib.send_email import send_custom_email
|
|
from zerver.models import UserProfile
|
|
|
|
|
|
class Command(ZulipBaseCommand):
|
|
help = """
|
|
Send a custom email with Zulip branding to the specified users.
|
|
|
|
Useful to send a notice to all users of a realm or server.
|
|
|
|
The From and Subject headers can be provided in the body of the Markdown
|
|
document used to generate the email, or on the command line."""
|
|
|
|
def add_arguments(self, parser: ArgumentParser) -> None:
|
|
parser.add_argument(
|
|
"--entire-server", action="store_true", help="Send to every user on the server."
|
|
)
|
|
parser.add_argument(
|
|
"--markdown-template-path",
|
|
"--path",
|
|
required=True,
|
|
help="Path to a Markdown-format body for the email.",
|
|
)
|
|
parser.add_argument(
|
|
"--subject",
|
|
help="Subject for the email. It can be declared in Markdown file in headers",
|
|
)
|
|
parser.add_argument(
|
|
"--from-name",
|
|
help="From line for the email. It can be declared in Markdown file in headers",
|
|
)
|
|
parser.add_argument("--reply-to", help="Optional reply-to line for the email")
|
|
parser.add_argument(
|
|
"--admins-only", help="Send only to organization administrators", action="store_true"
|
|
)
|
|
parser.add_argument(
|
|
"--dry-run",
|
|
action="store_true",
|
|
help="Prints emails of the recipients and text of the email.",
|
|
)
|
|
|
|
self.add_user_list_args(
|
|
parser,
|
|
help="Email addresses of user(s) to send emails to.",
|
|
all_users_help="Send to every user on the realm.",
|
|
)
|
|
self.add_realm_args(parser)
|
|
|
|
def handle(self, *args: Any, **options: str) -> None:
|
|
if options["entire_server"]:
|
|
users = UserProfile.objects.filter(is_active=True, is_bot=False, is_mirror_dummy=False)
|
|
else:
|
|
realm = self.get_realm(options)
|
|
try:
|
|
users = self.get_users(options, realm, is_bot=False)
|
|
except CommandError as error:
|
|
if str(error) == "You have to pass either -u/--users or -a/--all-users.":
|
|
raise CommandError(
|
|
"You have to pass -u/--users or -a/--all-users or --entire-server."
|
|
)
|
|
raise error
|
|
|
|
send_custom_email(users, options)
|
|
|
|
if options["dry_run"]:
|
|
print("Would send the above email to:")
|
|
for user in users:
|
|
print(f" {user.email}")
|