カスタムアクセス トークン スクリプトの作成
カスタムクレームの追加 を アクセス トークン に行うには、それらのクレームを含むオブジェクトを返すスクリプトを用意する必要があります。スクリプトは、カスタムクレームを含むオブジェクトを返す JavaScript 関数として記述します。
-
コンソール > カスタム JWT に移動します。
-
カスタマイズできるアクセス トークンには 2 種類あります:
- ユーザーアクセス トークン:エンドユーザー向けに発行されるアクセス トークン。例:Web アプリケーションやモバイルアプリケーション向け。
- マシン間通信アクセス トークン:サービスやアプリケーション向けに発行されるアクセス トークン。例:マシン間通信アプリケーション 向け。
アクセス トークンの種類によって、トークンペイロードのコンテキストが異なる場合があります。各種類ごとにトークンクレームを個別にカスタマイズできます。
カスタマイズしたいアクセス トークンの種類を選択し、カスタムクレームを追加 ボタンをクリックして新しいスクリプトを作成します。
カスタムトークンクレーム機能は、以下のユーザーのみ利用可能です:
- Logto OSS ユーザー
- Logto Cloud の開発環境テナント
- Logto Cloud の有料テナント(本番環境、Pro テナントや Enterprise テナント を含む)
getCustomJwtClaims() 関数の実装
カスタム JWT 詳細ページで、カスタムトークンクレームスクリプトを記述するスクリプトエディタが利用できます。スクリプトは、カスタムクレームのオブジェクトを返す JavaScript 関数である必要があります。
ステップ 1: スクリプトの編集
左側のコードエディタを使ってスクリプトを編集します。デフォルトで空のオブジェクトを返す getCustomJwtClaims が用意されています。関数を編集して、独自のカスタムクレームのオブジェクトを返すようにできます。
const getCustomJwtClaims = async ({ token, context, environmentVariables }) => {
return {};
};
このエディタは JavaScript 言語サーバーを利用して、基本的な構文ハイライト、コード補完、エラーチェックを提供します。入力パラメータは型定義されており、jsDoc スタイルでドキュメント化されています。エディタの IntelliSense を利用して、入力オブジェクトのプロパティに正しくアクセスできます。詳細なパラメータ定義はページ右側で確認できます。
この関数はモジュールとしてエクスポートされます。関数名は getCustomJwtClaims のままにして、モジュールが正しく関数をエクスポートできるようにしてください。
ステップ 2: 入力パラメータ
getCustomJwtClaims 関数は、オブジェクトを入力パラメータとして受け取ります。入力オブジェクトには次のプロパティが含まれます:
token
トークンペイロードオブジェクト。このオブジェクトには、元のトークンクレームやメタデータが含まれており、スクリプト内で参照できます。
トークンペイロードオブジェクトやユーザーデータオブジェクトの詳細な型定義は、ページ右側で確認できます。エディタの IntelliSense も、入力オブジェクトのプロパティへのアクセスをサポートします。
- ユーザーアクセス トークンデータオブジェクト
プロパティ 説明 型 jti一意の JWT ID stringaudトークンのオーディエンス stringscopeトークンのスコープ stringclientIdトークンのクライアント ID stringaccountIdトークンのユーザー ID stringexpiresWithSessionトークンがセッションとともに失効するかどうか booleangrantIdトークンの現在の認証 (Authentication) グラント ID stringgtyトークンのグラントタイプ stringkindトークンの種類 AccessToken - マシン間通信アクセス トークンデータオブジェクト
プロパティ 説明 型 jti一意の JWT ID stringaudトークンのオーディエンス stringscopeトークンのスコープ stringclientIdトークンのクライアント ID stringkindトークンの種類 ClientCredentials
context(ユーザーアクセス トークンのみ利用可能)
context オブジェクトには、現在の認可 (Authorization) プロセスに関連するユーザーデータやグラントデータが含まれます。
-
ユーザーデータオブジェクト ユーザーアクセス トークンの場合、Logto は追加のユーザーデータコンテキストを提供します。ユーザーデータオブジェクトには、カスタムクレームの設定に必要なすべてのユーザープロファイルデータや組織メンバーシップデータが含まれます。詳細は ユーザー および 組織 を参照してください。
-
組織データオブジェクト 組織アクセス トークン(特定の組織向けにリクエストされたアクセス トークン)の場合、Logto は
context.organizationを通じて対象の組織を提供します。これにより、組織ごとのクレームを付与できます。例えば、Logto の組織 ID を組織のカスタムデータに保存された内部 ID にマッピングするなど。このデータオブジェクトは、トークンが特定の組織向けに発行された場合のみ存在し、以下を含みます:プロパティ 説明 型 id一意の組織 ID stringname組織名 stringdescription組織の説明 string | nullcustomData組織のカスタムデータ Record<string, unknown>詳細は 組織 を参照してください。
-
グラントデータオブジェクト なりすましトークン交換によって付与されたユーザーアクセス トークンの場合、Logto は追加のグラントデータコンテキストを提供します。グラントデータオブジェクトには、サブジェクトトークンからのカスタムコンテキストが含まれます。詳細は ユーザーなりすまし を参照してください。
-
ユーザーインタラクションデータオブジェクト 特定のユーザーアクセス トークンについて、現在の認可 (Authorization) セッションでユーザーのインタラクション詳細にアクセスする必要がある場合があります。例えば、サインインに使用されたエンタープライズ SSO アイデンティティを取得したい場合など。このユーザーインタラクションデータオブジェクトには、最新のユーザー提出インタラクションデータが含まれます:
プロパティ 説明 型 interactionEvent現在のユーザーインタラクションのイベント SignInまたはRegisteruserId現在のユーザーインタラクションのユーザー ID stringverificationRecordsインタラクション中にユーザーが本人確認のために提出した認証記録のリスト VerificationRecord[]認証記録の型:
// VerificationType.Password{id: string;type: 'Password';identifier: {type: 'username' | 'email' | 'phone' | 'userId';value: string;}verified: boolean;}// VerificationType.EmailVerificationCode{id: string;templateType: 'SignIn' | 'Register' | 'ForgotPassword' | 'Generic';verified: boolean;type: 'EmailVerificationCode';identifier: {type: 'email';value: string;}}// VerificationType.PhoneVerificationCode{id: string;templateType: 'SignIn' | 'Register' | 'ForgotPassword' | 'Generic';verified: boolean;type: 'PhoneVerificationCode';identifier: {type: 'phone';value: string;}}// VerificationType.Social{id: string;type: 'Social';connectorId: string;socialUserInfo?: {id: string;email?: string | undefined;phone?: string | undefined;name?: string | undefined;avatar?: string | undefined;rawData?: Record<string, unknown> | undefined;} | undefined;}// VerificationType.EnterpriseSso{id: string;type: 'EnterpriseSso';connectorId: string;enterpriseUserInfo?: {id: string;email?: string | undefined;phone?: string | undefined;name?: string | undefined;avatar?: string | undefined;[key: string]?: unknown;} | undefined;issuer?: string | undefined;}// VerificationType.Totp (MFA){id: string;type: 'Totp';userId: string;verified: boolean;}// VerificationType.WebAuthn (MFA){id: string;type: 'WebAuthn';userId: string;verified: boolean;}// VerificationType.BackupCode (MFA){id: string;type: "BackupCode";userId: string;code?: string | undefined;}// VerificationType.OneTimeToken{id: string;type: "OneTimeToken";verified: boolean;identifier: {type: "email";value: string;};oneTimeTokenContext?: {jitOrganizationIds?: string[] | undefined;} | undefined;}注記:ユーザーインタラクションデータオブジェクトには、複数の認証記録が含まれる場合があります。特に、ユーザーが複数回サインインや登録を行った場合です。
例:ユーザーが
Social認証記録でサインインし、その後EmailVerificationCode認証記録で新しいメールアドレスを紐付け、さらにTotp認証記録で MFA 状態を検証した場合。この場合、スクリプト内で全ての認証記録を適切に処理する必要があります。各認証記録の種類は、ユーザーインタラクションデータオブジェクト内に一度だけ存在します。
environmentVariables
右側の 環境変数の設定 セクションで、スクリプト用の環境変数を設定できます。これらの変数は、スクリプト内でハードコーディングしたくない機密情報や設定データ(例:API キー、シークレット、URL など)を保存するのに利用できます。
ここで設定したすべての環境変数はスクリプト内で利用可能です。入力パラメータの environmentVariables オブジェクトを使ってアクセスしてください。
api
api オブジェクトは、トークン発行プロセスに対して追加のアクセス制御を行うためのユーティリティ関数を提供します。api オブジェクトには次の関数が含まれます:
api.denyAccess(message?: string): void
api.denyAccess() 関数は、カスタムメッセージ付きでトークン発行プロセスを拒否できます。トークン発行プロセスに対して追加のアクセス検証を強制したい場合に利用できます。
ステップ 3: 外部データの取得
スクリプト内で node 組み込みの fetch 関数を使って外部データを取得できます。fetch 関数は Promise ベースで、外部 API への HTTP リクエストを行えます。
const getCustomJwtClaims = async ({ environmentVariables }) => {
const response = await fetch('https://api.example.com/data', {
headers: {
Authorization: `Bearer ${environmentVariables.API_KEY}`,
},
});
const data = await response.json();
return {
data,
};
};
外部データの取得は、トークン発行プロセスに遅延をもたらす可能性があるため注意してください。外部 API が十分に信頼でき、かつ高速であることを確認してください。
さらに:
- スクリプト内でエラーやタイムアウトを適切に処理し、トークン発行プロセスがブロックされないようにしてください。
- 適切な認可ヘッダーを使用して、外部 API への不正アクセスを防止してください。
ステップ 4: スクリプトのテスト
スクリプトを保存する前に必ずテストしてください。ページ右側の テストコンテキスト タブをクリックして、テスト用のモックトークンペイロードやユーザーデータコンテキストを編集できます。
エディタ右上の テスト実行 をクリックすると、モックデータでスクリプトを実行できます。スクリプトの出力は テスト結果 ドロワーに表示されます。
テスト結果は、設定したモックデータで getCustomJwtClaims 関数を実行した際の出力です(シーケンス図 のステップ 3 完了後に得られる「追加トークンクレーム」)。実際のトークンペイロードやユーザーデータコンテキストは、トークン発行プロセスでスクリプトが実行される際には異なります。
作成 ボタンをクリックしてスクリプトを保存します。カスタムトークンクレームスクリプトは保存され、アクセス トークン発行プロセスに適用されます。