GitHubのメンションをSlackに通知するアプリを作りました。
GitHub App, Slack Appを使って実装しました。
誰でも使うことができます。
サービスページで使い方を詳しく説明しています。
この記事では、使い方と仕組みを書いていこうと思います。
動作
![]()
使い方
- Slack Appをインストールします。
- GitHub Appをインストールします。
- SlackでSlash commandを使い、GitHubアカウントを紐付けます。
- SlackでSlash commandを使い、通知を受け取りたいレポジトリを指定します。
Slack Appをインストールします。
Slack Appをインストールします。
GitHub Appをインストールします。
ここからインストールします。
この時、通知を受け取りたいレポジトリを選択して下さい。
SlackでSlash commandを使い、GitHubアカウントを紐付けます。
Slackで /ghmention と入力します。
SlackでSlash commandを使い、通知を受け取りたいレポジトリを指定します。
Slackで /ghmention subscribe owner/repo と入力します。
登場人物
- GitHub Apps
- Slack Apps
GitHub Apps とは
注意
OAuth Appsとは異なります。
違いを知る
GitHub AppsはOrganizationまたはUserアカウントにインストールされます。
レポジトリ単位にインストールされるものではありません。
GitHub Appはアクセスを許可されたレポジトリでしか動作しません。
つまり、アカウント単位でインストールされ、レポジトリ単位で動作します。
インストール時に最低一つのレポジトリへのアクセスを許可する必要があります。
GitHub Appsはレポジトリに対して様々なことが可能になります。
何が可能になるかは、インストールするGitHub Appsが求める権限によります。
例えばGitHub Appsは, Webhooksを利用してGitHubのイベントを受け取ることができます。
Webhooksには様々なイベントが用意されています。
その中の一つに、issue_comment-created イベントがあります。
このイベントはイシュー(もしくはプルリクエスト)のコメントが作成された時に発火されます。
Webhooksを通じて、GitHub Appsはイシューコメントが作成されたことをリアルタイムで知ることができます。
Slack Apps とは
Slackのワークスペースにインストールされるもの。
Slack Apps はワークスペースに対して様々なことができるようになります。
代表的な例は、Slack Appsがボットのようにメッセージを送信することです。
他には、Slash commandがあります。
Slash commandはSlackアプリで使える便利なオペレーションです。
(Slack アプリで /remind と入力してみてください。)
Slack Appsは独自のSlash commandを提供できます。
仕組み
GitHubでのメンションをSlackに通知する仕組みを説明します。
必要なプロセスは3つです。
- GitHubのユーザーとSlackのユーザーを紐付ける
- Slackユーザーは、メンションを通知してほしいGitHubのレポジトリを登録する
- GitHubでメンションされる
1 GitHubのユーザーとSlackのユーザーを紐付ける
なぜこれが必要か?
GitHubでどの名前がメンションされた時に、あなたに通知を送ればいいかわからないからです。
Slackに通知を送るにはSlackのユーザーIDが必要です。
あなたのSlackのユーザーIDとあなたのGitHubのユーザーIDを、
われわれのサービス上で紐付ける必要があります。
フロー
あなたはSlash commandを使ってGitHubアカウントを紐付ける必要があります。
Slash commandを使うと、あなたのSlackユーザーIDをわれわれは知ることができます。
Slash commandから帰ってきた、GitHubのOAuth URLを開きます。
もしあなたがGitHubへのアクセスを承認すれば、
われわれはあなたのGitHubのユーザーIDを知ることができます。
2 Slackユーザーは、メンションを通知してほしいGitHubのレポジトリを登録する
なぜこれが必要か?
どのGitHubレポジトリの通知を、どのSlackチャンネルへ通知すればいいかわからないからです。
あなたがリード権限のある全てのレポジトリの通知を、Slackのダイレクトメッセージに通知することも可能でしたが、
われわれはそれはあまり役に立たないと判断しました。
あなたは必要なレポジトリの通知を、必要なチャンネルのみに通知できるようコントロールすることができます。
フロー
あなたはSlash commandを使って、通知してほしいGitHubのレポジトリを登録する必要があります。
Slash commandを使ったSlackチャンネルにそのレポジトリの通知が来るようになります。
指定したレポジトリに対して、
1で紐付けたあなたのGitHubアカウントはリード権限を持っている必要があります。
3 GitHubでメンションされる
フロー
GitHubのWebhooksにより、イシューコメントなどのメッセージが作成されたら
われわれのサーバーに通知が来ます。
メッセージからメンションを抽出します。
メッセージが作成されたレポジトリのコラボレーター一覧をわれわれは取得します。
コラボレーターの名前にない、メンションを除外します。
レポジトリとメンションされたGitHubのユーザーIDで、Slackユーザーの登録を確認します。
確認されたSlackユーザーに通知を送ります。




