-
Notifications
You must be signed in to change notification settings - Fork 0
/
app.js
103 lines (81 loc) · 2.08 KB
/
app.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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
//node
var express = require("express");
var fs = require("fs");
var bodyParser = require('body-parser');
//user
var buildSchema = require("./buildSchema");
var sqlQueryBuilder = require("./sqlQueryBuilder");
var tedious = require('./tdsQuery');
//json
var tables = require('./tables');
var schema = require('./schema');
var operators = require('./operators');
var app = express();
app.set('view engine', 'ejs');
function sendFile(path, res){
var filePath = __dirname + path;
fs.exists(filePath, function(exists){
if(exists){
res.sendFile(filePath);
}else{
res.sendStatus(404);
}
});
}
app.get("/www/*", function(req, res){
sendFile(req.path, res);
});
function parseSqlQueryResult(result){
if(!result || !result.length){
return [];
}
var rows = [];
for(var rowIndex in result){
var row = result[rowIndex];
if(!row.length){
continue;
}
var columnData = {};
for(var colIndex in row){
var column = row[colIndex];
if(!column.metadata){
continue;
}
var colName = column.metadata.colName;
var value = column.value;
columnData[colName] = value;
}
rows.push(columnData);
}
return rows;
}
app.get("/", function(req, res){
res.render(__dirname + '/www/views/home', {
tables: JSON.stringify(tables),
schema: JSON.stringify(schema),
operators: JSON.stringify(operators)
});
});
app.use(bodyParser.json());
app.post("/runQuery", function(req, res){
var sqlQuery = sqlQueryBuilder(req.body);
tedious(sqlQuery, function(result){
var parsedData = parseSqlQueryResult(result);
res.json(parsedData);
});
});
app.get("/rebuildschema", function(req, res){
buildSchema(function(schema){
var stringifiedSchema = JSON.stringify(schema, null, " ");
fs.writeFile("schema.json", stringifiedSchema, function(err){
if(!err){
res.send(stringifiedSchema);
}else{
res.send(JSON.stringify(err, null, " "));
}
});
});
});
var portNo = 3000;
app.listen(portNo);
console.log("server started on port " + portNo);