mirror of
https://github.com/DeNNiiInc/dbgate.git
synced 2026-04-28 13:05:58 +00:00
introduced sqltree typescript library
This commit is contained in:
@@ -7,6 +7,7 @@
|
|||||||
"scripts": {
|
"scripts": {
|
||||||
"start:api": "yarn workspace @dbgate/api start",
|
"start:api": "yarn workspace @dbgate/api start",
|
||||||
"start:web": "yarn workspace @dbgate/web start",
|
"start:web": "yarn workspace @dbgate/web start",
|
||||||
|
"start:sqltree": "yarn workspace @dbgate/sqltree start",
|
||||||
"start": "concurrently --kill-others-on-fail \"yarn start:api\" \"yarn start:web\"",
|
"start": "concurrently --kill-others-on-fail \"yarn start:api\" \"yarn start:web\"",
|
||||||
|
|
||||||
"ts:api": "yarn workspace @dbgate/api ts",
|
"ts:api": "yarn workspace @dbgate/api ts",
|
||||||
|
|||||||
@@ -17,7 +17,8 @@
|
|||||||
"pg": "^7.17.0",
|
"pg": "^7.17.0",
|
||||||
"socket.io": "^2.3.0",
|
"socket.io": "^2.3.0",
|
||||||
"uuid": "^3.4.0",
|
"uuid": "^3.4.0",
|
||||||
"@dbgate/engines": "^0.1.0"
|
"@dbgate/engines": "^0.1.0",
|
||||||
|
"@dbgate/sqltree": "^0.1.0"
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"start": "nodemon src/index.js",
|
"start": "nodemon src/index.js",
|
||||||
|
|||||||
@@ -1,13 +0,0 @@
|
|||||||
class Command {
|
|
||||||
/** @param driver {import('@dbgate/types').EngineDriver} */
|
|
||||||
toSql(driver) {
|
|
||||||
const dumper = driver.createDumper();
|
|
||||||
this.dumpSql(dumper);
|
|
||||||
return dumper.s;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** @param dumper {import('@dbgate/types').SqlDumper} */
|
|
||||||
dumpSql(dumper) {}
|
|
||||||
}
|
|
||||||
|
|
||||||
module.exports = Command;
|
|
||||||
@@ -1,37 +0,0 @@
|
|||||||
const Command = require('./command');
|
|
||||||
|
|
||||||
class Select extends Command {
|
|
||||||
constructor() {
|
|
||||||
super();
|
|
||||||
/** @type {number} */
|
|
||||||
this.topRecords = undefined;
|
|
||||||
/** @type {import('@dbgate/types').NamedObjectInfo} */
|
|
||||||
this.from = undefined;
|
|
||||||
/** @type {import('@dbgate/types').RangeDefinition} */
|
|
||||||
this.range = undefined;
|
|
||||||
this.distinct = false;
|
|
||||||
this.selectAll = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** @param dumper {import('@dbgate/types').SqlDumper} */
|
|
||||||
dumpSql(dumper) {
|
|
||||||
dumper.put('^select ');
|
|
||||||
if (this.topRecords) {
|
|
||||||
dumper.put('^top %s ', this.topRecords);
|
|
||||||
}
|
|
||||||
if (this.distinct) {
|
|
||||||
dumper.put('^distinct ');
|
|
||||||
}
|
|
||||||
if (this.selectAll) {
|
|
||||||
dumper.put('* ');
|
|
||||||
} else {
|
|
||||||
// TODO
|
|
||||||
}
|
|
||||||
dumper.put('^from %f ', this.from);
|
|
||||||
if (this.range) {
|
|
||||||
dumper.put('^limit %s ^offset %s ', this.range.limit, this.range.offset);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
module.exports = Select;
|
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
const engines = require('@dbgate/engines');
|
const engines = require('@dbgate/engines');
|
||||||
const Select = require('../dmlf/select');
|
const { Select } = require('@dbgate/sqltree');
|
||||||
const driverConnect = require('../utility/driverConnect')
|
const driverConnect = require('../utility/driverConnect');
|
||||||
|
|
||||||
let systemConnection;
|
let systemConnection;
|
||||||
let storedConnection;
|
let storedConnection;
|
||||||
|
|||||||
1
packages/sqltree/.gitignore
vendored
Normal file
1
packages/sqltree/.gitignore
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
lib
|
||||||
19
packages/sqltree/package.json
Normal file
19
packages/sqltree/package.json
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
{
|
||||||
|
"version": "0.1.0",
|
||||||
|
"name": "@dbgate/sqltree",
|
||||||
|
"main": "lib/index.js",
|
||||||
|
"typings": "lib/index.d.ts",
|
||||||
|
"scripts": {
|
||||||
|
"prepare": "yarn build",
|
||||||
|
"build": "tsc",
|
||||||
|
"start": "tsc --watch"
|
||||||
|
},
|
||||||
|
"files": [
|
||||||
|
"lib"
|
||||||
|
],
|
||||||
|
"devDependencies": {
|
||||||
|
"@dbgate/types": "^0.1.0",
|
||||||
|
"@types/node": "^13.7.0",
|
||||||
|
"typescript": "^3.7.5"
|
||||||
|
}
|
||||||
|
}
|
||||||
13
packages/sqltree/src/Command.ts
Normal file
13
packages/sqltree/src/Command.ts
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
import { EngineDriver, SqlDumper } from "@dbgate/types";
|
||||||
|
|
||||||
|
class Command {
|
||||||
|
toSql(driver: EngineDriver) {
|
||||||
|
const dumper = driver.createDumper();
|
||||||
|
this.dumpSql(dumper);
|
||||||
|
return dumper.s;
|
||||||
|
}
|
||||||
|
|
||||||
|
dumpSql(dumper: SqlDumper) {}
|
||||||
|
}
|
||||||
|
|
||||||
|
export default Command;
|
||||||
31
packages/sqltree/src/Select.ts
Normal file
31
packages/sqltree/src/Select.ts
Normal file
@@ -0,0 +1,31 @@
|
|||||||
|
import Command from "./Command";
|
||||||
|
import { NamedObjectInfo, RangeDefinition, SqlDumper } from "@dbgate/types";
|
||||||
|
|
||||||
|
class Select extends Command {
|
||||||
|
topRecords: number;
|
||||||
|
from: NamedObjectInfo;
|
||||||
|
range: RangeDefinition;
|
||||||
|
distinct = false;
|
||||||
|
selectAll = false;
|
||||||
|
|
||||||
|
dumpSql(dumper: SqlDumper) {
|
||||||
|
dumper.put("^select ");
|
||||||
|
if (this.topRecords) {
|
||||||
|
dumper.put("^top %s ", this.topRecords);
|
||||||
|
}
|
||||||
|
if (this.distinct) {
|
||||||
|
dumper.put("^distinct ");
|
||||||
|
}
|
||||||
|
if (this.selectAll) {
|
||||||
|
dumper.put("* ");
|
||||||
|
} else {
|
||||||
|
// TODO
|
||||||
|
}
|
||||||
|
dumper.put("^from %f ", this.from);
|
||||||
|
if (this.range) {
|
||||||
|
dumper.put("^limit %s ^offset %s ", this.range.limit, this.range.offset);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export default Select;
|
||||||
2
packages/sqltree/src/index.ts
Normal file
2
packages/sqltree/src/index.ts
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
export { default as Select } from "./Select";
|
||||||
|
export { default as Command } from "./Command";
|
||||||
12
packages/sqltree/tsconfig.json
Normal file
12
packages/sqltree/tsconfig.json
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
{
|
||||||
|
"compilerOptions": {
|
||||||
|
"target": "ES2015",
|
||||||
|
"module": "commonjs",
|
||||||
|
"declaration": true,
|
||||||
|
"skipLibCheck": true,
|
||||||
|
"outDir": "lib"
|
||||||
|
},
|
||||||
|
"include": [
|
||||||
|
"src/**/*"
|
||||||
|
]
|
||||||
|
}
|
||||||
@@ -1474,6 +1474,11 @@
|
|||||||
resolved "https://registry.yarnpkg.com/@types/node/-/node-12.12.26.tgz#213e153babac0ed169d44a6d919501e68f59dea9"
|
resolved "https://registry.yarnpkg.com/@types/node/-/node-12.12.26.tgz#213e153babac0ed169d44a6d919501e68f59dea9"
|
||||||
integrity sha512-UmUm94/QZvU5xLcUlNR8hA7Ac+fGpO1EG/a8bcWVz0P0LqtxFmun9Y2bbtuckwGboWJIT70DoWq1r3hb56n3DA==
|
integrity sha512-UmUm94/QZvU5xLcUlNR8hA7Ac+fGpO1EG/a8bcWVz0P0LqtxFmun9Y2bbtuckwGboWJIT70DoWq1r3hb56n3DA==
|
||||||
|
|
||||||
|
"@types/node@^13.7.0":
|
||||||
|
version "13.7.7"
|
||||||
|
resolved "https://registry.yarnpkg.com/@types/node/-/node-13.7.7.tgz#1628e6461ba8cc9b53196dfeaeec7b07fa6eea99"
|
||||||
|
integrity sha512-Uo4chgKbnPNlxQwoFmYIwctkQVkMMmsAoGGU4JKwLuvBefF0pCq4FybNSnfkfRCpC7ZW7kttcC/TrRtAJsvGtg==
|
||||||
|
|
||||||
"@types/node@^8.0.47":
|
"@types/node@^8.0.47":
|
||||||
version "8.10.59"
|
version "8.10.59"
|
||||||
resolved "https://registry.yarnpkg.com/@types/node/-/node-8.10.59.tgz#9e34261f30183f9777017a13d185dfac6b899e04"
|
resolved "https://registry.yarnpkg.com/@types/node/-/node-8.10.59.tgz#9e34261f30183f9777017a13d185dfac6b899e04"
|
||||||
|
|||||||
Reference in New Issue
Block a user