|  | // Copyright (c) 2016, Compiler Explorer Authors | 
|  | // All rights reserved. | 
|  | // | 
|  | // Redistribution and use in source and binary forms, with or without | 
|  | // modification, are permitted provided that the following conditions are met: | 
|  | // | 
|  | //     * Redistributions of source code must retain the above copyright notice, | 
|  | //       this list of conditions and the following disclaimer. | 
|  | //     * Redistributions in binary form must reproduce the above copyright | 
|  | //       notice, this list of conditions and the following disclaimer in the | 
|  | //       documentation and/or other materials provided with the distribution. | 
|  | // | 
|  | // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | 
|  | // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | 
|  | // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | 
|  | // ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE | 
|  | // LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR | 
|  | // CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF | 
|  | // SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS | 
|  | // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN | 
|  | // CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) | 
|  | // ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE | 
|  | // POSSIBILITY OF SUCH DAMAGE. | 
|  |  | 
|  | import os from 'os'; | 
|  |  | 
|  | import tripleBeam from 'triple-beam'; | 
|  | import winston from 'winston'; | 
|  | import winstonPapertrail from 'winston-papertrail'; | 
|  | import TransportStream from 'winston-transport'; | 
|  |  | 
|  | const { Papertrail } = winstonPapertrail, { LEVEL, MESSAGE } = tripleBeam; | 
|  |  | 
|  | const consoleTransportInstance = new (winston.transports.Console)(); | 
|  | export const logger = winston.createLogger({ | 
|  | format: winston.format.combine( | 
|  | winston.format.colorize(), | 
|  | winston.format.splat(), | 
|  | winston.format.simple()), | 
|  | transports: [consoleTransportInstance], | 
|  | }); | 
|  |  | 
|  | logger.stream = { | 
|  | write: message => { | 
|  | logger.info(message.trim()); | 
|  | }, | 
|  | }; | 
|  |  | 
|  | logger.warnStream = { | 
|  | write: message => { | 
|  | logger.warn(message.trim()); | 
|  | }, | 
|  | }; | 
|  |  | 
|  | logger.errStream = { | 
|  | write: message => { | 
|  | logger.error(message.trim()); | 
|  | }, | 
|  | }; | 
|  |  | 
|  | // Our own transport which uses Papertrail under the hood but better adapts it to work | 
|  | // in winston 3.0 | 
|  | class MyPapertrailTransport extends TransportStream { | 
|  | constructor(opts) { | 
|  | super(opts); | 
|  |  | 
|  | this.hostname = os.hostname(); | 
|  | this.program = opts.identifier; | 
|  |  | 
|  | this.transport = new Papertrail( | 
|  | { | 
|  | host: opts.host, | 
|  | port: opts.port, | 
|  | logFormat: (level, message) => message, | 
|  | }, | 
|  | ); | 
|  | } | 
|  |  | 
|  | log(info, callback) { | 
|  | setImmediate(() => { | 
|  | this.emit('logged', info); | 
|  | }); | 
|  |  | 
|  | // We can't use callback here as winston-papertrail is a bit lax in calling it back | 
|  | this.transport.sendMessage(this.hostname, this.program, info[LEVEL], info[MESSAGE], (x) => x); | 
|  | callback(); | 
|  | } | 
|  | } | 
|  |  | 
|  | export function logToPapertrail(host, port, identifier) { | 
|  | const transport = new MyPapertrailTransport({ | 
|  | host: host, port: port, identifier: identifier, | 
|  | }); | 
|  | transport.transport.on('error', (err) => { | 
|  | logger.error(err); | 
|  | }); | 
|  |  | 
|  | transport.transport.on('connect', (message) => { | 
|  | logger.info(message); | 
|  | }); | 
|  | logger.add(transport); | 
|  | logger.info('Configured papertrail'); | 
|  | } | 
|  |  | 
|  | export function suppressConsoleLog() { | 
|  | consoleTransportInstance.silent = true; | 
|  | } |