Commit c8ca8e879c2c7a9fed97df4ec5fd50f657782cbe

Authored by Eric Fernandez
1 parent 4245e3200a
Exists in master

no tabla

Showing 2 changed files with 22 additions and 3 deletions   Show diff stats
rutas/comprobantes.js
1 module.exports = router = express.Router(); 1 module.exports = router = express.Router();
2 2
3 router.get('/comprobantes/:gln*?', function(req, res) { 3 router.get('/comprobantes/:gln*?', function(req, res) {
4 4
5 var cabecera = knex('PMAEFACT_TEMP') 5 var cabecera = knex('PMAEFACT_TEMP')
6 .where(function(qb) { 6 .where(function(qb) {
7 if (req.params.gln) { 7 if (req.params.gln) {
8 qb.where({GLN: req.params.gln}); 8 qb.where({GLN: req.params.gln});
9 } 9 }
10 }) 10 })
11 .select('*'); 11 .select('*');
12 12
13 var cuerpo = knex('PMOVFACT_TEMP') 13 var cuerpo = knex('PMOVFACT_TEMP')
14 .where(function(qb) { 14 .where(function(qb) {
15 if (req.params.gln) { 15 if (req.params.gln) {
16 qb.where({GLN: req.params.gln}); 16 qb.where({GLN: req.params.gln});
17 } 17 }
18 }) 18 })
19 .select('*'); 19 .select('*');
20 20
21 Promise.all([cabecera, cuerpo]).then(function(data) { 21 Promise.all([cabecera, cuerpo]).then(function(data) {
22 22
23 var result = []; 23 var result = [];
24 data[0].forEach((cabecera) => { 24 data[0].forEach((cabecera) => {
25 25
26 let idCabecera = cabecera.TIP + cabecera.TCO + cabecera.SUC + cabecera.NCO; 26 let idCabecera = cabecera.TIP + cabecera.TCO + cabecera.SUC + cabecera.NCO;
27 27
28 var cuerpos = data[1].filter((cuerpo) => { 28 var cuerpos = data[1].filter((cuerpo) => {
29 let idCuerpo = cuerpo.TIP + cuerpo.TCO + cuerpo.SUC + cuerpo.NCO; 29 let idCuerpo = cuerpo.TIP + cuerpo.TCO + cuerpo.SUC + cuerpo.NCO;
30 return idCuerpo == idCabecera; 30 return idCuerpo == idCabecera;
31 }); 31 });
32 32
33 result.push({ 33 result.push({
34 cabecera: cabecera, 34 cabecera: cabecera,
35 cuerpo: cuerpos 35 cuerpo: cuerpos
36 }); 36 });
37 }); 37 });
38 38
39 res.status(200).send(result); 39 res.status(200).send(result);
40 }); 40 });
41 }); 41 });
42 42
43 router.post('/comprobante', function(req, res) { 43 router.post('/comprobante', function(req, res) {
44 44
45 var recadv = require('../recadv')(JSON.parse(JSON.stringify(req.body.cabecera)), 45 var recadv = require('../recadv')(JSON.parse(JSON.stringify(req.body.cabecera)),
46 JSON.parse(JSON.stringify(req.body.cuerpo))); 46 JSON.parse(JSON.stringify(req.body.cuerpo)));
47 47
48 var guardar = wsServer.guardarComprobante(req, req.body.cabecera.GLN); 48 var guardar = wsServer.guardarComprobante(req, req.body.cabecera.GLN);
49 49
50 Promise.all([recadv, guardar]) 50 Promise.all([
51 recadv,
52 guardar,
53 knex('PMAEFACT_TEMP').where({
54 TIP: req.body.cabecera.TIP,
55 TCO: req.body.cabecera.TCO,
56 SUC: req.body.cabecera.SUC,
57 NCO: req.body.cabecera.NCO,
58 COD: req.body.cabecera.COD
59 })
60 .del(),
61 knex('PMOVFACT_TEMP').where({
62 TIP: req.body.cabecera.TIP,
63 TCO: req.body.cabecera.TCO,
64 SUC: req.body.cabecera.SUC,
65 NCO: req.body.cabecera.NCO
66 })])
51 .then(() => { 67 .then(() => {
52 res.status(200).send('Comprobante guardado con éxito'); 68 res.status(200).send('Comprobante guardado con éxito');
53 }) 69 })
54 .catch(() => res.status(500).send('Algo salió mal')); 70 .catch(err => res.status(500).send(err));
55 71
56 }); 72 });
57 73
webSocketServer/index.js
1 module.exports = function() { 1 module.exports = function() {
2 2
3 const webSocketServer = require('ws').Server; 3 const webSocketServer = require('ws').Server;
4 var clients = []; 4 var clients = [];
5 5
6 const objWs = {}; 6 const objWs = {};
7 7
8 objWs.wsServer = new webSocketServer({ 8 objWs.wsServer = new webSocketServer({
9 port: config.port 9 port: config.port
10 }); 10 });
11 11
12 objWs.wsServer.on('connection', function connection(ws) { 12 objWs.wsServer.on('connection', function connection(ws) {
13 13
14 console.log('open socket server'); 14 console.log('open socket server');
15 15
16 ws.on('message', function incoming(message) { 16 ws.on('message', function incoming(message) {
17 17
18 message = JSON.parse(message.toString('utf8')); 18 message = JSON.parse(message.toString('utf8'));
19 19
20 switch (message.action) { 20 switch (message.action) {
21 case 'gln': 21 case 'gln':
22 clients.push({ws: ws, gln: message.gln}); 22 clients.push({ws: ws, gln: message.gln});
23 break; 23 break;
24 default: 24 default:
25 // console.log(message.action); 25 // console.log(message.action);
26 } 26 }
27 }); 27 });
28 }); 28 });
29 29
30 objWs.getEntidad = function(gln, tableName, where, queryString) { 30 objWs.getEntidad = function(gln, tableName, where, queryString) {
31 31
32 return new Promise(function(resolve, reject) { 32 return new Promise(function(resolve, reject) {
33 33
34 var client = clients.filter(function(client) { 34 var client = clients.filter(function(client) {
35 return client.gln == gln 35 return client.gln == gln
36 })[0]; 36 })[0];
37 37
38 if (!client) { 38 if (!client) {
39 reject('No se encuentra el webSocket client'); 39 reject('No se encuentra el webSocket client');
40 } 40 }
41 41
42 var idSolicitud = Math.round(Math.random() * 1000); 42 var idSolicitud = Math.round(Math.random() * 1000);
43 43
44 var enviar = { 44 var enviar = {
45 action: 'getEntity', 45 action: 'getEntity',
46 idSolicitud: idSolicitud 46 idSolicitud: idSolicitud
47 }; 47 };
48 48
49 if (queryString) { 49 if (queryString) {
50 50
51 enviar.queryString = queryString; 51 enviar.queryString = queryString;
52 } else { 52 } else {
53 enviar.tableName = tableName; 53 enviar.tableName = tableName;
54 enviar.where = where || {}; 54 enviar.where = where || {};
55 } 55 }
56 56
57 client.ws.send(JSON.stringify(enviar)); 57 client.ws.send(JSON.stringify(enviar));
58 58
59 client.ws.on('message', function(message) { 59 client.ws.on('message', function(message) {
60 60
61 message = JSON.parse(message); 61 message = JSON.parse(message);
62 62
63 if (idSolicitud == message.idSolicitud) { 63 if (idSolicitud == message.idSolicitud) {
64 64
65 resolve(message.data); 65 resolve(message.data);
66 } 66 }
67 67
68 }); 68 });
69 }); 69 });
70 } 70 }
71 71
72 objWs.getClientGln = function(gln) { 72 objWs.getClientGln = function(gln) {
73 return clients.filter(function(client) { 73 return clients.filter(function(client) {
74 return client.gln = gln; 74 return client.gln = gln;
75 }); 75 });
76 } 76 }
77 77
78 objWs.guardarComprobante = function (cuerpo, gln) { 78 objWs.guardarComprobante = function (cuerpo, gln) {
79 79
80 return new Promise((resolve, reject) => { 80 return new Promise((resolve, reject) => {
81 81
82 var client = clients.filter(function(client) { 82 var client = clients.filter(function(client) {
83 return client.gln == gln 83 return client.gln == gln
84 })[0]; 84 })[0];
85 85
86 if (!client) { 86 if (!client) {
87 reject('No se encuentra el webSocket client'); 87 reject('No se encuentra el webSocket client');
88 } 88 }
89 89
90 var idSolicitud = Math.round(Math.random() * 1000); 90 var idSolicitud = Math.round(Math.random() * 1000);
91 91
92 var enviar = { 92 var enviar = {
93 action: 'comprobante', 93 action: 'comprobante',
94 req: cuerpo 94 req: cuerpo
95 }; 95 };
96 96
97 console.log(`enviando comprobante a cliente ${client} y ${cuerpo}`); 97 console.log(`enviando comprobante a cliente`)
98 console.log(client);
99 console.log(cuerpo);
100
98 client.ws.send(JSON.stringify(enviar)); 101 client.ws.send(JSON.stringify(enviar));
99 102
100 client.ws.on('message', function(message) { 103 client.ws.on('message', function(message) {
101 104
102 message = JSON.parse(message); 105 message = JSON.parse(message);
103 106
104 if (idSolicitud == message.idSolicitud) { 107 if (idSolicitud == message.idSolicitud) {
105 108
106 resolve(message.data); 109 resolve(message.data);
107 } 110 }
108 111
109 }); 112 });
110 113
111 }); 114 });
112 } 115 }
113 116
114 return objWs; 117 return objWs;
115 } 118 }
116 119