nci/httpApi.js

183 lines
4.0 KiB
JavaScript
Raw Normal View History

'use strict';
var Steppy = require('twostep').Steppy,
_ = require('underscore'),
2015-12-23 20:11:13 +00:00
querystring = require('querystring'),
libProject = require('./lib/project');
/*
* Pure rest api on pure nodejs follows below
*/
2015-12-01 08:18:33 +00:00
var router = {};
router.routes = {};
2015-12-02 20:24:45 +00:00
_(['get', 'post', 'patch', 'delete']).each(function(method) {
router[method] = function(path, handler) {
this.routes[method] = this.routes[method] || [];
var keys = [],
regExpStr = path.replace(/:(\w+)/g, function(match, name) {
keys.push(name);
return '(.+)';
});
this.routes[method].push({
regExp: new RegExp('^' + regExpStr + '$'),
handler: handler,
keys: keys
});
2015-12-01 08:18:33 +00:00
};
});
2015-12-02 20:24:45 +00:00
router.del = router['delete'];
router.getRoute = function(req) {
var parts,
route = _(this.routes[req.method.toLowerCase()]).find(function(route) {
parts = route.regExp.exec(req.path);
return parts;
});
if (route && route.keys.length) {
route.params = {};
_(route.keys).each(function(key, index) {
route.params[key] = parts[index + 1];
});
}
return route;
};
module.exports = function(app) {
2015-12-06 20:46:24 +00:00
var logger = app.lib.logger('http api');
2015-12-01 08:18:33 +00:00
// run building of a project
2015-12-08 00:22:23 +00:00
router.post('/api/0.1/builds', function(req, res, next) {
2015-12-01 08:18:33 +00:00
Steppy(
function() {
var projectName = req.body.project,
project = _(app.projects).findWhere({name: projectName});
if (project) {
res.statusCode = 204;
logger.log('Run project "%s"', projectName);
app.distributor.run({
projectName: projectName,
withScmChangesOnly: req.body.withScmChangesOnly,
skipQueued: req.body.skipQueued,
2015-12-01 08:18:33 +00:00
initiator: {type: 'httpApi'}
});
} else {
res.statusCode = 404;
}
res.end();
},
next
);
});
2015-12-02 20:24:45 +00:00
// TODO: restrict access with some sort of token
2015-12-08 00:22:23 +00:00
router.del('/api/0.1/projects/:name', function(req, res, next) {
2015-12-02 20:24:45 +00:00
var projectName = req.params.name;
Steppy(
function() {
logger.log('Cleaning up project "%s"', projectName);
2015-12-23 20:11:13 +00:00
libProject.remove({
2015-12-02 20:24:45 +00:00
baseDir: app.config.paths.projects,
name: projectName
}, this.slot());
},
function() {
logger.log('Project "%s" cleaned up', projectName);
res.statusCode = 204;
res.end();
},
next
);
});
2015-12-08 00:22:23 +00:00
router.patch('/api/0.1/projects/:name', function(req, res, next) {
2015-12-04 19:54:21 +00:00
var projectName = req.params.name,
newProjectName = req.body.name;
Steppy(
function() {
logger.log(
'Rename project "%s" to "%s"', projectName, newProjectName
);
if (!newProjectName) throw new Error('new project name is not set');
var curProject = _(app.projects).findWhere({name: projectName});
if (!curProject) {
throw new Error('Project "' + projectName + '" not found');
}
this.pass(curProject);
var newProject = _(app.projects).findWhere({name: newProjectName});
if (newProject) {
throw new Error(
'Project name "' + newProjectName + '" already used'
);
}
2015-12-23 20:11:13 +00:00
libProject.rename({
2015-12-04 19:54:21 +00:00
baseDir: app.config.paths.projects,
name: projectName,
newName: newProjectName
}, this.slot());
},
function(err, curProject) {
curProject.name = newProjectName;
res.statusCode = 204;
res.end();
},
next
);
});
2015-12-01 08:18:33 +00:00
return function(req, res) {
Steppy(
function() {
var stepCallback = this.slot();
2015-12-02 20:24:45 +00:00
var urlParts = req.url.split('?');
req.path = urlParts[0];
req.query = querystring.parse(urlParts[1]);
req.setEncoding('utf-8');
var bodyString = '';
req.on('data', function(data) {
bodyString += data;
});
req.on('end', function() {
2015-12-04 19:54:21 +00:00
var body = bodyString ? JSON.parse(bodyString) : {};
stepCallback(null, body);
});
req.on('error', stepCallback);
},
function(err, body) {
2015-12-01 08:18:33 +00:00
req.body = body;
2015-12-02 20:24:45 +00:00
var route = router.getRoute(req);
if (route) {
req.params = route.params;
route.handler(req, res, this.slot());
2015-12-01 08:18:33 +00:00
} else {
res.statusCode = 404;
res.end();
}
},
function(err) {
2015-07-05 18:03:58 +00:00
logger.error('Error occurred during request: ', err.stack || err);
2015-12-01 08:18:33 +00:00
res.statusCode = 500;
res.end();
}
);
};
};