You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							124 lines
						
					
					
						
							3.2 KiB
						
					
					
				
			
		
		
	
	
							124 lines
						
					
					
						
							3.2 KiB
						
					
					
				| 'use strict'
 | |
| 
 | |
| /**
 | |
|  * Code imported from `pino-http`
 | |
|  * Repo: https://github.com/pinojs/pino-http
 | |
|  * License: MIT (https://raw.githubusercontent.com/pinojs/pino-http/master/LICENSE)
 | |
|  */
 | |
| 
 | |
| const nullLogger = require('abstract-logging')
 | |
| const pino = require('pino')
 | |
| const { serializersSym } = pino.symbols
 | |
| const { FST_ERR_LOG_INVALID_DESTINATION } = require('./errors')
 | |
| 
 | |
| function createPinoLogger (opts, stream) {
 | |
|   stream = stream || opts.stream
 | |
|   delete opts.stream
 | |
| 
 | |
|   if (stream && opts.file) {
 | |
|     throw new FST_ERR_LOG_INVALID_DESTINATION()
 | |
|   } else if (opts.file) {
 | |
|     // we do not have stream
 | |
|     stream = pino.destination(opts.file)
 | |
|     delete opts.file
 | |
|   }
 | |
| 
 | |
|   const prevLogger = opts.logger
 | |
|   const prevGenReqId = opts.genReqId
 | |
|   let logger = null
 | |
| 
 | |
|   if (prevLogger) {
 | |
|     opts.logger = undefined
 | |
|     opts.genReqId = undefined
 | |
|     // we need to tap into pino internals because in v5 it supports
 | |
|     // adding serializers in child loggers
 | |
|     if (prevLogger[serializersSym]) {
 | |
|       opts.serializers = Object.assign({}, opts.serializers, prevLogger[serializersSym])
 | |
|     }
 | |
|     logger = prevLogger.child({}, opts)
 | |
|     opts.logger = prevLogger
 | |
|     opts.genReqId = prevGenReqId
 | |
|   } else {
 | |
|     logger = pino(opts, stream)
 | |
|   }
 | |
| 
 | |
|   return logger
 | |
| }
 | |
| 
 | |
| const serializers = {
 | |
|   req: function asReqValue (req) {
 | |
|     return {
 | |
|       method: req.method,
 | |
|       url: req.url,
 | |
|       version: req.headers && req.headers['accept-version'],
 | |
|       hostname: req.hostname,
 | |
|       remoteAddress: req.ip,
 | |
|       remotePort: req.socket ? req.socket.remotePort : undefined
 | |
|     }
 | |
|   },
 | |
|   err: pino.stdSerializers.err,
 | |
|   res: function asResValue (reply) {
 | |
|     return {
 | |
|       statusCode: reply.statusCode
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| function now () {
 | |
|   const ts = process.hrtime()
 | |
|   return (ts[0] * 1e3) + (ts[1] / 1e6)
 | |
| }
 | |
| 
 | |
| function createLogger (options) {
 | |
|   if (isValidLogger(options.logger)) {
 | |
|     const logger = createPinoLogger({
 | |
|       logger: options.logger,
 | |
|       serializers: Object.assign({}, serializers, options.logger.serializers)
 | |
|     })
 | |
|     return { logger, hasLogger: true }
 | |
|   } else if (!options.logger) {
 | |
|     const logger = nullLogger
 | |
|     logger.child = () => logger
 | |
|     return { logger, hasLogger: false }
 | |
|   } else {
 | |
|     const localLoggerOptions = {}
 | |
|     if (Object.prototype.toString.call(options.logger) === '[object Object]') {
 | |
|       Reflect.ownKeys(options.logger).forEach(prop => {
 | |
|         Object.defineProperty(localLoggerOptions, prop, {
 | |
|           value: options.logger[prop],
 | |
|           writable: true,
 | |
|           enumerable: true,
 | |
|           configurable: true
 | |
|         })
 | |
|       })
 | |
|     }
 | |
|     localLoggerOptions.level = localLoggerOptions.level || 'info'
 | |
|     localLoggerOptions.serializers = Object.assign({}, serializers, localLoggerOptions.serializers)
 | |
|     options.logger = localLoggerOptions
 | |
|     const logger = createPinoLogger(options.logger)
 | |
|     return { logger, hasLogger: true }
 | |
|   }
 | |
| }
 | |
| 
 | |
| function isValidLogger (logger) {
 | |
|   if (!logger) {
 | |
|     return false
 | |
|   }
 | |
| 
 | |
|   let result = true
 | |
|   const methods = ['info', 'error', 'debug', 'fatal', 'warn', 'trace', 'child']
 | |
|   for (let i = 0; i < methods.length; i += 1) {
 | |
|     if (!logger[methods[i]] || typeof logger[methods[i]] !== 'function') {
 | |
|       result = false
 | |
|       break
 | |
|     }
 | |
|   }
 | |
|   return result
 | |
| }
 | |
| 
 | |
| module.exports = {
 | |
|   createLogger,
 | |
|   serializers,
 | |
|   now
 | |
| }
 |