Skip to content

BlastillROID/winston-encrypted-socket.io

Repository files navigation

#winston-socket.io

Build Status Dependency Status Quality Gate Status Maintainability Rating Reliability Rating Security Rating Technical Debt Vulnerabilities

SonarCloud

A socket.io transport for winstonjs. Gives you the ability to log directly to a socket.io server.

##Options

  • host: The hostname of the socket.io server (default: http://localhost).
  • port: The port of the socket.io server (default: 3000).
  • secure: Use https for the socket.io server connection (default: false).
  • reconnect: Reconnect to socket.io server connection (default: false).
  • namespace: The socket.io namespace to use for the logs (default: "log").
  • log_topic: The topic to send the log messages on (default: "log").
  • encrypt: Choose to encrypt winston socket logs or not (default: false)
  • secret: the passphrase to encrypt logs with [needs encrypt to be true to allow changing it ] (default: null)
  • log_format: The format in which to log the information.
  • max_queue_size: The maximum number of messages to queue up for publishing if the client isnt connected to the server (default: 1000).

##How to use it

  const winston = require('winston');
  require('winston-socket.io');

  let logger = winston.createLogger({
    level: "info",
    transports: [
      new winston.transports.Console(),
      new winston.transports.SocketIO(
        {
          host: "http://myhost",
          port: 8080
          secure: true,
          reconnect: true,
          namespace: "log",
          log_topic: "log"
        }
      )
    ]
  });  

  logger.log("info", "I'm logging to the socket.io server!!!");

Can also be added to Winston as a transport in this method

  const winston = require('winston');
  require('winston-socket.io');

  winston.add(new winston.transports.SocketIO({
    host: "http://myhost",
    port: 8080
    secure: true,
    reconnect: true,
    namespace: "log",
    log_topic: "log"
  }));

##How to use encryption

  const winston = require('winston');
  require('winston-socket.io');

  let logger = winston.createLogger({
    level: "info",
    transports: [
      new winston.transports.Console(),
      new winston.transports.SocketIO(
        {
          host: "http://myhost",
          port: 8080
          secure: true,
          encrypt: true,
          secret: "secret",
          reconnect: true,
          namespace: "log",
          log_topic: "log"
        }
      )
    ]
  });  

  logger.log("info", "I'm logging encrypted data to the socket.io server!!!");

Decryption is done with the socket.io-encrypt package

io.use(encrypt("secret"));

  io.on("connection", function (socket) {
      socket.on("log_encrypted", function (data) {
            /**
            
            Data received here will automatically decrypted
            
            **/
      });
  });

About

An encrypted socket.io logger transport for Winston

Resources

Stars

Watchers

Forks

Packages

No packages published