diff --git a/tools/obscuroscan_v3/frontend/api/general.ts b/tools/obscuroscan_v3/frontend/api/general.ts new file mode 100644 index 0000000000..88324a5255 --- /dev/null +++ b/tools/obscuroscan_v3/frontend/api/general.ts @@ -0,0 +1,14 @@ +import { ResponseDataInterface } from "@/src/types/interfaces"; +import { httpRequest } from "."; +import { pathToUrl } from "@/src/routes/router"; +import { apiRoutes } from "@/src/routes"; + +export const fetchTestnetStatus = async (): Promise< + ResponseDataInterface +> => { + return await httpRequest>({ + method: "post", + url: pathToUrl(apiRoutes.getHealthStatus), + data: { jsonrpc: "2.0", method: "obscuro_health", params: [], id: 1 }, + }); +}; diff --git a/tools/obscuroscan_v3/frontend/src/components/health-indicator.tsx b/tools/obscuroscan_v3/frontend/src/components/health-indicator.tsx new file mode 100644 index 0000000000..6bc25c4827 --- /dev/null +++ b/tools/obscuroscan_v3/frontend/src/components/health-indicator.tsx @@ -0,0 +1,24 @@ +import React from "react"; +import { Badge, badgeVariants } from "./ui/badge"; +import { useGeneralService } from "../services/useGeneralService"; + +const HealthIndicator = () => { + const { testnetStatus } = useGeneralService(); + + return ( +
+

Testnet Status:

+ + {testnetStatus?.result ? "Live" : "Down"} + +
+ ); +}; + +export default HealthIndicator; diff --git a/tools/obscuroscan_v3/frontend/src/components/layouts/header.tsx b/tools/obscuroscan_v3/frontend/src/components/layouts/header.tsx index 7a2b0ce726..d2ddfb493d 100644 --- a/tools/obscuroscan_v3/frontend/src/components/layouts/header.tsx +++ b/tools/obscuroscan_v3/frontend/src/components/layouts/header.tsx @@ -5,6 +5,7 @@ import Link from "next/link"; import { HamburgerMenuIcon } from "@radix-ui/react-icons"; import { useState } from "react"; import { Button } from "../ui/button"; +import HealthIndicator from "../health-indicator"; export default function Header() { return ( @@ -16,6 +17,7 @@ export default function Header() {
+
diff --git a/tools/obscuroscan_v3/frontend/src/routes/index.ts b/tools/obscuroscan_v3/frontend/src/routes/index.ts index ebd6e29ecd..045b35989d 100644 --- a/tools/obscuroscan_v3/frontend/src/routes/index.ts +++ b/tools/obscuroscan_v3/frontend/src/routes/index.ts @@ -23,6 +23,9 @@ export const apiRoutes = { // **** ROLLUPS **** getRollups: "/items/rollup/latest/", decryptEncryptedRollup: "/actions/decryptTxBlob/", + + // **** INFO **** + getHealthStatus: "/info/health/", }; export const ethMethods = { diff --git a/tools/obscuroscan_v3/frontend/src/services/useGeneralService.ts b/tools/obscuroscan_v3/frontend/src/services/useGeneralService.ts new file mode 100644 index 0000000000..f82c686456 --- /dev/null +++ b/tools/obscuroscan_v3/frontend/src/services/useGeneralService.ts @@ -0,0 +1,19 @@ +import { fetchTestnetStatus } from "@/api/general"; +import { useQuery } from "@tanstack/react-query"; +import { useState } from "react"; + +export const useGeneralService = () => { + const [noPolling, setNoPolling] = useState(false); + + const { + data: testnetStatus, + isLoading: isStatusLoading, + refetch: refetchTestnetStatus, + } = useQuery({ + queryKey: ["testnetStatus"], + queryFn: () => fetchTestnetStatus(), + // refetchInterval: noPolling ? false : pollingInterval, + }); + + return { testnetStatus, isStatusLoading, setNoPolling, refetchTestnetStatus }; +};