この記事はNTTコムウェア Advent Calendar 2021 2日目の記事です。
NTTコムウェアの掛内です。
普段は、AWSを使ったアジャイル開発のSM兼テックリード兼開発メンバとして、開発を行っています。
POや他の開発メンバと一緒に、一般のお客様に利用して頂くシステムの開発及び価値向上について日々励んでいるところです。
クラウドもツールもプログラミングも大好きなのですが、今回は、少し変わり種を紹介させて頂きたいと思います。
はじめに
突然ですが、みなさんは朝シャキっと起きられますか?
私は、寝起きが悪いということはないのですが、在宅になり、朝のルーティンを一部省略できる様になったため、よくも悪くもダラダラするようになってしまいました。
良い仕事するためには、朝シャキっと起きることはとても重要です。
ということで、今回は朝シャキっと起きる方法を、あえてノーコードで実現する方法を紹介したいと思います。
概要
スマートボタン/IFTTT/スマートカーテンを組み合わせて、カーテンの自動開閉にスヌーズ機能を作っていきます。
カーテンのスヌーズ機能とは?
目覚まし時計にはスヌーズ機能(一定時間後にもう一度鳴らす)というものがあり、お馴染みかと思います。
これをカーテンに応用させて、以下のような機能をカーテンのスヌーズ機能として作ります
- 開きかけのカーテンを閉める
- 一定期間待つ
- カーテンを開ける
きっかけ
- 朝シャキっと起きるためには、起きてすぐに日光を浴びると良いと聞きました
- そこで、朝起きたらまずカーテンを開けることにしているのですが、カーテンまでたどり着くのに眠気が勝ってしまいます
- そのため、時間になったら自動でカーテンを開けてくれるスマートカーテンを買って付けてみました
- それ自体は良かったのですが、あと5分だけ寝たいときにちょっと困ります
- どうしてカーテンにはスヌーズ機能が無いのか。エンジニアなら無いなら作ろう! // 今ここです
対象読者
- カーテンにスヌーズ機能が欲しい方
- スマート家電/おうちハックが好きな方
- IFTTTが好きな方
スタート(前提条件)
実現のためにIoT機器を使うため、下記の製品が必要となります。
今回はノーコードで実現するため、特定のパブリッククラウドやプログラミング言語、IDE/SDKに関する知識は必要ありません。
ゴール(達成できること)
スマートボタンを押すと、スマートカーテンを操作しカーテンの開閉をコントロールする仕組みを、ノーコードで実現できるようになります。
スコープ外(ふれないもの)
各製品やIFTTTのアカウント作成が必要ですが、本稿では触れません。
(難しい操作ではありませんがうまく行かない場合は、公式サイトをご確認ください)
また、製品そのものの詳細には深入りしません。
開発環境/再現環境/バージョンなど
各製品のアプリ及びSaaSにて実現するため開発環境は不要です。
本編(概要)
全体のイメージ
まず、全体像は以下のようになります。
スマートボタンを操作すると、IFTTTを経由してスマートカーテンを操作します。
(ツールの連携をするために、スマートフォンとスマートハブも途中経由します)
スマートフォンの代わりにFlicHubでも代替可能です。 FlicHubを使えばスマートフォンがなくても動作できるようになります。 スマートフォンでペアリングする場合は、スマートボタンとスマートフォンがBluetoothで通信できる必要があります。
スマートボタンとは
スマートボタンは、インターネットに繋がる汎用的で多目的なボタンです。
製品はいくつかありますが、今回はFlicという製品を利用します。
専用アプリがあり、連携先も多くあります。今回はWebHook経由でIFTTTのイベントを呼び出します。
ボタンのイベントは「①ボタンをクリックする」「②ダブルクリックする」「③ホールドする(長押しする)」の3種類があるため、それぞれ設定します。
IFTTTとは
「if this then that」の略で、異なるプラットフォームのWebサービスを連携するSaaSです。
今回はこのサービスを用いて、スマートボタンとスマートカーテンのイベントを紐付けます。
スマートカーテンとは
名前が少し誤解を生みやすいのですが、カーテンそのものではありません。
カーテンレールに設定し、カーテンを引きずることで、カーテンの開閉を行ってくれるIoT機器です。
スマートカーテン1台では、1方向への移動しかできません。 中央から両開きのカーテンの場合は、2台必要となりますので、ご注意ください。
本編(実装)
それでは、いよいよ実装に入っていきます。
最初に記載したとおり、今回はノーコードで実現します。
Step1. ボタンをクリックしたらカーテンを開ける
まずは、一番シンプルにボタンを押したらカーテンを開けるところを作っていきます。
IFTTTのアカウントを作る
https://ifttt.com にアクセスし、IFTTTのアカウントを作成します。
※すでにお持ちの方はこのステップは飛ばしてください。
スマートボタンとスマートフォンのペアリング
- まずは、flicのアプリをダウンロードします
- ボタンをペアリングするために、PHONE > Add Flic to Phoneを選択します
- ボタンを押して、アプリとペアリングさせます
スマートハブ/スマートカーテンの設定
- こちらも、SwitchBotのアプリをダウンロードします
- ホーム画面の右上の「+」からSmartHubMiniとSmartCurtainをペアリングします
- 日本語で案内がありますので、指示に従えば設定を完了できます
- スマートカーテンを選択し、詳細を選択したあとに、設定(アイコン)からクラウドサービスを選択します
- クラウドサービスを有効にし、IFTTTをタップし、IFTTTの画面でログインをします
IFTTTの設定
まず、実現したいことは、Webhookを受け付けたらSwitchbotのカーテンを開く機能を呼び出すことです。
Flicにも専用のサービスがあるのですが、実装を疎結合にするためにWebHookを使ってイベントを作ります
- 自分のWebHookのkeyを確認します
- https://ifttt.com/maker_webhooks のdocumentationを選択し、自分のKeyをメモします
- IFTTTのCreateでアプリを作ります
- 「If This」をクリックし、「Webhooks」を選択し、「Receive a web request」を選択します
- EventNameにわかりやすいイベント名(openなど)を付け、「Create trigger」を押下します
- 「Then That」をクリックし、「SwitchBot」を選択し、「カーテンをコントロール」を選択します
- カーテンを選択し、アクションを選択するで「開く」を選び、「Create action」を押下します
スマートボタンのアプリの設定
ここでは、スマートボタンがクリックされたときに、上記のWebHookを呼び出せるようにします
1. ペアリングしたボタンを選択し、Clickイベントを選択します
2. 「Advanced」から「Internet Request」を選択します
3. メソッドから「GET」を選択し、 URLに下記を設定します
・https://maker.ifttt.com/trigger/{イベント名}/with/key/{key}
5. その他は入力せずに、「SaveACTION」を押下します
動作確認
- ボタンをクリックして、カーテンが開くことを確認します
Step2. ボタンをダブルクリックしたらカーテンを閉める
ほぼ同じなので、省略させていただきます。
Step1との差異は下記のとおりです
・カーテンの操作が、開くではなく閉じる(IFTTTの設定のスマートカーテンの操作)
・イベントの紐付けが、クリックではなくダブルクリックで行う(スマートボタンのアプリの設定)
Step3. ボタンをホールドしたら、スヌーズする
では、最後に一番やりたかったカーテンのスヌーズ機能を作っていきます。
情報整理
まず、流れを確認しておきます。
- 開きかけのカーテンを閉める
- 一定期間待つ(今回は5分)
- カーテンを開ける
開きかけのカーテンを閉めるのは、ボタンをホールドするまでの間にカーテンが開いてしまうので、一旦閉めるためです。
つづいて、今までに作ったものを確認します。
- ボタンをクリックすると、カーテンを開ける
- ボタンをダブルクリックすると、カーテンを閉める
最後に、実現のために必要な残りの機能を確認します。
- 遅延処理を作る
- 複数の処理を連続して呼び出す
Flicアプリにも、遅延のイベントがありますが、Flic2でないと利用ができないため、今回は、IFTTT/WebHook側で実現しています。
情報が整理できたところで、実現するホールドの機能や順番を下記に整理します。
①、②の順番を作る部分と、黄色の遅延用URLを呼ぶという部分が新規になります。
遅延処理を作る
IFTTTで遅延を作る場合は、下記の記事に従って、特定のURLを呼び出すことで実現できます。
具体的には、下記のURLを呼び出します
-
https://lab.grapeot.me/ifttt/delay?event={EVENTNAME}&t={DELAYINMINUTES}&key={WEBHOOKSKEY}
- EVENTNAME:WebHookの作成時に指定したイベント名(openなど)
- DELAYINMINUTES:遅延時間
- WEBHOOKSkey:WebHookのシークレットキー
そのため、今回は、「https://lab.grapeot.me/ifttt/delay?event=open&t=5&key={KEY} 」とすれば、呼び出してから5分後にopenイベントのWebHookを呼び出してくれます。
複数の処理を連続して呼び出す
イベントを複数設定する方法は簡単で、アプリで複数個設定すると順番に実行してくれます。
以下のように、closeのイベントと遅延後にカーテンを開けるWebHookを順番に設定します。
遅延時間は5分としています。t=5の部分をお好きな時間にすることでスヌーズ時間が変わります。 なお、遅延には1.5(1分30秒)のような指定も可能です
動作確認
ボタンを長押しすると、カーテンスヌーズ(カーテンが閉じて5分後に開く)ができました。
補足/備考
今回は一つの具体的な例として、スマートボタンとスマートカーテンを使いましたが、工夫次第で様々な機器を入出力にすることができます
本稿に記載されている情報は、2021年11月時点のもので、各製品やサービスは常に機能追加/変更が行われているため、ご留意ください
記載されている会社名、製品名、サービス名は、各社の商標または登録商標です。