logger

Un Sumor Cloud Outil.
Plus de Documentation

Il s'agit d'un journal léger pour Node.JS. Il peut afficher des journaux à différents niveaux et vous pouvez personnaliser la portée, l'identifiant et le fuseau horaire.

CI Test Coverage Audit

Installation

npm i @sumor/logger --save

Prérequis

Version de Node.JS

Nécessite la version Node.JS 16.x ou supérieure

Requérir le module ES de Node.JS

Comme ce package est écrit en module ES, veuillez modifier le code suivant dans votre fichier package.json :

{
  "type": "module"
}

Utilisation

Utilisation Générale

import Logger from '@sumor/logger'
const logger = new Logger()

logger.trace('Bonjour le Monde!')
// Vous verrez la sortie suivante :
// 2020-01-01 00:00:00.000 TRACE MAIN - Bonjour le Monde!

Changer la Portée

Pour certains cas, nous avons besoin de catégoriser les journaux. scope est utilisé à cette fin.

import Logger from '@sumor/logger'
const logger = new Logger({
  scope: 'DEMO'
})
logger.trace('Bonjour le Monde!')
// Vous verrez la sortie suivante :
// 2020-01-01 00:00:00.000 TRACE DEMO - Bonjour le Monde!

Identifier l'Utilisateur

Pour certains cas, nous avons besoin d'identifier l'utilisateur. id est utilisé à cette fin.

import Logger from '@sumor/logger'
const logger = new Logger({
  id: 'USER001'
})
logger.trace('Bonjour le Monde!')
// Vous verrez la sortie suivante :
// 2020-01-01 00:00:00.000 TRACE MAIN USER001 - Bonjour le Monde!

Changer le Niveau

La plupart du temps, nous avons seulement besoin de sortir les journaux d'un certain niveau. Ensuite, nous pouvons décider de les stocker et de les afficher ou non.

import Logger from '@sumor/logger'
const logger = new Logger()
logger.trace('Bonjour le Monde!') // trace est le niveau le plus bas, tous les journaux seront affichés
logger.debug('Bonjour le Monde!')
logger.info('Bonjour le Monde!')
logger.warn('Bonjour le Monde!')
logger.error('Bonjour le Monde!')
logger.fatal('Bonjour le Monde!') // fatal est le niveau le plus élevé, seules les erreurs critiques seront affichées

Changer le Fuseau Horaire

import Logger from '@sumor/logger'
const logger1 = new Logger({
  offset: 2 * 60 // le décalage UTC+2 est de 2 heures
})
logger1.info('Bonjour le Monde!')
// Vous verrez la sortie suivante :
// 2020-01-01 02:00:00.000 INFO MAIN - Bonjour le Monde!

const logger2 = new Logger({
  offset: 8 * 60 // le décalage UTC+8 est de 8 heures
})
logger2.info('Bonjour le Monde!')
// Vous verrez la sortie suivante :
// 2020-01-01 08:00:00.000 INFO MAIN - Bonjour le Monde!

Code Prédéfini

import Logger from '@sumor/logger'
const code = {
  trace: {
    HTTP_ACCESS: 'L'utilisateur accède via HTTP et l'adresse IP est {ip}'
  },
  debug: {
    USER_TOKEN_LOADED: "Les informations de connexion de l'utilisateur sont lues et l'identifiant de l'utilisateur est {id}"
  },
  info: {
    USER_LOGIN: "L'utilisateur se connecte et l'identifiant de l'utilisateur est {id}"
  },
  warn: {
    USER_LOGOUT: "L'utilisateur se déconnecte et l'identifiant de l'utilisateur est {id}"
  },
  error: {
    USER_LOGIN_FAILED: "L'échec de la connexion de l'utilisateur et l'identifiant de l'utilisateur sont {id}"
  },
  fatal: {
    USER_LOGIN_BLOCKED: "La connexion de l'utilisateur est bloquée et l'identifiant de l'utilisateur est {id}"
  }
}
const i18n = {
  zh: {
    USER_LOGIN: "L'utilisateur se connecte et l'identifiant de l'utilisateur est {id}"
  }
}
const logger1 = new Logger({
  code,
  i18n
})

logger1.code('USER_LOGIN', { id: 'USER001' })
// Vous verrez la sortie suivante :
// 2020-01-01 00:00:00.000 INFO MAIN - L'utilisateur se connecte et l'identifiant de l'utilisateur est USER001

const logger2 = new Logger({
  code,
  i18n,
  language: 'zh-US'
})

logger2.code('USER_LOGIN', { id: 'USER001' })
// Vous verrez la sortie suivante :
// 2020-01-01 00:00:00.000 INFO MAIN - L'utilisateur se connecte et l'identifiant de l'utilisateur est USER001

const logger3 = new Logger({
  code,
  i18n,
  language: 'zh-CN'
})

logger3.code('USER_LOGIN', { id: 'USER001' })
// Vous verrez la sortie suivante :
// 2020-01-01 00:00:00.000 INFO MAIN - L'utilisateur se connecte et l'identifiant de l'utilisateur est USER001