Skip to content

Files

Latest commit

217cb15 · Oct 29, 2024

History

History
89 lines (62 loc) · 3.33 KB

readme.md

File metadata and controls

89 lines (62 loc) · 3.33 KB

Gamu Logger - Javascript Version

🏠 Main page | 🐍 Python | 🌐 Javascript

📚 Table of Contents

🔨 Installation

install the package using npm:

npm install @gamunetwork/logger

💡 Usage

  • first you need to import the package:
    import { info, warning, error } from '@gamunetwork/logger';
  • then you can use the functions like this:
    info('This is an info message');
    warning('This is a warning message');
    error('This is an error message');

You may note that the logging function are also available as static methods in the Logger class. This allow you to have them encapsulated in a class and use them in a more object oriented way:

import { Logger } from '@gamunetwork/logger';

Logger.info('This is an info message');
Logger.warning('This is a warning message');
Logger.error('This is an error message');

⚙️ Configuration

You can configure the logger using the Logger class. Here is an example of how you can do it:

import { Logger, LEVELS, SENSITIVE_LEVELS } from '@gamunetwork/logger';

// default target is standard output, named 'stdout'

Logger.setLevel("stdout", LEVELS.INFO); // all logs with level less than INFO will be ignored

Logger.setSensitiveLevel("stdout", SENSITIVE_LEVELS.HIDE); // If a log message contains sensitive data, it will be hidden

Logger.addSensitiveData('password'); // add 'password' to the tdst of sensitive data (if a log message contains 'password', it will be hidden)

Logger.setModule('my-module'); // set the module name for the current file to 'my-module' (this will be displayed in the log message) (by default, no module name is set)

Please note that the logger can be used without any configuration. The default configuration is:

  • target: stdout
    • level: INFO
    • sensitive mode: HIDE
  • sensitive data: []
  • module name: None

Note also that the module name is set only for the current file. If you want to set the module name for all files, you need to set it in each file. From 2.1.0, sub-modules are supported. You can set the module name for a sub-module like this:

Logger.setModule('my-module.sub-module');

Warning: You can nest as many as sub-modules you want, but keep in mind this will increase significantly the length of every log message. This can make the log messages harder to read. So, use sub-modules wisely.

📁 Examples

you can find examples in the example directory.

  • example 1 - very simple calculator
  • example 2 - web server using express, implementing modules

📜 License

This project is licensed under the MIT License - see the LICENSE file for details.