これはなに?
タイトルのとおりですが、Webhookを使って、Discordのメッセージ・写真をSlackの特定のチャンネルに投稿、SlackのメッセージをDiscordの特定のチャンネルに投稿するBotを作成できるツール?(DiscordのBot(discord.py)とSlackのBot(bolt製))を作りました。
何も考えてないので複数のサーバーとかに対応はできていません。そのため、1つBotを作ったら、1つのSlackワークスペースと1つのDiscordギルドに対応させる感じです(1つのBotで複数対応はできません)。
なぜ作ったの?
DiscordとSlackでコミュニティが分かれてしまっていて、知見が分散してしまうことがあって悲しいので作ってみました。
また、Slackは無料版を使っているのでデータが失われてしまうのことも悲しんでいたことを思い出しました。
設定方法紹介記事
2024/04/20に書いたやつです。そういえば分かりづらいなと思ったので。
注意点
- Discordの写真はURLが分かればアクセスできる系なので、慈悲もなくSlackに投稿しちゃいます
- Discordのアイコン画像やギルド画像も躊躇せずSlackに投稿しちゃいます
- Slackのニックネーム、アイコン画像も取得してなんとなくDiscordに投稿しちゃいます
こんな感じ
Slackに写真付きで「afawefaw」って書くと、DiscordにWebhookで投稿されます。
(四角いアイコンがSlackで、丸いアイコンがDiscord側ですね)
*Slackに投稿されたファイルを問答無用で連携するとダメな例が多いと思うので、ファイルが有ったことだけ書いておくことにしています
Discordにaaaって書くと、SlackにaaaってWebhookで投稿されます。
(上がDiscord、下がSlackです)
動かすための流れ(けっこう面倒くさいです)
Discord
- Discord開発者ポータルでBotを作成
- Discord側のSlackからの投稿チャンネルにWebhookを作成
- Webhook Urlをメモする
- ギルドにBotを追加
Slack
- Slackのアプリ作成画面でAppを作成
- Basic Informationで、App-Level Tokensを作成(Scopeはconnections:write)
- トークンをメモする
- Socket ModeでSocket ModeをEnableにする
- Incoming WebhooksでWebhookを作成、Slack側で許可する
- Webhook Urlをメモする
- OAuth & PermissionsのScopesの項目にいき、Bot Token ScopesでOAuth Scopeを追加する
- channels:history
- chat:write
- incoming-webhook
- users:read
- この画面の上の方にいき、Bot User OAuth Tokenをメモする
- Event Subscriptionsを開き、Subscribe to bot eventsでmessage.channelsを追加する
- Install AppあたりでSlackワークスペースにAppをインストールする(タイミング忘れました、、、)
- Webhookしたいチャンネルを選べと言われ選択を強制されますが、適当でOKです(4.で作った方を使います)
Botを動かす
- poetryをインストール
- start.shに実行権限を与える(chmod 755 start.sh)
- .envを.env.sampleからコピーして編集する(メモっておいたやつらを書く) or 環境変数エディタ的なものに書き込む
- start.shを実行
GitHubのリポジトリ
参考(環境変数の説明)
全部必須なのでイメージ的にはこんなノリです(たくさん必要で大変ですね!)
それぞれの環境変数についての細かい説明はGitHubのリポジトリに載せています。
(動かす流れはこのブログの方が細かいですね)
反省点
- SlackのチャンネルとDiscordのチャンネルを同期する的な説明をして導入したのですが、Discord側だけ複数のチャンネルを連携できる仕様にして動かしたので、Slack側にはいろんなチャンネルの話題が混入してわかりづらい(たくさんできたらうれしいよね的発想はわかりづらさを生むことがわかりました)
- BOT_ID的やつはもしかするとWEBHOOK_URLから取れば素直だったかもしれないと思いました