@event-driven-io/pongo 0.16.9 → 0.16.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/cli.cjs CHANGED
@@ -5,7 +5,7 @@
5
5
 
6
6
 
7
7
 
8
- var _chunkNA3ELYRRcjs = require('./chunk-NA3ELYRR.cjs');
8
+ var _chunk3K7LHO2Pcjs = require('./chunk-3K7LHO2P.cjs');
9
9
 
10
10
  // src/cli.ts
11
11
  var _commander = require('commander');
@@ -92,7 +92,7 @@ var parseDefaultDbSchema = (imported) => {
92
92
  if (!imported.default.schema.dbs) {
93
93
  return missingDbs;
94
94
  }
95
- const dbs = _chunkNA3ELYRRcjs.objectEntries.call(void 0, imported.default.schema.dbs).map((db) => db[1]);
95
+ const dbs = _chunk3K7LHO2Pcjs.objectEntries.call(void 0, imported.default.schema.dbs).map((db) => db[1]);
96
96
  const defaultDb = dbs.find((db) => db.name === void 0);
97
97
  if (!defaultDb) {
98
98
  return missingDefaultDb;
@@ -100,11 +100,11 @@ var parseDefaultDbSchema = (imported) => {
100
100
  if (!defaultDb.collections) {
101
101
  return missingCollections;
102
102
  }
103
- const collections = _chunkNA3ELYRRcjs.objectEntries.call(void 0, defaultDb.collections).map((col) => col[1]);
103
+ const collections = _chunk3K7LHO2Pcjs.objectEntries.call(void 0, defaultDb.collections).map((col) => col[1]);
104
104
  if (collections.length === 0) {
105
105
  return missingCollections;
106
106
  }
107
- return _chunkNA3ELYRRcjs.toDbSchemaMetadata.call(void 0, defaultDb);
107
+ return _chunk3K7LHO2Pcjs.toDbSchemaMetadata.call(void 0, defaultDb);
108
108
  };
109
109
  var configCommand = new (0, _commander.Command)("config").description(
110
110
  "Manage Pongo configuration"
@@ -184,7 +184,7 @@ migrateCommand.command("run").description("Run database migrations").option(
184
184
  }
185
185
  const pool = _dumbo.dumbo.call(void 0, { connectionString });
186
186
  const migrations = collectionNames.flatMap(
187
- (collectionsName) => _chunkNA3ELYRRcjs.pongoCollectionSchemaComponent.call(void 0, collectionsName).migrations({
187
+ (collectionsName) => _chunk3K7LHO2Pcjs.pongoCollectionSchemaComponent.call(void 0, collectionsName).migrations({
188
188
  connector: "PostgreSQL:pg"
189
189
  // TODO: Provide connector here
190
190
  })
@@ -220,7 +220,7 @@ migrateCommand.command("sql").description("Generate SQL for database migration")
220
220
  const migrations = [
221
221
  ...coreMigrations,
222
222
  ...collectionNames.flatMap(
223
- (collectionName) => _chunkNA3ELYRRcjs.pongoCollectionSchemaComponent.call(void 0, collectionName).migrations({
223
+ (collectionName) => _chunk3K7LHO2Pcjs.pongoCollectionSchemaComponent.call(void 0, collectionName).migrations({
224
224
  connector: "PostgreSQL:pg"
225
225
  // TODO: Provide connector here
226
226
  })
@@ -310,7 +310,7 @@ var prettifyLogs = (logLevel) => {
310
310
  var startRepl = async (options) => {
311
311
  setLogLevel(_nullishCoalesce(process.env.DUMBO_LOG_LEVEL, () => ( options.logging.logLevel)));
312
312
  setLogStyle(_nullishCoalesce(process.env.DUMBO_LOG_STYLE, () => ( options.logging.logStyle)));
313
- console.log(_dumbo.color.green("Starting Pongo Shell (version: 0.16.9)"));
313
+ console.log(_dumbo.color.green("Starting Pongo Shell (version: 0.16.10)"));
314
314
  if (options.logging.printOptions) {
315
315
  console.log(_dumbo.color.green("With Options:"));
316
316
  console.log(_dumbo.prettyJson.call(void 0, options));
@@ -355,12 +355,12 @@ var startRepl = async (options) => {
355
355
  if (options.schema.collections.length > 0) {
356
356
  const collectionsSchema = {};
357
357
  for (const collectionName of options.schema.collections) {
358
- collectionsSchema[collectionName] = _chunkNA3ELYRRcjs.pongoSchema.collection(collectionName);
358
+ collectionsSchema[collectionName] = _chunk3K7LHO2Pcjs.pongoSchema.collection(collectionName);
359
359
  }
360
- const schema = _chunkNA3ELYRRcjs.pongoSchema.client({
361
- database: _chunkNA3ELYRRcjs.pongoSchema.db(options.schema.database, collectionsSchema)
360
+ const schema = _chunk3K7LHO2Pcjs.pongoSchema.client({
361
+ database: _chunk3K7LHO2Pcjs.pongoSchema.db(options.schema.database, collectionsSchema)
362
362
  });
363
- const typedClient = _chunkNA3ELYRRcjs.pongoClient.call(void 0, connectionString, {
363
+ const typedClient = _chunk3K7LHO2Pcjs.pongoClient.call(void 0, connectionString, {
364
364
  schema: {
365
365
  definition: schema,
366
366
  autoMigration: options.schema.autoMigration
@@ -372,7 +372,7 @@ var startRepl = async (options) => {
372
372
  }
373
373
  pongo = typedClient;
374
374
  } else {
375
- pongo = _chunkNA3ELYRRcjs.pongoClient.call(void 0, connectionString, {
375
+ pongo = _chunk3K7LHO2Pcjs.pongoClient.call(void 0, connectionString, {
376
376
  schema: { autoMigration: options.schema.autoMigration }
377
377
  });
378
378
  db = pongo.db(options.schema.database);
package/dist/cli.cjs.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["/home/runner/work/Pongo/Pongo/src/packages/pongo/dist/cli.cjs","../src/cli.ts","../src/commandLine/configFile.ts","../src/commandLine/migrate.ts","../src/commandLine/shell.ts"],"names":[],"mappings":"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","file":"/home/runner/work/Pongo/Pongo/src/packages/pongo/dist/cli.cjs","sourcesContent":[null,"#!/usr/bin/env node\nimport { Command } from 'commander';\nimport { configCommand, migrateCommand, shellCommand } from './commandLine';\n\nconst program = new Command();\n\nprogram.name('pongo').description('CLI tool for Pongo');\n\nprogram.addCommand(configCommand);\nprogram.addCommand(migrateCommand);\nprogram.addCommand(shellCommand);\n\nprogram.parse(process.argv);\n\nexport default program;\n","import { Command } from 'commander';\nimport fs from 'node:fs';\nimport {\n objectEntries,\n toDbSchemaMetadata,\n type PongoDbSchemaMetadata,\n type PongoSchemaConfig,\n} from '../core';\n\nconst formatTypeName = (input: string): string => {\n if (input.length === 0) {\n return input;\n }\n\n let formatted = input.charAt(0).toUpperCase() + input.slice(1);\n\n if (formatted.endsWith('s')) {\n formatted = formatted.slice(0, -1);\n }\n\n return formatted;\n};\n\nconst sampleConfig = (collectionNames: string[] = ['users']) => {\n const types = collectionNames\n .map(\n (name) =>\n `export type ${formatTypeName(name)} = { name: string; description: string; date: Date }`,\n )\n .join('\\n');\n\n const collections = collectionNames\n .map(\n (name) =>\n ` ${name}: pongoSchema.collection<${formatTypeName(name)}>('${name}'),`,\n )\n .join('\\n');\n\n return `import { pongoSchema } from '@event-driven-io/pongo';\n\n${types}\n\nexport default {\n schema: pongoSchema.client({\n database: pongoSchema.db({\n${collections}\n }),\n }),\n};`;\n};\n\nconst missingDefaultExport = `Error: Config should contain default export, e.g.\\n\\n${sampleConfig()}`;\nconst missingSchema = `Error: Config should contain schema property, e.g.\\n\\n${sampleConfig()}`;\nconst missingDbs = `Error: Config should have at least a single database defined, e.g.\\n\\n${sampleConfig()}`;\nconst missingDefaultDb = `Error: Config should have a default database defined (without name or or with default database name), e.g.\\n\\n${sampleConfig()}`;\nconst missingCollections = `Error: Database should have defined at least one collection, e.g.\\n\\n${sampleConfig()}`;\n\nexport const loadConfigFile = async (\n configPath: string,\n): Promise<PongoDbSchemaMetadata> => {\n const configUrl = new URL(configPath, `file://${process.cwd()}/`);\n try {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n const imported: Partial<{ default: PongoSchemaConfig }> = await import(\n configUrl.href\n );\n\n const parsed = parseDefaultDbSchema(imported);\n\n if (typeof parsed === 'string') {\n console.error(parsed);\n process.exit(1);\n }\n\n return parsed;\n } catch {\n console.error(`Error: Couldn't load file: ${configUrl.href}`);\n process.exit(1);\n }\n};\n\nexport const generateConfigFile = (\n configPath: string,\n collectionNames: string[],\n): void => {\n try {\n fs.writeFileSync(configPath, sampleConfig(collectionNames), 'utf8');\n console.log(`Configuration file stored at: ${configPath}`);\n } catch (error) {\n console.error(`Error: Couldn't store config file: ${configPath}!`);\n console.error(error);\n process.exit(1);\n }\n};\n\nexport const parseDefaultDbSchema = (\n imported: Partial<{ default: PongoSchemaConfig }>,\n): PongoDbSchemaMetadata | string => {\n if (!imported.default) {\n return missingDefaultExport;\n }\n\n if (!imported.default.schema) {\n return missingSchema;\n }\n\n if (!imported.default.schema.dbs) {\n return missingDbs;\n }\n\n const dbs = objectEntries(imported.default.schema.dbs).map((db) => db[1]);\n\n const defaultDb = dbs.find((db) => db.name === undefined);\n\n if (!defaultDb) {\n return missingDefaultDb;\n }\n\n if (!defaultDb.collections) {\n return missingCollections;\n }\n\n const collections = objectEntries(defaultDb.collections).map((col) => col[1]);\n\n if (collections.length === 0) {\n return missingCollections;\n }\n\n return toDbSchemaMetadata(defaultDb);\n};\n\ntype SampleConfigOptions =\n | {\n collection: string[];\n print?: boolean;\n }\n | {\n collection: string[];\n generate?: boolean;\n file?: string;\n };\n\nexport const configCommand = new Command('config').description(\n 'Manage Pongo configuration',\n);\n\nconfigCommand\n .command('sample')\n .description('Generate or print sample configuration')\n .option(\n '-col, --collection <name>',\n 'Specify the collection name',\n (value: string, previous: string[]) => {\n // Accumulate collection names into an array (explicitly typing `previous` as `string[]`)\n return previous.concat([value]);\n },\n [] as string[],\n )\n .option(\n '-f, --file <path>',\n 'Path to configuration file with collection list',\n )\n .option('-g, --generate', 'Generate sample config file')\n .option('-p, --print', 'Print sample config file')\n .action((options: SampleConfigOptions) => {\n const collectionNames =\n options.collection.length > 0 ? options.collection : ['users'];\n\n if (!('print' in options) && !('generate' in options)) {\n console.error(\n 'Error: Please provide either:\\n--print param to print sample config or\\n--generate to generate sample config file',\n );\n process.exit(1);\n }\n\n if ('print' in options) {\n console.log(`${sampleConfig(collectionNames)}`);\n } else if ('generate' in options) {\n if (!options.file) {\n console.error(\n 'Error: You need to provide a config file through a --file',\n );\n process.exit(1);\n }\n\n generateConfigFile(options.file, collectionNames);\n }\n });\n","import {\n combineMigrations,\n dumbo,\n migrationTableSchemaComponent,\n runPostgreSQLMigrations,\n} from '@event-driven-io/dumbo';\nimport { Command } from 'commander';\nimport { pongoCollectionSchemaComponent } from '../core';\nimport { loadConfigFile } from './configFile';\n\ninterface MigrateRunOptions {\n collection: string[];\n connectionString: string;\n config?: string;\n dryRun?: boolean;\n}\n\ninterface MigrateSqlOptions {\n print?: boolean;\n write?: string;\n config?: string;\n collection: string[];\n}\n\nexport const migrateCommand = new Command('migrate').description(\n 'Manage database migrations',\n);\n\nmigrateCommand\n .command('run')\n .description('Run database migrations')\n .option(\n '-cs, --connection-string <string>',\n 'Connection string for the database',\n )\n .option(\n '-col, --collection <name>',\n 'Specify the collection name',\n (value: string, previous: string[]) => {\n // Accumulate collection names into an array (explicitly typing `previous` as `string[]`)\n return previous.concat([value]);\n },\n [] as string[],\n )\n .option('-f, --config <path>', 'Path to configuration file with Pongo config')\n .option('-dr, --dryRun', 'Perform dry run without commiting changes', false)\n .action(async (options: MigrateRunOptions) => {\n const { collection, dryRun } = options;\n const connectionString =\n options.connectionString ?? process.env.DB_CONNECTION_STRING;\n let collectionNames: string[];\n\n if (!connectionString) {\n console.error(\n 'Error: Connection string is required. Provide it either as a \"--connection-string\" parameter or through the DB_CONNECTION_STRING environment variable.' +\n '\\nFor instance: --connection-string postgresql://postgres:postgres@localhost:5432/postgres',\n );\n process.exit(1);\n }\n\n if (options.config) {\n const config = await loadConfigFile(options.config);\n\n collectionNames = config.collections.map((c) => c.name);\n } else if (collection) {\n collectionNames = collection;\n } else {\n console.error(\n 'Error: You need to provide at least one collection name. Provide it either through \"--config\" file or as a \"--collection\" parameter.',\n );\n process.exit(1);\n }\n\n const pool = dumbo({ connectionString });\n\n const migrations = collectionNames.flatMap((collectionsName) =>\n pongoCollectionSchemaComponent(collectionsName).migrations({\n connector: 'PostgreSQL:pg', // TODO: Provide connector here\n }),\n );\n\n await runPostgreSQLMigrations(pool, migrations, {\n dryRun,\n });\n });\n\nmigrateCommand\n .command('sql')\n .description('Generate SQL for database migration')\n .option(\n '-col, --collection <name>',\n 'Specify the collection name',\n (value: string, previous: string[]) => {\n // Accumulate collection names into an array (explicitly typing `previous` as `string[]`)\n return previous.concat([value]);\n },\n [] as string[],\n )\n .option('-f, --config <path>', 'Path to configuration file with Pongo config')\n .option('--print', 'Print the SQL to the console (default)', true)\n //.option('--write <filename>', 'Write the SQL to a specified file')\n .action(async (options: MigrateSqlOptions) => {\n const { collection } = options;\n\n let collectionNames: string[];\n\n if (options.config) {\n const config = await loadConfigFile(options.config);\n\n collectionNames = config.collections.map((c) => c.name);\n } else if (collection) {\n collectionNames = collection;\n } else {\n console.error(\n 'Error: You need to provide at least one collection name. Provide it either through \"--config\" file or as a \"--collection\" parameter.',\n );\n process.exit(1);\n }\n\n const coreMigrations = migrationTableSchemaComponent.migrations({\n connector: 'PostgreSQL:pg',\n });\n const migrations = [\n ...coreMigrations,\n ...collectionNames.flatMap((collectionName) =>\n pongoCollectionSchemaComponent(collectionName).migrations({\n connector: 'PostgreSQL:pg', // TODO: Provide connector here\n }),\n ),\n ];\n\n console.log('Printing SQL:');\n console.log(combineMigrations(...migrations));\n });\n","import {\n checkConnection,\n color,\n LogLevel,\n LogStyle,\n prettyJson,\n SQL,\n type MigrationStyle,\n} from '@event-driven-io/dumbo';\nimport Table from 'cli-table3';\nimport { Command } from 'commander';\nimport repl from 'node:repl';\nimport {\n pongoClient,\n pongoSchema,\n type PongoClient,\n type PongoCollectionSchema,\n type PongoDb,\n} from '../core';\n\nlet pongo: PongoClient;\n\nconst calculateColumnWidths = (\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n results: any[],\n columnNames: string[],\n): number[] => {\n const columnWidths = columnNames.map((col) => {\n const maxWidth = Math.max(\n col.length, // Header size\n ...results.map((result) =>\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n result[col] ? String(result[col]).length : 0,\n ),\n );\n return maxWidth + 2; // Add padding\n });\n return columnWidths;\n};\n\nlet shouldDisplayResultsAsTable = false;\n\nconst printResultsAsTable = (print?: boolean) =>\n (shouldDisplayResultsAsTable = print === undefined || print === true);\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst printOutput = (obj: any): string =>\n Array.isArray(obj) && shouldDisplayResultsAsTable\n ? displayResultsAsTable(obj)\n : prettyJson(obj);\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst displayResultsAsTable = (results: any[]): string => {\n if (results.length === 0) {\n return color.yellow('No documents found.');\n }\n\n const columnNames = results\n\n .flatMap((result) =>\n // eslint-disable-next-line @typescript-eslint/no-unsafe-argument\n typeof result === 'object' ? Object.keys(result) : typeof result,\n )\n .filter((value, index, array) => array.indexOf(value) === index);\n\n const columnWidths = calculateColumnWidths(results, columnNames);\n\n const table = new Table({\n head: columnNames.map((col) => color.cyan(col)),\n colWidths: columnWidths,\n });\n\n results.forEach((result) => {\n table.push(\n columnNames.map((col) =>\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n result[col] !== undefined\n ? // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n Array.isArray(result[col])\n ? // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n displayResultsAsTable(result[col])\n : // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n prettyJson(result[col])\n : typeof result === 'object'\n ? ''\n : result != undefined && result != undefined\n ? prettyJson(result)\n : '',\n ),\n );\n });\n\n return table.toString();\n};\n\nconst setLogLevel = (logLevel: string) => {\n process.env.DUMBO_LOG_LEVEL = logLevel;\n};\n\nconst setLogStyle = (logLevel: string) => {\n process.env.DUMBO_LOG_STYLE = logLevel;\n};\n\nconst prettifyLogs = (logLevel?: string) => {\n if (logLevel !== undefined) setLogLevel(logLevel);\n setLogStyle(LogStyle.PRETTY);\n};\n\nconst startRepl = async (options: {\n logging: {\n printOptions: boolean;\n logLevel: LogLevel;\n logStyle: LogStyle;\n };\n schema: {\n database: string;\n collections: string[];\n autoMigration: MigrationStyle;\n };\n connectionString: string | undefined;\n}) => {\n // TODO: This will change when we have proper tracing and logging config\n // For now, that's enough\n setLogLevel(process.env.DUMBO_LOG_LEVEL ?? options.logging.logLevel);\n setLogStyle(process.env.DUMBO_LOG_STYLE ?? options.logging.logStyle);\n\n console.log(color.green('Starting Pongo Shell (version: 0.16.9)'));\n\n if (options.logging.printOptions) {\n console.log(color.green('With Options:'));\n console.log(prettyJson(options));\n }\n\n const connectionString =\n options.connectionString ??\n process.env.DB_CONNECTION_STRING ??\n 'postgresql://postgres:postgres@localhost:5432/postgres';\n\n if (!(options.connectionString ?? process.env.DB_CONNECTION_STRING)) {\n console.log(\n color.yellow(\n `No connection string provided, using: 'postgresql://postgres:postgres@localhost:5432/postgres'`,\n ),\n );\n }\n\n const connectionCheck = await checkConnection(connectionString);\n\n if (!connectionCheck.successful) {\n if (connectionCheck.errorType === 'ConnectionRefused') {\n console.error(\n color.red(\n `Connection was refused. Check if the PostgreSQL server is running and accessible.`,\n ),\n );\n } else if (connectionCheck.errorType === 'Authentication') {\n console.error(\n color.red(\n `Authentication failed. Check the username and password in the connection string.`,\n ),\n );\n } else {\n console.error(color.red('Error connecting to PostgreSQL server'));\n }\n console.log(color.red('Exiting Pongo Shell...'));\n process.exit();\n }\n\n console.log(color.green(`Successfully connected`));\n console.log(color.green('Use db.<collection>.<method>() to query.'));\n\n const shell = repl.start({\n prompt: color.green('pongo> '),\n useGlobal: true,\n breakEvalOnSigint: true,\n writer: printOutput,\n });\n\n let db: PongoDb;\n\n if (options.schema.collections.length > 0) {\n const collectionsSchema: Record<string, PongoCollectionSchema> = {};\n\n for (const collectionName of options.schema.collections) {\n collectionsSchema[collectionName] =\n pongoSchema.collection(collectionName);\n }\n\n const schema = pongoSchema.client({\n database: pongoSchema.db(options.schema.database, collectionsSchema),\n });\n\n const typedClient = pongoClient(connectionString, {\n schema: {\n definition: schema,\n autoMigration: options.schema.autoMigration,\n },\n });\n\n db = typedClient.database;\n\n for (const collectionName of options.schema.collections) {\n shell.context[collectionName] = typedClient.database[collectionName];\n }\n\n pongo = typedClient;\n } else {\n pongo = pongoClient(connectionString, {\n schema: { autoMigration: options.schema.autoMigration },\n });\n\n db = pongo.db(options.schema.database);\n }\n\n shell.context.pongo = pongo;\n shell.context.db = db;\n\n // helpers\n shell.context.SQL = SQL;\n shell.context.setLogLevel = setLogLevel;\n shell.context.setLogStyle = setLogStyle;\n shell.context.prettifyLogs = prettifyLogs;\n shell.context.printResultsAsTable = printResultsAsTable;\n shell.context.LogStyle = LogStyle;\n shell.context.LogLevel = LogLevel;\n\n // Intercept REPL output to display results as a table if they are arrays\n shell.on('exit', async () => {\n await teardown();\n process.exit();\n });\n\n shell.on('SIGINT', async () => {\n await teardown();\n process.exit();\n });\n};\n\nconst teardown = async () => {\n console.log(color.yellow('Exiting Pongo Shell...'));\n await pongo.close();\n};\n\nprocess.on('uncaughtException', teardown);\nprocess.on('SIGINT', teardown);\n\ninterface ShellOptions {\n database: string;\n collection: string[];\n connectionString?: string;\n disableAutoMigrations: boolean;\n logStyle?: string;\n logLevel?: string;\n prettyLog?: boolean;\n printOptions?: boolean;\n}\n\nconst shellCommand = new Command('shell')\n .description('Start an interactive Pongo shell')\n .option(\n '-cs, --connectionString <string>',\n 'Connection string for the database',\n )\n .option('-db, --database <string>', 'Database name to connect', 'postgres')\n .option(\n '-col, --collection <name>',\n 'Specify the collection name',\n (value: string, previous: string[]) => {\n // Accumulate collection names into an array (explicitly typing `previous` as `string[]`)\n return previous.concat([value]);\n },\n [] as string[],\n )\n .option(\n '-no-migrations, --disable-auto-migrations',\n 'Disable automatic migrations',\n )\n .option('-o, --print-options', 'Print shell options')\n .option(\n '-ll, --log-level <logLevel>',\n 'Log level: DISABLED, INFO, LOG, WARN, ERROR',\n 'DISABLED',\n )\n .option('-ls, --log-style', 'Log style: RAW, PRETTY', 'RAW')\n .option('-p, --pretty-log', 'Turn on logging with prettified output')\n .action(async (options: ShellOptions) => {\n const { collection, database } = options;\n const connectionString = options.connectionString;\n\n await startRepl({\n logging: {\n printOptions: options.printOptions === true,\n logStyle: options.prettyLog\n ? LogStyle.PRETTY\n : ((options.logStyle as LogStyle | undefined) ?? LogStyle.RAW),\n logLevel: options.logLevel\n ? (options.logLevel as LogLevel)\n : options.prettyLog\n ? LogLevel.INFO\n : LogLevel.DISABLED,\n },\n schema: {\n collections: collection,\n database,\n autoMigration: options.disableAutoMigrations\n ? 'None'\n : 'CreateOrUpdate',\n },\n connectionString,\n });\n });\n\nexport { shellCommand };\n"]}
1
+ {"version":3,"sources":["/home/runner/work/Pongo/Pongo/src/packages/pongo/dist/cli.cjs","../src/cli.ts","../src/commandLine/configFile.ts","../src/commandLine/migrate.ts","../src/commandLine/shell.ts"],"names":[],"mappings":"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","file":"/home/runner/work/Pongo/Pongo/src/packages/pongo/dist/cli.cjs","sourcesContent":[null,"#!/usr/bin/env node\nimport { Command } from 'commander';\nimport { configCommand, migrateCommand, shellCommand } from './commandLine';\n\nconst program = new Command();\n\nprogram.name('pongo').description('CLI tool for Pongo');\n\nprogram.addCommand(configCommand);\nprogram.addCommand(migrateCommand);\nprogram.addCommand(shellCommand);\n\nprogram.parse(process.argv);\n\nexport default program;\n","import { Command } from 'commander';\nimport fs from 'node:fs';\nimport {\n objectEntries,\n toDbSchemaMetadata,\n type PongoDbSchemaMetadata,\n type PongoSchemaConfig,\n} from '../core';\n\nconst formatTypeName = (input: string): string => {\n if (input.length === 0) {\n return input;\n }\n\n let formatted = input.charAt(0).toUpperCase() + input.slice(1);\n\n if (formatted.endsWith('s')) {\n formatted = formatted.slice(0, -1);\n }\n\n return formatted;\n};\n\nconst sampleConfig = (collectionNames: string[] = ['users']) => {\n const types = collectionNames\n .map(\n (name) =>\n `export type ${formatTypeName(name)} = { name: string; description: string; date: Date }`,\n )\n .join('\\n');\n\n const collections = collectionNames\n .map(\n (name) =>\n ` ${name}: pongoSchema.collection<${formatTypeName(name)}>('${name}'),`,\n )\n .join('\\n');\n\n return `import { pongoSchema } from '@event-driven-io/pongo';\n\n${types}\n\nexport default {\n schema: pongoSchema.client({\n database: pongoSchema.db({\n${collections}\n }),\n }),\n};`;\n};\n\nconst missingDefaultExport = `Error: Config should contain default export, e.g.\\n\\n${sampleConfig()}`;\nconst missingSchema = `Error: Config should contain schema property, e.g.\\n\\n${sampleConfig()}`;\nconst missingDbs = `Error: Config should have at least a single database defined, e.g.\\n\\n${sampleConfig()}`;\nconst missingDefaultDb = `Error: Config should have a default database defined (without name or or with default database name), e.g.\\n\\n${sampleConfig()}`;\nconst missingCollections = `Error: Database should have defined at least one collection, e.g.\\n\\n${sampleConfig()}`;\n\nexport const loadConfigFile = async (\n configPath: string,\n): Promise<PongoDbSchemaMetadata> => {\n const configUrl = new URL(configPath, `file://${process.cwd()}/`);\n try {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n const imported: Partial<{ default: PongoSchemaConfig }> = await import(\n configUrl.href\n );\n\n const parsed = parseDefaultDbSchema(imported);\n\n if (typeof parsed === 'string') {\n console.error(parsed);\n process.exit(1);\n }\n\n return parsed;\n } catch {\n console.error(`Error: Couldn't load file: ${configUrl.href}`);\n process.exit(1);\n }\n};\n\nexport const generateConfigFile = (\n configPath: string,\n collectionNames: string[],\n): void => {\n try {\n fs.writeFileSync(configPath, sampleConfig(collectionNames), 'utf8');\n console.log(`Configuration file stored at: ${configPath}`);\n } catch (error) {\n console.error(`Error: Couldn't store config file: ${configPath}!`);\n console.error(error);\n process.exit(1);\n }\n};\n\nexport const parseDefaultDbSchema = (\n imported: Partial<{ default: PongoSchemaConfig }>,\n): PongoDbSchemaMetadata | string => {\n if (!imported.default) {\n return missingDefaultExport;\n }\n\n if (!imported.default.schema) {\n return missingSchema;\n }\n\n if (!imported.default.schema.dbs) {\n return missingDbs;\n }\n\n const dbs = objectEntries(imported.default.schema.dbs).map((db) => db[1]);\n\n const defaultDb = dbs.find((db) => db.name === undefined);\n\n if (!defaultDb) {\n return missingDefaultDb;\n }\n\n if (!defaultDb.collections) {\n return missingCollections;\n }\n\n const collections = objectEntries(defaultDb.collections).map((col) => col[1]);\n\n if (collections.length === 0) {\n return missingCollections;\n }\n\n return toDbSchemaMetadata(defaultDb);\n};\n\ntype SampleConfigOptions =\n | {\n collection: string[];\n print?: boolean;\n }\n | {\n collection: string[];\n generate?: boolean;\n file?: string;\n };\n\nexport const configCommand = new Command('config').description(\n 'Manage Pongo configuration',\n);\n\nconfigCommand\n .command('sample')\n .description('Generate or print sample configuration')\n .option(\n '-col, --collection <name>',\n 'Specify the collection name',\n (value: string, previous: string[]) => {\n // Accumulate collection names into an array (explicitly typing `previous` as `string[]`)\n return previous.concat([value]);\n },\n [] as string[],\n )\n .option(\n '-f, --file <path>',\n 'Path to configuration file with collection list',\n )\n .option('-g, --generate', 'Generate sample config file')\n .option('-p, --print', 'Print sample config file')\n .action((options: SampleConfigOptions) => {\n const collectionNames =\n options.collection.length > 0 ? options.collection : ['users'];\n\n if (!('print' in options) && !('generate' in options)) {\n console.error(\n 'Error: Please provide either:\\n--print param to print sample config or\\n--generate to generate sample config file',\n );\n process.exit(1);\n }\n\n if ('print' in options) {\n console.log(`${sampleConfig(collectionNames)}`);\n } else if ('generate' in options) {\n if (!options.file) {\n console.error(\n 'Error: You need to provide a config file through a --file',\n );\n process.exit(1);\n }\n\n generateConfigFile(options.file, collectionNames);\n }\n });\n","import {\n combineMigrations,\n dumbo,\n migrationTableSchemaComponent,\n runPostgreSQLMigrations,\n} from '@event-driven-io/dumbo';\nimport { Command } from 'commander';\nimport { pongoCollectionSchemaComponent } from '../core';\nimport { loadConfigFile } from './configFile';\n\ninterface MigrateRunOptions {\n collection: string[];\n connectionString: string;\n config?: string;\n dryRun?: boolean;\n}\n\ninterface MigrateSqlOptions {\n print?: boolean;\n write?: string;\n config?: string;\n collection: string[];\n}\n\nexport const migrateCommand = new Command('migrate').description(\n 'Manage database migrations',\n);\n\nmigrateCommand\n .command('run')\n .description('Run database migrations')\n .option(\n '-cs, --connection-string <string>',\n 'Connection string for the database',\n )\n .option(\n '-col, --collection <name>',\n 'Specify the collection name',\n (value: string, previous: string[]) => {\n // Accumulate collection names into an array (explicitly typing `previous` as `string[]`)\n return previous.concat([value]);\n },\n [] as string[],\n )\n .option('-f, --config <path>', 'Path to configuration file with Pongo config')\n .option('-dr, --dryRun', 'Perform dry run without commiting changes', false)\n .action(async (options: MigrateRunOptions) => {\n const { collection, dryRun } = options;\n const connectionString =\n options.connectionString ?? process.env.DB_CONNECTION_STRING;\n let collectionNames: string[];\n\n if (!connectionString) {\n console.error(\n 'Error: Connection string is required. Provide it either as a \"--connection-string\" parameter or through the DB_CONNECTION_STRING environment variable.' +\n '\\nFor instance: --connection-string postgresql://postgres:postgres@localhost:5432/postgres',\n );\n process.exit(1);\n }\n\n if (options.config) {\n const config = await loadConfigFile(options.config);\n\n collectionNames = config.collections.map((c) => c.name);\n } else if (collection) {\n collectionNames = collection;\n } else {\n console.error(\n 'Error: You need to provide at least one collection name. Provide it either through \"--config\" file or as a \"--collection\" parameter.',\n );\n process.exit(1);\n }\n\n const pool = dumbo({ connectionString });\n\n const migrations = collectionNames.flatMap((collectionsName) =>\n pongoCollectionSchemaComponent(collectionsName).migrations({\n connector: 'PostgreSQL:pg', // TODO: Provide connector here\n }),\n );\n\n await runPostgreSQLMigrations(pool, migrations, {\n dryRun,\n });\n });\n\nmigrateCommand\n .command('sql')\n .description('Generate SQL for database migration')\n .option(\n '-col, --collection <name>',\n 'Specify the collection name',\n (value: string, previous: string[]) => {\n // Accumulate collection names into an array (explicitly typing `previous` as `string[]`)\n return previous.concat([value]);\n },\n [] as string[],\n )\n .option('-f, --config <path>', 'Path to configuration file with Pongo config')\n .option('--print', 'Print the SQL to the console (default)', true)\n //.option('--write <filename>', 'Write the SQL to a specified file')\n .action(async (options: MigrateSqlOptions) => {\n const { collection } = options;\n\n let collectionNames: string[];\n\n if (options.config) {\n const config = await loadConfigFile(options.config);\n\n collectionNames = config.collections.map((c) => c.name);\n } else if (collection) {\n collectionNames = collection;\n } else {\n console.error(\n 'Error: You need to provide at least one collection name. Provide it either through \"--config\" file or as a \"--collection\" parameter.',\n );\n process.exit(1);\n }\n\n const coreMigrations = migrationTableSchemaComponent.migrations({\n connector: 'PostgreSQL:pg',\n });\n const migrations = [\n ...coreMigrations,\n ...collectionNames.flatMap((collectionName) =>\n pongoCollectionSchemaComponent(collectionName).migrations({\n connector: 'PostgreSQL:pg', // TODO: Provide connector here\n }),\n ),\n ];\n\n console.log('Printing SQL:');\n console.log(combineMigrations(...migrations));\n });\n","import {\n checkConnection,\n color,\n LogLevel,\n LogStyle,\n prettyJson,\n SQL,\n type MigrationStyle,\n} from '@event-driven-io/dumbo';\nimport Table from 'cli-table3';\nimport { Command } from 'commander';\nimport repl from 'node:repl';\nimport {\n pongoClient,\n pongoSchema,\n type PongoClient,\n type PongoCollectionSchema,\n type PongoDb,\n} from '../core';\n\nlet pongo: PongoClient;\n\nconst calculateColumnWidths = (\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n results: any[],\n columnNames: string[],\n): number[] => {\n const columnWidths = columnNames.map((col) => {\n const maxWidth = Math.max(\n col.length, // Header size\n ...results.map((result) =>\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n result[col] ? String(result[col]).length : 0,\n ),\n );\n return maxWidth + 2; // Add padding\n });\n return columnWidths;\n};\n\nlet shouldDisplayResultsAsTable = false;\n\nconst printResultsAsTable = (print?: boolean) =>\n (shouldDisplayResultsAsTable = print === undefined || print === true);\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst printOutput = (obj: any): string =>\n Array.isArray(obj) && shouldDisplayResultsAsTable\n ? displayResultsAsTable(obj)\n : prettyJson(obj);\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst displayResultsAsTable = (results: any[]): string => {\n if (results.length === 0) {\n return color.yellow('No documents found.');\n }\n\n const columnNames = results\n\n .flatMap((result) =>\n // eslint-disable-next-line @typescript-eslint/no-unsafe-argument\n typeof result === 'object' ? Object.keys(result) : typeof result,\n )\n .filter((value, index, array) => array.indexOf(value) === index);\n\n const columnWidths = calculateColumnWidths(results, columnNames);\n\n const table = new Table({\n head: columnNames.map((col) => color.cyan(col)),\n colWidths: columnWidths,\n });\n\n results.forEach((result) => {\n table.push(\n columnNames.map((col) =>\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n result[col] !== undefined\n ? // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n Array.isArray(result[col])\n ? // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n displayResultsAsTable(result[col])\n : // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n prettyJson(result[col])\n : typeof result === 'object'\n ? ''\n : result != undefined && result != undefined\n ? prettyJson(result)\n : '',\n ),\n );\n });\n\n return table.toString();\n};\n\nconst setLogLevel = (logLevel: string) => {\n process.env.DUMBO_LOG_LEVEL = logLevel;\n};\n\nconst setLogStyle = (logLevel: string) => {\n process.env.DUMBO_LOG_STYLE = logLevel;\n};\n\nconst prettifyLogs = (logLevel?: string) => {\n if (logLevel !== undefined) setLogLevel(logLevel);\n setLogStyle(LogStyle.PRETTY);\n};\n\nconst startRepl = async (options: {\n logging: {\n printOptions: boolean;\n logLevel: LogLevel;\n logStyle: LogStyle;\n };\n schema: {\n database: string;\n collections: string[];\n autoMigration: MigrationStyle;\n };\n connectionString: string | undefined;\n}) => {\n // TODO: This will change when we have proper tracing and logging config\n // For now, that's enough\n setLogLevel(process.env.DUMBO_LOG_LEVEL ?? options.logging.logLevel);\n setLogStyle(process.env.DUMBO_LOG_STYLE ?? options.logging.logStyle);\n\n console.log(color.green('Starting Pongo Shell (version: 0.16.10)'));\n\n if (options.logging.printOptions) {\n console.log(color.green('With Options:'));\n console.log(prettyJson(options));\n }\n\n const connectionString =\n options.connectionString ??\n process.env.DB_CONNECTION_STRING ??\n 'postgresql://postgres:postgres@localhost:5432/postgres';\n\n if (!(options.connectionString ?? process.env.DB_CONNECTION_STRING)) {\n console.log(\n color.yellow(\n `No connection string provided, using: 'postgresql://postgres:postgres@localhost:5432/postgres'`,\n ),\n );\n }\n\n const connectionCheck = await checkConnection(connectionString);\n\n if (!connectionCheck.successful) {\n if (connectionCheck.errorType === 'ConnectionRefused') {\n console.error(\n color.red(\n `Connection was refused. Check if the PostgreSQL server is running and accessible.`,\n ),\n );\n } else if (connectionCheck.errorType === 'Authentication') {\n console.error(\n color.red(\n `Authentication failed. Check the username and password in the connection string.`,\n ),\n );\n } else {\n console.error(color.red('Error connecting to PostgreSQL server'));\n }\n console.log(color.red('Exiting Pongo Shell...'));\n process.exit();\n }\n\n console.log(color.green(`Successfully connected`));\n console.log(color.green('Use db.<collection>.<method>() to query.'));\n\n const shell = repl.start({\n prompt: color.green('pongo> '),\n useGlobal: true,\n breakEvalOnSigint: true,\n writer: printOutput,\n });\n\n let db: PongoDb;\n\n if (options.schema.collections.length > 0) {\n const collectionsSchema: Record<string, PongoCollectionSchema> = {};\n\n for (const collectionName of options.schema.collections) {\n collectionsSchema[collectionName] =\n pongoSchema.collection(collectionName);\n }\n\n const schema = pongoSchema.client({\n database: pongoSchema.db(options.schema.database, collectionsSchema),\n });\n\n const typedClient = pongoClient(connectionString, {\n schema: {\n definition: schema,\n autoMigration: options.schema.autoMigration,\n },\n });\n\n db = typedClient.database;\n\n for (const collectionName of options.schema.collections) {\n shell.context[collectionName] = typedClient.database[collectionName];\n }\n\n pongo = typedClient;\n } else {\n pongo = pongoClient(connectionString, {\n schema: { autoMigration: options.schema.autoMigration },\n });\n\n db = pongo.db(options.schema.database);\n }\n\n shell.context.pongo = pongo;\n shell.context.db = db;\n\n // helpers\n shell.context.SQL = SQL;\n shell.context.setLogLevel = setLogLevel;\n shell.context.setLogStyle = setLogStyle;\n shell.context.prettifyLogs = prettifyLogs;\n shell.context.printResultsAsTable = printResultsAsTable;\n shell.context.LogStyle = LogStyle;\n shell.context.LogLevel = LogLevel;\n\n // Intercept REPL output to display results as a table if they are arrays\n shell.on('exit', async () => {\n await teardown();\n process.exit();\n });\n\n shell.on('SIGINT', async () => {\n await teardown();\n process.exit();\n });\n};\n\nconst teardown = async () => {\n console.log(color.yellow('Exiting Pongo Shell...'));\n await pongo.close();\n};\n\nprocess.on('uncaughtException', teardown);\nprocess.on('SIGINT', teardown);\n\ninterface ShellOptions {\n database: string;\n collection: string[];\n connectionString?: string;\n disableAutoMigrations: boolean;\n logStyle?: string;\n logLevel?: string;\n prettyLog?: boolean;\n printOptions?: boolean;\n}\n\nconst shellCommand = new Command('shell')\n .description('Start an interactive Pongo shell')\n .option(\n '-cs, --connectionString <string>',\n 'Connection string for the database',\n )\n .option('-db, --database <string>', 'Database name to connect', 'postgres')\n .option(\n '-col, --collection <name>',\n 'Specify the collection name',\n (value: string, previous: string[]) => {\n // Accumulate collection names into an array (explicitly typing `previous` as `string[]`)\n return previous.concat([value]);\n },\n [] as string[],\n )\n .option(\n '-no-migrations, --disable-auto-migrations',\n 'Disable automatic migrations',\n )\n .option('-o, --print-options', 'Print shell options')\n .option(\n '-ll, --log-level <logLevel>',\n 'Log level: DISABLED, INFO, LOG, WARN, ERROR',\n 'DISABLED',\n )\n .option('-ls, --log-style', 'Log style: RAW, PRETTY', 'RAW')\n .option('-p, --pretty-log', 'Turn on logging with prettified output')\n .action(async (options: ShellOptions) => {\n const { collection, database } = options;\n const connectionString = options.connectionString;\n\n await startRepl({\n logging: {\n printOptions: options.printOptions === true,\n logStyle: options.prettyLog\n ? LogStyle.PRETTY\n : ((options.logStyle as LogStyle | undefined) ?? LogStyle.RAW),\n logLevel: options.logLevel\n ? (options.logLevel as LogLevel)\n : options.prettyLog\n ? LogLevel.INFO\n : LogLevel.DISABLED,\n },\n schema: {\n collections: collection,\n database,\n autoMigration: options.disableAutoMigrations\n ? 'None'\n : 'CreateOrUpdate',\n },\n connectionString,\n });\n });\n\nexport { shellCommand };\n"]}
package/dist/cli.js CHANGED
@@ -5,7 +5,7 @@ import {
5
5
  pongoCollectionSchemaComponent,
6
6
  pongoSchema,
7
7
  toDbSchemaMetadata
8
- } from "./chunk-2YS3A7WH.js";
8
+ } from "./chunk-NBYHLHUE.js";
9
9
 
10
10
  // src/cli.ts
11
11
  import { Command as Command4 } from "commander";
@@ -310,7 +310,7 @@ var prettifyLogs = (logLevel) => {
310
310
  var startRepl = async (options) => {
311
311
  setLogLevel(process.env.DUMBO_LOG_LEVEL ?? options.logging.logLevel);
312
312
  setLogStyle(process.env.DUMBO_LOG_STYLE ?? options.logging.logStyle);
313
- console.log(color.green("Starting Pongo Shell (version: 0.16.9)"));
313
+ console.log(color.green("Starting Pongo Shell (version: 0.16.10)"));
314
314
  if (options.logging.printOptions) {
315
315
  console.log(color.green("With Options:"));
316
316
  console.log(prettyJson(options));
package/dist/cli.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/cli.ts","../src/commandLine/configFile.ts","../src/commandLine/migrate.ts","../src/commandLine/shell.ts"],"sourcesContent":["#!/usr/bin/env node\nimport { Command } from 'commander';\nimport { configCommand, migrateCommand, shellCommand } from './commandLine';\n\nconst program = new Command();\n\nprogram.name('pongo').description('CLI tool for Pongo');\n\nprogram.addCommand(configCommand);\nprogram.addCommand(migrateCommand);\nprogram.addCommand(shellCommand);\n\nprogram.parse(process.argv);\n\nexport default program;\n","import { Command } from 'commander';\nimport fs from 'node:fs';\nimport {\n objectEntries,\n toDbSchemaMetadata,\n type PongoDbSchemaMetadata,\n type PongoSchemaConfig,\n} from '../core';\n\nconst formatTypeName = (input: string): string => {\n if (input.length === 0) {\n return input;\n }\n\n let formatted = input.charAt(0).toUpperCase() + input.slice(1);\n\n if (formatted.endsWith('s')) {\n formatted = formatted.slice(0, -1);\n }\n\n return formatted;\n};\n\nconst sampleConfig = (collectionNames: string[] = ['users']) => {\n const types = collectionNames\n .map(\n (name) =>\n `export type ${formatTypeName(name)} = { name: string; description: string; date: Date }`,\n )\n .join('\\n');\n\n const collections = collectionNames\n .map(\n (name) =>\n ` ${name}: pongoSchema.collection<${formatTypeName(name)}>('${name}'),`,\n )\n .join('\\n');\n\n return `import { pongoSchema } from '@event-driven-io/pongo';\n\n${types}\n\nexport default {\n schema: pongoSchema.client({\n database: pongoSchema.db({\n${collections}\n }),\n }),\n};`;\n};\n\nconst missingDefaultExport = `Error: Config should contain default export, e.g.\\n\\n${sampleConfig()}`;\nconst missingSchema = `Error: Config should contain schema property, e.g.\\n\\n${sampleConfig()}`;\nconst missingDbs = `Error: Config should have at least a single database defined, e.g.\\n\\n${sampleConfig()}`;\nconst missingDefaultDb = `Error: Config should have a default database defined (without name or or with default database name), e.g.\\n\\n${sampleConfig()}`;\nconst missingCollections = `Error: Database should have defined at least one collection, e.g.\\n\\n${sampleConfig()}`;\n\nexport const loadConfigFile = async (\n configPath: string,\n): Promise<PongoDbSchemaMetadata> => {\n const configUrl = new URL(configPath, `file://${process.cwd()}/`);\n try {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n const imported: Partial<{ default: PongoSchemaConfig }> = await import(\n configUrl.href\n );\n\n const parsed = parseDefaultDbSchema(imported);\n\n if (typeof parsed === 'string') {\n console.error(parsed);\n process.exit(1);\n }\n\n return parsed;\n } catch {\n console.error(`Error: Couldn't load file: ${configUrl.href}`);\n process.exit(1);\n }\n};\n\nexport const generateConfigFile = (\n configPath: string,\n collectionNames: string[],\n): void => {\n try {\n fs.writeFileSync(configPath, sampleConfig(collectionNames), 'utf8');\n console.log(`Configuration file stored at: ${configPath}`);\n } catch (error) {\n console.error(`Error: Couldn't store config file: ${configPath}!`);\n console.error(error);\n process.exit(1);\n }\n};\n\nexport const parseDefaultDbSchema = (\n imported: Partial<{ default: PongoSchemaConfig }>,\n): PongoDbSchemaMetadata | string => {\n if (!imported.default) {\n return missingDefaultExport;\n }\n\n if (!imported.default.schema) {\n return missingSchema;\n }\n\n if (!imported.default.schema.dbs) {\n return missingDbs;\n }\n\n const dbs = objectEntries(imported.default.schema.dbs).map((db) => db[1]);\n\n const defaultDb = dbs.find((db) => db.name === undefined);\n\n if (!defaultDb) {\n return missingDefaultDb;\n }\n\n if (!defaultDb.collections) {\n return missingCollections;\n }\n\n const collections = objectEntries(defaultDb.collections).map((col) => col[1]);\n\n if (collections.length === 0) {\n return missingCollections;\n }\n\n return toDbSchemaMetadata(defaultDb);\n};\n\ntype SampleConfigOptions =\n | {\n collection: string[];\n print?: boolean;\n }\n | {\n collection: string[];\n generate?: boolean;\n file?: string;\n };\n\nexport const configCommand = new Command('config').description(\n 'Manage Pongo configuration',\n);\n\nconfigCommand\n .command('sample')\n .description('Generate or print sample configuration')\n .option(\n '-col, --collection <name>',\n 'Specify the collection name',\n (value: string, previous: string[]) => {\n // Accumulate collection names into an array (explicitly typing `previous` as `string[]`)\n return previous.concat([value]);\n },\n [] as string[],\n )\n .option(\n '-f, --file <path>',\n 'Path to configuration file with collection list',\n )\n .option('-g, --generate', 'Generate sample config file')\n .option('-p, --print', 'Print sample config file')\n .action((options: SampleConfigOptions) => {\n const collectionNames =\n options.collection.length > 0 ? options.collection : ['users'];\n\n if (!('print' in options) && !('generate' in options)) {\n console.error(\n 'Error: Please provide either:\\n--print param to print sample config or\\n--generate to generate sample config file',\n );\n process.exit(1);\n }\n\n if ('print' in options) {\n console.log(`${sampleConfig(collectionNames)}`);\n } else if ('generate' in options) {\n if (!options.file) {\n console.error(\n 'Error: You need to provide a config file through a --file',\n );\n process.exit(1);\n }\n\n generateConfigFile(options.file, collectionNames);\n }\n });\n","import {\n combineMigrations,\n dumbo,\n migrationTableSchemaComponent,\n runPostgreSQLMigrations,\n} from '@event-driven-io/dumbo';\nimport { Command } from 'commander';\nimport { pongoCollectionSchemaComponent } from '../core';\nimport { loadConfigFile } from './configFile';\n\ninterface MigrateRunOptions {\n collection: string[];\n connectionString: string;\n config?: string;\n dryRun?: boolean;\n}\n\ninterface MigrateSqlOptions {\n print?: boolean;\n write?: string;\n config?: string;\n collection: string[];\n}\n\nexport const migrateCommand = new Command('migrate').description(\n 'Manage database migrations',\n);\n\nmigrateCommand\n .command('run')\n .description('Run database migrations')\n .option(\n '-cs, --connection-string <string>',\n 'Connection string for the database',\n )\n .option(\n '-col, --collection <name>',\n 'Specify the collection name',\n (value: string, previous: string[]) => {\n // Accumulate collection names into an array (explicitly typing `previous` as `string[]`)\n return previous.concat([value]);\n },\n [] as string[],\n )\n .option('-f, --config <path>', 'Path to configuration file with Pongo config')\n .option('-dr, --dryRun', 'Perform dry run without commiting changes', false)\n .action(async (options: MigrateRunOptions) => {\n const { collection, dryRun } = options;\n const connectionString =\n options.connectionString ?? process.env.DB_CONNECTION_STRING;\n let collectionNames: string[];\n\n if (!connectionString) {\n console.error(\n 'Error: Connection string is required. Provide it either as a \"--connection-string\" parameter or through the DB_CONNECTION_STRING environment variable.' +\n '\\nFor instance: --connection-string postgresql://postgres:postgres@localhost:5432/postgres',\n );\n process.exit(1);\n }\n\n if (options.config) {\n const config = await loadConfigFile(options.config);\n\n collectionNames = config.collections.map((c) => c.name);\n } else if (collection) {\n collectionNames = collection;\n } else {\n console.error(\n 'Error: You need to provide at least one collection name. Provide it either through \"--config\" file or as a \"--collection\" parameter.',\n );\n process.exit(1);\n }\n\n const pool = dumbo({ connectionString });\n\n const migrations = collectionNames.flatMap((collectionsName) =>\n pongoCollectionSchemaComponent(collectionsName).migrations({\n connector: 'PostgreSQL:pg', // TODO: Provide connector here\n }),\n );\n\n await runPostgreSQLMigrations(pool, migrations, {\n dryRun,\n });\n });\n\nmigrateCommand\n .command('sql')\n .description('Generate SQL for database migration')\n .option(\n '-col, --collection <name>',\n 'Specify the collection name',\n (value: string, previous: string[]) => {\n // Accumulate collection names into an array (explicitly typing `previous` as `string[]`)\n return previous.concat([value]);\n },\n [] as string[],\n )\n .option('-f, --config <path>', 'Path to configuration file with Pongo config')\n .option('--print', 'Print the SQL to the console (default)', true)\n //.option('--write <filename>', 'Write the SQL to a specified file')\n .action(async (options: MigrateSqlOptions) => {\n const { collection } = options;\n\n let collectionNames: string[];\n\n if (options.config) {\n const config = await loadConfigFile(options.config);\n\n collectionNames = config.collections.map((c) => c.name);\n } else if (collection) {\n collectionNames = collection;\n } else {\n console.error(\n 'Error: You need to provide at least one collection name. Provide it either through \"--config\" file or as a \"--collection\" parameter.',\n );\n process.exit(1);\n }\n\n const coreMigrations = migrationTableSchemaComponent.migrations({\n connector: 'PostgreSQL:pg',\n });\n const migrations = [\n ...coreMigrations,\n ...collectionNames.flatMap((collectionName) =>\n pongoCollectionSchemaComponent(collectionName).migrations({\n connector: 'PostgreSQL:pg', // TODO: Provide connector here\n }),\n ),\n ];\n\n console.log('Printing SQL:');\n console.log(combineMigrations(...migrations));\n });\n","import {\n checkConnection,\n color,\n LogLevel,\n LogStyle,\n prettyJson,\n SQL,\n type MigrationStyle,\n} from '@event-driven-io/dumbo';\nimport Table from 'cli-table3';\nimport { Command } from 'commander';\nimport repl from 'node:repl';\nimport {\n pongoClient,\n pongoSchema,\n type PongoClient,\n type PongoCollectionSchema,\n type PongoDb,\n} from '../core';\n\nlet pongo: PongoClient;\n\nconst calculateColumnWidths = (\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n results: any[],\n columnNames: string[],\n): number[] => {\n const columnWidths = columnNames.map((col) => {\n const maxWidth = Math.max(\n col.length, // Header size\n ...results.map((result) =>\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n result[col] ? String(result[col]).length : 0,\n ),\n );\n return maxWidth + 2; // Add padding\n });\n return columnWidths;\n};\n\nlet shouldDisplayResultsAsTable = false;\n\nconst printResultsAsTable = (print?: boolean) =>\n (shouldDisplayResultsAsTable = print === undefined || print === true);\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst printOutput = (obj: any): string =>\n Array.isArray(obj) && shouldDisplayResultsAsTable\n ? displayResultsAsTable(obj)\n : prettyJson(obj);\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst displayResultsAsTable = (results: any[]): string => {\n if (results.length === 0) {\n return color.yellow('No documents found.');\n }\n\n const columnNames = results\n\n .flatMap((result) =>\n // eslint-disable-next-line @typescript-eslint/no-unsafe-argument\n typeof result === 'object' ? Object.keys(result) : typeof result,\n )\n .filter((value, index, array) => array.indexOf(value) === index);\n\n const columnWidths = calculateColumnWidths(results, columnNames);\n\n const table = new Table({\n head: columnNames.map((col) => color.cyan(col)),\n colWidths: columnWidths,\n });\n\n results.forEach((result) => {\n table.push(\n columnNames.map((col) =>\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n result[col] !== undefined\n ? // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n Array.isArray(result[col])\n ? // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n displayResultsAsTable(result[col])\n : // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n prettyJson(result[col])\n : typeof result === 'object'\n ? ''\n : result != undefined && result != undefined\n ? prettyJson(result)\n : '',\n ),\n );\n });\n\n return table.toString();\n};\n\nconst setLogLevel = (logLevel: string) => {\n process.env.DUMBO_LOG_LEVEL = logLevel;\n};\n\nconst setLogStyle = (logLevel: string) => {\n process.env.DUMBO_LOG_STYLE = logLevel;\n};\n\nconst prettifyLogs = (logLevel?: string) => {\n if (logLevel !== undefined) setLogLevel(logLevel);\n setLogStyle(LogStyle.PRETTY);\n};\n\nconst startRepl = async (options: {\n logging: {\n printOptions: boolean;\n logLevel: LogLevel;\n logStyle: LogStyle;\n };\n schema: {\n database: string;\n collections: string[];\n autoMigration: MigrationStyle;\n };\n connectionString: string | undefined;\n}) => {\n // TODO: This will change when we have proper tracing and logging config\n // For now, that's enough\n setLogLevel(process.env.DUMBO_LOG_LEVEL ?? options.logging.logLevel);\n setLogStyle(process.env.DUMBO_LOG_STYLE ?? options.logging.logStyle);\n\n console.log(color.green('Starting Pongo Shell (version: 0.16.9)'));\n\n if (options.logging.printOptions) {\n console.log(color.green('With Options:'));\n console.log(prettyJson(options));\n }\n\n const connectionString =\n options.connectionString ??\n process.env.DB_CONNECTION_STRING ??\n 'postgresql://postgres:postgres@localhost:5432/postgres';\n\n if (!(options.connectionString ?? process.env.DB_CONNECTION_STRING)) {\n console.log(\n color.yellow(\n `No connection string provided, using: 'postgresql://postgres:postgres@localhost:5432/postgres'`,\n ),\n );\n }\n\n const connectionCheck = await checkConnection(connectionString);\n\n if (!connectionCheck.successful) {\n if (connectionCheck.errorType === 'ConnectionRefused') {\n console.error(\n color.red(\n `Connection was refused. Check if the PostgreSQL server is running and accessible.`,\n ),\n );\n } else if (connectionCheck.errorType === 'Authentication') {\n console.error(\n color.red(\n `Authentication failed. Check the username and password in the connection string.`,\n ),\n );\n } else {\n console.error(color.red('Error connecting to PostgreSQL server'));\n }\n console.log(color.red('Exiting Pongo Shell...'));\n process.exit();\n }\n\n console.log(color.green(`Successfully connected`));\n console.log(color.green('Use db.<collection>.<method>() to query.'));\n\n const shell = repl.start({\n prompt: color.green('pongo> '),\n useGlobal: true,\n breakEvalOnSigint: true,\n writer: printOutput,\n });\n\n let db: PongoDb;\n\n if (options.schema.collections.length > 0) {\n const collectionsSchema: Record<string, PongoCollectionSchema> = {};\n\n for (const collectionName of options.schema.collections) {\n collectionsSchema[collectionName] =\n pongoSchema.collection(collectionName);\n }\n\n const schema = pongoSchema.client({\n database: pongoSchema.db(options.schema.database, collectionsSchema),\n });\n\n const typedClient = pongoClient(connectionString, {\n schema: {\n definition: schema,\n autoMigration: options.schema.autoMigration,\n },\n });\n\n db = typedClient.database;\n\n for (const collectionName of options.schema.collections) {\n shell.context[collectionName] = typedClient.database[collectionName];\n }\n\n pongo = typedClient;\n } else {\n pongo = pongoClient(connectionString, {\n schema: { autoMigration: options.schema.autoMigration },\n });\n\n db = pongo.db(options.schema.database);\n }\n\n shell.context.pongo = pongo;\n shell.context.db = db;\n\n // helpers\n shell.context.SQL = SQL;\n shell.context.setLogLevel = setLogLevel;\n shell.context.setLogStyle = setLogStyle;\n shell.context.prettifyLogs = prettifyLogs;\n shell.context.printResultsAsTable = printResultsAsTable;\n shell.context.LogStyle = LogStyle;\n shell.context.LogLevel = LogLevel;\n\n // Intercept REPL output to display results as a table if they are arrays\n shell.on('exit', async () => {\n await teardown();\n process.exit();\n });\n\n shell.on('SIGINT', async () => {\n await teardown();\n process.exit();\n });\n};\n\nconst teardown = async () => {\n console.log(color.yellow('Exiting Pongo Shell...'));\n await pongo.close();\n};\n\nprocess.on('uncaughtException', teardown);\nprocess.on('SIGINT', teardown);\n\ninterface ShellOptions {\n database: string;\n collection: string[];\n connectionString?: string;\n disableAutoMigrations: boolean;\n logStyle?: string;\n logLevel?: string;\n prettyLog?: boolean;\n printOptions?: boolean;\n}\n\nconst shellCommand = new Command('shell')\n .description('Start an interactive Pongo shell')\n .option(\n '-cs, --connectionString <string>',\n 'Connection string for the database',\n )\n .option('-db, --database <string>', 'Database name to connect', 'postgres')\n .option(\n '-col, --collection <name>',\n 'Specify the collection name',\n (value: string, previous: string[]) => {\n // Accumulate collection names into an array (explicitly typing `previous` as `string[]`)\n return previous.concat([value]);\n },\n [] as string[],\n )\n .option(\n '-no-migrations, --disable-auto-migrations',\n 'Disable automatic migrations',\n )\n .option('-o, --print-options', 'Print shell options')\n .option(\n '-ll, --log-level <logLevel>',\n 'Log level: DISABLED, INFO, LOG, WARN, ERROR',\n 'DISABLED',\n )\n .option('-ls, --log-style', 'Log style: RAW, PRETTY', 'RAW')\n .option('-p, --pretty-log', 'Turn on logging with prettified output')\n .action(async (options: ShellOptions) => {\n const { collection, database } = options;\n const connectionString = options.connectionString;\n\n await startRepl({\n logging: {\n printOptions: options.printOptions === true,\n logStyle: options.prettyLog\n ? LogStyle.PRETTY\n : ((options.logStyle as LogStyle | undefined) ?? LogStyle.RAW),\n logLevel: options.logLevel\n ? (options.logLevel as LogLevel)\n : options.prettyLog\n ? LogLevel.INFO\n : LogLevel.DISABLED,\n },\n schema: {\n collections: collection,\n database,\n autoMigration: options.disableAutoMigrations\n ? 'None'\n : 'CreateOrUpdate',\n },\n connectionString,\n });\n });\n\nexport { shellCommand };\n"],"mappings":"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","names":["Command","Command","Command","Command","Command","Command"]}
1
+ {"version":3,"sources":["../src/cli.ts","../src/commandLine/configFile.ts","../src/commandLine/migrate.ts","../src/commandLine/shell.ts"],"sourcesContent":["#!/usr/bin/env node\nimport { Command } from 'commander';\nimport { configCommand, migrateCommand, shellCommand } from './commandLine';\n\nconst program = new Command();\n\nprogram.name('pongo').description('CLI tool for Pongo');\n\nprogram.addCommand(configCommand);\nprogram.addCommand(migrateCommand);\nprogram.addCommand(shellCommand);\n\nprogram.parse(process.argv);\n\nexport default program;\n","import { Command } from 'commander';\nimport fs from 'node:fs';\nimport {\n objectEntries,\n toDbSchemaMetadata,\n type PongoDbSchemaMetadata,\n type PongoSchemaConfig,\n} from '../core';\n\nconst formatTypeName = (input: string): string => {\n if (input.length === 0) {\n return input;\n }\n\n let formatted = input.charAt(0).toUpperCase() + input.slice(1);\n\n if (formatted.endsWith('s')) {\n formatted = formatted.slice(0, -1);\n }\n\n return formatted;\n};\n\nconst sampleConfig = (collectionNames: string[] = ['users']) => {\n const types = collectionNames\n .map(\n (name) =>\n `export type ${formatTypeName(name)} = { name: string; description: string; date: Date }`,\n )\n .join('\\n');\n\n const collections = collectionNames\n .map(\n (name) =>\n ` ${name}: pongoSchema.collection<${formatTypeName(name)}>('${name}'),`,\n )\n .join('\\n');\n\n return `import { pongoSchema } from '@event-driven-io/pongo';\n\n${types}\n\nexport default {\n schema: pongoSchema.client({\n database: pongoSchema.db({\n${collections}\n }),\n }),\n};`;\n};\n\nconst missingDefaultExport = `Error: Config should contain default export, e.g.\\n\\n${sampleConfig()}`;\nconst missingSchema = `Error: Config should contain schema property, e.g.\\n\\n${sampleConfig()}`;\nconst missingDbs = `Error: Config should have at least a single database defined, e.g.\\n\\n${sampleConfig()}`;\nconst missingDefaultDb = `Error: Config should have a default database defined (without name or or with default database name), e.g.\\n\\n${sampleConfig()}`;\nconst missingCollections = `Error: Database should have defined at least one collection, e.g.\\n\\n${sampleConfig()}`;\n\nexport const loadConfigFile = async (\n configPath: string,\n): Promise<PongoDbSchemaMetadata> => {\n const configUrl = new URL(configPath, `file://${process.cwd()}/`);\n try {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n const imported: Partial<{ default: PongoSchemaConfig }> = await import(\n configUrl.href\n );\n\n const parsed = parseDefaultDbSchema(imported);\n\n if (typeof parsed === 'string') {\n console.error(parsed);\n process.exit(1);\n }\n\n return parsed;\n } catch {\n console.error(`Error: Couldn't load file: ${configUrl.href}`);\n process.exit(1);\n }\n};\n\nexport const generateConfigFile = (\n configPath: string,\n collectionNames: string[],\n): void => {\n try {\n fs.writeFileSync(configPath, sampleConfig(collectionNames), 'utf8');\n console.log(`Configuration file stored at: ${configPath}`);\n } catch (error) {\n console.error(`Error: Couldn't store config file: ${configPath}!`);\n console.error(error);\n process.exit(1);\n }\n};\n\nexport const parseDefaultDbSchema = (\n imported: Partial<{ default: PongoSchemaConfig }>,\n): PongoDbSchemaMetadata | string => {\n if (!imported.default) {\n return missingDefaultExport;\n }\n\n if (!imported.default.schema) {\n return missingSchema;\n }\n\n if (!imported.default.schema.dbs) {\n return missingDbs;\n }\n\n const dbs = objectEntries(imported.default.schema.dbs).map((db) => db[1]);\n\n const defaultDb = dbs.find((db) => db.name === undefined);\n\n if (!defaultDb) {\n return missingDefaultDb;\n }\n\n if (!defaultDb.collections) {\n return missingCollections;\n }\n\n const collections = objectEntries(defaultDb.collections).map((col) => col[1]);\n\n if (collections.length === 0) {\n return missingCollections;\n }\n\n return toDbSchemaMetadata(defaultDb);\n};\n\ntype SampleConfigOptions =\n | {\n collection: string[];\n print?: boolean;\n }\n | {\n collection: string[];\n generate?: boolean;\n file?: string;\n };\n\nexport const configCommand = new Command('config').description(\n 'Manage Pongo configuration',\n);\n\nconfigCommand\n .command('sample')\n .description('Generate or print sample configuration')\n .option(\n '-col, --collection <name>',\n 'Specify the collection name',\n (value: string, previous: string[]) => {\n // Accumulate collection names into an array (explicitly typing `previous` as `string[]`)\n return previous.concat([value]);\n },\n [] as string[],\n )\n .option(\n '-f, --file <path>',\n 'Path to configuration file with collection list',\n )\n .option('-g, --generate', 'Generate sample config file')\n .option('-p, --print', 'Print sample config file')\n .action((options: SampleConfigOptions) => {\n const collectionNames =\n options.collection.length > 0 ? options.collection : ['users'];\n\n if (!('print' in options) && !('generate' in options)) {\n console.error(\n 'Error: Please provide either:\\n--print param to print sample config or\\n--generate to generate sample config file',\n );\n process.exit(1);\n }\n\n if ('print' in options) {\n console.log(`${sampleConfig(collectionNames)}`);\n } else if ('generate' in options) {\n if (!options.file) {\n console.error(\n 'Error: You need to provide a config file through a --file',\n );\n process.exit(1);\n }\n\n generateConfigFile(options.file, collectionNames);\n }\n });\n","import {\n combineMigrations,\n dumbo,\n migrationTableSchemaComponent,\n runPostgreSQLMigrations,\n} from '@event-driven-io/dumbo';\nimport { Command } from 'commander';\nimport { pongoCollectionSchemaComponent } from '../core';\nimport { loadConfigFile } from './configFile';\n\ninterface MigrateRunOptions {\n collection: string[];\n connectionString: string;\n config?: string;\n dryRun?: boolean;\n}\n\ninterface MigrateSqlOptions {\n print?: boolean;\n write?: string;\n config?: string;\n collection: string[];\n}\n\nexport const migrateCommand = new Command('migrate').description(\n 'Manage database migrations',\n);\n\nmigrateCommand\n .command('run')\n .description('Run database migrations')\n .option(\n '-cs, --connection-string <string>',\n 'Connection string for the database',\n )\n .option(\n '-col, --collection <name>',\n 'Specify the collection name',\n (value: string, previous: string[]) => {\n // Accumulate collection names into an array (explicitly typing `previous` as `string[]`)\n return previous.concat([value]);\n },\n [] as string[],\n )\n .option('-f, --config <path>', 'Path to configuration file with Pongo config')\n .option('-dr, --dryRun', 'Perform dry run without commiting changes', false)\n .action(async (options: MigrateRunOptions) => {\n const { collection, dryRun } = options;\n const connectionString =\n options.connectionString ?? process.env.DB_CONNECTION_STRING;\n let collectionNames: string[];\n\n if (!connectionString) {\n console.error(\n 'Error: Connection string is required. Provide it either as a \"--connection-string\" parameter or through the DB_CONNECTION_STRING environment variable.' +\n '\\nFor instance: --connection-string postgresql://postgres:postgres@localhost:5432/postgres',\n );\n process.exit(1);\n }\n\n if (options.config) {\n const config = await loadConfigFile(options.config);\n\n collectionNames = config.collections.map((c) => c.name);\n } else if (collection) {\n collectionNames = collection;\n } else {\n console.error(\n 'Error: You need to provide at least one collection name. Provide it either through \"--config\" file or as a \"--collection\" parameter.',\n );\n process.exit(1);\n }\n\n const pool = dumbo({ connectionString });\n\n const migrations = collectionNames.flatMap((collectionsName) =>\n pongoCollectionSchemaComponent(collectionsName).migrations({\n connector: 'PostgreSQL:pg', // TODO: Provide connector here\n }),\n );\n\n await runPostgreSQLMigrations(pool, migrations, {\n dryRun,\n });\n });\n\nmigrateCommand\n .command('sql')\n .description('Generate SQL for database migration')\n .option(\n '-col, --collection <name>',\n 'Specify the collection name',\n (value: string, previous: string[]) => {\n // Accumulate collection names into an array (explicitly typing `previous` as `string[]`)\n return previous.concat([value]);\n },\n [] as string[],\n )\n .option('-f, --config <path>', 'Path to configuration file with Pongo config')\n .option('--print', 'Print the SQL to the console (default)', true)\n //.option('--write <filename>', 'Write the SQL to a specified file')\n .action(async (options: MigrateSqlOptions) => {\n const { collection } = options;\n\n let collectionNames: string[];\n\n if (options.config) {\n const config = await loadConfigFile(options.config);\n\n collectionNames = config.collections.map((c) => c.name);\n } else if (collection) {\n collectionNames = collection;\n } else {\n console.error(\n 'Error: You need to provide at least one collection name. Provide it either through \"--config\" file or as a \"--collection\" parameter.',\n );\n process.exit(1);\n }\n\n const coreMigrations = migrationTableSchemaComponent.migrations({\n connector: 'PostgreSQL:pg',\n });\n const migrations = [\n ...coreMigrations,\n ...collectionNames.flatMap((collectionName) =>\n pongoCollectionSchemaComponent(collectionName).migrations({\n connector: 'PostgreSQL:pg', // TODO: Provide connector here\n }),\n ),\n ];\n\n console.log('Printing SQL:');\n console.log(combineMigrations(...migrations));\n });\n","import {\n checkConnection,\n color,\n LogLevel,\n LogStyle,\n prettyJson,\n SQL,\n type MigrationStyle,\n} from '@event-driven-io/dumbo';\nimport Table from 'cli-table3';\nimport { Command } from 'commander';\nimport repl from 'node:repl';\nimport {\n pongoClient,\n pongoSchema,\n type PongoClient,\n type PongoCollectionSchema,\n type PongoDb,\n} from '../core';\n\nlet pongo: PongoClient;\n\nconst calculateColumnWidths = (\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n results: any[],\n columnNames: string[],\n): number[] => {\n const columnWidths = columnNames.map((col) => {\n const maxWidth = Math.max(\n col.length, // Header size\n ...results.map((result) =>\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n result[col] ? String(result[col]).length : 0,\n ),\n );\n return maxWidth + 2; // Add padding\n });\n return columnWidths;\n};\n\nlet shouldDisplayResultsAsTable = false;\n\nconst printResultsAsTable = (print?: boolean) =>\n (shouldDisplayResultsAsTable = print === undefined || print === true);\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst printOutput = (obj: any): string =>\n Array.isArray(obj) && shouldDisplayResultsAsTable\n ? displayResultsAsTable(obj)\n : prettyJson(obj);\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst displayResultsAsTable = (results: any[]): string => {\n if (results.length === 0) {\n return color.yellow('No documents found.');\n }\n\n const columnNames = results\n\n .flatMap((result) =>\n // eslint-disable-next-line @typescript-eslint/no-unsafe-argument\n typeof result === 'object' ? Object.keys(result) : typeof result,\n )\n .filter((value, index, array) => array.indexOf(value) === index);\n\n const columnWidths = calculateColumnWidths(results, columnNames);\n\n const table = new Table({\n head: columnNames.map((col) => color.cyan(col)),\n colWidths: columnWidths,\n });\n\n results.forEach((result) => {\n table.push(\n columnNames.map((col) =>\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n result[col] !== undefined\n ? // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n Array.isArray(result[col])\n ? // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n displayResultsAsTable(result[col])\n : // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n prettyJson(result[col])\n : typeof result === 'object'\n ? ''\n : result != undefined && result != undefined\n ? prettyJson(result)\n : '',\n ),\n );\n });\n\n return table.toString();\n};\n\nconst setLogLevel = (logLevel: string) => {\n process.env.DUMBO_LOG_LEVEL = logLevel;\n};\n\nconst setLogStyle = (logLevel: string) => {\n process.env.DUMBO_LOG_STYLE = logLevel;\n};\n\nconst prettifyLogs = (logLevel?: string) => {\n if (logLevel !== undefined) setLogLevel(logLevel);\n setLogStyle(LogStyle.PRETTY);\n};\n\nconst startRepl = async (options: {\n logging: {\n printOptions: boolean;\n logLevel: LogLevel;\n logStyle: LogStyle;\n };\n schema: {\n database: string;\n collections: string[];\n autoMigration: MigrationStyle;\n };\n connectionString: string | undefined;\n}) => {\n // TODO: This will change when we have proper tracing and logging config\n // For now, that's enough\n setLogLevel(process.env.DUMBO_LOG_LEVEL ?? options.logging.logLevel);\n setLogStyle(process.env.DUMBO_LOG_STYLE ?? options.logging.logStyle);\n\n console.log(color.green('Starting Pongo Shell (version: 0.16.10)'));\n\n if (options.logging.printOptions) {\n console.log(color.green('With Options:'));\n console.log(prettyJson(options));\n }\n\n const connectionString =\n options.connectionString ??\n process.env.DB_CONNECTION_STRING ??\n 'postgresql://postgres:postgres@localhost:5432/postgres';\n\n if (!(options.connectionString ?? process.env.DB_CONNECTION_STRING)) {\n console.log(\n color.yellow(\n `No connection string provided, using: 'postgresql://postgres:postgres@localhost:5432/postgres'`,\n ),\n );\n }\n\n const connectionCheck = await checkConnection(connectionString);\n\n if (!connectionCheck.successful) {\n if (connectionCheck.errorType === 'ConnectionRefused') {\n console.error(\n color.red(\n `Connection was refused. Check if the PostgreSQL server is running and accessible.`,\n ),\n );\n } else if (connectionCheck.errorType === 'Authentication') {\n console.error(\n color.red(\n `Authentication failed. Check the username and password in the connection string.`,\n ),\n );\n } else {\n console.error(color.red('Error connecting to PostgreSQL server'));\n }\n console.log(color.red('Exiting Pongo Shell...'));\n process.exit();\n }\n\n console.log(color.green(`Successfully connected`));\n console.log(color.green('Use db.<collection>.<method>() to query.'));\n\n const shell = repl.start({\n prompt: color.green('pongo> '),\n useGlobal: true,\n breakEvalOnSigint: true,\n writer: printOutput,\n });\n\n let db: PongoDb;\n\n if (options.schema.collections.length > 0) {\n const collectionsSchema: Record<string, PongoCollectionSchema> = {};\n\n for (const collectionName of options.schema.collections) {\n collectionsSchema[collectionName] =\n pongoSchema.collection(collectionName);\n }\n\n const schema = pongoSchema.client({\n database: pongoSchema.db(options.schema.database, collectionsSchema),\n });\n\n const typedClient = pongoClient(connectionString, {\n schema: {\n definition: schema,\n autoMigration: options.schema.autoMigration,\n },\n });\n\n db = typedClient.database;\n\n for (const collectionName of options.schema.collections) {\n shell.context[collectionName] = typedClient.database[collectionName];\n }\n\n pongo = typedClient;\n } else {\n pongo = pongoClient(connectionString, {\n schema: { autoMigration: options.schema.autoMigration },\n });\n\n db = pongo.db(options.schema.database);\n }\n\n shell.context.pongo = pongo;\n shell.context.db = db;\n\n // helpers\n shell.context.SQL = SQL;\n shell.context.setLogLevel = setLogLevel;\n shell.context.setLogStyle = setLogStyle;\n shell.context.prettifyLogs = prettifyLogs;\n shell.context.printResultsAsTable = printResultsAsTable;\n shell.context.LogStyle = LogStyle;\n shell.context.LogLevel = LogLevel;\n\n // Intercept REPL output to display results as a table if they are arrays\n shell.on('exit', async () => {\n await teardown();\n process.exit();\n });\n\n shell.on('SIGINT', async () => {\n await teardown();\n process.exit();\n });\n};\n\nconst teardown = async () => {\n console.log(color.yellow('Exiting Pongo Shell...'));\n await pongo.close();\n};\n\nprocess.on('uncaughtException', teardown);\nprocess.on('SIGINT', teardown);\n\ninterface ShellOptions {\n database: string;\n collection: string[];\n connectionString?: string;\n disableAutoMigrations: boolean;\n logStyle?: string;\n logLevel?: string;\n prettyLog?: boolean;\n printOptions?: boolean;\n}\n\nconst shellCommand = new Command('shell')\n .description('Start an interactive Pongo shell')\n .option(\n '-cs, --connectionString <string>',\n 'Connection string for the database',\n )\n .option('-db, --database <string>', 'Database name to connect', 'postgres')\n .option(\n '-col, --collection <name>',\n 'Specify the collection name',\n (value: string, previous: string[]) => {\n // Accumulate collection names into an array (explicitly typing `previous` as `string[]`)\n return previous.concat([value]);\n },\n [] as string[],\n )\n .option(\n '-no-migrations, --disable-auto-migrations',\n 'Disable automatic migrations',\n )\n .option('-o, --print-options', 'Print shell options')\n .option(\n '-ll, --log-level <logLevel>',\n 'Log level: DISABLED, INFO, LOG, WARN, ERROR',\n 'DISABLED',\n )\n .option('-ls, --log-style', 'Log style: RAW, PRETTY', 'RAW')\n .option('-p, --pretty-log', 'Turn on logging with prettified output')\n .action(async (options: ShellOptions) => {\n const { collection, database } = options;\n const connectionString = options.connectionString;\n\n await startRepl({\n logging: {\n printOptions: options.printOptions === true,\n logStyle: options.prettyLog\n ? LogStyle.PRETTY\n : ((options.logStyle as LogStyle | undefined) ?? LogStyle.RAW),\n logLevel: options.logLevel\n ? (options.logLevel as LogLevel)\n : options.prettyLog\n ? LogLevel.INFO\n : LogLevel.DISABLED,\n },\n schema: {\n collections: collection,\n database,\n autoMigration: options.disableAutoMigrations\n ? 'None'\n : 'CreateOrUpdate',\n },\n connectionString,\n });\n });\n\nexport { shellCommand };\n"],"mappings":"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","names":["Command","Command","Command","Command","Command","Command"]}
package/dist/index.cjs CHANGED
@@ -36,7 +36,7 @@
36
36
 
37
37
 
38
38
 
39
- var _chunkNA3ELYRRcjs = require('./chunk-NA3ELYRR.cjs');
39
+ var _chunk3K7LHO2Pcjs = require('./chunk-3K7LHO2P.cjs');
40
40
 
41
41
 
42
42
 
@@ -75,5 +75,5 @@ var _chunkNA3ELYRRcjs = require('./chunk-NA3ELYRR.cjs');
75
75
 
76
76
 
77
77
 
78
- exports.ConcurrencyError = _chunkNA3ELYRRcjs.ConcurrencyError; exports.DOCUMENT_DOES_NOT_EXIST = _chunkNA3ELYRRcjs.DOCUMENT_DOES_NOT_EXIST; exports.DOCUMENT_EXISTS = _chunkNA3ELYRRcjs.DOCUMENT_EXISTS; exports.NO_CONCURRENCY_CHECK = _chunkNA3ELYRRcjs.NO_CONCURRENCY_CHECK; exports.ObjectId = _chunkNA3ELYRRcjs.ObjectId; exports.OperatorMap = _chunkNA3ELYRRcjs.OperatorMap; exports.PongoError = _chunkNA3ELYRRcjs.PongoError; exports.QueryOperators = _chunkNA3ELYRRcjs.QueryOperators; exports.clientToDbOptions = _chunkNA3ELYRRcjs.clientToDbOptions; exports.deepEquals = _chunkNA3ELYRRcjs.deepEquals; exports.expectedVersion = _chunkNA3ELYRRcjs.expectedVersion; exports.expectedVersionValue = _chunkNA3ELYRRcjs.expectedVersionValue; exports.getPongoDb = _chunkNA3ELYRRcjs.getPongoDb; exports.hasOperators = _chunkNA3ELYRRcjs.hasOperators; exports.isEquatable = _chunkNA3ELYRRcjs.isEquatable; exports.isGeneralExpectedDocumentVersion = _chunkNA3ELYRRcjs.isGeneralExpectedDocumentVersion; exports.isNumber = _chunkNA3ELYRRcjs.isNumber; exports.isOperator = _chunkNA3ELYRRcjs.isOperator; exports.isPostgresClientOptions = _chunkNA3ELYRRcjs.isPostgresClientOptions; exports.isString = _chunkNA3ELYRRcjs.isString; exports.objectEntries = _chunkNA3ELYRRcjs.objectEntries; exports.operationResult = _chunkNA3ELYRRcjs.operationResult; exports.pongoClient = _chunkNA3ELYRRcjs.pongoClient; exports.pongoCollection = _chunkNA3ELYRRcjs.pongoCollection; exports.pongoCollectionPostgreSQLMigrations = _chunkNA3ELYRRcjs.pongoCollectionPostgreSQLMigrations; exports.pongoCollectionSchemaComponent = _chunkNA3ELYRRcjs.pongoCollectionSchemaComponent; exports.pongoDbSchemaComponent = _chunkNA3ELYRRcjs.pongoDbSchemaComponent; exports.pongoSchema = _chunkNA3ELYRRcjs.pongoSchema; exports.pongoSession = _chunkNA3ELYRRcjs.pongoSession; exports.pongoTransaction = _chunkNA3ELYRRcjs.pongoTransaction; exports.postgresDb = _chunkNA3ELYRRcjs.postgresDb; exports.postgresSQLBuilder = _chunkNA3ELYRRcjs.postgresSQLBuilder; exports.proxyClientWithSchema = _chunkNA3ELYRRcjs.proxyClientWithSchema; exports.proxyPongoDbWithSchema = _chunkNA3ELYRRcjs.proxyPongoDbWithSchema; exports.toClientSchemaMetadata = _chunkNA3ELYRRcjs.toClientSchemaMetadata; exports.toDbSchemaMetadata = _chunkNA3ELYRRcjs.toDbSchemaMetadata; exports.transactionExecutorOrDefault = _chunkNA3ELYRRcjs.transactionExecutorOrDefault;
78
+ exports.ConcurrencyError = _chunk3K7LHO2Pcjs.ConcurrencyError; exports.DOCUMENT_DOES_NOT_EXIST = _chunk3K7LHO2Pcjs.DOCUMENT_DOES_NOT_EXIST; exports.DOCUMENT_EXISTS = _chunk3K7LHO2Pcjs.DOCUMENT_EXISTS; exports.NO_CONCURRENCY_CHECK = _chunk3K7LHO2Pcjs.NO_CONCURRENCY_CHECK; exports.ObjectId = _chunk3K7LHO2Pcjs.ObjectId; exports.OperatorMap = _chunk3K7LHO2Pcjs.OperatorMap; exports.PongoError = _chunk3K7LHO2Pcjs.PongoError; exports.QueryOperators = _chunk3K7LHO2Pcjs.QueryOperators; exports.clientToDbOptions = _chunk3K7LHO2Pcjs.clientToDbOptions; exports.deepEquals = _chunk3K7LHO2Pcjs.deepEquals; exports.expectedVersion = _chunk3K7LHO2Pcjs.expectedVersion; exports.expectedVersionValue = _chunk3K7LHO2Pcjs.expectedVersionValue; exports.getPongoDb = _chunk3K7LHO2Pcjs.getPongoDb; exports.hasOperators = _chunk3K7LHO2Pcjs.hasOperators; exports.isEquatable = _chunk3K7LHO2Pcjs.isEquatable; exports.isGeneralExpectedDocumentVersion = _chunk3K7LHO2Pcjs.isGeneralExpectedDocumentVersion; exports.isNumber = _chunk3K7LHO2Pcjs.isNumber; exports.isOperator = _chunk3K7LHO2Pcjs.isOperator; exports.isPostgresClientOptions = _chunk3K7LHO2Pcjs.isPostgresClientOptions; exports.isString = _chunk3K7LHO2Pcjs.isString; exports.objectEntries = _chunk3K7LHO2Pcjs.objectEntries; exports.operationResult = _chunk3K7LHO2Pcjs.operationResult; exports.pongoClient = _chunk3K7LHO2Pcjs.pongoClient; exports.pongoCollection = _chunk3K7LHO2Pcjs.pongoCollection; exports.pongoCollectionPostgreSQLMigrations = _chunk3K7LHO2Pcjs.pongoCollectionPostgreSQLMigrations; exports.pongoCollectionSchemaComponent = _chunk3K7LHO2Pcjs.pongoCollectionSchemaComponent; exports.pongoDbSchemaComponent = _chunk3K7LHO2Pcjs.pongoDbSchemaComponent; exports.pongoSchema = _chunk3K7LHO2Pcjs.pongoSchema; exports.pongoSession = _chunk3K7LHO2Pcjs.pongoSession; exports.pongoTransaction = _chunk3K7LHO2Pcjs.pongoTransaction; exports.postgresDb = _chunk3K7LHO2Pcjs.postgresDb; exports.postgresSQLBuilder = _chunk3K7LHO2Pcjs.postgresSQLBuilder; exports.proxyClientWithSchema = _chunk3K7LHO2Pcjs.proxyClientWithSchema; exports.proxyPongoDbWithSchema = _chunk3K7LHO2Pcjs.proxyPongoDbWithSchema; exports.toClientSchemaMetadata = _chunk3K7LHO2Pcjs.toClientSchemaMetadata; exports.toDbSchemaMetadata = _chunk3K7LHO2Pcjs.toDbSchemaMetadata; exports.transactionExecutorOrDefault = _chunk3K7LHO2Pcjs.transactionExecutorOrDefault;
79
79
  //# sourceMappingURL=index.cjs.map
package/dist/index.d.cts CHANGED
@@ -1,6 +1,6 @@
1
1
  import { Dumbo, SQLMigration, SQL, MigrationStyle, SchemaComponent, SQLExecutor } from '@event-driven-io/dumbo';
2
- import { P as PongoDocument, a as PongoDb, O as OptionalUnlessRequiredIdAndVersion, b as PongoFilter, c as PongoUpdate, U as UpdateOneOptions, W as WithoutId, R as ReplaceOneOptions, D as DeleteOneOptions, d as PongoCollection, C as CollectionOperationOptions, e as PongoTransactionOptions, f as PongoSession, g as PongoDbTransaction } from './pongoClient-CML2ZSy3.cjs';
3
- export { $ as $inc, h as $push, i as $set, j as $unset, A as AllowedDbClientOptions, k as AlternativeType, l as CollectionsMap, m as Condition, n as DBsMap, o as DOCUMENT_DOES_NOT_EXIST, p as DOCUMENT_EXISTS, q as DeleteManyOptions, r as Document, s as DocumentHandler, E as EnhancedOmit, t as ExpectedDocumentVersion, u as ExpectedDocumentVersionGeneral, v as ExpectedDocumentVersionValue, H as HandleOptions, w as HasId, I as InferIdType, x as InsertManyOptions, y as InsertOneOptions, N as NO_CONCURRENCY_CHECK, z as NonObjectIdLikeDocument, B as NotPooledPongoOptions, F as ObjectId, G as ObjectIdLike, J as OperationResult, K as OptionalId, L as OptionalUnlessRequiredId, M as OptionalUnlessRequiredVersion, Q as OptionalVersion, S as PongoClient, T as PongoClientOptions, V as PongoClientSchema, X as PongoClientSchemaMetadata, Y as PongoClientWithSchema, Z as PongoCollectionSchema, _ as PongoCollectionSchemaMetadata, a0 as PongoDBCollectionOptions, a1 as PongoDbClientOptions, a2 as PongoDbSchema, a3 as PongoDbSchemaMetadata, a4 as PongoDbWithSchema, a5 as PongoDeleteManyResult, a6 as PongoDeleteResult, a7 as PongoFilterOperator, a8 as PongoHandleResult, a9 as PongoInsertManyResult, aa as PongoInsertOneResult, ab as PongoSchemaConfig, ac as PongoUpdateManyResult, ad as PongoUpdateResult, ae as PooledPongoClientOptions, af as PostgresDbClientOptions, ag as RegExpOrString, ah as RootFilterOperators, ai as UpdateManyOptions, aj as WithId, ak as WithIdAndVersion, al as WithVersion, am as WithoutIdAndVersion, an as WithoutVersion, ao as clientToDbOptions, ap as expectedVersion, aq as expectedVersionValue, ar as getPongoDb, as as isGeneralExpectedDocumentVersion, at as isPostgresClientOptions, au as operationResult, av as pongoClient, aw as pongoDbSchemaComponent, ax as pongoSchema, ay as postgresDb, az as proxyClientWithSchema, aA as proxyPongoDbWithSchema, aB as toClientSchemaMetadata, aC as toDbSchemaMetadata } from './pongoClient-CML2ZSy3.cjs';
2
+ import { P as PongoDocument, a as PongoDb, O as OptionalUnlessRequiredIdAndVersion, b as PongoFilter, c as PongoUpdate, U as UpdateOneOptions, W as WithoutId, R as ReplaceOneOptions, D as DeleteOneOptions, d as PongoCollection, C as CollectionOperationOptions, e as PongoTransactionOptions, f as PongoSession, g as PongoDbTransaction } from './pongoClient-CPRWZZzH.cjs';
3
+ export { $ as $inc, h as $push, i as $set, j as $unset, A as AllowedDbClientOptions, k as AlternativeType, l as CollectionsMap, m as Condition, n as DBsMap, o as DOCUMENT_DOES_NOT_EXIST, p as DOCUMENT_EXISTS, q as DeleteManyOptions, r as Document, s as DocumentHandler, E as EnhancedOmit, t as ExpectedDocumentVersion, u as ExpectedDocumentVersionGeneral, v as ExpectedDocumentVersionValue, H as HandleOptions, w as HasId, I as InferIdType, x as InsertManyOptions, y as InsertOneOptions, N as NO_CONCURRENCY_CHECK, z as NonObjectIdLikeDocument, B as NotPooledPongoOptions, F as ObjectId, G as ObjectIdLike, J as OperationResult, K as OptionalId, L as OptionalUnlessRequiredId, M as OptionalUnlessRequiredVersion, Q as OptionalVersion, S as PongoClient, T as PongoClientOptions, V as PongoClientSchema, X as PongoClientSchemaMetadata, Y as PongoClientWithSchema, Z as PongoCollectionSchema, _ as PongoCollectionSchemaMetadata, a0 as PongoDBCollectionOptions, a1 as PongoDbClientOptions, a2 as PongoDbSchema, a3 as PongoDbSchemaMetadata, a4 as PongoDbWithSchema, a5 as PongoDeleteManyResult, a6 as PongoDeleteResult, a7 as PongoFilterOperator, a8 as PongoHandleResult, a9 as PongoInsertManyResult, aa as PongoInsertOneResult, ab as PongoMigrationOptions, ac as PongoSchemaConfig, ad as PongoUpdateManyResult, ae as PongoUpdateResult, af as PooledPongoClientOptions, ag as PostgresDbClientOptions, ah as RegExpOrString, ai as RootFilterOperators, aj as UpdateManyOptions, ak as WithId, al as WithIdAndVersion, am as WithVersion, an as WithoutIdAndVersion, ao as WithoutVersion, ap as clientToDbOptions, aq as expectedVersion, ar as expectedVersionValue, as as getPongoDb, at as isGeneralExpectedDocumentVersion, au as isPostgresClientOptions, av as operationResult, aw as pongoClient, ax as pongoDbSchemaComponent, ay as pongoSchema, az as postgresDb, aA as proxyClientWithSchema, aB as proxyPongoDbWithSchema, aC as toClientSchemaMetadata, aD as toDbSchemaMetadata } from './pongoClient-CPRWZZzH.cjs';
4
4
  import 'pg';
5
5
 
6
6
  type PongoCollectionOptions<T extends PongoDocument = PongoDocument, ConnectorType extends string = string, Payload extends PongoDocument = T> = {
package/dist/index.d.ts CHANGED
@@ -1,6 +1,6 @@
1
1
  import { Dumbo, SQLMigration, SQL, MigrationStyle, SchemaComponent, SQLExecutor } from '@event-driven-io/dumbo';
2
- import { P as PongoDocument, a as PongoDb, O as OptionalUnlessRequiredIdAndVersion, b as PongoFilter, c as PongoUpdate, U as UpdateOneOptions, W as WithoutId, R as ReplaceOneOptions, D as DeleteOneOptions, d as PongoCollection, C as CollectionOperationOptions, e as PongoTransactionOptions, f as PongoSession, g as PongoDbTransaction } from './pongoClient-CML2ZSy3.js';
3
- export { $ as $inc, h as $push, i as $set, j as $unset, A as AllowedDbClientOptions, k as AlternativeType, l as CollectionsMap, m as Condition, n as DBsMap, o as DOCUMENT_DOES_NOT_EXIST, p as DOCUMENT_EXISTS, q as DeleteManyOptions, r as Document, s as DocumentHandler, E as EnhancedOmit, t as ExpectedDocumentVersion, u as ExpectedDocumentVersionGeneral, v as ExpectedDocumentVersionValue, H as HandleOptions, w as HasId, I as InferIdType, x as InsertManyOptions, y as InsertOneOptions, N as NO_CONCURRENCY_CHECK, z as NonObjectIdLikeDocument, B as NotPooledPongoOptions, F as ObjectId, G as ObjectIdLike, J as OperationResult, K as OptionalId, L as OptionalUnlessRequiredId, M as OptionalUnlessRequiredVersion, Q as OptionalVersion, S as PongoClient, T as PongoClientOptions, V as PongoClientSchema, X as PongoClientSchemaMetadata, Y as PongoClientWithSchema, Z as PongoCollectionSchema, _ as PongoCollectionSchemaMetadata, a0 as PongoDBCollectionOptions, a1 as PongoDbClientOptions, a2 as PongoDbSchema, a3 as PongoDbSchemaMetadata, a4 as PongoDbWithSchema, a5 as PongoDeleteManyResult, a6 as PongoDeleteResult, a7 as PongoFilterOperator, a8 as PongoHandleResult, a9 as PongoInsertManyResult, aa as PongoInsertOneResult, ab as PongoSchemaConfig, ac as PongoUpdateManyResult, ad as PongoUpdateResult, ae as PooledPongoClientOptions, af as PostgresDbClientOptions, ag as RegExpOrString, ah as RootFilterOperators, ai as UpdateManyOptions, aj as WithId, ak as WithIdAndVersion, al as WithVersion, am as WithoutIdAndVersion, an as WithoutVersion, ao as clientToDbOptions, ap as expectedVersion, aq as expectedVersionValue, ar as getPongoDb, as as isGeneralExpectedDocumentVersion, at as isPostgresClientOptions, au as operationResult, av as pongoClient, aw as pongoDbSchemaComponent, ax as pongoSchema, ay as postgresDb, az as proxyClientWithSchema, aA as proxyPongoDbWithSchema, aB as toClientSchemaMetadata, aC as toDbSchemaMetadata } from './pongoClient-CML2ZSy3.js';
2
+ import { P as PongoDocument, a as PongoDb, O as OptionalUnlessRequiredIdAndVersion, b as PongoFilter, c as PongoUpdate, U as UpdateOneOptions, W as WithoutId, R as ReplaceOneOptions, D as DeleteOneOptions, d as PongoCollection, C as CollectionOperationOptions, e as PongoTransactionOptions, f as PongoSession, g as PongoDbTransaction } from './pongoClient-CPRWZZzH.js';
3
+ export { $ as $inc, h as $push, i as $set, j as $unset, A as AllowedDbClientOptions, k as AlternativeType, l as CollectionsMap, m as Condition, n as DBsMap, o as DOCUMENT_DOES_NOT_EXIST, p as DOCUMENT_EXISTS, q as DeleteManyOptions, r as Document, s as DocumentHandler, E as EnhancedOmit, t as ExpectedDocumentVersion, u as ExpectedDocumentVersionGeneral, v as ExpectedDocumentVersionValue, H as HandleOptions, w as HasId, I as InferIdType, x as InsertManyOptions, y as InsertOneOptions, N as NO_CONCURRENCY_CHECK, z as NonObjectIdLikeDocument, B as NotPooledPongoOptions, F as ObjectId, G as ObjectIdLike, J as OperationResult, K as OptionalId, L as OptionalUnlessRequiredId, M as OptionalUnlessRequiredVersion, Q as OptionalVersion, S as PongoClient, T as PongoClientOptions, V as PongoClientSchema, X as PongoClientSchemaMetadata, Y as PongoClientWithSchema, Z as PongoCollectionSchema, _ as PongoCollectionSchemaMetadata, a0 as PongoDBCollectionOptions, a1 as PongoDbClientOptions, a2 as PongoDbSchema, a3 as PongoDbSchemaMetadata, a4 as PongoDbWithSchema, a5 as PongoDeleteManyResult, a6 as PongoDeleteResult, a7 as PongoFilterOperator, a8 as PongoHandleResult, a9 as PongoInsertManyResult, aa as PongoInsertOneResult, ab as PongoMigrationOptions, ac as PongoSchemaConfig, ad as PongoUpdateManyResult, ae as PongoUpdateResult, af as PooledPongoClientOptions, ag as PostgresDbClientOptions, ah as RegExpOrString, ai as RootFilterOperators, aj as UpdateManyOptions, ak as WithId, al as WithIdAndVersion, am as WithVersion, an as WithoutIdAndVersion, ao as WithoutVersion, ap as clientToDbOptions, aq as expectedVersion, ar as expectedVersionValue, as as getPongoDb, at as isGeneralExpectedDocumentVersion, au as isPostgresClientOptions, av as operationResult, aw as pongoClient, ax as pongoDbSchemaComponent, ay as pongoSchema, az as postgresDb, aA as proxyClientWithSchema, aB as proxyPongoDbWithSchema, aC as toClientSchemaMetadata, aD as toDbSchemaMetadata } from './pongoClient-CPRWZZzH.js';
4
4
  import 'pg';
5
5
 
6
6
  type PongoCollectionOptions<T extends PongoDocument = PongoDocument, ConnectorType extends string = string, Payload extends PongoDocument = T> = {
package/dist/index.js CHANGED
@@ -36,7 +36,7 @@ import {
36
36
  toClientSchemaMetadata,
37
37
  toDbSchemaMetadata,
38
38
  transactionExecutorOrDefault
39
- } from "./chunk-2YS3A7WH.js";
39
+ } from "./chunk-NBYHLHUE.js";
40
40
  export {
41
41
  ConcurrencyError,
42
42
  DOCUMENT_DOES_NOT_EXIST,
@@ -1,4 +1,4 @@
1
- import { DatabaseTransactionFactory, SQL, SchemaComponent, QueryResultRow, QueryResult, DatabaseTransaction, SQLExecutor, PostgresConnector, MigrationStyle, NodePostgresConnection } from '@event-driven-io/dumbo';
1
+ import { DatabaseTransactionFactory, SQL, SchemaComponent, RunSQLMigrationsResult, QueryResultRow, QueryResult, DatabaseTransaction, SQLExecutor, PostgresConnector, MigrationStyle, NodePostgresConnection } from '@event-driven-io/dumbo';
2
2
  import pg from 'pg';
3
3
 
4
4
  interface PongoClient {
@@ -57,13 +57,17 @@ interface PongoDb<ConnectorType extends string = string> extends DatabaseTransac
57
57
  collections(): ReadonlyArray<PongoCollection<PongoDocument>>;
58
58
  readonly schema: Readonly<{
59
59
  component: SchemaComponent;
60
- migrate(): Promise<void>;
60
+ migrate(options?: PongoMigrationOptions): Promise<RunSQLMigrationsResult>;
61
61
  }>;
62
62
  sql: {
63
63
  query<Result extends QueryResultRow = QueryResultRow>(sql: SQL, options?: CollectionOperationOptions): Promise<Result[]>;
64
64
  command<Result extends QueryResultRow = QueryResultRow>(sql: SQL, options?: CollectionOperationOptions): Promise<QueryResult<Result>>;
65
65
  };
66
66
  }
67
+ type PongoMigrationOptions = {
68
+ dryRun?: boolean | undefined;
69
+ ignoreMigrationHashMismatch?: boolean | undefined;
70
+ };
67
71
  type CollectionOperationOptions = {
68
72
  session?: PongoSession;
69
73
  };
@@ -113,7 +117,7 @@ interface PongoCollection<T extends PongoDocument> {
113
117
  handle(id: string, handle: DocumentHandler<T>, options?: HandleOptions): Promise<PongoHandleResult<T>>;
114
118
  readonly schema: Readonly<{
115
119
  component: SchemaComponent;
116
- migrate(): Promise<void>;
120
+ migrate(options?: PongoMigrationOptions): Promise<RunSQLMigrationsResult>;
117
121
  }>;
118
122
  sql: {
119
123
  query<Result extends QueryResultRow = QueryResultRow>(sql: SQL, options?: CollectionOperationOptions): Promise<Result[]>;
@@ -366,4 +370,4 @@ declare const clientToDbOptions: <DbClientOptions extends AllowedDbClientOptions
366
370
  clientOptions: PongoClientOptions;
367
371
  }) => DbClientOptions;
368
372
 
369
- export { type $inc as $, type AllowedDbClientOptions as A, type NotPooledPongoOptions as B, type CollectionOperationOptions as C, type DeleteOneOptions as D, type EnhancedOmit as E, ObjectId as F, type ObjectIdLike as G, type HandleOptions as H, type InferIdType as I, type OperationResult as J, type OptionalId as K, type OptionalUnlessRequiredId as L, type OptionalUnlessRequiredVersion as M, NO_CONCURRENCY_CHECK as N, type OptionalUnlessRequiredIdAndVersion as O, type PongoDocument as P, type OptionalVersion as Q, type ReplaceOneOptions as R, type PongoClient as S, type PongoClientOptions as T, type UpdateOneOptions as U, type PongoClientSchema as V, type WithoutId as W, type PongoClientSchemaMetadata as X, type PongoClientWithSchema as Y, type PongoCollectionSchema as Z, type PongoCollectionSchemaMetadata as _, type PongoDb as a, type PongoDBCollectionOptions as a0, type PongoDbClientOptions as a1, type PongoDbSchema as a2, type PongoDbSchemaMetadata as a3, type PongoDbWithSchema as a4, type PongoDeleteManyResult as a5, type PongoDeleteResult as a6, type PongoFilterOperator as a7, type PongoHandleResult as a8, type PongoInsertManyResult as a9, proxyPongoDbWithSchema as aA, toClientSchemaMetadata as aB, toDbSchemaMetadata as aC, type PongoInsertOneResult as aa, type PongoSchemaConfig as ab, type PongoUpdateManyResult as ac, type PongoUpdateResult as ad, type PooledPongoClientOptions as ae, type PostgresDbClientOptions as af, type RegExpOrString as ag, type RootFilterOperators as ah, type UpdateManyOptions as ai, type WithId as aj, type WithIdAndVersion as ak, type WithVersion as al, type WithoutIdAndVersion as am, type WithoutVersion as an, clientToDbOptions as ao, expectedVersion as ap, expectedVersionValue as aq, getPongoDb as ar, isGeneralExpectedDocumentVersion as as, isPostgresClientOptions as at, operationResult as au, pongoClient as av, pongoDbSchemaComponent as aw, pongoSchema as ax, postgresDb as ay, proxyClientWithSchema as az, type PongoFilter as b, type PongoUpdate as c, type PongoCollection as d, type PongoTransactionOptions as e, type PongoSession as f, type PongoDbTransaction as g, type $push as h, type $set as i, type $unset as j, type AlternativeType as k, type CollectionsMap as l, type Condition as m, type DBsMap as n, DOCUMENT_DOES_NOT_EXIST as o, DOCUMENT_EXISTS as p, type DeleteManyOptions as q, type Document as r, type DocumentHandler as s, type ExpectedDocumentVersion as t, type ExpectedDocumentVersionGeneral as u, type ExpectedDocumentVersionValue as v, type HasId as w, type InsertManyOptions as x, type InsertOneOptions as y, type NonObjectIdLikeDocument as z };
373
+ export { type $inc as $, type AllowedDbClientOptions as A, type NotPooledPongoOptions as B, type CollectionOperationOptions as C, type DeleteOneOptions as D, type EnhancedOmit as E, ObjectId as F, type ObjectIdLike as G, type HandleOptions as H, type InferIdType as I, type OperationResult as J, type OptionalId as K, type OptionalUnlessRequiredId as L, type OptionalUnlessRequiredVersion as M, NO_CONCURRENCY_CHECK as N, type OptionalUnlessRequiredIdAndVersion as O, type PongoDocument as P, type OptionalVersion as Q, type ReplaceOneOptions as R, type PongoClient as S, type PongoClientOptions as T, type UpdateOneOptions as U, type PongoClientSchema as V, type WithoutId as W, type PongoClientSchemaMetadata as X, type PongoClientWithSchema as Y, type PongoCollectionSchema as Z, type PongoCollectionSchemaMetadata as _, type PongoDb as a, type PongoDBCollectionOptions as a0, type PongoDbClientOptions as a1, type PongoDbSchema as a2, type PongoDbSchemaMetadata as a3, type PongoDbWithSchema as a4, type PongoDeleteManyResult as a5, type PongoDeleteResult as a6, type PongoFilterOperator as a7, type PongoHandleResult as a8, type PongoInsertManyResult as a9, proxyClientWithSchema as aA, proxyPongoDbWithSchema as aB, toClientSchemaMetadata as aC, toDbSchemaMetadata as aD, type PongoInsertOneResult as aa, type PongoMigrationOptions as ab, type PongoSchemaConfig as ac, type PongoUpdateManyResult as ad, type PongoUpdateResult as ae, type PooledPongoClientOptions as af, type PostgresDbClientOptions as ag, type RegExpOrString as ah, type RootFilterOperators as ai, type UpdateManyOptions as aj, type WithId as ak, type WithIdAndVersion as al, type WithVersion as am, type WithoutIdAndVersion as an, type WithoutVersion as ao, clientToDbOptions as ap, expectedVersion as aq, expectedVersionValue as ar, getPongoDb as as, isGeneralExpectedDocumentVersion as at, isPostgresClientOptions as au, operationResult as av, pongoClient as aw, pongoDbSchemaComponent as ax, pongoSchema as ay, postgresDb as az, type PongoFilter as b, type PongoUpdate as c, type PongoCollection as d, type PongoTransactionOptions as e, type PongoSession as f, type PongoDbTransaction as g, type $push as h, type $set as i, type $unset as j, type AlternativeType as k, type CollectionsMap as l, type Condition as m, type DBsMap as n, DOCUMENT_DOES_NOT_EXIST as o, DOCUMENT_EXISTS as p, type DeleteManyOptions as q, type Document as r, type DocumentHandler as s, type ExpectedDocumentVersion as t, type ExpectedDocumentVersionGeneral as u, type ExpectedDocumentVersionValue as v, type HasId as w, type InsertManyOptions as x, type InsertOneOptions as y, type NonObjectIdLikeDocument as z };
@@ -1,4 +1,4 @@
1
- import { DatabaseTransactionFactory, SQL, SchemaComponent, QueryResultRow, QueryResult, DatabaseTransaction, SQLExecutor, PostgresConnector, MigrationStyle, NodePostgresConnection } from '@event-driven-io/dumbo';
1
+ import { DatabaseTransactionFactory, SQL, SchemaComponent, RunSQLMigrationsResult, QueryResultRow, QueryResult, DatabaseTransaction, SQLExecutor, PostgresConnector, MigrationStyle, NodePostgresConnection } from '@event-driven-io/dumbo';
2
2
  import pg from 'pg';
3
3
 
4
4
  interface PongoClient {
@@ -57,13 +57,17 @@ interface PongoDb<ConnectorType extends string = string> extends DatabaseTransac
57
57
  collections(): ReadonlyArray<PongoCollection<PongoDocument>>;
58
58
  readonly schema: Readonly<{
59
59
  component: SchemaComponent;
60
- migrate(): Promise<void>;
60
+ migrate(options?: PongoMigrationOptions): Promise<RunSQLMigrationsResult>;
61
61
  }>;
62
62
  sql: {
63
63
  query<Result extends QueryResultRow = QueryResultRow>(sql: SQL, options?: CollectionOperationOptions): Promise<Result[]>;
64
64
  command<Result extends QueryResultRow = QueryResultRow>(sql: SQL, options?: CollectionOperationOptions): Promise<QueryResult<Result>>;
65
65
  };
66
66
  }
67
+ type PongoMigrationOptions = {
68
+ dryRun?: boolean | undefined;
69
+ ignoreMigrationHashMismatch?: boolean | undefined;
70
+ };
67
71
  type CollectionOperationOptions = {
68
72
  session?: PongoSession;
69
73
  };
@@ -113,7 +117,7 @@ interface PongoCollection<T extends PongoDocument> {
113
117
  handle(id: string, handle: DocumentHandler<T>, options?: HandleOptions): Promise<PongoHandleResult<T>>;
114
118
  readonly schema: Readonly<{
115
119
  component: SchemaComponent;
116
- migrate(): Promise<void>;
120
+ migrate(options?: PongoMigrationOptions): Promise<RunSQLMigrationsResult>;
117
121
  }>;
118
122
  sql: {
119
123
  query<Result extends QueryResultRow = QueryResultRow>(sql: SQL, options?: CollectionOperationOptions): Promise<Result[]>;
@@ -366,4 +370,4 @@ declare const clientToDbOptions: <DbClientOptions extends AllowedDbClientOptions
366
370
  clientOptions: PongoClientOptions;
367
371
  }) => DbClientOptions;
368
372
 
369
- export { type $inc as $, type AllowedDbClientOptions as A, type NotPooledPongoOptions as B, type CollectionOperationOptions as C, type DeleteOneOptions as D, type EnhancedOmit as E, ObjectId as F, type ObjectIdLike as G, type HandleOptions as H, type InferIdType as I, type OperationResult as J, type OptionalId as K, type OptionalUnlessRequiredId as L, type OptionalUnlessRequiredVersion as M, NO_CONCURRENCY_CHECK as N, type OptionalUnlessRequiredIdAndVersion as O, type PongoDocument as P, type OptionalVersion as Q, type ReplaceOneOptions as R, type PongoClient as S, type PongoClientOptions as T, type UpdateOneOptions as U, type PongoClientSchema as V, type WithoutId as W, type PongoClientSchemaMetadata as X, type PongoClientWithSchema as Y, type PongoCollectionSchema as Z, type PongoCollectionSchemaMetadata as _, type PongoDb as a, type PongoDBCollectionOptions as a0, type PongoDbClientOptions as a1, type PongoDbSchema as a2, type PongoDbSchemaMetadata as a3, type PongoDbWithSchema as a4, type PongoDeleteManyResult as a5, type PongoDeleteResult as a6, type PongoFilterOperator as a7, type PongoHandleResult as a8, type PongoInsertManyResult as a9, proxyPongoDbWithSchema as aA, toClientSchemaMetadata as aB, toDbSchemaMetadata as aC, type PongoInsertOneResult as aa, type PongoSchemaConfig as ab, type PongoUpdateManyResult as ac, type PongoUpdateResult as ad, type PooledPongoClientOptions as ae, type PostgresDbClientOptions as af, type RegExpOrString as ag, type RootFilterOperators as ah, type UpdateManyOptions as ai, type WithId as aj, type WithIdAndVersion as ak, type WithVersion as al, type WithoutIdAndVersion as am, type WithoutVersion as an, clientToDbOptions as ao, expectedVersion as ap, expectedVersionValue as aq, getPongoDb as ar, isGeneralExpectedDocumentVersion as as, isPostgresClientOptions as at, operationResult as au, pongoClient as av, pongoDbSchemaComponent as aw, pongoSchema as ax, postgresDb as ay, proxyClientWithSchema as az, type PongoFilter as b, type PongoUpdate as c, type PongoCollection as d, type PongoTransactionOptions as e, type PongoSession as f, type PongoDbTransaction as g, type $push as h, type $set as i, type $unset as j, type AlternativeType as k, type CollectionsMap as l, type Condition as m, type DBsMap as n, DOCUMENT_DOES_NOT_EXIST as o, DOCUMENT_EXISTS as p, type DeleteManyOptions as q, type Document as r, type DocumentHandler as s, type ExpectedDocumentVersion as t, type ExpectedDocumentVersionGeneral as u, type ExpectedDocumentVersionValue as v, type HasId as w, type InsertManyOptions as x, type InsertOneOptions as y, type NonObjectIdLikeDocument as z };
373
+ export { type $inc as $, type AllowedDbClientOptions as A, type NotPooledPongoOptions as B, type CollectionOperationOptions as C, type DeleteOneOptions as D, type EnhancedOmit as E, ObjectId as F, type ObjectIdLike as G, type HandleOptions as H, type InferIdType as I, type OperationResult as J, type OptionalId as K, type OptionalUnlessRequiredId as L, type OptionalUnlessRequiredVersion as M, NO_CONCURRENCY_CHECK as N, type OptionalUnlessRequiredIdAndVersion as O, type PongoDocument as P, type OptionalVersion as Q, type ReplaceOneOptions as R, type PongoClient as S, type PongoClientOptions as T, type UpdateOneOptions as U, type PongoClientSchema as V, type WithoutId as W, type PongoClientSchemaMetadata as X, type PongoClientWithSchema as Y, type PongoCollectionSchema as Z, type PongoCollectionSchemaMetadata as _, type PongoDb as a, type PongoDBCollectionOptions as a0, type PongoDbClientOptions as a1, type PongoDbSchema as a2, type PongoDbSchemaMetadata as a3, type PongoDbWithSchema as a4, type PongoDeleteManyResult as a5, type PongoDeleteResult as a6, type PongoFilterOperator as a7, type PongoHandleResult as a8, type PongoInsertManyResult as a9, proxyClientWithSchema as aA, proxyPongoDbWithSchema as aB, toClientSchemaMetadata as aC, toDbSchemaMetadata as aD, type PongoInsertOneResult as aa, type PongoMigrationOptions as ab, type PongoSchemaConfig as ac, type PongoUpdateManyResult as ad, type PongoUpdateResult as ae, type PooledPongoClientOptions as af, type PostgresDbClientOptions as ag, type RegExpOrString as ah, type RootFilterOperators as ai, type UpdateManyOptions as aj, type WithId as ak, type WithIdAndVersion as al, type WithVersion as am, type WithoutIdAndVersion as an, type WithoutVersion as ao, clientToDbOptions as ap, expectedVersion as aq, expectedVersionValue as ar, getPongoDb as as, isGeneralExpectedDocumentVersion as at, isPostgresClientOptions as au, operationResult as av, pongoClient as aw, pongoDbSchemaComponent as ax, pongoSchema as ay, postgresDb as az, type PongoFilter as b, type PongoUpdate as c, type PongoCollection as d, type PongoTransactionOptions as e, type PongoSession as f, type PongoDbTransaction as g, type $push as h, type $set as i, type $unset as j, type AlternativeType as k, type CollectionsMap as l, type Condition as m, type DBsMap as n, DOCUMENT_DOES_NOT_EXIST as o, DOCUMENT_EXISTS as p, type DeleteManyOptions as q, type Document as r, type DocumentHandler as s, type ExpectedDocumentVersion as t, type ExpectedDocumentVersionGeneral as u, type ExpectedDocumentVersionValue as v, type HasId as w, type InsertManyOptions as x, type InsertOneOptions as y, type NonObjectIdLikeDocument as z };
package/dist/shim.cjs CHANGED
@@ -1,7 +1,7 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; } var _class;
2
2
 
3
3
 
4
- var _chunkNA3ELYRRcjs = require('./chunk-NA3ELYRR.cjs');
4
+ var _chunk3K7LHO2Pcjs = require('./chunk-3K7LHO2P.cjs');
5
5
 
6
6
  // src/mongo/findCursor.ts
7
7
  var FindCursor = (_class = class {
@@ -300,7 +300,7 @@ var Db = class {
300
300
  var MongoClient = class {
301
301
 
302
302
  constructor(connectionString, options = {}) {
303
- this.pongoClient = _chunkNA3ELYRRcjs.pongoClient.call(void 0, connectionString, options);
303
+ this.pongoClient = _chunk3K7LHO2Pcjs.pongoClient.call(void 0, connectionString, options);
304
304
  }
305
305
  async connect() {
306
306
  await this.pongoClient.connect();
@@ -313,12 +313,12 @@ var MongoClient = class {
313
313
  return new Db(this.pongoClient.db(dbName));
314
314
  }
315
315
  startSession(_options) {
316
- return _chunkNA3ELYRRcjs.pongoSession.call(void 0, );
316
+ return _chunk3K7LHO2Pcjs.pongoSession.call(void 0, );
317
317
  }
318
318
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
319
319
  async withSession(optionsOrExecutor, executor) {
320
320
  const callback = typeof optionsOrExecutor === "function" ? optionsOrExecutor : executor;
321
- const session = _chunkNA3ELYRRcjs.pongoSession.call(void 0, );
321
+ const session = _chunk3K7LHO2Pcjs.pongoSession.call(void 0, );
322
322
  try {
323
323
  return await callback(session);
324
324
  } finally {
package/dist/shim.d.cts CHANGED
@@ -1,6 +1,6 @@
1
1
  import { ClientSessionOptions } from 'http2';
2
2
  import { Document, Collection as Collection$1, ObjectId, ClientSession, WithSessionCallback, ReadConcern, ReadPreference, BSONSerializeOptions, WriteConcern, Hint, OptionalUnlessRequiredId, InsertOneOptions, InsertOneResult, BulkWriteOptions, InsertManyResult, AnyBulkWriteOperation, BulkWriteResult, Filter, UpdateFilter, UpdateOptions, UpdateResult, WithoutId, ReplaceOptions, DeleteOptions, DeleteResult, RenameOptions, DropCollectionOptions, WithId, FindOptions, FindCursor as FindCursor$1, OperationOptions, IndexSpecification, CreateIndexesOptions, IndexDescription, CommandOperationOptions, AbstractCursorOptions, ListIndexesCursor, IndexInformationOptions, IndexDescriptionInfo, IndexDescriptionCompact, EstimatedDocumentCountOptions, CountDocumentsOptions, EnhancedOmit, Flatten, FindOneAndDeleteOptions, ModifyResult, FindOneAndReplaceOptions, FindOneAndUpdateOptions, AggregateOptions, AggregationCursor, ChangeStreamDocument, ChangeStreamOptions, ChangeStream, UnorderedBulkOperation, OrderedBulkOperation, CountOptions, ListSearchIndexesOptions, ListSearchIndexesCursor, SearchIndexDescription } from 'mongodb';
3
- import { a as PongoDb, a0 as PongoDBCollectionOptions, s as DocumentHandler, H as HandleOptions, a8 as PongoHandleResult, T as PongoClientOptions, d as PongoCollection } from './pongoClient-CML2ZSy3.cjs';
3
+ import { a as PongoDb, a0 as PongoDBCollectionOptions, s as DocumentHandler, H as HandleOptions, a8 as PongoHandleResult, T as PongoClientOptions, d as PongoCollection } from './pongoClient-CPRWZZzH.cjs';
4
4
  import '@event-driven-io/dumbo';
5
5
  import 'pg';
6
6
 
package/dist/shim.d.ts CHANGED
@@ -1,6 +1,6 @@
1
1
  import { ClientSessionOptions } from 'http2';
2
2
  import { Document, Collection as Collection$1, ObjectId, ClientSession, WithSessionCallback, ReadConcern, ReadPreference, BSONSerializeOptions, WriteConcern, Hint, OptionalUnlessRequiredId, InsertOneOptions, InsertOneResult, BulkWriteOptions, InsertManyResult, AnyBulkWriteOperation, BulkWriteResult, Filter, UpdateFilter, UpdateOptions, UpdateResult, WithoutId, ReplaceOptions, DeleteOptions, DeleteResult, RenameOptions, DropCollectionOptions, WithId, FindOptions, FindCursor as FindCursor$1, OperationOptions, IndexSpecification, CreateIndexesOptions, IndexDescription, CommandOperationOptions, AbstractCursorOptions, ListIndexesCursor, IndexInformationOptions, IndexDescriptionInfo, IndexDescriptionCompact, EstimatedDocumentCountOptions, CountDocumentsOptions, EnhancedOmit, Flatten, FindOneAndDeleteOptions, ModifyResult, FindOneAndReplaceOptions, FindOneAndUpdateOptions, AggregateOptions, AggregationCursor, ChangeStreamDocument, ChangeStreamOptions, ChangeStream, UnorderedBulkOperation, OrderedBulkOperation, CountOptions, ListSearchIndexesOptions, ListSearchIndexesCursor, SearchIndexDescription } from 'mongodb';
3
- import { a as PongoDb, a0 as PongoDBCollectionOptions, s as DocumentHandler, H as HandleOptions, a8 as PongoHandleResult, T as PongoClientOptions, d as PongoCollection } from './pongoClient-CML2ZSy3.js';
3
+ import { a as PongoDb, a0 as PongoDBCollectionOptions, s as DocumentHandler, H as HandleOptions, a8 as PongoHandleResult, T as PongoClientOptions, d as PongoCollection } from './pongoClient-CPRWZZzH.js';
4
4
  import '@event-driven-io/dumbo';
5
5
  import 'pg';
6
6