Skip to content
Snippets Groups Projects
Commit bcf8b40d authored by João Victor Tozatti Risso's avatar João Victor Tozatti Risso
Browse files

Merge states.js with state.js

parent 63bdc8ec
Branches
Tags
1 merge request!7Refactor enrollments route to include query building
const express = require('express');
const xml = require('js2xmlparser');
const stateApp = express();
const libs = `${process.cwd()}/libs`;
const log = require(`${libs}/log`)(module);
const dbQuery = require(`${libs}/db/query_exec`);
function response(req, res) {
if (req.query.format === 'csv') {
res.csv(req.result.data);
} else if (req.query.format === 'xml') {
res.send(xml('result', JSON.stringify({ state: req.result.data })));
} else {
res.json({ result: req.result.data });
}
}
const squel = require('squel');
const query = require(`${libs}/middlewares/query`);
const response = require(`${libs}/middlewares/response`);
stateApp.get('/', (req, res, next) => {
const stateSql = 'SELECT * FROM estados';
dbQuery(stateSql).then((result) => {
req.result = result;
return response(req, res);
}, (error) => {
log.error(`[${req.originalUrl}] SQL query error: ${error}`);
next('Internal error, request could not be satisfied at this moment. Please, try again later');
});
});
req.query = squel.select().from('estados').toParam();
next();
}, query, response);
stateApp.get('/:id', (req, res, next) => {
const stateSql = 'SELECT * FROM estados WHERE pk_estado_id = ?';
const stateId = parseInt(req.params.id, 10);
dbQuery(stateSql, [stateId]).then((result) => {
req.result = result;
return response(req, res);
}, (error) => {
log.error(`[${req.originalUrl}] SQL query error: ${error}`);
next('Internal error, request could not be satisfied at this moment. Please, try again later');
});
});
req.query = squel.select().from('estados').where('pk_estado_id = ?',
parseInt(req.params.id, 10)).toParam();
next();
}, query, response);
stateApp.get('/region/:id', (req, res, next) => {
const stateSql = 'SELECT * FROM estados WHERE fk_regiao_id = ?';
const regionId = parseInt(req.params.id, 10);
dbQuery(stateSql, [regionId]).then((result) => {
req.result = result;
return response(req, res);
}, (error) => {
log.error(`[${req.originalUrl}] SQL query error: ${error}`);
next('Internal error, request could not be satisfied at this moment. Please, try again later');
});
});
req.query = squel.select().from('estados').where('fk_regiao_id = ?',
parseInt(req.params.id, 10)).toParam();
next();
}, query, response);
module.exports = stateApp;
var express = require('express')
var xml = require('js2xmlparser')
var router = express.Router()
var squel = require('squel')
var libs = process.cwd() + '/libs/'
var log = require(libs + 'log')(module)
var config = require(libs + 'config')
var conn = require(libs + 'db/monet')
var query = require(libs + 'middlewares/query')
function response(req, res) {
console.log('respostas :)')
if (req.query.format === 'csv') {
res.csv(req.result.data)
} else if (req.query.format === 'xml') {
res.send(xml("result", JSON.stringify({state: req.result.data})))
}
else {
res.json({
result: req.result.data
})
}
}
router.get('/', function(req, res, next) {
req.query = squel.select().from('estados').toParam()
next()
}, query, response)
router.get('/:id', function(req, res, next) {
req.query = squel.select().from('estados').where('pk_estado_id = ?', parseInt(req.params.id, 10)).toParam()
next()
}, query, response)
router.get('/region/:id', function(req, res, next) {
req.query = squel.select().from('estados').where('fk_regiao_id = ?', parseInt(req.params.id, 10)).toParam()
next()
}, query, response)
module.exports = router
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment