import { AuthenticationProviderStatusOk } from "@gnu-taler/anastasis-core"; import { h, VNode } from "preact"; import { useState } from "preact/hooks"; import { AsyncButton } from "../../components/AsyncButton"; import { useAnastasisContext } from "../../context/anastasis"; import { authMethods, KnownAuthMethods } from "./authMethod"; import { ConfirmModal } from "./ConfirmModal"; import { EditPoliciesScreen } from "./EditPoliciesScreen"; import { AnastasisClientFrame } from "./index"; export function ReviewPoliciesScreen(): VNode { const [editingPolicy, setEditingPolicy] = useState(); const [confirmReset, setConfirmReset] = useState(false); const reducer = useAnastasisContext(); if (!reducer) { return
no reducer in context
; } if ( !reducer.currentReducerState || reducer.currentReducerState.backup_state === undefined ) { return
invalid state
; } const configuredAuthMethods = reducer.currentReducerState.authentication_methods ?? []; const policies = reducer.currentReducerState.policies ?? []; const providers = reducer.currentReducerState.authentication_providers ?? {}; if (editingPolicy !== undefined) { return ( setEditingPolicy(undefined)} confirm={async (newMethods) => { await reducer.transition("update_policy", { policy_index: editingPolicy, policy: newMethods, }); setEditingPolicy(undefined); }} /> ); } async function resetPolicies(): Promise { if (!reducer) return Promise.resolve(); return reducer.runTransaction(async (tx) => { await tx.transition("back", {}); await tx.transition("next", {}); setConfirmReset(false); }); } const errors = policies.length < 1 ? "Need more policies" : undefined; return ( {policies.length > 0 && (

Based on your configured authentication method you have created, some policies have been configured. In order to recover your secret you have to solve all the challenges of at least one policy.

)} {policies.length < 1 && (

No policies had been created. Go back and add more authentication methods.

)}
setConfirmReset(true)}> Reset policies
{policies.map((p, policy_index) => { const methods = p.methods .map( (x) => configuredAuthMethods[x.authentication_method] && { ...configuredAuthMethods[x.authentication_method], provider: x.provider, }, ) .filter((x) => !!x); const policyName = methods.map((x) => x.type).join(" + "); if (p.methods.length > methods.length) { //there is at least one authentication method that is corrupted return null; } return (

Policy #{policy_index + 1}: {policyName}

{!methods.length &&

No auth method found

} {methods.map((m, i) => { const p = providers[ m.provider ] as AuthenticationProviderStatusOk; return (

{authMethods[m.type as KnownAuthMethods]?.icon} {m.instructions} recovery provided by{" "} {p.business_name}

); })}
); })} {confirmReset && ( setConfirmReset(false)} description="Do you want to reset the policies to default state?" label="Reset policies" cancelLabel="Cancel" onConfirm={resetPolicies} >

All policies will be recalculated based on the authentication providers configured and any change that you did will be lost

)}
); }