pad.libre-service.eu-etherpad/src/node/hooks/express/apicalls.js

61 lines
2.2 KiB
JavaScript
Raw Normal View History

2012-02-25 15:20:31 +01:00
var log4js = require('log4js');
var apiLogger = log4js.getLogger("API");
var formidable = require('formidable');
var apiHandler = require('../../handler/APIHandler');
2012-02-25 15:20:31 +01:00
//This is for making an api call, collecting all post information and passing it to the apiHandler
2012-04-07 15:25:37 +02:00
var apiCaller = function(req, res, fields) {
2012-02-25 15:20:31 +01:00
res.header("Content-Type", "application/json; charset=utf-8");
2012-09-09 18:20:16 +02:00
apiLogger.info("REQUEST, v"+ req.params.version + ":" + req.params.func + ", " + JSON.stringify(fields));
2012-02-25 15:20:31 +01:00
//wrap the send function so we can log the response
//note: res._send seems to be already in use, so better use a "unique" name
res._____send = res.send;
2012-02-25 15:20:31 +01:00
res.send = function (response) {
response = JSON.stringify(response);
apiLogger.info("RESPONSE, " + req.params.func + ", " + response);
//is this a jsonp call, if yes, add the function call
if(req.query.jsonp)
response = req.query.jsonp + "(" + response + ")";
res._____send(response);
2012-02-25 15:20:31 +01:00
}
//call the api handler
2012-09-09 18:20:16 +02:00
apiHandler.handle(req.params.version, req.params.func, fields, req, res);
2012-02-25 15:20:31 +01:00
}
2012-04-07 15:25:37 +02:00
exports.apiCaller = apiCaller;
2012-02-25 15:20:31 +01:00
exports.expressCreateServer = function (hook_name, args, cb) {
//This is a api GET call, collect all post informations and pass it to the apiHandler
2012-09-09 18:20:16 +02:00
args.app.get('/api/:version/:func', function (req, res) {
2012-02-25 15:20:31 +01:00
apiCaller(req, res, req.query)
});
//This is a api POST call, collect all post informations and pass it to the apiHandler
2012-09-09 18:20:16 +02:00
args.app.post('/api/:version/:func', function(req, res) {
2012-02-25 15:20:31 +01:00
new formidable.IncomingForm().parse(req, function (err, fields, files) {
apiCaller(req, res, fields)
});
});
//The Etherpad client side sends information about how a disconnect happen
args.app.post('/ep/pad/connection-diagnostic-info', function(req, res) {
new formidable.IncomingForm().parse(req, function(err, fields, files) {
console.log("DIAGNOSTIC-INFO: " + fields.diagnosticInfo);
res.end("OK");
});
});
//The Etherpad client side sends information about client side javscript errors
args.app.post('/jserror', function(req, res) {
new formidable.IncomingForm().parse(req, function(err, fields, files) {
console.error("CLIENT SIDE JAVASCRIPT ERROR: " + fields.errorInfo);
res.end("OK");
});
});
2012-04-07 15:25:37 +02:00
}