pg-error-enum
v0.7.3
Published
TypeScript Enum for Postgres Errors with no runtime dependencies
Downloads
140,995
Readme
pg-error-enum
TypeScript Enum for Postgres Errors with no runtime dependencies. Also compatible with plain JavaScript.
Quick Start
Installation
# Using npm
npm install --save pg-error-enum
# Using yarn
yarn add pg-error-enum
Usage
TypeScript or ES6 Modules
import { PostgresError } from "pg-error-enum";
JavaScript
const PostgresError = require("pg-error-enum").PostgresError;
Usage
if (error.code === PostgresError.UNIQUE_VIOLATION) {
throw new Error("That username is taken");
}
Generation
The Enum is generated directly from errcodes.txt in the Postgres repository.
It follows the syntax defined in the text file, i.e., in short:
Lines beginning with
#
and empty lines are ignored.Sections are parsed using:
const sectionRegex = /^Section:\s(?<description>.*)$/;
Each error code is parsed using:
const errorLineRegex = /^(?<sqlstate>[A-Z0-9]*)\s*(?<severity>[EWS])\s*ERRCODE_(?<constant>[A-Z_]*)\s*(?<code>[a-z_]*)$/;