Skip to content

Instantly share code, notes, and snippets.

@Caerbannog
Created June 21, 2017 09:59
Show Gist options
  • Save Caerbannog/63a96c3de80c783b646e9319d1789fe1 to your computer and use it in GitHub Desktop.
Save Caerbannog/63a96c3de80c783b646e9319d1789fe1 to your computer and use it in GitHub Desktop.
var https = require('https');
var util = require('util');
exports.handler = function(event, context) {
console.log(JSON.stringify(event, null, 2));
console.log('From SNS:', event.Records[0].Sns.Message);
var postData = {
//"channel": "#monitoring",
//"username": "AWS SNS via Lamda :: DevQa Cloud",
//"icon_emoji": ":aws:"
"text": "*" + event.Records[0].Sns.Subject + "*",
};
var message = event.Records[0].Sns.Message;
var severity = "good";
var dangerMessages = [
" but with errors",
" to RED",
"During an aborted deployment",
"Failed to deploy application",
"Failed to deploy configuration",
"has a dependent object",
"is not authorized to perform",
"Pending to Degraded",
"Stack deletion failed",
"Unsuccessful command execution",
"You do not have permission",
"Your quota allows for 0 more running instance"];
var warningMessages = [
" aborted operation.",
" to YELLOW",
"Adding instance ",
"Degraded to Info",
"Deleting SNS topic",
"is currently running under desired capacity",
"Ok to Info",
"Ok to Warning",
"Pending Initialization",
"Removed instance ",
"Rollback of environment"
];
for(var dangerMessagesItem in dangerMessages) {
if (message.indexOf(dangerMessages[dangerMessagesItem]) != -1) {
severity = "danger";
break;
}
}
// HACK Liberty Rider
try {
var obj = JSON.parse(message);
if (obj.NewStateValue == "ALARM") {
severity = "danger";
}
message = JSON.stringify(obj, null, 2);
}
catch(e) {
console.error("Parsing failed: " + e);
}
// End of HACK
// Only check for warning messages if necessary
if (severity == "good") {
for(var warningMessagesItem in warningMessages) {
if (message.indexOf(warningMessages[warningMessagesItem]) != -1) {
severity = "warning";
break;
}
}
}
postData.attachments = [
{
"color": severity,
"text": message
}
];
var options = {
method: 'POST',
hostname: 'hooks.slack.com',
port: 443,
path: '/services/T0E7ANRTQ/B5U8DD5T2/iMpF2rqFR9aVLnYASfdhiXYt'
};
var req = https.request(options, function(res) {
res.setEncoding('utf8');
res.on('data', function (chunk) {
context.done(null);
});
});
req.on('error', function(e) {
console.log('problem with request: ' + e.message);
});
req.write(util.format("%j", postData));
req.end();
};
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment