4.1.0 • Published 12 months ago

gracy v4.1.0

Weekly downloads
-
License
MIT
Repository
github
Last release
12 months ago

gracy

CI status license npm version

Gracy is a zero-dependency library that provides a simple way to execute custom function before a Node.js process exits. It helps you ensure that your applications perform cleanup tasks, gracefully close resources, and maintain data integrity during (un)expected shutdowns or terminations.

Installation

pnpm i -E gracy

Usage

import { onExit } from 'gracy'

onExit(
    async () => {
        closeHttpServer()
        await closeDatabaseConnection()
    },
    { logger: pinoInstance }
)

Configuration

The onExit function accepts an configuration object as its second argument. The following options are available:

NameDefault valueDescription
loggerconsoleLogger to use. You should use libraries for structured logging such as pino. Set to false to disable logging.
logLevel'info'Log level to use. Valid options are 'debug', 'info', 'error'.
logPrefix'[gracy] 'Prefix to use for log messages. Set to empty string to disable prefixing.
timeout10_000Timeout (in milliseconds) to wait for the function to finish. If the function does not finish in time, the process will exit with code 1.
events['uncaughtException', 'unhandledRejection']Events to listen to. Triggering these events will cause the process to exit with code 1.
signals['SIGTERM', 'SIGINT']Signals to listen to. Triggering these signals will cause the process to exit with code 0.

License

MIT

4.1.0

12 months ago

3.0.1

1 year ago

4.0.0

1 year ago

3.0.0

1 year ago

2.1.1

1 year ago

2.0.2

2 years ago

2.1.0

1 year ago

2.0.1

2 years ago

2.0.0

2 years ago

1.0.2

2 years ago

1.0.1

2 years ago

1.0.0

2 years ago