Почему Winston 3.0.0 не работает с Sails 0.12?

У меня эти настройки в файле config/log.js

let {transports: transp, createLogger} = require('winston');    
let commonSettings = {
    colorize: false,
    maxsize: 10000000,
    maxfiles: 10,
    timestamp: true
};

let settings = [{ filename: 'logs/warn.log', level: 'warn' }];    
let logger = createLogger({
    transports: settings.map(s => new transp.File({...s, ...commonSettings}))
});

module.exports.log = {
    custom: logger,
    inspect: false
};

Когда я пытаюсь запустить сервер Sails с помощью этой команды sails lift, я получаю следующую ошибку:

Uncaught TypeError: this.write is not a function
  at Function.DerivedLogger.(anonymous function) (node_modules/winston/lib/winston/create-logger.js:45:14)
  at Function._writeLogToConsole [as error] (node_modules/captains-log/lib/write.js:78:16)
  at Sails.runBootstrap (node_modules/sails/lib/app/private/bootstrap.js:56:17)
  at Sails.bound [as runBootstrap] (node_modules/sails/node_modules/lodash/dist/lodash.js:729:21)
  at Sails.initialize (node_modules/sails/lib/app/private/initialize.js:48:9)
  at bound (node_modules/sails/node_modules/lodash/dist/lodash.js:729:21)
  at /Users/egomezr/Documents/stack/backend/node_modules/sails/node_modules/async/lib/async.js:607:21
  at /Users/egomezr/Documents/stack/backend/node_modules/sails/node_modules/async/lib/async.js:246:17
  at iterate (node_modules/sails/node_modules/async/lib/async.js:146:13)
  at /Users/egomezr/Documents/stack/backend/node_modules/sails/node_modules/async/lib/async.js:157:25
  at /Users/egomezr/Documents/stack/backend/node_modules/sails/node_modules/async/lib/async.js:248:21
  at /Users/egomezr/Documents/stack/backend/node_modules/sails/node_modules/async/lib/async.js:612:34
  at /Users/egomezr/Documents/stack/backend/node_modules/sails/lib/app/load.js:201:13
  at /Users/egomezr/Documents/stack/backend/node_modules/sails/node_modules/async/lib/async.js:451:17
  at /Users/egomezr/Documents/stack/backend/node_modules/sails/node_modules/async/lib/async.js:441:17
  at _each (node_modules/sails/node_modules/async/lib/async.js:46:13)
  at Immediate.taskComplete (node_modules/sails/node_modules/async/lib/async.js:440:13)
  at process.topLevelDomainCallback (domain.js:101:23)

В чем может быть проблема?


person Ele    schedule 11.03.2018    source источник
comment
Вы уверены, что следуете документам для вер. 3.0.0? Например, для создания транспорта в качестве аргументов требуются только путь и уровень, а не то, что вы указываете.   -  person logout    schedule 12.03.2018
comment
@logout Я уверен, что эти настройки действительны.   -  person Ele    schedule 12.03.2018


Ответы (2)


Похоже, что Sails делает своего рода привязку к логгеру Winston, поэтому логгер теряет некоторые функции.

Открытая проблема: issues/4337

Я нашел обходной путь, чтобы заставить его работать:

let commonSettings = {
    colorize: false,
    maxsize: 10000000,
    maxfiles: 10,
    json: false
};

let settings = [
    {filename: `${__dirname}/../logs/warn.log`, level: 'warn'},
    {filename: `${__dirname}/../logs/error.log`, level: 'error'},
    {filename: `${__dirname}/../logs/debug.log`, level: 'debug'},
    {filename: `${__dirname}/../logs/info.log`, level: 'info'}
];

let {transports, createLogger, format} = require('winston');
let loggerSettings = {
    transports: [...settings.map(s => new transports.File({...s, ...commonSettings})), new transports.Console({
        format: format.simple()
    })],
    exitOnError: false
};

// This is the workaround
let winstonLogger = createLogger(loggerSettings);
let logger = {
    'info': function () {
        winstonLogger.info(...arguments);
    },
    'debug': function () {
        winstonLogger.debug(...arguments);
    },
    'error': function () {
        winstonLogger.error(...arguments);
    },
    'warn': function () {
        winstonLogger.warn(...arguments);
    },
    'log': function () {
        winstonLogger.log(...arguments);
    }
};
// End of workaround

module.exports.log = {
    custom: logger,
    inspect: false
};
person Ele    schedule 12.03.2018

Что бы это ни стоило, похоже, что о нем сообщили в выпусках Sails, но он был случайно закрыт в https://github.com/balderdashy/sails/issues/4209.

person Chris Cowdery-Corvan    schedule 13.03.2018
comment
Да, я думаю, было бы неплохо снова открыть этот вопрос. Открытая проблема: issues/4337 - person Ele; 13.03.2018