diff --git a/app/(dashboard)/dashboard/interviews/_actions/export.ts b/app/(dashboard)/dashboard/interviews/_actions/export.ts index e5e9ec0e..986f8f83 100644 --- a/app/(dashboard)/dashboard/interviews/_actions/export.ts +++ b/app/(dashboard)/dashboard/interviews/_actions/export.ts @@ -130,11 +130,10 @@ export const exportSessions = async ( const e = ensureError(error); await trackEvent({ type: 'Error', - error: { - message: e.name, - details: e.message, + error: e, + metadata: { + details: 'Server-side Error', path: '/(dashboard)/dashboard/interviews/_actions/export.ts', - stacktrace: e.stack ?? '', }, }); diff --git a/app/(interview)/onboard/[protocolId]/route.ts b/app/(interview)/onboard/[protocolId]/route.ts index f58a6f3d..6f17899c 100644 --- a/app/(interview)/onboard/[protocolId]/route.ts +++ b/app/(interview)/onboard/[protocolId]/route.ts @@ -14,11 +14,10 @@ const handler = async ( if (!protocolId || protocolId === 'undefined') { void trackEvent({ type: 'Error', - error: { + error: new Error('No protocol ID provided.'), + metadata: { details: 'No protocol ID provided', - message: 'No protocol ID provided', path: '/onboard/[protocolId]/route.ts', - stacktrace: '', }, }); @@ -48,11 +47,10 @@ const handler = async ( if (error) { void trackEvent({ type: 'Error', - error: { - details: error, - message: 'Failed to create interview', + error: new Error(error), + metadata: { + details: 'Failed to create interview', path: '/onboard/[protocolId]/route.ts', - stacktrace: '', }, }); diff --git a/app/api/trpc/[trpc]/route.ts b/app/api/trpc/[trpc]/route.ts index 64a80892..8c490c54 100644 --- a/app/api/trpc/[trpc]/route.ts +++ b/app/api/trpc/[trpc]/route.ts @@ -15,11 +15,10 @@ const handler = (req: Request) => void trackEvent({ type: 'Error', - error: { - message: error.message, + error: new Error(error.message), + metadata: { details: type, path: path ?? 'unknown', - stacktrace: 'unknown', }, }); diff --git a/components/Error.tsx b/components/Error.tsx index ad4e9b49..7fadbfd6 100644 --- a/components/Error.tsx +++ b/components/Error.tsx @@ -19,10 +19,9 @@ export default function Error({ try { await trackEvent({ type: 'Error', - error: { - message: error.message, + error, + metadata: { details: heading ?? '', - stacktrace: error.stack ?? '', path: window.location.pathname, }, }); diff --git a/components/ProtocolImport/JobReducer.ts b/components/ProtocolImport/JobReducer.ts index e763793e..e1eeeb88 100644 --- a/components/ProtocolImport/JobReducer.ts +++ b/components/ProtocolImport/JobReducer.ts @@ -124,11 +124,10 @@ export function jobReducer(state: ImportJob[], action: Action) { void trackEvent({ type: 'Error', - error: { + error: rawError, + metadata: { details: 'Protocol import error', - message: rawError.message, - stacktrace: rawError.stack ?? '', - path: '', + path: 'components/ProtocolImport/JobReducer.ts', }, }); diff --git a/package.json b/package.json index f84ccd59..0e185473 100644 --- a/package.json +++ b/package.json @@ -19,7 +19,7 @@ "seed": "tsx prisma/seed.ts" }, "dependencies": { - "@codaco/analytics": "^2.1.1", + "@codaco/analytics": "^3.1.0", "@codaco/protocol-validation": "3.0.0-alpha.4", "@codaco/shared-consts": "^0.0.2", "@headlessui/react": "^1.7.17", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index f01b1050..b301ee4b 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -6,8 +6,8 @@ settings: dependencies: '@codaco/analytics': - specifier: ^2.1.1 - version: 2.1.1(@maxmind/geoip2-node@5.0.0)(next@14.1.0) + specifier: ^3.1.0 + version: 3.1.0(@maxmind/geoip2-node@5.0.0)(next@14.1.0) '@codaco/protocol-validation': specifier: 3.0.0-alpha.4 version: 3.0.0-alpha.4(@types/eslint@8.44.6)(eslint-config-prettier@9.0.0)(eslint@8.52.0) @@ -1806,14 +1806,15 @@ packages: resolution: {integrity: sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==} dev: true - /@codaco/analytics@2.1.1(@maxmind/geoip2-node@5.0.0)(next@14.1.0): - resolution: {integrity: sha512-x7gQt+IL2BiEALNX+28HUIhl4z0eQ60zjJQD++pnCrTixYSK2+TXLjTr9QcLG9K4WSBA7UgDkHVLXnPoC3nZOA==} + /@codaco/analytics@3.1.0(@maxmind/geoip2-node@5.0.0)(next@14.1.0): + resolution: {integrity: sha512-wDGm7nMrDHlJ8inY66+lkK/fzc1kC/LL/drI5d8BXyc9sF7+FzB2iL8w093hNL5sKTOubJWWccKwIaX95EUJYQ==} peerDependencies: '@maxmind/geoip2-node': ^5.0.0 next: 13 || 14 dependencies: '@maxmind/geoip2-node': 5.0.0 next: 14.1.0(@babel/core@7.23.2)(react-dom@18.2.0)(react@18.2.0)(sass@1.69.4) + zod: 3.22.4 dev: false /@codaco/protocol-validation@3.0.0-alpha.4(@types/eslint@8.44.6)(eslint-config-prettier@9.0.0)(eslint@8.52.0): diff --git a/server/routers/interview.ts b/server/routers/interview.ts index 0f31763c..7e3c651b 100644 --- a/server/routers/interview.ts +++ b/server/routers/interview.ts @@ -102,11 +102,10 @@ export const interviewRouter = router({ void trackEvent({ type: 'Error', - error: { - message: e.name, + error: e, + metadata: { details: e.message, path: '/routers/interview.ts', - stacktrace: e.stack ?? '', }, });