フリーランスエンジニアのよねざわ(@satosiyonezawa)です。
Node-REDでGoogleカレンダー連携をしている情報があまりなかったので
今回は enebular を使って
Googleカレンダーの予定時間になったら
enebularのフロー(処理)を開始するということをやってみます。
#準備
- enebularの導入はこちら
- Introduction(公式)
- ↑から無料でアカウントを作ってHelloWorldの実行まですぐにできます
- 連携したいカレンダーのGoogleアカウントにログインしてください
#Googleノードをインストール
Googleカレンダーと連携できるノードをインストールします
-
node-red-node-googleノード をインストール
- 右上の adminタブ をクリック
- node-red-node-google と入力
- Installボタン をクリック
data:image/s3,"s3://crabby-images/3924a/3924a21052fee66766900f970c196d5343fbd6f2" alt="スクリーンショット 2019-09-21 16.07.26.png"
- ノードがインストールされました
data:image/s3,"s3://crabby-images/feb5a/feb5ac8f2ad2d09b97abbc0177793a4a9902a240" alt="スクリーンショット 2019-09-21 16.19.53.png"
- カレンダー(input)ノードをドラッグアンドドロップで設置します。
data:image/s3,"s3://crabby-images/7ff9a/7ff9adb33b56b7d0abdd76549fc4995a5d9c53ac" alt="スクリーンショット 2019-09-21 16.41.54.png"
-
以下の3つの項目が出てきました。次の章で詳しく解説します。
- リダイレクトURI
- クライアントID
- シークレットキー
data:image/s3,"s3://crabby-images/434dc/434dc1b115cf7d37b5df8b9f5a6648bc783f8b97" alt="スクリーンショット 2019-09-21 17.00.59.png"
#GCPのプロジェクトを作成
enebularとGoogleカレンダーを連携するために
Google側でリダイレクトURIの設定と
クライアントIDとシークレットキーの発行が必要になります。
- Googleの開発者コンソールにアクセスしましょう
- はじめてGCPを使うアカウントは以下の画面が出てくると思うのでチェックをして 同意して続行 を押します
- 本記事ではAPIの有効化をして認証情報を作成するだけなのでGCPの料金は発生しません。決済情報の入力も必要ありません。
data:image/s3,"s3://crabby-images/2fa4d/2fa4d11406f7f0d3277405c272ec921d93a1131c" alt="スクリーンショット 2019-09-21 17.28.43.png"
- プロジェクトを作成します。上の 組織なし をクリック
data:image/s3,"s3://crabby-images/4f339/4f33909cea51e523314b856473cf547234958f13" alt="スクリーンショット 2019-09-21 18.12.18.png"
- プロジェクトを作成 をクリック
data:image/s3,"s3://crabby-images/1ae9f/1ae9f0b0334f363eb2ab2f93d1ec7e168d30d669" alt="スクリーンショット 2019-09-21 18.12.45.png"
- プロジェクト名に任意の名前を入力
- 任意の場所を指定
- 作成ボタンをクリック
data:image/s3,"s3://crabby-images/7c6c2/7c6c2c7e7adb216b700642c67547b2bae331d991" alt="スクリーンショット 2019-09-21 18.14.04.png"
#Google+とGoogleカレンダーのAPIを有効にする
- ダッシュボードの APIとサービスを有効化 をクリック
data:image/s3,"s3://crabby-images/70a64/70a64c19da678bed6fe91d7588a3cf360e1c9e69" alt="スクリーンショット 2019-09-21 18.15.47.png"
- [google plus]で検索
data:image/s3,"s3://crabby-images/66fbb/66fbb0b1f9186d5515dc45ebf7cca6bb03de8b27" alt="スクリーンショット 2019-09-21 18.16.29.png"
- Google+ API をクリック
data:image/s3,"s3://crabby-images/535c5/535c561563f3df57093731954cb47ee70f4e799a" alt="スクリーンショット 2019-09-21 18.17.51.png"
- 有効にする ボタンをクリック
data:image/s3,"s3://crabby-images/74810/74810b734c89eed29a6e545f46fe5d54b359d42a" alt="スクリーンショット 2019-09-21 18.18.28.png"
- 同様にGoogleカレンダーのAPIを有効にします
data:image/s3,"s3://crabby-images/4cd4b/4cd4bfb60abcb6075e2b09d2c76e9c2668402a67" alt="スクリーンショット 2019-09-21 21.20.40.png"
data:image/s3,"s3://crabby-images/20167/20167101b792b63f492132bea7c028e0d1c2a2b6" alt="スクリーンショット 2019-09-21 21.21.24.png"
#認証情報を作成
- GoogleAPIsのダッシュボードから 認証情報 をクリック
- 認証情報を作成 をクリック
- OAuthクライアントID をクリック
data:image/s3,"s3://crabby-images/dff7d/dff7d8b85d88978627ac69d237655537de3bca95" alt="スクリーンショット 2019-09-21 18.40.01.png"
- enebularからGoogleと連携するときに開く同意画面について設定します
data:image/s3,"s3://crabby-images/819aa/819aa65fe7c53969f2d43401677a54d0103e65b0" alt="スクリーンショット 2019-09-21 18.54.52.png"
data:image/s3,"s3://crabby-images/5a3a6/5a3a6b7c796e9c6ed3817bdad4f89a072fde1652" alt="スクリーンショット 2019-09-21 18.56.40.png"
-
承認済みドメイン にURIのドメインを入力→Enter→保存ボタンをクリック
- カレンダーノードをダブルクリックしたときに表示される赤文字のドメイン
- 入力例:ev2-prod-node-red-XXXXXXXX-XXX.herokuapp.com
data:image/s3,"s3://crabby-images/deab1/deab18ba72d2c285bd8e3b41780116322d31dc65" alt="スクリーンショット 2019-09-21 19.20.27.png"
data:image/s3,"s3://crabby-images/0eb94/0eb942706eabb427dbd435e89399751d79c0604c" alt="スクリーンショット 2019-09-21 19.10.00.png"
- 認証情報を設定します
- アプリケーションの種類
- ウェブアプリケーション
- 名前
- 任意の名前
- 承認済みの JavaScript生成元
- 空欄
- 承認済みのリダイレクト URI
- ノード側の赤文字のURIをコピペ(https://からcallbackまで全て)
- 作成ボタンを押す
- アプリケーションの種類
data:image/s3,"s3://crabby-images/cc023/cc023186d699d20f3c86f20c96dc2a22b4e14701" alt="スクリーンショット 2019-09-21 19.38.58.png"
- 出現したクライアントIDとクライアントシークレットをノード側の認証情報にコピペ
data:image/s3,"s3://crabby-images/71266/71266888a8108bc5a817720e17489df8dccafc3d" alt="スクリーンショット 2019-09-21 19.48.23.png"
data:image/s3,"s3://crabby-images/25898/2589843415c4267e6fff523f67dc5c1418e045af" alt="スクリーンショット 2019-09-21 19.51.08.png"
このアプリは確認されていません という画面が出てきますが以下を実行します。
- 詳細ボタン
- ev2-prod-node-red-XXXXXX-XXX.herokuapp.com(安全ではないページ)に移動
data:image/s3,"s3://crabby-images/53770/53770e88283daa19f00c2ddf336861fe1f6c6e87" alt="スクリーンショット 2019-09-21 19.57.20.png"
- 許可→チェック→許可
Authorised - you can close this window and return to Node-RED と表示されれば連携成功
2020年1月2日追記
現在はここで失敗してしまいます。記事公開時は上記メッセージが出ていたのですが、連携できないとの指摘があり再現しました。
エラーメッセージ「auth worked but profile fetching failed」
GoogleAPI側の問題だと思いますが解決した方は教えていただければ幸いです。
↑2020年9月16日現在、問題無しとの報告いただきました!
data:image/s3,"s3://crabby-images/19fd8/19fd887685f437e03d92a996bb680249b9e357a4" alt="スクリーンショット 2019-09-21 20.44.36.png"
data:image/s3,"s3://crabby-images/99669/9966930e400260e2df19ba3b34edf2396805bfb6" alt="スクリーンショット 2019-09-21 20.45.24.png"
data:image/s3,"s3://crabby-images/fda4a/fda4ae97e7e9f63a17fc3c8730dc260e097e1bbe" alt="スクリーンショット 2019-09-21 20.52.54.png"
- ノード側に戻って追加ボタンをクリック
data:image/s3,"s3://crabby-images/3357f/3357ffccabe6fe82a768b649c1d12a3a1c87fb28" alt="スクリーンショット 2019-09-21 20.56.39.png"
- 画像の設定例ではカレンダーのイベントが始まった時にフローが開始します
data:image/s3,"s3://crabby-images/58db8/58db865ce2d947e4d567d50dc416763fad49b850" alt="スクリーンショット 2019-09-21 20.57.39.png"
- debugノードを設置してカレンダーノードとつないでデプロイボタンをクリック
data:image/s3,"s3://crabby-images/e0c26/e0c2670ac038512644ecfadbd958188ec2c87cb8" alt="スクリーンショット 2019-09-21 21.05.59.png"
#カレンダーを作成して連携確認
- 予定を作成します
data:image/s3,"s3://crabby-images/66512/665129e56f7ac20e25c98a9ebe826b658e2e5f09" alt="スクリーンショット 2019-09-21 21.26.53.png"
- 予定の開始時間が来たらフローが開始します
data:image/s3,"s3://crabby-images/e620e/e620e04fda0114cc3914ec41a903cf49161873ff" alt="スクリーンショット 2019-09-21 21.25.26.png"
- カレンダーの情報も取得しています。詳しくはノードの公式ページを参照
#まとめ
enebularとGoogleカレンダー連携をさせることができました。
enebular側の作業はわずかでGoogle側の設定がほとんどでしたね。
- カレンダーの情報も取得できるのでカレンダードリブンのシステム連携ができそう
- カレンダーAPIの他にもGoogle+APIの許可が必要(ノードの仕様のため?)
- OAuth認証は認証画面を挟んでいる分、設定がちょっとめんどう