From 9e6b4edee6b939771e46518eb5dce0885afe0010 Mon Sep 17 00:00:00 2001 From: Tim Abbott Date: Wed, 30 May 2018 16:09:32 -0700 Subject: [PATCH] integrations: Remove slack import script. This was migrated to the Zulip server project some time ago. --- zulip/integrations/slack/README.md | 13 -- zulip/integrations/slack/requirements.txt | 1 - zulip/integrations/slack/zulip_slack.py | 127 ------------------ .../integrations/slack/zulip_slack_config.py | 34 ----- 4 files changed, 175 deletions(-) delete mode 100644 zulip/integrations/slack/README.md delete mode 100644 zulip/integrations/slack/requirements.txt delete mode 100755 zulip/integrations/slack/zulip_slack.py delete mode 100644 zulip/integrations/slack/zulip_slack_config.py diff --git a/zulip/integrations/slack/README.md b/zulip/integrations/slack/README.md deleted file mode 100644 index f18fc68..0000000 --- a/zulip/integrations/slack/README.md +++ /dev/null @@ -1,13 +0,0 @@ -# Slack Data Import Tool - -The slack import tool has been shifted to the Zulip server repository. -The data can be converted from slack data format to zulip data format -using the command `./manage.py convert_slack_data`. - -The procedure to use this would be: - -1. `./manage.py convert_slack_data --output `. -2. To import this converted data into a new Zulip instance, use - `./manage.py import --destory-rebuild-database `. -3. To import this converted data into an existing Zulip instance (with multiple realms) - use `./manage.py import --import-into-nonempty `. diff --git a/zulip/integrations/slack/requirements.txt b/zulip/integrations/slack/requirements.txt deleted file mode 100644 index ede4490..0000000 --- a/zulip/integrations/slack/requirements.txt +++ /dev/null @@ -1 +0,0 @@ -slacker>=0.9.60 diff --git a/zulip/integrations/slack/zulip_slack.py b/zulip/integrations/slack/zulip_slack.py deleted file mode 100755 index 6759781..0000000 --- a/zulip/integrations/slack/zulip_slack.py +++ /dev/null @@ -1,127 +0,0 @@ -#!/usr/bin/env python -# -*- coding: utf-8 -*- -# -# -# slacker is a dependency for this script. -# - -from __future__ import absolute_import -from __future__ import print_function - -import sys -import string -import random -from six.moves import range -from typing import List, Dict - -import zulip -from slacker import Slacker, Response, Error as SlackError - -import zulip_slack_config as config - - -client = zulip.Client(email=config.ZULIP_USER, api_key=config.ZULIP_API_KEY, site=config.ZULIP_SITE) - - -class FromSlackImporter(object): - def __init__(self, slack_token, get_archived_channels=True): - # type: (str, bool) -> None - self.slack = Slacker(slack_token) - self.get_archived_channels = get_archived_channels - - self._check_slack_token() - - def get_slack_users_email(self): - # type: () -> Dict[str, Dict[str, str]] - - r = self.slack.users.list() - self._check_if_response_is_successful(r) - results_dict = {} - for user in r.body['members']: - if user['profile'].get('email') and user.get('deleted') is False: - results_dict[user['id']] = {'email': user['profile']['email'], 'name': user['profile']['real_name']} - return results_dict - - def get_slack_public_channels_names(self): - # type: () -> List[Dict[str, str]] - - r = self.slack.channels.list() - self._check_if_response_is_successful(r) - return [{'name': channel['name'], 'members': channel['members']} for channel in r.body['channels']] - - def get_slack_private_channels_names(self): - # type: () -> List[str] - - r = self.slack.groups.list() - self._check_if_response_is_successful(r) - return [ - channel['name'] for channel in r.body['groups'] - if not channel['is_archived'] or self.get_archived_channels - ] - - def _check_slack_token(self): - # type: () -> None - try: - r = self.slack.api.test() - self._check_if_response_is_successful(r) - except SlackError as e: - print(e) - sys.exit(1) - except Exception as e: - print(e) - sys.exit(1) - - def _check_if_response_is_successful(self, response): - # type: (Response) -> None - print(response) - if not response.successful: - print(response.error) - sys.exit(1) - -def _generate_random_password(size=10): - # type: (int) -> str - return ''.join(random.choice(string.ascii_letters + string.digits) for _ in range(size)) - -def get_and_add_users(slack_importer): - # type: (Slacker) -> Dict[str, Dict[str, str]] - users = slack_importer.get_slack_users_email() - added_users = {} - print('######### IMPORTING USERS STARTED #########\n') - for user_id, user in users.items(): - r = client.create_user({ - 'email': user['email'], - 'full_name': user['name'], - 'short_name': user['name'] - }) - if not r.get('msg'): - added_users[user_id] = user - print(u"{} -> {}\nCreated\n".format(user['name'], user['email'])) - else: - print(u"{} -> {}\n{}\n".format(user['name'], user['email'], r.get('msg'))) - print('######### IMPORTING USERS FINISHED #########\n') - return added_users - -def create_streams_and_add_subscribers(slack_importer, added_users): - # type: (Slacker, Dict[str, Dict[str, str]]) -> None - channels_list = slack_importer.get_slack_public_channels_names() - print('######### IMPORTING STREAMS STARTED #########\n') - for stream in channels_list: - subscribed_users = [added_users[member]['email'] for member in stream['members'] if member in added_users.keys()] - if subscribed_users: - r = client.add_subscriptions([{"name": stream['name']}], principals=subscribed_users) - if not r.get('msg'): - print(u"{} -> created\n".format(stream['name'])) - else: - print(u"{} -> {}\n".format(stream['name'], r.get('msg'))) - else: - print(u"{} -> wasn't created\nNo subscribers\n".format(stream['name'])) - print('######### IMPORTING STREAMS FINISHED #########\n') - -def main(): - # type: () -> None - importer = FromSlackImporter(config.SLACK_TOKEN) - added_users = get_and_add_users(importer) - create_streams_and_add_subscribers(importer, added_users) - -if __name__ == '__main__': - main() diff --git a/zulip/integrations/slack/zulip_slack_config.py b/zulip/integrations/slack/zulip_slack_config.py deleted file mode 100644 index dbed3d1..0000000 --- a/zulip/integrations/slack/zulip_slack_config.py +++ /dev/null @@ -1,34 +0,0 @@ -# -*- coding: utf-8 -*- -# -# Copyright © 2014 Zulip, Inc. -# -# Permission is hereby granted, free of charge, to any person obtaining a copy -# of this software and associated documentation files (the "Software"), to deal -# in the Software without restriction, including without limitation the rights -# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -# copies of the Software, and to permit persons to whom the Software is -# furnished to do so, subject to the following conditions: -# -# The above copyright notice and this permission notice shall be included in -# all copies or substantial portions of the Software. -# -# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN -# THE SOFTWARE. - - -### REQUIRED CONFIGURATION ### - -# Change these values to your Slack credentials. -SLACK_TOKEN = 'slack_token' - -# Change these values to the credentials for your Slack bot. -ZULIP_USER = 'user-email@zulip.com' -ZULIP_API_KEY = 'user-email_api_key' - -# Set this to your Zulip API server URI -ZULIP_SITE = 'https://zulip.example.com'