はじめに
この記事はAuth0を使ってSAML Service ProviderとIdentity Providerの環境を構築する手順です。Auth0はSAML SP/IdPのどちらでも機能することが可能で様々なSAMLのユースケースに対応できます。
検証環境
-
OS :
macOS Catalina 10.15.2
-
node :
10.15.3
-
npm :
6.13.2
手順
IdP側その1
Auth0のダッシュボードから"Create tenant"を選択して新しいIdP用のテナントを作成します。
data:image/s3,"s3://crabby-images/fc198/fc198112fda7fb5a93c101d21ee0c89879879c0e" alt=""
data:image/s3,"s3://crabby-images/2836a/2836a5a9756d37b31571c231db8f05c2c2780e5e" alt=""
左ペインの"Applications"をクリックして右上の"CREATE APPLICATION"を押します。
data:image/s3,"s3://crabby-images/7a205/7a20554211456d12fc864742870b3d59595f44f4" alt=""
"Name"に任意の名前を入力して"Choose an application type"で"Regular Web Applications"を選択して"CREATE"を押します。
data:image/s3,"s3://crabby-images/4c13c/4c13c60764e585beba0b2da04e2fa0c3e418ead1" alt=""
"Settings"タブの下にある"Show Advanced Settings"をクリック、"Endpoints"タブの"SAML Protocol URL"をクリップボードにコピーします。
このURLをSP側に登録します。
data:image/s3,"s3://crabby-images/d6770/d67706a6ac5548255391acfec0b778f2f6a1c46a" alt=""
"Certificates"タブをクリックして”DOWNLOAD CERTIFICATE”を押して公開鍵をダウンロードします。
この公開鍵をSP側に登録します。
data:image/s3,"s3://crabby-images/a9dd2/a9dd218e76daedfd867b1f0c789876c9c8dc3fc7" alt=""
SP側その1
IdP側その1と同じ手順でIdP用のテナントを作成します。詳細な手順は割愛しています。
左ペインの"Connections"->"Enteprise"をクリックして"SAML"の"+"をクリックします。
"Connection name"に任意の名前を入力、"Sign In URL", "Sign Out URL"にIdP側その1でクリップボードにコピーしたURLを入力します。"X509 Signing Certificate"にIdP側その1でダウンロードした公開鍵をアップロード、その他の項目は全てデフォルトで下の"SAVE CHANGES"を押します。
IdP側その2
作成したApplicationをクリックして”Addons”タブから"SAML2 WEB APP"フリップスイッチをオンにします。
data:image/s3,"s3://crabby-images/433ad/433ad6b6104bcf950ffe938f85264043e5486b04" alt=""
"Applicai¥tion Callback URL"にhttps://SPのテナント名.auth0.com/login/callback?connection=SAMLコネクション名
を入力します。
例 : https://pannacotta.auth0.com/login/callback?connection=saml-cookiegaugau
"Settings"に"audience": "urn:auth0:SPのテナント名:SAMLコネクション名"を入力して下の"SAVE CHANGES"を押します。
例 : "audience": "urn:auth0:pannacotta:saml-cookiegaugau"
data:image/s3,"s3://crabby-images/1764f/1764fc220599510b61fa86853dd60974511844be" alt=""
Applicationの登録
左ペインの"Applications"をクリックして右上の"CREATE APPLICATION"を押します。
data:image/s3,"s3://crabby-images/89fbc/89fbca26a493b6a31c1e0221e51c95483ae33b83" alt=""
"Name"に任意の名前を入力、"Choose an application type"で"Simgle Page Web Applications"を選択して”CREATE”を押します。
data:image/s3,"s3://crabby-images/018ed/018ed3cb2c0d39a1fbd9d9f77f74b7867b60aad8" alt=""
"Settings"タブをクリックして"Allowed Callback URLs", "Allowed Web Origins", "Allowed Logout URLs"に"http://localhost:3000
"を入力して画面下の"SAVE CHANGES"を押します。
Auth0で認証が成功した際やApplicationからログアウトした際にコールバックできるURLを指定しています。
data:image/s3,"s3://crabby-images/32832/32832867679f65cff8d1dd06ea50a317c1d16e80" alt=""
ApplicationのGitHubリポジトリをローカルPCにクローンします。
Auth0は65以上の言語やフレームワークに対応したSDK、それらのSDKを利用したサンプルアプリケーションをGitHubに公開しています。一から実装する必要は無いのでそれらを検索して利用して下さい。
$ git clone https://github.com/auth0-samples/auth0-react-samples.git
auth0-react-samples/01-Login/srcに移動します。
$ cd auth0-react-samples/01-Login/src
auth_config.json.exampleをコピーしてauth_config.jsonを作成します。
$ cp auth_config.json.example auth_config.json
auth_copnfig.jsonを編集します。
"clientID"は"Appications"->"作成したApplication"->"Settings"から確認できます。
{
"domain": "kiriko.auth0.com",
"clientId": "xxxx"
}
auth0-react-samples/01-Loginに移動します。
$ cd auth0-react-samples/01-Login
npm installを実行して必要なパッケージをインストールします。
$ npm install
npm startを実行してApplicationを起動します。
$ npm start
Chromeでhttp://localhost:3000
にアクセスして右上の"Log in"を押します。
手順通りに設定していればAuth0 のUniversal Login画面が表示されます。
data:image/s3,"s3://crabby-images/7be6e/7be6e7df1bec449bfcfc19b50469e0cd68b41a77" alt=""
SP側その2
SP側その1で作成したSAML Connectionをクリック、”IdP-initiated SSO”タブをクリックして"Default Application"に登録したApplicationを選択して”SAVE CHANGES”を押します。
SAMLをOIDCに変換してIdP-initiated SSOの中間者攻撃によるリスクを回避しています。
data:image/s3,"s3://crabby-images/ab074/ab074a3856605617697e9d5d9842ec5ef47710d1" alt=""
動作確認
SP側のDashboardからApplicationの登録で作成したApplicationをクリックして"Connections"を選択、作成したSAMLのフリップスイッチをオンにしてその他のConnectionsのフリップスイッチをオフにします。
data:image/s3,"s3://crabby-images/908ea/908ea51f57be91ddbe3847518a672dae8694f557" alt=""
Chromeでhttp://localhost:3000
にアクセスして右上の"Log in"を押します。"Log in at xxxx"ボタンを押してユーザをサインアップします。
data:image/s3,"s3://crabby-images/683bc/683bcb80a00d307f568740918d30caed01bf430a" alt=""
data:image/s3,"s3://crabby-images/a4606/a4606a871eb8122f5b1d25da570a649417879180" alt=""
data:image/s3,"s3://crabby-images/9139d/9139db27a285a55d98d6adbc23c224244fea096f" alt=""
SP側のDashboard左ペインの"Users&Roles"->"Users"に作成したSAMLコネクションでサインアップしたユーザが表示されていれば成功です。
data:image/s3,"s3://crabby-images/adc1b/adc1b0c7a2bc501f061c9104e1aef98a2571bc41" alt=""