初めまして、新卒1年目の伊藤です。
今回は、新卒研修にてGoogleによるSSO(シングルサインオン)を持つAzure Static Web Appsのアプリを作成したため、その方法をまとめていきます。
Azure Static Web Appsを構築する
まずは、Webアプリ用のファイルを作成します。今回は、index.htmlとstaticwebapp.config.jsonファイルを作成します。
index.html
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>StaticWebApp_Google</title>
</head>
<body>
<h1>StaticWebApp_GoogleでGoogleログインしました</h1>
</body>
</html>
staticwebapp.config.json
{
"$schema": "https://json.schemastore.org/staticwebapp.config.json",
"auth": {
"identityProviders": {
"google": {
"registration": {
"clientIdSettingName": "GOOGLE_CLIENT_ID",
"clientSecretSettingName": "GOOGLE_PROVIDER_AUTHENTICATION_SECRET"
}
}
}
},
"routes": [
{
"route": "/*",
"allowedRoles": ["authenticated"]
}
],
"responseOverrides": {
"401": {
"statusCode": 302,
"redirect": "/.auth/login/google"
}
}
}
staticwebapp.config.jsonはAzure Static Web Appsの設定ファイルであり、認証プロバイダやWebアプリの権限、リダイレクトなどの設定を行うことができます。詳細は、Microsoftのドキュメントを参考にしてみてください。
https://learn.microsoft.com/ja-jp/azure/static-web-apps/configuration
今回の設定では、auth項目でGoogleのクライアント情報を設定し、routes項目でアプリケーション全体へのアクセスを制限しています。また、responseOverrides項目で401エラー(未認証)の場合はGoogleのログインにリダイレクトさせる設定となっています。
作成したファイルは、GitHubのリポジトリに置いておきます。(staticwebapp_googleとする)
次に、Azure Static Web Appsのリソースを構築します。
data:image/s3,"s3://crabby-images/ec123/ec12351b2a8e2a19f4a7f14712d2c2382049dcf5" alt=""
設定項目は次の通りです。
名前 | staticwebapp-google |
プランの種類 | Standard |
ソース | GitHub |
GitHubリポジトリ | staticwebapp_google |
リソースの情報です。WebアプリのURLはGoogleの認証プロバイダの設定で使用します。以降ではhttps://example.azurestaticapps.netとします。
data:image/s3,"s3://crabby-images/ca3d2/ca3d2bd78df53ddccb3d21237f9adf0355fcc094" alt=""
Googleの認証プロバイダを設定する
Google Cloudコンソールでプロジェクトを新規作成します。
data:image/s3,"s3://crabby-images/3eaba/3eaba90406b16c56c679e47b9d7a6e496a9ad945" alt=""
作成後の画面です。
data:image/s3,"s3://crabby-images/81a7c/81a7c4cec813436b85b82c5da3d746f7d119896c" alt=""
APIとサービスで、OAuth同意画面を作成します。User Typeを内部に設定すると組織内のユーザーのみ使用できるWebアプリを作成することができます。
data:image/s3,"s3://crabby-images/60b6b/60b6be6b77887811d780fca9465865fc5a16f4ba" alt=""
Googleの認証同意画面を設定します。
data:image/s3,"s3://crabby-images/d6adb/d6adb197c890cb326d95a630952a338119e51eb1" alt=""
設定項目は次の通りです。
アプリ名 | staticwebapp google |
ユーザーサポートメール、デベロッパーの連絡先情報 | 設定者のメールアドレス |
アプリケーションのホームページ | https://example.azurestaticapps.net |
承認済みドメイン | example.azurestaticapps.net |
次にスコープを設定します。今回は、userinfo.profileを設定します。
data:image/s3,"s3://crabby-images/67b1a/67b1aeb2f2d70f3c688f62cd5a998bea9bfeac88" alt=""
概要では、設定の確認を行うことができます。
data:image/s3,"s3://crabby-images/23da8/23da89dccb2cb8bc324c0100ceed2e7693820c20" alt=""
同意画面の設定後は、OAuthクライアントIDを選択して認証プロバイダを設定します。
data:image/s3,"s3://crabby-images/cc364/cc364dde9a8e20212501100fe47d6ca1bf2cb49c" alt=""
設定項目は次の通りです。
アプリケーションの種類 | ウェブアプリケーション |
名前 | staticwebapp-google |
承認済みのJavascript生成元 | https://example.azurestaticapps.net |
承認済みのリダイレクト URI | https://example.azurestaticapps.net/.auth/login/google/callback |
設定後はGoogleのクライアント情報が表示されます。
data:image/s3,"s3://crabby-images/71485/71485c1c0e5f7c8befdc75f9ac54b589d878f8c7" alt=""
Azure Static Web Appsのリソースの環境変数で、Googleクライアント情報を設定します。staticwebapp.config.jsonファイルのGOOGLE_CLIENT_ID、GOOGLE_PROVIDER_AUTHENTICATION_SECRETにそれぞれクライアントIDとクライアントシークレットの値を適用します。
data:image/s3,"s3://crabby-images/832f0/832f07d029efa8c2cf226ab4d7d0aa0a4633b99b" alt=""
動作確認
Webアプリにアクセスします。初回はGoogleのログインが求められます。
data:image/s3,"s3://crabby-images/1cfac/1cfac5f647f9029992ced19c516716c284c760d7" alt=""
ログイン時には、同意画面が表示されます。
data:image/s3,"s3://crabby-images/ed176/ed176591b0c82aa3e48df75f50238948d2c09366" alt=""
Webアプリの画面が表示されました。
data:image/s3,"s3://crabby-images/9d395/9d395043f35830c4c526696f4b287924ace1c928" alt=""
組織外のアカウントでログインしようとすると、組織内でのみ利用可能となっていることを確認できます。
data:image/s3,"s3://crabby-images/933a5/933a509b245a86bc023aec9e18e208ad0517ee10" alt=""
まとめ
Azure Static Web Appsを使用することでGoogleによるSSOを持つWebアプリを簡単に作成することができました。
少しでも参考になれば幸いです。
参考
https://learn.microsoft.com/ja-jp/azure/static-web-apps/configuration
https://learn.microsoft.com/ja-jp/azure/app-service/configure-authentication-provider-google
https://developers.google.com/identity/gsi/web/guides/get-google-api-clientid?hl=ja