diff --git a/libs/app.js b/libs/app.js index 205448c6f7a4c2603523266153f871b01e3d39d5..bf578043c93e2871ba030fd4d9a0d4df92d448fa 100644 --- a/libs/app.js +++ b/libs/app.js @@ -3,6 +3,7 @@ var path = require('path') var cookieParser = require('cookie-parser') var bodyParser = require('body-parser') var csv = require('csv-express') +var xml = require('xml') var methodOverride = require('method-override') var libs = process.cwd() + '/libs/' diff --git a/libs/routes/api.js b/libs/routes/api.js index faafaf2120779f37bb1c0cff77260fd44f9f332e..d5dadcd3d622a4c4574f1286c5f89f9bf4f1dc42 100644 --- a/libs/routes/api.js +++ b/libs/routes/api.js @@ -1,6 +1,6 @@ var express = require('express') var router = express.Router() - +var xml = require('xml') var libs = process.cwd() + '/libs/' var log = require(libs + 'log')(module) @@ -27,7 +27,7 @@ router.get('/data', function(req, res) { }) }) -router.get('/matriculas/:format?', function(req, res) { +router.get('/matriculas.:format?', function(req, res) { log.debug(req.query); tbl_name = "matriculas"; @@ -49,8 +49,13 @@ router.get('/matriculas/:format?', function(req, res) { 'SELECT * FROM ' + tbl_name, true ).then(function(result) { log.debug(result); - if (req.params.format) { + if (req.params.format === 'csv') { res.csv(result.data) + } else if (req.params.format === 'xml') { + res.set('Content-Type', 'text/xml') + res.send(xml({ + 'result': result.data + })) } else { res.json({ diff --git a/package.json b/package.json index f5ff893b8066bb494f62f583a1ad5a55f08ed693..54616e2e555988dbeb354cef9e5883f06d1ddcf6 100644 --- a/package.json +++ b/package.json @@ -18,7 +18,8 @@ "method-override": "^2.3.3", "monetdb": "^1.1.2", "nconf": "^0.6.x", - "winston": "^0.8.x" + "winston": "^0.8.x", + "xml": "^1.0.1" }, "license": "MIT" }