@openstapps/logger
TypeScript icon, indicating that this package has built-in type declarations

3.0.0 • Public • Published

@openstapps/logger

pipeline status coverage report

This is a simple logger for TypeScript projects with transformations for the log output.

Logs are only printed if their log level is equal or higher than the defined log level.

Log Levels

Available log levels are:

  • 1 - INFO
  • 2 - LOG
  • 4 - WARN
  • 8 - ERROR
  • 16 - OK

You can set your log level with the environment variable STAPPS_LOG_LEVEL.

To select your desired log levels add the corresponding numbers and set the value of STAPPS_LOG_LEVEL to the sum.

For example STAPPS_LOG_LEVEL=17 is 16 + 1 and would log everything that is OK or INFO.

If you want to use logger in production (NODE_ENV=production) and allow all transports to fail set ALLOW_NO_TRANSPORT to true.

Additionally setting the environment variable STAPPS_EXIT_LEVEL which works in the same manner as STAPPS_LOG_LEVEL will terminate your process after logging at the selected level(s) (usefull for integration tests). It will be ignored in afore mentioned productive environments.

SMTP

This class also provides a simple implementation of an SMTP transport which can be used as a TransportWithVerification for the logger. You can use this to transport errors of the logger or to transport mails of your own monitoring solution.

Usage

You can instatiate it with a config or it will check for a config in the environment variables. Environment variables can overwrite the actual config values.

Environment variables are:

  • SMTP_AUTH_USER: SMTP username
  • SMTP_AUTH_PASSWORD: SMTP password
  • SMTP_HOST: SMTP host
  • SMTP_PORT: SMTP port
  • SMTP_RECIPIENTS: comma seperated list of recipients
  • SMTP_CC: comma seperated list of recipients for the carbon copy (CC)
  • SMTP_SENDER_MAIL: sender of the mail
  • SMTP_SENDER_NAME: name of the sender
  • SMTP_SECURE: true to enable tls

Transformations

By default the logger will only add the log level to the message. It will replace newlines with spaces and might skip some of your choosen Transformers when in production (NODE_ENV=production) for compatibility reasons with existing log aggregators and analyzers.

You can change this behavior by setting other Transformers via Logger.setTransformations. If you do so, mind the order of the transformers.

You may choose from the following:

  • AddLogLevel, which prepends the output with the log level
  • Colorize, which colorizes the output according to the log level
  • Timestamp, which prepends a timestamp to the output

Readme

Keywords

none

Package Sidebar

Install

npm i @openstapps/logger

Weekly Downloads

222

Version

3.0.0

License

GPL-3.0-only

Unpacked Size

131 kB

Total Files

8

Last publish

Collaborators

  • openstappspublisher
  • abcdev
  • jovankrunic