error-handling-standardizer

Error Handling Standardizer

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "error-handling-standardizer" with this command: npx skills add patricio0312rev/skills/patricio0312rev-skills-error-handling-standardizer

Error Handling Standardizer

Build consistent, debuggable error handling across the application.

Error Taxonomy

export class AppError extends Error { constructor( public code: string, public message: string, public statusCode: number = 500, public isOperational: boolean = true, public details?: any ) { super(message); Error.captureStackTrace(this, this.constructor); } }

export class ValidationError extends AppError { constructor(details: Record<string, string[]>) { super("VALIDATION_ERROR", "Validation failed", 400, true, details); } }

export class NotFoundError extends AppError { constructor(resource: string) { super("NOT_FOUND", ${resource} not found, 404); } }

export class UnauthorizedError extends AppError { constructor(message = "Unauthorized") { super("UNAUTHORIZED", message, 401); } }

export class ForbiddenError extends AppError { constructor(message = "Forbidden") { super("FORBIDDEN", message, 403); } }

Error Handler Middleware

export const errorHandler = ( err: Error, req: Request, res: Response, next: NextFunction ) => { // Log error logger.error("Request error", { error: err.message, stack: err.stack, path: req.path, method: req.method, requestId: req.id, });

// Operational errors (known) if (err instanceof AppError && err.isOperational) { return res.status(err.statusCode).json({ success: false, error: { code: err.code, message: err.message, details: err.details, trace_id: req.id, }, }); }

// Programming errors (unknown) return res.status(500).json({ success: false, error: { code: "INTERNAL_ERROR", message: "An unexpected error occurred", trace_id: req.id, }, }); };

Structured Logging

import winston from "winston";

export const logger = winston.createLogger({ level: "info", format: winston.format.combine( winston.format.timestamp(), winston.format.errors({ stack: true }), winston.format.json() ), transports: [ new winston.transports.File({ filename: "error.log", level: "error" }), new winston.transports.File({ filename: "combined.log" }), ], });

// Log with context logger.error("Payment processing failed", { userId: user.id, amount: payment.amount, error: err.message, trace_id: req.id, });

Safe Client Messages

// Never expose internal errors to clients const getSafeErrorMessage = (err: Error): string => { if (err instanceof AppError && err.isOperational) { return err.message; // Safe, user-facing message }

// Generic message for unexpected errors return "An unexpected error occurred"; };

Async Error Handling

// Wrap async routes export const asyncHandler = (fn: RequestHandler) => { return (req: Request, res: Response, next: NextFunction) => { Promise.resolve(fn(req, res, next)).catch(next); }; };

// Usage router.get( "/users", asyncHandler(async (req, res) => { const users = await userService.findAll(); res.json(users); }) );

Best Practices

  • Use custom error classes

  • Distinguish operational vs programming errors

  • Log all errors with context

  • Never expose stack traces to clients

  • Include trace IDs for debugging

  • Monitor error rates by type

  • Set up alerting for critical errors

Output Checklist

  • Custom error classes defined

  • Error handler middleware

  • HTTP status code mapping

  • Structured logging setup

  • Safe client error messages

  • Async error wrapper

  • Error monitoring/alerts

  • Documentation of error codes

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

General

framer-motion-animator

No summary provided by upstream source.

Repository SourceNeeds Review
General

eslint-prettier-config

No summary provided by upstream source.

Repository SourceNeeds Review
General

postman-collection-generator

No summary provided by upstream source.

Repository SourceNeeds Review
General

nginx-config-optimizer

No summary provided by upstream source.

Repository SourceNeeds Review