This commit is contained in:
2016-02-02 13:58:00 -05:00
parent 5d43be9123
commit e4e4c71ce1

View File

@ -33,65 +33,66 @@ router.get('/start/:name', function(req, res, next){
}); });
router.get('/live/:template/:name', function(req, res, next){ router.get('/live/:template/:name', function(req, res, next){
lxc.startEphemeral(req.params.name, req.params.template, function (data) { return lxc.startEphemeral(req.params.name, req.params.template, function (data) {
console.log('live', arguments); console.log('live', arguments);
res.json(data); return res.json(data);
}); });
}); });
router.get('/stop/:name', function(req, res, next){ router.get('/stop/:name', function(req, res, next){
lxc.stop(req.params.name, function(data){ return lxc.stop(req.params.name, function(data){
console.log('stop', arguments); console.log('stop', arguments);
if(data){ if(data){
res.json({status: 500, name: req.params.name, message: data}); return res.json({status: 500, name: req.params.name, message: data});
}else{ }else{
res.json({status: 200}); return res.json({status: 200});
} }
}); });
}); });
router.get('/clone/:template/:name', function(req, res, next){ router.get('/clone/:template/:name', function(req, res, next){
lxc.clone(req.params.name, req.params.template, function(data){ return lxc.clone(req.params.name, req.params.template, function(data){
console.log('clone', arguments); console.log('clone', arguments);
if( data.match(/Created container/) ){ if( data.match(/Created container/) ){
res.json({status: 200}); return res.json({status: 200});
}else{ }else{
res.json({status: 500, message: data}); return res.json({status: 500, message: data});
} }
}); });
}); });
router.get('/destroy/:name', function(req, res, next){ router.get('/destroy/:name', function(req, res, next){
lxc.destroy(req.params.name, function(data){ return lxc.destroy(req.params.name, function(data){
console.log('destroy', arguments); console.log('destroy', arguments);
if(data){ if(data){
res.json({status: 500, message: data}); return res.json({status: 500, message: data});
}else{ }else{
res.json({status: 200}); return res.json({status: 200});
} }
}); });
}); });
router.get('/info/:name', function(req, res, next){ router.get('/info/:name', function(req, res, next){
lxc.info(req.params.name, function(data){ return lxc.info(req.params.name, function(data){
res.json(data); return res.json(data);
}); });
}); });
router.get('/list', function(req, res, next) { router.get('/list', function(req, res, next) {
lxc.list(function(data){ return lxc.list(function(data){
res.json(data); return res.json(data);
}); });
}); });
router.post('/run/:ip?', function(req, res, next){ router.post('/run/:ip?', function(req, res, next){
var runner = function(res, req, ip){ var runner = function(res, req, ip){
request.post({url:'http://'+ip, body: req.body}, function(error, response, body){ console.log('runner on', ip);
return request.post({url:'http://'+ip, body: req.body}, function(error, response, body){
console.log('request args:', arguments) console.log('request args:', arguments)
body = JSON.parse(body); body = JSON.parse(body);
body['ip'] = ip.replace('10.0.', '') body['ip'] = ip.replace('10.0.', '')
return res.json(body) return res.json(body)
}) });
}; };
@ -101,7 +102,7 @@ router.post('/run/:ip?', function(req, res, next){
}else{ }else{
var name = 'u1-'+(Math.random()*100).toString().replace('.',''); var name = 'u1-'+(Math.random()*100).toString().replace('.','');
console.log('new VM', name); console.log('new VM', name);
lxc.startEphemeral(name, 'u1', function(data){ return lxc.startEphemeral(name, 'u1', function(data){
return runner(res, req, data.ip); return runner(res, req, data.ip);
}); });
} }