こんにちは。ファンリピートの鳴海です。
今回はBubbleでシステムを運用している際に、リストを特定の時間にSlack通知させる実装について、説明していきたいと思います。
またBubbleやSlack APIについての開発や実際に画面を作成していますので、よければご覧ください。
Bubbleとは?
data:image/s3,"s3://crabby-images/f70bf/f70bf7c5d99d70fee56366fc1f3a7aa27d561035" alt=""
URL:https://bubble.io/blog/content/images/2020/09/Logo-with-clearspace.png
Bubble.ioはプログラミング知識があってもなくても、Webアプリが簡単に制作できるサービスとなっており、
誰でも使えるようなサービスとなっております概要としては下記の通りとなっています。
- ノーコードツールの一つである
- レスポンシブに対応している
- 拡張性が高い
ノーコードツールの一つである
data:image/s3,"s3://crabby-images/74b5f/74b5f89ef6f375f932af60f0839ad185bea728df" alt=""
ドラッグ&ドロップという操作で、Webアプリが制作できます
またアプリをインストールする必要がなく、
クラウドプラットフォームというサイト上でアプリケーションを構築できるので、
インターネットがあればいつでもどこでもアクセスができるため、チームで連携してアプリを作れます
レスポンシブに対応している
data:image/s3,"s3://crabby-images/6cf58/6cf58d317e0eb0e000dedad83eb50caac5c88258" alt=""
画面サイズに合わせて、自動調整してくれる機能があります
BubbleではCSS Flexboxと呼ばれるページ要素のレイアウト方法により、
要素自体に0~100%、px単位で設定ができるため、細かいデザインの設計が可能となっています。
拡張性が高い
data:image/s3,"s3://crabby-images/edaa4/edaa4f7864e4accfe2296e485dec1c788ab1cdaf" alt=""
プラグインでは、UI、機能など様々なプラグインをインストールできます。
マップ機能や検索機能などデフォルトでも様々なシステムが搭載されていますが、
プラグインでは画像をスライドショーでの表示、ヘッダーをハンバーガーメニューなどといった機能があります。
今回はSlackで通知するためのAPI connectorというプラグインを活用して、具体的にどのように活用していくか説明していきます。
Slack Web APIの設定
APIを使うことにより、外部からの処理や通知などの自動化ができるものとなります。
Slack Web APIとは?
予定があったタスクや予約の申し込みなどSlackに通知させたい内容を自動送信してくれるようなBotという
設定するためのツールとなっており、下記の通りで可能です。
今回はメッセージの送信の設定方法について説明します。
- メッセージの送信や削除
- チャンネルの作成や削除、編集
- ユーザー情報の取得
- チャンネルメンバーの追加や削除
- ファイルのアップロードやダウンロード
アプリケーションの作成
初めにSlack APIを通知する準備するために下記のサイトで登録します。
Creat new APPを押下します。
data:image/s3,"s3://crabby-images/3f796/3f796de3dc8b476440db66202a32e4f9e4781cda" alt="slackのBot作成"
From scratchを押下します。
選択することによって、どのワークスペースかどの範囲かという設定ができます。
data:image/s3,"s3://crabby-images/e8e8a/e8e8af79981759cad15ea8b4037d092df71e1df0" alt="slackのFrom sractch選択"
次に名前を決めて、どのワークスペースか指定し、Create Appを押します。
data:image/s3,"s3://crabby-images/5743c/5743c9e182937c57c1808570a21db44596a433d8" alt="slackのBotのApp nameとworkspaceの接続先の設定"
Botを使いたいので、Add features and functionalityを押します。
data:image/s3,"s3://crabby-images/4b6ec/4b6ec84bd23678c8e1c9c84a2b5f024333cf8119" alt="slackのAdd freature and functionalityの設定"
Botsを押します。
data:image/s3,"s3://crabby-images/2bf30/2bf3055da241dcdd2d2e278e150be91fefc99abe" alt="slackのbotsを選択"
Botの名前やTokenを発行して、Botsを作成していきます。
data:image/s3,"s3://crabby-images/a91c0/a91c041021efb77b77d2b2c075d0e15c81006c3d" alt="slackのreview scopes to addの選択"
次にBotに権限を与えてあげたいので、calls:readを選択します。
権限についてSlackでドキュメントを公開しているので、詳しくみたい方は下記を参照してください。
data:image/s3,"s3://crabby-images/3432f/3432f5425ca3ac4b9e990fd1478adb6342b2080e" alt=""
data:image/s3,"s3://crabby-images/26c2a/26c2abc9ac3ed16e29cd10fff2f5fc92d197bfdc" alt="slack botのchat:writeの選択"
追加するとSuccess!とでるので、これでScopeの設定はOKです。
data:image/s3,"s3://crabby-images/fbd81/fbd812347f7130e292984981872a5e4e8ca17376" alt="botのchat write選択後の確認"
次にBotに名前を付けたいので、App Homeを押して、Home画面に戻ります。
data:image/s3,"s3://crabby-images/0b1bc/0b1bcd32811549b7c0354e92187fc62be265e012" alt=""
そうすると、Your App’s Presence in SlackというSlackの環境設定が表示されるので、Editを押します。
data:image/s3,"s3://crabby-images/38a74/38a741bd652e14a325f24120d79b697fa31ef5ae" alt="slack botの名前"
ここで通知された時に、名前が表示されるので、わかりやすい名前で設定しましょう。
data:image/s3,"s3://crabby-images/176ec/176ec5361314d330b212a34e7d08c76fa2066509" alt="slackl botの名前の編集画面"
次にワークスペースに設定したBotをインストールしたいので、Install Appを押下します。
data:image/s3,"s3://crabby-images/0ef4f/0ef4f02a621e51b9019131f3b609665b9c95d6b2" alt="install appを押下します。"
Install to appを押します。
data:image/s3,"s3://crabby-images/fd73e/fd73e173d179e86b72f0ca0b16eab1fcdb771f62" alt="作成したbotをworkspaceへインストール画面"
そうすると、許可しますかと求められますので、ここで指定したワークスペースか問題なければ、許可するを押します。
data:image/s3,"s3://crabby-images/4dd9b/4dd9b86efef92ec6d7786593ac9b2558b11a3d6a" alt=""
そうすると、Tokenが発行されますので、誰にも漏れないようにメモしておきます。
このTokenを知られてしまうと、悪用されて、意図しない通知がされてしまう可能性があるので、気を付けましょう。
data:image/s3,"s3://crabby-images/9078c/9078c0019196188c53724203f05bd36a6eea14d9" alt="slack botのトークン発行"
Tokenの次はClient idとCliend secretというBotに通知するときの認証情報が必要となりますので、
Basic Informationを押下します。
data:image/s3,"s3://crabby-images/820b4/820b448be5608be22ca84739ef1093c764e65be8" alt="basic informationから確認"
そうすると表示されるので、こちらもTokenと同様に漏れないようにメモしておきます。
data:image/s3,"s3://crabby-images/5439d/5439de2ef990ea5ef444498371bcfd5fb32e67b1" alt="basic informationからclient idとtokenの発行"
Botを招待
次に作成したボットをワークスペースから招待してあげます。招待したチャンネルを開き、チャンネル名をクリックします。
data:image/s3,"s3://crabby-images/a0afb/a0afb3c2f81fe02775e3348ac4224cd92dcbf0e5" alt=""
インテグレーションに移動すると、Appというのがあるので、アプリを追加するを押下します。
data:image/s3,"s3://crabby-images/d0323/d032307b5017f6715744ea24f0e18ca437472902" alt="アプリを追加するを押下"
次にどのAppを追加するか問われますので、作成したBotで追加します。
data:image/s3,"s3://crabby-images/3e7ec/3e7ec76a2ecb269763c0c779be1d8e03bf3282a8" alt="作成したボットが表示されるので、そちらの追加を押下"
無事にできたら、これでワークスペースにBotが追加されました。
Bubbleでの手順
ワークスペースにBotを追加ができたので、次は通知させるためにBubbleで設定します。
アプリを作成する
初めにこちらのページにアクセスして、Get started for freeからアカウントを作成しましょう。https://bubble.io/
data:image/s3,"s3://crabby-images/6a628/6a62813b8bd91714bdf8a7c31a1b61bad677f6ad" alt=""
メールアドレスやパスワードを打ち込み、Start buidlingをクリックすると画像のようなポップアップが表示されるので、Build→Nextボタン→other→Completeと進めてください。
data:image/s3,"s3://crabby-images/35321/35321303c6c691789f2225d4f1d3915c2a8a82d9" alt=""
そうすると登録したメールアドレスにメールが届くので、そちらをクリックしてあげてください。
data:image/s3,"s3://crabby-images/0afee/0afee16285027162cd8433e5412e38bc5ade59a0" alt="Ok got it!を押下"
リンクをクリックすると、Start buildingのボタンがあるので、クリックしてください。
data:image/s3,"s3://crabby-images/e2bfa/e2bfa982782dbbcd3d646978d7803bb77ba7f94b" alt="メール認証が完了"
トップページのCreate a new appをクリックし、Name your appで名前を決めて、他の項目を入力し、Create appをクリックすると編集画面に飛びます。
data:image/s3,"s3://crabby-images/3cad5/3cad5d3daee178acf5e47cc3ac47de699a78f0a1" alt="アプリ作成時に目的を聞かれるので、適当に入力"
アシスタントというのが左側に表示されるので、Skip application assistantをクリックしてください。これでアプリの登録が完了です。
data:image/s3,"s3://crabby-images/a5b20/a5b207f8ca4650aa6d6b9c01d20120dbec5cfce4" alt="skip application assitantを押下"
必要なプラグインをインストールする
APIでSlack通知させるために、今回はAPI connectorというのを使います。
Search for a plugins…で、API connectorと検索し、installをクリックする。
data:image/s3,"s3://crabby-images/871cf/871cfbb6098dae839e8d28324593bf8c68985d51" alt="PluginsタブからAPI connetorをインストール"
Slack APIが使えるように設定する
Add another APIを押下します。
data:image/s3,"s3://crabby-images/43725/4372513a9c877374a640ef0e65a947ea2f3d07b0" alt="Api connectorでAdd another APIを押下"
どのAPIかわかりやすいように名前を付けてあげて、expandを押して、そちらにも名前を付けてあげます。
data:image/s3,"s3://crabby-images/a7240/a7240a03ca79a4250335f08ab29bc6e50b3296e0" alt="API nameをセット"
次に下記の通りで設定します。
data:image/s3,"s3://crabby-images/d2efc/d2efc557f1c431ce1c4cfd29adae73ad96f4d512" alt="use as Action
Data type Json
Post https;//slack.com/api/chat.postMessageで設定"
Use as Action
Actionに変更することで、Workflow上で使えます。
POST
他にも取得する際のGETや削除や作成などがありますが、今回は送信したいので、POSTを選択します。
https://slack.com/api/chat.postMessage
Slack Web APIの1つで、指定したチャンネルにメッセージを投稿するためのURLとなります。これで送る処理ができます。
他にも色々なSlack Web APIがあるので、みてみてください。
data:image/s3,"s3://crabby-images/ace90/ace9009098c737b5229c779c6e700de2e185fa6a" alt="コピーしたslackのトークンと、content-typeをapplcation/jsonに設定"
次に処理を送る際に認証情報を設定してあげます。こちらを設定してあげないと認証情報がありませんとはじかれますので、下記の通りで設定します。
Headersに追加する。
Authorization
Keyに「Authorization」
valueに「Bearer slackで設定した時のトークン」
Bearer認証となりますので、このような入力となります。
Content-type
Keyに「Content-type」
Valueに「application/json」
Content-typeはHTTPヘッダーの一種で、送信されるコンテンツの種類を示すために使用されます。
application/jsonは、送信するデータがJSON形式であることを示します。
JSONは、Web APIでよく使用されるデータ形式の一つであり、JavaScriptオブジェクトと似た構文を持っています。
HTTPリクエストのボディにJSON形式のデータを含める場合、Content-typeをapplication/jsonに設定して、JSON形式であることを示す必要があります。
data:image/s3,"s3://crabby-images/228e2/228e24b0b118f08be4d37a5208c6e175cc5546b9" alt="body typeとkeyの設定"
Body type JSON
JSON形式で、送り先のチャンネルIDと送る文章などを設定ができます。
Body
{
"channel": "<channel_id>",
"text": "<text>",
}
Keyに「text」、Valueに「こんにちは」
送信できるように「こんにちは」としています。
channel_id、Valueに「チャンネルID」
チャンネルにAppを追加した時のような手順で、チャンネル設定を開き、IDをコピーします。
data:image/s3,"s3://crabby-images/d6318/d63187b7065a264eb3b03eef1269a89a27e014e9" alt="slackのチャンネルからIDをコピー"
入力が終わったら、Initialize callを押してテストします。
Bubbleの方ではtrueと来ていれば成功です。
data:image/s3,"s3://crabby-images/187ba/187bac5bc6256dd9600dd80579b58f8bc23e6244" alt="initialize callでテスト"
Slackの方にも通知が来ています。
data:image/s3,"s3://crabby-images/028af/028af4be96c6e241d80882e3b9b56e1e3ad37825" alt="slackで通知の確認"
データ型を設定する
BubbleのDataタブからテーブルを追加して、テキスト型のカラムを追加し、いくつかデータを入れておこうと思います。
Dataタブを開きます。
data:image/s3,"s3://crabby-images/817b5/817b5af8ebc0b7443fefd2416b000d944f7599b9" alt="Bubbleのデータタブを開く"
Slackという名前で作成します。
data:image/s3,"s3://crabby-images/46177/461770ee46856250ae6775db6a2319c06024ec7f" alt="slackというテーブルを作成"
次にCreate a new fieldでカラムを追加します。
data:image/s3,"s3://crabby-images/9878a/9878a9719bd9c8aac3c34a8cd9ed212b1b282cba" alt="messageというテキストカラムを作成"
入力が終わったら、CREATEボタンを押下します。そうすると、messageが追加されているのが確認できます。
次にデータを入れます。
App dataを押します。
data:image/s3,"s3://crabby-images/45fdc/45fdc370c7354f79d11d971aa262256a64fb1f68" alt="App dataをクリック"
New entryからいくつかデータを追加します。
data:image/s3,"s3://crabby-images/9fa28/9fa289e6c6f96a72ba3fb169190175e56b2ea72f" alt="New entryからデータをセットします。"
今回は「通知1」という形で、5つほど作成します。
data:image/s3,"s3://crabby-images/5aa66/5aa66d25835758767bf0b34f2dfca3f4317077ff" alt="messageに入力し、createを押下"
下記のように追加していれば、OKです。
data:image/s3,"s3://crabby-images/3580a/3580a68ca74d6df4022c8d26d18bdf65f1ebc300" alt=""
画面を作成する
追加したデータを一覧に表示させ、ボタンを押すと即日通知と特定の時間で毎日通知させる方法を説明します。
データを表示する
Designタブで、Repeating groupをドロップします。
data:image/s3,"s3://crabby-images/fc489/fc4896ac68b4e739457cdb79412b2fac127e3bc1" alt="Repeating groupをセット"
データのセット
Type of contentでslackを選択します。
Data sourceに加え、Do a search forで取得します。
data:image/s3,"s3://crabby-images/dbcbd/dbcbda6fd4029aef19bb9ef20367dbc8bcfa3450" alt="repeating groupのdata sourceに do a search forで作成したslackというテーブルでセット"
Typeをslackにし、messageを降順で表示させます。
data:image/s3,"s3://crabby-images/8b037/8b0373cec4259a3d15b5dab08269420a58cda588" alt="sort byをmessage、Descendingを'no'"
次にテキストを表示させたいので、Textエレメントをドロップします。
data:image/s3,"s3://crabby-images/f8c50/f8c50f9d95bd3e07246f043d5b39387a668f5a89" alt="テキストエレメントをRepeating group内にセットします"
…edit me…をクリックして、Current cell’s Slack’s messageを選択します。
data:image/s3,"s3://crabby-images/96813/968133975e92eab6d3e1ab7ea6f524a01c97a618" alt=""
これでひとまずプレビューしてみます。
data:image/s3,"s3://crabby-images/fa92b/fa92b1f951a8eedd6a491ee71dd16b27ef6b1cec" alt="設定が完了したら、previewを押下します。"
ボタンを追加
2つボタンを追加します。
data:image/s3,"s3://crabby-images/29f4d/29f4da2ff71b7d8315b746e1ed2184770f5d0890" alt="Buttonを2つドラッグアンドドロップします。"
名前をA、Bで付けておきます。
data:image/s3,"s3://crabby-images/a7c1e/a7c1ec0a0e1b2e4673ac2065ad589f58fb5c9aaa" alt="ドロップしたエレメントにA、Bで命名してあげます。"
即時通知
Aのボタンを押下したら、通知できるようにしたいので、Aのボタンを選択し、Start/Edit workflowを押します。
data:image/s3,"s3://crabby-images/52cfe/52cfee1d7bbe80129cc8c50abcc1c067815c484d" alt="Aボタンを押下時の処理を設定していきます。"
そうすると自動的にWorkflowのタブに移りますので、PluginからSlack notification – noticationを選択します。
data:image/s3,"s3://crabby-images/f6da8/f6da8a7465860471190f23a3a8c5476d094cb938" alt=""
(body).textで通知する内容をセットできます。
data:image/s3,"s3://crabby-images/cae7c/cae7c08da20dc6301200ced8a6c075d8962fffc7" alt="body.textを空にしてください。"
ここではRepeating groupにセットしているデータを送信したいので、
RepeatingGroup Slack’s List of Slack:each item’s messageを選択します。
data:image/s3,"s3://crabby-images/92c95/92c959e336a558424dfd8842b92f2effc21121cc" alt=""
毎日セットする方法については、Backendの設定が必要となりますので、次のセクションで説明します。
Backendを設定する
Backendでは基本的にAPIでの処理を設定するときに、使われるページで、デフォルトでは表示されていません。
なので、SettingからBackend workflowを使えるようにします。
設定方法
Settingタブを開きます。
data:image/s3,"s3://crabby-images/f77e1/f77e114104f0649ce23bace51ca35c06df1c5dfb" alt="settingタブを開きます。"
APIを押します。
data:image/s3,"s3://crabby-images/30697/30697e9995f8757449ccbbde28c9d04f29dc1887" alt="APIタブを開きます。"
Enable Workflow API and backend workflowsをチェックします。
data:image/s3,"s3://crabby-images/5fbfd/5fbfd0750ce15e3c0fc699c91563d079a4e76bc0" alt="Backend workflowを有効にします。"
ページをクリックすると、Backend workflowが表示されるので、そちらを押します。
Backendの設定
data:image/s3,"s3://crabby-images/7ea49/7ea49123959ca21b042a5e9f24706f70bc71c42e" alt="左上のページからBackendを選択して、押下します。"
New API workflowを押します。
data:image/s3,"s3://crabby-images/4f52d/4f52de67652f41747787d60ccaf8df5a55baa0bf" alt=""
APIの名前をつけます。
data:image/s3,"s3://crabby-images/d4bfe/d4bfe4f97ef578de198a6dca72220bad82b2993d" alt="nameにSlack通知と入れておきます。"
Parameterにテキストを受け取るようにします。
data:image/s3,"s3://crabby-images/0fa56/0fa56af8c1be6cdc08e54473567fa344f9ed484b" alt="parameterの設定で、typeをmessage、typeをtextにします。"
Designタブで行った設定と同じく、Slack Notificationを選択します。
data:image/s3,"s3://crabby-images/e3063/e3063febe06bcca4bad80339f595e74aec41b060" alt="同じ手順で、plugins>slack notificationを選択します。"
(body).textで先ほどパラメータで設定したmessageが表示されますので、そちらをセットします。
data:image/s3,"s3://crabby-images/7985e/7985e5804a7e7f861aafa7121db74c71666583fa" alt="body textにmessagesを選択します。"
次にRecurringというAPI処理で、毎日繰り返すような処理を追加します。
data:image/s3,"s3://crabby-images/721be/721bec5b81e94ed84a072226f410ba38a134af29" alt="次にReccuring eventを追加します。"
Event nameとType of thingをセットします。
data:image/s3,"s3://crabby-images/1ab46/1ab469228ddbe4347cf1f6eef8fc4871a954b58a" alt="Event nameは毎日通知、Type of thingはSlackにします。"
次に先ほどSlack通知のAPI workflowを作成したので、そちらを処理に追加します。
data:image/s3,"s3://crabby-images/72653/72653b4bc5ad3dfae2d671c5179fb3e2b7b520eb" alt="Schedule API workflowをセットします。"
API workflowをslack通知で選択し、Scheduled timeをCurrent date/time、messageにはDo a search forでSlackでのリストを取得し、それぞれmeesageのカラムを出力するようにします。
data:image/s3,"s3://crabby-images/1e16d/1e16ddfd1266eaed3f133af04885b513a23b4bd4" alt="schdule timeとmessageには、
それぞれ下記のように設定してください。
Current date/time、repeating groupと同じdata source"
毎日送られるようにセット
DesignタブでBのボタンを押下した時の設定します。
data:image/s3,"s3://crabby-images/1411e/1411eb981e60ffe92b13735488cff8b2bdf5f2f6" alt="Bボタンを押下時の設定します。"
繰り返すためにrecurring eventを選択します。
data:image/s3,"s3://crabby-images/e9f25/e9f25053d4e2a76403f351cade86f93edf29fa5f" alt="set/cancel a recurring eventを選択します。"
API folder
繰り返し通知するAPIフォルダを選択
Workflow thing
Workflow thingにはDo a search forでSlackのテーブルを選択し、
first itemにします。実際に処理が行われる際にはBackendで設定したリストが通知されます。
Frequency
下記のような間隔で選択できます。今回は毎日通知させたいので、Dailyを選択します。
- Daily(毎日)
- Weekly(一週間ごと)
- Monthly(1か月ごと)
- Quarterly(4半期ごと)
- Yearly(1年ごと)
data:image/s3,"s3://crabby-images/a04be/a04bee14d5c89361bf1337dd76526711b1792835" alt=""
これで設定は完了です。
検証
Aのボタンを押下してみます。Slackで通知されていました。
data:image/s3,"s3://crabby-images/39686/39686550553a8fcf82950ef711f5a24cd8d5e489" alt="Aボタン押下後にslack通知されていることを確認"
Bのボタンを押下してみて、Logsでセットしてあるか確認します。
data:image/s3,"s3://crabby-images/f86f1/f86f1dfc83a389e4f9894b6149144fa5f795a535" alt="Bボタンを押下後にBubble Logs>からセットされていることを確認します。"
通知されるまで待ってみて。しっかりと来てました。
data:image/s3,"s3://crabby-images/3d221/3d221e87153ec41c9472e953f67d8dcaf48959a6" alt=""
通知後もセットしてあるか、Logsでみると、しっかり次の日にセットされていました。
data:image/s3,"s3://crabby-images/07baa/07baa5727dc908dabe0f9748a73a89847b12183c" alt=""
まとめ
リストを特定の時間にSlack通知させる実装について、説明しました。
BubbleではBackendで細かくAPIの設定ができるので、バッチ処理などもできて、便利ですね。
今後も何か他に活用できそうなことがあれば、紹介していきます。