@duckcodeailabs/dql-connectors 0.1.0 → 0.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +41 -0
- package/dist/connection-pool.d.ts.map +1 -1
- package/dist/connection-pool.js +27 -0
- package/dist/connection-pool.js.map +1 -1
- package/dist/connector.d.ts +9 -2
- package/dist/connector.d.ts.map +1 -1
- package/dist/drivers/athena.d.ts +15 -0
- package/dist/drivers/athena.d.ts.map +1 -0
- package/dist/drivers/athena.js +113 -0
- package/dist/drivers/athena.js.map +1 -0
- package/dist/drivers/clickhouse.d.ts +12 -0
- package/dist/drivers/clickhouse.d.ts.map +1 -0
- package/dist/drivers/clickhouse.js +77 -0
- package/dist/drivers/clickhouse.js.map +1 -0
- package/dist/drivers/databricks.d.ts +15 -0
- package/dist/drivers/databricks.d.ts.map +1 -0
- package/dist/drivers/databricks.js +108 -0
- package/dist/drivers/databricks.js.map +1 -0
- package/dist/drivers/duckdb.d.ts +6 -1
- package/dist/drivers/duckdb.d.ts.map +1 -1
- package/dist/drivers/duckdb.js +42 -6
- package/dist/drivers/duckdb.js.map +1 -1
- package/dist/drivers/fabric.d.ts +7 -0
- package/dist/drivers/fabric.d.ts.map +1 -0
- package/dist/drivers/fabric.js +12 -0
- package/dist/drivers/fabric.js.map +1 -0
- package/dist/drivers/mssql.d.ts +2 -2
- package/dist/drivers/mssql.d.ts.map +1 -1
- package/dist/drivers/mssql.js.map +1 -1
- package/dist/drivers/postgresql.d.ts +2 -2
- package/dist/drivers/postgresql.d.ts.map +1 -1
- package/dist/drivers/postgresql.js.map +1 -1
- package/dist/drivers/redshift.d.ts +7 -0
- package/dist/drivers/redshift.d.ts.map +1 -0
- package/dist/drivers/redshift.js +12 -0
- package/dist/drivers/redshift.js.map +1 -0
- package/dist/drivers/trino.d.ts +12 -0
- package/dist/drivers/trino.d.ts.map +1 -0
- package/dist/drivers/trino.js +100 -0
- package/dist/drivers/trino.js.map +1 -0
- package/dist/index.d.ts +14 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +14 -0
- package/dist/index.js.map +1 -1
- package/dist/sql-params.js +1 -1
- package/dist/sql-params.js.map +1 -1
- package/package.json +3 -2
package/README.md
ADDED
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
# `@duckcodeailabs/dql-connectors`
|
|
2
|
+
|
|
3
|
+
Query execution and connector layer for DQL.
|
|
4
|
+
|
|
5
|
+
It provides connection management, driver normalization, SQL parameter handling, and query execution across supported databases and local engines.
|
|
6
|
+
|
|
7
|
+
## Install
|
|
8
|
+
|
|
9
|
+
```bash
|
|
10
|
+
pnpm add @duckcodeailabs/dql-connectors
|
|
11
|
+
```
|
|
12
|
+
|
|
13
|
+
## Example
|
|
14
|
+
|
|
15
|
+
```ts
|
|
16
|
+
import { QueryExecutor } from '@duckcodeailabs/dql-connectors';
|
|
17
|
+
|
|
18
|
+
const executor = new QueryExecutor();
|
|
19
|
+
|
|
20
|
+
const result = await executor.executePositional(
|
|
21
|
+
'select * from read_csv_auto(?) limit 5',
|
|
22
|
+
['./data/revenue.csv'],
|
|
23
|
+
{ driver: 'file', filepath: ':memory:' },
|
|
24
|
+
);
|
|
25
|
+
|
|
26
|
+
console.log(result.columns);
|
|
27
|
+
console.log(result.rows);
|
|
28
|
+
|
|
29
|
+
await executor.disconnect();
|
|
30
|
+
```
|
|
31
|
+
|
|
32
|
+
## Common Uses
|
|
33
|
+
|
|
34
|
+
- power local preview with CSV, Parquet, or DuckDB-backed flows
|
|
35
|
+
- execute compiled DQL SQL against warehouse connections
|
|
36
|
+
- normalize placeholders and parameter values across drivers
|
|
37
|
+
|
|
38
|
+
## Learn More
|
|
39
|
+
|
|
40
|
+
- Data sources: [`../../docs/data-sources.md`](../../docs/data-sources.md)
|
|
41
|
+
- Project config: [`../../docs/project-config.md`](../../docs/project-config.md)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"connection-pool.d.ts","sourceRoot":"","sources":["../src/connection-pool.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"connection-pool.d.ts","sourceRoot":"","sources":["../src/connection-pool.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAkC1E,wBAAgB,yBAAyB,CAAC,MAAM,EAAE,gBAAgB,GAAG,MAAM,CA0B1E;AAED,qBAAa,qBAAqB;IAChC,OAAO,CAAC,UAAU,CAA6C;IAEzD,YAAY,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAalE,eAAe,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC;IASxD,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC;IAMpC,OAAO,CAAC,eAAe;IAmCvB,OAAO,CAAC,SAAS;CAGlB"}
|
package/dist/connection-pool.js
CHANGED
|
@@ -6,6 +6,12 @@ import { BigQueryConnector } from './drivers/bigquery.js';
|
|
|
6
6
|
import { DuckDBConnector } from './drivers/duckdb.js';
|
|
7
7
|
import { MSSQLConnector } from './drivers/mssql.js';
|
|
8
8
|
import { FileConnector } from './drivers/file.js';
|
|
9
|
+
import { RedshiftConnector } from './drivers/redshift.js';
|
|
10
|
+
import { FabricConnector } from './drivers/fabric.js';
|
|
11
|
+
import { ClickHouseConnector } from './drivers/clickhouse.js';
|
|
12
|
+
import { DatabricksConnector } from './drivers/databricks.js';
|
|
13
|
+
import { AthenaConnector } from './drivers/athena.js';
|
|
14
|
+
import { TrinoConnector } from './drivers/trino.js';
|
|
9
15
|
import { createHash } from 'node:crypto';
|
|
10
16
|
function stableSerialize(value) {
|
|
11
17
|
if (value === null)
|
|
@@ -35,12 +41,21 @@ export function createConnectionConfigKey(config) {
|
|
|
35
41
|
database: config.database,
|
|
36
42
|
username: config.username,
|
|
37
43
|
password: config.password,
|
|
44
|
+
token: config.token,
|
|
38
45
|
ssl: config.ssl,
|
|
39
46
|
filepath: config.filepath,
|
|
40
47
|
projectId: config.projectId,
|
|
41
48
|
account: config.account,
|
|
42
49
|
warehouse: config.warehouse,
|
|
50
|
+
workgroup: config.workgroup,
|
|
43
51
|
connectionString: config.connectionString,
|
|
52
|
+
schema: config.schema,
|
|
53
|
+
role: config.role,
|
|
54
|
+
region: config.region,
|
|
55
|
+
outputLocation: config.outputLocation,
|
|
56
|
+
httpPath: config.httpPath,
|
|
57
|
+
catalog: config.catalog,
|
|
58
|
+
privateKey: config.privateKey,
|
|
44
59
|
};
|
|
45
60
|
const payload = stableSerialize(normalized);
|
|
46
61
|
return createHash('sha1').update(payload).digest('hex');
|
|
@@ -88,6 +103,18 @@ export class ConnectionPoolManager {
|
|
|
88
103
|
return new MSSQLConnector();
|
|
89
104
|
case 'file':
|
|
90
105
|
return new FileConnector();
|
|
106
|
+
case 'redshift':
|
|
107
|
+
return new RedshiftConnector();
|
|
108
|
+
case 'fabric':
|
|
109
|
+
return new FabricConnector();
|
|
110
|
+
case 'clickhouse':
|
|
111
|
+
return new ClickHouseConnector();
|
|
112
|
+
case 'databricks':
|
|
113
|
+
return new DatabricksConnector();
|
|
114
|
+
case 'athena':
|
|
115
|
+
return new AthenaConnector();
|
|
116
|
+
case 'trino':
|
|
117
|
+
return new TrinoConnector();
|
|
91
118
|
default:
|
|
92
119
|
throw new Error(`Unsupported database driver: ${config.driver}`);
|
|
93
120
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"connection-pool.js","sourceRoot":"","sources":["../src/connection-pool.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAC9D,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAC1D,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAEzC,SAAS,eAAe,CAAC,KAAc;IACrC,IAAI,KAAK,KAAK,IAAI;QAAE,OAAO,MAAM,CAAC;IAClC,IAAI,KAAK,KAAK,SAAS;QAAE,OAAO,WAAW,CAAC;IAC5C,IAAI,OAAO,KAAK,KAAK,QAAQ;QAAE,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC5D,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC;QAAE,OAAO,IAAI,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC;IAEvF,MAAM,GAAG,GAAG,KAAgC,CAAC;IAC7C,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;IACrC,MAAM,OAAO,GAAa,EAAE,CAAC;IAC7B,KAAK,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC;QACrB,MAAM,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;QACjB,IAAI,CAAC,KAAK,SAAS;YAAE,SAAS;QAC9B,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,eAAe,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;IAC7D,CAAC;IACD,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC;AAClC,CAAC;AAED,MAAM,UAAU,yBAAyB,CAAC,MAAwB;IAChE,MAAM,UAAU,GAA4B;QAC1C,MAAM,EAAE,MAAM,CAAC,MAAM;QACrB,IAAI,EAAE,MAAM,CAAC,IAAI;QACjB,IAAI,EAAE,MAAM,CAAC,IAAI;QACjB,QAAQ,EAAE,MAAM,CAAC,QAAQ;QACzB,QAAQ,EAAE,MAAM,CAAC,QAAQ;QACzB,QAAQ,EAAE,MAAM,CAAC,QAAQ;QACzB,GAAG,EAAE,MAAM,CAAC,GAAG;QACf,QAAQ,EAAE,MAAM,CAAC,QAAQ;QACzB,SAAS,EAAE,MAAM,CAAC,SAAS;QAC3B,OAAO,EAAE,MAAM,CAAC,OAAO;QACvB,SAAS,EAAE,MAAM,CAAC,SAAS;QAC3B,gBAAgB,EAAE,MAAM,CAAC,gBAAgB;
|
|
1
|
+
{"version":3,"file":"connection-pool.js","sourceRoot":"","sources":["../src/connection-pool.ts"],"names":[],"mappings":"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"}
|
package/dist/connector.d.ts
CHANGED
|
@@ -1,23 +1,30 @@
|
|
|
1
1
|
import type { QueryResult } from './result-types.js';
|
|
2
2
|
export interface ConnectionConfig {
|
|
3
|
-
driver: 'postgresql' | 'mysql' | 'sqlite' | 'bigquery' | 'snowflake' | 'duckdb' | 'mssql' | 'file';
|
|
3
|
+
driver: 'postgresql' | 'mysql' | 'sqlite' | 'bigquery' | 'snowflake' | 'duckdb' | 'mssql' | 'file' | 'redshift' | 'fabric' | 'clickhouse' | 'databricks' | 'athena' | 'trino';
|
|
4
4
|
host?: string;
|
|
5
5
|
port?: number;
|
|
6
6
|
database?: string;
|
|
7
|
+
catalog?: string;
|
|
7
8
|
username?: string;
|
|
8
9
|
password?: string;
|
|
10
|
+
token?: string;
|
|
9
11
|
ssl?: boolean;
|
|
10
12
|
filepath?: string;
|
|
11
13
|
projectId?: string;
|
|
12
14
|
account?: string;
|
|
13
15
|
warehouse?: string;
|
|
16
|
+
workgroup?: string;
|
|
14
17
|
schema?: string;
|
|
15
18
|
role?: string;
|
|
19
|
+
region?: string;
|
|
20
|
+
outputLocation?: string;
|
|
21
|
+
httpPath?: string;
|
|
16
22
|
privateKey?: string;
|
|
17
23
|
connectionString?: string;
|
|
18
24
|
}
|
|
25
|
+
export type DriverName = ConnectionConfig['driver'];
|
|
19
26
|
export interface DatabaseConnector {
|
|
20
|
-
readonly driverName:
|
|
27
|
+
readonly driverName: DriverName;
|
|
21
28
|
connect(config: ConnectionConfig): Promise<void>;
|
|
22
29
|
execute(sql: string, params?: unknown[]): Promise<QueryResult>;
|
|
23
30
|
disconnect(): Promise<void>;
|
package/dist/connector.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"connector.d.ts","sourceRoot":"","sources":["../src/connector.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAErD,MAAM,WAAW,gBAAgB;IAC/B,MAAM,
|
|
1
|
+
{"version":3,"file":"connector.d.ts","sourceRoot":"","sources":["../src/connector.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAErD,MAAM,WAAW,gBAAgB;IAC/B,MAAM,EACF,YAAY,GACZ,OAAO,GACP,QAAQ,GACR,UAAU,GACV,WAAW,GACX,QAAQ,GACR,OAAO,GACP,MAAM,GACN,UAAU,GACV,QAAQ,GACR,YAAY,GACZ,YAAY,GACZ,QAAQ,GACR,OAAO,CAAC;IACZ,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,GAAG,CAAC,EAAE,OAAO,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B;AAED,MAAM,MAAM,UAAU,GAAG,gBAAgB,CAAC,QAAQ,CAAC,CAAC;AAEpD,MAAM,WAAW,iBAAiB;IAChC,QAAQ,CAAC,UAAU,EAAE,UAAU,CAAC;IAChC,OAAO,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACjD,OAAO,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;IAC/D,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5B,IAAI,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC;CAC1B"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { DatabaseConnector, ConnectionConfig } from '../connector.js';
|
|
2
|
+
import type { QueryResult } from '../result-types.js';
|
|
3
|
+
export declare class AthenaConnector implements DatabaseConnector {
|
|
4
|
+
readonly driverName = "athena";
|
|
5
|
+
private client;
|
|
6
|
+
private athenaModule;
|
|
7
|
+
private database?;
|
|
8
|
+
private outputLocation?;
|
|
9
|
+
private workgroup?;
|
|
10
|
+
connect(config: ConnectionConfig): Promise<void>;
|
|
11
|
+
execute(sql: string, params?: unknown[]): Promise<QueryResult>;
|
|
12
|
+
disconnect(): Promise<void>;
|
|
13
|
+
ping(): Promise<boolean>;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=athena.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"athena.d.ts","sourceRoot":"","sources":["../../src/drivers/athena.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAC3E,OAAO,KAAK,EAAE,WAAW,EAA+B,MAAM,oBAAoB,CAAC;AAEnF,qBAAa,eAAgB,YAAW,iBAAiB;IACvD,QAAQ,CAAC,UAAU,YAAY;IAC/B,OAAO,CAAC,MAAM,CAAa;IAC3B,OAAO,CAAC,YAAY,CAAa;IACjC,OAAO,CAAC,QAAQ,CAAC,CAAS;IAC1B,OAAO,CAAC,cAAc,CAAC,CAAS;IAChC,OAAO,CAAC,SAAS,CAAC,CAAS;IAErB,OAAO,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC;IAShD,OAAO,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC;IA4E9D,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAK3B,IAAI,IAAI,OAAO,CAAC,OAAO,CAAC;CAQ/B"}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
export class AthenaConnector {
|
|
2
|
+
driverName = 'athena';
|
|
3
|
+
client = null;
|
|
4
|
+
athenaModule = null;
|
|
5
|
+
database;
|
|
6
|
+
outputLocation;
|
|
7
|
+
workgroup;
|
|
8
|
+
async connect(config) {
|
|
9
|
+
const moduleName = '@aws-sdk/client-athena';
|
|
10
|
+
this.athenaModule = await import(moduleName);
|
|
11
|
+
this.client = new this.athenaModule.AthenaClient({ region: config.region ?? config.host ?? 'us-east-1' });
|
|
12
|
+
this.database = config.database;
|
|
13
|
+
this.outputLocation = config.outputLocation ?? config.schema;
|
|
14
|
+
this.workgroup = config.workgroup ?? config.warehouse;
|
|
15
|
+
}
|
|
16
|
+
async execute(sql, params) {
|
|
17
|
+
if (!this.client || !this.athenaModule) {
|
|
18
|
+
throw new Error('Athena connector not connected. Call connect() first.');
|
|
19
|
+
}
|
|
20
|
+
if (params && params.length > 0) {
|
|
21
|
+
throw new Error('Athena connector does not yet support positional parameters.');
|
|
22
|
+
}
|
|
23
|
+
if (!this.outputLocation) {
|
|
24
|
+
throw new Error('Athena connector requires outputLocation or schema to point to an S3 query-results path.');
|
|
25
|
+
}
|
|
26
|
+
const startTime = performance.now();
|
|
27
|
+
const started = await this.client.send(new this.athenaModule.StartQueryExecutionCommand({
|
|
28
|
+
QueryString: sql,
|
|
29
|
+
QueryExecutionContext: this.database ? { Database: this.database } : undefined,
|
|
30
|
+
ResultConfiguration: { OutputLocation: this.outputLocation },
|
|
31
|
+
WorkGroup: this.workgroup,
|
|
32
|
+
}));
|
|
33
|
+
const queryExecutionId = started.QueryExecutionId;
|
|
34
|
+
if (!queryExecutionId) {
|
|
35
|
+
throw new Error('Athena did not return a query execution id.');
|
|
36
|
+
}
|
|
37
|
+
while (true) {
|
|
38
|
+
const statusResult = await this.client.send(new this.athenaModule.GetQueryExecutionCommand({ QueryExecutionId: queryExecutionId }));
|
|
39
|
+
const state = statusResult.QueryExecution?.Status?.State;
|
|
40
|
+
if (state === 'SUCCEEDED') {
|
|
41
|
+
break;
|
|
42
|
+
}
|
|
43
|
+
if (state === 'FAILED' || state === 'CANCELLED') {
|
|
44
|
+
throw new Error(statusResult.QueryExecution?.Status?.StateChangeReason ?? `Athena query ${state?.toLowerCase()}.`);
|
|
45
|
+
}
|
|
46
|
+
await delay(500);
|
|
47
|
+
}
|
|
48
|
+
const rows = [];
|
|
49
|
+
let columns = [];
|
|
50
|
+
let nextToken;
|
|
51
|
+
do {
|
|
52
|
+
const resultPage = await this.client.send(new this.athenaModule.GetQueryResultsCommand({
|
|
53
|
+
QueryExecutionId: queryExecutionId,
|
|
54
|
+
NextToken: nextToken,
|
|
55
|
+
}));
|
|
56
|
+
const columnInfo = resultPage.ResultSet?.ResultSetMetadata?.ColumnInfo ?? [];
|
|
57
|
+
if (columns.length === 0) {
|
|
58
|
+
columns = columnInfo.map((column) => ({
|
|
59
|
+
name: column.Name,
|
|
60
|
+
type: mapAthenaType(column.Type),
|
|
61
|
+
driverType: column.Type,
|
|
62
|
+
}));
|
|
63
|
+
}
|
|
64
|
+
const pageRows = resultPage.ResultSet?.Rows ?? [];
|
|
65
|
+
for (let index = 0; index < pageRows.length; index++) {
|
|
66
|
+
const data = pageRows[index].Data ?? [];
|
|
67
|
+
const record = Object.fromEntries(columns.map((column, columnIndex) => [column.name, data[columnIndex]?.VarCharValue ?? null]));
|
|
68
|
+
const isHeaderRow = index === 0 && rows.length === 0 && columns.every((column) => String(record[column.name] ?? '') === column.name);
|
|
69
|
+
if (!isHeaderRow) {
|
|
70
|
+
rows.push(record);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
nextToken = resultPage.NextToken;
|
|
74
|
+
} while (nextToken);
|
|
75
|
+
return {
|
|
76
|
+
columns,
|
|
77
|
+
rows,
|
|
78
|
+
rowCount: rows.length,
|
|
79
|
+
executionTimeMs: performance.now() - startTime,
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
async disconnect() {
|
|
83
|
+
this.client = null;
|
|
84
|
+
this.athenaModule = null;
|
|
85
|
+
}
|
|
86
|
+
async ping() {
|
|
87
|
+
try {
|
|
88
|
+
await this.execute('SELECT 1 AS ok');
|
|
89
|
+
return true;
|
|
90
|
+
}
|
|
91
|
+
catch {
|
|
92
|
+
return false;
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
function mapAthenaType(driverType) {
|
|
97
|
+
const lower = driverType.toLowerCase();
|
|
98
|
+
if (lower.includes('int') || lower.includes('double') || lower.includes('real') || lower.includes('decimal'))
|
|
99
|
+
return 'number';
|
|
100
|
+
if (lower === 'date')
|
|
101
|
+
return 'date';
|
|
102
|
+
if (lower.includes('timestamp'))
|
|
103
|
+
return 'datetime';
|
|
104
|
+
if (lower === 'boolean')
|
|
105
|
+
return 'boolean';
|
|
106
|
+
if (lower.includes('char') || lower.includes('string') || lower.includes('varchar'))
|
|
107
|
+
return 'string';
|
|
108
|
+
return 'unknown';
|
|
109
|
+
}
|
|
110
|
+
function delay(ms) {
|
|
111
|
+
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
112
|
+
}
|
|
113
|
+
//# sourceMappingURL=athena.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"athena.js","sourceRoot":"","sources":["../../src/drivers/athena.ts"],"names":[],"mappings":"AAGA,MAAM,OAAO,eAAe;IACjB,UAAU,GAAG,QAAQ,CAAC;IACvB,MAAM,GAAQ,IAAI,CAAC;IACnB,YAAY,GAAQ,IAAI,CAAC;IACzB,QAAQ,CAAU;IAClB,cAAc,CAAU;IACxB,SAAS,CAAU;IAE3B,KAAK,CAAC,OAAO,CAAC,MAAwB;QACpC,MAAM,UAAU,GAAG,wBAAwB,CAAC;QAC5C,IAAI,CAAC,YAAY,GAAG,MAAM,MAAM,CAAC,UAAoB,CAAC,CAAC;QACvD,IAAI,CAAC,MAAM,GAAG,IAAI,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,IAAI,IAAI,WAAW,EAAE,CAAC,CAAC;QAC1G,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;QAChC,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,cAAc,IAAI,MAAM,CAAC,MAAM,CAAC;QAC7D,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,SAAS,IAAI,MAAM,CAAC,SAAS,CAAC;IACxD,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,GAAW,EAAE,MAAkB;QAC3C,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YACvC,MAAM,IAAI,KAAK,CAAC,uDAAuD,CAAC,CAAC;QAC3E,CAAC;QACD,IAAI,MAAM,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAChC,MAAM,IAAI,KAAK,CAAC,8DAA8D,CAAC,CAAC;QAClF,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;YACzB,MAAM,IAAI,KAAK,CAAC,0FAA0F,CAAC,CAAC;QAC9G,CAAC;QAED,MAAM,SAAS,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC;QACpC,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,YAAY,CAAC,0BAA0B,CAAC;YACtF,WAAW,EAAE,GAAG;YAChB,qBAAqB,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,SAAS;YAC9E,mBAAmB,EAAE,EAAE,cAAc,EAAE,IAAI,CAAC,cAAc,EAAE;YAC5D,SAAS,EAAE,IAAI,CAAC,SAAS;SAC1B,CAAC,CAAC,CAAC;QACJ,MAAM,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,CAAC;QAClD,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACtB,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAC;QACjE,CAAC;QAED,OAAO,IAAI,EAAE,CAAC;YACZ,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,YAAY,CAAC,wBAAwB,CAAC,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,CAAC,CAAC,CAAC;YACpI,MAAM,KAAK,GAAG,YAAY,CAAC,cAAc,EAAE,MAAM,EAAE,KAAK,CAAC;YACzD,IAAI,KAAK,KAAK,WAAW,EAAE,CAAC;gBAC1B,MAAM;YACR,CAAC;YACD,IAAI,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,WAAW,EAAE,CAAC;gBAChD,MAAM,IAAI,KAAK,CAAC,YAAY,CAAC,cAAc,EAAE,MAAM,EAAE,iBAAiB,IAAI,gBAAgB,KAAK,EAAE,WAAW,EAAE,GAAG,CAAC,CAAC;YACrH,CAAC;YACD,MAAM,KAAK,CAAC,GAAG,CAAC,CAAC;QACnB,CAAC;QAED,MAAM,IAAI,GAAU,EAAE,CAAC;QACvB,IAAI,OAAO,GAAiB,EAAE,CAAC;QAC/B,IAAI,SAA6B,CAAC;QAElC,GAAG,CAAC;YACF,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,YAAY,CAAC,sBAAsB,CAAC;gBACrF,gBAAgB,EAAE,gBAAgB;gBAClC,SAAS,EAAE,SAAS;aACrB,CAAC,CAAC,CAAC;YAEJ,MAAM,UAAU,GAAG,UAAU,CAAC,SAAS,EAAE,iBAAiB,EAAE,UAAU,IAAI,EAAE,CAAC;YAC7E,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACzB,OAAO,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC,MAAW,EAAE,EAAE,CAAC,CAAC;oBACzC,IAAI,EAAE,MAAM,CAAC,IAAI;oBACjB,IAAI,EAAE,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC;oBAChC,UAAU,EAAE,MAAM,CAAC,IAAI;iBACxB,CAAC,CAAC,CAAC;YACN,CAAC;YAED,MAAM,QAAQ,GAAG,UAAU,CAAC,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC;YAClD,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,QAAQ,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC;gBACrD,MAAM,IAAI,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,IAAI,IAAI,EAAE,CAAC;gBACxC,MAAM,MAAM,GAAG,MAAM,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,WAAW,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,WAAW,CAAC,EAAE,YAAY,IAAI,IAAI,CAAC,CAAC,CAAQ,CAAC;gBAEvI,MAAM,WAAW,GAAG,KAAK,KAAK,CAAC,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,IAAI,OAAO,CAAC,KAAK,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,KAAK,MAAM,CAAC,IAAI,CAAC,CAAC;gBACrI,IAAI,CAAC,WAAW,EAAE,CAAC;oBACjB,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;gBACpB,CAAC;YACH,CAAC;YAED,SAAS,GAAG,UAAU,CAAC,SAAS,CAAC;QACnC,CAAC,QAAQ,SAAS,EAAE;QAEpB,OAAO;YACL,OAAO;YACP,IAAI;YACJ,QAAQ,EAAE,IAAI,CAAC,MAAM;YACrB,eAAe,EAAE,WAAW,CAAC,GAAG,EAAE,GAAG,SAAS;SAC/C,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,UAAU;QACd,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;IAC3B,CAAC;IAED,KAAK,CAAC,IAAI;QACR,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;YACrC,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;CACF;AAED,SAAS,aAAa,CAAC,UAAkB;IACvC,MAAM,KAAK,GAAG,UAAU,CAAC,WAAW,EAAE,CAAC;IACvC,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC;QAAE,OAAO,QAAQ,CAAC;IAC9H,IAAI,KAAK,KAAK,MAAM;QAAE,OAAO,MAAM,CAAC;IACpC,IAAI,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC;QAAE,OAAO,UAAU,CAAC;IACnD,IAAI,KAAK,KAAK,SAAS;QAAE,OAAO,SAAS,CAAC;IAC1C,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC;QAAE,OAAO,QAAQ,CAAC;IACrG,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,SAAS,KAAK,CAAC,EAAU;IACvB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;AAC3D,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { DatabaseConnector, ConnectionConfig } from '../connector.js';
|
|
2
|
+
import type { QueryResult } from '../result-types.js';
|
|
3
|
+
export declare class ClickHouseConnector implements DatabaseConnector {
|
|
4
|
+
readonly driverName = "clickhouse";
|
|
5
|
+
private endpoint;
|
|
6
|
+
private headers;
|
|
7
|
+
connect(config: ConnectionConfig): Promise<void>;
|
|
8
|
+
execute(sql: string, params?: unknown[]): Promise<QueryResult>;
|
|
9
|
+
disconnect(): Promise<void>;
|
|
10
|
+
ping(): Promise<boolean>;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=clickhouse.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clickhouse.d.ts","sourceRoot":"","sources":["../../src/drivers/clickhouse.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAC3E,OAAO,KAAK,EAAE,WAAW,EAA+B,MAAM,oBAAoB,CAAC;AAEnF,qBAAa,mBAAoB,YAAW,iBAAiB;IAC3D,QAAQ,CAAC,UAAU,gBAAgB;IACnC,OAAO,CAAC,QAAQ,CAAuB;IACvC,OAAO,CAAC,OAAO,CAA8B;IAEvC,OAAO,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC;IAehD,OAAO,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC;IAoC9D,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAK3B,IAAI,IAAI,OAAO,CAAC,OAAO,CAAC;CAQ/B"}
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
export class ClickHouseConnector {
|
|
2
|
+
driverName = 'clickhouse';
|
|
3
|
+
endpoint = null;
|
|
4
|
+
headers = {};
|
|
5
|
+
async connect(config) {
|
|
6
|
+
const protocol = config.ssl === false ? 'http' : 'https';
|
|
7
|
+
const host = config.host ?? 'localhost';
|
|
8
|
+
const port = config.port ?? (config.ssl === false ? 8123 : 8443);
|
|
9
|
+
this.endpoint = `${protocol}://${host}:${port}`;
|
|
10
|
+
this.headers = {
|
|
11
|
+
'Content-Type': 'text/plain; charset=utf-8',
|
|
12
|
+
};
|
|
13
|
+
if (config.username || config.password) {
|
|
14
|
+
const token = Buffer.from(`${config.username ?? 'default'}:${config.password ?? ''}`).toString('base64');
|
|
15
|
+
this.headers.Authorization = `Basic ${token}`;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
async execute(sql, params) {
|
|
19
|
+
if (!this.endpoint) {
|
|
20
|
+
throw new Error('ClickHouse connector not connected. Call connect() first.');
|
|
21
|
+
}
|
|
22
|
+
if (params && params.length > 0) {
|
|
23
|
+
throw new Error('ClickHouse connector does not yet support positional parameters.');
|
|
24
|
+
}
|
|
25
|
+
const startTime = performance.now();
|
|
26
|
+
const response = await fetch(this.endpoint, {
|
|
27
|
+
method: 'POST',
|
|
28
|
+
headers: this.headers,
|
|
29
|
+
body: `${sql.trim().replace(/;$/, '')} FORMAT JSON`,
|
|
30
|
+
});
|
|
31
|
+
if (!response.ok) {
|
|
32
|
+
throw new Error(`ClickHouse query failed: ${await response.text()}`);
|
|
33
|
+
}
|
|
34
|
+
const payload = await response.json();
|
|
35
|
+
const executionTimeMs = performance.now() - startTime;
|
|
36
|
+
const rows = payload.data ?? [];
|
|
37
|
+
const columns = (payload.meta ?? []).map((column) => ({
|
|
38
|
+
name: column.name,
|
|
39
|
+
type: mapColumnType(column.type),
|
|
40
|
+
driverType: column.type,
|
|
41
|
+
}));
|
|
42
|
+
return {
|
|
43
|
+
columns,
|
|
44
|
+
rows,
|
|
45
|
+
rowCount: payload.rows ?? rows.length,
|
|
46
|
+
executionTimeMs,
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
async disconnect() {
|
|
50
|
+
this.endpoint = null;
|
|
51
|
+
this.headers = {};
|
|
52
|
+
}
|
|
53
|
+
async ping() {
|
|
54
|
+
try {
|
|
55
|
+
await this.execute('SELECT 1 AS ok');
|
|
56
|
+
return true;
|
|
57
|
+
}
|
|
58
|
+
catch {
|
|
59
|
+
return false;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
function mapColumnType(driverType) {
|
|
64
|
+
const lower = driverType.toLowerCase();
|
|
65
|
+
if (lower.includes('int') || lower.includes('float') || lower.includes('decimal'))
|
|
66
|
+
return 'number';
|
|
67
|
+
if (lower.includes('date') && !lower.includes('datetime'))
|
|
68
|
+
return 'date';
|
|
69
|
+
if (lower.includes('datetime') || lower.includes('timestamp'))
|
|
70
|
+
return 'datetime';
|
|
71
|
+
if (lower.includes('bool'))
|
|
72
|
+
return 'boolean';
|
|
73
|
+
if (lower.includes('string') || lower.includes('uuid'))
|
|
74
|
+
return 'string';
|
|
75
|
+
return 'unknown';
|
|
76
|
+
}
|
|
77
|
+
//# sourceMappingURL=clickhouse.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clickhouse.js","sourceRoot":"","sources":["../../src/drivers/clickhouse.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { DatabaseConnector, ConnectionConfig } from '../connector.js';
|
|
2
|
+
import type { QueryResult } from '../result-types.js';
|
|
3
|
+
export declare class DatabricksConnector implements DatabaseConnector {
|
|
4
|
+
readonly driverName = "databricks";
|
|
5
|
+
private baseUrl;
|
|
6
|
+
private token;
|
|
7
|
+
private warehouseId;
|
|
8
|
+
private catalog?;
|
|
9
|
+
private schema?;
|
|
10
|
+
connect(config: ConnectionConfig): Promise<void>;
|
|
11
|
+
execute(sql: string, params?: unknown[]): Promise<QueryResult>;
|
|
12
|
+
disconnect(): Promise<void>;
|
|
13
|
+
ping(): Promise<boolean>;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=databricks.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"databricks.d.ts","sourceRoot":"","sources":["../../src/drivers/databricks.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAC3E,OAAO,KAAK,EAAE,WAAW,EAA+B,MAAM,oBAAoB,CAAC;AASnF,qBAAa,mBAAoB,YAAW,iBAAiB;IAC3D,QAAQ,CAAC,UAAU,gBAAgB;IACnC,OAAO,CAAC,OAAO,CAAuB;IACtC,OAAO,CAAC,KAAK,CAAuB;IACpC,OAAO,CAAC,WAAW,CAAuB;IAC1C,OAAO,CAAC,OAAO,CAAC,CAAS;IACzB,OAAO,CAAC,MAAM,CAAC,CAAS;IAElB,OAAO,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC;IAkBhD,OAAO,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC;IA2D9D,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAM3B,IAAI,IAAI,OAAO,CAAC,OAAO,CAAC;CAQ/B"}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
export class DatabricksConnector {
|
|
2
|
+
driverName = 'databricks';
|
|
3
|
+
baseUrl = null;
|
|
4
|
+
token = null;
|
|
5
|
+
warehouseId = null;
|
|
6
|
+
catalog;
|
|
7
|
+
schema;
|
|
8
|
+
async connect(config) {
|
|
9
|
+
if (!config.host) {
|
|
10
|
+
throw new Error('Databricks connection requires a host.');
|
|
11
|
+
}
|
|
12
|
+
if (!(config.token ?? config.password)) {
|
|
13
|
+
throw new Error('Databricks connection requires a token.');
|
|
14
|
+
}
|
|
15
|
+
if (!(config.warehouse ?? config.httpPath)) {
|
|
16
|
+
throw new Error('Databricks connection requires a warehouse identifier in the warehouse field.');
|
|
17
|
+
}
|
|
18
|
+
this.baseUrl = config.host.startsWith('http') ? config.host : `https://${config.host}`;
|
|
19
|
+
this.token = config.token ?? config.password ?? null;
|
|
20
|
+
this.warehouseId = config.warehouse ?? config.httpPath ?? null;
|
|
21
|
+
this.catalog = config.catalog ?? config.database;
|
|
22
|
+
this.schema = config.schema;
|
|
23
|
+
}
|
|
24
|
+
async execute(sql, params) {
|
|
25
|
+
if (!this.baseUrl || !this.token || !this.warehouseId) {
|
|
26
|
+
throw new Error('Databricks connector not connected. Call connect() first.');
|
|
27
|
+
}
|
|
28
|
+
if (params && params.length > 0) {
|
|
29
|
+
throw new Error('Databricks connector does not yet support positional parameters.');
|
|
30
|
+
}
|
|
31
|
+
const startTime = performance.now();
|
|
32
|
+
const response = await fetch(`${this.baseUrl}/api/2.0/sql/statements`, {
|
|
33
|
+
method: 'POST',
|
|
34
|
+
headers: {
|
|
35
|
+
Authorization: `Bearer ${this.token}`,
|
|
36
|
+
'Content-Type': 'application/json',
|
|
37
|
+
},
|
|
38
|
+
body: JSON.stringify({
|
|
39
|
+
statement: sql,
|
|
40
|
+
warehouse_id: this.warehouseId,
|
|
41
|
+
catalog: this.catalog,
|
|
42
|
+
schema: this.schema,
|
|
43
|
+
disposition: 'INLINE',
|
|
44
|
+
}),
|
|
45
|
+
});
|
|
46
|
+
if (!response.ok) {
|
|
47
|
+
throw new Error(`Databricks query failed: ${await response.text()}`);
|
|
48
|
+
}
|
|
49
|
+
let payload = await response.json();
|
|
50
|
+
while (payload.status?.state === 'PENDING' || payload.status?.state === 'RUNNING') {
|
|
51
|
+
await delay(500);
|
|
52
|
+
const poll = await fetch(`${this.baseUrl}/api/2.0/sql/statements/${payload.statement_id}`, {
|
|
53
|
+
headers: { Authorization: `Bearer ${this.token}` },
|
|
54
|
+
});
|
|
55
|
+
if (!poll.ok) {
|
|
56
|
+
throw new Error(`Databricks polling failed: ${await poll.text()}`);
|
|
57
|
+
}
|
|
58
|
+
payload = await poll.json();
|
|
59
|
+
}
|
|
60
|
+
if (payload.status?.error?.message) {
|
|
61
|
+
throw new Error(`Databricks query failed: ${payload.status.error.message}`);
|
|
62
|
+
}
|
|
63
|
+
const columns = (payload.manifest?.schema?.columns ?? []).map((column) => ({
|
|
64
|
+
name: column.name,
|
|
65
|
+
type: mapWarehouseType(column.type_text),
|
|
66
|
+
driverType: column.type_text,
|
|
67
|
+
}));
|
|
68
|
+
const rows = (payload.result?.data_array ?? []).map((row) => Object.fromEntries(columns.map((column, index) => [column.name, row[index]])));
|
|
69
|
+
return {
|
|
70
|
+
columns,
|
|
71
|
+
rows,
|
|
72
|
+
rowCount: rows.length,
|
|
73
|
+
executionTimeMs: performance.now() - startTime,
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
async disconnect() {
|
|
77
|
+
this.baseUrl = null;
|
|
78
|
+
this.token = null;
|
|
79
|
+
this.warehouseId = null;
|
|
80
|
+
}
|
|
81
|
+
async ping() {
|
|
82
|
+
try {
|
|
83
|
+
await this.execute('SELECT 1 AS ok');
|
|
84
|
+
return true;
|
|
85
|
+
}
|
|
86
|
+
catch {
|
|
87
|
+
return false;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
function mapWarehouseType(driverType) {
|
|
92
|
+
const lower = driverType.toLowerCase();
|
|
93
|
+
if (lower.includes('int') || lower.includes('decimal') || lower.includes('double') || lower.includes('float'))
|
|
94
|
+
return 'number';
|
|
95
|
+
if (lower === 'date')
|
|
96
|
+
return 'date';
|
|
97
|
+
if (lower.includes('timestamp'))
|
|
98
|
+
return 'datetime';
|
|
99
|
+
if (lower === 'boolean')
|
|
100
|
+
return 'boolean';
|
|
101
|
+
if (lower.includes('string') || lower.includes('char'))
|
|
102
|
+
return 'string';
|
|
103
|
+
return 'unknown';
|
|
104
|
+
}
|
|
105
|
+
function delay(ms) {
|
|
106
|
+
return new Promise((resolve) => setTimeout(resolve, ms));
|
|
107
|
+
}
|
|
108
|
+
//# sourceMappingURL=databricks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"databricks.js","sourceRoot":"","sources":["../../src/drivers/databricks.ts"],"names":[],"mappings":"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"}
|
package/dist/drivers/duckdb.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { DatabaseConnector, ConnectionConfig } from '../connector.js';
|
|
2
|
-
import type { QueryResult } from '../result-types.js';
|
|
2
|
+
import type { QueryResult, Row } from '../result-types.js';
|
|
3
3
|
export declare class DuckDBConnector implements DatabaseConnector {
|
|
4
4
|
readonly driverName = "duckdb";
|
|
5
5
|
private db;
|
|
@@ -9,4 +9,9 @@ export declare class DuckDBConnector implements DatabaseConnector {
|
|
|
9
9
|
disconnect(): Promise<void>;
|
|
10
10
|
ping(): Promise<boolean>;
|
|
11
11
|
}
|
|
12
|
+
export declare function resolveDuckDBModule(module: unknown): {
|
|
13
|
+
Database: new (path: string, callback: (err: Error | null) => void) => any;
|
|
14
|
+
};
|
|
15
|
+
export declare function normalizeDuckDBRow(row: Row): Row;
|
|
16
|
+
export declare function normalizeDuckDBValue(value: unknown): unknown;
|
|
12
17
|
//# sourceMappingURL=duckdb.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"duckdb.d.ts","sourceRoot":"","sources":["../../src/drivers/duckdb.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAC3E,OAAO,KAAK,EAAE,WAAW,
|
|
1
|
+
{"version":3,"file":"duckdb.d.ts","sourceRoot":"","sources":["../../src/drivers/duckdb.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAC3E,OAAO,KAAK,EAAE,WAAW,EAA0B,GAAG,EAAE,MAAM,oBAAoB,CAAC;AAEnF,qBAAa,eAAgB,YAAW,iBAAiB;IACvD,QAAQ,CAAC,UAAU,YAAY;IAC/B,OAAO,CAAC,EAAE,CAAa;IACvB,OAAO,CAAC,UAAU,CAAa;IAEzB,OAAO,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC;IAmBhD,OAAO,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC;IAmD9D,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAe3B,IAAI,IAAI,OAAO,CAAC,OAAO,CAAC;CAS/B;AAED,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,OAAO,GAAG;IAAE,QAAQ,EAAE,KAAK,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,GAAG,EAAE,KAAK,GAAG,IAAI,KAAK,IAAI,KAAK,GAAG,CAAA;CAAE,CAuBnI;AAED,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,GAAG,GAAG,GAAG,CAIhD;AAED,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,OAAO,GAAG,OAAO,CAc5D"}
|
package/dist/drivers/duckdb.js
CHANGED
|
@@ -4,7 +4,8 @@ export class DuckDBConnector {
|
|
|
4
4
|
connection = null;
|
|
5
5
|
async connect(config) {
|
|
6
6
|
// Dynamic import to avoid requiring duckdb when not used
|
|
7
|
-
const
|
|
7
|
+
const duckdbModule = await import('duckdb');
|
|
8
|
+
const duckdb = resolveDuckDBModule(duckdbModule);
|
|
8
9
|
const dbPath = config.filepath ?? ':memory:';
|
|
9
10
|
return new Promise((resolve, reject) => {
|
|
10
11
|
this.db = new duckdb.Database(dbPath, (err) => {
|
|
@@ -38,16 +39,17 @@ export class DuckDBConnector {
|
|
|
38
39
|
});
|
|
39
40
|
return;
|
|
40
41
|
}
|
|
41
|
-
|
|
42
|
-
|
|
42
|
+
const normalizedRows = result.map((row) => normalizeDuckDBRow(row));
|
|
43
|
+
// Infer columns from first normalized row so JSON-facing types match runtime values.
|
|
44
|
+
const columns = Object.keys(normalizedRows[0]).map((name) => ({
|
|
43
45
|
name,
|
|
44
|
-
type: inferDuckDBType(
|
|
46
|
+
type: inferDuckDBType(normalizedRows[0][name]),
|
|
45
47
|
driverType: 'duckdb',
|
|
46
48
|
}));
|
|
47
49
|
resolve({
|
|
48
50
|
columns,
|
|
49
|
-
rows:
|
|
50
|
-
rowCount:
|
|
51
|
+
rows: normalizedRows,
|
|
52
|
+
rowCount: normalizedRows.length,
|
|
51
53
|
executionTimeMs,
|
|
52
54
|
});
|
|
53
55
|
};
|
|
@@ -85,6 +87,40 @@ export class DuckDBConnector {
|
|
|
85
87
|
}
|
|
86
88
|
}
|
|
87
89
|
}
|
|
90
|
+
export function resolveDuckDBModule(module) {
|
|
91
|
+
const candidate = (module &&
|
|
92
|
+
typeof module === 'object' &&
|
|
93
|
+
'Database' in module &&
|
|
94
|
+
typeof module.Database === 'function')
|
|
95
|
+
? module
|
|
96
|
+
: (module &&
|
|
97
|
+
typeof module === 'object' &&
|
|
98
|
+
'default' in module &&
|
|
99
|
+
module.default &&
|
|
100
|
+
typeof module.default.Database === 'function')
|
|
101
|
+
? module.default
|
|
102
|
+
: null;
|
|
103
|
+
if (!candidate) {
|
|
104
|
+
throw new Error('DuckDB module did not expose a Database constructor.');
|
|
105
|
+
}
|
|
106
|
+
return candidate;
|
|
107
|
+
}
|
|
108
|
+
export function normalizeDuckDBRow(row) {
|
|
109
|
+
return Object.fromEntries(Object.entries(row).map(([key, value]) => [key, normalizeDuckDBValue(value)]));
|
|
110
|
+
}
|
|
111
|
+
export function normalizeDuckDBValue(value) {
|
|
112
|
+
if (typeof value === 'bigint') {
|
|
113
|
+
const asNumber = Number(value);
|
|
114
|
+
return Number.isSafeInteger(asNumber) ? asNumber : value.toString();
|
|
115
|
+
}
|
|
116
|
+
if (Array.isArray(value)) {
|
|
117
|
+
return value.map((item) => normalizeDuckDBValue(item));
|
|
118
|
+
}
|
|
119
|
+
if (value && typeof value === 'object' && !(value instanceof Date)) {
|
|
120
|
+
return Object.fromEntries(Object.entries(value).map(([key, nested]) => [key, normalizeDuckDBValue(nested)]));
|
|
121
|
+
}
|
|
122
|
+
return value;
|
|
123
|
+
}
|
|
88
124
|
function inferDuckDBType(value) {
|
|
89
125
|
if (value === null || value === undefined)
|
|
90
126
|
return 'null';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"duckdb.js","sourceRoot":"","sources":["../../src/drivers/duckdb.ts"],"names":[],"mappings":"AAGA,MAAM,OAAO,eAAe;IACjB,UAAU,GAAG,QAAQ,CAAC;IACvB,EAAE,GAAQ,IAAI,CAAC;IACf,UAAU,GAAQ,IAAI,CAAC;IAE/B,KAAK,CAAC,OAAO,CAAC,MAAwB;QACpC,yDAAyD;QACzD,MAAM,
|
|
1
|
+
{"version":3,"file":"duckdb.js","sourceRoot":"","sources":["../../src/drivers/duckdb.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { MSSQLConnector } from './mssql.js';
|
|
2
|
+
import type { ConnectionConfig } from '../connector.js';
|
|
3
|
+
export declare class FabricConnector extends MSSQLConnector {
|
|
4
|
+
readonly driverName = "fabric";
|
|
5
|
+
connect(config: ConnectionConfig): Promise<void>;
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=fabric.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fabric.d.ts","sourceRoot":"","sources":["../../src/drivers/fabric.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAC5C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAExD,qBAAa,eAAgB,SAAQ,cAAc;IACjD,QAAQ,CAAC,UAAU,YAAY;IAEzB,OAAO,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC;CAOvD"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { MSSQLConnector } from './mssql.js';
|
|
2
|
+
export class FabricConnector extends MSSQLConnector {
|
|
3
|
+
driverName = 'fabric';
|
|
4
|
+
async connect(config) {
|
|
5
|
+
await super.connect({
|
|
6
|
+
...config,
|
|
7
|
+
driver: 'fabric',
|
|
8
|
+
port: config.port ?? 1433,
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=fabric.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fabric.js","sourceRoot":"","sources":["../../src/drivers/fabric.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAG5C,MAAM,OAAO,eAAgB,SAAQ,cAAc;IACxC,UAAU,GAAG,QAAQ,CAAC;IAE/B,KAAK,CAAC,OAAO,CAAC,MAAwB;QACpC,MAAM,KAAK,CAAC,OAAO,CAAC;YAClB,GAAG,MAAM;YACT,MAAM,EAAE,QAAQ;YAChB,IAAI,EAAE,MAAM,CAAC,IAAI,IAAI,IAAI;SAC1B,CAAC,CAAC;IACL,CAAC;CACF"}
|
package/dist/drivers/mssql.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import type { DatabaseConnector, ConnectionConfig } from '../connector.js';
|
|
1
|
+
import type { DatabaseConnector, ConnectionConfig, DriverName } from '../connector.js';
|
|
2
2
|
import type { QueryResult } from '../result-types.js';
|
|
3
3
|
export declare class MSSQLConnector implements DatabaseConnector {
|
|
4
|
-
readonly driverName
|
|
4
|
+
readonly driverName: DriverName;
|
|
5
5
|
private pool;
|
|
6
6
|
private sql;
|
|
7
7
|
connect(config: ConnectionConfig): Promise<void>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mssql.d.ts","sourceRoot":"","sources":["../../src/drivers/mssql.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"mssql.d.ts","sourceRoot":"","sources":["../../src/drivers/mssql.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AACvF,OAAO,KAAK,EAAE,WAAW,EAA+B,MAAM,oBAAoB,CAAC;AAEnF,qBAAa,cAAe,YAAW,iBAAiB;IACtD,QAAQ,CAAC,UAAU,EAAE,UAAU,CAAW;IAC1C,OAAO,CAAC,IAAI,CAAa;IACzB,OAAO,CAAC,GAAG,CAAa;IAElB,OAAO,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC;IA4BhD,OAAO,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC;IA2D9D,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAO3B,IAAI,IAAI,OAAO,CAAC,OAAO,CAAC;CAS/B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mssql.js","sourceRoot":"","sources":["../../src/drivers/mssql.ts"],"names":[],"mappings":"AAGA,MAAM,OAAO,cAAc;IAChB,UAAU,
|
|
1
|
+
{"version":3,"file":"mssql.js","sourceRoot":"","sources":["../../src/drivers/mssql.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import type { DatabaseConnector, ConnectionConfig } from '../connector.js';
|
|
1
|
+
import type { DatabaseConnector, ConnectionConfig, DriverName } from '../connector.js';
|
|
2
2
|
import type { QueryResult } from '../result-types.js';
|
|
3
3
|
export declare class PostgreSQLConnector implements DatabaseConnector {
|
|
4
|
-
readonly driverName
|
|
4
|
+
readonly driverName: DriverName;
|
|
5
5
|
private pool;
|
|
6
6
|
connect(config: ConnectionConfig): Promise<void>;
|
|
7
7
|
execute(sql: string, params?: unknown[]): Promise<QueryResult>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"postgresql.d.ts","sourceRoot":"","sources":["../../src/drivers/postgresql.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"postgresql.d.ts","sourceRoot":"","sources":["../../src/drivers/postgresql.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AACvF,OAAO,KAAK,EAAE,WAAW,EAA+B,MAAM,oBAAoB,CAAC;AAEnF,qBAAa,mBAAoB,YAAW,iBAAiB;IAC3D,QAAQ,CAAC,UAAU,EAAE,UAAU,CAAgB;IAC/C,OAAO,CAAC,IAAI,CAAwB;IAE9B,OAAO,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC;IAkBhD,OAAO,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC;IAyB9D,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAO3B,IAAI,IAAI,OAAO,CAAC,OAAO,CAAC;CAS/B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"postgresql.js","sourceRoot":"","sources":["../../src/drivers/postgresql.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,IAAI,CAAC;AAIpB,MAAM,OAAO,mBAAmB;IACrB,UAAU,
|
|
1
|
+
{"version":3,"file":"postgresql.js","sourceRoot":"","sources":["../../src/drivers/postgresql.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { PostgreSQLConnector } from './postgresql.js';
|
|
2
|
+
import type { ConnectionConfig } from '../connector.js';
|
|
3
|
+
export declare class RedshiftConnector extends PostgreSQLConnector {
|
|
4
|
+
readonly driverName = "redshift";
|
|
5
|
+
connect(config: ConnectionConfig): Promise<void>;
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=redshift.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redshift.d.ts","sourceRoot":"","sources":["../../src/drivers/redshift.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AACtD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAExD,qBAAa,iBAAkB,SAAQ,mBAAmB;IACxD,QAAQ,CAAC,UAAU,cAAc;IAE3B,OAAO,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC;CAOvD"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { PostgreSQLConnector } from './postgresql.js';
|
|
2
|
+
export class RedshiftConnector extends PostgreSQLConnector {
|
|
3
|
+
driverName = 'redshift';
|
|
4
|
+
async connect(config) {
|
|
5
|
+
await super.connect({
|
|
6
|
+
...config,
|
|
7
|
+
driver: 'redshift',
|
|
8
|
+
port: config.port ?? 5439,
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=redshift.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redshift.js","sourceRoot":"","sources":["../../src/drivers/redshift.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AAGtD,MAAM,OAAO,iBAAkB,SAAQ,mBAAmB;IAC/C,UAAU,GAAG,UAAU,CAAC;IAEjC,KAAK,CAAC,OAAO,CAAC,MAAwB;QACpC,MAAM,KAAK,CAAC,OAAO,CAAC;YAClB,GAAG,MAAM;YACT,MAAM,EAAE,UAAU;YAClB,IAAI,EAAE,MAAM,CAAC,IAAI,IAAI,IAAI;SAC1B,CAAC,CAAC;IACL,CAAC;CACF"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { DatabaseConnector, ConnectionConfig } from '../connector.js';
|
|
2
|
+
import type { QueryResult } from '../result-types.js';
|
|
3
|
+
export declare class TrinoConnector implements DatabaseConnector {
|
|
4
|
+
readonly driverName = "trino";
|
|
5
|
+
private endpoint;
|
|
6
|
+
private headers;
|
|
7
|
+
connect(config: ConnectionConfig): Promise<void>;
|
|
8
|
+
execute(sql: string, params?: unknown[]): Promise<QueryResult>;
|
|
9
|
+
disconnect(): Promise<void>;
|
|
10
|
+
ping(): Promise<boolean>;
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=trino.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"trino.d.ts","sourceRoot":"","sources":["../../src/drivers/trino.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAC3E,OAAO,KAAK,EAAE,WAAW,EAA+B,MAAM,oBAAoB,CAAC;AASnF,qBAAa,cAAe,YAAW,iBAAiB;IACtD,QAAQ,CAAC,UAAU,WAAW;IAC9B,OAAO,CAAC,QAAQ,CAAuB;IACvC,OAAO,CAAC,OAAO,CAA8B;IAEvC,OAAO,CAAC,MAAM,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC;IAkBhD,OAAO,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC;IA6D9D,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAK3B,IAAI,IAAI,OAAO,CAAC,OAAO,CAAC;CAQ/B"}
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
export class TrinoConnector {
|
|
2
|
+
driverName = 'trino';
|
|
3
|
+
endpoint = null;
|
|
4
|
+
headers = {};
|
|
5
|
+
async connect(config) {
|
|
6
|
+
const protocol = config.ssl === false ? 'http' : 'https';
|
|
7
|
+
const host = config.host ?? 'localhost';
|
|
8
|
+
const port = config.port ?? 8080;
|
|
9
|
+
this.endpoint = `${protocol}://${host}:${port}`;
|
|
10
|
+
this.headers = {
|
|
11
|
+
'X-Trino-User': config.username ?? 'dql',
|
|
12
|
+
'X-Trino-Catalog': config.catalog ?? config.database ?? 'system',
|
|
13
|
+
'X-Trino-Schema': config.schema ?? 'default',
|
|
14
|
+
'Content-Type': 'text/plain; charset=utf-8',
|
|
15
|
+
};
|
|
16
|
+
if (config.username && config.password) {
|
|
17
|
+
const token = Buffer.from(`${config.username}:${config.password}`).toString('base64');
|
|
18
|
+
this.headers.Authorization = `Basic ${token}`;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
async execute(sql, params) {
|
|
22
|
+
if (!this.endpoint) {
|
|
23
|
+
throw new Error('Trino connector not connected. Call connect() first.');
|
|
24
|
+
}
|
|
25
|
+
if (params && params.length > 0) {
|
|
26
|
+
throw new Error('Trino connector does not yet support positional parameters.');
|
|
27
|
+
}
|
|
28
|
+
const startTime = performance.now();
|
|
29
|
+
const initialResponse = await fetch(`${this.endpoint}/v1/statement`, {
|
|
30
|
+
method: 'POST',
|
|
31
|
+
headers: this.headers,
|
|
32
|
+
body: sql,
|
|
33
|
+
});
|
|
34
|
+
if (!initialResponse.ok) {
|
|
35
|
+
throw new Error(`Trino query failed: ${await initialResponse.text()}`);
|
|
36
|
+
}
|
|
37
|
+
const rows = [];
|
|
38
|
+
let columns = [];
|
|
39
|
+
let payload = await initialResponse.json();
|
|
40
|
+
while (true) {
|
|
41
|
+
if (payload.error?.message) {
|
|
42
|
+
throw new Error(`Trino query failed: ${payload.error.message}`);
|
|
43
|
+
}
|
|
44
|
+
if (payload.columns && columns.length === 0) {
|
|
45
|
+
columns = payload.columns.map((column) => ({
|
|
46
|
+
name: column.name,
|
|
47
|
+
type: mapTrinoType(column.type),
|
|
48
|
+
driverType: column.type,
|
|
49
|
+
}));
|
|
50
|
+
}
|
|
51
|
+
if (payload.data && columns.length > 0) {
|
|
52
|
+
for (const row of payload.data) {
|
|
53
|
+
rows.push(Object.fromEntries(columns.map((column, index) => [column.name, row[index]])));
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
if (!payload.nextUri) {
|
|
57
|
+
break;
|
|
58
|
+
}
|
|
59
|
+
const nextResponse = await fetch(payload.nextUri, { headers: this.headers });
|
|
60
|
+
if (!nextResponse.ok) {
|
|
61
|
+
throw new Error(`Trino pagination failed: ${await nextResponse.text()}`);
|
|
62
|
+
}
|
|
63
|
+
payload = await nextResponse.json();
|
|
64
|
+
}
|
|
65
|
+
return {
|
|
66
|
+
columns,
|
|
67
|
+
rows,
|
|
68
|
+
rowCount: rows.length,
|
|
69
|
+
executionTimeMs: performance.now() - startTime,
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
async disconnect() {
|
|
73
|
+
this.endpoint = null;
|
|
74
|
+
this.headers = {};
|
|
75
|
+
}
|
|
76
|
+
async ping() {
|
|
77
|
+
try {
|
|
78
|
+
await this.execute('SELECT 1 AS ok');
|
|
79
|
+
return true;
|
|
80
|
+
}
|
|
81
|
+
catch {
|
|
82
|
+
return false;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
function mapTrinoType(driverType) {
|
|
87
|
+
const lower = driverType.toLowerCase();
|
|
88
|
+
if (lower.includes('int') || lower.includes('double') || lower.includes('real') || lower.includes('decimal'))
|
|
89
|
+
return 'number';
|
|
90
|
+
if (lower === 'date')
|
|
91
|
+
return 'date';
|
|
92
|
+
if (lower.includes('timestamp'))
|
|
93
|
+
return 'datetime';
|
|
94
|
+
if (lower === 'boolean')
|
|
95
|
+
return 'boolean';
|
|
96
|
+
if (lower.includes('char') || lower.includes('varchar'))
|
|
97
|
+
return 'string';
|
|
98
|
+
return 'unknown';
|
|
99
|
+
}
|
|
100
|
+
//# sourceMappingURL=trino.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"trino.js","sourceRoot":"","sources":["../../src/drivers/trino.ts"],"names":[],"mappings":"AAUA,MAAM,OAAO,cAAc;IAChB,UAAU,GAAG,OAAO,CAAC;IACtB,QAAQ,GAAkB,IAAI,CAAC;IAC/B,OAAO,GAA2B,EAAE,CAAC;IAE7C,KAAK,CAAC,OAAO,CAAC,MAAwB;QACpC,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,KAAK,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC;QACzD,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,IAAI,WAAW,CAAC;QACxC,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC;QACjC,IAAI,CAAC,QAAQ,GAAG,GAAG,QAAQ,MAAM,IAAI,IAAI,IAAI,EAAE,CAAC;QAChD,IAAI,CAAC,OAAO,GAAG;YACb,cAAc,EAAE,MAAM,CAAC,QAAQ,IAAI,KAAK;YACxC,iBAAiB,EAAE,MAAM,CAAC,OAAO,IAAI,MAAM,CAAC,QAAQ,IAAI,QAAQ;YAChE,gBAAgB,EAAE,MAAM,CAAC,MAAM,IAAI,SAAS;YAC5C,cAAc,EAAE,2BAA2B;SAC5C,CAAC;QAEF,IAAI,MAAM,CAAC,QAAQ,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;YACvC,MAAM,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,QAAQ,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;YACtF,IAAI,CAAC,OAAO,CAAC,aAAa,GAAG,SAAS,KAAK,EAAE,CAAC;QAChD,CAAC;IACH,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,GAAW,EAAE,MAAkB;QAC3C,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,MAAM,IAAI,KAAK,CAAC,sDAAsD,CAAC,CAAC;QAC1E,CAAC;QACD,IAAI,MAAM,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAChC,MAAM,IAAI,KAAK,CAAC,6DAA6D,CAAC,CAAC;QACjF,CAAC;QAED,MAAM,SAAS,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC;QACpC,MAAM,eAAe,GAAG,MAAM,KAAK,CAAC,GAAG,IAAI,CAAC,QAAQ,eAAe,EAAE;YACnE,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,IAAI,EAAE,GAAG;SACV,CAAC,CAAC;QAEH,IAAI,CAAC,eAAe,CAAC,EAAE,EAAE,CAAC;YACxB,MAAM,IAAI,KAAK,CAAC,uBAAuB,MAAM,eAAe,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QACzE,CAAC;QAED,MAAM,IAAI,GAAU,EAAE,CAAC;QACvB,IAAI,OAAO,GAAiB,EAAE,CAAC;QAC/B,IAAI,OAAO,GAAG,MAAM,eAAe,CAAC,IAAI,EAAkB,CAAC;QAE3D,OAAO,IAAI,EAAE,CAAC;YACZ,IAAI,OAAO,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC;gBAC3B,MAAM,IAAI,KAAK,CAAC,uBAAuB,OAAO,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;YAClE,CAAC;YAED,IAAI,OAAO,CAAC,OAAO,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC5C,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;oBACzC,IAAI,EAAE,MAAM,CAAC,IAAI;oBACjB,IAAI,EAAE,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC;oBAC/B,UAAU,EAAE,MAAM,CAAC,IAAI;iBACxB,CAAC,CAAC,CAAC;YACN,CAAC;YAED,IAAI,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACvC,KAAK,MAAM,GAAG,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;oBAC/B,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAQ,CAAC,CAAC;gBAClG,CAAC;YACH,CAAC;YAED,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;gBACrB,MAAM;YACR,CAAC;YAED,MAAM,YAAY,GAAG,MAAM,KAAK,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;YAC7E,IAAI,CAAC,YAAY,CAAC,EAAE,EAAE,CAAC;gBACrB,MAAM,IAAI,KAAK,CAAC,4BAA4B,MAAM,YAAY,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;YAC3E,CAAC;YACD,OAAO,GAAG,MAAM,YAAY,CAAC,IAAI,EAAkB,CAAC;QACtD,CAAC;QAED,OAAO;YACL,OAAO;YACP,IAAI;YACJ,QAAQ,EAAE,IAAI,CAAC,MAAM;YACrB,eAAe,EAAE,WAAW,CAAC,GAAG,EAAE,GAAG,SAAS;SAC/C,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,UAAU;QACd,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;IACpB,CAAC;IAED,KAAK,CAAC,IAAI;QACR,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;YACrC,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;CACF;AAED,SAAS,YAAY,CAAC,UAAkB;IACtC,MAAM,KAAK,GAAG,UAAU,CAAC,WAAW,EAAE,CAAC;IACvC,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC;QAAE,OAAO,QAAQ,CAAC;IAC9H,IAAI,KAAK,KAAK,MAAM;QAAE,OAAO,MAAM,CAAC;IACpC,IAAI,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC;QAAE,OAAO,UAAU,CAAC;IACnD,IAAI,KAAK,KAAK,SAAS;QAAE,OAAO,SAAS,CAAC;IAC1C,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC;QAAE,OAAO,QAAQ,CAAC;IACzE,OAAO,SAAS,CAAC;AACnB,CAAC"}
|
package/dist/index.d.ts
CHANGED
|
@@ -4,4 +4,18 @@ export { ConnectionPoolManager } from './connection-pool.js';
|
|
|
4
4
|
export { QueryExecutor } from './query-executor.js';
|
|
5
5
|
export type { SQLParamSpec } from './sql-params.js';
|
|
6
6
|
export { buildParamValues, normalizeSQLPlaceholders } from './sql-params.js';
|
|
7
|
+
export { PostgreSQLConnector } from './drivers/postgresql.js';
|
|
8
|
+
export { MySQLConnector } from './drivers/mysql.js';
|
|
9
|
+
export { SQLiteConnector } from './drivers/sqlite.js';
|
|
10
|
+
export { BigQueryConnector } from './drivers/bigquery.js';
|
|
11
|
+
export { SnowflakeConnector } from './drivers/snowflake.js';
|
|
12
|
+
export { DuckDBConnector } from './drivers/duckdb.js';
|
|
13
|
+
export { MSSQLConnector } from './drivers/mssql.js';
|
|
14
|
+
export { FileConnector } from './drivers/file.js';
|
|
15
|
+
export { RedshiftConnector } from './drivers/redshift.js';
|
|
16
|
+
export { FabricConnector } from './drivers/fabric.js';
|
|
17
|
+
export { ClickHouseConnector } from './drivers/clickhouse.js';
|
|
18
|
+
export { DatabricksConnector } from './drivers/databricks.js';
|
|
19
|
+
export { AthenaConnector } from './drivers/athena.js';
|
|
20
|
+
export { TrinoConnector } from './drivers/trino.js';
|
|
7
21
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAEA,YAAY,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAC1E,YAAY,EAAE,WAAW,EAAE,UAAU,EAAE,UAAU,EAAE,GAAG,EAAE,MAAM,mBAAmB,CAAC;AAClF,OAAO,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,YAAY,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AACpD,OAAO,EAAE,gBAAgB,EAAE,wBAAwB,EAAE,MAAM,iBAAiB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAEA,YAAY,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAC1E,YAAY,EAAE,WAAW,EAAE,UAAU,EAAE,UAAU,EAAE,GAAG,EAAE,MAAM,mBAAmB,CAAC;AAClF,OAAO,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,YAAY,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AACpD,OAAO,EAAE,gBAAgB,EAAE,wBAAwB,EAAE,MAAM,iBAAiB,CAAC;AAC7E,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAC9D,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAC1D,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAC9D,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAC9D,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -2,4 +2,18 @@
|
|
|
2
2
|
export { ConnectionPoolManager } from './connection-pool.js';
|
|
3
3
|
export { QueryExecutor } from './query-executor.js';
|
|
4
4
|
export { buildParamValues, normalizeSQLPlaceholders } from './sql-params.js';
|
|
5
|
+
export { PostgreSQLConnector } from './drivers/postgresql.js';
|
|
6
|
+
export { MySQLConnector } from './drivers/mysql.js';
|
|
7
|
+
export { SQLiteConnector } from './drivers/sqlite.js';
|
|
8
|
+
export { BigQueryConnector } from './drivers/bigquery.js';
|
|
9
|
+
export { SnowflakeConnector } from './drivers/snowflake.js';
|
|
10
|
+
export { DuckDBConnector } from './drivers/duckdb.js';
|
|
11
|
+
export { MSSQLConnector } from './drivers/mssql.js';
|
|
12
|
+
export { FileConnector } from './drivers/file.js';
|
|
13
|
+
export { RedshiftConnector } from './drivers/redshift.js';
|
|
14
|
+
export { FabricConnector } from './drivers/fabric.js';
|
|
15
|
+
export { ClickHouseConnector } from './drivers/clickhouse.js';
|
|
16
|
+
export { DatabricksConnector } from './drivers/databricks.js';
|
|
17
|
+
export { AthenaConnector } from './drivers/athena.js';
|
|
18
|
+
export { TrinoConnector } from './drivers/trino.js';
|
|
5
19
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,4CAA4C;AAI5C,OAAO,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEpD,OAAO,EAAE,gBAAgB,EAAE,wBAAwB,EAAE,MAAM,iBAAiB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,4CAA4C;AAI5C,OAAO,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEpD,OAAO,EAAE,gBAAgB,EAAE,wBAAwB,EAAE,MAAM,iBAAiB,CAAC;AAC7E,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAC9D,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAC1D,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAC1D,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAC9D,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAC9D,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC"}
|
package/dist/sql-params.js
CHANGED
|
@@ -24,7 +24,7 @@ export function buildParamValues(params, variables) {
|
|
|
24
24
|
export function normalizeSQLPlaceholders(sql, driver) {
|
|
25
25
|
if (!sql)
|
|
26
26
|
return sql;
|
|
27
|
-
if (driver === 'postgresql' || driver === 'mssql')
|
|
27
|
+
if (driver === 'postgresql' || driver === 'mssql' || driver === 'redshift' || driver === 'fabric')
|
|
28
28
|
return sql;
|
|
29
29
|
// Replace $N -> ? outside quoted regions.
|
|
30
30
|
let out = '';
|
package/dist/sql-params.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sql-params.js","sourceRoot":"","sources":["../src/sql-params.ts"],"names":[],"mappings":"AAIA,MAAM,UAAU,gBAAgB,CAC9B,MAAsB,EACtB,SAAkC;IAElC,IAAI,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,EAAE,CAAC;IAC9C,OAAO,CAAC,GAAG,MAAM,CAAC;SACf,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,QAAQ,CAAC;SACvC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;QACT,IAAI,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;YAC5D,OAAO,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QAC3B,CAAC;QACD,IAAI,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,EAAE,cAAc,CAAC,EAAE,CAAC;YAC5D,OAAO,CAAC,CAAC,YAAY,CAAC;QACxB,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC,CAAC,CAAC;AACP,CAAC;AAED;;;;;;;GAOG;AACH,MAAM,UAAU,wBAAwB,CACtC,GAAW,EACX,MAAkC;IAElC,IAAI,CAAC,GAAG;QAAE,OAAO,GAAG,CAAC;IACrB,IAAI,MAAM,KAAK,YAAY,IAAI,MAAM,KAAK,OAAO;QAAE,OAAO,GAAG,CAAC;
|
|
1
|
+
{"version":3,"file":"sql-params.js","sourceRoot":"","sources":["../src/sql-params.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@duckcodeailabs/dql-connectors",
|
|
3
|
-
"version": "0.1.
|
|
4
|
-
"description": "DQL database connectors
|
|
3
|
+
"version": "0.1.2",
|
|
4
|
+
"description": "DQL database connectors for local files, SQL warehouses, and lakehouse engines",
|
|
5
5
|
"license": "Apache-2.0",
|
|
6
6
|
"type": "module",
|
|
7
7
|
"main": "./dist/index.js",
|
|
@@ -24,6 +24,7 @@
|
|
|
24
24
|
"access": "public"
|
|
25
25
|
},
|
|
26
26
|
"dependencies": {
|
|
27
|
+
"@aws-sdk/client-athena": "^3.882.0",
|
|
27
28
|
"@google-cloud/bigquery": "^7.5.0",
|
|
28
29
|
"better-sqlite3": "^11.7.0",
|
|
29
30
|
"duckdb": "^1.1.0",
|