log.js 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. 'use strict';
  2. var bunyan = require('hexo-bunyan');
  3. var chalk = require('chalk');
  4. var Writable = require('stream').Writable;
  5. var levelNames = {
  6. 10: 'TRACE',
  7. 20: 'DEBUG',
  8. 30: 'INFO ',
  9. 40: 'WARN ',
  10. 50: 'ERROR',
  11. 60: 'FATAL'
  12. };
  13. var levelColors = {
  14. 10: 'gray',
  15. 20: 'gray',
  16. 30: 'green',
  17. 40: 'bgYellow',
  18. 50: 'bgRed',
  19. 60: 'bgRed'
  20. };
  21. function ConsoleStream(env) {
  22. Writable.call(this, {objectMode: true});
  23. this.debug = env.debug;
  24. }
  25. require('util').inherits(ConsoleStream, Writable);
  26. ConsoleStream.prototype._write = function(data, enc, callback) {
  27. var level = data.level;
  28. var msg = '';
  29. // Time
  30. if (this.debug) {
  31. msg += chalk.gray(formatTime(data.time)) + ' ';
  32. }
  33. // Level
  34. msg += chalk[levelColors[level]](levelNames[level]) + ' ';
  35. // Message
  36. msg += data.msg + '\n';
  37. // Error
  38. if (data.err) {
  39. var err = data.err.stack || data.err.message;
  40. if (err) msg += chalk.yellow(err) + '\n';
  41. }
  42. if (level >= 40) {
  43. process.stderr.write(msg);
  44. } else {
  45. process.stdout.write(msg);
  46. }
  47. callback();
  48. };
  49. function formatTime(date) {
  50. return date.toISOString().substring(11, 23);
  51. }
  52. function createLogger(options) {
  53. options = options || {};
  54. var streams = [];
  55. if (!options.silent) {
  56. streams.push({
  57. type: 'raw',
  58. level: options.debug ? 'trace' : 'info',
  59. stream: new ConsoleStream(options)
  60. });
  61. }
  62. if (options.debug) {
  63. streams.push({
  64. level: 'trace',
  65. path: 'debug.log'
  66. });
  67. }
  68. var logger = bunyan.createLogger({
  69. name: options.name || 'hexo',
  70. streams: streams,
  71. serializers: {
  72. err: bunyan.stdSerializers.err
  73. }
  74. });
  75. // Alias for logger levels
  76. logger.d = logger.debug;
  77. logger.i = logger.info;
  78. logger.w = logger.warn;
  79. logger.e = logger.error;
  80. logger.log = logger.info;
  81. return logger;
  82. }
  83. module.exports = createLogger;