mirror of https://github.com/zulip/zulip.git
models: Delete legacy convert_bot_to_outgoing_webhook.
We also delete a couple helper functions that were only used there. This management command was primarily used before we had a UI for creating outgoing webhook bots.
This commit is contained in:
parent
9bd535f914
commit
c63b8983a0
|
@ -1,59 +0,0 @@
|
|||
|
||||
from argparse import ArgumentParser
|
||||
from typing import Any
|
||||
|
||||
from zerver.lib.management import ZulipBaseCommand
|
||||
from zerver.models import Service, UserProfile
|
||||
|
||||
class Command(ZulipBaseCommand):
|
||||
help = """Given an existing bot, converts it into an outgoing webhook bot."""
|
||||
|
||||
def add_arguments(self, parser: ArgumentParser) -> None:
|
||||
self.add_realm_args(parser)
|
||||
parser.add_argument('bot_email', metavar='<bot_email>', type=str,
|
||||
help='email of bot')
|
||||
parser.add_argument('service_name', metavar='<service_name>', type=str,
|
||||
help='name of Service object to create')
|
||||
parser.add_argument('base_url', metavar='<base_url>', type=str,
|
||||
help='Endpoint URL of outgoing webhook')
|
||||
# TODO: Add token and interface as arguments once OutgoingWebhookWorker
|
||||
# uses these fields on the Service object.
|
||||
|
||||
def handle(self, *args: Any, **options: str) -> None:
|
||||
|
||||
bot_email = options['bot_email']
|
||||
service_name = options['service_name']
|
||||
base_url = options['base_url']
|
||||
realm = self.get_realm(options)
|
||||
|
||||
if not bot_email:
|
||||
print('Email of existing bot must be provided')
|
||||
exit(1)
|
||||
|
||||
if not service_name:
|
||||
print('Name for Service object must be provided')
|
||||
exit(1)
|
||||
|
||||
if not base_url:
|
||||
print('Endpoint URL of outgoing webhook must be provided')
|
||||
exit(1)
|
||||
|
||||
# TODO: Normalize email?
|
||||
bot_profile = self.get_user(email=bot_email, realm=realm)
|
||||
if not bot_profile.is_bot:
|
||||
print('User %s is not a bot' % (bot_email,))
|
||||
exit(1)
|
||||
if bot_profile.is_outgoing_webhook_bot:
|
||||
print('%s is already marked as an outgoing webhook bot' % (bot_email,))
|
||||
exit(1)
|
||||
|
||||
Service.objects.create(name=service_name,
|
||||
user_profile=bot_profile,
|
||||
base_url=base_url,
|
||||
token='',
|
||||
interface=1)
|
||||
|
||||
bot_profile.bot_type = UserProfile.OUTGOING_WEBHOOK_BOT
|
||||
bot_profile.save()
|
||||
|
||||
print('Successfully converted %s into an outgoing webhook bot' % (bot_email,))
|
|
@ -764,14 +764,6 @@ class UserProfile(AbstractBaseUser, PermissionsMixin):
|
|||
def is_incoming_webhook(self) -> bool:
|
||||
return self.bot_type == UserProfile.INCOMING_WEBHOOK_BOT
|
||||
|
||||
@property
|
||||
def is_outgoing_webhook_bot(self) -> bool:
|
||||
return self.bot_type == UserProfile.OUTGOING_WEBHOOK_BOT
|
||||
|
||||
@property
|
||||
def is_embedded_bot(self) -> bool:
|
||||
return self.bot_type == UserProfile.EMBEDDED_BOT
|
||||
|
||||
@property
|
||||
def allowed_bot_types(self) -> List[int]:
|
||||
allowed_bot_types = []
|
||||
|
|
Loading…
Reference in New Issue