-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
61 lines (51 loc) · 2.33 KB
/
server.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
//Constants
const express = require('express');
const exphbs = require('express-handlebars');
const Handlebars = require('handlebars');
const bodyParser = require('body-parser');
const http = require('http');
const url = require('url');
const moment = require('moment');
const mysql = require('mysql');
const server = http.createServer((req, res) => {
const urlObj = url.parse(req.url, true);
const idMonitoramento = urlObj.query.idMonitoramento;
const idPropriedade = urlObj.query.idPropriedade;
})
const connection = mysql.createConnection({
user: 'root',
password: '',
host: 'localhost',
database: 'geotecnologia'
})
const app = express();
app.use(bodyParser.urlencoded({ extended: false }));
app.use('/css', express.static(__dirname + '/public/css'));
app.use('/js', express.static(__dirname + '/public/js'));
app.use('/img', express.static(__dirname + '/public/img'));
// Template engine
app.engine('hbs', exphbs.engine({
extname: '.hbs',
helpers: {
formatDate: (date) => {
return moment(date).format('DD/MM/YYYY');
}
}
}));
app.set('view engine', 'hbs');
// Routes and Templates
app.get('/', (req, res) => { res.render('index'); })
app.get('/list', (req, res) => {
connection.query('SELECT m.idMonitoramento, m.dataMonitoramento, m.analista, m.resultado, pd.idprodutor, pd.nomeProdutor, pd.cpfProdutor, pr.idPropriedade, pr.nomePropriedade, pr.numeroCadastroRural FROM propriedades pr, vinculo v INNER JOIN monitoramentos m ON (v.idVinculo = m.idVinculo) INNER JOIN produtores pd ON (v.idProdutor = pd.idProdutor) order by nomePropriedade ASC', (err, results, fields) => {
res.render('list', { data: results });
})
})
app.get('/select/:idMonitoramento', (req, res) => {
connection.query('SELECT m.idMonitoramento, m.parecerAnalise, pd.idprodutor, pr.idPropriedade, pr.tipoPropriedade, v.idVinculo, v.tipoVinculoProdutor FROM propriedades pr, vinculo v INNER JOIN monitoramentos m ON (v.idVinculo = m.idVinculo) INNER JOIN produtores pd ON (v.idProdutor = pd.idProdutor) WHERE m.resultado = "Liberado" AND idMonitoramento=?', [req.params.idMonitoramento], (err, results, fields) => {
res.render('select', { idMonitoramento: req.params.idMonitoramento, data: results });
})
})
//Start server
app.listen(3000, () => {
console.log('Server started on port 3000');
});