コンテンツにスキップ

JavaScript@Keycloakクライアント

はじめに

本サイトにつきまして、以下をご認識のほど宜しくお願いいたします。


01. Keycloakクライアント

KeycloakクライアントになりうるJavaScriptパッケージにはいくつかある。

ここでは、keycloak-jsパッケージについて記載する。

  • keycloak-js (Keycloak専用)
  • oidc-client
  • oidc-client-ts
  • ...


02. Keycloak

init

ログイン処理を実施する。

初回認証時の場合は、Keycloakに認可リクエストを送信する。

次回認証時は、任意の場所 (例:SessionStorage、LocalStorage、ローカルマシンのCookieディレクトリ) に保管している認証情報をリクエストに設定する。

例えば、トークンをAuthorizationヘッダーで運搬する場合はSessionStorageやLocalStorageから取得し、Cookieヘッダーの場合はローカルマシンのCookieディレクトリから取得する。

import Keycloak from "keycloak-js";

// JavaScriptパッケージを初期化する
const keycloak = new Keycloak({
  url: "http://<Keycloakのドメイン名>",
  realm: "<realm名>",
  clientId: "<クライアントID>",
});

// login-requiredを有効化すると、未認証の場合には認証を開始し、認証済みの場合はログインページをリクエストする
// @see https://www.keycloak.org/docs/23.0.7/securing_apps/#using-the-adapter
keycloak.init({onLoad: "login-required"}).then((auth) => {
  if (!auth) {
    console.log("not Authenticated");
  } else {
    console.log("Authenticated");
    console.log(keycloak);
    // LocalStorageにトークンを設定する
    localStorage.setItem("token", keycloak.token);
  }
});

const authLink = setContext((_, {headers}) => {
  // LocalStorageからトークンを取得する
  const token = localStorage.getItem("token");

  return {
    headers: {
      ...headers,
      // 取得したトークンをリクエストのAuthorizationヘッダーに設定する
      Authorization: token ? `Bearer ${token}` : "",
    },
  };
});


onAuthSuccess

ログイン処理が成功した場合に、事後処理を挿入する。

import Keycloak from "keycloak-js";

const keycloak = new Keycloak({
  url: "http://<Keycloakのドメイン名>",
  realm: "<realm名>",
  clientId: "<クライアントID>",
});

keycloak.onAuthSuccess = () => {
  console.log("ログイン成功");
};


onAuthLogout

ログアウト処理が成功した場合に、事後処理を挿入する。

import Keycloak from "keycloak-js";

const keycloak = new Keycloak({
  url: "http://<Keycloakのドメイン名>",
  realm: "<realm名>",
  clientId: "<クライアントID>",
});

keycloak.onAuthLogout = () => {
  console.log("ログアウト成功!");
};