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

View File

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

View File

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