2016-06-23 19:36:35 +00:00
|
|
|
var irc = require('irc');
|
|
|
|
var express = require('express');
|
|
|
|
var bodyParser = require('body-parser');
|
2016-07-16 17:22:27 +00:00
|
|
|
var request = require('request');
|
2016-06-23 19:36:35 +00:00
|
|
|
|
|
|
|
var config = require('./config');
|
|
|
|
|
2016-06-23 23:39:10 +00:00
|
|
|
var channels = [];
|
|
|
|
var hookToChannel = {};
|
|
|
|
for (var who in config.reports) {
|
|
|
|
if (who.indexOf('#') === 0)
|
|
|
|
channels.push(who);
|
|
|
|
|
|
|
|
var hooks = config.reports[who];
|
|
|
|
for (var i = 0; i < hooks.length; i++) {
|
|
|
|
var hook = hooks[i];
|
|
|
|
(hookToChannel[hook] = hookToChannel[hook] || []).push(who);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-23 19:36:35 +00:00
|
|
|
var client = new irc.Client(config.server, config.nick, {
|
|
|
|
//debug: true,
|
2016-06-23 23:39:10 +00:00
|
|
|
channels: channels,
|
2016-06-23 19:36:35 +00:00
|
|
|
userName: config.userName,
|
|
|
|
realName: config.realName,
|
|
|
|
retryDelay: 120000
|
|
|
|
});
|
|
|
|
|
|
|
|
var app = express();
|
|
|
|
|
|
|
|
app.use(bodyParser.json()); // for parsing application/json
|
|
|
|
app.use(bodyParser.urlencoded({ extended: true })); // for parsing application/x-www-form-urlencoded
|
|
|
|
|
2016-07-16 17:22:27 +00:00
|
|
|
function shortenURL(url, callback) {
|
|
|
|
request('https://lstu.fr/a', { method: 'POST', form: { lsturl: url, format: 'json' } }, function (err, res, body) {
|
|
|
|
try {
|
|
|
|
body = JSON.parse(body);
|
|
|
|
} catch(err) {
|
|
|
|
body = {err: 'cant parse JSON'};
|
|
|
|
}
|
|
|
|
if (err || !body.success) {
|
|
|
|
console.error("Error when shortening link: (status: " + res.statusCode + ")", '\nerror:', err, '\nfailure reason:', body.msg);
|
|
|
|
} else {
|
|
|
|
callback(body.short);
|
|
|
|
}
|
|
|
|
});
|
2016-06-23 19:50:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
var handlers = {
|
|
|
|
|
2016-07-16 17:22:27 +00:00
|
|
|
push: function(body, say) {
|
2016-06-23 19:50:55 +00:00
|
|
|
var user = body.user_name;
|
2016-06-23 20:05:10 +00:00
|
|
|
var projectName = body.project.name;
|
2016-06-23 23:28:27 +00:00
|
|
|
|
2016-06-23 19:50:55 +00:00
|
|
|
var commits = body.commits;
|
2016-06-23 23:28:27 +00:00
|
|
|
var numCommits = body.total_commits_count;
|
2016-06-23 19:50:55 +00:00
|
|
|
|
2016-06-23 23:28:27 +00:00
|
|
|
var branchName = body.ref.replace('refs/heads/', '');
|
2016-06-23 19:50:55 +00:00
|
|
|
|
2016-06-23 23:28:27 +00:00
|
|
|
var msg = [];
|
|
|
|
if (!numCommits) {
|
|
|
|
// Special case: a branch was created or deleted.
|
|
|
|
var action = 'created';
|
|
|
|
if (body.after === '0000000000000000000000000000000000000000')
|
|
|
|
action = 'deleted';
|
|
|
|
msg.push(projectName + ': ' + user + ' ' + action + ' branch ' + branchName);
|
2016-07-16 17:22:27 +00:00
|
|
|
say(msg);
|
2016-06-23 19:50:55 +00:00
|
|
|
} else {
|
2016-06-23 23:28:27 +00:00
|
|
|
var maybeS = numCommits === 1 ? '' : 's';
|
|
|
|
msg.push('push on ' + projectName + '@' + branchName + ': ' + user + ' pushed ' + commits.length + ' commit' + maybeS + '.');
|
2016-06-23 19:50:55 +00:00
|
|
|
|
2016-07-16 17:22:27 +00:00
|
|
|
var lastCommit = commits[0];
|
|
|
|
shortenURL(lastCommit.url, function(shortUrl) {
|
|
|
|
if (!err) {
|
|
|
|
msg.push('last commit: ' + lastCommit.message + ' : ' + shortUrl);
|
|
|
|
say(msg);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2016-06-23 20:05:10 +00:00
|
|
|
},
|
|
|
|
|
2016-07-16 17:22:27 +00:00
|
|
|
issue: function(body, say) {
|
2016-06-23 20:05:10 +00:00
|
|
|
var user = body.user.name;
|
|
|
|
var projectName = body.project.name;
|
|
|
|
|
|
|
|
var issue = body.object_attributes;
|
|
|
|
var issueNumber = issue.iid;
|
|
|
|
var issueTitle = issue.title;
|
|
|
|
var issueState = issue.state;
|
|
|
|
var url = issue.url;
|
|
|
|
|
2016-06-23 23:16:38 +00:00
|
|
|
// Don't trigger the hook on issue's update;
|
|
|
|
if (issue.action === 'update')
|
|
|
|
return;
|
|
|
|
|
2016-07-16 17:22:27 +00:00
|
|
|
shortenURL(url, function(shortUrl) {
|
|
|
|
var msg = [projectName + ': issue #' + issueNumber + ' has changed state ("' + issueState + '")'];
|
|
|
|
msg.push(issueTitle + ' ' + shortUrl);
|
|
|
|
say(msg)
|
|
|
|
});
|
2016-06-23 20:05:10 +00:00
|
|
|
},
|
|
|
|
|
2016-07-16 17:22:27 +00:00
|
|
|
merge_request: function(body, say) {
|
2016-06-23 20:05:10 +00:00
|
|
|
var user = body.user.name;
|
|
|
|
|
|
|
|
var request = body.object_attributes;
|
|
|
|
|
2016-06-23 20:09:56 +00:00
|
|
|
var projectName = request.target.name;
|
|
|
|
|
2016-06-23 20:05:10 +00:00
|
|
|
var from = request.source_branch;
|
|
|
|
var to = request.target_branch;
|
|
|
|
|
|
|
|
var id = request.iid;
|
|
|
|
var title = request.title;
|
|
|
|
var url = request.url;
|
|
|
|
var state = request.state;
|
|
|
|
|
2016-07-16 17:22:27 +00:00
|
|
|
shortenURL(url, function(shortUrl) {
|
|
|
|
var msg = [projectName + ': merge request (' + from + ':' + to + ') #' + id + ' has changed state ("' + state + '")'];
|
|
|
|
msg.push(title + ' ' + shortUrl);
|
|
|
|
say(msg);
|
|
|
|
});
|
2016-06-23 20:05:10 +00:00
|
|
|
},
|
|
|
|
|
2016-07-16 17:22:27 +00:00
|
|
|
build: function(body, msg) {
|
2016-06-23 20:21:04 +00:00
|
|
|
|
|
|
|
var id = body.build_id;
|
|
|
|
var status = body.build_status;
|
|
|
|
|
|
|
|
var isFinished = body.build_finished_at !== null;
|
|
|
|
var duration = body.build_duration;
|
|
|
|
|
|
|
|
var projectName = body.project_name;
|
|
|
|
var stage = body.build_stage;
|
|
|
|
|
|
|
|
var msg = [];
|
|
|
|
msg.push(projectName + ': build #' + id + ' (' + stage + ') changed status: ' + status);
|
|
|
|
if (isFinished)
|
|
|
|
msg.push('build finished in ' + duration + ' seconds. ');
|
|
|
|
|
2016-07-16 17:22:27 +00:00
|
|
|
say(msg);
|
2016-06-23 19:50:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2016-07-16 17:22:27 +00:00
|
|
|
function say(msgs) {
|
2016-06-23 19:50:55 +00:00
|
|
|
if (msgs) {
|
2016-06-23 23:39:10 +00:00
|
|
|
var whom = hookToChannel[body.object_kind] || [];
|
2016-06-23 19:50:55 +00:00
|
|
|
if (msgs instanceof Array) {
|
|
|
|
for (var i = 0; i < msgs.length; i++)
|
2016-07-16 17:22:27 +00:00
|
|
|
client.say(whom, msgs[i]);
|
2016-06-23 19:50:55 +00:00
|
|
|
} else {
|
2016-07-16 17:22:27 +00:00
|
|
|
client.say(whom, msgs);
|
2016-06-23 19:50:55 +00:00
|
|
|
}
|
|
|
|
}
|
2016-07-16 17:22:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
app.post('/', function(req, res) {
|
|
|
|
var body = req.body || {};
|
|
|
|
|
|
|
|
var msgs = null;
|
|
|
|
if (body.object_kind && handlers[body.object_kind])
|
|
|
|
handlers[body.object_kind](body, say);
|
|
|
|
else
|
|
|
|
console.log("Unexpected object_kind:", body.object_kind);
|
2016-06-23 19:50:55 +00:00
|
|
|
|
2016-06-23 19:36:35 +00:00
|
|
|
res.sendStatus(200);
|
|
|
|
});
|
|
|
|
|
|
|
|
app.listen(config.port, config.hostname, function() {
|
|
|
|
console.log('gitlab-to-irc running.');
|
|
|
|
});
|