drizzle-orm 0.33.0-7bea25c → 0.33.0-86140ad

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.
Files changed (51) hide show
  1. package/monodriver.cjs +138 -34
  2. package/monodriver.cjs.map +1 -1
  3. package/monodriver.d.cts +53 -19
  4. package/monodriver.d.ts +53 -19
  5. package/monodriver.js +138 -34
  6. package/monodriver.js.map +1 -1
  7. package/package.json +3 -51
  8. package/pg-core/index.cjs +0 -4
  9. package/pg-core/index.cjs.map +1 -1
  10. package/pg-core/index.d.cts +0 -2
  11. package/pg-core/index.d.ts +0 -2
  12. package/pg-core/index.js +0 -2
  13. package/pg-core/index.js.map +1 -1
  14. package/pg-core/table.cjs.map +1 -1
  15. package/pg-core/table.d.cts +1 -2
  16. package/pg-core/table.d.ts +1 -2
  17. package/pg-core/table.js.map +1 -1
  18. package/pg-core/utils.cjs +2 -23
  19. package/pg-core/utils.cjs.map +1 -1
  20. package/pg-core/utils.d.cts +0 -2
  21. package/pg-core/utils.d.ts +0 -2
  22. package/pg-core/utils.js +2 -23
  23. package/pg-core/utils.js.map +1 -1
  24. package/version.cjs +1 -1
  25. package/version.d.cts +1 -1
  26. package/version.d.ts +1 -1
  27. package/version.js +1 -1
  28. package/neon/index.cjs +0 -23
  29. package/neon/index.cjs.map +0 -1
  30. package/neon/index.d.cts +0 -1
  31. package/neon/index.d.ts +0 -1
  32. package/neon/index.js +0 -2
  33. package/neon/index.js.map +0 -1
  34. package/neon/rls.cjs +0 -58
  35. package/neon/rls.cjs.map +0 -1
  36. package/neon/rls.d.cts +0 -13
  37. package/neon/rls.d.ts +0 -13
  38. package/neon/rls.js +0 -31
  39. package/neon/rls.js.map +0 -1
  40. package/pg-core/policies.cjs +0 -52
  41. package/pg-core/policies.cjs.map +0 -1
  42. package/pg-core/policies.d.cts +0 -22
  43. package/pg-core/policies.d.ts +0 -22
  44. package/pg-core/policies.js +0 -27
  45. package/pg-core/policies.js.map +0 -1
  46. package/pg-core/roles.cjs +0 -57
  47. package/pg-core/roles.cjs.map +0 -1
  48. package/pg-core/roles.d.cts +0 -13
  49. package/pg-core/roles.d.ts +0 -13
  50. package/pg-core/roles.js +0 -32
  51. package/pg-core/roles.js.map +0 -1
package/monodriver.d.ts CHANGED
@@ -3,14 +3,14 @@
3
3
  /// <reference types="bun-types" />
4
4
  import type { RDSDataClient, RDSDataClientConfig as RDSConfig } from '@aws-sdk/client-rds-data';
5
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';
6
+ import type { HTTPTransactionOptions as NeonHttpConfig, NeonQueryFunction, Pool as NeonServerlessPool, PoolConfig as NeonServerlessConfig, QueryResult, QueryResultRow } from '@neondatabase/serverless';
7
7
  import type { Client as PlanetscaleClient, Config as PlanetscaleConfig } from '@planetscale/database';
8
8
  import type { Config as TiDBServerlessConfig, Connection as TiDBConnection } from '@tidbcloud/serverless';
9
- import type { QueryResult, QueryResultRow, VercelPool } from '@vercel/postgres';
9
+ import type { VercelPool } from '@vercel/postgres';
10
10
  import type { Database as BetterSQLite3Database, Options as BetterSQLite3Options } from 'better-sqlite3';
11
11
  import type { Database as BunDatabase } from 'bun:sqlite';
12
12
  import type { Pool as Mysql2Pool, PoolOptions as Mysql2Config } from 'mysql2';
13
- import type { Pool as NodePgPool, PoolConfig as NodePGPoolConfig } from 'pg';
13
+ import type { Pool as NodePgPool, PoolConfig as NodePgPoolConfig } from 'pg';
14
14
  import type { Options as PostgresJSOptions, PostgresType as PostgresJSPostgresType, Sql as PostgresJsClient } from 'postgres';
15
15
  import type { AwsDataApiPgDatabase, DrizzleAwsDataApiPgConfig } from "./aws-data-api/pg/index.js";
16
16
  import type { BetterSQLite3Database as DrizzleBetterSQLite3Database } from "./better-sqlite3/index.js";
@@ -20,7 +20,7 @@ import type { LibSQLDatabase } from "./libsql/index.js";
20
20
  import type { MySql2Database, MySql2DrizzleConfig } from "./mysql2/index.js";
21
21
  import type { NeonHttpDatabase } from "./neon-http/index.js";
22
22
  import type { NeonDatabase } from "./neon-serverless/index.js";
23
- import type { NodePgDatabase } from "./node-postgres/index.js";
23
+ import type { NodePgDatabase } from "./node-postgres/driver.js";
24
24
  import type { PlanetScaleDatabase } from "./planetscale-serverless/index.js";
25
25
  import type { PostgresJsDatabase } from "./postgres-js/index.js";
26
26
  import type { TiDBServerlessDatabase } from "./tidb-serverless/index.js";
@@ -57,9 +57,8 @@ type BetterSQLite3DatabaseConfig = {
57
57
  type MonodriverNeonHttpConfig = {
58
58
  connectionString: string;
59
59
  options?: NeonHttpConfig<boolean, boolean>;
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
+ } | string;
61
+ type DatabaseClient = 'node-postgres' | 'postgres-js' | 'neon-serverless' | 'neon-http' | 'vercel-postgres' | 'aws-data-api-pg' | 'planetscale' | 'mysql2' | 'tidb-serverless' | 'libsql' | 'turso' | 'd1' | 'bun:sqlite' | 'better-sqlite3';
63
62
  type ClientDrizzleInstanceMap<TSchema extends Record<string, any>> = {
64
63
  'node-postgres': NodePgDatabase<TSchema>;
65
64
  'postgres-js': PostgresJsDatabase<TSchema>;
@@ -71,55 +70,59 @@ type ClientDrizzleInstanceMap<TSchema extends Record<string, any>> = {
71
70
  mysql2: MySql2Database<TSchema>;
72
71
  'tidb-serverless': TiDBServerlessDatabase<TSchema>;
73
72
  libsql: LibSQLDatabase<TSchema>;
73
+ turso: LibSQLDatabase<TSchema>;
74
74
  d1: DrizzleD1Database<TSchema>;
75
75
  'bun:sqlite': BunSQLiteDatabase<TSchema>;
76
76
  'better-sqlite3': DrizzleBetterSQLite3Database<TSchema>;
77
77
  };
78
+ type Primitive = string | number | boolean | undefined | null;
78
79
  type ClientInstanceMap = {
79
80
  'node-postgres': NodePgPool;
80
81
  'postgres-js': PostgresJsClient;
81
82
  'neon-serverless': NeonServerlessPool;
82
83
  'neon-http': NeonQueryFunction<boolean, boolean>;
83
- 'vercel-postgres': VercelPool & (<O extends QueryResultRow>(strings: TemplateStringsArray, ...values: VercelPrimitive[]) => Promise<QueryResult<O>>);
84
+ 'vercel-postgres': VercelPool & (<O extends QueryResultRow>(strings: TemplateStringsArray, ...values: Primitive[]) => Promise<QueryResult<O>>);
84
85
  'aws-data-api-pg': RDSDataClient;
85
86
  planetscale: PlanetscaleClient;
86
87
  mysql2: Mysql2Pool;
87
88
  'tidb-serverless': TiDBConnection;
88
89
  libsql: LibsqlClient;
90
+ turso: LibsqlClient;
89
91
  d1: D1Database;
90
92
  'bun:sqlite': BunDatabase;
91
93
  'better-sqlite3': BetterSQLite3Database;
92
94
  };
93
95
  type InitializerParams = {
94
96
  'node-postgres': {
95
- connection: NodePGPoolConfig;
97
+ connection?: string | NodePgPoolConfig;
96
98
  };
97
99
  'postgres-js': {
98
100
  connection: string | PostgresJSOptions<Record<string, PostgresJSPostgresType>>;
99
101
  };
100
102
  'neon-serverless': {
101
- connection: NeonServerlessConfig;
103
+ connection?: string | NeonServerlessConfig;
102
104
  };
103
105
  'neon-http': {
104
106
  connection: MonodriverNeonHttpConfig;
105
107
  };
106
- 'vercel-postgres': {
107
- connection: VercelPool;
108
- };
108
+ 'vercel-postgres': {};
109
109
  'aws-data-api-pg': {
110
110
  connection?: RDSConfig;
111
111
  };
112
112
  planetscale: {
113
- connection: PlanetscaleConfig;
113
+ connection: PlanetscaleConfig | string;
114
114
  };
115
115
  mysql2: {
116
116
  connection: Mysql2Config | string;
117
117
  };
118
118
  'tidb-serverless': {
119
- connection: TiDBServerlessConfig;
119
+ connection: TiDBServerlessConfig | string;
120
120
  };
121
121
  libsql: {
122
- connection: LibsqlConfig;
122
+ connection: LibsqlConfig | string;
123
+ };
124
+ turso: {
125
+ connection: LibsqlConfig | string;
123
126
  };
124
127
  d1: {
125
128
  connection: D1Database;
@@ -134,7 +137,38 @@ type InitializerParams = {
134
137
  type DetermineClient<TClient extends DatabaseClient, TSchema extends Record<string, unknown>> = ClientDrizzleInstanceMap<TSchema>[TClient] & {
135
138
  $client: ClientInstanceMap[TClient];
136
139
  };
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> : TClient extends 'neon-serverless' ? DrizzleConfig<TSchema> & {
138
- ws?: any;
139
- } : DrizzleConfig<TSchema>)): Promise<DetermineClient<TClient, TSchema>>;
140
+ export declare function drizzle<TClient extends DatabaseClient, TSchema extends Record<string, unknown> = Record<string, never>>(client: TClient, ...params: TClient extends 'bun:sqlite' | 'better-sqlite3' ? ([
141
+ ] | [
142
+ (InitializerParams[TClient] & DrizzleConfig<TSchema>)
143
+ ] | [
144
+ ':memory:'
145
+ ] | [
146
+ (string & {})
147
+ ]) : TClient extends 'vercel-postgres' ? ([] | [
148
+ (InitializerParams[TClient] & DrizzleConfig<TSchema>)
149
+ ]) : TClient extends 'node-postgres' ? ([
150
+ (InitializerParams[TClient] & DrizzleConfig<TSchema>)
151
+ ] | [
152
+ string
153
+ ]) : TClient extends 'postgres-js' | 'tidb-serverless' | 'libsql' | 'turso' | 'planetscale' ? ([
154
+ (InitializerParams[TClient] & DrizzleConfig<TSchema>)
155
+ ] | [
156
+ string
157
+ ]) : TClient extends 'mysql2' ? ([
158
+ (InitializerParams[TClient] & MySql2DrizzleConfig<TSchema>)
159
+ ] | [
160
+ string
161
+ ]) : TClient extends 'aws-data-api-pg' ? [
162
+ InitializerParams[TClient] & DrizzleAwsDataApiPgConfig<TSchema>
163
+ ] : TClient extends 'neon-serverless' ? ([
164
+ InitializerParams[TClient] & DrizzleConfig<TSchema> & {
165
+ ws?: any;
166
+ }
167
+ ] | [string] | []) : TClient extends 'neon-http' ? ([
168
+ InitializerParams[TClient] & DrizzleConfig<TSchema>
169
+ ] | [
170
+ string
171
+ ]) : [
172
+ (InitializerParams[TClient] & DrizzleConfig<TSchema>)
173
+ ]): Promise<DetermineClient<TClient, TSchema>>;
140
174
  export {};
package/monodriver.js CHANGED
@@ -6,23 +6,34 @@ const importError = (libName) => {
6
6
  function assertUnreachable(_) {
7
7
  throw new Error("Didn't expect to get here");
8
8
  }
9
- async function drizzle(client, params) {
10
- const { connection, ws, ...drizzleConfig } = params;
9
+ async function drizzle(client, ...params) {
11
10
  switch (client) {
12
11
  case "node-postgres": {
13
- const { Pool } = await import("pg").catch(() => importError("pg"));
12
+ const defpg = await import("pg");
14
13
  const { drizzle: drizzle2 } = await import("./node-postgres");
15
- const instance = new Pool(connection);
16
- const db = drizzle2(instance, drizzleConfig);
14
+ if (typeof params[0] === "object") {
15
+ const { connection, ...drizzleConfig } = params[0];
16
+ const instance2 = typeof connection === "string" ? new defpg.default.Pool({
17
+ connectionString: connection
18
+ }) : new defpg.default.Pool(connection);
19
+ const db2 = drizzle2(instance2, drizzleConfig);
20
+ db2.$client = instance2;
21
+ return db2;
22
+ }
23
+ const instance = typeof params[0] === "string" ? new defpg.default.Pool({
24
+ connectionString: params[0]
25
+ }) : new defpg.default.Pool(params[0]);
26
+ const db = drizzle2(instance);
17
27
  db.$client = instance;
18
28
  return db;
19
29
  }
20
30
  case "aws-data-api-pg": {
31
+ const { connection, ...drizzleConfig } = params[0];
21
32
  const { RDSDataClient } = await import("@aws-sdk/client-rds-data").catch(
22
33
  () => importError("@aws-sdk/client-rds-data")
23
34
  );
24
35
  const { drizzle: drizzle2 } = await import("./aws-data-api/pg");
25
- const instance = new RDSDataClient(connection);
36
+ const instance = connection ? new RDSDataClient(connection) : new RDSDataClient();
26
37
  const db = drizzle2(instance, drizzleConfig);
27
38
  db.$client = instance;
28
39
  return db;
@@ -30,61 +41,107 @@ async function drizzle(client, params) {
30
41
  case "better-sqlite3": {
31
42
  const { default: Client } = await import("better-sqlite3").catch(() => importError("better-sqlite3"));
32
43
  const { drizzle: drizzle2 } = await import("./better-sqlite3");
33
- if (typeof connection === "object") {
34
- const { filename, options } = connection;
35
- const instance2 = new Client(filename, options);
44
+ if (typeof params[0] === "object") {
45
+ const { connection, ...drizzleConfig } = params[0];
46
+ if (typeof connection === "object") {
47
+ const { filename, options } = connection;
48
+ const instance3 = new Client(filename, options);
49
+ const db3 = drizzle2(instance3, drizzleConfig);
50
+ db3.$client = instance3;
51
+ return db3;
52
+ }
53
+ const instance2 = new Client(connection);
36
54
  const db2 = drizzle2(instance2, drizzleConfig);
37
55
  db2.$client = instance2;
38
56
  return db2;
39
57
  }
40
- const instance = new Client(connection);
41
- const db = drizzle2(instance, drizzleConfig);
58
+ const instance = new Client(params[0]);
59
+ const db = drizzle2(instance);
42
60
  db.$client = instance;
43
61
  return db;
44
62
  }
45
63
  case "bun:sqlite": {
46
64
  const { Database: Client } = await import("bun:sqlite").catch(() => importError("bun:sqlite"));
47
65
  const { drizzle: drizzle2 } = await import("./bun-sqlite");
48
- if (typeof connection === "object") {
49
- const { filename, options } = connection;
50
- const instance2 = new Client(filename, options);
66
+ if (typeof params[0] === "object") {
67
+ const { connection, ...drizzleConfig } = params[0];
68
+ if (typeof connection === "object") {
69
+ const { filename, options } = connection;
70
+ const instance3 = new Client(filename, options);
71
+ const db3 = drizzle2(instance3, drizzleConfig);
72
+ db3.$client = instance3;
73
+ return db3;
74
+ }
75
+ const instance2 = new Client(connection);
51
76
  const db2 = drizzle2(instance2, drizzleConfig);
52
77
  db2.$client = instance2;
53
78
  return db2;
54
79
  }
55
- const instance = new Client(connection);
56
- const db = drizzle2(instance, drizzleConfig);
80
+ const instance = new Client(params[0]);
81
+ const db = drizzle2(instance);
57
82
  db.$client = instance;
58
83
  return db;
59
84
  }
60
85
  case "d1": {
86
+ const { connection, ...drizzleConfig } = params[0];
61
87
  const { drizzle: drizzle2 } = await import("./d1");
62
88
  const db = drizzle2(connection, drizzleConfig);
63
89
  db.$client = connection;
64
90
  return db;
65
91
  }
66
- case "libsql": {
92
+ case "libsql":
93
+ case "turso": {
67
94
  const { createClient } = await import("@libsql/client").catch(() => importError("@libsql/client"));
68
95
  const { drizzle: drizzle2 } = await import("./libsql");
69
- const instance = createClient(connection);
96
+ if (typeof params[0] === "string") {
97
+ const instance2 = createClient({
98
+ url: params[0]
99
+ });
100
+ const db2 = drizzle2(instance2);
101
+ db2.$client = instance2;
102
+ return db2;
103
+ }
104
+ const { connection, ...drizzleConfig } = params[0];
105
+ const instance = typeof connection === "string" ? createClient({ url: connection }) : createClient(connection);
70
106
  const db = drizzle2(instance, drizzleConfig);
71
107
  db.$client = instance;
72
108
  return db;
73
109
  }
74
110
  case "mysql2": {
75
111
  const { createPool } = await import("mysql2/promise").catch(() => importError("mysql2/promise"));
76
- const instance = createPool(connection);
77
112
  const { drizzle: drizzle2 } = await import("./mysql2");
78
- const db = drizzle2(instance, drizzleConfig);
113
+ if (typeof params[0] === "object") {
114
+ const { connection, ...drizzleConfig } = params[0];
115
+ const instance2 = createPool(connection);
116
+ const db2 = drizzle2(instance2, drizzleConfig);
117
+ db2.$client = instance2;
118
+ return db2;
119
+ }
120
+ const connectionString = params[0];
121
+ const instance = createPool(connectionString);
122
+ const db = drizzle2(instance);
79
123
  db.$client = instance;
80
124
  return db;
81
125
  }
82
126
  case "neon-http": {
83
127
  const { neon } = await import("@neondatabase/serverless").catch(() => importError("@neondatabase/serverless"));
84
- const { connectionString, options } = connection;
85
128
  const { drizzle: drizzle2 } = await import("./neon-http");
86
- const instance = neon(connectionString, options);
87
- const db = drizzle2(instance, drizzleConfig);
129
+ if (typeof params[0] === "object") {
130
+ const { connection, ...drizzleConfig } = params[0];
131
+ if (typeof connection === "object") {
132
+ const { connectionString, options } = connection;
133
+ const instance3 = neon(connectionString, options);
134
+ const db3 = drizzle2(instance3, drizzleConfig);
135
+ db3.$client = instance3;
136
+ return db3;
137
+ }
138
+ const instance2 = neon(connection);
139
+ const db2 = drizzle2(instance2, drizzleConfig);
140
+ db2.$client = instance2;
141
+ return db2;
142
+ }
143
+ const instance = neon(params[0]);
144
+ const db = drizzle2(instance);
88
145
  db.$client = instance;
89
146
  return db;
90
147
  }
@@ -93,41 +150,88 @@ async function drizzle(client, params) {
93
150
  () => importError("@neondatabase/serverless")
94
151
  );
95
152
  const { drizzle: drizzle2 } = await import("./neon-serverless");
96
- const instance = new Pool(connection);
97
- if (ws) {
98
- neonConfig.webSocketConstructor = ws;
153
+ if (typeof params[0] === "string") {
154
+ const instance2 = new Pool({
155
+ connectionString: params[0]
156
+ });
157
+ const db2 = drizzle2(instance2);
158
+ db2.$client = instance2;
159
+ return db2;
99
160
  }
100
- const db = drizzle2(instance, drizzleConfig);
161
+ if (typeof params[0] === "object") {
162
+ const { connection, ws, ...drizzleConfig } = params[0];
163
+ if (ws) {
164
+ neonConfig.webSocketConstructor = ws;
165
+ }
166
+ const instance2 = typeof connection === "string" ? new Pool({
167
+ connectionString: connection
168
+ }) : new Pool(connection);
169
+ const db2 = drizzle2(instance2, drizzleConfig);
170
+ db2.$client = instance2;
171
+ return db2;
172
+ }
173
+ const instance = new Pool();
174
+ const db = drizzle2(instance);
101
175
  db.$client = instance;
102
176
  return db;
103
177
  }
104
178
  case "planetscale": {
105
179
  const { Client } = await import("@planetscale/database").catch(() => importError("@planetscale/database"));
106
180
  const { drizzle: drizzle2 } = await import("./planetscale-serverless");
107
- const instance = new Client(
108
- connection
109
- );
110
- const db = drizzle2(instance, drizzleConfig);
181
+ if (typeof params[0] === "object") {
182
+ const { connection, ...drizzleConfig } = params[0];
183
+ const instance2 = typeof connection === "string" ? new Client({
184
+ url: connection
185
+ }) : new Client(
186
+ connection
187
+ );
188
+ const db2 = drizzle2(instance2, drizzleConfig);
189
+ db2.$client = instance2;
190
+ return db2;
191
+ }
192
+ const instance = new Client({
193
+ url: params[0]
194
+ });
195
+ const db = drizzle2(instance);
111
196
  db.$client = instance;
112
197
  return db;
113
198
  }
114
199
  case "postgres-js": {
115
200
  const { default: client2 } = await import("postgres").catch(() => importError("postgres"));
116
201
  const { drizzle: drizzle2 } = await import("./postgres-js");
117
- const instance = client2(connection);
118
- const db = drizzle2(instance, drizzleConfig);
202
+ if (typeof params[0] === "object") {
203
+ const { connection, ...drizzleConfig } = params[0];
204
+ const instance2 = client2(connection);
205
+ const db2 = drizzle2(instance2, drizzleConfig);
206
+ db2.$client = instance2;
207
+ return db2;
208
+ }
209
+ const instance = client2(params[0]);
210
+ const db = drizzle2(instance);
119
211
  db.$client = instance;
120
212
  return db;
121
213
  }
122
214
  case "tidb-serverless": {
123
215
  const { connect } = await import("@tidbcloud/serverless").catch(() => importError("@tidbcloud/serverless"));
124
216
  const { drizzle: drizzle2 } = await import("./tidb-serverless");
125
- const instance = connect(connection);
217
+ if (typeof params[0] === "string") {
218
+ const instance2 = connect({
219
+ url: params[0]
220
+ });
221
+ const db2 = drizzle2(instance2);
222
+ db2.$client = instance2;
223
+ return db2;
224
+ }
225
+ const { connection, ...drizzleConfig } = params[0];
226
+ const instance = typeof connection === "string" ? connect({
227
+ url: connection
228
+ }) : connect(connection);
126
229
  const db = drizzle2(instance, drizzleConfig);
127
230
  db.$client = instance;
128
231
  return db;
129
232
  }
130
233
  case "vercel-postgres": {
234
+ const drizzleConfig = params[0];
131
235
  const { sql } = await import("@vercel/postgres").catch(() => importError("@vercel/postgres"));
132
236
  const { drizzle: drizzle2 } = await import("./vercel-postgres");
133
237
  const db = drizzle2(sql, drizzleConfig);
package/monodriver.js.map CHANGED
@@ -1 +1 @@
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: TClient extends 'neon-serverless' ? DrizzleConfig<TSchema> & {\n\t\t\t\t\tws?: any;\n\t\t\t\t}\n\t\t\t: DrizzleConfig<TSchema>),\n): Promise<DetermineClient<TClient, TSchema>> {\n\tconst { connection, ws, ...drizzleConfig } = params as typeof params & {\n\t\tws?: any;\n\t};\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, neonConfig } = await import('@neondatabase/serverless').catch(() =>\n\t\t\t\timportError('@neondatabase/serverless')\n\t\t\t);\n\t\t\tconst { drizzle } = await import('./neon-serverless');\n\t\t\tconst instance = new Pool(connection as NeonServerlessConfig);\n\n\t\t\tif (ws) {\n\t\t\t\tneonConfig.webSocketConstructor = ws;\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 '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"]}
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\tQueryResult,\n\tQueryResultRow,\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 { 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/driver.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} | string;\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| 'turso'\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\tturso: LibSQLDatabase<TSchema>;\n\td1: DrizzleD1Database<TSchema>;\n\t'bun:sqlite': BunSQLiteDatabase<TSchema>;\n\t'better-sqlite3': DrizzleBetterSQLite3Database<TSchema>;\n};\n\ntype Primitive = string | number | boolean | undefined | null;\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>(strings: TemplateStringsArray, ...values: Primitive[]) => 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\tturso: 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?: string | NodePgPoolConfig;\n\t};\n\t'postgres-js': {\n\t\tconnection: string | PostgresJSOptions<Record<string, PostgresJSPostgresType>>;\n\t};\n\t'neon-serverless': {\n\t\tconnection?: string | NeonServerlessConfig;\n\t};\n\t'neon-http': {\n\t\tconnection: MonodriverNeonHttpConfig;\n\t};\n\t'vercel-postgres': {};\n\t'aws-data-api-pg': {\n\t\tconnection?: RDSConfig;\n\t};\n\tplanetscale: {\n\t\tconnection: PlanetscaleConfig | string;\n\t};\n\tmysql2: {\n\t\tconnection: Mysql2Config | string;\n\t};\n\t'tidb-serverless': {\n\t\tconnection: TiDBServerlessConfig | string;\n\t};\n\tlibsql: {\n\t\tconnection: LibsqlConfig | string;\n\t};\n\tturso: {\n\t\tconnection: LibsqlConfig | string;\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\t...params: TClient extends 'bun:sqlite' | 'better-sqlite3' ? (\n\t\t\t[] | [\n\t\t\t\t(\n\t\t\t\t\t& InitializerParams[TClient]\n\t\t\t\t\t& DrizzleConfig<TSchema>\n\t\t\t\t),\n\t\t\t] | [\n\t\t\t\t':memory:',\n\t\t\t] | [\n\t\t\t\t(string & {}),\n\t\t\t]\n\t\t)\n\t\t: TClient extends 'vercel-postgres' ? ([] | [\n\t\t\t\t(\n\t\t\t\t\t& InitializerParams[TClient]\n\t\t\t\t\t& DrizzleConfig<TSchema>\n\t\t\t\t),\n\t\t\t])\n\t\t: TClient extends 'node-postgres' ? (\n\t\t\t\t[\n\t\t\t\t\t(\n\t\t\t\t\t\t& InitializerParams[TClient]\n\t\t\t\t\t\t& DrizzleConfig<TSchema>\n\t\t\t\t\t),\n\t\t\t\t] | [\n\t\t\t\t\tstring,\n\t\t\t\t]\n\t\t\t)\n\t\t: TClient extends 'postgres-js' | 'tidb-serverless' | 'libsql' | 'turso' | 'planetscale' ? (\n\t\t\t\t[\n\t\t\t\t\t(\n\t\t\t\t\t\t& InitializerParams[TClient]\n\t\t\t\t\t\t& DrizzleConfig<TSchema>\n\t\t\t\t\t),\n\t\t\t\t] | [\n\t\t\t\t\tstring,\n\t\t\t\t]\n\t\t\t)\n\t\t: TClient extends 'mysql2' ? (\n\t\t\t\t[\n\t\t\t\t\t(\n\t\t\t\t\t\t& InitializerParams[TClient]\n\t\t\t\t\t\t& MySql2DrizzleConfig<TSchema>\n\t\t\t\t\t),\n\t\t\t\t] | [\n\t\t\t\t\tstring,\n\t\t\t\t]\n\t\t\t)\n\t\t: TClient extends 'aws-data-api-pg' ? [\n\t\t\t\tInitializerParams[TClient] & DrizzleAwsDataApiPgConfig<TSchema>,\n\t\t\t]\n\t\t: TClient extends 'neon-serverless' ? (\n\t\t\t\t| [\n\t\t\t\t\tInitializerParams[TClient] & DrizzleConfig<TSchema> & {\n\t\t\t\t\t\tws?: any;\n\t\t\t\t\t},\n\t\t\t\t]\n\t\t\t\t| [string]\n\t\t\t\t| []\n\t\t\t)\n\t\t: TClient extends 'neon-http' ? ([\n\t\t\t\tInitializerParams[TClient] & DrizzleConfig<TSchema>,\n\t\t\t] | [\n\t\t\t\tstring,\n\t\t\t])\n\t\t: [\n\t\t\t(\n\t\t\t\t& InitializerParams[TClient]\n\t\t\t\t& DrizzleConfig<TSchema>\n\t\t\t),\n\t\t]\n): Promise<DetermineClient<TClient, TSchema>> {\n\tswitch (client) {\n\t\tcase 'node-postgres': {\n\t\t\tconst defpg = await import('pg');\n\t\t\tconst { drizzle } = await import('./node-postgres');\n\n\t\t\tif (typeof params[0] === 'object') {\n\t\t\t\tconst { connection, ...drizzleConfig } = params[0] as\n\t\t\t\t\t& { connection: NodePgPoolConfig | string }\n\t\t\t\t\t& DrizzleConfig;\n\n\t\t\t\tconst instance = typeof connection === 'string'\n\t\t\t\t\t? new defpg.default.Pool({\n\t\t\t\t\t\tconnectionString: connection,\n\t\t\t\t\t})\n\t\t\t\t\t: new defpg.default.Pool(connection);\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 = typeof params[0] === 'string'\n\t\t\t\t? new defpg.default.Pool({\n\t\t\t\t\tconnectionString: params[0],\n\t\t\t\t})\n\t\t\t\t: new defpg.default.Pool(params[0]);\n\t\t\tconst db = drizzle(instance) 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 { connection, ...drizzleConfig } = params[0] as\n\t\t\t\t& { connection: RDSDataClientConfig | undefined }\n\t\t\t\t& DrizzleAwsDataApiPgConfig;\n\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\n\t\t\tconst instance = connection ? new RDSDataClient(connection) : new RDSDataClient();\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 '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 params[0] === 'object') {\n\t\t\t\tconst { connection, ...drizzleConfig } = params[0] as {\n\t\t\t\t\tconnection: BetterSQLite3DatabaseConfig;\n\t\t\t\t} & DrizzleConfig;\n\n\t\t\t\tif (typeof connection === 'object') {\n\t\t\t\t\tconst { filename, options } = connection;\n\n\t\t\t\t\tconst instance = new Client(filename, options);\n\t\t\t\t\tconst db = drizzle(instance, drizzleConfig) as any;\n\t\t\t\t\tdb.$client = instance;\n\n\t\t\t\t\treturn db;\n\t\t\t\t}\n\n\t\t\t\tconst instance = new Client(connection);\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(params[0]);\n\t\t\tconst db = drizzle(instance) 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 params[0] === 'object') {\n\t\t\t\tconst { connection, ...drizzleConfig } = params[0] as {\n\t\t\t\t\tconnection: BunSqliteDatabaseConfig | string | undefined;\n\t\t\t\t} & DrizzleConfig;\n\n\t\t\t\tif (typeof connection === 'object') {\n\t\t\t\t\tconst { filename, options } = connection;\n\n\t\t\t\t\tconst instance = new Client(filename, options);\n\t\t\t\t\tconst db = drizzle(instance, drizzleConfig) as any;\n\t\t\t\t\tdb.$client = instance;\n\n\t\t\t\t\treturn db;\n\t\t\t\t}\n\n\t\t\t\tconst instance = new Client(connection);\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(params[0]);\n\t\t\tconst db = drizzle(instance) 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 { connection, ...drizzleConfig } = params[0] as { connection: D1Database } & DrizzleConfig;\n\n\t\t\tconst { drizzle } = await import('./d1');\n\n\t\t\tconst db = drizzle(connection, drizzleConfig) as any;\n\t\t\tdb.$client = connection;\n\n\t\t\treturn db;\n\t\t}\n\t\tcase 'libsql':\n\t\tcase 'turso': {\n\t\t\tconst { createClient } = await import('@libsql/client').catch(() => importError('@libsql/client'));\n\t\t\tconst { drizzle } = await import('./libsql');\n\n\t\t\tif (typeof params[0] === 'string') {\n\t\t\t\tconst instance = createClient({\n\t\t\t\t\turl: params[0],\n\t\t\t\t});\n\t\t\t\tconst db = drizzle(instance) 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 { connection, ...drizzleConfig } = params[0] as any as { connection: LibsqlConfig } & DrizzleConfig;\n\n\t\t\tconst instance = typeof connection === 'string' ? createClient({ url: connection }) : createClient(connection);\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 { drizzle } = await import('./mysql2');\n\n\t\t\tif (typeof params[0] === 'object') {\n\t\t\t\tconst { connection, ...drizzleConfig } = params[0] as\n\t\t\t\t\t& { connection: Mysql2Config | string }\n\t\t\t\t\t& MySql2DrizzleConfig;\n\n\t\t\t\tconst instance = createPool(connection as Mysql2Config);\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 connectionString = params[0]!;\n\t\t\tconst instance = createPool(connectionString);\n\n\t\t\tconst db = drizzle(instance) 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 { drizzle } = await import('./neon-http');\n\n\t\t\tif (typeof params[0] === 'object') {\n\t\t\t\tconst { connection, ...drizzleConfig } = params[0] as { connection: MonodriverNeonHttpConfig } & DrizzleConfig;\n\n\t\t\t\tif (typeof connection === 'object') {\n\t\t\t\t\tconst { connectionString, options } = connection;\n\n\t\t\t\t\tconst instance = neon(connectionString, options);\n\t\t\t\t\tconst db = drizzle(instance, drizzleConfig) as any;\n\t\t\t\t\tdb.$client = instance;\n\n\t\t\t\t\treturn db;\n\t\t\t\t}\n\n\t\t\t\tconst instance = neon(connection);\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 = neon(params[0]!);\n\t\t\tconst db = drizzle(instance) 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, neonConfig } = await import('@neondatabase/serverless').catch(() =>\n\t\t\t\timportError('@neondatabase/serverless')\n\t\t\t);\n\t\t\tconst { drizzle } = await import('./neon-serverless');\n\t\t\tif (typeof params[0] === 'string') {\n\t\t\t\tconst instance = new Pool({\n\t\t\t\t\tconnectionString: params[0],\n\t\t\t\t});\n\n\t\t\t\tconst db = drizzle(instance) as any;\n\t\t\t\tdb.$client = instance;\n\n\t\t\t\treturn db;\n\t\t\t}\n\n\t\t\tif (typeof params[0] === 'object') {\n\t\t\t\tconst { connection, ws, ...drizzleConfig } = params[0] as {\n\t\t\t\t\tconnection?: NeonServerlessConfig | string;\n\t\t\t\t\tws?: any;\n\t\t\t\t} & DrizzleConfig;\n\n\t\t\t\tif (ws) {\n\t\t\t\t\tneonConfig.webSocketConstructor = ws;\n\t\t\t\t}\n\n\t\t\t\tconst instance = typeof connection === 'string'\n\t\t\t\t\t? new Pool({\n\t\t\t\t\t\tconnectionString: connection,\n\t\t\t\t\t})\n\t\t\t\t\t: new Pool(connection);\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 Pool();\n\t\t\tconst db = drizzle(instance) 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\n\t\t\tif (typeof params[0] === 'object') {\n\t\t\t\tconst { connection, ...drizzleConfig } = params[0] as\n\t\t\t\t\t& { connection: PlanetscaleConfig | string }\n\t\t\t\t\t& DrizzleConfig;\n\n\t\t\t\tconst instance = typeof connection === 'string'\n\t\t\t\t\t? new Client({\n\t\t\t\t\t\turl: connection,\n\t\t\t\t\t})\n\t\t\t\t\t: new Client(\n\t\t\t\t\t\tconnection,\n\t\t\t\t\t);\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({\n\t\t\t\turl: params[0],\n\t\t\t});\n\t\t\tconst db = drizzle(instance) 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\n\t\t\tif (typeof params[0] === 'object') {\n\t\t\t\tconst { connection, ...drizzleConfig } = params[0] as {\n\t\t\t\t\tconnection: PostgresJSOptions<Record<string, PostgresJSPostgresType>>;\n\t\t\t\t} & DrizzleConfig;\n\n\t\t\t\tconst instance = client(connection);\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 = client(params[0]!);\n\t\t\tconst db = drizzle(instance) 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\n\t\t\tif (typeof params[0] === 'string') {\n\t\t\t\tconst instance = connect({\n\t\t\t\t\turl: params[0],\n\t\t\t\t});\n\t\t\t\tconst db = drizzle(instance) 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 { connection, ...drizzleConfig } = params[0] as\n\t\t\t\t& { connection: TiDBServerlessConfig | string }\n\t\t\t\t& DrizzleConfig;\n\n\t\t\tconst instance = typeof connection === 'string'\n\t\t\t\t? connect({\n\t\t\t\t\turl: connection,\n\t\t\t\t})\n\t\t\t\t: connect(connection);\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 drizzleConfig = params[0] as DrizzleConfig | undefined;\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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "drizzle-orm",
3
- "version": "0.33.0-7bea25c",
3
+ "version": "0.33.0-86140ad",
4
4
  "description": "Drizzle ORM package for SQL databases",
5
5
  "type": "module",
6
6
  "scripts": {
@@ -45,7 +45,7 @@
45
45
  "peerDependencies": {
46
46
  "@aws-sdk/client-rds-data": ">=3",
47
47
  "@cloudflare/workers-types": ">=3",
48
- "@electric-sql/pglite": ">=0.2.0",
48
+ "@electric-sql/pglite": ">=0.1.1",
49
49
  "@libsql/client": ">=0.10.0",
50
50
  "@neondatabase/serverless": ">=0.1",
51
51
  "@op-engineering/op-sqlite": ">=2",
@@ -160,7 +160,7 @@
160
160
  "devDependencies": {
161
161
  "@aws-sdk/client-rds-data": "^3.549.0",
162
162
  "@cloudflare/workers-types": "^4.20230904.0",
163
- "@electric-sql/pglite": "^0.2.5",
163
+ "@electric-sql/pglite": "^0.1.1",
164
164
  "@libsql/client": "^0.10.0",
165
165
  "@neondatabase/serverless": "^0.9.0",
166
166
  "@op-engineering/op-sqlite": "^2.0.16",
@@ -1097,30 +1097,6 @@
1097
1097
  "types": "./mysql2/session.d.ts",
1098
1098
  "default": "./mysql2/session.js"
1099
1099
  },
1100
- "./neon": {
1101
- "import": {
1102
- "types": "./neon/index.d.ts",
1103
- "default": "./neon/index.js"
1104
- },
1105
- "require": {
1106
- "types": "./neon/index.d.cts",
1107
- "default": "./neon/index.cjs"
1108
- },
1109
- "types": "./neon/index.d.ts",
1110
- "default": "./neon/index.js"
1111
- },
1112
- "./neon/rls": {
1113
- "import": {
1114
- "types": "./neon/rls.d.ts",
1115
- "default": "./neon/rls.js"
1116
- },
1117
- "require": {
1118
- "types": "./neon/rls.d.cts",
1119
- "default": "./neon/rls.cjs"
1120
- },
1121
- "types": "./neon/rls.d.ts",
1122
- "default": "./neon/rls.js"
1123
- },
1124
1100
  "./neon-http/driver": {
1125
1101
  "import": {
1126
1102
  "types": "./neon-http/driver.d.ts",
@@ -1409,18 +1385,6 @@
1409
1385
  "types": "./pg-core/indexes.d.ts",
1410
1386
  "default": "./pg-core/indexes.js"
1411
1387
  },
1412
- "./pg-core/policies": {
1413
- "import": {
1414
- "types": "./pg-core/policies.d.ts",
1415
- "default": "./pg-core/policies.js"
1416
- },
1417
- "require": {
1418
- "types": "./pg-core/policies.d.cts",
1419
- "default": "./pg-core/policies.cjs"
1420
- },
1421
- "types": "./pg-core/policies.d.ts",
1422
- "default": "./pg-core/policies.js"
1423
- },
1424
1388
  "./pg-core/primary-keys": {
1425
1389
  "import": {
1426
1390
  "types": "./pg-core/primary-keys.d.ts",
@@ -1433,18 +1397,6 @@
1433
1397
  "types": "./pg-core/primary-keys.d.ts",
1434
1398
  "default": "./pg-core/primary-keys.js"
1435
1399
  },
1436
- "./pg-core/roles": {
1437
- "import": {
1438
- "types": "./pg-core/roles.d.ts",
1439
- "default": "./pg-core/roles.js"
1440
- },
1441
- "require": {
1442
- "types": "./pg-core/roles.d.cts",
1443
- "default": "./pg-core/roles.cjs"
1444
- },
1445
- "types": "./pg-core/roles.d.ts",
1446
- "default": "./pg-core/roles.js"
1447
- },
1448
1400
  "./pg-core/schema": {
1449
1401
  "import": {
1450
1402
  "types": "./pg-core/schema.d.ts",
package/pg-core/index.cjs CHANGED
@@ -22,10 +22,8 @@ __reExport(pg_core_exports, require("./db.cjs"), module.exports);
22
22
  __reExport(pg_core_exports, require("./dialect.cjs"), module.exports);
23
23
  __reExport(pg_core_exports, require("./foreign-keys.cjs"), module.exports);
24
24
  __reExport(pg_core_exports, require("./indexes.cjs"), module.exports);
25
- __reExport(pg_core_exports, require("./policies.cjs"), module.exports);
26
25
  __reExport(pg_core_exports, require("./primary-keys.cjs"), module.exports);
27
26
  __reExport(pg_core_exports, require("./query-builders/index.cjs"), module.exports);
28
- __reExport(pg_core_exports, require("./roles.cjs"), module.exports);
29
27
  __reExport(pg_core_exports, require("./schema.cjs"), module.exports);
30
28
  __reExport(pg_core_exports, require("./sequence.cjs"), module.exports);
31
29
  __reExport(pg_core_exports, require("./session.cjs"), module.exports);
@@ -45,10 +43,8 @@ __reExport(pg_core_exports, require("./view.cjs"), module.exports);
45
43
  ...require("./dialect.cjs"),
46
44
  ...require("./foreign-keys.cjs"),
47
45
  ...require("./indexes.cjs"),
48
- ...require("./policies.cjs"),
49
46
  ...require("./primary-keys.cjs"),
50
47
  ...require("./query-builders/index.cjs"),
51
- ...require("./roles.cjs"),
52
48
  ...require("./schema.cjs"),
53
49
  ...require("./sequence.cjs"),
54
50
  ...require("./session.cjs"),