今回はABLICのPH-Bシリーズを使って、異常検知された際にTeamsに通知が行くよう設定していきたいと思います。
teamsの設定
teamsのメッセージ送信設定は、個人チャットやグループではできず、チーム内でのみ設定できます。
そのため、まずチーム作成をします。
左のタブからチームを選択し、+ボタンでチームを作成を選択します。
data:image/s3,"s3://crabby-images/e1d3d/e1d3db793d14ce0d5bdda03f2aee5766a8c4b814" alt=""
data:image/s3,"s3://crabby-images/71ddf/71ddf1fb2781987814b96f9de54738ea43bc8a91" alt=""
チーム名などは何でも大丈夫です。
data:image/s3,"s3://crabby-images/8f9fc/8f9fc8560e5e3492ab08fc3cb7ac7128cf2bfb13" alt=""
作成しましたら、下図の赤い四角い部分をクリックします。すると、右側にタブが出てきます。
data:image/s3,"s3://crabby-images/a327e/a327e693012c3b1870c722d3e0ad3c22e4d5c0b1" alt=""
出てきたタブのチャンネルを管理をクリックします。一番下にあるコネクタの編集をクリックしてください。
data:image/s3,"s3://crabby-images/630cb/630cb35de3ffb12af6cb46edd1da8d9c48d66650" alt=""
data:image/s3,"s3://crabby-images/cc2b3/cc2b33a639e3ee6e0def119e2e2cab25ad49bccd" alt=""
「自分はこの後のすべての作業で、次のページに進まないことが何度かあり間違ったかと思いましたが、気長に待ったり何度かやり直したらできました。特に何もせずただやり直しただけです。」
すると複数のコネクタが出てきますので、左の検索欄から「incoming」と入れると「Incoming Webhook」が出てきますので、Addをクリック。
data:image/s3,"s3://crabby-images/7020c/7020cfb8a6930ac6be1d07d74e321beb90e87823" alt=""
追加をクリックします。
data:image/s3,"s3://crabby-images/066fb/066fb96ffc290d7e819107fa6339a26adf33a8dc" alt=""
下図のページになりましたら、赤い四角の中に「追加したいチャンネル名」をいれてCreateをクリックします。
data:image/s3,"s3://crabby-images/65d90/65d90dc374b5472a56618d90a790c3270a097a9e" alt=""
すると下にURLが発行されますので、これをコピーしてメモしてください。メモが終わったら、下にあるDoneをクリックします。
data:image/s3,"s3://crabby-images/26f56/26f563a86428f17382fc8c0b09e8325652475585" alt=""
data:image/s3,"s3://crabby-images/c24c5/c24c505762c5743c898adcf20db56a5dfe4e04ea" alt=""
すると元のページに戻ってきますので、Incoming WebhookがConfigureとなっていることを確認し、ページを閉じてください。
data:image/s3,"s3://crabby-images/889ba/889ba72e4550c771a4e413f30a1f0ce018ab1715" alt=""
これでTeamsの設定は完了になります。
OpenBlockの設定
今回はPH-Bの中身を変えていきます。
data:image/s3,"s3://crabby-images/a4460/a4460d752fe3f3626c71c1916fd5de93d48396d9" alt=""
まずは必要な下図の3つのノードを追加していきます。
data:image/s3,"s3://crabby-images/8967d/8967d542354f832b6abe59f3a5a145cb2af49694" alt=""
3つのノードをメール本文1の上に追加し、ノードを接続します。
data:image/s3,"s3://crabby-images/f89a1/f89a10d1003a95300832532fdfe9c23be672fd09" alt=""
次にfunctionノードの中身を開き、下記の内容を書きます。
このfunctionの理由は、webhookではJavaScriptで送るのが基本のためメール本文が使えないためです。
const location = msg.payload.sensor_location;
const data = msg.payload.data_Dec;
const test = {"text": "場所:" +location+ "(センサー番号:" +data+ "番)で漏水を検知しました。"};
msg.payload = test;
data:image/s3,"s3://crabby-images/1db30/1db304f5891587b9d83110e5e00a5ac5a9d8b5b6" alt=""
data:image/s3,"s3://crabby-images/b4cf3/b4cf3df2f83ad456134bb77b96d85874dfa64ce0" alt=""
中身を簡単に説明しますと、設置場所のノードで「msg.payload.sensor_location」、センサー識別のノードで「msg.payload.data_Dec」が決まっていますので、2つをデータとして移し替えtest部分で文字として表示しています。
要するにメールの中身を作っています。
次にhttp requestを開きます。
data:image/s3,"s3://crabby-images/adbbf/adbbf32922532068c530a5a65082bfc01526e1dd" alt=""
この中の、メソッドをGETからPOSTに変更し、URLをTeamsでコピーしたURLにしてください。
data:image/s3,"s3://crabby-images/5653a/5653a2461f5324575024a83620caba7979722cce" alt=""
data:image/s3,"s3://crabby-images/bf5c3/bf5c3d185f09b74cfbbabd91aab9cab3af66d340" alt=""
data:image/s3,"s3://crabby-images/36eca/36ecab47e33837ef5ba1101b2c9ca19315f1561c" alt=""
http requstはこれで完了です。
次にdebugノードを開き、対象をmsgオブジェクト全体に設定します。
data:image/s3,"s3://crabby-images/7c0d2/7c0d23b93960f58c01ef1736fce036b948947ae8" alt=""
data:image/s3,"s3://crabby-images/e5d43/e5d43569b894b3965ef397a8205c7641ed984be4" alt=""
最後にfunctionノードと設置位置のノードを繋げて、右上のデプロイをクリックします。
data:image/s3,"s3://crabby-images/3c588/3c588d5cb5d56ad3e845f42f7e596e28a6955339" alt=""
これで完成になります。
デバックとして、テストメール送信をクリックしていただき、Teamsにメッセージが届いていれば成功です。
data:image/s3,"s3://crabby-images/5712f/5712fe37474b6905ad1aa60416a1fea8ae1108f4" alt=""
data:image/s3,"s3://crabby-images/52838/52838e234ff53ad4a5cf62cf3d8466ecf03ef8bf" alt=""