mfa-begin-enroll-options 画面では、利用可能な多要素認証の登録オプションがユーザーに表示され、登録する要素を選択できます。
各画面には、それぞれ固有のHooksとメソッドがあります。SDK は、各画面について 部分インポート と ルートインポート をサポートしています。
- 部分インポートを使用すると、特定のユースケースに必要なコードだけを含められます。
- ルートインポートを使用すると、単一のバンドルからすべての画面を読み込めます。これは、想定されるすべての画面に対応する単一のビルドが必要な場合に便利です。
// ルートインポート
import { useMfaBeginEnrollOptions } from '@auth0/auth0-acul-react';
// 部分インポート
import {
useMfaBeginEnrollOptions,
// コンテキストHooks
useUser,
useTenant,
useBranding,
useClient,
useOrganization,
usePrompt,
useScreen,
useTransaction,
useUntrustedData,
// 共通Hooks
useCurrentScreen,
useAuth0Themes,
useErrors,
// ユーティリティHooks
useChangeLanguage,
// メソッド
enroll,
} from "@auth0/auth0-acul-react/mfa-begin-enroll-options";
function MfaBeginEnrollOptionsScreen() {
const { enroll } = useMfaBeginEnrollOptions();
return (
<button onClick={() => enroll({ action: 'otp' })}>
Enroll with Authenticator App
</button>
);
}
mfa-begin-enroll-options 画面で Auth0 のコンテキストデータへの読み取り専用アクセスを提供する、画面スコープのHooksです。@auth0/auth0-acul-react/mfa-begin-enroll-options からインポートします。
このフックは、mfa-begin-enroll-options 画面に表示されるロゴ、色、テーマ設定などのブランディング設定を提供します。import { useBranding } from '@auth0/auth0-acul-react/mfa-begin-enroll-options';
function CustomTheme() {
const branding = useBranding();
}
このフックは、mfa-begin-enroll-options 画面向けの id、name、logoUrl など、クライアント関連の設定を提供します。import { useClient } from '@auth0/auth0-acul-react/mfa-begin-enroll-options';
function AppInfo() {
const client = useClient();
}
このフックは、MFA 登録が組織スコープの場合に、ユーザーの組織に関する情報を提供します。組織コンテキストが存在しない場合は null を返します。import { useOrganization } from '@auth0/auth0-acul-react/mfa-begin-enroll-options';
function OrgSelector() {
const organization = useOrganization();
if (!organization) {
return <p>No organization context</p>;
}
}
このフックには、認証フロー内の現在のプロンプトに関するデータが含まれます。import { usePrompt } from '@auth0/auth0-acul-react/mfa-begin-enroll-options';
function FlowInfo() {
const prompt = usePrompt();
}
このフックには、mfa-begin-enroll-options 画面に固有の詳細情報 (設定やコンテキストなど) が含まれます。import { useScreen } from '@auth0/auth0-acul-react/mfa-begin-enroll-options';
function ScreenDebug() {
const screen = useScreen();
}
このフックには、id や関連するメタデータなど、テナントに関するデータが含まれます。import { useTenant } from '@auth0/auth0-acul-react/mfa-begin-enroll-options';
function TenantInfo() {
const tenant = useTenant();
}
このフックは、利用可能な MFA 要素や現在のフロー状態など、mfa-begin-enroll-options 画面のトランザクション固有のデータを提供します。import { useTransaction } from '@auth0/auth0-acul-react/mfa-begin-enroll-options';
function TransactionInfo() {
const transaction = useTransaction();
}
このフックは、URL パラメーターから事前入力された値など、画面に渡される信頼できないデータを扱います。import { useUntrustedData } from '@auth0/auth0-acul-react/mfa-begin-enroll-options';
function PrefilledForm() {
const untrustedData = useUntrustedData();
}
このフックは、username、email、利用可能な認証方式など、現在のユーザーの詳細を提供します。import { useUser } from '@auth0/auth0-acul-react/mfa-begin-enroll-options';
function UserProfile() {
const user = useUser();
}
このフックは、mfa-begin-enroll-options 画面で利用可能なすべてのメソッドとコンテキストを返します。
このメソッドは、選択した MFA 要素の登録を開始し、その要素の登録画面へ進みます。import { useMfaBeginEnrollOptions } from '@auth0/auth0-acul-react/mfa-begin-enroll-options';
function EnrollOptions() {
const { enroll } = useMfaBeginEnrollOptions();
return (
<button onClick={() => enroll({ action: 'otp' })}>
Authenticator App で登録する
</button>
);
}
メソッドのパラメーター
登録する要素を指定するアクションです。“push-notification”、“otp”、“sms”、“phone”、“voice”、“webauthn-roaming” のいずれかです。
このフックは、ブランディングコンテキストからフラット化された設定を含む現在のテーマオプションを取得します。
このフックは、現在のACUL画面の表示言語を変更するための関数を返します。
このフックは、現在の画面のコンテキストとstateを取得します。
このフックは、画面上のサーバー、クライアント、開発者のエラーを読み取って管理します。