Rails 7+webpackをCloud Run+Cloud SQL構成で動かす では Ruby on Rails 7 を Cloud Run で実行する方法を説明しました。
この記事では Cloud Run 上で動作する同じ Ruby on Rails アプリケーションを使って IAP で認証する方法を説明します。
この記事で説明するサンプルコードは下記にあります。
Cloud Run に IAP を適用するには、HTTP(S) ロードバランサを作成し、ロードバランサに IAP を適用し、ロードバランサの背後にネットワークエンドポイントグループ(NEG)として Cloud Run サービスを配置します。
下図は サーバーレス ネットワーク エンドポイント グループの概要 から引用した構成図です。
data:image/s3,"s3://crabby-images/17145/17145835cc472968875ba7d230d938f28ed0d6e6" alt="Image in a image block"
Google Cloud コンソールから Cloud Load Balancing を開きロードバランサを作成します。
ロードバランサの種類は「HTTP(S) 負荷分散」を選択します。
data:image/s3,"s3://crabby-images/36f21/36f21d461e946b52c51ec9943931851a18ed99c5" alt="Image in a image block"
data:image/s3,"s3://crabby-images/7b33e/7b33ecfceca5240f6a0a47c6e31267f404ddd978" alt="Image in a image block"
「高度なトラフィック管理」では「従来の HTTP(S) ロードバランサ」を選択します。
もう一方は現時点では IAP に対応していないためです。
data:image/s3,"s3://crabby-images/de029/de0295659e1379a4cd7be41c1835ce9678ba7fc4" alt="Image in a image block"
バックエンドから順に構成していきます。まずはバックエンドサービスを作成します。
data:image/s3,"s3://crabby-images/159f6/159f6587f49ef2041a8f0a889a4a9febfcea55cc" alt="Image in a image block"
名前は rails7-cloudrun-iap-sample-backend
としておきます。
バックエンドタイプは「サーバーレス ネットワーク エンドポイント グループ」を選択します。
data:image/s3,"s3://crabby-images/b777b/b777b6595574295aad7e15ab29686efef2726b02" alt="Image in a image block"
新しいバックエンドとしてサーバーレス NEG を作成します。
data:image/s3,"s3://crabby-images/5d28e/5d28edd5dc257aa32e85739177b13847f5849261" alt="Image in a image block"
rails7-cloudrun-iap-sample-neg
という名前で作成します。
リージョンは Cloud Run サービスと同じ asia-northeast1(東京)
を選びます。
サーバーレス NEG の種類で Cloud Run を選択し、作成したおいた Cloud Run サービスを選択します。
data:image/s3,"s3://crabby-images/a61d7/a61d7167b51e341a567a7f494ca81f85819da2fa" alt="Image in a image block"
バックエンドを作成したら次はフロントエンドを構成します。
名前は rails7-cloudrun-iap-sample-frondend
とします。
プロトコルは「HTTPS (HTTP/2 を含む)」を選択し、証明書を作成します。
data:image/s3,"s3://crabby-images/49e38/49e388a6c9f804fb7e59aa5bdd81493671712e34" alt="Image in a image block"
証明書の名前は rails7-cloudrun-iap-sample-cert
とします。
証明書、ドメインは適宜選択・入力してください。
data:image/s3,"s3://crabby-images/0f049/0f049ac568b1c9ff10c56d95afc68896639d46c4" alt="Image in a image block"
証明書を作成してフロントエンドを構成したら、ロードバランサの名前を rails7-cloudrun-iap-sample-lb
として作成します。
data:image/s3,"s3://crabby-images/e1f45/e1f45bf03bbdff845d2a9606bb4fd69347018cbc" alt="Image in a image block"
ロードバランサを作成したら、証明書作成時に登録したドメインがロードバランサのパブリック IP を指すように DNS レコードを設定します。
「IAM と管理」を開き Identity-Aware Proxy を選択します。
API を有効化した後、最初に OAuth 同意画面を構成する必要があります。
アプリ名、メールアドレスを入力して「保存して次へ」を押して「OAuth 同意画面」を構成したら、次の「スコープ」は入力する必要はありません。IAP の画面へ戻りましょう。
data:image/s3,"s3://crabby-images/87bce/87bce4f6f1baf959f6b2f099d42382123248fafa" alt="Image in a image block"
IAP の画面に戻ると先ほど作成したらバックエンドサービスが表示されているので、IAP のトグルボタンを押して IAP を有効化します。
data:image/s3,"s3://crabby-images/12c29/12c299104b2bfb090bf88969a1e23d269b2110a4" alt="Image in a image block"
IAP を有効にしたバックエンドサービスにチェックを入れ、情報パネルから「プリンシパルを追加」を選びます。
プリンシパルには自分を含むログインを許可したいユーザーの Gmail アドレスを入力します。
ロールは IAP-secured Web App User
を選択します。
data:image/s3,"s3://crabby-images/9c5e2/9c5e24c689348da1db1cc2ba7531dc7159909523" alt="Image in a image block"
ドメインにアクセスしたときに Google アカウントへのログイン画面が表示されれば成功です。
data:image/s3,"s3://crabby-images/23f01/23f016d43fe9fc0919c3f7a2dc8243ead89affa1" alt="Image in a image block"
IAP を迂回して Cloud Run にアクセスできないように Cloud Run のロール/プリンシパルに Cloud Run 起動元/allUsers
がないことを確認しておきましょう。
IAP を経由したリクエストには署名付きヘッダが追加され、認証したユーザーを取得することができます。
署名付きヘッダを検証するために IAP から JWT オーディエンスコードを取得しておきます。
data:image/s3,"s3://crabby-images/408ad/408ad80f0e097c6286584f230fda0546fd88e1e4" alt="Image in a image block"
取得したオーディエンスコードは credentials や環境変数などに設定しておきます。
署名付きヘッダを検証してペイロードからメールアドレスを得るには次のようにします。
require "googleauth"
def iap_user_email
iap_jwt = request.headers["X-Goog-Iap-Jwt-Assertion"]
aud = Rails.application.credentials.production[:iap_jwt_aud]
payload = Google::Auth::IDTokens.verify_iap iap_jwt, aud: aud
payload["email"]
end
サンプルアプリでは画像のようにメールアドレスを表示していますので参考にしてみてください。
data:image/s3,"s3://crabby-images/5e0a8/5e0a83f250cd432d47593fef1f60b79e5fafb1aa" alt="Image in a image block"
署名付きヘッダからユーザーを取得する方法について詳しくは下記のヘルプをご覧ください。
例として使用したサンプルアプリは下記にあります。
以上です。この記事では Cloud Run 上で動作する同じ Ruby on Rails アプリケーションを使って IAP で認証する方法を説明しました。
コメントを送る
コメントはブログオーナーのみ閲覧できます