LoginSignup
16
12

More than 5 years have passed since last update.

Gitlab と Discord をSlack WebHook互換を使ってサクッと連携させる。

Posted at

はじめに結論

Discord から発行される WebHook URL

/webhooks/{webhook.id}/{webhook.token}

の末尾に /slack をつけ、Slack API として Gitlabに登録する

/webhooks/{webhook.id}/{webhook.token}/slack

はじめに

Discord をチームの連絡ツールに使っているという方もいらっしゃると思います。そして ソースコードは Github ではなく、Gitlab を利用している方もいるでしょう。

そうしていると、Gitlab の Push イベントやビルドイベントの通知を Discord で取得したくなりませんか。

しかしながら悲しいことに、Gitlab から Discord への Webhook はそのままでは対応していません。そこで対応策としてネット検索すると、いかのような記事が出てきます。

GitLabの通知をWebhookでDiscordに送信する
(https://qiita.com/otuhs_d/items/fbb80a0bad8d0921b8e6)

たしかに上記の記事通り設定を頑張れば、Discord へ通知できるようになるですが、わざわざプログラムを書くのも面倒くさい。できれば、マウスポチポチすることで簡単に設定したい。

もう少し簡単な方法はないのかなと調査したら、あったのでお知らせします。

Discord のWebHook について

まずは公式サイトで情報の確認です。以下の URL が Webhook の解説になります。

そこを読むと以下のような記述があります。

Execute Slack-Compatible Webhook

POST /webhooks/{webhook.id}/{webhook.token}/slack

Discord の Webhook は末尾に /slack を付加すると Slack 互換のWebhook になります。Gitlab は Slack へのWebhook は対応しているため、こちらのURLを利用することで Slack Bot として登録できるようになります。

そのことを踏まえて設定していきましょう。

Discord のWebhook設定

「サーバー設定」-「Webhooks」からWebhookの設定をします。

discord_menu.png

Webhookを作成をクリックして、以下のとおりオプション設定をしてください。

discord_webhook.png

チャンネル:メッセージを投稿するチャンネルの選択
名前:メッセージを投稿する際のユーザ名
WEBHOOK ICON:メッセージを投稿する際のユーザのアバターの編集

WEBHOOK URL をコピーしてメモしてください。

Gitlab の Webhook を設定

「設定」-「インテグレーション」から一番下の「Slack notifications」を選択します。

gitlab_integration.png

どの通知を行うかはチェックボックスのオンオフで指定できます。

gitlab_slack_webhook.png

ページ下部の Webhook に Discord から発行された WEBHOOK URL を記入してください。そして末尾に /slack を追加してください。

例えば、Discrod から発行された WEBHOOK URLが以下の場合

https://discordapp.com/api/webhooks/{webhook.id}/{webhook.token}/

以下のように/slackを追加してください。

https://discordapp.com/api/webhooks/{webhook.id}/{webhook.token}/slack

好みでUsernameを指定し、Test settings and save changes をクリックして設定は完了です。

正しく設定されていれば、Discord に通知が飛んでくるはずです。

お疲れ様でした。

おわりに

「Discord は Slack 互換で動作させることができる」というのが今回の記事の肝です。最近のサービスではたいてい Slack は対応しています。おそらく、Slack互換動作のことを知っていれば、ほかの Webhook サービスも簡単に Discord に対応させることが出来ると思います。

開発の助けになればと思い記事にしました。

16
12
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
16
12