From 62aefe30a501b6f5fe9ac65b64e1a40a5a8d4d1b Mon Sep 17 00:00:00 2001 From: forbesus Date: Wed, 4 Dec 2024 01:10:57 -0800 Subject: [PATCH] feat(observability): utilise new logger in stats-web closes #436 --- apps/stats-web/src/app/blocks/[height]/errors.tsx | 5 ++++- apps/stats-web/src/app/error.tsx | 4 +++- apps/stats-web/src/app/transactions/[hash]/error.tsx | 4 +++- apps/stats-web/src/app/transactions/[hash]/page.tsx | 5 +---- apps/stats-web/src/config/env-config.schema.ts | 4 +++- apps/stats-web/src/lib/copyClipboard.ts | 12 ++++++++---- 6 files changed, 22 insertions(+), 12 deletions(-) diff --git a/apps/stats-web/src/app/blocks/[height]/errors.tsx b/apps/stats-web/src/app/blocks/[height]/errors.tsx index 65ae27eb5..2eb0b60a7 100644 --- a/apps/stats-web/src/app/blocks/[height]/errors.tsx +++ b/apps/stats-web/src/app/blocks/[height]/errors.tsx @@ -2,10 +2,13 @@ import { useEffect } from "react"; +import { useLogger } from "@/hooks/useLogger"; + export default function Error({ error, reset }: { error: Error & { digest?: string }; reset: () => void }) { + const blockErrorLogger = useLogger("apps/stats-web/src/app/blocks/[height]/errors.tsx"); useEffect(() => { // Log the error to an error reporting service - console.error(error); + blockErrorLogger.debug(error); }, [error]); return ( diff --git a/apps/stats-web/src/app/error.tsx b/apps/stats-web/src/app/error.tsx index c6ede3758..fd875b1db 100644 --- a/apps/stats-web/src/app/error.tsx +++ b/apps/stats-web/src/app/error.tsx @@ -5,11 +5,13 @@ import { Button } from "@akashnetwork/ui/components"; import PageContainer from "@/components/PageContainer"; import { Title } from "@/components/Title"; +import { useLogger } from "@/hooks/useLogger"; export default function Error({ error, reset }: { error: Error & { digest?: string }; reset: () => void }) { + const errorLogger = useLogger("apps/stats-web/src/app/error.tsx"); useEffect(() => { // Log the error to an error reporting service - console.error(error); + errorLogger.debug(error); }, [error]); return ( diff --git a/apps/stats-web/src/app/transactions/[hash]/error.tsx b/apps/stats-web/src/app/transactions/[hash]/error.tsx index c6ede3758..afc67c62d 100644 --- a/apps/stats-web/src/app/transactions/[hash]/error.tsx +++ b/apps/stats-web/src/app/transactions/[hash]/error.tsx @@ -5,11 +5,13 @@ import { Button } from "@akashnetwork/ui/components"; import PageContainer from "@/components/PageContainer"; import { Title } from "@/components/Title"; +import { useLogger } from "@/hooks/useLogger"; export default function Error({ error, reset }: { error: Error & { digest?: string }; reset: () => void }) { + const transactionLogger = useLogger("apps/stats-web/src/app/transactions/[hash]/errors.tsx"); useEffect(() => { // Log the error to an error reporting service - console.error(error); + transactionLogger.debug(error); }, [error]); return ( diff --git a/apps/stats-web/src/app/transactions/[hash]/page.tsx b/apps/stats-web/src/app/transactions/[hash]/page.tsx index 76bc605b6..d59a83c65 100644 --- a/apps/stats-web/src/app/transactions/[hash]/page.tsx +++ b/apps/stats-web/src/app/transactions/[hash]/page.tsx @@ -33,16 +33,14 @@ export async function generateMetadata({ params: { hash } }: TransactionDetailPa async function fetchTransactionData(hash: string, network: Network["id"]): Promise { const apiUrl = serverApiUrlService.getBaseApiUrlFor(network); - console.log("DEBUG apiUrl", apiUrl); const response = await fetch(`${apiUrl}/v1/transactions/${hash}`); - + if (!response.ok && response.status !== 404) { // This will activate the closest `error.js` Error Boundary throw new Error("Error fetching transaction data"); } else if (response.status === 404) { return null; } - return response.json(); } @@ -52,7 +50,6 @@ export default async function TransactionDetailPage(props: TransactionDetailPage searchParams: { network } } = TransactionDetailPageSchema.parse(props); const transaction = await fetchTransactionData(hash, network); - return ( Transaction Details diff --git a/apps/stats-web/src/config/env-config.schema.ts b/apps/stats-web/src/config/env-config.schema.ts index 8773a82bf..624edc1cf 100644 --- a/apps/stats-web/src/config/env-config.schema.ts +++ b/apps/stats-web/src/config/env-config.schema.ts @@ -1,7 +1,9 @@ +import { LoggerService } from "@akashnetwork/logging"; import { z } from "zod"; export const networkId = z.enum(["mainnet", "sandbox", "testnet"]); const coercedBoolean = () => z.enum(["true", "false"]).transform(val => val === "true"); +const envLogger = LoggerService.forContext("apps/stats-web/src/config/env-config.schema.ts"); export const browserEnvSchema = z.object({ NEXT_PUBLIC_DEFAULT_NETWORK_ID: networkId.optional().default("mainnet"), @@ -26,7 +28,7 @@ export type ServerEnvConfig = z.infer; export const validateStaticEnvVars = (config: Record) => browserEnvSchema.parse(config); export const validateRuntimeEnvVars = (config: Record) => { if (process.env.NEXT_PHASE === "phase-production-build") { - console.log("Skipping validation of serverEnvConfig during build"); + envLogger.debug("Skipping validation of serverEnvConfig during build"); return config as ServerEnvConfig; } else { return serverEnvSchema.parse(config); diff --git a/apps/stats-web/src/lib/copyClipboard.ts b/apps/stats-web/src/lib/copyClipboard.ts index 9744acbdc..4364937df 100644 --- a/apps/stats-web/src/lib/copyClipboard.ts +++ b/apps/stats-web/src/lib/copyClipboard.ts @@ -1,3 +1,7 @@ +import { LoggerService } from "@akashnetwork/logging"; + +const clipboardLogger = LoggerService.forContext("apps/stats-web/src/lib/copyClipboard.ts"); + function fallbackCopyTextToClipboard(text: string) { const textArea = document.createElement("textarea"); textArea.value = text; @@ -14,9 +18,9 @@ function fallbackCopyTextToClipboard(text: string) { try { const successful = document.execCommand("copy"); const msg = successful ? "successful" : "unsuccessful"; - console.log("Fallback: Copying text command was " + msg); + clipboardLogger.debug("Fallback: Copying text command was " + msg); } catch (err) { - console.error("Fallback: Oops, unable to copy", err); + clipboardLogger.debug(`Fallback: Oops, unable to copy: ${err}`); } document.body.removeChild(textArea); @@ -28,10 +32,10 @@ export const copyTextToClipboard = (text: string) => { } navigator.clipboard.writeText(text).then( () => { - console.log("Async: Copying to clipboard was successful!"); + clipboardLogger.debug("Async: Copying to clipboard was successful!"); }, err => { - console.error("Async: Could not copy text: ", err); + clipboardLogger.debug(`Async: Could not copy text: ${err}`); } ); };