Skip to content
Snippets Groups Projects
Select Git revision
  • ce34a5530d2c4c9623c3adbb8ece6f1d37c47d74
  • main default protected
  • renovate/main-renovatebot-github-action-43.x
  • next
  • renovate/main-containerbase-internal-tools-3.x
  • renovate/main-lock-file-maintenance
  • renovate/main-docs-renovate-renovate-41.x
  • feat/gnupg
  • fix/36615b-branch-reuse-no-cache
  • renovate/main-redis-5.x
  • chore/punycode
  • refactor/pin-new-value
  • feat/36219--git-x509-signing
  • feat/structured-logger
  • hotfix/39.264.1
  • feat/skip-dangling
  • gh-readonly-queue/next/pr-36034-7a061c4ca1024a19e2c295d773d9642625d1c2be
  • hotfix/39.238.3
  • refactor/gitlab-auto-approve
  • feat/template-strings
  • gh-readonly-queue/next/pr-35654-137d934242c784e0c45d4b957362214f0eade1d7
  • 41.43.5
  • 41.43.4
  • 41.43.3
  • 41.43.2
  • 41.43.1
  • 41.43.0
  • 41.42.12
  • 41.42.11
  • 41.42.10
  • 41.42.9
  • 41.42.8
  • 41.42.7
  • 41.42.6
  • 41.42.5
  • 41.42.4
  • 41.42.3
  • 41.42.2
  • 41.42.1
  • 41.42.0
  • 41.41.0
41 results

pretty-stdout.ts

Blame
  • user avatar
    RahulGautamSingh authored and GitHub committed
    Co-authored-by: default avatarRhys Arkins <rhys@arkins.net>
    Co-authored-by: default avatarMichael Kriese <michael.kriese@visualon.de>
    ee2e155f
    History
    pretty-stdout.ts 2.49 KiB
    // Code originally derived from https://github.com/hadfieldn/node-bunyan-prettystream but since heavily edited
    // Neither fork nor original repo appear to be maintained
    
    import { Stream } from 'stream';
    import * as util from 'util';
    import chalk from 'chalk';
    import stringify from 'json-stringify-pretty-compact';
    import type { BunyanRecord } from './types';
    
    const bunyanFields = [
      'name',
      'hostname',
      'pid',
      'level',
      'v',
      'time',
      'msg',
      'start_time',
    ];
    const metaFields = [
      'repository',
      'packageFile',
      'depType',
      'dependency',
      'dependencies',
      'branch',
    ];
    
    const levels: Record<number, string> = {
      10: chalk.gray('TRACE'),
      20: chalk.blue('DEBUG'),
      30: chalk.green(' INFO'),
      40: chalk.magenta(' WARN'),
      50: chalk.red('ERROR'),
      60: chalk.bgRed('FATAL'),
    };
    
    export function indent(str: string, leading = false): string {
      const prefix = leading ? '       ' : '';
      return prefix + str.split(/\r?\n/).join('\n       '); // TODO #12874
    }
    
    export function getMeta(rec: BunyanRecord): string {
      if (!rec) {
        return '';
      }
      let res = rec.module ? ` [${rec.module}]` : ``;
      const filteredMeta = metaFields.filter((elem) => rec[elem]);
      if (!filteredMeta.length) {
        return res;
      }
      const metaStr = filteredMeta
        .map((field) => `${field}=${String(rec[field])}`)
        .join(', ');
      res = ` (${metaStr})${res}`;
      return chalk.gray(res);
    }
    
    export function getDetails(rec: BunyanRecord): string {
      if (!rec) {
        return '';
      }
      const recFiltered = { ...rec };
      delete recFiltered.module;
      Object.keys(recFiltered).forEach((key) => {
        if (
          key === 'logContext' ||
          bunyanFields.includes(key) ||
          metaFields.includes(key)
        ) {
          delete recFiltered[key];
        }
      });
      const remainingKeys = Object.keys(recFiltered);
      if (remainingKeys.length === 0) {
        return '';
      }
      return `${remainingKeys
        .map((key) => `${indent(`"${key}": ${stringify(recFiltered[key])}`, true)}`)
        .join(',\n')}\n`;
    }
    
    export function formatRecord(rec: BunyanRecord): string {
      const level = levels[rec.level];
      const msg = `${indent(rec.msg)}`;
      const meta = getMeta(rec);
      const details = getDetails(rec);
      return util.format('%s: %s%s\n%s', level, msg, meta, details);
    }
    
    export class RenovateStream extends Stream {
      readable: boolean;
    
      writable: boolean;
    
      constructor() {
        super();
        this.readable = true;
        this.writable = true;
      }
    
      // istanbul ignore next
      write(data: BunyanRecord): boolean {
        this.emit('data', formatRecord(data));
        return true;
      }
    }