aboutsummaryrefslogtreecommitdiff
path: root/packages/aml-backoffice-ui/src/hooks/useCaseDetails.ts
blob: 9db1e2aecbea08a19e0c1c7b8dd860d253f7d4d8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101

import {
  HttpResponse,
  HttpResponseOk
} from "@gnu-taler/web-util/browser";
import { AmlExchangeBackend } from "../types.js";
// FIX default import https://github.com/microsoft/TypeScript/issues/49189
import { AmountString, OfficerAccount, PaytoString, TalerExchangeApi, TalerExchangeResultByMethod, TalerHttpError } from "@gnu-taler/taler-util";
import _useSWR, { SWRHook, useSWRConfig } from "swr";
import { useExchangeApiContext } from "../context/config.js";
import { usePublicBackend } from "./useBackend.js";
import { useOfficer } from "./useOfficer.js";
const useSWR = _useSWR as unknown as SWRHook;

export function useCaseDetails(paytoHash: string) {
  const officer = useOfficer();
  const session = officer.state === "ready" ? officer.account : undefined;

  const { api } = useExchangeApiContext();

  async function fetcher([officer, account]: [OfficerAccount, PaytoString]) {
    return await api.getDecisionDetails(officer, account)
  }

  const { data, error } = useSWR<TalerExchangeResultByMethod<"getDecisionDetails">, TalerHttpError>(
    !session ? undefined : [session, paytoHash], fetcher, {
    refreshInterval: 0,
    refreshWhenHidden: false,
    revalidateOnFocus: false,
    revalidateOnReconnect: false,
    refreshWhenOffline: false,
    errorRetryCount: 0,
    errorRetryInterval: 1,
    shouldRetryOnError: false,
    keepPreviousData: true,
  });

  if (data) return data;
  if (error) return error;
  return undefined;
}

const example1: TalerExchangeApi.AmlDecisionDetails = {
  aml_history: [
    {
      justification: "Lack of documentation",
      decider_pub: "ASDASDASD",
      decision_time: {
        t_s: Date.now() / 1000,
      },
      new_state: 2,
      new_threshold: "USD:0" as AmountString,
    },
    {
      justification: "Doing a transfer of high amount",
      decider_pub: "ASDASDASD",
      decision_time: {
        t_s: Date.now() / 1000 - 60 * 60 * 24 * 30 * 6,
      },
      new_state: 1,
      new_threshold: "USD:2000" as AmountString,
    },
    {
      justification: "Account is known to the system",
      decider_pub: "ASDASDASD",
      decision_time: {
        t_s: Date.now() / 1000 - 60 * 60 * 24 * 30 * 9,
      },
      new_state: 0,
      new_threshold: "USD:100" as AmountString,
    },
  ],
  kyc_attributes: [
    {
      collection_time: {
        t_s: Date.now() / 1000 - 60 * 60 * 24 * 30 * 8,
      },
      expiration_time: {
        t_s: Date.now() / 1000 - 60 * 60 * 24 * 30 * 4,
      },
      provider_section: "asdasd",
      attributes: {
        name: "Sebastian",
      },
    },
    {
      collection_time: {
        t_s: Date.now() / 1000 - 60 * 60 * 24 * 30 * 5,
      },
      expiration_time: {
        t_s: Date.now() / 1000 - 60 * 60 * 24 * 30 * 2,
      },
      provider_section: "asdasd",
      attributes: {
        creditCard: "12312312312",
      },
    },
  ],
};