ngrokを使ってみる(OAuth、GitHub、Node-RED)
はじめに
今回はngrokを使ってみました。ローカルで起動しているサーバーを、グローバルに公開することができます。
▼こちらの記事で紹介されていました。
https://qiita.com/mininobu/items/b45dbc70faedf30f484e
https://qiita.com/yama-github/items/94514830ad7759bc3687
前々からローカルで起動しているNode-REDを公開したかったのですが、試してみると簡単にできました。
セキュリティが怖かったので、GitHubのアカウントでログインするようにしました。
▼以前の記事はこちら
ngrokの準備
今回はWindows環境で試しています。
▼ダウンロードはこちらから
▼ZIP形式で実行ファイルをダウンロードしました。
data:image/s3,"s3://crabby-images/51441/514412e7454a9c34492bb03d4c4951d8ef3acd1c" alt=""
ngrokのアカウントを作成して、ログインします。
▼ngrokのページはこちら
ngrok | Unified Application Delivery Platform for Developers
▼ログインすると、Getting Startedなどのページが表示されました。NodeJSもあります。
data:image/s3,"s3://crabby-images/97ba7/97ba79deb7e6f41ad8c59ad6ff2c1d69d6c04fc0" alt=""
▼インストール方法やコマンドが表示されています。authtokenを設定する必要があるので、表示されているコマンドを実行してください。
data:image/s3,"s3://crabby-images/907ed/907eda59c5fcaec759ceb069a213ce40e9a8866b" alt=""
▼他にもGuideがありました。今回はOAuthを導入してみます。
data:image/s3,"s3://crabby-images/0c176/0c17610fd969a248f9862e11584486671d10cc18" alt=""
▼こちらはトラフィックの監視ですね。
data:image/s3,"s3://crabby-images/f3d16/f3d167ed3d42887e5ba59a0e8f823e2bcc9b48de" alt=""
起動してみる
とりあえずコマンドを入力して、起動してみます。
▼以下のコマンドを実行しました。
ngrok http http://localhost:8080
▼Forwadingのところに、公開されているURLが表示されます。
▼アクセスして、Visit Siteを選択しました。
data:image/s3,"s3://crabby-images/a4c85/a4c85e2fbe6b0a4156b5bfc002582be8a4fcb41a" alt=""
▼エラーが表示されました。
data:image/s3,"s3://crabby-images/b2bb8/b2bb87f7bee7e83e7bbfe3501a5f9785ba6ca0e1" alt=""
localhost:8080で何も起動していないので、エラーとして表示されています。次に、ローカルで起動しているサーバーのポートに対して起動してみます。
Node-REDの公開
今回はローカルで起動しているNode-REDのエディタをngrokで公開してみます。
▼Node-REDのポート番号は、デフォルトでは1880です。
data:image/s3,"s3://crabby-images/ab692/ab69202180f5e168e9fae6fbcf63877d502516d2" alt=""
1880ポートをngrokで公開します。
▼以下のコマンドを実行します。
ngrok.exe http 1880
▼この状態で公開されているURLにアクセスすると、Node-REDのエディタ画面が表示されました。
data:image/s3,"s3://crabby-images/f864a/f864afde853fc36fe6ea18d0ad23dd8ff400f4e8" alt=""
▼ダッシュボードも表示されました。
data:image/s3,"s3://crabby-images/49057/49057510e65972ca53754b11e6021da104eb0d0a" alt=""
▼HTTP Requestsも表示されています。
data:image/s3,"s3://crabby-images/2293d/2293defe35d8caaeaef7ccb454a701d38c4852b7" alt=""
OAuthの導入
GitHubの設定
今回はGitHubのアカウントでログインするようにしてみます。
▼OAuthのページはこちら。
https://ngrok.com/docs/http/oauth/?ref=getting-started&cty=agent-cli
▼他にサポートされているプロバイダはこちらに書かれています。GoogleやFacebook、Amazonなどがあるみたいですね。
https://ngrok.com/docs/http/oauth/?ref=getting-started&cty=agent-cli#supported-providers
▼GitHub OAuthのページはこちら。
https://ngrok.com/docs/integrations/github/oauth
まずはGitHubで設定を行います。
▼GitHubのページで、Settingsを選択します。
data:image/s3,"s3://crabby-images/570a8/570a807e7554d0575f56fb4f2ecb1525023b8472" alt=""
下の方にあるDeveloper Settingsを選択し、OAuth Appsを選びます。
▼新しいアプリケーションを登録します。
data:image/s3,"s3://crabby-images/e94b9/e94b962fd148d6d0da6c42f3bc16f49cd0ee4be5" alt=""
▼次のような入力項目が表示されます。
data:image/s3,"s3://crabby-images/741ed/741ed221c9caab0cfd28cb8af1dbbc819e053677" alt=""
Homepage URLは、ngrokで公開されるURLとは別で良いようです。
▼Authorization callbackのURLはこちらで設定します。
https://idp.ngrok.com/oauth2/callback
▼これで登録してみました。
data:image/s3,"s3://crabby-images/b1c24/b1c247e3c9443634181c059d494d4a7952d28644" alt=""
▼登録後、設定画面が表示されます。Client secretsは発行しておいてください。
data:image/s3,"s3://crabby-images/45ff0/45ff07e5d88eb136d2a11e6882fc8bddf8f9e04d" alt=""
▼先程設定したものは後から変更できます。ロゴも設定できるようです。
data:image/s3,"s3://crabby-images/b06ce/b06cef0af4c2f0c6e31f5490e3f487faf8d3b3b2" alt=""
▼以下のコマンドで実行後、URLにアクセスするとGitHubのアカウントでのログインが要求されます。
ngrok.exe http 1880 --oauth github
先程GitHubで発行したClient IDとClient secretsを設定してngrokを起動することもできます。
▼コマンドはこちら
ngrok.exe http 1880 --oauth github --oauth-client-id "<Client ID>" --oauth-client-secret "<Client secrets>"
▼ちなみにClient IDのみで、Client secretsを省くと以下のようなエラーが出ました。両方必要です。
data:image/s3,"s3://crabby-images/df1c6/df1c6bb43e2594cd6303f267931f6dfaa4858f18" alt=""
▼IDやsecretsを設定した場合、間違った値だとログインできません。
data:image/s3,"s3://crabby-images/aae3d/aae3de04feb3345880f29ef853e0486c652b8c39" alt=""
PCでログインしてみる
GitHubのアカウントでのログインを要求する状態で、ngrokを起動しました。
▼URLにアクセスすると、UsernameやPasswordの入力画面が表示されます。
data:image/s3,"s3://crabby-images/6a34d/6a34def4dd4236e06ca1df3052d2c28658b7fb6e" alt=""
▼私の場合、2段階認証を設定していたので入力が必要でした。
data:image/s3,"s3://crabby-images/b55b6/b55b6a9b74a65dc873c1a37aa83f5dd49403c5b3" alt=""
▼ngrokへのAuthorizeが要求されました。
data:image/s3,"s3://crabby-images/bb9c1/bb9c1c1250e7c3d632be8363ba803af89cb8cf69" alt=""
▼その後、Node-REDの画面が表示されました。
data:image/s3,"s3://crabby-images/cc8bf/cc8bf2553c49a73d24b5854d0e3131bc5a727e3c" alt=""
スマートフォンでログインしてみる
スマートフォンでもログインしてみました。
▼GitHubへのログイン画面が表示されました。
data:image/s3,"s3://crabby-images/6d28f/6d28fd92034bdb26e46bf89dfade5392653dd556" alt=""
▼こちらでも2段階認証が必要でした。
data:image/s3,"s3://crabby-images/573c9/573c95aeba6ae565f8ac626ebc6edeb486d801cb" alt=""
▼Node-REDの画面が表示されました。さすがに狭いですね。
data:image/s3,"s3://crabby-images/dc5b6/dc5b69a70c0c8d1a5e78a9c1252304b291b83066" alt=""
▼ダッシュボードの画面も表示されました。こちらは便利に使えそうですね。
data:image/s3,"s3://crabby-images/3658e/3658e65fcdafcfabdd19f525dee7658b43b709c8" alt=""
Trafficを見てみる
ngrokのサービスを監視するため、Trafficを見てみました。
▼Web Inspection Interfaceのページはこちら
https://ngrok.com/docs/agent/web-inspection-interface/?ref=getting-started
ローカルではhttp://localhost:4040にアクセスすると、直近のログを見ることができます。
▼リクエストとその詳細が表示されます。
data:image/s3,"s3://crabby-images/7b6bc/7b6bc6653e22eeb09da6d69153397132c01495f9" alt=""
▼Headersを見ると、GitHubのユーザー名やCookieも表示されています。
data:image/s3,"s3://crabby-images/dac3a/dac3a47beb61345ecedcbcbf4ddff717042a2fce" alt=""
Traffic Inspectorでも見てみました。ngrokのページでサインイン後、Observabilityの欄から表示できます。
▼こちらでもログを確認できます。
data:image/s3,"s3://crabby-images/befe5/befe56e968461aca3421d532b811285586cc34e2" alt=""
ログを選択すると、詳細を表示することができます。
▼デフォルトではFull capture modeになっていないので、全ては表示されていません。
data:image/s3,"s3://crabby-images/26d83/26d83fa10d3a38249c1b45b5dc3ffe60f21088ab" alt=""
ngrokのSettingsにあるAccountのページで、さらに詳細を表示する設定に変更します。
▼ObservabilityをEnabledにします。
data:image/s3,"s3://crabby-images/05127/05127795c336b10026bc1e39f4eb264dcb7b499f" alt=""
これでどのアカウントでログインしたのかが表示されるようになりました。
▼変更が反映されるまでには時間がかかりました。
data:image/s3,"s3://crabby-images/8aa57/8aa57da145c20838092cb26961eec8cbe132ad70" alt=""
最後に
ngrokでローカルで起動していたNode-REDを公開してみましたが、簡単にできてびっくりしています。簡単すぎてセキュリティが怖い...
無料プランだと静的ドメインを1つだけ取得できるようです。それ以外のドメインだと起動ごとにURLが変わってしまうのですが、テスト用にしか使わないので十分かなと思っています。むしろ同じURLを使い回さないので、悪用されにくいかもしれません。
セキュリティの観点だとどこまでも懸念点は出てくるのですが、また詳しく調べてみます。