-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
86 lines (71 loc) · 2.87 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
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
var express = require('express')
var bodyParser = require('body-parser')
var cors = require('cors')
var marked = require('marked')
var app = express()
app.use(cors())
app.use(bodyParser.text())
app.use(bodyParser.json())
app.use("/explore", express.static('public'))
// init sqlite db
var fs = require('fs')
var dbFile = './.data/sqlite.db'
var exists = fs.existsSync(dbFile)
var sqlite3 = require('sqlite3').verbose()
var db = new sqlite3.Database(dbFile)
db.exec("PRAGMA foreign_keys = ON")
info((x) => console.log(x))
app.post('/exec', (req, res) => executeSql(req.body.sql, req.body.params, x => res.send(x)))
app.put('/exec', (req, res) => executeSql(req.body, [], x => res.send(x)))
app.get('/exec/:sql', (req, res) => executeSql(req.params.sql, [], x => res.send(x)))
app.get('/info', (req, res) => info(x => res.send(x)))
app.get('/dump', (req, res) => dump(x => res.send(x)))
function dump(callback) {
function loop(sqls, i, dump) {
db.all(sqls[i].sql, (err, res) => {
dump.push({ table: sqls[i].table, content: res })
i++
if (i == sqls.length) callback(dump)
else loop(sqls, i, dump)
})
}
db.all("SELECT name FROM sqlite_master WHERE type='table'", (err, tables) => {
loop(tables.map(x => { return { sql: "SELECT * from " + x.name, table: x.name }}), 0, [])
})
}
function info(callback) {
db.all("SELECT name, sql FROM sqlite_master WHERE type='table'", (err, tables) => {
let sql = tables
.map(x => "SELECT '" + x.name + "' as name, COUNT(*) as rows, '" + x.sql + "' as schema from " + x.name + " UNION ")
.reduce((x, y) => x + y)
sql = sql.substr(0, sql.length - 6)
db.all(sql, (err, tableInfos) => callback({ tables: tableInfos }))
})
}
function executeSql(sql, params, callback) {
params = params || []
if (!sql) return callback({ error: "no sql was given to execute" })
sql = sql.trim()
if (sql.toLowerCase().startsWith("select ")) {
console.log("executing sql: " + sql + "\nwith params: ", params)
db.all(sql, params, (err, rows) => {
console.log("error", err)
callback({ result: rows, error: err ? err.stack : undefined })
})
} else {
//sql = "PRAGMA foreign_keys = ON; \n" + sql + ";"
console.log("executing sql: " + sql + "\nwith params: ", params)
db.serialize(() => db.run(sql, params, err => {
console.log("error", err)
callback({ result: err ? "failed" : "ok", error: err ? err.stack : undefined })
}))
}
}
app.get("/", (req, res) => {
let content = marked(fs.readFileSync('./README.md', 'utf8'))
res.send( '<div class="markdown-body" style="margin: 0 auto 0 auto; max-width: 850px; padding: 0 12px 0 12px">'
+ '<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/github-markdown-css/3.0.1/github-markdown.min.css">'
+ content
+ '</div>')
})
app.listen(process.env.PORT, () => console.log('NodeJS is listenning..'))