npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

apicustomerrors

v1.4.0

Published

Modulo para manejar los diferentes tipos de errores que hay a la hora de desarrollar una API

Downloads

49

Readme

Api custom errors

Este paquete proporciona una serie de clases de error personalizadas para manejar diferentes tipos de errores HTTP en aplicaciones JavaScript. Estas clases extienden la clase Error nativa de JavaScript, proporcionando una manera estructurada de manejar errores en tu aplicación 0 dependencias adicionales.

Clases Disponibles

El paquete incluye las siguientes clases de error personalizadas:

  • BAD_REQUEST_ERROR: Para errores de solicitud incorrecta (400).
  • UNAUTHORIZED_ERROR: Para errores de no autorizado (401).
  • FORBIDDEN_ERROR: Para errores de prohibido (403).
  • NOT_FOUND_ERROR: Para errores de recurso no encontrado (404).
  • METHOD_NOT_ALLOWED_ERROR: Para errores de método no permitido (405).
  • TOO_MANY_REQUESTS_ERROR: Para errores de demasiadas solicitudes (429).
  • CONFLICT_ERROR: Para errores de conflicto (409).
  • UNSUPPORTED_MEDIA_TYPE_ERROR: Para errores de tipo de medio no soportado (415).
  • INTERNAL_SERVER_ERROR: Para errores internos del servidor (500).
  • SERVICE_UNAVAILABLE_ERROR: Para errores de servicio no disponible (503).

Cada clase de error incluye un name personalizado, un statusCode correspondiente al error HTTP, y un mensaje de error opcional.

Instalación

npm i apicustomerrors

Uso

Para usar una de las clases de error en tu aplicación, primero debes importarla:

import { BAD_REQUEST_ERROR, UNAUTHORIZED_ERROR, FORBIDDEN_ERROR } from 'apicustomerrors';

Luego, puedes utilizar estas clases para lanzar errores en tu aplicación:

function validarUsuario(usuario) {
  if (!usuario) {
    throw new UNAUTHORIZED_ERROR('Usuario no autorizado.');
  }
}

try {
  validarUsuario(null);
} catch (error) {
  console.error(error.statusCode); // 401
  console.error(error.message); // Usuario no autorizado.
}