import { AuthenticationProviderStatusOk } from "anastasis-core"; import { h, VNode } from "preact"; import { useState } from "preact/hooks"; import { useAnastasisContext } from "../../context/anastasis"; import { authMethods, KnownAuthMethods } from "./authMethod"; import { EditPoliciesScreen } from "./EditPoliciesScreen"; import { AnastasisClientFrame } from "./index"; export function ReviewPoliciesScreen(): VNode { const [editingPolicy, setEditingPolicy] = useState(); 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); }} /> ); } 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.

)}
{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}

); })}
); })}
); }