save connection, list connections

This commit is contained in:
Jan Prochazka
2020-01-01 22:11:35 +01:00
parent 0119d1839f
commit 800f3eec26
5 changed files with 67 additions and 21 deletions

View File

@@ -1,23 +1,36 @@
const os = require('os');
const path = require('path');
const fs = require('fs-extra');
const express = require('express');
const router = express.Router();
const { fork } = require('child_process');
const _ = require('lodash');
function datadir() {
return path.join(os.homedir(), 'dbgate-data');
}
router.post('/test', async (req, res) => {
const subprocess = fork(`${__dirname}/connectProcess.js`);
subprocess.send(req.body);
subprocess.on('message', resp => res.json(resp));
});
// const { server, port, user, password } = req.body;
// let pool;
// try {
// pool = await mssql.connect({ server, port, user, password });
// const resp = await pool.request().query('SELECT @@VERSION AS version');
// const { version } = resp.recordset[0];
// res.json({ version });
// } catch (e) {
// res.json({ error: e.message });
// }
// if (pool) await pool.close();
router.post('/save', async (req, res) => {
await fs.mkdir(datadir());
const fileName = `${new Date().getTime()}.con`;
await fs.writeFile(path.join(datadir(), fileName), JSON.stringify(req.body));
res.json({ fileName });
});
router.get('/list', async (req, res) => {
const files = await fs.readdir(datadir());
res
.json(
await Promise.all(files.filter(x => x.endsWith('.con')).map(x => fs.readFile(path.join(datadir(), x), 'utf-8')))
)
.map(x => _.omit(JSON.parse(x), 'password'));
});
module.exports = router;