mirror of
https://github.com/nttgin/BGPalerter.git
synced 2024-05-19 06:50:08 +00:00
added reportSyslog
This commit is contained in:
@@ -47,6 +47,7 @@ Please uncomment the related section and configure according to your needs.
|
||||
- [reportEmail](docs/configuration.md#reportemail)
|
||||
- [reportSlack](docs/configuration.md#reportslack)
|
||||
- [reportKafka](docs/configuration.md#reportkafka)
|
||||
- [reportSyslog](docs/configuration.md#reportsyslog)
|
||||
- [Uptime monitoring](docs/uptime-monitor.md)
|
||||
- [More information for developers](docs/develop.md)
|
||||
- [All npm commands](docs/develop.md#all-npm-commands)
|
||||
|
@@ -106,10 +106,29 @@ reports:
|
||||
# - path
|
||||
# - misconfiguration
|
||||
# params:
|
||||
# host: localhost:9092
|
||||
# host: localhost
|
||||
# port: 9092
|
||||
# topics:
|
||||
# default: bgpalerter
|
||||
|
||||
# - file: reportSyslog
|
||||
# channels:
|
||||
# - hijack
|
||||
# - newprefix
|
||||
# - visibility
|
||||
# - path
|
||||
# - asn-monitor
|
||||
# - misconfiguration
|
||||
# params:
|
||||
# host: localhost
|
||||
# port: 514
|
||||
# templates:
|
||||
# default: "++BGPalerter-3-${type}: ${summary}|${earliest}|${latest}"
|
||||
# hijack: "++BGPalerter-5-${type}: ${summary}|${prefix}|${description}|${asn}|${newprefix}|${neworigin}|${earliest}|${latest}|${peers}"
|
||||
# newprefix: "++BGPalerter-4-${type}: ${summary}|${prefix}|${description}|${asn}|${newprefix}|${neworigin}|${earliest}|${latest}|${peers}"
|
||||
# visibility: "++BGPalerter-5-${type}: ${summary}|${prefix}|${description}|${asn}|${earliest}|${latest}|${peers}"
|
||||
|
||||
|
||||
|
||||
############################
|
||||
# Notification settings:
|
||||
|
@@ -268,6 +268,20 @@ Parameters for this report module:
|
||||
|
||||
|Parameter| Description|
|
||||
|---|---|
|
||||
|host| Host and port of the Kafka instance/broker (e.g. localhost:9092).|
|
||||
|host| Host of the Kafka instance/broker (e.g. localhost).|
|
||||
|port| Port of the Kafka instance/broker (e.g. 9092).|
|
||||
|topics| A dictionary containing a mapping from BGPalerter channels to Kafka topics (e.g. `hijack: hijack-topic`). By default all channels are sent to the topic `bgpalerter` (`default: bgpalerter`) |
|
||||
|
||||
#### reportSyslog
|
||||
|
||||
This report module sends the alerts on Syslog.
|
||||
|
||||
Parameters for this report module:
|
||||
|
||||
|Parameter| Description|
|
||||
|---|---|
|
||||
|showPaths| Amount of AS_PATHs to report in the alert (0 to disable). |
|
||||
|host| Host of the Syslog server (e.g. localhost).|
|
||||
|port| Port of the Syslog server (e.g. 514).|
|
||||
|templates| A dictionary containing string templates for each BGPalerter channels. If a channel doesn't have a template defined, the `default` template will be used (see `config.yml.example` for more details). |
|
||||
|
||||
|
@@ -44,6 +44,7 @@
|
||||
"resnap": "^1.0.1",
|
||||
"restify": "^8.5.0",
|
||||
"restify-errors": "^8.0.1",
|
||||
"syslog-client": "^1.1.1",
|
||||
"websocket-stream": "^5.5.0",
|
||||
"winston": "^3.2.1",
|
||||
"winston-daily-rotate-file": "^4.3.1",
|
||||
|
105
src/reports/reportSyslog.js
Normal file
105
src/reports/reportSyslog.js
Normal file
@@ -0,0 +1,105 @@
|
||||
/*
|
||||
* BSD 3-Clause License
|
||||
*
|
||||
* Copyright (c) 2019, NTT Ltd.
|
||||
* 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.
|
||||
*
|
||||
* Neither the name of the copyright holder nor the names of its
|
||||
* contributors may be used to endorse or promote products derived from
|
||||
* this software without specific prior written permission.
|
||||
*
|
||||
* 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 Report from "./report";
|
||||
import syslog from "syslog-client";
|
||||
|
||||
export default class ReportSyslog extends Report {
|
||||
|
||||
constructor(channels, params, env) {
|
||||
super(channels, params, env);
|
||||
this.client = null;
|
||||
this.connected = false;
|
||||
this.connecting = null;
|
||||
this.host = [ params.hostname || "localhost", params.port ].filter(i => i != null).join(":");
|
||||
this.options = {
|
||||
syslogHostname: params.hostname,
|
||||
transport: syslog.Transport.Udp,
|
||||
port: params.port
|
||||
};
|
||||
}
|
||||
|
||||
|
||||
_getMessage = (channel, content) => {
|
||||
return this.parseTemplate(this.params.templates[channel] || this.params.templates["default"], this.getContext(channel, content));
|
||||
};
|
||||
|
||||
_connectToSyslog = () => {
|
||||
if (!this.connecting) {
|
||||
this.connecting = new Promise((resolve, reject) => {
|
||||
if (this.connected) {
|
||||
resolve(true);
|
||||
} else {
|
||||
console.log("connecting");
|
||||
this.client = syslog.createClient(this.host, this.options);
|
||||
this.connected = true;
|
||||
|
||||
this.client.on("close", function () {
|
||||
this.logger.log({
|
||||
level: 'error',
|
||||
message: 'Syslog disconnected: ' + error
|
||||
});
|
||||
});
|
||||
|
||||
this.client.on("error", function () {
|
||||
this.logger.log({
|
||||
level: 'error',
|
||||
message: 'Syslog: ' + error
|
||||
});
|
||||
});
|
||||
|
||||
resolve(true);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
return this.connecting;
|
||||
};
|
||||
|
||||
report = (channel, content) => {
|
||||
return this._connectToSyslog()
|
||||
.then(() => {
|
||||
const message = this._getMessage(channel, content);
|
||||
|
||||
console.log(message);
|
||||
this.client.log(message, {}, error => {
|
||||
if (error) {
|
||||
this.logger.log({
|
||||
level: 'error',
|
||||
message: 'Syslog: ' + error
|
||||
});
|
||||
}
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
}
|
@@ -4811,6 +4811,11 @@ supports-color@^7.1.0:
|
||||
dependencies:
|
||||
has-flag "^4.0.0"
|
||||
|
||||
syslog-client@^1.1.1:
|
||||
version "1.1.1"
|
||||
resolved "https://registry.yarnpkg.com/syslog-client/-/syslog-client-1.1.1.tgz#bdb28de3b5b7eb28a11352ec3eb78e55aed2ab6b"
|
||||
integrity sha1-vbKN47W36yihE1LsPreOVa7Sq2s=
|
||||
|
||||
tar-fs@^2.0.0:
|
||||
version "2.0.0"
|
||||
resolved "https://registry.yarnpkg.com/tar-fs/-/tar-fs-2.0.0.tgz#677700fc0c8b337a78bee3623fdc235f21d7afad"
|
||||
|
Reference in New Issue
Block a user