Socket
Socket
Sign inDemoInstall

resitail

Package Overview
Dependencies
15
Maintainers
1
Versions
78
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    resitail

Stream your residue server logs using hooks


Version published
Maintainers
1
Install size
578 kB
Created

Readme

Source

Resitail

Version Apache 2.0 license

Donate

Stream residue server logs via various hooks

Quick start

  • npm install -g resitail
  • sudo resitail --config <config>

Notice the sudo, this is because all the files written by residue server will need sudo access as they may be owned by one user or another with limited permissions. Resitail needs to be able to read all of these log files.

Configuration

A configuration file looks like:

{
    "residue_config" : "<residue-config>",
    "hooks": [
    ... <see Connecting Hooks section below>
    ]
}

Creating Hook

Hook is essentially a JS module with following minimal requirements

  • A class with options constructor
  • A send function with data parameter.
  • Export this class

Once connected resitail will use this send function to send the logs

A most commonly used hook is resitail-f. It is even used in production servers for muflihun.com

Example:

"use strict";

function sampleHook (options) {
    this.options = options;

    this.send = (data) => {
        console.log(data);
    }
}

module.exports = (options) => new sampleHook(options);

Data contains following properties:

PropertyDescription
eventEvent name (i.e, resitail:line, resitail:err)
event_typeType of event (i.e, info, error)
lineContents of event (either log line or error details etc)
channelType of channel (i.e, client or logger)
channel_nameName of channel (i.e, client_id or logger_id)
logger_idLogger ID if channel is client
client_idClient ID if channel is logger

Connecting Hook

Once hook is ready you can connect it by adding it to configuration.

{
    "name": "<hook name>",
    <path or package>
    "enabled": false,
    "config": {
        "channels" : {
            "to_client" : true,
            "to_logger" : true
        }
        ... more configs specific to hook
    }
}

A fully working hook configuration looks like:

From registry (notice package and version):

{
    "name": "resitail-f",
    "package": "resitail-f",
    "version": "latest"
    "enabled": true,
    "config": {
        "channels" : {
            "to_client" : true,
            "to_logger" : true
        }
        port: 3000
    }
}

This will install the package globally.

Local (notice path):

{
    "name": "resitail-f",
    "path": "../resitail-f",
    "enabled": true,
    "config": {
        "channels" : {
            "to_client" : true,
            "to_logger" : true
        }
        port: 3000
    }
}

Notes

License

Copyright 2017-present Zuhd Web Services
Copyright 2017-present @abumusamq

https://github.com/zuhd-org/
https://muflihun.com/
https://zuhd.org

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

Keywords

FAQs

Last updated on 24 Nov 2018

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc