phone-identifier-challenge 画面は、ユーザーがワンタイムコードを入力して電話番号を確認する必要がある場合に表示されます。この画面では、ワンタイムコードの送信、再送、SMS 配信と音声通話配信の切り替え、または前の手順への戻り操作を行えます。
各画面には、それぞれ固有のフックとメソッドのセットがあります。SDK は、各画面で 部分インポート と ルートインポート をサポートしています。
- 部分インポートを使用すると、特定のユースケースに必要なコードだけを含めることができます。
- ルートインポートを使用すると、単一のバンドルからすべての画面を読み込めるため、想定されるすべての画面を 1 つのビルドで処理したい場合に便利です。
// ルートインポート
import { usePhoneIdentifierChallenge } from '@auth0/auth0-acul-react';
// 部分インポート
import {
usePhoneIdentifierChallenge,
// コンテキストフック
useUser,
useTenant,
useBranding,
useClient,
useOrganization,
usePrompt,
useScreen,
useTransaction,
useUntrustedData,
// 共通フック
useCurrentScreen,
useAuth0Themes,
useErrors,
useResend,
// ユーティリティフック
useChangeLanguage,
// メソッド
submitPhoneChallenge,
resendCode,
returnToPrevious,
switchToText,
switchToVoice,
} from '@auth0/auth0-acul-react/phone-identifier-challenge';
function PhoneIdentifierChallengeScreen() {
const { submitPhoneChallenge } = usePhoneIdentifierChallenge();
return (
<button onClick={() => submitPhoneChallenge({ code: '123456' })}>Verify</button>
);
}
phone-identifier-challenge 画面で Auth0 のコンテキストデータへの読み取り専用アクセスを提供する、画面スコープのフックです。@auth0/auth0-acul-react/phone-identifier-challenge からインポートします。
このフックは、phone-identifier-challenge 画面に表示されるロゴ、色、テーマ設定などのブランディング構成を提供します。import { useBranding } from '@auth0/auth0-acul-react/phone-identifier-challenge';
function CustomTheme() {
const branding = useBranding();
}
このフックは、phone-identifier-challenge 画面に関する id、name、logoUrl などのクライアント関連の構成を提供します。import { useClient } from '@auth0/auth0-acul-react/phone-identifier-challenge';
function AppInfo() {
const client = useClient();
}
このフックは、電話番号チャレンジが組織スコープの場合に、ユーザーの組織に関する情報を提供します。組織コンテキストが存在しない場合は null を返します。import { useOrganization } from '@auth0/auth0-acul-react/phone-identifier-challenge';
function OrgSelector() {
const organization = useOrganization();
if (!organization) {
return <p>No Organization context</p>;
}
}
このフックには、認証フローにおける現在のプロンプトに関するデータが含まれます。import { usePrompt } from '@auth0/auth0-acul-react/phone-identifier-challenge';
function FlowInfo() {
const prompt = usePrompt();
}
このフックには、設定やコンテキストなど、phone-identifier-challenge 画面固有の詳細が含まれます。import { useScreen } from '@auth0/auth0-acul-react/phone-identifier-challenge';
function ScreenDebug() {
const screen = useScreen();
}
このフックには、id や関連するメタデータなど、テナントに関するデータが含まれます。import { useTenant } from '@auth0/auth0-acul-react/phone-identifier-challenge';
function TenantInfo() {
const tenant = useTenant();
}
このフックは、アクティブな接続や現在のフロー状態など、phone-identifier-challenge 画面に関するトランザクション固有のデータを提供します。import { useTransaction } from '@auth0/auth0-acul-react/phone-identifier-challenge';
function TransactionInfo() {
const transaction = useTransaction();
}
このフックは、URL のクエリ文字列から事前入力されたパラメーターなど、画面に渡される信頼できないデータを扱います。import { useUntrustedData } from '@auth0/auth0-acul-react/phone-identifier-challenge';
function PrefilledForm() {
const untrustedData = useUntrustedData();
}
このフックは、username、email、利用可能な認証方法など、現在のユーザーに関する情報を提供します。import { useUser } from '@auth0/auth0-acul-react/phone-identifier-challenge';
function UserProfile() {
const user = useUser();
}
usePhoneIdentifierChallenge
このフックは、phone-identifier-challenge 画面で使用できるすべてのメソッドとコンテキストを返します。
このメソッドは、ユーザーが入力したワンタイムコードを送信して電話番号を確認し、認証フローの次のステップに進みます。import { usePhoneIdentifierChallenge } from '@auth0/auth0-acul-react/phone-identifier-challenge';
function VerifyButton() {
const { submitPhoneChallenge } = usePhoneIdentifierChallenge();
return (
<button onClick={() => submitPhoneChallenge({ code: '123456' })}>
Verify
</button>
);
}
メソッドのパラメーター
このテナントで CAPTCHA が有効になっている場合の、CAPTCHA レスポンストークン。
このメソッドは、ユーザーの電話番号にワンタイムコードを再送信します。import { usePhoneIdentifierChallenge } from '@auth0/auth0-acul-react/phone-identifier-challenge';
function ResendButton() {
const { resendCode } = usePhoneIdentifierChallenge();
return (
<button onClick={() => resendCode()}>
Resend Code
</button>
);
}
このメソッドは、ユーザーを認証フローの前のステップに戻します。import { usePhoneIdentifierChallenge } from '@auth0/auth0-acul-react/phone-identifier-challenge';
function BackButton() {
const { returnToPrevious } = usePhoneIdentifierChallenge();
return (
<button onClick={() => returnToPrevious()}>
Back
</button>
);
}
このメソッドは、電話番号確認の送信方法を SMS テキストメッセージに切り替えます。import { usePhoneIdentifierChallenge } from '@auth0/auth0-acul-react/phone-identifier-challenge';
function SwitchToSmsButton() {
const { switchToText } = usePhoneIdentifierChallenge();
return (
<button onClick={() => switchToText()}>
Send via SMS
</button>
);
}
このメソッドは、電話番号確認の送信方法を音声通話に切り替えます。import { usePhoneIdentifierChallenge } from '@auth0/auth0-acul-react/phone-identifier-challenge';
function SwitchToVoiceButton() {
const { switchToVoice } = usePhoneIdentifierChallenge();
return (
<button onClick={() => switchToVoice()}>
Send via Voice Call
</button>
);
}
このフックは、ブランディングコンテキストからフラット化された設定を含む現在のテーマオプションを取得します。
このフックは、現在の ACUL 画面の表示言語を変更する関数を返します。
このフックは、現在の画面のコンテキストと state を取得します。
このフックは、画面上のサーバー、クライアント、開発者のエラーを読み取り、管理します。
このフックは、resendCode メソッドの再送クールダウンの状態とタイマーを管理します。