2022年2月28日にenebularのクラウド実行環境の機能がリリースされました
今までenebularで作成したフローをサービスとして動かすには、HerokuやAWS Lambdaの環境を自前で用意してデプロイする必要があったけど、その必要が無くなった感じです❗
実はAWSとかHerokuとか無料枠を超えてそのうち請求が来るんじゃないかとビクビクしながら使ってましたw
(勝手に請求されることは無いと思いますが)
このクラウド実行環境では、定期的にフローを動作させるか、URLを発行してアクセスするか、2通りの方法でフローをサービスとして動作させることができます。例えば、定期的に情報をチェックして、更新されていたら通知するとか、他のサービスのWebhookを受け先に使うとか、Webページを作ることも可能です。
無料でも以下の条件で利用することができます。
- 1ヶ月のHTTPリクエスト回数が50000回まで
- 1ヶ月の合計実行時間が24時間まで
詳しくはオフィシャルのドキュメント「実行環境とは」を確認して下さい。
ちょっとLINEbotを作ってみたかったので、LINEbotに対して、位置情報を共有するとその場所の花粉量を教えてくれるというものを作ってみました。
次の流れで作ってみたので、手順を紹介します。
クラウド実行環境の準備
enebularのユーザー登録とプロジェクトの作成が済んでいれば、クラウド実行環境を作れます。(enebularのはじめ方ははじめよう、enebular (1)を参照ください)
プロジェクトのダッシュボードのメニューに「実行環境」があるので、そこをクリックします。
実行環境の画面右下の[+]ボタンをクリックします。
実行環境作成のダイアログが表示されるので、名前を入力して「OK」をクリックします。実行環境作成には1~2分ほどかかります。
次にURLの生成を行います。
実行環境の設定を開き、「設定を編集する」をクリックします。
HTTPトリガーの項目で、スイッチをOFFからONにするとパス欄にパスを入力します。
このパスはenebular全体でユニークなものになります。すでに同じパスが存在する場合はエラーになりますので、その場合は異なるパスを入力して下さい。
設定編集画面の右下に「保存」ボタンがあるので、それをクリックします。
以下の場所のコピーボタンをクリックするとURLがクリップボードにコピーされます。
このURLをLINE Messaging APIのWebhook URLに登録します。
(LINE Messaging APIの設定方法は次項参照)
公式LINEとLINE Messaging APIの設定
LINEbotを作るにはまず、LINE公式アカウントを準備する必要があります。
LINE for Businessから「アカウントの開設(無料)」をクリックします。
次のページで、「LINE公式アカウント開設(無料)」をクリックします。
次のページで、「アカウントを作成」をクリックします。次に「メールアドレスで登録」をクリックします。
メールアドレスを入力し、「登録用のリンクを送信」をクリックするとメールが送られてくるので、メール内の「登録画面に進む」をクリックします。
登録画面では、名前とパスワードを入力し、「登録」をクリックします。確認画面が表示されるので、問題なければ次に進み、最後に「サービスに移動」をクリックして下さい。
次の画面で作成するLINE公式アカウントの情報を入力します。個人的に使うものであれば業種は個人にすればOKです。入力後、「確認」をクリックし、問題なければ「完了」をクリックします。LINE公式アカウントの作成が完了したら、「LINE Official Account Managerへ」をクリックします。
最初にLINE Official Account Managerに入ると公式アカウントをLINEの友達に登録するQRコードが表示されるので、このタイミングで自分のLINEに友達登録しておいたほうが便利です。
次にLINE Messaging APIを設定を行うため、画面上部の「応答モード:bot」をクリックします。
応答は、enebularのクラウド実行環境上のアプリから行なうようにするため、「応答メッセージ」はOFF、「Webhook」はONにします。
次にMessaging APIを使用開始するため、左のメニューから「Messaging API」をクリックします。
開発者情報を入力する必要があるため、入力します。
作成されたMessaging APIにアクセスするための「Channel secret」が表示されます。
フローで使用しますので、コピーして控えておきます。
ここで、Webhook URLに控えておいたenebularのクラウド実行環境のURLを入力し、保存をクリックします。
次にチャンネルアクセストークンを発行するため、「https://developers.line.biz/console/ 」にアクセスします。
作成したプロバイダーが表示されているので、それをクリックし、チャンネル設定から作成したチャンネルをクリックします。
次の画面で、最初に作成した公式チャンネルが表示されるので、それをクリックします。
チャンネルアクセストークン(長期)の「発行」ボタンをクリックし、トークンを発行します。
フローで使用しますので、コピーして控えておきます。
これで公式LINEとLINE Messaging APIの設定完了です。
ここで控えたChannel secret
とチャンネルアクセストークン
はフローのLINEノードで使用します。
フローの準備とデプロイ
作ったフローはこんな感じです。ReplyMessage
と書いてあるノードがLINEで応答するノードです。
クラウド実行環境では、LCDP in
ノードから始まります。そして、LCDP out
ノードで終わる必要があります。
LCDP out
ノードに到達しない場合は、毎回設定したタイムアウト時間で実行終了することになり、月の実行時間を使い切ってしまうことになります。
逆にLCDP out
ノードに到達するとすぐにフローが終了してしまうので、時間のかかる処理を行う際は、完了を待つようにして下さい。
上記のフローでは、LINEの返信完了やエラーのキャッチでLCDP out
ノードに行くようにしてあります。
(基本的には意識する必要ないですが、LCDP in
ノードが出力するmsg.uhuru.lcdpNode
オブジェクトをLCDP out
ノードに入れる必要があるので、その点も注意して下さい。)
作成したフローは、以下で公開しています。LCDPノード
と花粉量を取得するPollenノード
も必要になるので、合わせてインポートして下さい。
すべてインポートしたらフローを開き、ReplyMessage
ノードのプロパティを開きます。ここで、控えておいたLINE公式チャンネルのChannel secret
とチャンネルアクセストークン
を入力します。
入力が終わったら、右上の「デプロイ」ボタンをクリックし、保存します。
次にクラウド実行環境に作成したフローをデプロイします。クラウド実行環境の「概要」を開き、「デプロイ」ボタンをクリックします。
インポートしたフローを選択し、「デプロイ」ボタンをクリックします。
以下の画面に移るので、「デプロイ中」から「デプロイ済み」になるまで待ちます。
これで準備は完了です。
動作確認
実際にLINEで位置を送って確認します。
クラウド実行環境は初回起動に若干時間がかかるので、送ってから10秒ぐらい返ってくるのにかかりますが、ちゃんと花粉の量が返ってきました。
今回のフローでは、位置情報が送られてくるのが前提となっているので、文字を送るとエラーになります。
LCDPinノード
とReplyMessageノード
の間に受け取るメッセージに応じたメッセージを返すこともできるので試してみて下さい。