2019-07-11 12:49:18 +02:00
|
|
|
/*
|
|
|
|
* 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 axios from "axios";
|
|
|
|
|
2019-08-15 16:21:09 +02:00
|
|
|
export default class ReportSlack extends Report {
|
2019-07-11 12:49:18 +02:00
|
|
|
|
|
|
|
constructor(channels, params, env) {
|
|
|
|
super(channels, params, env);
|
|
|
|
|
|
|
|
|
2019-09-17 19:19:23 +02:00
|
|
|
this.enabled = true;
|
|
|
|
if (!this.params.hooks || !Object.keys(this.params.hooks).length){
|
|
|
|
this.logger.log({
|
|
|
|
level: 'error',
|
|
|
|
message: "Slack reporting is not enabled: no group is defined"
|
|
|
|
});
|
|
|
|
this.enabled = false;
|
2019-10-02 01:30:17 +02:00
|
|
|
} else {
|
|
|
|
if (!this.params.hooks["default"]) {
|
|
|
|
this.logger.log({
|
|
|
|
level: 'error',
|
|
|
|
message: "In hooks, for reportSlack, a group named 'default' is required for communications to the admin."
|
|
|
|
});
|
|
|
|
}
|
2019-09-17 19:19:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2020-01-18 20:45:59 +01:00
|
|
|
_sendSlackMessage = (url, channel, content, context) => {
|
|
|
|
let message = content.message;
|
|
|
|
const color = (this.params && this.params.colors && this.params.colors[channel])
|
|
|
|
? this.params.colors[channel]
|
2019-09-19 22:36:12 +02:00
|
|
|
: '#4287f5';
|
|
|
|
|
2020-01-18 20:45:59 +01:00
|
|
|
if (this.params.showPaths > 0) {
|
|
|
|
message += `${content.message}. Top ${context.pathNumber} most used AS paths: \n ${context.paths}`;
|
|
|
|
}
|
|
|
|
|
2019-07-11 12:49:18 +02:00
|
|
|
axios({
|
2019-09-17 19:19:23 +02:00
|
|
|
url: url,
|
2019-07-11 12:49:18 +02:00
|
|
|
method: "POST",
|
|
|
|
resposnseType: "json",
|
|
|
|
data: {
|
2019-09-18 11:41:27 +02:00
|
|
|
attachments: [
|
|
|
|
{
|
2019-09-19 22:36:12 +02:00
|
|
|
color: color,
|
2020-01-18 20:45:59 +01:00
|
|
|
title: channel,
|
|
|
|
text: message
|
2019-09-18 11:41:27 +02:00
|
|
|
}
|
|
|
|
]
|
2019-07-11 12:49:18 +02:00
|
|
|
}
|
|
|
|
})
|
|
|
|
.catch((error) => {
|
|
|
|
this.logger.log({
|
|
|
|
level: 'error',
|
|
|
|
message: error
|
|
|
|
});
|
|
|
|
})
|
2019-09-17 19:19:23 +02:00
|
|
|
};
|
|
|
|
|
2020-01-18 20:45:59 +01:00
|
|
|
report = (channel, content) => {
|
2020-01-23 03:20:09 +01:00
|
|
|
if (this.enabled) {
|
2020-01-18 20:45:59 +01:00
|
|
|
const context = this.getContext(channel, content);
|
2019-09-19 22:36:12 +02:00
|
|
|
let groups = content.data.map(i => i.matchedRule.group).filter(i => i != null);
|
2019-10-06 12:32:30 -05:00
|
|
|
|
|
|
|
groups = (groups.length) ? [...new Set(groups)] : Object.keys(this.params.hooks); // If there are no groups defined, send to all of them
|
2019-07-11 12:49:18 +02:00
|
|
|
|
2019-09-17 19:19:23 +02:00
|
|
|
for (let group of groups) {
|
|
|
|
if (this.params.hooks[group]) {
|
2020-01-18 20:45:59 +01:00
|
|
|
this._sendSlackMessage(this.params.hooks[group], channel, content, context);
|
2019-09-17 19:19:23 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2019-07-11 12:49:18 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
}
|