drizzle-orm 0.33.0-ab3b46d → 0.33.0-ad58316
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/better-sqlite3/driver.cjs +7 -1
- package/better-sqlite3/driver.cjs.map +1 -1
- package/better-sqlite3/driver.d.cts +4 -1
- package/better-sqlite3/driver.d.ts +4 -1
- package/better-sqlite3/driver.js +6 -1
- package/better-sqlite3/driver.js.map +1 -1
- package/bun-sqlite/driver.cjs +7 -1
- package/bun-sqlite/driver.cjs.map +1 -1
- package/bun-sqlite/driver.d.cts +4 -1
- package/bun-sqlite/driver.d.ts +4 -1
- package/bun-sqlite/driver.js +6 -1
- package/bun-sqlite/driver.js.map +1 -1
- package/expo-sqlite/driver.cjs +7 -1
- package/expo-sqlite/driver.cjs.map +1 -1
- package/expo-sqlite/driver.d.cts +4 -1
- package/expo-sqlite/driver.d.ts +4 -1
- package/expo-sqlite/driver.js +6 -1
- package/expo-sqlite/driver.js.map +1 -1
- package/libsql/migrator.cjs +1 -1
- package/libsql/migrator.cjs.map +1 -1
- package/libsql/migrator.d.cts +1 -1
- package/libsql/migrator.d.ts +1 -1
- package/libsql/migrator.js +1 -1
- package/libsql/migrator.js.map +1 -1
- package/libsql/session.cjs +12 -0
- package/libsql/session.cjs.map +1 -1
- package/libsql/session.d.cts +1 -0
- package/libsql/session.d.ts +1 -0
- package/libsql/session.js +12 -0
- package/libsql/session.js.map +1 -1
- package/monodriver.cjs +54 -20
- package/monodriver.cjs.map +1 -1
- package/monodriver.d.cts +79 -58
- package/monodriver.d.ts +79 -58
- package/monodriver.js +54 -20
- package/monodriver.js.map +1 -1
- package/monomigrator.cjs +29 -57
- package/monomigrator.cjs.map +1 -1
- package/monomigrator.d.cts +3 -53
- package/monomigrator.d.ts +3 -53
- package/monomigrator.js +29 -57
- package/monomigrator.js.map +1 -1
- package/mysql-proxy/driver.cjs +7 -1
- package/mysql-proxy/driver.cjs.map +1 -1
- package/mysql-proxy/driver.d.cts +4 -1
- package/mysql-proxy/driver.d.ts +4 -1
- package/mysql-proxy/driver.js +6 -1
- package/mysql-proxy/driver.js.map +1 -1
- package/mysql2/driver.cjs +6 -1
- package/mysql2/driver.cjs.map +1 -1
- package/mysql2/driver.d.cts +3 -1
- package/mysql2/driver.d.ts +3 -1
- package/mysql2/driver.js +5 -1
- package/mysql2/driver.js.map +1 -1
- package/mysql2/migrator.cjs +4 -1
- package/mysql2/migrator.cjs.map +1 -1
- package/mysql2/migrator.d.cts +1 -1
- package/mysql2/migrator.d.ts +1 -1
- package/mysql2/migrator.js +4 -1
- package/mysql2/migrator.js.map +1 -1
- package/neon-serverless/driver.cjs +6 -1
- package/neon-serverless/driver.cjs.map +1 -1
- package/neon-serverless/driver.d.cts +3 -1
- package/neon-serverless/driver.d.ts +3 -1
- package/neon-serverless/driver.js +5 -1
- package/neon-serverless/driver.js.map +1 -1
- package/node-postgres/driver.cjs +6 -1
- package/node-postgres/driver.cjs.map +1 -1
- package/node-postgres/driver.d.cts +3 -1
- package/node-postgres/driver.d.ts +3 -1
- package/node-postgres/driver.js +5 -1
- package/node-postgres/driver.js.map +1 -1
- package/op-sqlite/driver.cjs +7 -1
- package/op-sqlite/driver.cjs.map +1 -1
- package/op-sqlite/driver.d.cts +4 -1
- package/op-sqlite/driver.d.ts +4 -1
- package/op-sqlite/driver.js +6 -1
- package/op-sqlite/driver.js.map +1 -1
- package/package.json +51 -51
- package/pg-core/db.cjs.map +1 -1
- package/pg-core/db.d.cts +1 -1
- package/pg-core/db.d.ts +1 -1
- package/pg-core/db.js.map +1 -1
- package/pg-proxy/driver.cjs +7 -1
- package/pg-proxy/driver.cjs.map +1 -1
- package/pg-proxy/driver.d.cts +4 -1
- package/pg-proxy/driver.d.ts +4 -1
- package/pg-proxy/driver.js +6 -1
- package/pg-proxy/driver.js.map +1 -1
- package/pglite/driver.cjs +6 -1
- package/pglite/driver.cjs.map +1 -1
- package/pglite/driver.d.cts +3 -1
- package/pglite/driver.d.ts +3 -1
- package/pglite/driver.js +5 -1
- package/pglite/driver.js.map +1 -1
- package/planetscale-serverless/driver.cjs +7 -1
- package/planetscale-serverless/driver.cjs.map +1 -1
- package/planetscale-serverless/driver.d.cts +4 -1
- package/planetscale-serverless/driver.d.ts +4 -1
- package/planetscale-serverless/driver.js +6 -1
- package/planetscale-serverless/driver.js.map +1 -1
- package/planetscale-serverless/migrator.cjs +4 -1
- package/planetscale-serverless/migrator.cjs.map +1 -1
- package/planetscale-serverless/migrator.d.cts +1 -1
- package/planetscale-serverless/migrator.d.ts +1 -1
- package/planetscale-serverless/migrator.js +4 -1
- package/planetscale-serverless/migrator.js.map +1 -1
- package/postgres-js/driver.cjs +7 -1
- package/postgres-js/driver.cjs.map +1 -1
- package/postgres-js/driver.d.cts +4 -1
- package/postgres-js/driver.d.ts +4 -1
- package/postgres-js/driver.js +6 -1
- package/postgres-js/driver.js.map +1 -1
- package/tidb-serverless/driver.cjs +7 -1
- package/tidb-serverless/driver.cjs.map +1 -1
- package/tidb-serverless/driver.d.cts +4 -1
- package/tidb-serverless/driver.d.ts +4 -1
- package/tidb-serverless/driver.js +6 -1
- package/tidb-serverless/driver.js.map +1 -1
- package/vercel-postgres/driver.cjs +6 -1
- package/vercel-postgres/driver.cjs.map +1 -1
- package/vercel-postgres/driver.d.cts +3 -1
- package/vercel-postgres/driver.d.ts +3 -1
- package/vercel-postgres/driver.js +5 -1
- package/vercel-postgres/driver.js.map +1 -1
- package/version.cjs +2 -2
- package/version.cjs.map +1 -1
- package/version.d.cts +2 -2
- package/version.d.ts +2 -2
- package/version.js +2 -2
- package/version.js.map +1 -1
package/monodriver.d.ts
CHANGED
|
@@ -1,18 +1,19 @@
|
|
|
1
1
|
/// <reference types="@cloudflare/workers-types" />
|
|
2
2
|
/// <reference types="node" />
|
|
3
3
|
/// <reference types="bun-types" />
|
|
4
|
-
import type { RDSDataClientConfig as RDSConfig } from '@aws-sdk/client-rds-data';
|
|
5
|
-
import type { Config as LibsqlConfig } from '@libsql/client';
|
|
6
|
-
import type { HTTPTransactionOptions as NeonHttpConfig, PoolConfig as NeonServerlessConfig } from '@neondatabase/serverless';
|
|
7
|
-
import type { Config as PlanetscaleConfig } from '@planetscale/database';
|
|
8
|
-
import type { Config as TiDBServerlessConfig } from '@tidbcloud/serverless';
|
|
9
|
-
import type { VercelPool } from '@vercel/postgres';
|
|
10
|
-
import type { Options as BetterSQLite3Options } from 'better-sqlite3';
|
|
11
|
-
import type {
|
|
12
|
-
import type {
|
|
13
|
-
import type {
|
|
4
|
+
import type { RDSDataClient, RDSDataClientConfig as RDSConfig } from '@aws-sdk/client-rds-data';
|
|
5
|
+
import type { Client as LibsqlClient, Config as LibsqlConfig } from '@libsql/client';
|
|
6
|
+
import type { HTTPTransactionOptions as NeonHttpConfig, NeonQueryFunction, Pool as NeonServerlessPool, PoolConfig as NeonServerlessConfig } from '@neondatabase/serverless';
|
|
7
|
+
import type { Client as PlanetscaleClient, Config as PlanetscaleConfig } from '@planetscale/database';
|
|
8
|
+
import type { Config as TiDBServerlessConfig, Connection as TiDBConnection } from '@tidbcloud/serverless';
|
|
9
|
+
import type { QueryResult, QueryResultRow, VercelPool } from '@vercel/postgres';
|
|
10
|
+
import type { Database as BetterSQLite3Database, Options as BetterSQLite3Options } from 'better-sqlite3';
|
|
11
|
+
import type { Database as BunDatabase } from 'bun:sqlite';
|
|
12
|
+
import type { Pool as Mysql2Pool, PoolOptions as Mysql2Config } from 'mysql2';
|
|
13
|
+
import type { Pool as NodePgPool, PoolConfig as NodePGPoolConfig } from 'pg';
|
|
14
|
+
import type { Options as PostgresJSOptions, PostgresType as PostgresJSPostgresType, Sql as PostgresJsClient } from 'postgres';
|
|
14
15
|
import type { AwsDataApiPgDatabase, DrizzleAwsDataApiPgConfig } from "./aws-data-api/pg/index.js";
|
|
15
|
-
import type { BetterSQLite3Database } from "./better-sqlite3/index.js";
|
|
16
|
+
import type { BetterSQLite3Database as DrizzleBetterSQLite3Database } from "./better-sqlite3/index.js";
|
|
16
17
|
import type { BunSQLiteDatabase } from "./bun-sqlite/index.js";
|
|
17
18
|
import type { DrizzleD1Database } from "./d1/index.js";
|
|
18
19
|
import type { LibSQLDatabase } from "./libsql/index.js";
|
|
@@ -46,17 +47,19 @@ type BunSqliteDatabaseOptions = number | {
|
|
|
46
47
|
readwrite?: boolean;
|
|
47
48
|
};
|
|
48
49
|
type BunSqliteDatabaseConfig = {
|
|
49
|
-
filename?: string;
|
|
50
|
+
filename?: ':memory:' | (string & {});
|
|
50
51
|
options?: BunSqliteDatabaseOptions;
|
|
51
|
-
} | string | undefined;
|
|
52
|
+
} | ':memory:' | (string & {}) | undefined;
|
|
52
53
|
type BetterSQLite3DatabaseConfig = {
|
|
53
|
-
filename?: string | Buffer;
|
|
54
|
+
filename?: ':memory:' | (string & {}) | Buffer;
|
|
54
55
|
options?: BetterSQLite3Options;
|
|
55
|
-
} | string | undefined;
|
|
56
|
+
} | ':memory:' | (string & {}) | undefined;
|
|
56
57
|
type MonodriverNeonHttpConfig = {
|
|
57
58
|
connectionString: string;
|
|
58
59
|
options?: NeonHttpConfig<boolean, boolean>;
|
|
59
60
|
};
|
|
61
|
+
type VercelPrimitive = string | number | boolean | undefined | null;
|
|
62
|
+
type DatabaseClient = 'node-postgres' | 'postgres-js' | 'neon-serverless' | 'neon-http' | 'vercel-postgres' | 'aws-data-api-pg' | 'planetscale' | 'mysql2' | 'tidb-serverless' | 'libsql' | 'd1' | 'bun:sqlite' | 'better-sqlite3';
|
|
60
63
|
type ClientDrizzleInstanceMap<TSchema extends Record<string, any>> = {
|
|
61
64
|
'node-postgres': NodePgDatabase<TSchema>;
|
|
62
65
|
'postgres-js': PostgresJsDatabase<TSchema>;
|
|
@@ -70,48 +73,66 @@ type ClientDrizzleInstanceMap<TSchema extends Record<string, any>> = {
|
|
|
70
73
|
libsql: LibSQLDatabase<TSchema>;
|
|
71
74
|
d1: DrizzleD1Database<TSchema>;
|
|
72
75
|
'bun:sqlite': BunSQLiteDatabase<TSchema>;
|
|
73
|
-
'better-sqlite3':
|
|
76
|
+
'better-sqlite3': DrizzleBetterSQLite3Database<TSchema>;
|
|
74
77
|
};
|
|
75
|
-
type
|
|
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
|
-
|
|
104
|
-
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
|
|
78
|
+
type ClientInstanceMap = {
|
|
79
|
+
'node-postgres': NodePgPool;
|
|
80
|
+
'postgres-js': PostgresJsClient;
|
|
81
|
+
'neon-serverless': NeonServerlessPool;
|
|
82
|
+
'neon-http': NeonQueryFunction<boolean, boolean>;
|
|
83
|
+
'vercel-postgres': VercelPool & (<O extends QueryResultRow>(strings: TemplateStringsArray, ...values: VercelPrimitive[]) => Promise<QueryResult<O>>);
|
|
84
|
+
'aws-data-api-pg': RDSDataClient;
|
|
85
|
+
planetscale: PlanetscaleClient;
|
|
86
|
+
mysql2: Mysql2Pool;
|
|
87
|
+
'tidb-serverless': TiDBConnection;
|
|
88
|
+
libsql: LibsqlClient;
|
|
89
|
+
d1: D1Database;
|
|
90
|
+
'bun:sqlite': BunDatabase;
|
|
91
|
+
'better-sqlite3': BetterSQLite3Database;
|
|
92
|
+
};
|
|
93
|
+
type InitializerParams = {
|
|
94
|
+
'node-postgres': {
|
|
95
|
+
connection: NodePGPoolConfig;
|
|
96
|
+
};
|
|
97
|
+
'postgres-js': {
|
|
98
|
+
connection: string | PostgresJSOptions<Record<string, PostgresJSPostgresType>>;
|
|
99
|
+
};
|
|
100
|
+
'neon-serverless': {
|
|
101
|
+
connection: NeonServerlessConfig;
|
|
102
|
+
};
|
|
103
|
+
'neon-http': {
|
|
104
|
+
connection: MonodriverNeonHttpConfig;
|
|
105
|
+
};
|
|
106
|
+
'vercel-postgres': {
|
|
107
|
+
connection: VercelPool;
|
|
108
|
+
};
|
|
109
|
+
'aws-data-api-pg': {
|
|
110
|
+
connection?: RDSConfig;
|
|
111
|
+
};
|
|
112
|
+
planetscale: {
|
|
113
|
+
connection: PlanetscaleConfig;
|
|
114
|
+
};
|
|
115
|
+
mysql2: {
|
|
116
|
+
connection: Mysql2Config | string;
|
|
117
|
+
};
|
|
118
|
+
'tidb-serverless': {
|
|
119
|
+
connection: TiDBServerlessConfig;
|
|
120
|
+
};
|
|
121
|
+
libsql: {
|
|
122
|
+
connection: LibsqlConfig;
|
|
123
|
+
};
|
|
124
|
+
d1: {
|
|
125
|
+
connection: D1Database;
|
|
126
|
+
};
|
|
127
|
+
'bun:sqlite': {
|
|
128
|
+
connection?: BunSqliteDatabaseConfig;
|
|
129
|
+
};
|
|
130
|
+
'better-sqlite3': {
|
|
131
|
+
connection?: BetterSQLite3DatabaseConfig;
|
|
132
|
+
};
|
|
133
|
+
};
|
|
134
|
+
type DetermineClient<TClient extends DatabaseClient, TSchema extends Record<string, unknown>> = ClientDrizzleInstanceMap<TSchema>[TClient] & {
|
|
135
|
+
$client: ClientInstanceMap[TClient];
|
|
136
|
+
};
|
|
137
|
+
export declare function drizzle<TClient extends DatabaseClient, TSchema extends Record<string, unknown> = Record<string, never>>(client: TClient, params: InitializerParams[TClient] & (TClient extends 'mysql2' ? MySql2DrizzleConfig<TSchema> : TClient extends 'aws-data-api-pg' ? DrizzleAwsDataApiPgConfig<TSchema> : DrizzleConfig<TSchema>)): Promise<DetermineClient<TClient, TSchema>>;
|
|
117
138
|
export {};
|
package/monodriver.js
CHANGED
|
@@ -3,14 +3,19 @@ const importError = (libName) => {
|
|
|
3
3
|
`Please install '${libName}' for Drizzle ORM to connect to database`
|
|
4
4
|
);
|
|
5
5
|
};
|
|
6
|
-
|
|
7
|
-
|
|
6
|
+
function assertUnreachable(_) {
|
|
7
|
+
throw new Error("Didn't expect to get here");
|
|
8
|
+
}
|
|
9
|
+
async function drizzle(client, params) {
|
|
10
|
+
const { connection, ...drizzleConfig } = params;
|
|
8
11
|
switch (client) {
|
|
9
12
|
case "node-postgres": {
|
|
10
13
|
const { Pool } = await import("pg").catch(() => importError("pg"));
|
|
11
14
|
const { drizzle: drizzle2 } = await import("./node-postgres");
|
|
12
15
|
const instance = new Pool(connection);
|
|
13
|
-
|
|
16
|
+
const db = drizzle2(instance, drizzleConfig);
|
|
17
|
+
db.$client = instance;
|
|
18
|
+
return db;
|
|
14
19
|
}
|
|
15
20
|
case "aws-data-api-pg": {
|
|
16
21
|
const { RDSDataClient } = await import("@aws-sdk/client-rds-data").catch(
|
|
@@ -18,7 +23,9 @@ const drizzle = async (params) => {
|
|
|
18
23
|
);
|
|
19
24
|
const { drizzle: drizzle2 } = await import("./aws-data-api/pg");
|
|
20
25
|
const instance = new RDSDataClient(connection);
|
|
21
|
-
|
|
26
|
+
const db = drizzle2(instance, drizzleConfig);
|
|
27
|
+
db.$client = instance;
|
|
28
|
+
return db;
|
|
22
29
|
}
|
|
23
30
|
case "better-sqlite3": {
|
|
24
31
|
const { default: Client } = await import("better-sqlite3").catch(() => importError("better-sqlite3"));
|
|
@@ -26,10 +33,14 @@ const drizzle = async (params) => {
|
|
|
26
33
|
if (typeof connection === "object") {
|
|
27
34
|
const { filename, options } = connection;
|
|
28
35
|
const instance2 = new Client(filename, options);
|
|
29
|
-
|
|
36
|
+
const db2 = drizzle2(instance2, drizzleConfig);
|
|
37
|
+
db2.$client = instance2;
|
|
38
|
+
return db2;
|
|
30
39
|
}
|
|
31
40
|
const instance = new Client(connection);
|
|
32
|
-
|
|
41
|
+
const db = drizzle2(instance, drizzleConfig);
|
|
42
|
+
db.$client = instance;
|
|
43
|
+
return db;
|
|
33
44
|
}
|
|
34
45
|
case "bun:sqlite": {
|
|
35
46
|
const { Database: Client } = await import("bun:sqlite").catch(() => importError("bun:sqlite"));
|
|
@@ -37,39 +48,53 @@ const drizzle = async (params) => {
|
|
|
37
48
|
if (typeof connection === "object") {
|
|
38
49
|
const { filename, options } = connection;
|
|
39
50
|
const instance2 = new Client(filename, options);
|
|
40
|
-
|
|
51
|
+
const db2 = drizzle2(instance2, drizzleConfig);
|
|
52
|
+
db2.$client = instance2;
|
|
53
|
+
return db2;
|
|
41
54
|
}
|
|
42
55
|
const instance = new Client(connection);
|
|
43
|
-
|
|
56
|
+
const db = drizzle2(instance, drizzleConfig);
|
|
57
|
+
db.$client = instance;
|
|
58
|
+
return db;
|
|
44
59
|
}
|
|
45
60
|
case "d1": {
|
|
46
61
|
const { drizzle: drizzle2 } = await import("./d1");
|
|
47
|
-
|
|
62
|
+
const db = drizzle2(connection, drizzleConfig);
|
|
63
|
+
db.$client = connection;
|
|
64
|
+
return db;
|
|
48
65
|
}
|
|
49
66
|
case "libsql": {
|
|
50
67
|
const { createClient } = await import("@libsql/client").catch(() => importError("@libsql/client"));
|
|
51
68
|
const { drizzle: drizzle2 } = await import("./libsql");
|
|
52
69
|
const instance = createClient(connection);
|
|
53
|
-
|
|
70
|
+
const db = drizzle2(instance, drizzleConfig);
|
|
71
|
+
db.$client = instance;
|
|
72
|
+
return db;
|
|
54
73
|
}
|
|
55
74
|
case "mysql2": {
|
|
56
|
-
const {
|
|
57
|
-
const instance =
|
|
75
|
+
const { createPool } = await import("mysql2/promise").catch(() => importError("mysql2/promise"));
|
|
76
|
+
const instance = createPool(connection);
|
|
58
77
|
const { drizzle: drizzle2 } = await import("./mysql2");
|
|
59
|
-
|
|
78
|
+
const db = drizzle2(instance, drizzleConfig);
|
|
79
|
+
db.$client = instance;
|
|
80
|
+
return db;
|
|
60
81
|
}
|
|
61
82
|
case "neon-http": {
|
|
62
83
|
const { neon } = await import("@neondatabase/serverless").catch(() => importError("@neondatabase/serverless"));
|
|
63
84
|
const { connectionString, options } = connection;
|
|
64
85
|
const { drizzle: drizzle2 } = await import("./neon-http");
|
|
65
86
|
const instance = neon(connectionString, options);
|
|
66
|
-
|
|
87
|
+
const db = drizzle2(instance, drizzleConfig);
|
|
88
|
+
db.$client = instance;
|
|
89
|
+
return db;
|
|
67
90
|
}
|
|
68
91
|
case "neon-serverless": {
|
|
69
92
|
const { Pool } = await import("@neondatabase/serverless").catch(() => importError("@neondatabase/serverless"));
|
|
70
93
|
const { drizzle: drizzle2 } = await import("./neon-serverless");
|
|
71
94
|
const instance = new Pool(connection);
|
|
72
|
-
|
|
95
|
+
const db = drizzle2(instance, drizzleConfig);
|
|
96
|
+
db.$client = instance;
|
|
97
|
+
return db;
|
|
73
98
|
}
|
|
74
99
|
case "planetscale": {
|
|
75
100
|
const { Client } = await import("@planetscale/database").catch(() => importError("@planetscale/database"));
|
|
@@ -77,27 +102,36 @@ const drizzle = async (params) => {
|
|
|
77
102
|
const instance = new Client(
|
|
78
103
|
connection
|
|
79
104
|
);
|
|
80
|
-
|
|
105
|
+
const db = drizzle2(instance, drizzleConfig);
|
|
106
|
+
db.$client = instance;
|
|
107
|
+
return db;
|
|
81
108
|
}
|
|
82
109
|
case "postgres-js": {
|
|
83
110
|
const { default: client2 } = await import("postgres").catch(() => importError("postgres"));
|
|
84
111
|
const { drizzle: drizzle2 } = await import("./postgres-js");
|
|
85
112
|
const instance = client2(connection);
|
|
86
|
-
|
|
113
|
+
const db = drizzle2(instance, drizzleConfig);
|
|
114
|
+
db.$client = instance;
|
|
115
|
+
return db;
|
|
87
116
|
}
|
|
88
117
|
case "tidb-serverless": {
|
|
89
118
|
const { connect } = await import("@tidbcloud/serverless").catch(() => importError("@tidbcloud/serverless"));
|
|
90
119
|
const { drizzle: drizzle2 } = await import("./tidb-serverless");
|
|
91
120
|
const instance = connect(connection);
|
|
92
|
-
|
|
121
|
+
const db = drizzle2(instance, drizzleConfig);
|
|
122
|
+
db.$client = instance;
|
|
123
|
+
return db;
|
|
93
124
|
}
|
|
94
125
|
case "vercel-postgres": {
|
|
95
126
|
const { sql } = await import("@vercel/postgres").catch(() => importError("@vercel/postgres"));
|
|
96
127
|
const { drizzle: drizzle2 } = await import("./vercel-postgres");
|
|
97
|
-
|
|
128
|
+
const db = drizzle2(sql, drizzleConfig);
|
|
129
|
+
db.$client = sql;
|
|
130
|
+
return db;
|
|
98
131
|
}
|
|
99
132
|
}
|
|
100
|
-
|
|
133
|
+
assertUnreachable(client);
|
|
134
|
+
}
|
|
101
135
|
export {
|
|
102
136
|
drizzle
|
|
103
137
|
};
|
package/monodriver.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/monodriver.ts"],"sourcesContent":["/* eslint-disable import/extensions */\nimport type { RDSDataClientConfig as RDSConfig } from '@aws-sdk/client-rds-data';\nimport type { Config as LibsqlConfig } from '@libsql/client';\nimport type {\n\tHTTPTransactionOptions as NeonHttpConfig,\n\tPoolConfig as NeonServerlessConfig,\n} from '@neondatabase/serverless';\nimport type { Config as PlanetscaleConfig } from '@planetscale/database';\nimport type { Config as TiDBServerlessConfig } from '@tidbcloud/serverless';\nimport type { VercelPool } from '@vercel/postgres';\nimport type { Options as BetterSQLite3Options } from 'better-sqlite3';\nimport type { PoolOptions as Mysql2Config } from 'mysql2';\nimport type { PoolConfig as NodePGPoolConfig } from 'pg';\nimport type { Options as PostgresJSOptions, PostgresType as PostgresJSPostgresType } from 'postgres';\nimport type { AwsDataApiPgDatabase, DrizzleAwsDataApiPgConfig } from './aws-data-api/pg/index.ts';\nimport type { BetterSQLite3Database } from './better-sqlite3/index.ts';\nimport type { BunSQLiteDatabase } from './bun-sqlite/index.ts';\nimport type { DrizzleD1Database } from './d1/index.ts';\nimport type { LibSQLDatabase } from './libsql/index.ts';\nimport type { MySql2Database, MySql2DrizzleConfig } from './mysql2/index.ts';\nimport type { NeonHttpDatabase } from './neon-http/index.ts';\nimport type { NeonDatabase } from './neon-serverless/index.ts';\nimport type { NodePgDatabase } from './node-postgres/index.ts';\nimport type { PlanetScaleDatabase } from './planetscale-serverless/index.ts';\nimport type { PostgresJsDatabase } from './postgres-js/index.ts';\nimport type { TiDBServerlessDatabase } from './tidb-serverless/index.ts';\nimport type { DrizzleConfig } from './utils.ts';\nimport type { VercelPgDatabase } from './vercel-postgres/index.ts';\n\ntype BunSqliteDatabaseOptions =\n\t| number\n\t| {\n\t\t/**\n\t\t * Open the database as read-only (no write operations, no create).\n\t\t *\n\t\t * Equivalent to {@link constants.SQLITE_OPEN_READONLY}\n\t\t */\n\t\treadonly?: boolean;\n\t\t/**\n\t\t * Allow creating a new database\n\t\t *\n\t\t * Equivalent to {@link constants.SQLITE_OPEN_CREATE}\n\t\t */\n\t\tcreate?: boolean;\n\t\t/**\n\t\t * Open the database as read-write\n\t\t *\n\t\t * Equivalent to {@link constants.SQLITE_OPEN_READWRITE}\n\t\t */\n\t\treadwrite?: boolean;\n\t};\n\ntype BunSqliteDatabaseConfig =\n\t| {\n\t\tfilename?: string;\n\t\toptions?: BunSqliteDatabaseOptions;\n\t}\n\t| string\n\t| undefined;\n\ntype BetterSQLite3DatabaseConfig =\n\t| {\n\t\tfilename?: string | Buffer;\n\t\toptions?: BetterSQLite3Options;\n\t}\n\t| string\n\t| undefined;\n\ntype MonodriverNeonHttpConfig = {\n\tconnectionString: string;\n\toptions?: NeonHttpConfig<boolean, boolean>;\n};\n\ntype ClientDrizzleInstanceMap<TSchema extends Record<string, any>> = {\n\t'node-postgres': NodePgDatabase<TSchema>;\n\t'postgres-js': PostgresJsDatabase<TSchema>;\n\t'neon-serverless': NeonDatabase<TSchema>;\n\t'neon-http': NeonHttpDatabase<TSchema>;\n\t'vercel-postgres': VercelPgDatabase<TSchema>;\n\t'aws-data-api-pg': AwsDataApiPgDatabase<TSchema>;\n\tplanetscale: PlanetScaleDatabase<TSchema>;\n\tmysql2: MySql2Database<TSchema>;\n\t'tidb-serverless': TiDBServerlessDatabase<TSchema>;\n\tlibsql: LibSQLDatabase<TSchema>;\n\td1: DrizzleD1Database<TSchema>;\n\t'bun:sqlite': BunSQLiteDatabase<TSchema>;\n\t'better-sqlite3': BetterSQLite3Database<TSchema>;\n};\n\ntype InitializerParams<\n\tTSchema extends Record<string, unknown> = Record<string, never>,\n> =\n\t| ({\n\t\tclient: 'node-postgres';\n\t\tconnection: NodePGPoolConfig;\n\t} & DrizzleConfig<TSchema>)\n\t| ({\n\t\tclient: 'postgres-js';\n\t\tconnection: PostgresJSOptions<Record<string, PostgresJSPostgresType>>;\n\t} & DrizzleConfig<TSchema>)\n\t| ({\n\t\tclient: 'neon-serverless';\n\t\tconnection: NeonServerlessConfig;\n\t} & DrizzleConfig<TSchema>)\n\t| ({\n\t\tclient: 'neon-http';\n\t\tconnection: MonodriverNeonHttpConfig;\n\t} & DrizzleConfig<TSchema>)\n\t| ({\n\t\tclient: 'vercel-postgres';\n\t\tconnection: VercelPool;\n\t} & DrizzleConfig<TSchema>)\n\t| ({\n\t\tclient: 'aws-data-api-pg';\n\t\tconnection: RDSConfig;\n\t} & DrizzleAwsDataApiPgConfig<TSchema>)\n\t| ({\n\t\tclient: 'planetscale';\n\t\tconnection: PlanetscaleConfig;\n\t} & DrizzleConfig<TSchema>)\n\t| ({\n\t\tclient: 'mysql2';\n\t\tconnection: Mysql2Config;\n\t} & MySql2DrizzleConfig<TSchema>)\n\t| ({\n\t\tclient: 'tidb-serverless';\n\t\tconnection: TiDBServerlessConfig;\n\t} & DrizzleConfig<TSchema>)\n\t| ({\n\t\tclient: 'libsql';\n\t\tconnection: LibsqlConfig;\n\t} & DrizzleConfig<TSchema>)\n\t| ({\n\t\tclient: 'd1';\n\t\tconnection: D1Database;\n\t} & DrizzleConfig<TSchema>)\n\t| ({\n\t\tclient: 'bun:sqlite';\n\t\tconnection: BunSqliteDatabaseConfig;\n\t} & DrizzleConfig<TSchema>)\n\t| ({\n\t\tclient: 'better-sqlite3';\n\t\tconnection: BetterSQLite3DatabaseConfig;\n\t} & DrizzleConfig<TSchema>);\n\ntype DetermineClient<\n\tTParams extends InitializerParams<any>,\n> = ClientDrizzleInstanceMap<\n\tTParams['schema'] extends Record<string, unknown> ? TParams['schema'] : Record<string, never>\n>[TParams['client']];\n\nconst importError = (libName: string) => {\n\tthrow new Error(\n\t\t`Please install '${libName}' for Drizzle ORM to connect to database`,\n\t);\n};\n\nexport const drizzle = async <\n\tTSchema extends Record<string, any>,\n\tTParams extends InitializerParams<TSchema>,\n>(params: TParams): Promise<DetermineClient<TParams>> => {\n\tconst { client, connection, ...drizzleConfig } = params;\n\n\tswitch (client) {\n\t\tcase 'node-postgres': {\n\t\t\tconst { Pool } = await import('pg').catch(() => importError('pg'));\n\t\t\tconst { drizzle } = await import('./node-postgres');\n\t\t\tconst instance = new Pool(connection as NodePGPoolConfig);\n\n\t\t\treturn drizzle(instance, drizzleConfig) as any;\n\t\t}\n\t\tcase 'aws-data-api-pg': {\n\t\t\tconst { RDSDataClient } = await import('@aws-sdk/client-rds-data').catch(() =>\n\t\t\t\timportError('@aws-sdk/client-rds-data')\n\t\t\t);\n\t\t\tconst { drizzle } = await import('./aws-data-api/pg');\n\t\t\tconst instance = new RDSDataClient(connection);\n\n\t\t\treturn drizzle(instance, drizzleConfig as any as DrizzleAwsDataApiPgConfig) as any;\n\t\t}\n\t\tcase 'better-sqlite3': {\n\t\t\tconst { default: Client } = await import('better-sqlite3').catch(() => importError('better-sqlite3'));\n\t\t\tconst { drizzle } = await import('./better-sqlite3');\n\n\t\t\tif (typeof connection === 'object') {\n\t\t\t\tconst { filename, options } = connection as Exclude<BetterSQLite3DatabaseConfig, string | undefined>;\n\n\t\t\t\tconst instance = new Client(filename, options);\n\n\t\t\t\treturn drizzle(instance, drizzleConfig) as any;\n\t\t\t}\n\n\t\t\tconst instance = new Client(connection);\n\n\t\t\treturn drizzle(instance, drizzleConfig) as any;\n\t\t}\n\t\tcase 'bun:sqlite': {\n\t\t\tconst { Database: Client } = await import('bun:sqlite').catch(() => importError('bun:sqlite'));\n\t\t\tconst { drizzle } = await import('./bun-sqlite');\n\n\t\t\tif (typeof connection === 'object') {\n\t\t\t\tconst { filename, options } = connection as Exclude<BunSqliteDatabaseConfig, string | undefined>;\n\n\t\t\t\tconst instance = new Client(filename, options);\n\n\t\t\t\treturn drizzle(instance, drizzleConfig) as any;\n\t\t\t}\n\n\t\t\tconst instance = new Client(connection);\n\n\t\t\treturn drizzle(instance, drizzleConfig) as any;\n\t\t}\n\t\tcase 'd1': {\n\t\t\tconst { drizzle } = await import('./d1');\n\t\t\treturn drizzle(connection as D1Database, drizzleConfig) as any;\n\t\t}\n\t\tcase 'libsql': {\n\t\t\tconst { createClient } = await import('@libsql/client').catch(() => importError('@libsql/client'));\n\t\t\tconst { drizzle } = await import('./libsql');\n\t\t\tconst instance = createClient(connection as LibsqlConfig);\n\n\t\t\treturn drizzle(instance, drizzleConfig) as any;\n\t\t}\n\t\tcase 'mysql2': {\n\t\t\tconst { createConnection } = await import('mysql2/promise').catch(() => importError('mysql2/promise'));\n\t\t\tconst instance = await createConnection(connection as Mysql2Config);\n\t\t\tconst { drizzle } = await import('./mysql2');\n\n\t\t\treturn drizzle(instance, drizzleConfig as MySql2DrizzleConfig) as any;\n\t\t}\n\t\tcase 'neon-http': {\n\t\t\tconst { neon } = await import('@neondatabase/serverless').catch(() => importError('@neondatabase/serverless'));\n\t\t\tconst { connectionString, options } = connection as MonodriverNeonHttpConfig;\n\t\t\tconst { drizzle } = await import('./neon-http');\n\t\t\tconst instance = neon(connectionString, options);\n\n\t\t\treturn drizzle(instance, drizzleConfig) as any;\n\t\t}\n\t\tcase 'neon-serverless': {\n\t\t\tconst { Pool } = await import('@neondatabase/serverless').catch(() => importError('@neondatabase/serverless'));\n\t\t\tconst { drizzle } = await import('./neon-serverless');\n\t\t\tconst instance = new Pool(connection as NeonServerlessConfig);\n\n\t\t\treturn drizzle(instance, drizzleConfig) as any;\n\t\t}\n\t\tcase 'planetscale': {\n\t\t\tconst { Client } = await import('@planetscale/database').catch(() => importError('@planetscale/database'));\n\t\t\tconst { drizzle } = await import('./planetscale-serverless');\n\t\t\tconst instance = new Client(\n\t\t\t\tconnection as PlanetscaleConfig,\n\t\t\t);\n\n\t\t\treturn drizzle(instance, drizzleConfig) as any;\n\t\t}\n\t\tcase 'postgres-js': {\n\t\t\tconst { default: client } = await import('postgres').catch(() => importError('postgres'));\n\t\t\tconst { drizzle } = await import('./postgres-js');\n\t\t\tconst instance = client(connection as PostgresJSOptions<Record<string, PostgresJSPostgresType>>);\n\n\t\t\treturn drizzle(instance, drizzleConfig) as any;\n\t\t}\n\t\tcase 'tidb-serverless': {\n\t\t\tconst { connect } = await import('@tidbcloud/serverless').catch(() => importError('@tidbcloud/serverless'));\n\t\t\tconst { drizzle } = await import('./tidb-serverless');\n\t\t\tconst instance = connect(connection as TiDBServerlessConfig);\n\n\t\t\treturn drizzle(instance, drizzleConfig) as any;\n\t\t}\n\t\tcase 'vercel-postgres': {\n\t\t\tconst { sql } = await import('@vercel/postgres').catch(() => importError('@vercel/postgres'));\n\t\t\tconst { drizzle } = await import('./vercel-postgres');\n\n\t\t\treturn drizzle(sql, drizzleConfig) as any;\n\t\t}\n\t}\n};\n"],"mappings":"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","names":["drizzle","instance","client"]}
|
|
1
|
+
{"version":3,"sources":["../src/monodriver.ts"],"sourcesContent":["/* eslint-disable import/extensions */\nimport type { RDSDataClient, RDSDataClientConfig, RDSDataClientConfig as RDSConfig } from '@aws-sdk/client-rds-data';\nimport type { Client as LibsqlClient, Config as LibsqlConfig } from '@libsql/client';\nimport type {\n\tHTTPTransactionOptions as NeonHttpConfig,\n\tNeonQueryFunction,\n\tPool as NeonServerlessPool,\n\tPoolConfig as NeonServerlessConfig,\n} from '@neondatabase/serverless';\nimport type { Client as PlanetscaleClient, Config as PlanetscaleConfig } from '@planetscale/database';\nimport type { Config as TiDBServerlessConfig, Connection as TiDBConnection } from '@tidbcloud/serverless';\nimport type { QueryResult, QueryResultRow, VercelPool } from '@vercel/postgres';\nimport type { Database as BetterSQLite3Database, Options as BetterSQLite3Options } from 'better-sqlite3';\nimport type { Database as BunDatabase } from 'bun:sqlite';\nimport type { Pool as Mysql2Pool, PoolOptions as Mysql2Config } from 'mysql2';\nimport type { Pool as NodePgPool, PoolConfig as NodePGPoolConfig } from 'pg';\nimport type {\n\tOptions as PostgresJSOptions,\n\tPostgresType as PostgresJSPostgresType,\n\tSql as PostgresJsClient,\n} from 'postgres';\nimport type { AwsDataApiPgDatabase, DrizzleAwsDataApiPgConfig } from './aws-data-api/pg/index.ts';\nimport type { BetterSQLite3Database as DrizzleBetterSQLite3Database } from './better-sqlite3/index.ts';\nimport type { BunSQLiteDatabase } from './bun-sqlite/index.ts';\nimport type { DrizzleD1Database } from './d1/index.ts';\nimport type { LibSQLDatabase } from './libsql/index.ts';\nimport type { MySql2Database, MySql2DrizzleConfig } from './mysql2/index.ts';\nimport type { NeonHttpDatabase } from './neon-http/index.ts';\nimport type { NeonDatabase } from './neon-serverless/index.ts';\nimport type { NodePgDatabase } from './node-postgres/index.ts';\nimport type { PlanetScaleDatabase } from './planetscale-serverless/index.ts';\nimport type { PostgresJsDatabase } from './postgres-js/index.ts';\nimport type { TiDBServerlessDatabase } from './tidb-serverless/index.ts';\nimport type { DrizzleConfig } from './utils.ts';\nimport type { VercelPgDatabase } from './vercel-postgres/index.ts';\n\ntype BunSqliteDatabaseOptions =\n\t| number\n\t| {\n\t\t/**\n\t\t * Open the database as read-only (no write operations, no create).\n\t\t *\n\t\t * Equivalent to {@link constants.SQLITE_OPEN_READONLY}\n\t\t */\n\t\treadonly?: boolean;\n\t\t/**\n\t\t * Allow creating a new database\n\t\t *\n\t\t * Equivalent to {@link constants.SQLITE_OPEN_CREATE}\n\t\t */\n\t\tcreate?: boolean;\n\t\t/**\n\t\t * Open the database as read-write\n\t\t *\n\t\t * Equivalent to {@link constants.SQLITE_OPEN_READWRITE}\n\t\t */\n\t\treadwrite?: boolean;\n\t};\n\ntype BunSqliteDatabaseConfig =\n\t| {\n\t\tfilename?: ':memory:' | (string & {});\n\t\toptions?: BunSqliteDatabaseOptions;\n\t}\n\t| ':memory:'\n\t| (string & {})\n\t| undefined;\n\ntype BetterSQLite3DatabaseConfig =\n\t| {\n\t\tfilename?:\n\t\t\t| ':memory:'\n\t\t\t| (string & {})\n\t\t\t| Buffer;\n\t\toptions?: BetterSQLite3Options;\n\t}\n\t| ':memory:'\n\t| (string & {})\n\t| undefined;\n\ntype MonodriverNeonHttpConfig = {\n\tconnectionString: string;\n\toptions?: NeonHttpConfig<boolean, boolean>;\n};\n\ntype VercelPrimitive = string | number | boolean | undefined | null;\n\ntype DatabaseClient =\n\t| 'node-postgres'\n\t| 'postgres-js'\n\t| 'neon-serverless'\n\t| 'neon-http'\n\t| 'vercel-postgres'\n\t| 'aws-data-api-pg'\n\t| 'planetscale'\n\t| 'mysql2'\n\t| 'tidb-serverless'\n\t| 'libsql'\n\t| 'd1'\n\t| 'bun:sqlite'\n\t| 'better-sqlite3';\n\ntype ClientDrizzleInstanceMap<TSchema extends Record<string, any>> = {\n\t'node-postgres': NodePgDatabase<TSchema>;\n\t'postgres-js': PostgresJsDatabase<TSchema>;\n\t'neon-serverless': NeonDatabase<TSchema>;\n\t'neon-http': NeonHttpDatabase<TSchema>;\n\t'vercel-postgres': VercelPgDatabase<TSchema>;\n\t'aws-data-api-pg': AwsDataApiPgDatabase<TSchema>;\n\tplanetscale: PlanetScaleDatabase<TSchema>;\n\tmysql2: MySql2Database<TSchema>;\n\t'tidb-serverless': TiDBServerlessDatabase<TSchema>;\n\tlibsql: LibSQLDatabase<TSchema>;\n\td1: DrizzleD1Database<TSchema>;\n\t'bun:sqlite': BunSQLiteDatabase<TSchema>;\n\t'better-sqlite3': DrizzleBetterSQLite3Database<TSchema>;\n};\n\ntype ClientInstanceMap = {\n\t'node-postgres': NodePgPool;\n\t'postgres-js': PostgresJsClient;\n\t'neon-serverless': NeonServerlessPool;\n\t'neon-http': NeonQueryFunction<boolean, boolean>;\n\t'vercel-postgres':\n\t\t& VercelPool\n\t\t& (<O extends QueryResultRow>(\n\t\t\tstrings: TemplateStringsArray,\n\t\t\t...values: VercelPrimitive[]\n\t\t) => Promise<QueryResult<O>>);\n\t'aws-data-api-pg': RDSDataClient;\n\tplanetscale: PlanetscaleClient;\n\tmysql2: Mysql2Pool;\n\t'tidb-serverless': TiDBConnection;\n\tlibsql: LibsqlClient;\n\td1: D1Database;\n\t'bun:sqlite': BunDatabase;\n\t'better-sqlite3': BetterSQLite3Database;\n};\n\ntype InitializerParams = {\n\t'node-postgres': {\n\t\tconnection: NodePGPoolConfig;\n\t};\n\t'postgres-js': {\n\t\tconnection: string | PostgresJSOptions<Record<string, PostgresJSPostgresType>>;\n\t};\n\t'neon-serverless': {\n\t\tconnection: NeonServerlessConfig;\n\t};\n\t'neon-http': {\n\t\tconnection: MonodriverNeonHttpConfig;\n\t};\n\t'vercel-postgres': {\n\t\tconnection: VercelPool;\n\t};\n\t'aws-data-api-pg': {\n\t\tconnection?: RDSConfig;\n\t};\n\tplanetscale: {\n\t\tconnection: PlanetscaleConfig;\n\t};\n\tmysql2: {\n\t\tconnection: Mysql2Config | string;\n\t};\n\t'tidb-serverless': {\n\t\tconnection: TiDBServerlessConfig;\n\t};\n\tlibsql: {\n\t\tconnection: LibsqlConfig;\n\t};\n\td1: {\n\t\tconnection: D1Database;\n\t};\n\t'bun:sqlite': {\n\t\tconnection?: BunSqliteDatabaseConfig;\n\t};\n\t'better-sqlite3': {\n\t\tconnection?: BetterSQLite3DatabaseConfig;\n\t};\n};\n\ntype DetermineClient<\n\tTClient extends DatabaseClient,\n\tTSchema extends Record<string, unknown>,\n> =\n\t& ClientDrizzleInstanceMap<\n\t\tTSchema\n\t>[TClient]\n\t& {\n\t\t$client: ClientInstanceMap[TClient];\n\t};\n\nconst importError = (libName: string) => {\n\tthrow new Error(\n\t\t`Please install '${libName}' for Drizzle ORM to connect to database`,\n\t);\n};\n\nfunction assertUnreachable(_: never | undefined): never {\n\tthrow new Error(\"Didn't expect to get here\");\n}\n\nexport async function drizzle<\n\tTClient extends DatabaseClient,\n\tTSchema extends Record<string, unknown> = Record<string, never>,\n>(\n\tclient: TClient,\n\tparams:\n\t\t& InitializerParams[TClient]\n\t\t& (TClient extends 'mysql2' ? MySql2DrizzleConfig<TSchema>\n\t\t\t: TClient extends 'aws-data-api-pg' ? DrizzleAwsDataApiPgConfig<TSchema>\n\t\t\t: DrizzleConfig<TSchema>),\n): Promise<DetermineClient<TClient, TSchema>> {\n\tconst { connection, ...drizzleConfig } = params;\n\n\tswitch (client) {\n\t\tcase 'node-postgres': {\n\t\t\tconst { Pool } = await import('pg').catch(() => importError('pg'));\n\t\t\tconst { drizzle } = await import('./node-postgres');\n\t\t\tconst instance = new Pool(connection as NodePGPoolConfig);\n\n\t\t\tconst db = drizzle(instance, drizzleConfig) as any;\n\t\t\tdb.$client = instance;\n\n\t\t\treturn db;\n\t\t}\n\t\tcase 'aws-data-api-pg': {\n\t\t\tconst { RDSDataClient } = await import('@aws-sdk/client-rds-data').catch(() =>\n\t\t\t\timportError('@aws-sdk/client-rds-data')\n\t\t\t);\n\t\t\tconst { drizzle } = await import('./aws-data-api/pg');\n\t\t\tconst instance = new RDSDataClient(connection as RDSDataClientConfig);\n\n\t\t\tconst db = drizzle(instance, drizzleConfig as any as DrizzleAwsDataApiPgConfig) as any;\n\t\t\tdb.$client = instance;\n\n\t\t\treturn db;\n\t\t}\n\t\tcase 'better-sqlite3': {\n\t\t\tconst { default: Client } = await import('better-sqlite3').catch(() => importError('better-sqlite3'));\n\t\t\tconst { drizzle } = await import('./better-sqlite3');\n\n\t\t\tif (typeof connection === 'object') {\n\t\t\t\tconst { filename, options } = connection as Exclude<BetterSQLite3DatabaseConfig, string | undefined>;\n\n\t\t\t\tconst instance = new Client(filename, options);\n\n\t\t\t\tconst db = drizzle(instance, drizzleConfig) as any;\n\t\t\t\tdb.$client = instance;\n\n\t\t\t\treturn db;\n\t\t\t}\n\n\t\t\tconst instance = new Client(connection);\n\n\t\t\tconst db = drizzle(instance, drizzleConfig) as any;\n\t\t\tdb.$client = instance;\n\n\t\t\treturn db;\n\t\t}\n\t\tcase 'bun:sqlite': {\n\t\t\tconst { Database: Client } = await import('bun:sqlite').catch(() => importError('bun:sqlite'));\n\t\t\tconst { drizzle } = await import('./bun-sqlite');\n\n\t\t\tif (typeof connection === 'object') {\n\t\t\t\tconst { filename, options } = connection as Exclude<BunSqliteDatabaseConfig, string | undefined>;\n\n\t\t\t\tconst instance = new Client(filename, options);\n\n\t\t\t\tconst db = drizzle(instance, drizzleConfig) as any;\n\t\t\t\tdb.$client = instance;\n\n\t\t\t\treturn db;\n\t\t\t}\n\n\t\t\tconst instance = new Client(connection);\n\n\t\t\tconst db = drizzle(instance, drizzleConfig) as any;\n\t\t\tdb.$client = instance;\n\n\t\t\treturn db;\n\t\t}\n\t\tcase 'd1': {\n\t\t\tconst { drizzle } = await import('./d1');\n\n\t\t\tconst db = drizzle(connection as D1Database, drizzleConfig) as any;\n\t\t\tdb.$client = connection;\n\n\t\t\treturn db;\n\t\t}\n\t\tcase 'libsql': {\n\t\t\tconst { createClient } = await import('@libsql/client').catch(() => importError('@libsql/client'));\n\t\t\tconst { drizzle } = await import('./libsql');\n\t\t\tconst instance = createClient(connection as LibsqlConfig);\n\n\t\t\tconst db = drizzle(instance, drizzleConfig) as any;\n\t\t\tdb.$client = instance;\n\n\t\t\treturn db;\n\t\t}\n\t\tcase 'mysql2': {\n\t\t\tconst { createPool } = await import('mysql2/promise').catch(() => importError('mysql2/promise'));\n\t\t\tconst instance = createPool(connection as Mysql2Config);\n\t\t\tconst { drizzle } = await import('./mysql2');\n\n\t\t\tconst db = drizzle(instance, drizzleConfig as MySql2DrizzleConfig) as any;\n\t\t\tdb.$client = instance;\n\n\t\t\treturn db;\n\t\t}\n\t\tcase 'neon-http': {\n\t\t\tconst { neon } = await import('@neondatabase/serverless').catch(() => importError('@neondatabase/serverless'));\n\t\t\tconst { connectionString, options } = connection as MonodriverNeonHttpConfig;\n\t\t\tconst { drizzle } = await import('./neon-http');\n\t\t\tconst instance = neon(connectionString, options);\n\n\t\t\tconst db = drizzle(instance, drizzleConfig) as any;\n\t\t\tdb.$client = instance;\n\n\t\t\treturn db;\n\t\t}\n\t\tcase 'neon-serverless': {\n\t\t\tconst { Pool } = await import('@neondatabase/serverless').catch(() => importError('@neondatabase/serverless'));\n\t\t\tconst { drizzle } = await import('./neon-serverless');\n\t\t\tconst instance = new Pool(connection as NeonServerlessConfig);\n\n\t\t\tconst db = drizzle(instance, drizzleConfig) as any;\n\t\t\tdb.$client = instance;\n\n\t\t\treturn db;\n\t\t}\n\t\tcase 'planetscale': {\n\t\t\tconst { Client } = await import('@planetscale/database').catch(() => importError('@planetscale/database'));\n\t\t\tconst { drizzle } = await import('./planetscale-serverless');\n\t\t\tconst instance = new Client(\n\t\t\t\tconnection as PlanetscaleConfig,\n\t\t\t);\n\n\t\t\tconst db = drizzle(instance, drizzleConfig) as any;\n\t\t\tdb.$client = instance;\n\n\t\t\treturn db;\n\t\t}\n\t\tcase 'postgres-js': {\n\t\t\tconst { default: client } = await import('postgres').catch(() => importError('postgres'));\n\t\t\tconst { drizzle } = await import('./postgres-js');\n\t\t\tconst instance = client(connection as PostgresJSOptions<Record<string, PostgresJSPostgresType>>);\n\n\t\t\tconst db = drizzle(instance, drizzleConfig) as any;\n\t\t\tdb.$client = instance;\n\n\t\t\treturn db;\n\t\t}\n\t\tcase 'tidb-serverless': {\n\t\t\tconst { connect } = await import('@tidbcloud/serverless').catch(() => importError('@tidbcloud/serverless'));\n\t\t\tconst { drizzle } = await import('./tidb-serverless');\n\t\t\tconst instance = connect(connection as TiDBServerlessConfig);\n\n\t\t\tconst db = drizzle(instance, drizzleConfig) as any;\n\t\t\tdb.$client = instance;\n\n\t\t\treturn db;\n\t\t}\n\t\tcase 'vercel-postgres': {\n\t\t\tconst { sql } = await import('@vercel/postgres').catch(() => importError('@vercel/postgres'));\n\t\t\tconst { drizzle } = await import('./vercel-postgres');\n\n\t\t\tconst db = drizzle(sql, drizzleConfig) as any;\n\t\t\tdb.$client = sql;\n\n\t\t\treturn db;\n\t\t}\n\t}\n\n\tassertUnreachable(client);\n}\n"],"mappings":"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","names":["drizzle","instance","db","client"]}
|
package/monomigrator.cjs
CHANGED
|
@@ -31,88 +31,60 @@ __export(monomigrator_exports, {
|
|
|
31
31
|
migrate: () => migrate
|
|
32
32
|
});
|
|
33
33
|
module.exports = __toCommonJS(monomigrator_exports);
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
switch (
|
|
37
|
-
case "
|
|
34
|
+
var import_entity = require("./entity.cjs");
|
|
35
|
+
async function migrate(db, config) {
|
|
36
|
+
switch (db.constructor[import_entity.entityKind]) {
|
|
37
|
+
case "AwsDataApiPgDatabase": {
|
|
38
38
|
const { migrate: migrate2 } = await import("./aws-data-api/pg/migrator");
|
|
39
|
-
return migrate2(
|
|
39
|
+
return migrate2(db, config);
|
|
40
40
|
}
|
|
41
|
-
case "
|
|
41
|
+
case "BetterSQLite3Database": {
|
|
42
42
|
const { migrate: migrate2 } = await import("./better-sqlite3/migrator");
|
|
43
|
-
return migrate2(
|
|
43
|
+
return migrate2(db, config);
|
|
44
44
|
}
|
|
45
|
-
case "
|
|
45
|
+
case "BunSQLiteDatabase": {
|
|
46
46
|
const { migrate: migrate2 } = await import("./bun-sqlite/migrator");
|
|
47
|
-
return migrate2(
|
|
47
|
+
return migrate2(db, config);
|
|
48
48
|
}
|
|
49
|
-
case "
|
|
49
|
+
case "D1Database": {
|
|
50
50
|
const { migrate: migrate2 } = await import("./d1/migrator");
|
|
51
|
-
return migrate2(
|
|
51
|
+
return migrate2(db, config);
|
|
52
52
|
}
|
|
53
|
-
case "
|
|
54
|
-
const { migrate: migrate2 } = await import("./expo-sqlite/migrator");
|
|
55
|
-
return migrate2(rest[0], rest[1]);
|
|
56
|
-
}
|
|
57
|
-
case "libsql": {
|
|
53
|
+
case "LibSQLDatabase": {
|
|
58
54
|
const { migrate: migrate2 } = await import("./libsql/migrator");
|
|
59
|
-
return migrate2(
|
|
60
|
-
}
|
|
61
|
-
case "mysql-proxy": {
|
|
62
|
-
const { migrate: migrate2 } = await import("./mysql-proxy/migrator");
|
|
63
|
-
return migrate2(rest[0], rest[1], rest[2]);
|
|
55
|
+
return migrate2(db, config);
|
|
64
56
|
}
|
|
65
|
-
case "
|
|
57
|
+
case "MySql2Database": {
|
|
66
58
|
const { migrate: migrate2 } = await import("./mysql2/migrator");
|
|
67
|
-
return migrate2(
|
|
59
|
+
return migrate2(db, config);
|
|
68
60
|
}
|
|
69
|
-
case "
|
|
61
|
+
case "NeonHttpDatabase": {
|
|
70
62
|
const { migrate: migrate2 } = await import("./neon-http/migrator");
|
|
71
|
-
return migrate2(
|
|
63
|
+
return migrate2(db, config);
|
|
72
64
|
}
|
|
73
|
-
case "
|
|
65
|
+
case "NeonServerlessDatabase": {
|
|
74
66
|
const { migrate: migrate2 } = await import("./neon-serverless/migrator");
|
|
75
|
-
return migrate2(
|
|
67
|
+
return migrate2(db, config);
|
|
76
68
|
}
|
|
77
|
-
case "
|
|
69
|
+
case "NodePgDatabase": {
|
|
78
70
|
const { migrate: migrate2 } = await import("./node-postgres/migrator");
|
|
79
|
-
return migrate2(
|
|
80
|
-
}
|
|
81
|
-
case "op-sqlite": {
|
|
82
|
-
const { migrate: migrate2 } = await import("./op-sqlite/migrator");
|
|
83
|
-
return migrate2(rest[0], rest[1]);
|
|
84
|
-
}
|
|
85
|
-
case "pg-proxy": {
|
|
86
|
-
const { migrate: migrate2 } = await import("./pg-proxy/migrator");
|
|
87
|
-
return migrate2(rest[0], rest[1], rest[2]);
|
|
71
|
+
return migrate2(db, config);
|
|
88
72
|
}
|
|
89
|
-
case "
|
|
90
|
-
const { migrate: migrate2 } = await import("./pglite/migrator");
|
|
91
|
-
return migrate2(rest[0], rest[1]);
|
|
92
|
-
}
|
|
93
|
-
case "planetscale": {
|
|
73
|
+
case "PlanetScaleDatabase": {
|
|
94
74
|
const { migrate: migrate2 } = await import("./planetscale-serverless/migrator");
|
|
95
|
-
return migrate2(
|
|
75
|
+
return migrate2(db, config);
|
|
96
76
|
}
|
|
97
|
-
case "
|
|
77
|
+
case "PostgresJsDatabase": {
|
|
98
78
|
const { migrate: migrate2 } = await import("./postgres-js/migrator");
|
|
99
|
-
return migrate2(
|
|
100
|
-
}
|
|
101
|
-
case "sqlite-proxy": {
|
|
102
|
-
const { migrate: migrate2 } = await import("./sqlite-proxy/migrator");
|
|
103
|
-
return migrate2(rest[0], rest[1], rest[2]);
|
|
79
|
+
return migrate2(db, config);
|
|
104
80
|
}
|
|
105
|
-
case "
|
|
81
|
+
case "TiDBServerlessDatabase": {
|
|
106
82
|
const { migrate: migrate2 } = await import("./tidb-serverless/migrator");
|
|
107
|
-
return migrate2(
|
|
83
|
+
return migrate2(db, config);
|
|
108
84
|
}
|
|
109
|
-
case "
|
|
85
|
+
case "VercelPgDatabase": {
|
|
110
86
|
const { migrate: migrate2 } = await import("./vercel-postgres/migrator");
|
|
111
|
-
return migrate2(
|
|
112
|
-
}
|
|
113
|
-
case "xata-http": {
|
|
114
|
-
const { migrate: migrate2 } = await import("./xata-http/migrator");
|
|
115
|
-
return migrate2(rest[0], rest[1]);
|
|
87
|
+
return migrate2(db, config);
|
|
116
88
|
}
|
|
117
89
|
}
|
|
118
90
|
}
|
package/monomigrator.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/monomigrator.ts"],"sourcesContent":["/* eslint-disable import/extensions */\nimport type { AwsDataApiPgDatabase } from './aws-data-api/pg/index.ts';\nimport type { BetterSQLite3Database } from './better-sqlite3/index.ts';\nimport type { BunSQLiteDatabase } from './bun-sqlite/index.ts';\nimport type { DrizzleD1Database } from './d1/index.ts';\nimport type { ExpoSQLiteDatabase } from './expo-sqlite/index.ts';\nimport type { LibSQLDatabase } from './libsql/index.ts';\nimport type { MigrationConfig } from './migrator.ts';\nimport type { MySqlRemoteDatabase } from './mysql-proxy/index.ts';\nimport type { ProxyMigrator as MySqlProxyMigrator } from './mysql-proxy/migrator.ts';\nimport type { MySql2Database } from './mysql2/index.ts';\nimport type { NeonHttpDatabase } from './neon-http/index.ts';\nimport type { NeonDatabase } from './neon-serverless/index.ts';\nimport type { NodePgDatabase } from './node-postgres/index.ts';\nimport type { OPSQLiteDatabase } from './op-sqlite/index.ts';\nimport type { PgRemoteDatabase } from './pg-proxy/index.ts';\nimport type { ProxyMigrator as PgProxyMigrator } from './pg-proxy/migrator.ts';\nimport type { PgliteDatabase } from './pglite/index.ts';\nimport type { PlanetScaleDatabase } from './planetscale-serverless/index.ts';\nimport type { ProxyMigrator as SQLiteProxyMigrator } from './sqlite-proxy/migrator.ts';\nimport type { VercelPgDatabase } from './vercel-postgres/index.ts';\nimport type { XataHttpDatabase } from './xata-http/index.ts';\nimport type { MigrationConfig as XataHttpMigrationConfig } from './xata-http/migrator.ts';\n\ntype OPSQLiteMigrationConfig = {\n\tjournal: {\n\t\tentries: { idx: number; when: number; tag: string; breakpoints: boolean }[];\n\t};\n\tmigrations: Record<string, string>;\n};\n\ntype ExpoSQLiteMigrationConfig = {\n\tjournal: {\n\t\tentries: { idx: number; when: number; tag: string; breakpoints: boolean }[];\n\t};\n\tmigrations: Record<string, string>;\n};\n\ntype DatabaseType =\n\t| 'aws-data-api-pg'\n\t| 'better-sqlite3'\n\t| 'bun:sqlite'\n\t| 'd1'\n\t| 'expo-sqlite'\n\t| 'libsql'\n\t| 'mysql-proxy'\n\t| 'mysql2'\n\t| 'neon-http'\n\t| 'neon-serverless'\n\t| 'node-postgres'\n\t| 'op-sqlite'\n\t| 'pg-proxy'\n\t| 'pglite'\n\t| 'planetscale'\n\t| 'postgres-js'\n\t| 'sqlite-proxy'\n\t| 'tidb-serverless'\n\t| 'vercel-postgres'\n\t| 'xata-http';\n\nexport async function migrate(\n\ttype: 'aws-data-api-pg',\n\tdb: AwsDataApiPgDatabase<any>,\n\tconfig: string | MigrationConfig,\n): Promise<void>;\nexport async function migrate(\n\ttype: 'better-sqlite3',\n\tdb: BetterSQLite3Database<any>,\n\tconfig: string | MigrationConfig,\n): Promise<void>;\nexport async function migrate(\n\ttype: 'bun:sqlite',\n\tdb: BunSQLiteDatabase<any>,\n\tconfig: string | MigrationConfig,\n): Promise<void>;\nexport async function migrate(type: 'd1', db: DrizzleD1Database<any>, config: string | MigrationConfig): Promise<void>;\nexport async function migrate(\n\ttype: 'expo-sqlite',\n\tdb: ExpoSQLiteDatabase<any>,\n\tconfig: ExpoSQLiteMigrationConfig,\n): Promise<void>;\nexport async function migrate(type: 'libsql', db: LibSQLDatabase<any>, config: MigrationConfig): Promise<void>;\nexport async function migrate(\n\ttype: 'mysql-proxy',\n\tdb: MySqlRemoteDatabase<any>,\n\tcallback: MySqlProxyMigrator,\n\tconfig: MigrationConfig,\n): Promise<void>;\nexport async function migrate(type: 'mysql2', db: MySql2Database<any>, config: MigrationConfig): Promise<void>;\nexport async function migrate(\n\ttype: 'neon-http',\n\tdb: NeonHttpDatabase<any>,\n\tconfig: string | MigrationConfig,\n): Promise<void>;\nexport async function migrate(\n\ttype: 'neon-serverless',\n\tdb: NeonDatabase<any>,\n\tconfig: string | MigrationConfig,\n): Promise<void>;\nexport async function migrate(\n\ttype: 'node-postgres',\n\tdb: NodePgDatabase<any>,\n\tconfig: string | MigrationConfig,\n): Promise<void>;\nexport async function migrate(\n\ttype: 'op-sqlite',\n\tdb: OPSQLiteDatabase<any>,\n\tconfig: OPSQLiteMigrationConfig,\n): Promise<void>;\nexport async function migrate(\n\ttype: 'pg-proxy',\n\tdb: PgRemoteDatabase<any>,\n\tcallback: PgProxyMigrator,\n\tconfig: string | MigrationConfig,\n): Promise<void>;\nexport async function migrate(type: 'pglite', db: PgliteDatabase<any>, config: string | MigrationConfig): Promise<void>;\nexport async function migrate(\n\ttype: 'planetscale',\n\tdb: PlanetScaleDatabase<any>,\n\tconfig: MigrationConfig,\n): Promise<void>;\nexport async function migrate(\n\ttype: 'postgres-js',\n\tdb: PlanetScaleDatabase<any>,\n\tconfig: string | MigrationConfig,\n): Promise<void>;\nexport async function migrate(\n\ttype: 'sqlite-proxy',\n\tdb: PgRemoteDatabase<any>,\n\tcallback: SQLiteProxyMigrator,\n\tconfig: string | MigrationConfig,\n): Promise<void>;\nexport async function migrate(\n\ttype: 'tidb-serverless',\n\tdb: PlanetScaleDatabase<any>,\n\tconfig: MigrationConfig,\n): Promise<void>;\nexport async function migrate(\n\ttype: 'vercel-postgres',\n\tdb: VercelPgDatabase<any>,\n\tconfig: string | MigrationConfig,\n): Promise<void>;\nexport async function migrate(\n\ttype: 'xata-http',\n\tdb: XataHttpDatabase<any>,\n\tconfig: string | XataHttpMigrationConfig,\n): Promise<void>;\nexport async function migrate(\n\ttype: DatabaseType,\n\tdb: any,\n\tconfig:\n\t\t| string\n\t\t| MigrationConfig\n\t\t| ExpoSQLiteMigrationConfig\n\t\t| OPSQLiteMigrationConfig\n\t\t| XataHttpMigrationConfig\n\t\t| PgProxyMigrator\n\t\t| MySqlProxyMigrator\n\t\t| SQLiteProxyMigrator,\n\textraConfig?: string | MigrationConfig | undefined,\n) {\n\tconst rest = [db, config, extraConfig];\n\n\tswitch (type) {\n\t\tcase 'aws-data-api-pg': {\n\t\t\tconst { migrate } = await import('./aws-data-api/pg/migrator');\n\n\t\t\treturn migrate(rest[0], rest[1] as string | MigrationConfig);\n\t\t}\n\t\tcase 'better-sqlite3': {\n\t\t\tconst { migrate } = await import('./better-sqlite3/migrator');\n\n\t\t\treturn migrate(rest[0], rest[1] as string | MigrationConfig);\n\t\t}\n\t\tcase 'bun:sqlite': {\n\t\t\tconst { migrate } = await import('./bun-sqlite/migrator');\n\n\t\t\treturn migrate(rest[0], rest[1] as string | MigrationConfig);\n\t\t}\n\t\tcase 'd1': {\n\t\t\tconst { migrate } = await import('./d1/migrator');\n\n\t\t\treturn migrate(rest[0], rest[1] as string | MigrationConfig);\n\t\t}\n\t\tcase 'expo-sqlite': {\n\t\t\tconst { migrate } = await import('./expo-sqlite/migrator');\n\n\t\t\treturn migrate(rest[0], rest[1] as ExpoSQLiteMigrationConfig);\n\t\t}\n\t\tcase 'libsql': {\n\t\t\tconst { migrate } = await import('./libsql/migrator');\n\n\t\t\treturn migrate(rest[0], rest[1] as MigrationConfig);\n\t\t}\n\t\tcase 'mysql-proxy': {\n\t\t\tconst { migrate } = await import('./mysql-proxy/migrator');\n\n\t\t\treturn migrate(rest[0], rest[1] as MySqlProxyMigrator, rest[2] as MigrationConfig);\n\t\t}\n\t\tcase 'mysql2': {\n\t\t\tconst { migrate } = await import('./mysql2/migrator');\n\n\t\t\treturn migrate(rest[0], rest[1] as MigrationConfig);\n\t\t}\n\t\tcase 'neon-http': {\n\t\t\tconst { migrate } = await import('./neon-http/migrator');\n\n\t\t\treturn migrate(rest[0], rest[1] as string | MigrationConfig);\n\t\t}\n\t\tcase 'neon-serverless': {\n\t\t\tconst { migrate } = await import('./neon-serverless/migrator');\n\n\t\t\treturn migrate(rest[0], rest[1] as string | MigrationConfig);\n\t\t}\n\t\tcase 'node-postgres': {\n\t\t\tconst { migrate } = await import('./node-postgres/migrator');\n\n\t\t\treturn migrate(rest[0], rest[1] as string | MigrationConfig);\n\t\t}\n\t\tcase 'op-sqlite': {\n\t\t\tconst { migrate } = await import('./op-sqlite/migrator');\n\n\t\t\treturn migrate(rest[0], rest[1] as OPSQLiteMigrationConfig);\n\t\t}\n\t\tcase 'pg-proxy': {\n\t\t\tconst { migrate } = await import('./pg-proxy/migrator');\n\n\t\t\treturn migrate(rest[0], rest[1] as PgProxyMigrator, rest[2] as string | MigrationConfig);\n\t\t}\n\t\tcase 'pglite': {\n\t\t\tconst { migrate } = await import('./pglite/migrator');\n\n\t\t\treturn migrate(rest[0], rest[1] as string | MigrationConfig);\n\t\t}\n\t\tcase 'planetscale': {\n\t\t\tconst { migrate } = await import('./planetscale-serverless/migrator');\n\n\t\t\treturn migrate(rest[0], rest[1] as MigrationConfig);\n\t\t}\n\t\tcase 'postgres-js': {\n\t\t\tconst { migrate } = await import('./postgres-js/migrator');\n\n\t\t\treturn migrate(rest[0], rest[1] as string | MigrationConfig);\n\t\t}\n\t\tcase 'sqlite-proxy': {\n\t\t\tconst { migrate } = await import('./sqlite-proxy/migrator');\n\n\t\t\treturn migrate(rest[0], rest[1] as SQLiteProxyMigrator, rest[2] as string | MigrationConfig);\n\t\t}\n\t\tcase 'tidb-serverless': {\n\t\t\tconst { migrate } = await import('./tidb-serverless/migrator');\n\n\t\t\treturn migrate(rest[0], rest[1] as MigrationConfig);\n\t\t}\n\t\tcase 'vercel-postgres': {\n\t\t\tconst { migrate } = await import('./vercel-postgres/migrator');\n\n\t\t\treturn migrate(rest[0], rest[1] as string | MigrationConfig);\n\t\t}\n\t\tcase 'xata-http': {\n\t\t\tconst { migrate } = await import('./xata-http/migrator');\n\n\t\t\treturn migrate(rest[0], rest[1] as string | MigrationConfig);\n\t\t}\n\t}\n}\n"],"mappings":"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","names":["migrate"]}
|
|
1
|
+
{"version":3,"sources":["../src/monomigrator.ts"],"sourcesContent":["/* eslint-disable import/extensions */\nimport type { AwsDataApiPgDatabase } from './aws-data-api/pg/index.ts';\nimport type { BetterSQLite3Database } from './better-sqlite3/index.ts';\nimport type { BunSQLiteDatabase } from './bun-sqlite/index.ts';\nimport type { DrizzleD1Database } from './d1/index.ts';\nimport { entityKind } from './entity.ts';\nimport type { LibSQLDatabase } from './libsql/index.ts';\nimport type { MigrationConfig } from './migrator.ts';\nimport type { MySql2Database } from './mysql2/index.ts';\nimport type { NeonHttpDatabase } from './neon-http/index.ts';\nimport type { NeonDatabase } from './neon-serverless/index.ts';\nimport type { NodePgDatabase } from './node-postgres/index.ts';\nimport type { PlanetScaleDatabase } from './planetscale-serverless/index.ts';\nimport type { PostgresJsDatabase } from './postgres-js/index.ts';\nimport type { TiDBServerlessDatabase } from './tidb-serverless/index.ts';\nimport type { VercelPgDatabase } from './vercel-postgres/index.ts';\n\nexport async function migrate(\n\tdb:\n\t\t| AwsDataApiPgDatabase<any>\n\t\t| BetterSQLite3Database<any>\n\t\t| BunSQLiteDatabase<any>\n\t\t| DrizzleD1Database<any>\n\t\t| LibSQLDatabase<any>\n\t\t| MySql2Database<any>\n\t\t| NeonHttpDatabase<any>\n\t\t| NeonDatabase<any>\n\t\t| NodePgDatabase<any>\n\t\t| PlanetScaleDatabase<any>\n\t\t| PostgresJsDatabase<any>\n\t\t| VercelPgDatabase<any>\n\t\t| TiDBServerlessDatabase<any>,\n\tconfig:\n\t\t| string\n\t\t| MigrationConfig,\n) {\n\tswitch ((<any> db).constructor[entityKind]) {\n\t\tcase 'AwsDataApiPgDatabase': {\n\t\t\tconst { migrate } = await import('./aws-data-api/pg/migrator');\n\n\t\t\treturn migrate(db as AwsDataApiPgDatabase, config as string | MigrationConfig);\n\t\t}\n\t\tcase 'BetterSQLite3Database': {\n\t\t\tconst { migrate } = await import('./better-sqlite3/migrator');\n\n\t\t\treturn migrate(db as BetterSQLite3Database, config as string | MigrationConfig);\n\t\t}\n\t\tcase 'BunSQLiteDatabase': {\n\t\t\tconst { migrate } = await import('./bun-sqlite/migrator');\n\n\t\t\treturn migrate(db as BunSQLiteDatabase, config as string | MigrationConfig);\n\t\t}\n\t\tcase 'D1Database': {\n\t\t\tconst { migrate } = await import('./d1/migrator');\n\n\t\t\treturn migrate(db as DrizzleD1Database, config as string | MigrationConfig);\n\t\t}\n\t\tcase 'LibSQLDatabase': {\n\t\t\tconst { migrate } = await import('./libsql/migrator');\n\n\t\t\treturn migrate(db as LibSQLDatabase, config as string | MigrationConfig);\n\t\t}\n\t\tcase 'MySql2Database': {\n\t\t\tconst { migrate } = await import('./mysql2/migrator');\n\n\t\t\treturn migrate(db as MySql2Database, config as string | MigrationConfig);\n\t\t}\n\t\tcase 'NeonHttpDatabase': {\n\t\t\tconst { migrate } = await import('./neon-http/migrator');\n\n\t\t\treturn migrate(db as NeonHttpDatabase, config as string | MigrationConfig);\n\t\t}\n\t\tcase 'NeonServerlessDatabase': {\n\t\t\tconst { migrate } = await import('./neon-serverless/migrator');\n\n\t\t\treturn migrate(db as NeonDatabase, config as string | MigrationConfig);\n\t\t}\n\t\tcase 'NodePgDatabase': {\n\t\t\tconst { migrate } = await import('./node-postgres/migrator');\n\n\t\t\treturn migrate(db as NodePgDatabase, config as string | MigrationConfig);\n\t\t}\n\t\tcase 'PlanetScaleDatabase': {\n\t\t\tconst { migrate } = await import('./planetscale-serverless/migrator');\n\n\t\t\treturn migrate(db as PlanetScaleDatabase, config as string | MigrationConfig);\n\t\t}\n\t\tcase 'PostgresJsDatabase': {\n\t\t\tconst { migrate } = await import('./postgres-js/migrator');\n\n\t\t\treturn migrate(db as PostgresJsDatabase, config as string | MigrationConfig);\n\t\t}\n\t\tcase 'TiDBServerlessDatabase': {\n\t\t\tconst { migrate } = await import('./tidb-serverless/migrator');\n\n\t\t\treturn migrate(db as TiDBServerlessDatabase, config as MigrationConfig);\n\t\t}\n\t\tcase 'VercelPgDatabase': {\n\t\t\tconst { migrate } = await import('./vercel-postgres/migrator');\n\n\t\t\treturn migrate(db as VercelPgDatabase, config as string | MigrationConfig);\n\t\t}\n\t}\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAKA,oBAA2B;AAY3B,eAAsB,QACrB,IAcA,QAGC;AACD,UAAe,GAAI,YAAY,wBAAU,GAAG;AAAA,IAC3C,KAAK,wBAAwB;AAC5B,YAAM,EAAE,SAAAA,SAAQ,IAAI,MAAM,OAAO,4BAA4B;AAE7D,aAAOA,SAAQ,IAA4B,MAAkC;AAAA,IAC9E;AAAA,IACA,KAAK,yBAAyB;AAC7B,YAAM,EAAE,SAAAA,SAAQ,IAAI,MAAM,OAAO,2BAA2B;AAE5D,aAAOA,SAAQ,IAA6B,MAAkC;AAAA,IAC/E;AAAA,IACA,KAAK,qBAAqB;AACzB,YAAM,EAAE,SAAAA,SAAQ,IAAI,MAAM,OAAO,uBAAuB;AAExD,aAAOA,SAAQ,IAAyB,MAAkC;AAAA,IAC3E;AAAA,IACA,KAAK,cAAc;AAClB,YAAM,EAAE,SAAAA,SAAQ,IAAI,MAAM,OAAO,eAAe;AAEhD,aAAOA,SAAQ,IAAyB,MAAkC;AAAA,IAC3E;AAAA,IACA,KAAK,kBAAkB;AACtB,YAAM,EAAE,SAAAA,SAAQ,IAAI,MAAM,OAAO,mBAAmB;AAEpD,aAAOA,SAAQ,IAAsB,MAAkC;AAAA,IACxE;AAAA,IACA,KAAK,kBAAkB;AACtB,YAAM,EAAE,SAAAA,SAAQ,IAAI,MAAM,OAAO,mBAAmB;AAEpD,aAAOA,SAAQ,IAAsB,MAAkC;AAAA,IACxE;AAAA,IACA,KAAK,oBAAoB;AACxB,YAAM,EAAE,SAAAA,SAAQ,IAAI,MAAM,OAAO,sBAAsB;AAEvD,aAAOA,SAAQ,IAAwB,MAAkC;AAAA,IAC1E;AAAA,IACA,KAAK,0BAA0B;AAC9B,YAAM,EAAE,SAAAA,SAAQ,IAAI,MAAM,OAAO,4BAA4B;AAE7D,aAAOA,SAAQ,IAAoB,MAAkC;AAAA,IACtE;AAAA,IACA,KAAK,kBAAkB;AACtB,YAAM,EAAE,SAAAA,SAAQ,IAAI,MAAM,OAAO,0BAA0B;AAE3D,aAAOA,SAAQ,IAAsB,MAAkC;AAAA,IACxE;AAAA,IACA,KAAK,uBAAuB;AAC3B,YAAM,EAAE,SAAAA,SAAQ,IAAI,MAAM,OAAO,mCAAmC;AAEpE,aAAOA,SAAQ,IAA2B,MAAkC;AAAA,IAC7E;AAAA,IACA,KAAK,sBAAsB;AAC1B,YAAM,EAAE,SAAAA,SAAQ,IAAI,MAAM,OAAO,wBAAwB;AAEzD,aAAOA,SAAQ,IAA0B,MAAkC;AAAA,IAC5E;AAAA,IACA,KAAK,0BAA0B;AAC9B,YAAM,EAAE,SAAAA,SAAQ,IAAI,MAAM,OAAO,4BAA4B;AAE7D,aAAOA,SAAQ,IAA8B,MAAyB;AAAA,IACvE;AAAA,IACA,KAAK,oBAAoB;AACxB,YAAM,EAAE,SAAAA,SAAQ,IAAI,MAAM,OAAO,4BAA4B;AAE7D,aAAOA,SAAQ,IAAwB,MAAkC;AAAA,IAC1E;AAAA,EACD;AACD;","names":["migrate"]}
|