Skip to content

croct-tech/logging-js

Repository files navigation

Croct
Logging
An interoperability layer for logging libraries.

Version Build

📦 Releases · 🐞 Report Bug · ✨ Request Feature

Installation

We recommend using NPM to install the package:

npm install @croct/logging

Basic usage

The following example shows how to log a message using the ConsoleLogger:

import {ConsoleLogger, LogLevel} from '@croct/logging';

const logger = new ConsoleLogger();

logger.log({
    level: LogLevel.ERROR,
    message: 'Unable to load data',
    details: { 
        cause: 'The request failed',
        status: 500,
    },
});

Implementations

This package provides the following implementations:

  • SuppressedLogger
    A logger that does not log anything, but can be used to suppress logging where desired.
  • ConsoleLogger
    A logger that writes to the console using the appropriate console API semantics.
  • PrefixedLogger
    A logger that prepends a prefix to all log messages.
  • InMemoryLogger
    A logger that stores all log messages in memory.

Utilities

Because JavaScript allows throwing pretty much anything, proving more information about the error often requires some boilerplate code.

This package provides a few utilities to make it easier to log errors:

Contributing

Contributions to the package are always welcome!

  • Report any bugs or issues on the issue tracker.
  • For major changes, please open an issue first to discuss what you would like to change.
  • Please make sure to update tests as appropriate.

Testing

Before running the test suites, the development dependencies must be installed:

npm install

Then, to run all tests:

npm run test

Run the following command to check the code against the style guide:

npm run lint

Building

Before building the project, the dependencies must be installed:

npm install

Then, to build the CommonJS module:

npm run build

License

Copyright © 2015-2022 Croct Limited, All Rights Reserved.

All information contained herein is, and remains the property of Croct Limited. The intellectual, design and technical concepts contained herein are proprietary to Croct Limited s and may be covered by U.S. and Foreign Patents, patents in process, and are protected by trade secret or copyright law. Dissemination of this information or reproduction of this material is strictly forbidden unless prior written permission is obtained from Croct Limited.