/* eslint-disable @typescript-eslint/camelcase */ 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 ?? []; 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(" + "); return (

Policy #{policy_index + 1}: {policyName}

{!methods.length &&

No auth method found

} {methods.map((m, i) => { return (

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

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