@event-driven-io/pongo 0.17.0-beta.35 → 0.17.0-beta.36

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 (61) hide show
  1. package/dist/cli.cjs +311 -494
  2. package/dist/cli.cjs.map +1 -1
  3. package/dist/cli.d.cts +4 -4
  4. package/dist/cli.d.ts +4 -3
  5. package/dist/cli.js +279 -494
  6. package/dist/cli.js.map +1 -1
  7. package/dist/cloudflare.cjs +36 -48
  8. package/dist/cloudflare.cjs.map +1 -1
  9. package/dist/cloudflare.d.cts +7 -7
  10. package/dist/cloudflare.d.ts +7 -7
  11. package/dist/cloudflare.js +29 -47
  12. package/dist/cloudflare.js.map +1 -1
  13. package/dist/core-CwxxuUAn.cjs +1590 -0
  14. package/dist/core-CwxxuUAn.cjs.map +1 -0
  15. package/dist/core-D_iZiiYe.js +1308 -0
  16. package/dist/core-D_iZiiYe.js.map +1 -0
  17. package/dist/core-DwoTLYbR.cjs +319 -0
  18. package/dist/core-DwoTLYbR.cjs.map +1 -0
  19. package/dist/core-fsJmsQDa.js +307 -0
  20. package/dist/core-fsJmsQDa.js.map +1 -0
  21. package/dist/index-DMq6F3x9.d.ts +705 -0
  22. package/dist/index-Du_IHXAj.d.ts +10 -0
  23. package/dist/index-ZKOB86ub.d.cts +10 -0
  24. package/dist/index-qeC-p0Tq.d.cts +705 -0
  25. package/dist/index.cjs +61 -118
  26. package/dist/index.cjs.map +1 -1
  27. package/dist/index.d.cts +11 -130
  28. package/dist/index.d.ts +11 -130
  29. package/dist/index.js +14 -119
  30. package/dist/index.js.map +1 -1
  31. package/dist/pg.cjs +214 -320
  32. package/dist/pg.cjs.map +1 -1
  33. package/dist/pg.d.cts +24 -22
  34. package/dist/pg.d.ts +24 -22
  35. package/dist/pg.js +209 -321
  36. package/dist/pg.js.map +1 -1
  37. package/dist/shim.cjs +281 -367
  38. package/dist/shim.cjs.map +1 -1
  39. package/dist/shim.d.cts +140 -137
  40. package/dist/shim.d.ts +140 -137
  41. package/dist/shim.js +275 -366
  42. package/dist/shim.js.map +1 -1
  43. package/dist/sqlite3.cjs +41 -56
  44. package/dist/sqlite3.cjs.map +1 -1
  45. package/dist/sqlite3.d.cts +9 -9
  46. package/dist/sqlite3.d.ts +9 -9
  47. package/dist/sqlite3.js +35 -56
  48. package/dist/sqlite3.js.map +1 -1
  49. package/package.json +15 -15
  50. package/dist/chunk-EQ3T4XHT.cjs +0 -1583
  51. package/dist/chunk-EQ3T4XHT.cjs.map +0 -1
  52. package/dist/chunk-H6YIW5C5.js +0 -399
  53. package/dist/chunk-H6YIW5C5.js.map +0 -1
  54. package/dist/chunk-NTHMSHNG.cjs +0 -399
  55. package/dist/chunk-NTHMSHNG.cjs.map +0 -1
  56. package/dist/chunk-NWYI26VT.js +0 -1583
  57. package/dist/chunk-NWYI26VT.js.map +0 -1
  58. package/dist/index-BfBszcG4.d.ts +0 -8
  59. package/dist/index-a-fxODW1.d.cts +0 -8
  60. package/dist/pongoTransactionCache-CRuPGag3.d.cts +0 -556
  61. package/dist/pongoTransactionCache-CRuPGag3.d.ts +0 -556
package/dist/cli.js CHANGED
@@ -1,532 +1,317 @@
1
1
  #!/usr/bin/env node
2
- import {
3
- objectEntries,
4
- pongoClient,
5
- pongoDriverRegistry,
6
- pongoSchema,
7
- toDbSchemaMetadata
8
- } from "./chunk-NWYI26VT.js";
9
-
10
- // src/cli.ts
11
- import { Command as Command4 } from "commander";
12
-
13
- // src/commandLine/configFile.ts
2
+ import { A as objectEntries, _ as toDbSchemaMetadata, o as pongoClient, p as pongoSchema, u as pongoDriverRegistry } from "./core-D_iZiiYe.js";
3
+ import { JSONSerializer, LogLevel, LogStyle, SQL, color, combineMigrations, dumbo, parseConnectionString, prettyJson, runSQLMigrations } from "@event-driven-io/dumbo";
14
4
  import { Command } from "commander";
15
- import fs from "fs";
16
- var formatTypeName = (input) => {
17
- if (input.length === 0) {
18
- return input;
19
- }
20
- let formatted = input.charAt(0).toUpperCase() + input.slice(1);
21
- if (formatted.endsWith("s")) {
22
- formatted = formatted.slice(0, -1);
23
- }
24
- return formatted;
5
+ import fs from "node:fs";
6
+ import { checkConnection } from "@event-driven-io/dumbo/pg";
7
+ import Table from "cli-table3";
8
+ import repl from "node:repl";
9
+
10
+ //#region src/commandLine/configFile.ts
11
+ const formatTypeName = (input) => {
12
+ if (input.length === 0) return input;
13
+ let formatted = input.charAt(0).toUpperCase() + input.slice(1);
14
+ if (formatted.endsWith("s")) formatted = formatted.slice(0, -1);
15
+ return formatted;
25
16
  };
26
- var sampleConfig = (collectionNames = ["users"]) => {
27
- const types = collectionNames.map(
28
- (name) => `export type ${formatTypeName(name)} = { name: string; description: string; date: Date }`
29
- ).join("\n");
30
- const collections = collectionNames.map(
31
- (name) => ` ${name}: pongoSchema.collection<${formatTypeName(name)}>('${name}'),`
32
- ).join("\n");
33
- return `import { pongoSchema } from '@event-driven-io/pongo';
17
+ const sampleConfig = (collectionNames = ["users"]) => {
18
+ return `import { pongoSchema } from '@event-driven-io/pongo';
34
19
 
35
- ${types}
20
+ ${collectionNames.map((name) => `export type ${formatTypeName(name)} = { name: string; description: string; date: Date }`).join("\n")}
36
21
 
37
22
  export default {
38
23
  schema: pongoSchema.client({
39
24
  database: pongoSchema.db({
40
- ${collections}
25
+ ${collectionNames.map((name) => ` ${name}: pongoSchema.collection<${formatTypeName(name)}>('${name}'),`).join("\n")}
41
26
  }),
42
27
  }),
43
28
  };`;
44
29
  };
45
- var missingDefaultExport = `Error: Config should contain default export, e.g.
46
-
47
- ${sampleConfig()}`;
48
- var missingSchema = `Error: Config should contain schema property, e.g.
49
-
50
- ${sampleConfig()}`;
51
- var missingDbs = `Error: Config should have at least a single database defined, e.g.
52
-
53
- ${sampleConfig()}`;
54
- var missingDefaultDb = `Error: Config should have a default database defined (without name or or with default database name), e.g.
55
-
56
- ${sampleConfig()}`;
57
- var missingCollections = `Error: Database should have defined at least one collection, e.g.
58
-
59
- ${sampleConfig()}`;
60
- var loadConfigFile = async (configPath) => {
61
- const configUrl = new URL(configPath, `file://${process.cwd()}/`);
62
- try {
63
- const imported = await import(configUrl.href);
64
- const parsed = parseDefaultDbSchema(imported);
65
- if (typeof parsed === "string") {
66
- console.error(parsed);
67
- process.exit(1);
68
- }
69
- return parsed;
70
- } catch {
71
- console.error(`Error: Couldn't load file: ${configUrl.href}`);
72
- process.exit(1);
73
- }
30
+ const missingDefaultExport = `Error: Config should contain default export, e.g.\n\n${sampleConfig()}`;
31
+ const missingSchema = `Error: Config should contain schema property, e.g.\n\n${sampleConfig()}`;
32
+ const missingDbs = `Error: Config should have at least a single database defined, e.g.\n\n${sampleConfig()}`;
33
+ const missingDefaultDb = `Error: Config should have a default database defined (without name or or with default database name), e.g.\n\n${sampleConfig()}`;
34
+ const missingCollections = `Error: Database should have defined at least one collection, e.g.\n\n${sampleConfig()}`;
35
+ const loadConfigFile = async (configPath) => {
36
+ const configUrl = new URL(configPath, `file://${process.cwd()}/`);
37
+ try {
38
+ const parsed = parseDefaultDbSchema(await import(configUrl.href));
39
+ if (typeof parsed === "string") {
40
+ console.error(parsed);
41
+ process.exit(1);
42
+ }
43
+ return parsed;
44
+ } catch {
45
+ console.error(`Error: Couldn't load file: ${configUrl.href}`);
46
+ process.exit(1);
47
+ }
74
48
  };
75
- var generateConfigFile = (configPath, collectionNames) => {
76
- try {
77
- fs.writeFileSync(configPath, sampleConfig(collectionNames), "utf8");
78
- console.log(`Configuration file stored at: ${configPath}`);
79
- } catch (error) {
80
- console.error(`Error: Couldn't store config file: ${configPath}!`);
81
- console.error(error);
82
- process.exit(1);
83
- }
49
+ const generateConfigFile = (configPath, collectionNames) => {
50
+ try {
51
+ fs.writeFileSync(configPath, sampleConfig(collectionNames), "utf8");
52
+ console.log(`Configuration file stored at: ${configPath}`);
53
+ } catch (error) {
54
+ console.error(`Error: Couldn't store config file: ${configPath}!`);
55
+ console.error(error);
56
+ process.exit(1);
57
+ }
84
58
  };
85
- var parseDefaultDbSchema = (imported) => {
86
- if (!imported.default) {
87
- return missingDefaultExport;
88
- }
89
- if (!imported.default.schema) {
90
- return missingSchema;
91
- }
92
- if (!imported.default.schema.dbs) {
93
- return missingDbs;
94
- }
95
- const dbs = objectEntries(imported.default.schema.dbs).map((db) => db[1]);
96
- const defaultDb = dbs.find((db) => db.name === void 0);
97
- if (!defaultDb) {
98
- return missingDefaultDb;
99
- }
100
- if (!defaultDb.collections) {
101
- return missingCollections;
102
- }
103
- const collections = objectEntries(defaultDb.collections).map((col) => col[1]);
104
- if (collections.length === 0) {
105
- return missingCollections;
106
- }
107
- return toDbSchemaMetadata(defaultDb);
59
+ const parseDefaultDbSchema = (imported) => {
60
+ if (!imported.default) return missingDefaultExport;
61
+ if (!imported.default.schema) return missingSchema;
62
+ if (!imported.default.schema.dbs) return missingDbs;
63
+ const defaultDb = objectEntries(imported.default.schema.dbs).map((db) => db[1]).find((db) => db.name === void 0);
64
+ if (!defaultDb) return missingDefaultDb;
65
+ if (!defaultDb.collections) return missingCollections;
66
+ if (objectEntries(defaultDb.collections).map((col) => col[1]).length === 0) return missingCollections;
67
+ return toDbSchemaMetadata(defaultDb);
108
68
  };
109
- var configCommand = new Command("config").description(
110
- "Manage Pongo configuration"
111
- );
112
- configCommand.command("sample").description("Generate or print sample configuration").option(
113
- "--col, --collection <name>",
114
- "Specify the collection name",
115
- (value, previous) => {
116
- return previous.concat([value]);
117
- },
118
- []
119
- ).option(
120
- "-f, --file <path>",
121
- "Path to configuration file with collection list"
122
- ).option("-g, --generate", "Generate sample config file").option("-p, --print", "Print sample config file").action((options) => {
123
- const collectionNames = options.collection.length > 0 ? options.collection : ["users"];
124
- if (!("print" in options) && !("generate" in options)) {
125
- console.error(
126
- "Error: Please provide either:\n--print param to print sample config or\n--generate to generate sample config file"
127
- );
128
- process.exit(1);
129
- }
130
- if ("print" in options) {
131
- console.log(`${sampleConfig(collectionNames)}`);
132
- } else if ("generate" in options) {
133
- if (!options.file) {
134
- console.error(
135
- "Error: You need to provide a config file through a --file"
136
- );
137
- process.exit(1);
138
- }
139
- generateConfigFile(options.file, collectionNames);
140
- }
69
+ const configCommand = new Command("config").description("Manage Pongo configuration");
70
+ configCommand.command("sample").description("Generate or print sample configuration").option("--col, --collection <name>", "Specify the collection name", (value, previous) => {
71
+ return previous.concat([value]);
72
+ }, []).option("-f, --file <path>", "Path to configuration file with collection list").option("-g, --generate", "Generate sample config file").option("-p, --print", "Print sample config file").action((options) => {
73
+ const collectionNames = options.collection.length > 0 ? options.collection : ["users"];
74
+ if (!("print" in options) && !("generate" in options)) {
75
+ console.error("Error: Please provide either:\n--print param to print sample config or\n--generate to generate sample config file");
76
+ process.exit(1);
77
+ }
78
+ if ("print" in options) console.log(`${sampleConfig(collectionNames)}`);
79
+ else if ("generate" in options) {
80
+ if (!options.file) {
81
+ console.error("Error: You need to provide a config file through a --file");
82
+ process.exit(1);
83
+ }
84
+ generateConfigFile(options.file, collectionNames);
85
+ }
141
86
  });
142
87
 
143
- // src/commandLine/migrate.ts
144
- import {
145
- combineMigrations,
146
- dumbo,
147
- JSONSerializer,
148
- parseConnectionString,
149
- runSQLMigrations
150
- } from "@event-driven-io/dumbo";
151
- import { Command as Command2 } from "commander";
152
- var migrateCommand = new Command2("migrate").description(
153
- "Manage database migrations"
154
- );
155
- migrateCommand.command("run").description("Run database migrations").option(
156
- "--dbt, --database-type <string>",
157
- "Database type that should be used for connection (e.g., PostgreSQL or SQLite)",
158
- void 0
159
- ).option(
160
- "--drv, --database-driver <string>",
161
- 'Database driver that should be used for connection (e.g., "pg" for PostgreSQL, "sqlite3" for SQLite)'
162
- ).option(
163
- "--dbn, --database-name <string>",
164
- "Database name to connect to",
165
- void 0
166
- ).option(
167
- "--cs, --connection-string <string>",
168
- "Connection string for the database"
169
- ).option(
170
- "--col, --collection <name>",
171
- "Specify the collection name",
172
- (value, previous) => {
173
- return previous.concat([value]);
174
- },
175
- []
176
- ).option("-f, --config <path>", "Path to configuration file with Pongo config").option("--dr, --dryRun", "Perform dry run without commiting changes", false).option(
177
- "--t, --timeout <ms>",
178
- "Set the migration timeout in milliseconds",
179
- parseInt
180
- ).action(async (options) => {
181
- const { collection, dryRun, databaseName, databaseDriver, timeoutMs } = options;
182
- const connectionString = options.connectionString ?? process.env.DB_CONNECTION_STRING;
183
- const databaseType = options.databaseType ?? parseConnectionString(connectionString).databaseType;
184
- let collectionNames;
185
- if (!connectionString) {
186
- console.error(
187
- 'Error: Connection string is required. Provide it either as a "--connection-string" parameter or through the DB_CONNECTION_STRING environment variable.\nFor instance: --connection-string postgresql://postgres:postgres@localhost:5432/postgres'
188
- );
189
- process.exit(1);
190
- }
191
- if (options.config) {
192
- const config = await loadConfigFile(options.config);
193
- collectionNames = config.collections.map((c) => c.name);
194
- } else if (collection) {
195
- collectionNames = collection;
196
- } else {
197
- console.error(
198
- 'Error: You need to provide at least one collection name. Provide it either through "--config" file or as a "--collection" parameter.'
199
- );
200
- process.exit(1);
201
- }
202
- const driverType = `${databaseType}:${databaseDriver}`;
203
- const migrations = getMigrations({
204
- driverType,
205
- connectionString,
206
- databaseName,
207
- collectionNames
208
- });
209
- const pool = dumbo({ connectionString, driverType });
210
- await runSQLMigrations(pool, migrations, {
211
- dryRun,
212
- migrationTimeoutMs: timeoutMs
213
- });
88
+ //#endregion
89
+ //#region src/commandLine/migrate.ts
90
+ const migrateCommand = new Command("migrate").description("Manage database migrations");
91
+ migrateCommand.command("run").description("Run database migrations").option("--dbt, --database-type <string>", "Database type that should be used for connection (e.g., PostgreSQL or SQLite)", void 0).option("--drv, --database-driver <string>", "Database driver that should be used for connection (e.g., \"pg\" for PostgreSQL, \"sqlite3\" for SQLite)").option("--dbn, --database-name <string>", "Database name to connect to", void 0).option("--cs, --connection-string <string>", "Connection string for the database").option("--col, --collection <name>", "Specify the collection name", (value, previous) => {
92
+ return previous.concat([value]);
93
+ }, []).option("-f, --config <path>", "Path to configuration file with Pongo config").option("--dr, --dryRun", "Perform dry run without commiting changes", false).option("--t, --timeout <ms>", "Set the migration timeout in milliseconds", parseInt).action(async (options) => {
94
+ const { collection, dryRun, databaseName, databaseDriver, timeoutMs } = options;
95
+ const connectionString = options.connectionString ?? process.env.DB_CONNECTION_STRING;
96
+ const databaseType = options.databaseType ?? parseConnectionString(connectionString).databaseType;
97
+ let collectionNames;
98
+ if (!connectionString) {
99
+ console.error("Error: Connection string is required. Provide it either as a \"--connection-string\" parameter or through the DB_CONNECTION_STRING environment variable.\nFor instance: --connection-string postgresql://postgres:postgres@localhost:5432/postgres");
100
+ process.exit(1);
101
+ }
102
+ if (options.config) collectionNames = (await loadConfigFile(options.config)).collections.map((c) => c.name);
103
+ else if (collection) collectionNames = collection;
104
+ else {
105
+ console.error("Error: You need to provide at least one collection name. Provide it either through \"--config\" file or as a \"--collection\" parameter.");
106
+ process.exit(1);
107
+ }
108
+ const driverType = `${databaseType}:${databaseDriver}`;
109
+ const migrations = getMigrations({
110
+ driverType,
111
+ connectionString,
112
+ databaseName,
113
+ collectionNames
114
+ });
115
+ await runSQLMigrations(dumbo({
116
+ connectionString,
117
+ driverType
118
+ }), migrations, {
119
+ dryRun,
120
+ migrationTimeoutMs: timeoutMs
121
+ });
214
122
  });
215
- migrateCommand.command("sql").description("Generate SQL for database migration").option(
216
- "--dbt, --database-type <string>",
217
- "Database type that should be used for connection (e.g., PostgreSQL or SQLite)"
218
- ).option(
219
- "--drv, --database-driver <string>",
220
- 'Database driver that should be used for connection (e.g., "pg" for PostgreSQL, "sqlite3" for SQLite)'
221
- ).option(
222
- "--dbn, --database-name <string>",
223
- "Database name to connect to",
224
- void 0
225
- ).option(
226
- "--col, --collection <name>",
227
- "Specify the collection name",
228
- (value, previous) => {
229
- return previous.concat([value]);
230
- },
231
- []
232
- ).option("-f, --config <path>", "Path to configuration file with Pongo config").option("--print", "Print the SQL to the console (default)", true).action(async (options) => {
233
- const { collection, databaseName, databaseType, databaseDriver } = options;
234
- let collectionNames;
235
- if (options.config) {
236
- const config = await loadConfigFile(options.config);
237
- collectionNames = config.collections.map((c) => c.name);
238
- } else if (collection) {
239
- collectionNames = collection;
240
- } else {
241
- console.error(
242
- 'Error: You need to provide at least one collection name. Provide it either through "--config" file or as a "--collection" parameter.'
243
- );
244
- process.exit(1);
245
- }
246
- const driverType = `${databaseType}:${databaseDriver}`;
247
- const migrations = getMigrations({
248
- driverType,
249
- connectionString: void 0,
250
- databaseName,
251
- collectionNames
252
- });
253
- console.log("Printing SQL:");
254
- console.log(combineMigrations(...migrations));
123
+ migrateCommand.command("sql").description("Generate SQL for database migration").option("--dbt, --database-type <string>", "Database type that should be used for connection (e.g., PostgreSQL or SQLite)").option("--drv, --database-driver <string>", "Database driver that should be used for connection (e.g., \"pg\" for PostgreSQL, \"sqlite3\" for SQLite)").option("--dbn, --database-name <string>", "Database name to connect to", void 0).option("--col, --collection <name>", "Specify the collection name", (value, previous) => {
124
+ return previous.concat([value]);
125
+ }, []).option("-f, --config <path>", "Path to configuration file with Pongo config").option("--print", "Print the SQL to the console (default)", true).action(async (options) => {
126
+ const { collection, databaseName, databaseType, databaseDriver } = options;
127
+ let collectionNames;
128
+ if (options.config) collectionNames = (await loadConfigFile(options.config)).collections.map((c) => c.name);
129
+ else if (collection) collectionNames = collection;
130
+ else {
131
+ console.error("Error: You need to provide at least one collection name. Provide it either through \"--config\" file or as a \"--collection\" parameter.");
132
+ process.exit(1);
133
+ }
134
+ const migrations = getMigrations({
135
+ driverType: `${databaseType}:${databaseDriver}`,
136
+ connectionString: void 0,
137
+ databaseName,
138
+ collectionNames
139
+ });
140
+ console.log("Printing SQL:");
141
+ console.log(combineMigrations(...migrations));
255
142
  });
256
- var getMigrations = ({
257
- driverType,
258
- connectionString,
259
- databaseName,
260
- collectionNames
261
- }) => {
262
- const driver = pongoDriverRegistry.tryGet(driverType);
263
- if (driver === null) {
264
- console.error(
265
- `Error: No database driver found for driver type "${driverType}". Make sure the driver is registered and the connection string is correct.`
266
- );
267
- process.exit(1);
268
- }
269
- const dbDefinition = pongoSchema.db.from(databaseName, collectionNames);
270
- const driverOptions = {
271
- schema: { definition: dbDefinition },
272
- serializer: JSONSerializer
273
- };
274
- const customOptions = {
275
- connectionString,
276
- databaseName
277
- };
278
- const db = driver.databaseFactory({ ...driverOptions, ...customOptions });
279
- return db.schema.component.migrations;
143
+ const getMigrations = ({ driverType, connectionString, databaseName, collectionNames }) => {
144
+ const driver = pongoDriverRegistry.tryGet(driverType);
145
+ if (driver === null) {
146
+ console.error(`Error: No database driver found for driver type "${driverType}". Make sure the driver is registered and the connection string is correct.`);
147
+ process.exit(1);
148
+ }
149
+ const driverOptions = {
150
+ schema: { definition: pongoSchema.db.from(databaseName, collectionNames) },
151
+ serializer: JSONSerializer
152
+ };
153
+ const customOptions = {
154
+ connectionString,
155
+ databaseName
156
+ };
157
+ return driver.databaseFactory({
158
+ ...driverOptions,
159
+ ...customOptions
160
+ }).schema.component.migrations;
280
161
  };
281
162
 
282
- // src/commandLine/shell.ts
283
- import {
284
- color,
285
- LogLevel,
286
- LogStyle,
287
- parseConnectionString as parseConnectionString2,
288
- prettyJson,
289
- SQL
290
- } from "@event-driven-io/dumbo";
291
- import { checkConnection } from "@event-driven-io/dumbo/pg";
292
- import Table from "cli-table3";
293
- import { Command as Command3 } from "commander";
294
- import repl from "repl";
295
- var pongo;
296
- var calculateColumnWidths = (results, columnNames) => {
297
- const columnWidths = columnNames.map((col) => {
298
- const maxWidth = Math.max(
299
- col.length,
300
- ...results.map(
301
- (result) => (
302
- // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
303
- result[col] ? String(result[col]).length : 0
304
- )
305
- )
306
- );
307
- return maxWidth + 2;
308
- });
309
- return columnWidths;
163
+ //#endregion
164
+ //#region src/commandLine/shell.ts
165
+ let pongo;
166
+ const calculateColumnWidths = (results, columnNames) => {
167
+ return columnNames.map((col) => {
168
+ return Math.max(col.length, ...results.map((result) => result[col] ? String(result[col]).length : 0)) + 2;
169
+ });
310
170
  };
311
- var shouldDisplayResultsAsTable = false;
312
- var printResultsAsTable = (print) => shouldDisplayResultsAsTable = print === void 0 || print === true;
313
- var printOutput = (obj) => Array.isArray(obj) && shouldDisplayResultsAsTable ? displayResultsAsTable(obj) : prettyJson(obj);
314
- var displayResultsAsTable = (results) => {
315
- if (results.length === 0) {
316
- return color.yellow("No documents found.");
317
- }
318
- const columnNames = results.flatMap(
319
- (result) => (
320
- // eslint-disable-next-line @typescript-eslint/no-unsafe-argument
321
- typeof result === "object" ? Object.keys(result) : typeof result
322
- )
323
- ).filter((value, index, array) => array.indexOf(value) === index);
324
- const columnWidths = calculateColumnWidths(results, columnNames);
325
- const table = new Table({
326
- head: columnNames.map((col) => color.cyan(col)),
327
- colWidths: columnWidths
328
- });
329
- results.forEach((result) => {
330
- table.push(
331
- columnNames.map(
332
- (col) => (
333
- // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
334
- result[col] !== void 0 ? (
335
- // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
336
- Array.isArray(result[col]) ? (
337
- // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
338
- displayResultsAsTable(result[col])
339
- ) : (
340
- // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
341
- prettyJson(result[col])
342
- )
343
- ) : typeof result === "object" ? "" : result != void 0 && result != void 0 ? prettyJson(result) : ""
344
- )
345
- )
346
- );
347
- });
348
- return table.toString();
171
+ let shouldDisplayResultsAsTable = false;
172
+ const printResultsAsTable = (print) => shouldDisplayResultsAsTable = print === void 0 || print === true;
173
+ const printOutput = (obj) => Array.isArray(obj) && shouldDisplayResultsAsTable ? displayResultsAsTable(obj) : prettyJson(obj);
174
+ const displayResultsAsTable = (results) => {
175
+ if (results.length === 0) return color.yellow("No documents found.");
176
+ const columnNames = results.flatMap((result) => typeof result === "object" ? Object.keys(result) : typeof result).filter((value, index, array) => array.indexOf(value) === index);
177
+ const columnWidths = calculateColumnWidths(results, columnNames);
178
+ const table = new Table({
179
+ head: columnNames.map((col) => color.cyan(col)),
180
+ colWidths: columnWidths
181
+ });
182
+ results.forEach((result) => {
183
+ table.push(columnNames.map((col) => result[col] !== void 0 ? Array.isArray(result[col]) ? displayResultsAsTable(result[col]) : prettyJson(result[col]) : typeof result === "object" ? "" : result != void 0 && result != void 0 ? prettyJson(result) : ""));
184
+ });
185
+ return table.toString();
349
186
  };
350
- var setLogLevel = (logLevel) => {
351
- process.env.DUMBO_LOG_LEVEL = logLevel;
187
+ const setLogLevel = (logLevel) => {
188
+ process.env.DUMBO_LOG_LEVEL = logLevel;
352
189
  };
353
- var setLogStyle = (logLevel) => {
354
- process.env.DUMBO_LOG_STYLE = logLevel;
190
+ const setLogStyle = (logLevel) => {
191
+ process.env.DUMBO_LOG_STYLE = logLevel;
355
192
  };
356
- var prettifyLogs = (logLevel) => {
357
- if (logLevel !== void 0) setLogLevel(logLevel);
358
- setLogStyle(LogStyle.PRETTY);
193
+ const prettifyLogs = (logLevel) => {
194
+ if (logLevel !== void 0) setLogLevel(logLevel);
195
+ setLogStyle(LogStyle.PRETTY);
359
196
  };
360
- var startRepl = async (options) => {
361
- setLogLevel(process.env.DUMBO_LOG_LEVEL ?? options.logging.logLevel);
362
- setLogStyle(process.env.DUMBO_LOG_STYLE ?? options.logging.logStyle);
363
- console.log(color.green("Starting Pongo Shell (version: 0.17.0-beta.35)"));
364
- if (options.logging.printOptions) {
365
- console.log(color.green("With Options:"));
366
- console.log(prettyJson(options));
367
- }
368
- const connectionString = options.connectionString ?? process.env.DB_CONNECTION_STRING ?? "postgresql://postgres:postgres@localhost:5432/postgres";
369
- if (!(options.connectionString ?? process.env.DB_CONNECTION_STRING)) {
370
- console.log(
371
- color.yellow(
372
- `No connection string provided, using: 'postgresql://postgres:postgres@localhost:5432/postgres'`
373
- )
374
- );
375
- }
376
- const { databaseType } = parseConnectionString2(connectionString);
377
- const driverType = `${databaseType}:${options.databaseDriver}`;
378
- const driver = pongoDriverRegistry.tryGet(driverType);
379
- if (driver === null) {
380
- console.error(
381
- `Error: No database driver found for driver type "${driverType}". Make sure the driver is installed and the connection string is correct.`
382
- );
383
- process.exit(1);
384
- }
385
- const connectionCheck = await checkConnection(connectionString);
386
- if (!connectionCheck.successful) {
387
- if (connectionCheck.errorType === "ConnectionRefused") {
388
- console.error(
389
- color.red(
390
- `Connection was refused. Check if the PostgreSQL server is running and accessible.`
391
- )
392
- );
393
- } else if (connectionCheck.errorType === "Authentication") {
394
- console.error(
395
- color.red(
396
- `Authentication failed. Check the username and password in the connection string.`
397
- )
398
- );
399
- } else {
400
- console.error(color.red("Error connecting to PostgreSQL server"));
401
- }
402
- console.log(color.red("Exiting Pongo Shell..."));
403
- process.exit();
404
- }
405
- console.log(color.green(`Successfully connected`));
406
- console.log(color.green("Use db.<collection>.<method>() to query."));
407
- const shell = repl.start({
408
- prompt: color.green("pongo> "),
409
- useGlobal: true,
410
- breakEvalOnSigint: true,
411
- writer: printOutput
412
- });
413
- let db;
414
- if (options.schema.collections.length > 0) {
415
- const collectionsSchema = {};
416
- for (const collectionName of options.schema.collections) {
417
- collectionsSchema[collectionName] = pongoSchema.collection(collectionName);
418
- }
419
- const schema = pongoSchema.client({
420
- database: pongoSchema.db(options.schema.database, collectionsSchema)
421
- });
422
- const driverOptions = {
423
- driver,
424
- schema: {
425
- definition: schema,
426
- autoMigration: options.schema.autoMigration
427
- }
428
- };
429
- const customOptions = {
430
- connectionString
431
- };
432
- const typedClient = pongoClient({
433
- ...driverOptions,
434
- ...customOptions
435
- });
436
- db = typedClient.database;
437
- for (const collectionName of options.schema.collections) {
438
- shell.context[collectionName] = typedClient.database[collectionName];
439
- }
440
- pongo = typedClient;
441
- } else {
442
- const driverOptions = {
443
- driver,
444
- schema: {
445
- autoMigration: options.schema.autoMigration
446
- }
447
- };
448
- const customOptions = {
449
- connectionString
450
- };
451
- pongo = pongoClient({
452
- ...driverOptions,
453
- ...customOptions
454
- });
455
- db = pongo.db(options.schema.database);
456
- }
457
- shell.context.pongo = pongo;
458
- shell.context.db = db;
459
- shell.context.SQL = SQL;
460
- shell.context.setLogLevel = setLogLevel;
461
- shell.context.setLogStyle = setLogStyle;
462
- shell.context.prettifyLogs = prettifyLogs;
463
- shell.context.printResultsAsTable = printResultsAsTable;
464
- shell.context.LogStyle = LogStyle;
465
- shell.context.LogLevel = LogLevel;
466
- shell.on("exit", async () => {
467
- await teardown();
468
- process.exit();
469
- });
470
- shell.on("SIGINT", async () => {
471
- await teardown();
472
- process.exit();
473
- });
197
+ const startRepl = async (options) => {
198
+ setLogLevel(process.env.DUMBO_LOG_LEVEL ?? options.logging.logLevel);
199
+ setLogStyle(process.env.DUMBO_LOG_STYLE ?? options.logging.logStyle);
200
+ console.log(color.green("Starting Pongo Shell (version: 0.17.0-beta.36)"));
201
+ if (options.logging.printOptions) {
202
+ console.log(color.green("With Options:"));
203
+ console.log(prettyJson(options));
204
+ }
205
+ const connectionString = options.connectionString ?? process.env.DB_CONNECTION_STRING ?? "postgresql://postgres:postgres@localhost:5432/postgres";
206
+ if (!(options.connectionString ?? process.env.DB_CONNECTION_STRING)) console.log(color.yellow(`No connection string provided, using: 'postgresql://postgres:postgres@localhost:5432/postgres'`));
207
+ const { databaseType } = parseConnectionString(connectionString);
208
+ const driverType = `${databaseType}:${options.databaseDriver}`;
209
+ const driver = pongoDriverRegistry.tryGet(driverType);
210
+ if (driver === null) {
211
+ console.error(`Error: No database driver found for driver type "${driverType}". Make sure the driver is installed and the connection string is correct.`);
212
+ process.exit(1);
213
+ }
214
+ const connectionCheck = await checkConnection(connectionString);
215
+ if (!connectionCheck.successful) {
216
+ if (connectionCheck.errorType === "ConnectionRefused") console.error(color.red(`Connection was refused. Check if the PostgreSQL server is running and accessible.`));
217
+ else if (connectionCheck.errorType === "Authentication") console.error(color.red(`Authentication failed. Check the username and password in the connection string.`));
218
+ else console.error(color.red("Error connecting to PostgreSQL server"));
219
+ console.log(color.red("Exiting Pongo Shell..."));
220
+ process.exit();
221
+ }
222
+ console.log(color.green(`Successfully connected`));
223
+ console.log(color.green("Use db.<collection>.<method>() to query."));
224
+ const shell = repl.start({
225
+ prompt: color.green("pongo> "),
226
+ useGlobal: true,
227
+ breakEvalOnSigint: true,
228
+ writer: printOutput
229
+ });
230
+ let db;
231
+ if (options.schema.collections.length > 0) {
232
+ const collectionsSchema = {};
233
+ for (const collectionName of options.schema.collections) collectionsSchema[collectionName] = pongoSchema.collection(collectionName);
234
+ const driverOptions = {
235
+ driver,
236
+ schema: {
237
+ definition: pongoSchema.client({ database: pongoSchema.db(options.schema.database, collectionsSchema) }),
238
+ autoMigration: options.schema.autoMigration
239
+ }
240
+ };
241
+ const customOptions = { connectionString };
242
+ const typedClient = pongoClient({
243
+ ...driverOptions,
244
+ ...customOptions
245
+ });
246
+ db = typedClient.database;
247
+ for (const collectionName of options.schema.collections) shell.context[collectionName] = typedClient.database[collectionName];
248
+ pongo = typedClient;
249
+ } else {
250
+ const driverOptions = {
251
+ driver,
252
+ schema: { autoMigration: options.schema.autoMigration }
253
+ };
254
+ const customOptions = { connectionString };
255
+ pongo = pongoClient({
256
+ ...driverOptions,
257
+ ...customOptions
258
+ });
259
+ db = pongo.db(options.schema.database);
260
+ }
261
+ shell.context.pongo = pongo;
262
+ shell.context.db = db;
263
+ shell.context.SQL = SQL;
264
+ shell.context.setLogLevel = setLogLevel;
265
+ shell.context.setLogStyle = setLogStyle;
266
+ shell.context.prettifyLogs = prettifyLogs;
267
+ shell.context.printResultsAsTable = printResultsAsTable;
268
+ shell.context.LogStyle = LogStyle;
269
+ shell.context.LogLevel = LogLevel;
270
+ shell.on("exit", async () => {
271
+ await teardown();
272
+ process.exit();
273
+ });
274
+ shell.on("SIGINT", async () => {
275
+ await teardown();
276
+ process.exit();
277
+ });
474
278
  };
475
- var teardown = async () => {
476
- console.log(color.yellow("Exiting Pongo Shell..."));
477
- await pongo.close();
279
+ const teardown = async () => {
280
+ console.log(color.yellow("Exiting Pongo Shell..."));
281
+ await pongo.close();
478
282
  };
479
283
  process.on("uncaughtException", teardown);
480
284
  process.on("SIGINT", teardown);
481
- var shellCommand = new Command3("shell").description("Start an interactive Pongo shell").option(
482
- "--drv, --database-driver <string>",
483
- 'Database driver that should be used for connection (e.g., "pg" for PostgreSQL, "sqlite3" for SQLite)',
484
- "pg"
485
- ).option(
486
- "--cs, --connectionString <string>",
487
- "Connection string for the database"
488
- ).option("--db, --database <string>", "Database name to connect", "postgres").option(
489
- "--col, --collection <name>",
490
- "Specify the collection name",
491
- (value, previous) => {
492
- return previous.concat([value]);
493
- },
494
- []
495
- ).option(
496
- "--no-migrations, --disable-auto-migrations",
497
- "Disable automatic migrations"
498
- ).option("-o, --print-options", "Print shell options").option(
499
- "--ll, --log-level <logLevel>",
500
- "Log level: DISABLED, INFO, LOG, WARN, ERROR",
501
- "DISABLED"
502
- ).option("--ls, --log-style", "Log style: RAW, PRETTY", "RAW").option("-p, --pretty-log", "Turn on logging with prettified output").action(async (options) => {
503
- const { collection, database } = options;
504
- const connectionString = options.connectionString;
505
- await startRepl({
506
- logging: {
507
- printOptions: options.printOptions === true,
508
- logStyle: options.prettyLog ? LogStyle.PRETTY : options.logStyle ?? LogStyle.RAW,
509
- logLevel: options.logLevel ? options.logLevel : options.prettyLog ? LogLevel.INFO : LogLevel.DISABLED
510
- },
511
- schema: {
512
- collections: collection,
513
- database,
514
- autoMigration: options.disableAutoMigrations ? "None" : "CreateOrUpdate"
515
- },
516
- connectionString,
517
- databaseDriver: options.databaseDriver
518
- });
285
+ const shellCommand = new Command("shell").description("Start an interactive Pongo shell").option("--drv, --database-driver <string>", "Database driver that should be used for connection (e.g., \"pg\" for PostgreSQL, \"sqlite3\" for SQLite)", "pg").option("--cs, --connectionString <string>", "Connection string for the database").option("--db, --database <string>", "Database name to connect", "postgres").option("--col, --collection <name>", "Specify the collection name", (value, previous) => {
286
+ return previous.concat([value]);
287
+ }, []).option("--no-migrations, --disable-auto-migrations", "Disable automatic migrations").option("-o, --print-options", "Print shell options").option("--ll, --log-level <logLevel>", "Log level: DISABLED, INFO, LOG, WARN, ERROR", "DISABLED").option("--ls, --log-style", "Log style: RAW, PRETTY", "RAW").option("-p, --pretty-log", "Turn on logging with prettified output").action(async (options) => {
288
+ const { collection, database } = options;
289
+ const connectionString = options.connectionString;
290
+ await startRepl({
291
+ logging: {
292
+ printOptions: options.printOptions === true,
293
+ logStyle: options.prettyLog ? LogStyle.PRETTY : options.logStyle ?? LogStyle.RAW,
294
+ logLevel: options.logLevel ? options.logLevel : options.prettyLog ? LogLevel.INFO : LogLevel.DISABLED
295
+ },
296
+ schema: {
297
+ collections: collection,
298
+ database,
299
+ autoMigration: options.disableAutoMigrations ? "None" : "CreateOrUpdate"
300
+ },
301
+ connectionString,
302
+ databaseDriver: options.databaseDriver
303
+ });
519
304
  });
520
305
 
521
- // src/cli.ts
522
- var program = new Command4();
306
+ //#endregion
307
+ //#region src/cli.ts
308
+ const program = new Command();
523
309
  program.name("pongo").description("CLI tool for Pongo");
524
310
  program.addCommand(configCommand);
525
311
  program.addCommand(migrateCommand);
526
312
  program.addCommand(shellCommand);
527
313
  program.parse(process.argv);
528
- var cli_default = program;
529
- export {
530
- cli_default as default
531
- };
314
+
315
+ //#endregion
316
+ export { program as default };
532
317
  //# sourceMappingURL=cli.js.map