Skip to content

Forked and child loggers

We're providing two ways to create a new logger instance based on the existing one:

  • .fork() - creates a copy of the logger with the same params as the original one, but with the ability to override them.
  • .child() - creates a nested branded logger with optionally overridden params.

.fork(params?)

typescript
const logger = createLogger({
  name: 'my-logger',
  meta: {
    // ... some meta
  },
  level: 'info'
});

const fork = logger.fork({
  level: 'debug'
});

logger.debug('debug'); // SKIP
fork.debug('debug'); // [my-logger] debug
const logger = createLogger({
  name: 'my-logger',
  meta: {
    // ... some meta
  },
  level: 'info'
});

const fork = logger.fork({
  level: 'debug'
});

logger.debug('debug'); // SKIP
fork.debug('debug'); // [my-logger] debug

.child(name, params?)

Merging name with the parent name:

typescript
const logger = createLogger({
  name: 'foo'
});

const child = logger.child('bar');

child.info('info'); // [foo:bar] info
const logger = createLogger({
  name: 'foo'
});

const child = logger.child('bar');

child.info('info'); // [foo:bar] info

Override params

typescript
const child = logger.child('child-logger', {
  level: 'debug',
  meta: {
    service: 'my-service'
  }
});
const child = logger.child('child-logger', {
  level: 'debug',
  meta: {
    service: 'my-service'
  }
});

Released under the MIT License.