今回は、Google Apps Script (GAS) でSlackのAPIが簡単に取り扱えるライブラリの紹介です。
ここでは、SlackにインストールしたBotからメッセージを通知するものを作ります。
目次
Slackの設定
Appの作成
Slack API のページを開く
「①Create New App」→「②From scratch」をクリック
data:image/s3,"s3://crabby-images/211fb/211fbb660faf507e20c8bc28340eba356bc652c1" alt=""
「App Name」にはアプリ名(表示名、後で変更可)
その下はAppを導入するワークスペースを選択
data:image/s3,"s3://crabby-images/1e3d4/1e3d48026a6d84064c5218be4596ad47c7525d9b" alt=""
スコープの設定
Basic Infomation (最初の画面) にある「①Add features and functionality」→「②Permissions」をクリック
data:image/s3,"s3://crabby-images/43b37/43b3783cbab8bf5756c19ec23e20082d5d6e5b3a" alt=""
Scopes の項目で「Add an OAuth Scope」をクリック
ここでは、このApp(Bot)がアクセスできる操作を指定する。
※「Bot Token Scopes」と「User Token Scopes」の2つあるが、今回は前者を使用
data:image/s3,"s3://crabby-images/56b1c/56b1ccfba115cfd7460f27aef33a28ba2b3b02e0" alt=""
「chat:write」と「chat:write.public」をクリック
※「chat:write.public」を有効にすると、Botがチャンネルに参加していなくてもメッセージが送信できる。
data:image/s3,"s3://crabby-images/e9b49/e9b49f73a5f6793c08476ca3d9c7d8077d61c59d" alt=""
Botの設定
Basic Infomation (最初の画面) にある「①Add features and functionality」→「③Bots」をクリック
data:image/s3,"s3://crabby-images/43b37/43b3783cbab8bf5756c19ec23e20082d5d6e5b3a" alt=""
Your App’s Presence in Slack の項目にある App Display Name の「Edit」をクリック
data:image/s3,"s3://crabby-images/eadb5/eadb5d1cf3b17d7972bcf47bb0863686bec63d12" alt=""
Display Name:表示されるBot名
Default username:Slackで参照する際に使用される名前
data:image/s3,"s3://crabby-images/d7724/d772498f20d7bb55bd4327dc8ae7b44e7ab56ac4" alt=""
AppをSlackにインストール
Basic Infomation (最初の画面) にある「①Install your app」→「②Install to Workspace」をクリック
data:image/s3,"s3://crabby-images/56d43/56d430abd3a70f1a2e69704d4591df7418112259" alt=""
アプリがSlackにアクセスする権限をリクエストしてくるので、「許可する」をクリック
data:image/s3,"s3://crabby-images/4ef5c/4ef5c71c0002df98b863cb5e0a9aeaf885042500" alt=""
このような画面が出る場合は、Botの設定で Display Name を設定できていない可能性があります。
data:image/s3,"s3://crabby-images/8c779/8c7790993f323aa36c92b092929fa2cf0f1664d8" alt=""
Tokenを確認
Basic Infomation (最初の画面) にある「①Add features and functionality」→「②Permissions」
「Bot User OAuth Token」に記載されているものが Token です。後ほどGASで設定するので、コピーしておく。
data:image/s3,"s3://crabby-images/4cf13/4cf13b4363d4897b1b72214c7d4257f42e3cbf10" alt=""
GASの設定
ライブラリ(SlackApp)の追加
①GASの左側にあるライブラリの”+” をクリック
②以下のスプリクトIDを入力し、「検索」をクリック
1on93YOYfSmV92R5q59NpKmsyWIQD8qnoLYk-gkQBI92C58SPyA2x1-bq
data:image/s3,"s3://crabby-images/1e8c7/1e8c765dfaff170a2d75378c95c8b7e1e6abc407" alt=""
IDの欄に「SlackApp」が表示されたら「追加」をクリック
data:image/s3,"s3://crabby-images/80102/80102681d0f04be2c9e2a0426009466e1a5a95a5" alt=""
Slackに通知するプログラム
「funcion MyFunction()~~」と書かれている部分をすべて消して、以下のプログラムを記述
function sendSlack() {
const slackApp = SlackApp.create("{xoxb-xxxxxx}"); #SlackAppで取得したToken
const channelId = "{Cxxxxxxxx}"; #投稿するchannelID
//or const channelId = "#general";
const text = "Hello World"; #投稿するメッセージ
slackApp.postMessage(channelId, text);
}
- {xoxb-xxxxxx} :SlackApp設定時に取得した Token を入力
- {Cxxxxxxxx} :“C”から始まるチャンネルID もしくは チャンネル名(“#general”)
data:image/s3,"s3://crabby-images/c0efa/c0efa62c429d9b9bbb5b8497a36e69d3a27a6d27" alt=""
「①プロジェクトを保存」→「②実行」をクリック
data:image/s3,"s3://crabby-images/0e6bc/0e6bcdc3593fab3d2b6e41f0742268706d83550b" alt=""
承認が必要な場合
はじめて実行する場合は「承認が必要です」通知が出てくるので、「権限を確認」をクリック
※この後、Googleアカウントを選択する画面が出てくる場合があるので、使用しているアカウントでログイン
data:image/s3,"s3://crabby-images/accc3/accc39fbc0bd29df80b751d9a77723126b7a13a2" alt=""
「このアプリはGoogleで確認されていません」と表示されるので、左下の「詳細」をクリック
※「安全なページに戻る」をクリックすると、先に進めません。
data:image/s3,"s3://crabby-images/40a1c/40a1c79dd20c12708bd534304623d1d3d5fdc6e6" alt=""
左下の「xxx(安全ではないページ)に移動」をクリック
data:image/s3,"s3://crabby-images/e3070/e3070566a3fb701f0e690debbd8d9df9055cfe2c" alt=""
Googleアカウントへのアクセスを許可するか表示されるので、右下の「許可」をクリック
※プログラム(GAS)がGoogle内部のデータにアクセスすることを承認するかの画面です。プログラムに不正なコードが混入している場合には、情報漏えいのリスクがあります。
data:image/s3,"s3://crabby-images/9474a/9474ad98a27fff93485817bd2e4816ded408d166" alt=""
動作確認
GASで以下のように実行ログが出ていればOKです。
エラーが出たら、コピペしたコードに間違いがないか、SlackAppを手順通りに作成したかなど、確認しましょう。
data:image/s3,"s3://crabby-images/20fa4/20fa4cc9b9af005ebb675667425f6f997ab9097d" alt=""
同時にSlackにも通知されます。
data:image/s3,"s3://crabby-images/67361/67361143fdb63d388b133390760946f416b4a184" alt=""