Keycloak Gatekeeperとは
Keycloak Gatekeeperは、認可リバースプロシキとして動作するGo言語で実装されたアプリケーションとなります。
元々あったKeycloak Security Proxyが非推奨となり、後継としてKeycloak Gatekeeperが開発されています。
Keycloak Gatekeeperを導入すると、保護対象アプリケーションに手を加える必要無いのが大きなメリットです。
実行環境・構成
WindowsServer2016のローカル環境で構築
Keycloak 6.0.1 localhost:8080
Keycloak gatekeeper localhost:3000
保護対象のサンプルアプリ localhost:5000
ブラウザ:google chrome
data:image/s3,"s3://crabby-images/fb93f/fb93fbafff86c1dfb1865ca9e38f31857a9c8f27" alt=""
Keycloakの概要
Keycloakの概要については、こちらの記事をご確認下さい。
↓
以下、Keycloak Gatekeeperの設定を行います。
Keycloakの設定
Keycloakの設定として、以下1.~6.を行います。
1.レルムを作成する。
2.ユーザーを作成する。(user001,admin001)
3.ロールを作成する。(user,admin)
4.ユーザーにロールを登録する。
5.Keycloak gatekeepwerを登録する。
6.mapperを登録する。(issu対策)
1.レルムを作成する。
Keycloak管理画面左上のドロップダウンとクリックし
add realmをクリック。
レルム:DEMOを作成。
data:image/s3,"s3://crabby-images/d8801/d8801c01aa96112708119662072275f57fdc22b2" alt=""
2.ユーザーを作成する。(user001,admin001)
Keycloak管理画面左のUsersをクリックし、
画面右側のAdd userをクリック。
ユーザー名:user001で作成。
ユーザー作成後、credentialsタブをクリックし、
passowrdを設定、tmporaryをOFFにする。
data:image/s3,"s3://crabby-images/cbd94/cbd94269eb1eaa89529631291ea084a7cb51e6b8" alt=""
user001と同じ手順で、ユーザー名:admin001を作成。
3.ロールを作成する。(user,admin)
Keycloak管理画面左のRolesをクリックし、
右側のAdd Roleをクリック。
ロール名:userを作成。
data:image/s3,"s3://crabby-images/1a484/1a484bbe4e4936437169ac1db5c1e72a2914d9e1" alt=""
同じく、ロール名:adminを作成する。
4.ユーザーにロールを登録する。
Keycloak管理画面左のUsersをクリックし、
ロールに追加したいユーザーを選びます。
Role Mappingsタブをクリック。
追加したいロールをAvailable Rolesから選択し、
Add selectedボタンでロールを追加します。
data:image/s3,"s3://crabby-images/50ecb/50ecb12296ced9a775169202435196d3d8b4c9ec" alt=""
User001→userロールへ、
admin001→adminロールへ追加します。
5.Keycloak Gatekeeperを登録する。
Keycloak管理画面左のclientsをクリックし、
画面右側のcreateボタンをクリック。
以下のように設定します。
Client ID:gatekeeper-api
Client Protocol:openid-connect
Root URL: http://localhost:3000
Access Type:confidential
data:image/s3,"s3://crabby-images/1a28f/1a28f759c36c12ce1d36c35d36fef60330484de6" alt=""
data:image/s3,"s3://crabby-images/b4d64/b4d644d2b0c43da643036644b0622b409072aed3" alt=""
上記設定を保存すると、Credentialsタブが出現します。
Credentialsタブの Secretテキストボックスの文字列をメモします。
(以降のKeycloak Gatekeeper ymlファイル設定で必要。)
data:image/s3,"s3://crabby-images/0bd8c/0bd8c4e740657487dad185ed99311373aaca27a7" alt=""
data:image/s3,"s3://crabby-images/0bb03/0bb0319b1f992cb044d0a385397b2f0210b65413" alt=""
6.mapperを登録する。(issue対策)
Keycloak管理画面左のclientsが選択、gatekeeper-apiを編集状態にします。
次にmapperを追加します。
mappersタブを選択し、画面右側createをクリック。
Mapper Type:Audience
Included Client Audience:gatekeeper-api(先ほど編集したclient)
※keycloak 6.0.1時点でも、公式ドキュメントに記載されており
Gatekeeperを動作させるのに上記mapperの追加が必要でした。
data:image/s3,"s3://crabby-images/9a7e7/9a7e78c835a336bdeaf4dc1c48faf915f01a0646" alt=""
Keycloak Gatekeeperのダウンロード・設定
keycloak Gatekeeperの公式ドキュメントは以下にあります。
2.4. Keycloak Gatekeeper
https://www.keycloak.org/docs/latest/securing_apps/index.html
keycloak Gatekeeperは、以下よりWindows版 (keycloak-gatekeeper-windows-amd64.tar.gz) をダウンロードします。
https://www.keycloak.org/downloads.html
ダウンロードしたファイルは、tar.gz圧縮ファイルですが、
Powershellのtarコマンドで解凍可能です。
コマンド
ps>tar xvf .\keycloak-gatekeeper-windows-amd64.tar.gz
解凍すると、keycloak-gatekeeper.exeが生成されます。
このkeycloak-gatekeeper.exeを任意のフォルダに置きます。
keycloak-gatekeeper.exeファイルを置いたフォルダが、
Keycloak Gatekeeperの実行フォルダとなります。
例:C:\Users\<ユーザー名>\Documents\gatekeeper\keycloak-gatekeeper.exe
Keycloak gatekeeperの設定ファイルとし、以下のymlファイル(gatekeeper.yml)を作成し Keycloak-gatekeeperを置いたフォルダと同階層に配置します。
ファイル名:gatekeeper.yml
discovery-url: http://localhost:8080/auth/realms/demo
client-id: gatekeeper-api
client-secret: a87c8a52-55be-44e3-a6ee-b8d75d6f2888
listen: localhost:3000
enable-refresh-tokens: true
secure-cookie: false
redirection-url: http://localhost:3000
encryption-key: 3lKvZzSmAq8DoMYGPRkVfSQrF27GKCPF
upstream-url: http://localhost:5000
resources:
- uri: /index.html
white-listed: true
- uri: /secure/demo_all_user.html
methods:
- GET
- uri: /secure/user_roll.html
methods:
- GET
roles:
- user
- uri: /secure/admin_roll.html
methods:
- GET
roles:
- admin
# discovery-url:KeycloakのRealmに対するエンドポイント
# client-id:作成したクライアントID
# client-secret:先ほどメモしたGatekeeper client Secret
# listen:Gatekeeperのポート
# secure-cookie … バックエンドがhttpsではない場合、falseにする(デフォルトtrue)
# redirection-url … OAuthのコールバックURLを指定。
# encryption-key … セッションの暗号化キー。
# upstream-url … バックエンドのURL
# 各リソースに対するアクセス設定です。今回は、以下のように設定しました。
# /index.html … 誰でもアクセス可(white-listed: true)
# /secure/demo_all_user.html … demoレルムでログインしていればアクセス可
# /secure/user_roll.html … userロールを持っていればアクセス可
# /secure/admin_roll.html … adminロールを持っていればアクセス可
# *を使用して配下を指定することも可能。 ( 例:/secure/* )
保護対象のサンプルアプリケーション作成
保護対象のサンプルアプリケーションは、node.js上で動作するhtml表示アプリケーションを作成しました。
確認環境
WindowsServer2016、Windows10pro
node.js:v10.16.0
npm:6.9.0
実際に使用したサンプルアプリケーションのnode.js設定ファイル、htmlファイル一式をダウンロード可能です。
↓
https://github.com/git9fukanubsawa/keycloak_gatekeeper_nodejs
使い方は、ダウンロードしたzip圧縮ファイルを任意のフォルダで解凍・設置します。
(C:\Users\<ユーザー名>\Documentsで解凍)
以下のように、【npm start】コマンドを実行。
C:\Users\<ユーザー名>\Documents>cd keycloak_gatekeeper_nodejs
C:\Users\<ユーザー名>\Documents\keycloak_gatekeeper_nodejs>npm start
> keycloak_gatekeeper_nodejs@0.1.0 start C:\Users\Administrator\Documents\keycloak_gatekeeper_nodejs
> node index.js
[Thu Jun 06 2019 16:47:07 GMT+0900 (GMT+09:00)]_localhost:5000_Server running
http://localhost:5000/index.htmlにアクセスすると以下のようなページが表示されます。(リンクをクリックすると画面遷移します。)
data:image/s3,"s3://crabby-images/f189d/f189d6497ac436d9e1ce6f00aefd32338782daa5" alt=""
参考:フォルダ構成
C:\Users\\Documents\keycloak_gatekeeper_nodejs\htmldir\
│ index.html
│
└─secure
admin_roll.html
demo_all_user.html
user_roll.html
Keycloak gatekeeperの動作確認
Keycloak本体が起動している状態で、gatekeeper.ymlをオプションとして渡しkeycloak-Gatekeeperを起動します。
C:\Users\\Documents\gatekeeper>keycloak-gatekeeper.exe --config gatekeeper.yml
data:image/s3,"s3://crabby-images/2a894/2a894f48954165cfa15be6a4021d83630b89d9c8" alt=""
google Cherome ブラウザで、http://localhost:3000/index.htmlを開く。
ページのリンクをクリックすることにより画面遷移します。
動作としては以下の通りです。
data:image/s3,"s3://crabby-images/8c821/8c821846ab2ffacb9b40252123a4d28785d200f8" alt=""
〇:htmlページが表示される。
data:image/s3,"s3://crabby-images/215b5/215b5f8c5bbed6317c614bcba2360db0b090f0d6" alt=""
□:Keycloak Serverログイン画面が表示される。
data:image/s3,"s3://crabby-images/d6924/d69246cda5fa5a9b61e37602ff5899943c07dc7d" alt=""
×:ページが表示されない
data:image/s3,"s3://crabby-images/04659/04659680c2342cf309fb5e5bb9c5867a3a3f9b13" alt=""
×Keycloak Gatekeeper まとめ
・レルム、ユーザー、ロールの作成
・Keycloak Serverの設定
・Keycloak Gatekeeperの設定
案外設定項目も少なく、簡単にプロキシ型認証が設定出来ました。
以下の記事を参考にさせて頂きました。
https://kazuhira-r.hatenablog.com/entry/2019/02/23/194727
https://qiita.com/k2n/items/635e0b08ecac421c56d2