passwordless prompt page

This commit is contained in:
Max Peintner
2023-06-19 16:28:29 +02:00
parent ed7d612660
commit f8bbfb3d57
4 changed files with 37 additions and 15 deletions

View File

@@ -22,6 +22,7 @@ async function loadSessions(): Promise<Session[]> {
export default async function Page() {
let sessions = await loadSessions();
console.log(sessions);
return (
<div className="flex flex-col items-center space-y-4">

View File

@@ -9,7 +9,7 @@ export default async function Page({
}: {
searchParams: Record<string | number | symbol, string | undefined>;
}) {
const { loginName } = searchParams;
const { loginName, prompt } = searchParams;
const sessionFactors = await loadSession(loginName);
@@ -21,10 +21,16 @@ export default async function Page({
}
});
}
const title = !!prompt
? "Authenticate with a passkey"
: "Use your passkey to confirm its really you";
const description = !!prompt
? "When set up, you will be able to authenticate without a password."
: "Your device will ask for your fingerprint, face, or screen lock";
return (
<div className="flex flex-col items-center space-y-4">
<h1>Use your passkey to confirm its really you</h1>
<h1>{title}</h1>
{sessionFactors && (
<UserAvatar
@@ -33,9 +39,7 @@ export default async function Page({
showDropdown
></UserAvatar>
)}
<p className="ztdl-p mb-6 block">
Your device will ask for your fingerprint, face, or screen lock
</p>
<p className="ztdl-p mb-6 block">{description}</p>
<Alert type={AlertType.INFO}>
<span>
@@ -60,7 +64,9 @@ export default async function Page({
</div>
)}
{sessionFactors?.id && <RegisterPasskey sessionId={sessionFactors.id} />}
{sessionFactors?.id && (
<RegisterPasskey sessionId={sessionFactors.id} isPrompt={!!prompt} />
)}
</div>
);
}

View File

@@ -55,7 +55,10 @@ export default function PasswordForm({ loginName }: Props) {
if (resp.factors && !resp.factors.passwordless) {
return router.push(
`/passkey/add?` +
new URLSearchParams({ loginName: resp.factors.user.loginName })
new URLSearchParams({
loginName: resp.factors.user.loginName,
prompt: "true",
})
);
} else {
return router.push(`/accounts`);

View File

@@ -12,9 +12,10 @@ type Inputs = {};
type Props = {
sessionId: string;
isPrompt: boolean;
};
export default function RegisterPasskey({ sessionId }: Props) {
export default function RegisterPasskey({ sessionId, isPrompt }: Props) {
const { register, handleSubmit, formState } = useForm<Inputs>({
mode: "onBlur",
});
@@ -172,6 +173,15 @@ export default function RegisterPasskey({ sessionId }: Props) {
)}
<div className="mt-8 flex w-full flex-row items-center">
{isPrompt ? (
<Button
type="button"
variant={ButtonVariants.Secondary}
onClick={() => router.push("/accounts")}
>
skip
</Button>
) : (
<Button
type="button"
variant={ButtonVariants.Secondary}
@@ -179,6 +189,8 @@ export default function RegisterPasskey({ sessionId }: Props) {
>
back
</Button>
)}
<span className="flex-grow"></span>
<Button
type="submit"