mfa-webauthn-platform-enrollment 画面では、Touch ID や Windows Hello などのプラットフォーム認証器を、MFA の認証要素として登録するようユーザーに求めます。
各画面には、それぞれ固有のフックとメソッドがあります。SDK は、各画面について 部分インポート と ルートインポート をサポートしています。
- 部分インポートを使用すると、特定のユースケースに必要なコードだけを含めることができます。
- ルートインポートを使用すると、単一のバンドルからすべての画面を読み込めます。これは、想定されるすべての画面を 1 つの統一されたビルドで処理したい場合に便利です。
// ルートインポート
import { useMfaWebAuthnPlatformEnrollment } from '@auth0/auth0-acul-react';
// 部分インポート
import {
useMfaWebAuthnPlatformEnrollment,
// コンテキストフック
useUser,
useTenant,
useBranding,
useClient,
useOrganization,
usePrompt,
useScreen,
useTransaction,
useUntrustedData,
// 共通フック
useCurrentScreen,
useAuth0Themes,
useErrors,
// ユーティリティフック
useChangeLanguage,
// メソッド
refuseEnrollmentOnThisDevice,
reportBrowserError,
snoozeEnrollment,
submitPasskeyCredential,
} from "@auth0/auth0-acul-react/mfa-webauthn-platform-enrollment";
function MfaWebAuthnPlatformEnrollmentScreen() {
const { submitPasskeyCredential } = useMfaWebAuthnPlatformEnrollment();
return (
<button onClick={() => submitPasskeyCredential()}>
Enroll Platform Authenticator
</button>
);
}
mfa-webauthn-platform-enrollment 画面で Auth0 のコンテキストデータへの読み取り専用アクセスを提供する画面スコープのフックです。@auth0/auth0-acul-react/mfa-webauthn-platform-enrollment からインポートします。
このフックは、mfa-webauthn-platform-enrollment 画面に表示されるロゴ、色、テーマ設定などのブランディング設定を提供します。import { useBranding } from '@auth0/auth0-acul-react/mfa-webauthn-platform-enrollment';
function CustomTheme() {
const branding = useBranding();
}
このフックは、mfa-webauthn-platform-enrollment 画面で使用する id、name、logoUrl などのクライアント関連の設定を提供します。import { useClient } from '@auth0/auth0-acul-react/mfa-webauthn-platform-enrollment';
function AppInfo() {
const client = useClient();
}
MFA フローが組織スコープの場合、このフックはユーザーの組織に関する情報を提供します。組織コンテキストが存在しない場合は null を返します。import { useOrganization } from '@auth0/auth0-acul-react/mfa-webauthn-platform-enrollment';
function OrgSelector() {
const organization = useOrganization();
if (!organization) {
return <p>No organization context</p>;
}
}
このフックには、認証フロー内の現在のプロンプトに関するデータが含まれます。import { usePrompt } from '@auth0/auth0-acul-react/mfa-webauthn-platform-enrollment';
function FlowInfo() {
const prompt = usePrompt();
}
このフックには、設定やコンテキストなど、mfa-webauthn-platform-enrollment 画面に固有の詳細情報が含まれます。import { useScreen } from '@auth0/auth0-acul-react/mfa-webauthn-platform-enrollment';
function ScreenDebug() {
const screen = useScreen();
}
このフックには、id や関連するメタデータなど、テナントに関するデータが含まれます。import { useTenant } from '@auth0/auth0-acul-react/mfa-webauthn-platform-enrollment';
function TenantInfo() {
const tenant = useTenant();
}
このフックは、現在の MFA フローの状態など、mfa-webauthn-platform-enrollment 画面におけるトランザクション固有のデータを提供します。import { useTransaction } from '@auth0/auth0-acul-react/mfa-webauthn-platform-enrollment';
function TransactionInfo() {
const transaction = useTransaction();
}
このフックは、URL パラメーターから事前入力された値など、画面に渡される信頼できないデータを扱います。import { useUntrustedData } from '@auth0/auth0-acul-react/mfa-webauthn-platform-enrollment';
function PrefilledForm() {
const untrustedData = useUntrustedData();
}
このフックは、username、email、利用可能な認証方法など、現在アクティブなユーザーの詳細を提供します。import { useUser } from '@auth0/auth0-acul-react/mfa-webauthn-platform-enrollment';
function UserProfile() {
const user = useUser();
}
useMfaWebAuthnPlatformEnrollment
このフックは、mfa-webauthn-platform-enrollment 画面で使用できるすべてのメソッドとコンテキストを返します。
refuseEnrollmentOnThisDevice
このメソッドは、現在のデバイスでのプラットフォーム認証器の登録を拒否します。import { useMfaWebAuthnPlatformEnrollment } from '@auth0/auth0-acul-react/mfa-webauthn-platform-enrollment';
function RefuseEnrollmentButton() {
const { refuseEnrollmentOnThisDevice } = useMfaWebAuthnPlatformEnrollment();
return (
<button onClick={() => refuseEnrollmentOnThisDevice()}>
Not on This Device
</button>
);
}
このメソッドは、プラットフォーム認証器の登録中に発生したブラウザーレベルの WebAuthn エラーを報告します。import { useMfaWebAuthnPlatformEnrollment } from '@auth0/auth0-acul-react/mfa-webauthn-platform-enrollment';
function HandleWebAuthnError({ error }) {
const { reportBrowserError } = useMfaWebAuthnPlatformEnrollment();
return (
<button onClick={() => reportBrowserError({ error })}>
Report Error
</button>
);
}
メソッド パラメーター
報告する WebAuthn API (navigator.credentials.create()) のエラーオブジェクトです。エラー名 (例: 'NotAllowedError') 。
このメソッドは、プラットフォーム認証器の登録を後で行うように延期します。import { useMfaWebAuthnPlatformEnrollment } from '@auth0/auth0-acul-react/mfa-webauthn-platform-enrollment';
function SnoozeButton() {
const { snoozeEnrollment } = useMfaWebAuthnPlatformEnrollment();
return (
<button onClick={() => snoozeEnrollment()}>
Remind Me Later
</button>
);
}
このメソッドは、登録を完了するために、プラットフォーム認証器が作成した passkey の認証情報を送信します。import { useMfaWebAuthnPlatformEnrollment } from '@auth0/auth0-acul-react/mfa-webauthn-platform-enrollment';
function EnrollButton() {
const { submitPasskeyCredential } = useMfaWebAuthnPlatformEnrollment();
return (
<button onClick={() => submitPasskeyCredential()}>
Enroll Platform Authenticator
</button>
);
}
このフックは、ブランディングコンテキストのフラット化された設定を含む現在のテーマオプションを取得します。
このフックは、現在の ACUL 画面の表示言語を変更するための関数を返します。
このフックは、現在の画面のコンテキストと state を取得します。
このフックは、画面上のサーバー、クライアント、開発者のエラーを取得して管理します。