2
0
Files
cal/calcom/packages/lib/redactError.ts
2024-08-09 00:39:27 +02:00

29 lines
875 B
TypeScript

import { Prisma } from "@prisma/client";
import logger from "@calcom/lib/logger";
import { IS_PRODUCTION } from "./constants";
const log = logger.getSubLogger({ prefix: [`[redactError]`] });
function shouldRedact<T extends Error>(error: T) {
return (
error instanceof Prisma.PrismaClientInitializationError ||
error instanceof Prisma.PrismaClientKnownRequestError ||
error instanceof Prisma.PrismaClientUnknownRequestError ||
error instanceof Prisma.PrismaClientValidationError
);
}
export const redactError = <T extends Error | unknown>(error: T) => {
if (!(error instanceof Error)) {
return error;
}
log.debug("Type of Error: ", error.constructor);
if (shouldRedact(error) && IS_PRODUCTION) {
log.error("Error: ", JSON.stringify(error));
return new Error("An error occured while querying the database.");
}
return error;
};