projen
Version:
CDK for software projects
114 lines • 12.4 kB
JavaScript
;
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.LogLevel = exports.Logger = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const chalk = require("chalk");
const common_1 = require("./common");
const component_1 = require("./component");
const logging_1 = require("./logging");
const util_1 = require("./util");
const constructs_1 = require("./util/constructs");
/**
* Project-level logging utilities.
*/
class Logger extends component_1.Component {
constructor(scope, options = {}) {
const project = (0, constructs_1.findClosestProject)(scope);
super(scope, `${new.target.name}#${project.name}`);
// if we are running inside a test, default to no logs
const defaultLevel = common_1.IS_TEST_RUN ? LogLevel.OFF : LogLevel.INFO;
this.level = options.level ?? defaultLevel;
this.usePrefix = options.usePrefix ?? false;
}
/**
* Log a message to stderr with a given logging level. The message will be
* printed as long as `logger.level` is set to the message's severity or higher.
*
* @param level Logging verbosity
* @param text strings or objects to print
*/
log(level, ...text) {
if (level === LogLevel.OFF) {
throw new Error("Cannot log a message with level LogLevel.OFF");
}
let maxLevel = this.level;
// logging level can be overridden through the --debug CLI option
if ((0, util_1.isTruthy)(process.env.DEBUG) && maxLevel < LogLevel.DEBUG) {
maxLevel = LogLevel.DEBUG;
}
if (level <= maxLevel) {
const color = this.colorForLogLevel(level) ??
((...values) => values.join(" "));
const prefix = this.usePrefix ? `[${this.project.name}] ` : "";
console.error(`${logging_1.ICON} ${prefix}${color(...text)}`);
}
}
/**
* Log a message to stderr with VERBOSE severity
* @param text strings or objects to print
*/
verbose(...text) {
this.log(LogLevel.VERBOSE, ...text);
}
/**
* Log a message to stderr with DEBUG severity
* @param text strings or objects to print
*/
debug(...text) {
this.log(LogLevel.DEBUG, ...text);
}
/**
* Log a message to stderr with INFO severity
* @param text strings or objects to print
*/
info(...text) {
this.log(LogLevel.INFO, ...text);
}
/**
* Log a message to stderr with WARN severity
* @param text strings or objects to print
*/
warn(...text) {
this.log(LogLevel.WARN, ...text);
}
/**
* Log a message to stderr with ERROR severity
* @param text strings or objects to print
*/
error(...text) {
this.log(LogLevel.ERROR, ...text);
}
colorForLogLevel(level) {
switch (level) {
case LogLevel.ERROR:
return chalk.red;
case LogLevel.WARN:
return chalk.yellow;
case LogLevel.INFO:
return chalk.cyan;
case LogLevel.DEBUG:
return chalk.gray;
case LogLevel.VERBOSE:
return chalk.white;
default:
return chalk.white;
}
}
}
exports.Logger = Logger;
_a = JSII_RTTI_SYMBOL_1;
Logger[_a] = { fqn: "projen.Logger", version: "0.95.2" };
/**
* Logging verbosity.
*/
var LogLevel;
(function (LogLevel) {
LogLevel["OFF"] = "00.off";
LogLevel["ERROR"] = "10.error";
LogLevel["WARN"] = "20.warn";
LogLevel["INFO"] = "30.info";
LogLevel["DEBUG"] = "40.debug";
LogLevel["VERBOSE"] = "50.verbose";
})(LogLevel || (exports.LogLevel = LogLevel = {}));
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logger.js","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"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","sourcesContent":["import * as chalk from \"chalk\";\nimport { IConstruct } from \"constructs\";\nimport { IS_TEST_RUN } from \"./common\";\nimport { Component } from \"./component\";\nimport { ICON } from \"./logging\";\nimport { isTruthy } from \"./util\";\nimport { findClosestProject } from \"./util/constructs\";\n\n/**\n * Options for logging utilities.\n */\nexport interface LoggerOptions {\n  /**\n   * The logging verbosity. The levels available (in increasing verbosity) are\n   * OFF, ERROR, WARN, INFO, DEBUG, and VERBOSE.\n   *\n   * @default LogLevel.INFO\n   */\n  readonly level?: LogLevel;\n\n  /**\n   * Include a prefix for all logging messages with the project name.\n   *\n   * @default false\n   */\n  readonly usePrefix?: boolean;\n}\n\n/**\n * Project-level logging utilities.\n */\nexport class Logger extends Component {\n  private readonly level: LogLevel;\n  private readonly usePrefix: boolean;\n\n  constructor(scope: IConstruct, options: LoggerOptions = {}) {\n    const project = findClosestProject(scope);\n    super(scope, `${new.target.name}#${project.name}`);\n\n    // if we are running inside a test, default to no logs\n    const defaultLevel = IS_TEST_RUN ? LogLevel.OFF : LogLevel.INFO;\n\n    this.level = options.level ?? defaultLevel;\n    this.usePrefix = options.usePrefix ?? false;\n  }\n\n  /**\n   * Log a message to stderr with a given logging level. The message will be\n   * printed as long as `logger.level` is set to the message's severity or higher.\n   *\n   * @param level Logging verbosity\n   * @param text strings or objects to print\n   */\n  public log(level: LogLevel, ...text: any[]) {\n    if (level === LogLevel.OFF) {\n      throw new Error(\"Cannot log a message with level LogLevel.OFF\");\n    }\n\n    let maxLevel = this.level;\n\n    // logging level can be overridden through the --debug CLI option\n    if (isTruthy(process.env.DEBUG) && maxLevel < LogLevel.DEBUG) {\n      maxLevel = LogLevel.DEBUG;\n    }\n\n    if (level <= maxLevel) {\n      const color =\n        this.colorForLogLevel(level) ??\n        ((...values: string[]): string => values.join(\" \"));\n      const prefix = this.usePrefix ? `[${this.project.name}] ` : \"\";\n      console.error(`${ICON} ${prefix}${color(...text)}`);\n    }\n  }\n\n  /**\n   * Log a message to stderr with VERBOSE severity\n   * @param text strings or objects to print\n   */\n  public verbose(...text: any[]) {\n    this.log(LogLevel.VERBOSE, ...text);\n  }\n\n  /**\n   * Log a message to stderr with DEBUG severity\n   * @param text strings or objects to print\n   */\n  public debug(...text: any[]) {\n    this.log(LogLevel.DEBUG, ...text);\n  }\n\n  /**\n   * Log a message to stderr with INFO severity\n   * @param text strings or objects to print\n   */\n  public info(...text: any[]) {\n    this.log(LogLevel.INFO, ...text);\n  }\n\n  /**\n   * Log a message to stderr with WARN severity\n   * @param text strings or objects to print\n   */\n  public warn(...text: any[]) {\n    this.log(LogLevel.WARN, ...text);\n  }\n\n  /**\n   * Log a message to stderr with ERROR severity\n   * @param text strings or objects to print\n   */\n  public error(...text: any[]) {\n    this.log(LogLevel.ERROR, ...text);\n  }\n\n  private colorForLogLevel(level: LogLevel): chalk.ChalkFunction {\n    switch (level) {\n      case LogLevel.ERROR:\n        return chalk.red;\n      case LogLevel.WARN:\n        return chalk.yellow;\n      case LogLevel.INFO:\n        return chalk.cyan;\n      case LogLevel.DEBUG:\n        return chalk.gray;\n      case LogLevel.VERBOSE:\n        return chalk.white;\n      default:\n        return chalk.white;\n    }\n  }\n}\n\n/**\n * Logging verbosity.\n */\nexport enum LogLevel {\n  OFF = \"00.off\",\n  ERROR = \"10.error\",\n  WARN = \"20.warn\",\n  INFO = \"30.info\",\n  DEBUG = \"40.debug\",\n  VERBOSE = \"50.verbose\",\n}\n"]}