add body-parser to compute request message

This commit is contained in:
Ivan Socolsky 2015-02-12 14:12:09 -03:00
parent 9cadcfe7f6
commit 2aeeecd90f
2 changed files with 32 additions and 63 deletions

94
app.js
View File

@ -3,14 +3,15 @@
var _ = require('lodash'); var _ = require('lodash');
var async = require('async'); var async = require('async');
var log = require('npmlog'); var log = require('npmlog');
var CopayServer = require('./lib/server');
var express = require('express'); var express = require('express');
var querystring = require('querystring'); var querystring = require('querystring');
var bodyParser = require('body-parser')
var CopayServer = require('./lib/server');
log.debug = log.verbose; log.debug = log.verbose;
log.level = 'debug'; log.level = 'debug';
var POST_LIMIT = 1024 * 100 /* Max POST 100 kb */ ;
CopayServer.initialize(); CopayServer.initialize();
@ -32,6 +33,12 @@ var allowCORS = function(req, res, next) {
} }
app.use(allowCORS); app.use(allowCORS);
var POST_LIMIT = 1024 * 100 /* Max POST 100 kb */ ;
app.use(bodyParser.json({
limit: POST_LIMIT
}));
var port = process.env.COPAY_PORT || 3001; var port = process.env.COPAY_PORT || 3001;
var router = express.Router(); var router = express.Router();
@ -60,82 +67,45 @@ function getCredentials(req) {
return { return {
copayerId: identity, copayerId: identity,
signature: req.header('x-signature'),
}; };
}; };
function getServerWithAuth(req, res, cb) { function getServerWithAuth(req, res, cb) {
var credentials = getCredentials(req); var credentials = getCredentials(req);
var auth = {
CopayServer.getInstanceWithAuth({
copayerId: credentials.copayerId, copayerId: credentials.copayerId,
message: 'hello world!', message: req.url + '|' + JSON.stringify(req.body),
signature: '3045022100addd20e5413865d65d561ad2979f2289a40d52594b1f804840babd9a63e4ebbf02204b86285e1fcab02df772e7a1325fc4b511ecad79a8f80a2bd1ad8bfa858ac3d4', signature: credentials.signature,
}, function(err, server) { };
CopayServer.getInstanceWithAuth(auth, function(err, server) {
if (err) return returnError(err, res); if (err) return returnError(err, res);
return cb(server); return cb(server);
}); });
}; };
function authenticate() {
return true;
};
function parsePost(req, res, cb) {
var queryData = '';
req.on('data', function(data) {
queryData += data;
if (queryData.length > POST_LIMIT) {
queryData = '';
res.writeHead(413, {
'Content-Type': 'text/plain'
});
res.end();
req.connection.destroy();
}
}).on('end', function() {
try {
var params = JSON.parse(queryData);
cb(params);
} catch (ex) {
returnError({
code: 400,
message: 'Unable to parse request'
}, res);
}
});
};
router.post('/v1/wallets/', function(req, res) { router.post('/v1/wallets/', function(req, res) {
parsePost(req, res, function(params) { var server = CopayServer.getInstance();
var server = CopayServer.getInstance(); server.createWallet(req.body, function(err, wallet) {
server.createWallet(params, function(err, wallet) { if (err) returnError(err, res);
if (err) returnError(err, res);
res.json(wallet); res.json(wallet);
});
}); });
}); });
router.post('/v1/wallets/:id/join/', function(req, res) { router.post('/v1/wallets/join/', function(req, res) {
parsePost(req, res, function(params) { req.body.walletId = req.params['id'];
params.walletId = req.params['id']; var server = CopayServer.getInstance();
var server = CopayServer.getInstance(); server.joinWallet(req.body, function(err) {
server.joinWallet(params, function(err) { if (err) returnError(err, res);
if (err) returnError(err, res);
res.end(); res.end();
});
}); });
}); });
router.get('/v1/wallets/', function(req, res) { router.get('/v1/wallets/', function(req, res) {
var credentials = getCredentials(req); getServerWithAuth(req, res, function(server) {
CopayServer.getInstanceWithAuth(getCredentials(req) {
copayerId: credentials.copayerId,
message: 'hello world!',
signature: '3045022100addd20e5413865d65d561ad2979f2289a40d52594b1f804840babd9a63e4ebbf02204b86285e1fcab02df772e7a1325fc4b511ecad79a8f80a2bd1ad8bfa858ac3d4',
}, function(err, server) {
if (err) return returnError(err, res); if (err) return returnError(err, res);
server.getWallet({}, function(err, wallet) { server.getWallet({}, function(err, wallet) {
if (err) returnError(err, res); if (err) returnError(err, res);
@ -145,12 +115,10 @@ router.get('/v1/wallets/', function(req, res) {
}); });
router.post('/v1/addresses/', function(req, res) { router.post('/v1/addresses/', function(req, res) {
parsePost(req, res, function(params) { getServerWithAuth(req, res, function(server) {
getServerWithAuth(req, res, function(server) { server.createAddress(req.body, function(err, address) {
server.createAddress(params, function(err, address) { if (err) returnError(err, res);
if (err) returnError(err, res); res.json(address);
res.json(address);
});
}); });
}); });
}); });

View File

@ -20,6 +20,7 @@
"async": "^0.9.0", "async": "^0.9.0",
"bitcore": "0.10.0", "bitcore": "0.10.0",
"bitcore-explorers": "^0.9.1", "bitcore-explorers": "^0.9.1",
"body-parser": "^1.11.0",
"commander": "^2.6.0", "commander": "^2.6.0",
"express": "^4.10.0", "express": "^4.10.0",
"inherits": "^2.0.1", "inherits": "^2.0.1",