👨💻
#17 Google ChatにSlackのリマインダーを転送してみた
はじめに
今回は、Slackに設定したリマインダーをGoogle Chat に転送する方法を紹介します。
Google Chat でいい感じのリマインダーアプリを探していたのですが、時刻を1分単位で指定できなかったり繰り返し設定がしづらかったりと、なかなかSlackのような使い勝手のいいリマインダーが見つからなかったため、いっそSlackのリマインダーを Google Chat に転送することにしました。
なお、本記事の方法にはGoogle Workspaceのご利用が必要です。
構成
Slack → GAS(Google Apps Script) → Google Chat
Slack Events API を使用して Slack 上のイベントを検知し、GAS経由でGoogle Chat に転送します。
今回は、Slack の bot ユーザーが参加したチャンネルでの投稿をすべて転送する設定にしています。
本当は bot ユーザーへのDMに反応するようにしたかったのですが、Slack のリマインダーはbot相手のDMに対しては設定できなかったためこのような設定にしました。
実装
Google Chat, GAS, Slack の順で設定していきます。
Google Chat の Webhook URLを発行
- 転送先にしたいGoogle Chat スペースで、上部の下矢印から、
アプリと統合
を選択
<img alt='' src='アプリと統合.png'> -
Webhook を管理
をクリック (Google Workspace のアカウントでないとボタンが押せません)
<img alt='' src='webhook.png'> - 名前を入力(なんでもOK)、保存をクリック
<img alt='' src='webhook登録.png'> - URLが発行されるのでコピー
<img alt='' src='webhookurl.png'>
GASで転送処理をデプロイ
- GAS で以下のコードをコピペ
function doPost(e) {
const params = JSON.parse(e.postData.getDataAsString());
// 有効性チェック用
if (params.type === "url_verification") {
return ContentService.createTextOutput(params.challenge);
}
// Google Chatに転送
const webhookurl = '{さっきコピーしたGoogle ChatのWebhook URL}';
const data = {
'text': params.event.text
};
const options = {
'method': 'post',
'headers' : {
'Content-Type': 'application/json; charset=UTF-8'
},
'payload': JSON.stringify(data)
};
UrlFetchApp.fetch(webhookurl, options);
}
- Slackからイベントが通知されたとき(POST通信を受け取ったとき)に自動的に「doPost」という関数が呼び出されるため、関数名を変更すると動かなくなります。
- Slackは、イベントが起きた時にまずダミーのリクエストをしてURLが有効かを検証します。有効であることを示すため、リクエスト内のchallengeパラメータを返す必要があります。
- 上部のフロッピーディスクのアイコンをクリックして保存
- 右上の
デプロイ
→新しいデプロイ
を選択 -
種類の選択
→Webアプリ
を選択 -
説明
: 内容を記載(未入力でもOK)、次のユーザーとして実行
: 自分、アクセスできるユーザー
全員 を選択してデプロイクリック
<img alt='' src='deploy.png'> - 完了するとURLが表示されるのでコピー
<img alt='' src='deployurl.png'>
Slack App の作成
- https://api.slack.com/apps を開き、Create New App をクリック
- From scratch を選択
- アプリ名(なんでもいいです)を入力、アプリのインストール先のワークスペースを選択
- すると↓のページが表示されるので、各項目に以下のように設定
<img alt='' src='basicinfo.png'>
- Event Subscriptions
- Enable: ON
- Request URL: さっきコピーしたGASのデプロイURL
- Subscribe to bot events → Add Bot User Event:
message.channels
を選択
<img alt='' src='events.png'>
- Subscribe to bot events → Add Bot User Event:
- App Home
- App Display Name → Edit をクリック
- Display Name: botの表示名。なんでもOK
- Username: botの識別子。なんでもOK
<img alt='' src='apphome.png'>
- Install App → Install to Workspace をクリックして、ワークスペースにAppをインストール
テスト
- Slack のワークスペースにbotユーザーが追加されているので、任意のチャンネルに招待。
- てきとうなメッセージを送信
<img alt='' src='aaaslack.png'> - Google Chat にメッセージが転送されました!
<img alt='' src='aaa.png'> - 続いて、botが参加したチャンネル宛に、1分後のリマインダーを設定
/remind #チャンネル名 テスト in 1 minutes
<img alt='' src='testslack.png'> - 1分待つ
- 狙い通り、Slack上のリマインダーが Google Chat にメッセージが転送されました!
<img alt='' src='test.png'>
さいごに
転送先のスペースの分岐や、関係ないメッセージには反応しないようにする等、改善点はありますがひとまずうまくいってよかったです。
読んでいただきありがとうございます!
Discussion