@event-driven-io/pongo 0.17.0-alpha.6 → 0.17.0-beta.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/chunk-4BL6YWLW.cjs +872 -0
- package/dist/chunk-4BL6YWLW.cjs.map +1 -0
- package/dist/chunk-ECQ2CKZE.cjs +330 -0
- package/dist/chunk-ECQ2CKZE.cjs.map +1 -0
- package/dist/chunk-EYQDS752.js +364 -0
- package/dist/chunk-EYQDS752.js.map +1 -0
- package/dist/{chunk-OO7GMTMP.js → chunk-NCNRRYVE.js} +573 -876
- package/dist/chunk-NCNRRYVE.js.map +1 -0
- package/dist/chunk-WH26IXHN.js +10 -0
- package/dist/chunk-WH26IXHN.js.map +1 -0
- package/dist/chunk-WKW4LGF6.cjs +10 -0
- package/dist/chunk-WKW4LGF6.cjs.map +1 -0
- package/dist/chunk-Y7LRKJLJ.js +330 -0
- package/dist/chunk-Y7LRKJLJ.js.map +1 -0
- package/dist/chunk-ZPWKWNK2.cjs +364 -0
- package/dist/chunk-ZPWKWNK2.cjs.map +1 -0
- package/dist/cli.cjs +112 -36
- package/dist/cli.cjs.map +1 -1
- package/dist/cli.js +110 -34
- package/dist/cli.js.map +1 -1
- package/dist/d1.cjs +54 -0
- package/dist/d1.cjs.map +1 -0
- package/dist/d1.d.cts +11 -0
- package/dist/d1.d.ts +11 -0
- package/dist/d1.js +54 -0
- package/dist/d1.js.map +1 -0
- package/dist/index-BJopB-em.d.cts +7 -0
- package/dist/index-G5DECNb_.d.ts +7 -0
- package/dist/index.cjs +3 -6
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +58 -18
- package/dist/index.d.ts +58 -18
- package/dist/index.js +14 -17
- package/dist/pg-73DOKU64.js +11 -0
- package/dist/pg-73DOKU64.js.map +1 -0
- package/dist/pg-I267A7IL.cjs +11 -0
- package/dist/pg-I267A7IL.cjs.map +1 -0
- package/dist/pg.cjs +4 -3
- package/dist/pg.cjs.map +1 -1
- package/dist/pg.d.cts +36 -6
- package/dist/pg.d.ts +36 -6
- package/dist/pg.js +10 -9
- package/dist/pongoCollectionSchemaComponent-t_e9n2Wc.d.cts +426 -0
- package/dist/pongoCollectionSchemaComponent-t_e9n2Wc.d.ts +426 -0
- package/dist/shim.cjs +43 -8
- package/dist/shim.cjs.map +1 -1
- package/dist/shim.d.cts +12 -9
- package/dist/shim.d.ts +12 -9
- package/dist/shim.js +40 -5
- package/dist/shim.js.map +1 -1
- package/dist/sqlite3.cjs +66 -1
- package/dist/sqlite3.cjs.map +1 -1
- package/dist/sqlite3.d.cts +13 -1
- package/dist/sqlite3.d.ts +13 -1
- package/dist/sqlite3.js +65 -0
- package/dist/sqlite3.js.map +1 -1
- package/package.json +34 -12
- package/README.md +0 -230
- package/dist/chunk-AV4SHJQB.cjs +0 -1175
- package/dist/chunk-AV4SHJQB.cjs.map +0 -1
- package/dist/chunk-OO7GMTMP.js.map +0 -1
- package/dist/pg-BfTNWLV9.d.ts +0 -39
- package/dist/pg-C9NmCQe7.d.cts +0 -39
- package/dist/pongoClient-D8jPedlZ.d.cts +0 -364
- package/dist/pongoClient-D8jPedlZ.d.ts +0 -364
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["/home/runner/work/Pongo/Pongo/src/packages/pongo/dist/chunk-AV4SHJQB.cjs","../src/storage/postgresql/sqlBuilder/index.ts","../src/core/collection/pongoCollection.ts","../src/storage/postgresql/dbClient.ts","../src/core/collection/query.ts","../src/core/errors/index.ts","../src/core/pongoClient.ts","../src/core/pongoDb.ts","../src/core/pongoTransaction.ts","../src/core/pongoSession.ts","../src/core/typing/entries.ts","../src/core/typing/operations.ts","../src/core/schema/index.ts","../src/core/utils/deepEquals.ts","../src/storage/postgresql/sqlBuilder/filter/queryOperators.ts","../src/storage/postgresql/sqlBuilder/filter/index.ts","../src/storage/postgresql/sqlBuilder/update/index.ts"],"names":["sql","options","db","createCollection","expectedVersion","schemaComponent","runPostgreSQLMigrations","operationResult","pongoClient","NodePostgresConnectorType"],"mappings":"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","file":"/home/runner/work/Pongo/Pongo/src/packages/pongo/dist/chunk-AV4SHJQB.cjs","sourcesContent":[null,"import {\n isSQL,\n JSONSerializer,\n rawSql,\n sql,\n sqlMigration,\n type SQL,\n type SQLMigration,\n} from '@event-driven-io/dumbo';\nimport {\n expectedVersionValue,\n type DeleteOneOptions,\n type FindOptions,\n type OptionalUnlessRequiredIdAndVersion,\n type PongoCollectionSQLBuilder,\n type PongoFilter,\n type PongoUpdate,\n type ReplaceOneOptions,\n type UpdateOneOptions,\n type WithoutId,\n} from '../../../core';\nimport { constructFilterQuery } from './filter';\nimport { buildUpdateQuery } from './update';\n\nconst createCollection = (collectionName: string): SQL =>\n sql(\n `CREATE TABLE IF NOT EXISTS %I (\n _id TEXT PRIMARY KEY, \n data JSONB NOT NULL, \n metadata JSONB NOT NULL DEFAULT '{}',\n _version BIGINT NOT NULL DEFAULT 1,\n _partition TEXT NOT NULL DEFAULT 'png_global',\n _archived BOOLEAN NOT NULL DEFAULT FALSE,\n _created TIMESTAMPTZ NOT NULL DEFAULT now(),\n _updated TIMESTAMPTZ NOT NULL DEFAULT now()\n )`,\n collectionName,\n );\n\nexport const pongoCollectionPostgreSQLMigrations = (collectionName: string) => [\n sqlMigration(`pongoCollection:${collectionName}:001:createtable`, [\n createCollection(collectionName),\n ]),\n];\n\nexport const postgresSQLBuilder = (\n collectionName: string,\n): PongoCollectionSQLBuilder => ({\n migrations: (): SQLMigration[] =>\n pongoCollectionPostgreSQLMigrations(collectionName),\n createCollection: (): SQL => createCollection(collectionName),\n insertOne: <T>(document: OptionalUnlessRequiredIdAndVersion<T>): SQL => {\n return sql(\n 'INSERT INTO %I (_id, data, _version) VALUES (%L, %L, %L) ON CONFLICT(_id) DO NOTHING;',\n collectionName,\n document._id,\n JSONSerializer.serialize(document),\n document._version ?? 1n,\n );\n },\n insertMany: <T>(documents: OptionalUnlessRequiredIdAndVersion<T>[]): SQL => {\n const values = documents\n .map((doc) =>\n sql(\n '(%L, %L, %L)',\n doc._id,\n JSONSerializer.serialize(doc),\n doc._version ?? 1n,\n ),\n )\n .join(', ');\n return sql(\n `INSERT INTO %I (_id, data, _version) VALUES %s \n ON CONFLICT(_id) DO NOTHING\n RETURNING _id;`,\n collectionName,\n values,\n );\n },\n updateOne: <T>(\n filter: PongoFilter<T> | SQL,\n update: PongoUpdate<T> | SQL,\n options?: UpdateOneOptions,\n ): SQL => {\n const expectedVersion = expectedVersionValue(options?.expectedVersion);\n const expectedVersionUpdate =\n expectedVersion != null ? 'AND %I._version = %L' : '';\n const expectedVersionParams =\n expectedVersion != null ? [collectionName, expectedVersion] : [];\n\n const filterQuery = isSQL(filter) ? filter : constructFilterQuery(filter);\n const updateQuery = isSQL(update) ? update : buildUpdateQuery(update);\n\n return sql(\n `WITH existing AS (\n SELECT _id, _version as current_version\n FROM %I %s \n LIMIT 1\n ),\n updated AS (\n UPDATE %I \n SET \n data = %s || jsonb_build_object('_id', %I._id) || jsonb_build_object('_version', (_version + 1)::text),\n _version = _version + 1\n FROM existing \n WHERE %I._id = existing._id ${expectedVersionUpdate}\n RETURNING %I._id, %I._version\n )\n SELECT \n existing._id,\n COALESCE(updated._version, existing.current_version) AS version,\n COUNT(existing._id) over() AS matched,\n COUNT(updated._id) over() AS modified\n FROM existing\n LEFT JOIN updated \n ON existing._id = updated._id;`,\n collectionName,\n where(filterQuery),\n collectionName,\n updateQuery,\n collectionName,\n collectionName,\n ...expectedVersionParams,\n collectionName,\n collectionName,\n );\n },\n replaceOne: <T>(\n filter: PongoFilter<T> | SQL,\n document: WithoutId<T>,\n options?: ReplaceOneOptions,\n ): SQL => {\n const expectedVersion = expectedVersionValue(options?.expectedVersion);\n const expectedVersionUpdate =\n expectedVersion != null ? 'AND %I._version = %L' : '';\n const expectedVersionParams =\n expectedVersion != null ? [collectionName, expectedVersion] : [];\n\n const filterQuery = isSQL(filter) ? filter : constructFilterQuery(filter);\n\n return sql(\n `WITH existing AS (\n SELECT _id, _version as current_version\n FROM %I %s \n LIMIT 1\n ),\n updated AS (\n UPDATE %I \n SET \n data = %L || jsonb_build_object('_id', %I._id) || jsonb_build_object('_version', (_version + 1)::text),\n _version = _version + 1\n FROM existing \n WHERE %I._id = existing._id ${expectedVersionUpdate}\n RETURNING %I._id, %I._version\n )\n SELECT \n existing._id,\n COALESCE(updated._version, existing.current_version) AS version,\n COUNT(existing._id) over() AS matched,\n COUNT(updated._id) over() AS modified\n FROM existing\n LEFT JOIN updated \n ON existing._id = updated._id;`,\n collectionName,\n where(filterQuery),\n collectionName,\n JSONSerializer.serialize(document),\n collectionName,\n collectionName,\n ...expectedVersionParams,\n collectionName,\n collectionName,\n );\n },\n updateMany: <T>(\n filter: PongoFilter<T> | SQL,\n update: PongoUpdate<T> | SQL,\n ): SQL => {\n const filterQuery = isSQL(filter) ? filter : constructFilterQuery(filter);\n const updateQuery = isSQL(update) ? update : buildUpdateQuery(update);\n\n return sql(\n `UPDATE %I \n SET \n data = %s || jsonb_build_object('_version', (_version + 1)::text),\n _version = _version + 1\n %s;`,\n collectionName,\n updateQuery,\n where(filterQuery),\n );\n },\n deleteOne: <T>(\n filter: PongoFilter<T> | SQL,\n options?: DeleteOneOptions,\n ): SQL => {\n const expectedVersion = expectedVersionValue(options?.expectedVersion);\n const expectedVersionUpdate =\n expectedVersion != null ? 'AND %I._version = %L' : '';\n const expectedVersionParams =\n expectedVersion != null ? [collectionName, expectedVersion] : [];\n\n const filterQuery = isSQL(filter) ? filter : constructFilterQuery(filter);\n\n return sql(\n `WITH existing AS (\n SELECT _id\n FROM %I %s \n LIMIT 1\n ),\n deleted AS (\n DELETE FROM %I\n USING existing\n WHERE %I._id = existing._id ${expectedVersionUpdate}\n RETURNING %I._id\n )\n SELECT \n existing._id,\n COUNT(existing._id) over() AS matched,\n COUNT(deleted._id) over() AS deleted\n FROM existing\n LEFT JOIN deleted \n ON existing._id = deleted._id;`,\n collectionName,\n where(filterQuery),\n collectionName,\n collectionName,\n ...expectedVersionParams,\n collectionName,\n );\n },\n deleteMany: <T>(filter: PongoFilter<T> | SQL): SQL => {\n const filterQuery = isSQL(filter) ? filter : constructFilterQuery(filter);\n\n return sql('DELETE FROM %I %s', collectionName, where(filterQuery));\n },\n findOne: <T>(filter: PongoFilter<T> | SQL): SQL => {\n const filterQuery = isSQL(filter) ? filter : constructFilterQuery(filter);\n\n return sql(\n 'SELECT data FROM %I %s LIMIT 1;',\n collectionName,\n where(filterQuery),\n );\n },\n find: <T>(filter: PongoFilter<T> | SQL, options?: FindOptions): SQL => {\n const filterQuery = isSQL(filter) ? filter : constructFilterQuery(filter);\n const query: SQL[] = [];\n\n query.push(sql('SELECT data FROM %I', collectionName));\n\n const whereStmt = where(filterQuery);\n if (whereStmt.length > 0) {\n query.push(sql('%s', whereStmt));\n }\n\n if (options?.limit) {\n query.push(sql('LIMIT %s', options.limit));\n }\n\n if (options?.skip) {\n query.push(sql('OFFSET %s', options.skip));\n }\n\n return sql(query.join(' ') + ';');\n },\n countDocuments: <T>(filter: PongoFilter<T> | SQL): SQL => {\n const filterQuery = isSQL(filter) ? filter : constructFilterQuery(filter);\n return sql(\n 'SELECT COUNT(1) as count FROM %I %s;',\n collectionName,\n where(filterQuery),\n );\n },\n rename: (newName: string): SQL =>\n sql('ALTER TABLE %I RENAME TO %I;', collectionName, newName),\n drop: (targetName: string = collectionName): SQL =>\n sql('DROP TABLE IF EXISTS %I', targetName),\n});\n\nconst where = (filter: string): SQL =>\n filter.length > 0 ? sql('WHERE %s', filter) : rawSql('');\n","import {\n schemaComponent,\n single,\n type ConnectorType,\n type DatabaseTransaction,\n type Dumbo,\n type MigrationStyle,\n type QueryResult,\n type QueryResultRow,\n type SchemaComponent,\n type SQL,\n type SQLExecutor,\n type SQLMigration,\n} from '@event-driven-io/dumbo';\nimport { runPostgreSQLMigrations } from '@event-driven-io/dumbo/pg';\nimport { v7 as uuid } from 'uuid';\nimport {\n deepEquals,\n expectedVersionValue,\n operationResult,\n type CollectionOperationOptions,\n type DeleteManyOptions,\n type DeleteOneOptions,\n type DocumentHandler,\n type FindOptions,\n type HandleOptions,\n type InsertManyOptions,\n type InsertOneOptions,\n type OptionalUnlessRequiredIdAndVersion,\n type PongoCollection,\n type PongoDb,\n type PongoDeleteResult,\n type PongoDocument,\n type PongoFilter,\n type PongoHandleResult,\n type PongoInsertManyResult,\n type PongoInsertOneResult,\n type PongoUpdate,\n type PongoUpdateManyResult,\n type PongoUpdateResult,\n type ReplaceOneOptions,\n type UpdateManyOptions,\n type UpdateOneOptions,\n type WithIdAndVersion,\n type WithoutId,\n type WithVersion,\n} from '..';\nimport { pongoCollectionPostgreSQLMigrations } from '../../storage/postgresql';\n\nexport type PongoCollectionOptions<\n Connector extends ConnectorType = ConnectorType,\n> = {\n db: PongoDb<Connector>;\n collectionName: string;\n pool: Dumbo;\n sqlBuilder: PongoCollectionSQLBuilder;\n schema?: { autoMigration?: MigrationStyle };\n errors?: { throwOnOperationFailures?: boolean };\n};\n\nconst enlistIntoTransactionIfActive = async <\n Connector extends ConnectorType = ConnectorType,\n>(\n db: PongoDb<Connector>,\n options: CollectionOperationOptions | undefined,\n): Promise<DatabaseTransaction | null> => {\n const transaction = options?.session?.transaction;\n\n if (!transaction || !transaction.isActive) return null;\n\n return await transaction.enlistDatabase(db);\n};\n\nexport const transactionExecutorOrDefault = async <\n Connector extends ConnectorType = ConnectorType,\n>(\n db: PongoDb<Connector>,\n options: CollectionOperationOptions | undefined,\n defaultSqlExecutor: SQLExecutor,\n): Promise<SQLExecutor> => {\n const existingTransaction = await enlistIntoTransactionIfActive(db, options);\n return existingTransaction?.execute ?? defaultSqlExecutor;\n};\n\nexport const pongoCollection = <\n T extends PongoDocument,\n Connector extends ConnectorType = ConnectorType,\n>({\n db,\n collectionName,\n pool,\n sqlBuilder: SqlFor,\n schema,\n errors,\n}: PongoCollectionOptions<Connector>): PongoCollection<T> => {\n const sqlExecutor = pool.execute;\n const command = async <Result extends QueryResultRow = QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ) =>\n (\n await transactionExecutorOrDefault(db, options, sqlExecutor)\n ).command<Result>(sql);\n\n const query = async <T extends QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ) =>\n (await transactionExecutorOrDefault(db, options, sqlExecutor)).query<T>(\n sql,\n );\n\n let shouldMigrate = schema?.autoMigration !== 'None';\n\n const createCollection = (options?: CollectionOperationOptions) => {\n shouldMigrate = false;\n\n if (options?.session) return command(SqlFor.createCollection(), options);\n else return command(SqlFor.createCollection());\n };\n\n const ensureCollectionCreated = (options?: CollectionOperationOptions) => {\n if (!shouldMigrate) {\n return Promise.resolve();\n }\n\n return createCollection(options);\n };\n\n const collection = {\n dbName: db.databaseName,\n collectionName,\n createCollection: async (options?: CollectionOperationOptions) => {\n await createCollection(options);\n },\n insertOne: async (\n document: OptionalUnlessRequiredIdAndVersion<T>,\n options?: InsertOneOptions,\n ): Promise<PongoInsertOneResult> => {\n await ensureCollectionCreated(options);\n\n const _id = (document._id as string | undefined | null) ?? uuid();\n const _version = document._version ?? 1n;\n\n const result = await command(\n SqlFor.insertOne({\n ...document,\n _id,\n _version,\n } as OptionalUnlessRequiredIdAndVersion<T>),\n options,\n );\n\n const successful = (result.rowCount ?? 0) > 0;\n\n return operationResult<PongoInsertOneResult>(\n {\n successful,\n insertedId: successful ? _id : null,\n nextExpectedVersion: _version,\n },\n { operationName: 'insertOne', collectionName, errors },\n );\n },\n insertMany: async (\n documents: OptionalUnlessRequiredIdAndVersion<T>[],\n options?: InsertManyOptions,\n ): Promise<PongoInsertManyResult> => {\n await ensureCollectionCreated(options);\n\n const rows = documents.map((doc) => ({\n ...doc,\n _id: (doc._id as string | undefined | null) ?? uuid(),\n _version: doc._version ?? 1n,\n }));\n\n const result = await command(\n SqlFor.insertMany(rows as OptionalUnlessRequiredIdAndVersion<T>[]),\n options,\n );\n\n return operationResult<PongoInsertManyResult>(\n {\n successful: result.rowCount === rows.length,\n insertedCount: result.rowCount ?? 0,\n insertedIds: result.rows.map((d) => d._id as string),\n },\n { operationName: 'insertMany', collectionName, errors },\n );\n },\n updateOne: async (\n filter: PongoFilter<T>,\n update: PongoUpdate<T>,\n options?: UpdateOneOptions,\n ): Promise<PongoUpdateResult> => {\n await ensureCollectionCreated(options);\n\n const result = await command<UpdateSqlResult>(\n SqlFor.updateOne(filter, update, options),\n options,\n );\n\n return operationResult<PongoUpdateResult>(\n {\n successful:\n result.rows.length > 0 &&\n result.rows[0]!.modified === result.rows[0]!.matched,\n modifiedCount: Number(result.rows[0]?.modified ?? 0),\n matchedCount: Number(result.rows[0]?.matched ?? 0),\n nextExpectedVersion: result.rows[0]?.version ?? 0n,\n },\n { operationName: 'updateOne', collectionName, errors },\n );\n },\n replaceOne: async (\n filter: PongoFilter<T>,\n document: WithoutId<T>,\n options?: ReplaceOneOptions,\n ): Promise<PongoUpdateResult> => {\n await ensureCollectionCreated(options);\n\n const result = await command<UpdateSqlResult>(\n SqlFor.replaceOne(filter, document, options),\n options,\n );\n return operationResult<PongoUpdateResult>(\n {\n successful: result.rows.length > 0 && result.rows[0]!.modified > 0,\n modifiedCount: Number(result.rows[0]?.modified ?? 0),\n matchedCount: Number(result.rows[0]?.matched ?? 0),\n nextExpectedVersion: result.rows[0]?.version ?? 0n,\n },\n { operationName: 'replaceOne', collectionName, errors },\n );\n },\n updateMany: async (\n filter: PongoFilter<T>,\n update: PongoUpdate<T>,\n options?: UpdateManyOptions,\n ): Promise<PongoUpdateManyResult> => {\n await ensureCollectionCreated(options);\n\n const result = await command(SqlFor.updateMany(filter, update), options);\n\n return operationResult<PongoUpdateManyResult>(\n {\n successful: true,\n modifiedCount: result.rowCount ?? 0,\n matchedCount: result.rowCount ?? 0,\n },\n { operationName: 'updateMany', collectionName, errors },\n );\n },\n deleteOne: async (\n filter?: PongoFilter<T>,\n options?: DeleteOneOptions,\n ): Promise<PongoDeleteResult> => {\n await ensureCollectionCreated(options);\n\n const result = await command<DeleteSqlResult>(\n SqlFor.deleteOne(filter ?? {}, options),\n options,\n );\n return operationResult<PongoDeleteResult>(\n {\n successful: result.rows.length > 0 && result.rows[0]!.deleted! > 0,\n deletedCount: Number(result.rows[0]?.deleted ?? 0),\n matchedCount: Number(result.rows[0]?.matched ?? 0),\n },\n { operationName: 'deleteOne', collectionName, errors },\n );\n },\n deleteMany: async (\n filter?: PongoFilter<T>,\n options?: DeleteManyOptions,\n ): Promise<PongoDeleteResult> => {\n await ensureCollectionCreated(options);\n\n const result = await command(SqlFor.deleteMany(filter ?? {}), options);\n\n return operationResult<PongoDeleteResult>(\n {\n successful: (result.rowCount ?? 0) > 0,\n deletedCount: result.rowCount ?? 0,\n matchedCount: result.rowCount ?? 0,\n },\n { operationName: 'deleteMany', collectionName, errors },\n );\n },\n findOne: async (\n filter?: PongoFilter<T>,\n options?: CollectionOperationOptions,\n ): Promise<WithIdAndVersion<T> | null> => {\n await ensureCollectionCreated(options);\n\n const result = await query(SqlFor.findOne(filter ?? {}), options);\n return (result.rows[0]?.data ?? null) as WithIdAndVersion<T> | null;\n },\n findOneAndDelete: async (\n filter: PongoFilter<T>,\n options?: DeleteOneOptions,\n ): Promise<WithIdAndVersion<T> | null> => {\n await ensureCollectionCreated(options);\n\n const existingDoc = await collection.findOne(filter, options);\n\n if (existingDoc === null) return null;\n\n await collection.deleteOne(filter, options);\n return existingDoc;\n },\n findOneAndReplace: async (\n filter: PongoFilter<T>,\n replacement: WithoutId<T>,\n options?: ReplaceOneOptions,\n ): Promise<WithIdAndVersion<T> | null> => {\n await ensureCollectionCreated(options);\n\n const existingDoc = await collection.findOne(filter, options);\n\n if (existingDoc === null) return null;\n\n await collection.replaceOne(filter, replacement, options);\n\n return existingDoc;\n },\n findOneAndUpdate: async (\n filter: PongoFilter<T>,\n update: PongoUpdate<T>,\n options?: UpdateOneOptions,\n ): Promise<WithIdAndVersion<T> | null> => {\n await ensureCollectionCreated(options);\n\n const existingDoc = await collection.findOne(filter, options);\n\n if (existingDoc === null) return null;\n\n await collection.updateOne(filter, update, options);\n\n return existingDoc;\n },\n handle: async (\n id: string,\n handle: DocumentHandler<T>,\n options?: HandleOptions,\n ): Promise<PongoHandleResult<T>> => {\n const { expectedVersion: version, ...operationOptions } = options ?? {};\n await ensureCollectionCreated(options);\n\n const byId: PongoFilter<T> = { _id: id };\n\n const existing = (await collection.findOne(\n byId,\n options,\n )) as WithVersion<T> | null;\n\n const expectedVersion = expectedVersionValue(version);\n\n if (\n (existing == null && version === 'DOCUMENT_EXISTS') ||\n (existing == null && expectedVersion != null) ||\n (existing != null && version === 'DOCUMENT_DOES_NOT_EXIST') ||\n (existing != null &&\n expectedVersion !== null &&\n existing._version !== expectedVersion)\n ) {\n return operationResult<PongoHandleResult<T>>(\n {\n successful: false,\n document: existing as T,\n },\n { operationName: 'handle', collectionName, errors },\n );\n }\n\n const result = await handle(\n existing !== null ? ({ ...existing } as T) : null,\n );\n\n if (deepEquals(existing as T | null, result))\n return operationResult<PongoHandleResult<T>>(\n {\n successful: true,\n document: existing as T | null,\n },\n { operationName: 'handle', collectionName, errors },\n );\n\n if (!existing && result) {\n const newDoc = { ...result, _id: id };\n const insertResult = await collection.insertOne(\n { ...newDoc, _id: id } as OptionalUnlessRequiredIdAndVersion<T>,\n {\n ...operationOptions,\n expectedVersion: 'DOCUMENT_DOES_NOT_EXIST',\n },\n );\n return {\n ...insertResult,\n document: {\n ...newDoc,\n _version: insertResult.nextExpectedVersion,\n } as T,\n };\n }\n\n if (existing && !result) {\n const deleteResult = await collection.deleteOne(byId, {\n ...operationOptions,\n expectedVersion: expectedVersion ?? 'DOCUMENT_EXISTS',\n });\n return { ...deleteResult, document: null };\n }\n\n if (existing && result) {\n const replaceResult = await collection.replaceOne(byId, result, {\n ...operationOptions,\n expectedVersion: expectedVersion ?? 'DOCUMENT_EXISTS',\n });\n return {\n ...replaceResult,\n document: {\n ...result,\n _version: replaceResult.nextExpectedVersion,\n } as T,\n };\n }\n\n return operationResult<PongoHandleResult<T>>(\n {\n successful: true,\n document: existing as T,\n },\n { operationName: 'handle', collectionName, errors },\n );\n },\n find: async (\n filter?: PongoFilter<T>,\n options?: FindOptions,\n ): Promise<WithIdAndVersion<T>[]> => {\n await ensureCollectionCreated(options);\n\n const result = await query(SqlFor.find(filter ?? {}, options));\n return result.rows.map((row) => row.data as WithIdAndVersion<T>);\n },\n countDocuments: async (\n filter?: PongoFilter<T>,\n options?: CollectionOperationOptions,\n ): Promise<number> => {\n await ensureCollectionCreated(options);\n\n const { count } = await single(\n query<{ count: number }>(SqlFor.countDocuments(filter ?? {})),\n );\n return count;\n },\n drop: async (options?: CollectionOperationOptions): Promise<boolean> => {\n await ensureCollectionCreated(options);\n const result = await command(SqlFor.drop());\n return (result?.rowCount ?? 0) > 0;\n },\n rename: async (\n newName: string,\n options?: CollectionOperationOptions,\n ): Promise<PongoCollection<T>> => {\n await ensureCollectionCreated(options);\n await command(SqlFor.rename(newName));\n collectionName = newName;\n return collection;\n },\n\n sql: {\n async query<Result extends QueryResultRow = QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ): Promise<Result[]> {\n await ensureCollectionCreated(options);\n\n const result = await query<Result>(sql, options);\n return result.rows;\n },\n async command<Result extends QueryResultRow = QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ): Promise<QueryResult<Result>> {\n await ensureCollectionCreated(options);\n\n return command(sql, options);\n },\n },\n schema: {\n get component(): SchemaComponent {\n return schemaComponent('pongo:schema_component:collection', {\n migrations: SqlFor.migrations,\n });\n },\n migrate: () => runPostgreSQLMigrations(pool, SqlFor.migrations()), // TODO: This needs to change to support more connectors\n },\n };\n\n return collection;\n};\n\nexport const pongoCollectionSchemaComponent = (collectionName: string) =>\n schemaComponent('pongo:schema_component:collection', {\n migrations: () => pongoCollectionPostgreSQLMigrations(collectionName), // TODO: This needs to change to support more connectors\n });\n\nexport type PongoCollectionSQLBuilder = {\n migrations: () => SQLMigration[];\n createCollection: () => SQL;\n insertOne: <T>(document: OptionalUnlessRequiredIdAndVersion<T>) => SQL;\n insertMany: <T>(documents: OptionalUnlessRequiredIdAndVersion<T>[]) => SQL;\n updateOne: <T>(\n filter: PongoFilter<T> | SQL,\n update: PongoUpdate<T> | SQL,\n options?: UpdateOneOptions,\n ) => SQL;\n replaceOne: <T>(\n filter: PongoFilter<T> | SQL,\n document: WithoutId<T>,\n options?: ReplaceOneOptions,\n ) => SQL;\n updateMany: <T>(\n filter: PongoFilter<T> | SQL,\n update: PongoUpdate<T> | SQL,\n ) => SQL;\n deleteOne: <T>(\n filter: PongoFilter<T> | SQL,\n options?: DeleteOneOptions,\n ) => SQL;\n deleteMany: <T>(filter: PongoFilter<T> | SQL) => SQL;\n findOne: <T>(filter: PongoFilter<T> | SQL) => SQL;\n find: <T>(filter: PongoFilter<T> | SQL, options?: FindOptions) => SQL;\n countDocuments: <T>(filter: PongoFilter<T> | SQL) => SQL;\n rename: (newName: string) => SQL;\n drop: () => SQL;\n};\n\ntype UpdateSqlResult = {\n matched: bigint;\n modified: bigint;\n version: bigint;\n};\n\ntype DeleteSqlResult = {\n matched: bigint | null;\n deleted: bigint | null;\n};\n","import {\n schemaComponent,\n SQL,\n type QueryResult,\n type QueryResultRow,\n type SchemaComponent,\n} from '@event-driven-io/dumbo';\nimport {\n dumbo,\n getDatabaseNameOrDefault,\n NodePostgresConnectorType,\n runPostgreSQLMigrations,\n type PostgresConnector,\n type PostgresPoolOptions,\n} from '@event-driven-io/dumbo/pg';\nimport type { Document } from 'mongodb';\nimport {\n objectEntries,\n pongoCollection,\n pongoCollectionSchemaComponent,\n proxyPongoDbWithSchema,\n transactionExecutorOrDefault,\n type CollectionOperationOptions,\n type PongoCollection,\n type PongoDb,\n type PongoDbClientOptions,\n} from '../../core';\nimport { postgresSQLBuilder } from './sqlBuilder';\n\nexport type PostgresDbClientOptions = PongoDbClientOptions<PostgresConnector>;\n\nexport const isPostgresClientOptions = (\n options: PongoDbClientOptions,\n): options is PostgresDbClientOptions =>\n options.connector === NodePostgresConnectorType;\n\nexport const postgresDb = (\n options: PostgresDbClientOptions,\n): PongoDb<PostgresConnector> => {\n const { connectionString, dbName } = options;\n const databaseName = dbName ?? getDatabaseNameOrDefault(connectionString);\n\n const pool = dumbo<PostgresPoolOptions>({\n connectionString,\n ...options.connectionOptions,\n });\n\n const collections = new Map<string, PongoCollection<Document>>();\n\n const command = async <Result extends QueryResultRow = QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ) =>\n (\n await transactionExecutorOrDefault(db, options, pool.execute)\n ).command<Result>(sql);\n\n const query = async <T extends QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ) =>\n (await transactionExecutorOrDefault(db, options, pool.execute)).query<T>(\n sql,\n );\n\n const db: PongoDb<PostgresConnector> = {\n connector: options.connector,\n databaseName,\n connect: () => Promise.resolve(),\n close: () => pool.close(),\n\n collections: () => [...collections.values()],\n collection: (collectionName) =>\n pongoCollection({\n collectionName,\n db,\n pool,\n sqlBuilder: postgresSQLBuilder(collectionName),\n schema: options.schema ? options.schema : {},\n errors: options.errors ? options.errors : {},\n }),\n transaction: () => pool.transaction(),\n withTransaction: (handle) => pool.withTransaction(handle),\n\n schema: {\n get component(): SchemaComponent {\n return schemaComponent('pongoDb', {\n components: [...collections.values()].map((c) => c.schema.component),\n });\n },\n migrate: () =>\n runPostgreSQLMigrations(\n pool,\n [...collections.values()].flatMap((c) =>\n // TODO: This needs to change to support more connectors\n c.schema.component.migrations({ connector: 'PostgreSQL:pg' }),\n ),\n ),\n },\n\n sql: {\n async query<Result extends QueryResultRow = QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ): Promise<Result[]> {\n const result = await query<Result>(sql, options);\n return result.rows;\n },\n async command<Result extends QueryResultRow = QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ): Promise<QueryResult<Result>> {\n return command(sql, options);\n },\n },\n };\n\n const dbsSchema = options?.schema?.definition?.dbs;\n\n if (dbsSchema) {\n const dbSchema = objectEntries(dbsSchema)\n .map((e) => e[1])\n .find((db) => db.name === dbName || db.name === databaseName);\n\n if (dbSchema) return proxyPongoDbWithSchema(db, dbSchema, collections);\n }\n\n return db;\n};\n\nexport const pongoDbSchemaComponent = (\n collections: string[] | SchemaComponent[],\n) => {\n const components =\n collections.length > 0 && typeof collections[0] === 'string'\n ? collections.map((collectionName) =>\n pongoCollectionSchemaComponent(collectionName as string),\n )\n : (collections as SchemaComponent[]);\n\n return schemaComponent('pongo:schema_component:db', {\n components,\n });\n};\n","export const QueryOperators = {\n $eq: '$eq',\n $gt: '$gt',\n $gte: '$gte',\n $lt: '$lt',\n $lte: '$lte',\n $ne: '$ne',\n $in: '$in',\n $nin: '$nin',\n $elemMatch: '$elemMatch',\n $all: '$all',\n $size: '$size',\n};\n\nexport const OperatorMap = {\n $gt: '>',\n $gte: '>=',\n $lt: '<',\n $lte: '<=',\n $ne: '!=',\n};\n\nexport const isOperator = (key: string) => key.startsWith('$');\n\nexport const hasOperators = (value: Record<string, unknown>) =>\n Object.keys(value).some(isOperator);\n","export const isNumber = (val: unknown): val is number =>\n typeof val === 'number' && val === val;\n\nexport const isString = (val: unknown): val is string =>\n typeof val === 'string';\n\nexport class PongoError extends Error {\n public errorCode: number;\n\n constructor(\n options?: { errorCode: number; message?: string } | string | number,\n ) {\n const errorCode =\n options && typeof options === 'object' && 'errorCode' in options\n ? options.errorCode\n : isNumber(options)\n ? options\n : 500;\n const message =\n options && typeof options === 'object' && 'message' in options\n ? options.message\n : isString(options)\n ? options\n : `Error with status code '${errorCode}' ocurred during Pongo processing`;\n\n super(message);\n this.errorCode = errorCode;\n\n // 👇️ because we are extending a built-in class\n Object.setPrototypeOf(this, PongoError.prototype);\n }\n}\n\nexport class ConcurrencyError extends PongoError {\n constructor(message?: string) {\n super({\n errorCode: 412,\n message: message ?? `Expected document state does not match current one!`,\n });\n\n // 👇️ because we are extending a built-in class\n Object.setPrototypeOf(this, ConcurrencyError.prototype);\n }\n}\n","import { type MigrationStyle } from '@event-driven-io/dumbo';\nimport {\n NodePostgresConnectorType,\n type NodePostgresConnection,\n} from '@event-driven-io/dumbo/pg';\nimport pg from 'pg';\nimport type { PostgresDbClientOptions } from '../storage/postgresql';\nimport { getPongoDb, type AllowedDbClientOptions } from './pongoDb';\nimport { pongoSession } from './pongoSession';\nimport {\n proxyClientWithSchema,\n type PongoClientSchema,\n type PongoClientWithSchema,\n} from './schema';\nimport type { PongoClient, PongoDb, PongoSession } from './typing';\n\nexport type PooledPongoClientOptions =\n | {\n pool: pg.Pool;\n }\n | {\n pooled: true;\n }\n | {\n pool: pg.Pool;\n pooled: true;\n }\n | object;\n\nexport type NotPooledPongoOptions =\n | {\n client: pg.Client;\n }\n | {\n pooled: false;\n }\n | {\n client: pg.Client;\n pooled: false;\n }\n | {\n connection: NodePostgresConnection;\n pooled?: false;\n };\n\nexport type PongoClientOptions<\n TypedClientSchema extends PongoClientSchema = PongoClientSchema,\n> = {\n schema?: { autoMigration?: MigrationStyle; definition?: TypedClientSchema };\n errors?: { throwOnOperationFailures?: boolean };\n connectionOptions?: PooledPongoClientOptions | NotPooledPongoOptions;\n};\n\nexport const pongoClient = <\n TypedClientSchema extends PongoClientSchema = PongoClientSchema,\n DbClientOptions extends AllowedDbClientOptions = AllowedDbClientOptions,\n>(\n connectionString: string,\n options: PongoClientOptions<TypedClientSchema> = {},\n): PongoClient & PongoClientWithSchema<TypedClientSchema> => {\n const dbClients = new Map<string, PongoDb>();\n\n const dbClient = getPongoDb<DbClientOptions>(\n clientToDbOptions({\n connectionString,\n clientOptions: options,\n }),\n );\n dbClients.set(dbClient.databaseName, dbClient);\n\n const pongoClient: PongoClient = {\n connect: async () => {\n await dbClient.connect();\n return pongoClient;\n },\n close: async () => {\n for (const db of dbClients.values()) {\n await db.close();\n }\n },\n db: (dbName?: string): PongoDb => {\n if (!dbName) return dbClient;\n\n return (\n dbClients.get(dbName) ??\n dbClients\n .set(\n dbName,\n getPongoDb<DbClientOptions>(\n clientToDbOptions({\n connectionString,\n dbName,\n clientOptions: options,\n }),\n ),\n )\n .get(dbName)!\n );\n },\n startSession: pongoSession,\n withSession: async <T>(\n callback: (session: PongoSession) => Promise<T>,\n ): Promise<T> => {\n const session = pongoSession();\n\n try {\n return await callback(session);\n } finally {\n await session.endSession();\n }\n },\n };\n\n return proxyClientWithSchema(pongoClient, options?.schema?.definition);\n};\n\nexport const clientToDbOptions = <\n DbClientOptions extends AllowedDbClientOptions = AllowedDbClientOptions,\n>(options: {\n connectionString: string;\n dbName?: string;\n clientOptions: PongoClientOptions;\n}): DbClientOptions => {\n const postgreSQLOptions: PostgresDbClientOptions = {\n connector: NodePostgresConnectorType,\n connectionString: options.connectionString,\n dbName: options.dbName,\n ...options.clientOptions,\n };\n\n return postgreSQLOptions as DbClientOptions;\n};\n","import type { ConnectorType } from '@event-driven-io/dumbo/src';\nimport {\n isPostgresClientOptions,\n postgresDb,\n type PostgresDbClientOptions,\n} from '../storage/postgresql';\nimport type { PongoClientOptions } from './pongoClient';\nimport type { PongoDb } from './typing';\n\nexport type PongoDbClientOptions<\n Connector extends ConnectorType = ConnectorType,\n> = {\n connector: Connector;\n connectionString: string;\n dbName: string | undefined;\n} & PongoClientOptions;\n\nexport type AllowedDbClientOptions = PostgresDbClientOptions;\n\nexport const getPongoDb = <\n DbClientOptions extends AllowedDbClientOptions = AllowedDbClientOptions,\n>(\n options: DbClientOptions,\n): PongoDb => {\n const { connector } = options;\n // This is the place where in the future could come resolution of other database types\n if (!isPostgresClientOptions(options))\n throw new Error(`Unsupported db type: ${connector}`);\n\n return postgresDb(options);\n};\n","import type { DatabaseTransaction } from '@event-driven-io/dumbo';\nimport type {\n PongoDb,\n PongoDbTransaction,\n PongoTransactionOptions,\n} from './typing';\n\nexport const pongoTransaction = (\n options: PongoTransactionOptions,\n): PongoDbTransaction => {\n let isCommitted = false;\n let isRolledBack = false;\n let databaseName: string | null = null;\n let transaction: DatabaseTransaction | null = null;\n\n return {\n enlistDatabase: async (db: PongoDb): Promise<DatabaseTransaction> => {\n if (transaction && databaseName !== db.databaseName)\n throw new Error(\n \"There's already other database assigned to transaction\",\n );\n\n if (transaction && databaseName === db.databaseName) return transaction;\n\n databaseName = db.databaseName;\n transaction = db.transaction();\n await transaction.begin();\n\n return transaction;\n },\n commit: async () => {\n if (!transaction) throw new Error('No database transaction started!');\n if (isCommitted) return;\n if (isRolledBack) throw new Error('Transaction is not active!');\n\n isCommitted = true;\n\n await transaction.commit();\n\n transaction = null;\n },\n rollback: async (error?: unknown) => {\n if (!transaction) throw new Error('No database transaction started!');\n if (isCommitted) throw new Error('Cannot rollback commited transaction!');\n if (isRolledBack) return;\n\n isRolledBack = true;\n\n await transaction.rollback(error);\n\n transaction = null;\n },\n databaseName,\n isStarting: false,\n isCommitted,\n get isActive() {\n return !isCommitted && !isRolledBack;\n },\n get sqlExecutor() {\n if (transaction === null)\n throw new Error('No database transaction was started');\n\n return transaction.execute;\n },\n options,\n };\n};\n","import { pongoTransaction } from './pongoTransaction';\nimport type {\n PongoDbTransaction,\n PongoSession,\n PongoTransactionOptions,\n} from './typing';\n\nexport type PongoSessionOptions = {\n explicit?: boolean;\n defaultTransactionOptions: PongoTransactionOptions;\n};\n\nconst isActive = (\n transaction: PongoDbTransaction | null,\n): transaction is PongoDbTransaction => transaction?.isActive === true;\n\nfunction assertInActiveTransaction(\n transaction: PongoDbTransaction | null,\n): asserts transaction is PongoDbTransaction {\n if (!isActive(transaction)) throw new Error('No active transaction exists!');\n}\n\nfunction assertNotInActiveTransaction(\n transaction: PongoDbTransaction | null,\n): asserts transaction is null {\n if (isActive(transaction))\n throw new Error('Active transaction already exists!');\n}\n\nexport const pongoSession = (options?: PongoSessionOptions): PongoSession => {\n const explicit = options?.explicit === true;\n const defaultTransactionOptions: PongoTransactionOptions =\n options?.defaultTransactionOptions ?? {\n get snapshotEnabled() {\n return false;\n },\n };\n\n let transaction: PongoDbTransaction | null = null;\n let hasEnded = false;\n\n const startTransaction = (options?: PongoTransactionOptions) => {\n assertNotInActiveTransaction(transaction);\n\n transaction = pongoTransaction(options ?? defaultTransactionOptions);\n };\n const commitTransaction = async () => {\n assertInActiveTransaction(transaction);\n\n await transaction.commit();\n };\n const abortTransaction = async () => {\n assertInActiveTransaction(transaction);\n\n await transaction.rollback();\n };\n\n const endSession = async (): Promise<void> => {\n if (hasEnded) return;\n hasEnded = true;\n\n if (isActive(transaction)) await transaction.rollback();\n };\n\n const session = {\n get hasEnded() {\n return hasEnded;\n },\n explicit,\n defaultTransactionOptions: defaultTransactionOptions ?? {\n get snapshotEnabled() {\n return false;\n },\n },\n get transaction() {\n return transaction;\n },\n get snapshotEnabled() {\n return defaultTransactionOptions.snapshotEnabled;\n },\n endSession,\n incrementTransactionNumber: () => {},\n inTransaction: () => isActive(transaction),\n startTransaction,\n commitTransaction,\n abortTransaction,\n withTransaction: async <T = unknown>(\n fn: (session: PongoSession) => Promise<T>,\n options?: PongoTransactionOptions,\n ): Promise<T> => {\n startTransaction(options);\n\n try {\n const result = await fn(session);\n await commitTransaction();\n return result;\n } catch (error) {\n await abortTransaction();\n throw error;\n }\n },\n };\n\n return session;\n};\n","type Entry<T> = {\n [K in keyof Required<T>]: [K, Required<T>[K]];\n}[keyof Required<T>];\n\ntype IterableEntry<T> = Entry<T> & {\n [Symbol.iterator](): Iterator<Entry<T>>;\n};\n\nexport const objectEntries = <T extends object>(obj: T): IterableEntry<T>[] =>\n Object.entries(obj).map(([key, value]) => [key as keyof T, value]);\n\nexport type NonPartial<T> = { [K in keyof Required<T>]: T[K] };\n","import {\n type ConnectorType,\n type DatabaseTransaction,\n type DatabaseTransactionFactory,\n JSONSerializer,\n type QueryResult,\n type QueryResultRow,\n type SchemaComponent,\n type SQL,\n type SQLExecutor,\n} from '@event-driven-io/dumbo';\nimport { v7 as uuid } from 'uuid';\nimport { ConcurrencyError } from '../errors';\n\nexport interface PongoClient {\n connect(): Promise<this>;\n\n close(): Promise<void>;\n\n db(dbName?: string): PongoDb;\n\n startSession(): PongoSession;\n\n withSession<T = unknown>(\n callback: (session: PongoSession) => Promise<T>,\n ): Promise<T>;\n}\n\nexport declare interface PongoTransactionOptions {\n get snapshotEnabled(): boolean;\n maxCommitTimeMS?: number;\n}\n\nexport interface PongoDbTransaction {\n get databaseName(): string | null;\n options: PongoTransactionOptions;\n enlistDatabase: (database: PongoDb) => Promise<DatabaseTransaction>;\n commit: () => Promise<void>;\n rollback: (error?: unknown) => Promise<void>;\n get sqlExecutor(): SQLExecutor;\n get isStarting(): boolean;\n get isActive(): boolean;\n get isCommitted(): boolean;\n}\n\nexport interface PongoSession {\n hasEnded: boolean;\n explicit: boolean;\n defaultTransactionOptions: PongoTransactionOptions;\n transaction: PongoDbTransaction | null;\n get snapshotEnabled(): boolean;\n\n endSession(): Promise<void>;\n incrementTransactionNumber(): void;\n inTransaction(): boolean;\n startTransaction(options?: PongoTransactionOptions): void;\n commitTransaction(): Promise<void>;\n abortTransaction(): Promise<void>;\n withTransaction<T = unknown>(\n fn: (session: PongoSession) => Promise<T>,\n options?: PongoTransactionOptions,\n ): Promise<T>;\n}\n\nexport interface PongoDb<Connector extends ConnectorType = ConnectorType>\n extends DatabaseTransactionFactory<Connector> {\n get connector(): Connector;\n get databaseName(): string;\n connect(): Promise<void>;\n close(): Promise<void>;\n collection<T extends PongoDocument>(name: string): PongoCollection<T>;\n collections(): ReadonlyArray<PongoCollection<PongoDocument>>;\n readonly schema: Readonly<{\n component: SchemaComponent;\n migrate(): Promise<void>;\n }>;\n sql: {\n query<Result extends QueryResultRow = QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ): Promise<Result[]>;\n command<Result extends QueryResultRow = QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ): Promise<QueryResult<Result>>;\n };\n}\n\nexport type CollectionOperationOptions = {\n session?: PongoSession;\n};\n\nexport type InsertOneOptions = {\n expectedVersion?: Extract<\n ExpectedDocumentVersion,\n 'DOCUMENT_DOES_NOT_EXIST' | 'NO_CONCURRENCY_CHECK'\n >;\n} & CollectionOperationOptions;\n\nexport type InsertManyOptions = {\n expectedVersion?: Extract<\n ExpectedDocumentVersion,\n 'DOCUMENT_DOES_NOT_EXIST' | 'NO_CONCURRENCY_CHECK'\n >;\n} & CollectionOperationOptions;\n\nexport type UpdateOneOptions = {\n expectedVersion?: Exclude<ExpectedDocumentVersion, 'DOCUMENT_DOES_NOT_EXIST'>;\n} & CollectionOperationOptions;\n\nexport type UpdateManyOptions = {\n expectedVersion?: Extract<\n ExpectedDocumentVersion,\n 'DOCUMENT_EXISTS' | 'NO_CONCURRENCY_CHECK'\n >;\n} & CollectionOperationOptions;\n\nexport type HandleOptions = {\n expectedVersion?: ExpectedDocumentVersion;\n} & CollectionOperationOptions;\n\nexport type ReplaceOneOptions = {\n expectedVersion?: Exclude<ExpectedDocumentVersion, 'DOCUMENT_DOES_NOT_EXIST'>;\n} & CollectionOperationOptions;\n\nexport type DeleteOneOptions = {\n expectedVersion?: Exclude<ExpectedDocumentVersion, 'DOCUMENT_DOES_NOT_EXIST'>;\n} & CollectionOperationOptions;\n\nexport type DeleteManyOptions = {\n expectedVersion?: Extract<\n ExpectedDocumentVersion,\n 'DOCUMENT_EXISTS' | 'NO_CONCURRENCY_CHECK'\n >;\n} & CollectionOperationOptions;\n\nexport type FindOptions = {\n limit?: number;\n skip?: number;\n} & CollectionOperationOptions;\n\nexport interface PongoCollection<T extends PongoDocument> {\n readonly dbName: string;\n readonly collectionName: string;\n createCollection(options?: CollectionOperationOptions): Promise<void>;\n insertOne(\n document: OptionalUnlessRequiredId<T>,\n options?: InsertOneOptions,\n ): Promise<PongoInsertOneResult>;\n insertMany(\n documents: OptionalUnlessRequiredId<T>[],\n options?: CollectionOperationOptions,\n ): Promise<PongoInsertManyResult>;\n updateOne(\n filter: PongoFilter<T> | SQL,\n update: PongoUpdate<T> | SQL,\n options?: UpdateOneOptions,\n ): Promise<PongoUpdateResult>;\n replaceOne(\n filter: PongoFilter<T> | SQL,\n document: WithoutId<T>,\n options?: ReplaceOneOptions,\n ): Promise<PongoUpdateResult>;\n updateMany(\n filter: PongoFilter<T> | SQL,\n update: PongoUpdate<T> | SQL,\n options?: UpdateManyOptions,\n ): Promise<PongoUpdateManyResult>;\n deleteOne(\n filter?: PongoFilter<T> | SQL,\n options?: DeleteOneOptions,\n ): Promise<PongoDeleteResult>;\n deleteMany(\n filter?: PongoFilter<T> | SQL,\n options?: DeleteManyOptions,\n ): Promise<PongoDeleteResult>;\n findOne(\n filter?: PongoFilter<T> | SQL,\n options?: CollectionOperationOptions,\n ): Promise<WithIdAndVersion<T> | null>;\n find(\n filter?: PongoFilter<T> | SQL,\n options?: FindOptions,\n ): Promise<WithIdAndVersion<T>[]>;\n findOneAndDelete(\n filter: PongoFilter<T> | SQL,\n options?: DeleteOneOptions,\n ): Promise<WithIdAndVersion<T> | null>;\n findOneAndReplace(\n filter: PongoFilter<T> | SQL,\n replacement: WithoutId<T>,\n options?: ReplaceOneOptions,\n ): Promise<WithIdAndVersion<T> | null>;\n findOneAndUpdate(\n filter: PongoFilter<T> | SQL,\n update: PongoUpdate<T> | SQL,\n options?: UpdateOneOptions,\n ): Promise<WithIdAndVersion<T> | null>;\n countDocuments(\n filter?: PongoFilter<T> | SQL,\n options?: CollectionOperationOptions,\n ): Promise<number>;\n drop(options?: CollectionOperationOptions): Promise<boolean>;\n rename(\n newName: string,\n options?: CollectionOperationOptions,\n ): Promise<PongoCollection<T>>;\n handle(\n id: string,\n handle: DocumentHandler<T>,\n options?: HandleOptions,\n ): Promise<PongoHandleResult<T>>;\n readonly schema: Readonly<{\n component: SchemaComponent;\n migrate(): Promise<void>;\n }>;\n sql: {\n query<Result extends QueryResultRow = QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ): Promise<Result[]>;\n command<Result extends QueryResultRow = QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ): Promise<QueryResult<Result>>;\n };\n}\n\nexport type ObjectId = string & { __brandId: 'ObjectId' };\nexport const ObjectId = (value?: string) => value ?? uuid();\n\nexport type HasId = { _id: string };\n\nexport declare type InferIdType<TSchema> = TSchema extends {\n _id: infer IdType;\n}\n ? // eslint-disable-next-line @typescript-eslint/no-explicit-any\n Record<any, never> extends IdType\n ? never\n : IdType\n : TSchema extends {\n _id?: infer IdType;\n }\n ? unknown extends IdType\n ? ObjectId\n : IdType\n : ObjectId;\n\n/** TypeScript Omit (Exclude to be specific) does not work for objects with an \"any\" indexed type, and breaks discriminated unions @public */\nexport declare type EnhancedOmit<TRecordOrUnion, KeyUnion> =\n string extends keyof TRecordOrUnion\n ? TRecordOrUnion\n : // eslint-disable-next-line @typescript-eslint/no-explicit-any\n TRecordOrUnion extends any\n ? Pick<TRecordOrUnion, Exclude<keyof TRecordOrUnion, KeyUnion>>\n : never;\n\nexport declare type OptionalUnlessRequiredId<TSchema> = TSchema extends {\n _id: string | ObjectId;\n}\n ? TSchema\n : OptionalId<TSchema>;\n\nexport declare type OptionalUnlessRequiredVersion<TSchema> = TSchema extends {\n _version: bigint;\n}\n ? TSchema\n : OptionalVersion<TSchema>;\n\nexport declare type OptionalUnlessRequiredIdAndVersion<TSchema> =\n OptionalUnlessRequiredId<TSchema> & OptionalUnlessRequiredVersion<TSchema>;\n\nexport declare type WithId<TSchema> = EnhancedOmit<TSchema, '_id'> & {\n _id: string | ObjectId;\n};\nexport type WithoutId<T> = Omit<T, '_id'>;\n\nexport declare type WithVersion<TSchema> = EnhancedOmit<TSchema, '_version'> & {\n _version: bigint;\n};\nexport type WithoutVersion<T> = Omit<T, '_version'>;\n\nexport type WithIdAndVersion<T> = WithId<WithVersion<T>>;\nexport type WithoutIdAndVersion<T> = WithoutId<WithoutVersion<T>>;\n\n/** @public */\nexport declare type RegExpOrString<T> = T extends string ? RegExp | T : T;\n\nexport declare interface Document {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [key: string]: any;\n}\n\nexport declare type OptionalId<TSchema> = EnhancedOmit<TSchema, '_id'> & {\n _id?: string | ObjectId;\n};\nexport declare type OptionalVersion<TSchema> = EnhancedOmit<\n TSchema,\n '_version'\n> & {\n _version?: bigint;\n};\n\nexport declare interface ObjectIdLike {\n __id?: string | ObjectId;\n}\n\nexport declare type NonObjectIdLikeDocument = {\n [key in keyof ObjectIdLike]?: never;\n} & Document;\n\nexport declare type AlternativeType<T> =\n T extends ReadonlyArray<infer U> ? T | RegExpOrString<U> : RegExpOrString<T>;\n\nexport declare type Condition<T> =\n | AlternativeType<T>\n | PongoFilterOperator<AlternativeType<T>>;\n\nexport declare type PongoFilter<TSchema> =\n | {\n [P in keyof WithId<TSchema>]?: Condition<WithId<TSchema>[P]>;\n }\n | HasId; // TODO: & RootFilterOperators<WithId<TSchema>>;\n\nexport declare interface RootFilterOperators<TSchema> extends Document {\n $and?: PongoFilter<TSchema>[];\n $nor?: PongoFilter<TSchema>[];\n $or?: PongoFilter<TSchema>[];\n $text?: {\n $search: string;\n $language?: string;\n $caseSensitive?: boolean;\n $diacriticSensitive?: boolean;\n };\n $where?: string | ((this: TSchema) => boolean);\n $comment?: string | Document;\n}\n\nexport declare interface PongoFilterOperator<TValue>\n extends NonObjectIdLikeDocument {\n $eq?: TValue;\n $gt?: TValue;\n $gte?: TValue;\n $lt?: TValue;\n $lte?: TValue;\n $ne?: TValue;\n $in?: TValue[];\n $nin?: TValue[];\n // $eq?: TValue;\n // $gt?: TValue;\n // $gte?: TValue;\n // $in?: ReadonlyArray<TValue>;\n // $lt?: TValue;\n // $lte?: TValue;\n // $ne?: TValue;\n // $nin?: ReadonlyArray<TValue>;\n // $not?: TValue extends string ? FilterOperators<TValue> | RegExp : FilterOperators<TValue>;\n // /**\n // * When `true`, `$exists` matches the documents that contain the field,\n // * including documents where the field value is null.\n // */\n // $exists?: boolean;\n // $type?: BSONType | BSONTypeAlias;\n // $expr?: Record<string, any>;\n // $jsonSchema?: Record<string, any>;\n // $mod?: TValue extends number ? [number, number] : never;\n // $regex?: TValue extends string ? RegExp | BSONRegExp | string : never;\n // $options?: TValue extends string ? string : never;\n // $geoIntersects?: {\n // $geometry: Document;\n // };\n // $geoWithin?: Document;\n // $near?: Document;\n // $nearSphere?: Document;\n // $maxDistance?: number;\n // $all?: ReadonlyArray<any>;\n // $elemMatch?: Document;\n // $size?: TValue extends ReadonlyArray<any> ? number : never;\n // $bitsAllClear?: BitwiseFilter;\n // $bitsAllSet?: BitwiseFilter;\n // $bitsAnyClear?: BitwiseFilter;\n // $bitsAnySet?: BitwiseFilter;\n // $rand?: Record<string, never>;\n}\n\nexport type $set<T> = Partial<T>;\nexport type $unset<T> = { [P in keyof T]?: '' };\nexport type $inc<T> = { [P in keyof T]?: number | bigint };\nexport type $push<T> = { [P in keyof T]?: T[P] };\n\nexport type ExpectedDocumentVersionGeneral =\n | 'DOCUMENT_EXISTS'\n | 'DOCUMENT_DOES_NOT_EXIST'\n | 'NO_CONCURRENCY_CHECK';\n\nexport type ExpectedDocumentVersionValue = bigint & { __brand: 'sql' };\n\nexport type ExpectedDocumentVersion =\n | (bigint & { __brand: 'sql' })\n | bigint\n | ExpectedDocumentVersionGeneral;\n\nexport const DOCUMENT_EXISTS =\n 'DOCUMENT_EXISTS' as ExpectedDocumentVersionGeneral;\nexport const DOCUMENT_DOES_NOT_EXIST =\n 'DOCUMENT_DOES_NOT_EXIST' as ExpectedDocumentVersionGeneral;\nexport const NO_CONCURRENCY_CHECK =\n 'NO_CONCURRENCY_CHECK' as ExpectedDocumentVersionGeneral;\n\nexport const isGeneralExpectedDocumentVersion = (\n version: ExpectedDocumentVersion,\n): version is ExpectedDocumentVersionGeneral =>\n version === 'DOCUMENT_DOES_NOT_EXIST' ||\n version === 'DOCUMENT_EXISTS' ||\n version === 'NO_CONCURRENCY_CHECK';\n\nexport const expectedVersionValue = (\n version: ExpectedDocumentVersion | undefined,\n): ExpectedDocumentVersionValue | null =>\n version === undefined || isGeneralExpectedDocumentVersion(version)\n ? null\n : (version as ExpectedDocumentVersionValue);\n\nexport const expectedVersion = (\n version: number | bigint | string | undefined | null,\n): ExpectedDocumentVersion => {\n return version\n ? (BigInt(version) as ExpectedDocumentVersion)\n : NO_CONCURRENCY_CHECK;\n};\n\nexport type PongoUpdate<T> = {\n $set?: Partial<T>;\n $unset?: $unset<T>;\n $inc?: $inc<T>;\n $push?: $push<T>;\n};\n\nexport type OperationResult = {\n acknowledged: boolean;\n successful: boolean;\n\n assertSuccessful: (errorMessage?: string) => void;\n};\n\nexport const operationResult = <T extends OperationResult>(\n result: Omit<T, 'assertSuccess' | 'acknowledged' | 'assertSuccessful'>,\n options: {\n operationName: string;\n collectionName: string;\n errors?: { throwOnOperationFailures?: boolean } | undefined;\n },\n): T => {\n const operationResult: T = {\n ...result,\n acknowledged: true,\n successful: result.successful,\n assertSuccessful: (errorMessage?: string) => {\n const { successful } = result;\n const { operationName, collectionName } = options;\n\n if (!successful)\n throw new ConcurrencyError(\n errorMessage ??\n `${operationName} on ${collectionName} failed. Expected document state does not match current one! Result: ${JSONSerializer.serialize(result)}!`,\n );\n },\n } as T;\n\n if (options.errors?.throwOnOperationFailures)\n operationResult.assertSuccessful();\n\n return operationResult;\n};\n\nexport interface PongoInsertOneResult extends OperationResult {\n insertedId: string | null;\n nextExpectedVersion: bigint;\n}\n\nexport interface PongoInsertManyResult extends OperationResult {\n insertedIds: string[];\n insertedCount: number;\n}\n\nexport interface PongoUpdateResult extends OperationResult {\n matchedCount: number;\n modifiedCount: number;\n nextExpectedVersion: bigint;\n}\n\nexport interface PongoUpdateManyResult extends OperationResult {\n matchedCount: number;\n modifiedCount: number;\n}\n\nexport interface PongoDeleteResult extends OperationResult {\n matchedCount: number;\n deletedCount: number;\n}\n\nexport interface PongoDeleteManyResult extends OperationResult {\n deletedCount: number;\n}\n\nexport type PongoHandleResult<T> =\n | (PongoInsertOneResult & { document: T })\n | (PongoUpdateResult & { document: T })\n | (PongoDeleteResult & { document: null })\n | (OperationResult & { document: null });\n\nexport type PongoDocument = Record<string, unknown>;\n\nexport type DocumentHandler<T extends PongoDocument> =\n | ((document: T | null) => T | null)\n | ((document: T | null) => Promise<T | null>);\n","import type { ConnectorType } from '@event-driven-io/dumbo/src';\nimport {\n type Document,\n type PongoClient,\n type PongoCollection,\n type PongoDb,\n type PongoDocument,\n objectEntries,\n} from '../typing';\n\nexport interface PongoCollectionSchema<\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n T extends PongoDocument = PongoDocument,\n> {\n name: string;\n}\n\n// Database schema interface\nexport interface PongoDbSchema<\n T extends Record<string, PongoCollectionSchema> = Record<\n string,\n PongoCollectionSchema\n >,\n> {\n name?: string;\n collections: T;\n}\n\nexport interface PongoClientSchema<\n T extends Record<string, PongoDbSchema> = Record<string, PongoDbSchema>,\n> {\n dbs: T;\n}\n\nexport type CollectionsMap<T extends Record<string, PongoCollectionSchema>> = {\n [K in keyof T]: PongoCollection<\n T[K] extends PongoCollectionSchema<infer U> ? U : PongoDocument\n >;\n};\n\nexport type PongoDbWithSchema<\n T extends Record<string, PongoCollectionSchema>,\n Connector extends ConnectorType = ConnectorType,\n> = CollectionsMap<T> & PongoDb<Connector>;\n\nexport type DBsMap<\n T extends Record<string, PongoDbSchema>,\n Connector extends ConnectorType = ConnectorType,\n> = {\n [K in keyof T]: CollectionsMap<T[K]['collections']> & PongoDb<Connector>;\n};\n\nexport type PongoClientWithSchema<\n T extends PongoClientSchema,\n Connector extends ConnectorType = ConnectorType,\n> = DBsMap<T['dbs'], Connector> & PongoClient;\n\nconst pongoCollectionSchema = <T extends PongoDocument>(\n name: string,\n): PongoCollectionSchema<T> => ({\n name,\n});\n\nfunction pongoDbSchema<T extends Record<string, PongoCollectionSchema>>(\n collections: T,\n): PongoDbSchema<T>;\nfunction pongoDbSchema<T extends Record<string, PongoCollectionSchema>>(\n name: string,\n collections: T,\n): PongoDbSchema<T>;\nfunction pongoDbSchema<T extends Record<string, PongoCollectionSchema>>(\n nameOrCollections: string | T,\n collections?: T,\n): PongoDbSchema<T> {\n if (collections === undefined) {\n if (typeof nameOrCollections === 'string') {\n throw new Error('You need to provide colleciton definition');\n }\n return {\n collections: nameOrCollections,\n };\n }\n\n return nameOrCollections && typeof nameOrCollections === 'string'\n ? {\n name: nameOrCollections,\n collections,\n }\n : { collections: collections };\n}\n\nconst pongoClientSchema = <T extends Record<string, PongoDbSchema>>(\n dbs: T,\n): PongoClientSchema<T> => ({\n dbs,\n});\n\nexport const pongoSchema = {\n client: pongoClientSchema,\n db: pongoDbSchema,\n collection: pongoCollectionSchema,\n};\n\n// Factory function to create DB instances\nexport const proxyPongoDbWithSchema = <\n T extends Record<string, PongoCollectionSchema>,\n Connector extends ConnectorType = ConnectorType,\n>(\n pongoDb: PongoDb<Connector>,\n dbSchema: PongoDbSchema<T>,\n collections: Map<string, PongoCollection<Document>>,\n): PongoDbWithSchema<T, Connector> => {\n const collectionNames = Object.keys(dbSchema.collections);\n\n for (const collectionName of collectionNames) {\n collections.set(collectionName, pongoDb.collection(collectionName));\n }\n\n return new Proxy(\n pongoDb as PongoDb<Connector> & {\n [key: string]: unknown;\n },\n {\n get(target, prop: string) {\n return collections.get(prop) ?? target[prop];\n },\n },\n ) as PongoDbWithSchema<T, Connector>;\n};\n\nexport const proxyClientWithSchema = <\n TypedClientSchema extends PongoClientSchema,\n>(\n client: PongoClient,\n schema: TypedClientSchema | undefined,\n): PongoClientWithSchema<TypedClientSchema> => {\n if (!schema) return client as PongoClientWithSchema<TypedClientSchema>;\n\n const dbNames = Object.keys(schema.dbs);\n\n return new Proxy(\n client as PongoClient & {\n [key: string]: unknown;\n },\n {\n get(target, prop: string) {\n if (dbNames.includes(prop)) return client.db(schema.dbs[prop]?.name);\n\n return target[prop];\n },\n },\n ) as PongoClientWithSchema<TypedClientSchema>;\n};\n\nexport type PongoCollectionSchemaMetadata = {\n name: string;\n};\n\nexport type PongoDbSchemaMetadata = {\n name?: string | undefined;\n collections: PongoCollectionSchemaMetadata[];\n};\n\nexport type PongoClientSchemaMetadata = {\n databases: PongoDbSchemaMetadata[];\n database: (name?: string) => PongoDbSchemaMetadata | undefined;\n};\n\nexport const toDbSchemaMetadata = <TypedDbSchema extends PongoDbSchema>(\n schema: TypedDbSchema,\n): PongoDbSchemaMetadata => ({\n name: schema.name,\n collections: objectEntries(schema.collections).map((c) => ({\n name: c[1].name,\n })),\n});\n\nexport const toClientSchemaMetadata = <\n TypedClientSchema extends PongoClientSchema,\n>(\n schema: TypedClientSchema,\n): PongoClientSchemaMetadata => {\n const databases = objectEntries(schema.dbs).map((e) =>\n toDbSchemaMetadata(e[1]),\n );\n\n return {\n databases,\n database: (name) => databases.find((db) => db.name === name),\n };\n};\n\nexport interface PongoSchemaConfig<\n TypedClientSchema extends PongoClientSchema = PongoClientSchema,\n> {\n schema: TypedClientSchema;\n}\n","export const deepEquals = <T>(left: T, right: T): boolean => {\n if (isEquatable(left)) {\n return left.equals(right);\n }\n\n if (Array.isArray(left)) {\n return (\n Array.isArray(right) &&\n left.length === right.length &&\n left.every((val, index) => deepEquals(val, right[index]))\n );\n }\n\n if (\n typeof left !== 'object' ||\n typeof right !== 'object' ||\n left === null ||\n right === null\n ) {\n return left === right;\n }\n\n if (Array.isArray(right)) return false;\n\n const keys1 = Object.keys(left);\n const keys2 = Object.keys(right);\n\n if (\n keys1.length !== keys2.length ||\n !keys1.every((key) => keys2.includes(key))\n )\n return false;\n\n for (const key in left) {\n if (left[key] instanceof Function && right[key] instanceof Function)\n continue;\n\n const isEqual = deepEquals(left[key], right[key]);\n if (!isEqual) {\n return false;\n }\n }\n\n return true;\n};\n\nexport type Equatable<T> = { equals: (right: T) => boolean } & T;\n\nexport const isEquatable = <T>(left: T): left is Equatable<T> => {\n return (\n left &&\n typeof left === 'object' &&\n 'equals' in left &&\n typeof left['equals'] === 'function'\n );\n};\n","import { JSONSerializer, sql } from '@event-driven-io/dumbo';\nimport { objectEntries, OperatorMap } from '../../../../core';\n\nexport const handleOperator = (\n path: string,\n operator: string,\n value: unknown,\n): string => {\n if (path === '_id' || path === '_version') {\n return handleMetadataOperator(path, operator, value);\n }\n\n switch (operator) {\n case '$eq':\n return sql(\n `(data @> %L::jsonb OR jsonb_path_exists(data, '$.%s[*] ? (@ == %s)'))`,\n JSONSerializer.serialize(buildNestedObject(path, value)),\n path,\n JSONSerializer.serialize(value),\n );\n case '$gt':\n case '$gte':\n case '$lt':\n case '$lte':\n case '$ne':\n return sql(\n `data #>> %L ${OperatorMap[operator]} %L`,\n `{${path.split('.').join(',')}}`,\n value,\n );\n case '$in':\n return sql(\n 'data #>> %L IN (%s)',\n `{${path.split('.').join(',')}}`,\n (value as unknown[]).map((v) => sql('%L', v)).join(', '),\n );\n case '$nin':\n return sql(\n 'data #>> %L NOT IN (%s)',\n `{${path.split('.').join(',')}}`,\n (value as unknown[]).map((v) => sql('%L', v)).join(', '),\n );\n case '$elemMatch': {\n const subQuery = objectEntries(value as Record<string, unknown>)\n .map(([subKey, subValue]) =>\n sql(`@.\"%s\" == %s`, subKey, JSONSerializer.serialize(subValue)),\n )\n .join(' && ');\n return sql(`jsonb_path_exists(data, '$.%s[*] ? (%s)')`, path, subQuery);\n }\n case '$all':\n return sql(\n 'data @> %L::jsonb',\n JSONSerializer.serialize(buildNestedObject(path, value)),\n );\n case '$size':\n return sql(\n 'jsonb_array_length(data #> %L) = %L',\n `{${path.split('.').join(',')}}`,\n value,\n );\n default:\n throw new Error(`Unsupported operator: ${operator}`);\n }\n};\n\nconst handleMetadataOperator = (\n fieldName: string,\n operator: string,\n value: unknown,\n): string => {\n switch (operator) {\n case '$eq':\n return sql(`${fieldName} = %L`, value);\n case '$gt':\n case '$gte':\n case '$lt':\n case '$lte':\n case '$ne':\n return sql(`${fieldName} ${OperatorMap[operator]} %L`, value);\n case '$in':\n return sql(\n `${fieldName} IN (%s)`,\n (value as unknown[]).map((v) => sql('%L', v)).join(', '),\n );\n case '$nin':\n return sql(\n `${fieldName} NOT IN (%s)`,\n (value as unknown[]).map((v) => sql('%L', v)).join(', '),\n );\n default:\n throw new Error(`Unsupported operator: ${operator}`);\n }\n};\n\nconst buildNestedObject = (\n path: string,\n value: unknown,\n): Record<string, unknown> =>\n path\n .split('.')\n .reverse()\n .reduce((acc, key) => ({ [key]: acc }), value as Record<string, unknown>);\n","import {\n hasOperators,\n objectEntries,\n QueryOperators,\n type PongoFilter,\n} from '../../../../core';\nimport { handleOperator } from './queryOperators';\n\nexport * from './queryOperators';\n\nconst AND = 'AND';\n\nexport const constructFilterQuery = <T>(filter: PongoFilter<T>): string =>\n Object.entries(filter)\n .map(([key, value]) =>\n isRecord(value)\n ? constructComplexFilterQuery(key, value)\n : handleOperator(key, '$eq', value),\n )\n .join(` ${AND} `);\n\nconst constructComplexFilterQuery = (\n key: string,\n value: Record<string, unknown>,\n): string => {\n const isEquality = !hasOperators(value);\n\n return objectEntries(value)\n .map(\n ([nestedKey, val]) =>\n isEquality\n ? handleOperator(`${key}.${nestedKey}`, QueryOperators.$eq, val) // regular value\n : handleOperator(key, nestedKey, val), // operator\n )\n .join(` ${AND} `);\n};\n\nconst isRecord = (value: unknown): value is Record<string, unknown> =>\n value !== null && typeof value === 'object' && !Array.isArray(value);\n","import { JSONSerializer, sql, type SQL } from '@event-driven-io/dumbo';\nimport {\n objectEntries,\n type $inc,\n type $push,\n type $set,\n type $unset,\n type PongoUpdate,\n} from '../../../../core';\n\nexport const buildUpdateQuery = <T>(update: PongoUpdate<T>): SQL =>\n objectEntries(update).reduce((currentUpdateQuery, [op, value]) => {\n switch (op) {\n case '$set':\n return buildSetQuery(value, currentUpdateQuery);\n case '$unset':\n return buildUnsetQuery(value, currentUpdateQuery);\n case '$inc':\n return buildIncQuery(value, currentUpdateQuery);\n case '$push':\n return buildPushQuery(value, currentUpdateQuery);\n default:\n return currentUpdateQuery;\n }\n }, sql('data'));\n\nexport const buildSetQuery = <T>(set: $set<T>, currentUpdateQuery: SQL): SQL =>\n sql('%s || %L::jsonb', currentUpdateQuery, JSONSerializer.serialize(set));\n\nexport const buildUnsetQuery = <T>(\n unset: $unset<T>,\n currentUpdateQuery: SQL,\n): SQL =>\n sql(\n '%s - %L',\n currentUpdateQuery,\n Object.keys(unset)\n .map((k) => `{${k}}`)\n .join(', '),\n );\n\nexport const buildIncQuery = <T>(\n inc: $inc<T>,\n currentUpdateQuery: SQL,\n): SQL => {\n for (const [key, value] of Object.entries(inc)) {\n currentUpdateQuery = sql(\n typeof value === 'bigint'\n ? \"jsonb_set(%s, '{%s}', to_jsonb((COALESCE((data->>'%s')::BIGINT, 0) + %L)::TEXT), true)\"\n : \"jsonb_set(%s, '{%s}', to_jsonb(COALESCE((data->>'%s')::NUMERIC, 0) + %L), true)\",\n currentUpdateQuery,\n key,\n key,\n value,\n );\n }\n return currentUpdateQuery;\n};\n\nexport const buildPushQuery = <T>(\n push: $push<T>,\n currentUpdateQuery: SQL,\n): SQL => {\n for (const [key, value] of Object.entries(push)) {\n currentUpdateQuery = sql(\n \"jsonb_set(%s, '{%s}', (coalesce(data->'%s', '[]'::jsonb) || %L::jsonb), true)\",\n currentUpdateQuery,\n key,\n key,\n JSONSerializer.serialize([value]),\n );\n }\n return currentUpdateQuery;\n};\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/storage/postgresql/sqlBuilder/index.ts","../src/core/collection/pongoCollection.ts","../src/storage/postgresql/dbClient.ts","../src/core/collection/query.ts","../src/core/errors/index.ts","../src/core/pongoClient.ts","../src/core/pongoDb.ts","../src/core/pongoTransaction.ts","../src/core/pongoSession.ts","../src/core/typing/entries.ts","../src/core/typing/operations.ts","../src/core/schema/index.ts","../src/core/utils/deepEquals.ts","../src/storage/postgresql/sqlBuilder/filter/queryOperators.ts","../src/storage/postgresql/sqlBuilder/filter/index.ts","../src/storage/postgresql/sqlBuilder/update/index.ts"],"sourcesContent":["import {\n isSQL,\n JSONSerializer,\n rawSql,\n sql,\n sqlMigration,\n type SQL,\n type SQLMigration,\n} from '@event-driven-io/dumbo';\nimport {\n expectedVersionValue,\n type DeleteOneOptions,\n type FindOptions,\n type OptionalUnlessRequiredIdAndVersion,\n type PongoCollectionSQLBuilder,\n type PongoFilter,\n type PongoUpdate,\n type ReplaceOneOptions,\n type UpdateOneOptions,\n type WithoutId,\n} from '../../../core';\nimport { constructFilterQuery } from './filter';\nimport { buildUpdateQuery } from './update';\n\nconst createCollection = (collectionName: string): SQL =>\n sql(\n `CREATE TABLE IF NOT EXISTS %I (\n _id TEXT PRIMARY KEY, \n data JSONB NOT NULL, \n metadata JSONB NOT NULL DEFAULT '{}',\n _version BIGINT NOT NULL DEFAULT 1,\n _partition TEXT NOT NULL DEFAULT 'png_global',\n _archived BOOLEAN NOT NULL DEFAULT FALSE,\n _created TIMESTAMPTZ NOT NULL DEFAULT now(),\n _updated TIMESTAMPTZ NOT NULL DEFAULT now()\n )`,\n collectionName,\n );\n\nexport const pongoCollectionPostgreSQLMigrations = (collectionName: string) => [\n sqlMigration(`pongoCollection:${collectionName}:001:createtable`, [\n createCollection(collectionName),\n ]),\n];\n\nexport const postgresSQLBuilder = (\n collectionName: string,\n): PongoCollectionSQLBuilder => ({\n migrations: (): SQLMigration[] =>\n pongoCollectionPostgreSQLMigrations(collectionName),\n createCollection: (): SQL => createCollection(collectionName),\n insertOne: <T>(document: OptionalUnlessRequiredIdAndVersion<T>): SQL => {\n return sql(\n 'INSERT INTO %I (_id, data, _version) VALUES (%L, %L, %L) ON CONFLICT(_id) DO NOTHING;',\n collectionName,\n document._id,\n JSONSerializer.serialize(document),\n document._version ?? 1n,\n );\n },\n insertMany: <T>(documents: OptionalUnlessRequiredIdAndVersion<T>[]): SQL => {\n const values = documents\n .map((doc) =>\n sql(\n '(%L, %L, %L)',\n doc._id,\n JSONSerializer.serialize(doc),\n doc._version ?? 1n,\n ),\n )\n .join(', ');\n return sql(\n `INSERT INTO %I (_id, data, _version) VALUES %s \n ON CONFLICT(_id) DO NOTHING\n RETURNING _id;`,\n collectionName,\n values,\n );\n },\n updateOne: <T>(\n filter: PongoFilter<T> | SQL,\n update: PongoUpdate<T> | SQL,\n options?: UpdateOneOptions,\n ): SQL => {\n const expectedVersion = expectedVersionValue(options?.expectedVersion);\n const expectedVersionUpdate =\n expectedVersion != null ? 'AND %I._version = %L' : '';\n const expectedVersionParams =\n expectedVersion != null ? [collectionName, expectedVersion] : [];\n\n const filterQuery = isSQL(filter) ? filter : constructFilterQuery(filter);\n const updateQuery = isSQL(update) ? update : buildUpdateQuery(update);\n\n return sql(\n `WITH existing AS (\n SELECT _id, _version as current_version\n FROM %I %s \n LIMIT 1\n ),\n updated AS (\n UPDATE %I \n SET \n data = %s || jsonb_build_object('_id', %I._id) || jsonb_build_object('_version', (_version + 1)::text),\n _version = _version + 1\n FROM existing \n WHERE %I._id = existing._id ${expectedVersionUpdate}\n RETURNING %I._id, %I._version\n )\n SELECT \n existing._id,\n COALESCE(updated._version, existing.current_version) AS version,\n COUNT(existing._id) over() AS matched,\n COUNT(updated._id) over() AS modified\n FROM existing\n LEFT JOIN updated \n ON existing._id = updated._id;`,\n collectionName,\n where(filterQuery),\n collectionName,\n updateQuery,\n collectionName,\n collectionName,\n ...expectedVersionParams,\n collectionName,\n collectionName,\n );\n },\n replaceOne: <T>(\n filter: PongoFilter<T> | SQL,\n document: WithoutId<T>,\n options?: ReplaceOneOptions,\n ): SQL => {\n const expectedVersion = expectedVersionValue(options?.expectedVersion);\n const expectedVersionUpdate =\n expectedVersion != null ? 'AND %I._version = %L' : '';\n const expectedVersionParams =\n expectedVersion != null ? [collectionName, expectedVersion] : [];\n\n const filterQuery = isSQL(filter) ? filter : constructFilterQuery(filter);\n\n return sql(\n `WITH existing AS (\n SELECT _id, _version as current_version\n FROM %I %s \n LIMIT 1\n ),\n updated AS (\n UPDATE %I \n SET \n data = %L || jsonb_build_object('_id', %I._id) || jsonb_build_object('_version', (_version + 1)::text),\n _version = _version + 1\n FROM existing \n WHERE %I._id = existing._id ${expectedVersionUpdate}\n RETURNING %I._id, %I._version\n )\n SELECT \n existing._id,\n COALESCE(updated._version, existing.current_version) AS version,\n COUNT(existing._id) over() AS matched,\n COUNT(updated._id) over() AS modified\n FROM existing\n LEFT JOIN updated \n ON existing._id = updated._id;`,\n collectionName,\n where(filterQuery),\n collectionName,\n JSONSerializer.serialize(document),\n collectionName,\n collectionName,\n ...expectedVersionParams,\n collectionName,\n collectionName,\n );\n },\n updateMany: <T>(\n filter: PongoFilter<T> | SQL,\n update: PongoUpdate<T> | SQL,\n ): SQL => {\n const filterQuery = isSQL(filter) ? filter : constructFilterQuery(filter);\n const updateQuery = isSQL(update) ? update : buildUpdateQuery(update);\n\n return sql(\n `UPDATE %I \n SET \n data = %s || jsonb_build_object('_version', (_version + 1)::text),\n _version = _version + 1\n %s;`,\n collectionName,\n updateQuery,\n where(filterQuery),\n );\n },\n deleteOne: <T>(\n filter: PongoFilter<T> | SQL,\n options?: DeleteOneOptions,\n ): SQL => {\n const expectedVersion = expectedVersionValue(options?.expectedVersion);\n const expectedVersionUpdate =\n expectedVersion != null ? 'AND %I._version = %L' : '';\n const expectedVersionParams =\n expectedVersion != null ? [collectionName, expectedVersion] : [];\n\n const filterQuery = isSQL(filter) ? filter : constructFilterQuery(filter);\n\n return sql(\n `WITH existing AS (\n SELECT _id\n FROM %I %s \n LIMIT 1\n ),\n deleted AS (\n DELETE FROM %I\n USING existing\n WHERE %I._id = existing._id ${expectedVersionUpdate}\n RETURNING %I._id\n )\n SELECT \n existing._id,\n COUNT(existing._id) over() AS matched,\n COUNT(deleted._id) over() AS deleted\n FROM existing\n LEFT JOIN deleted \n ON existing._id = deleted._id;`,\n collectionName,\n where(filterQuery),\n collectionName,\n collectionName,\n ...expectedVersionParams,\n collectionName,\n );\n },\n deleteMany: <T>(filter: PongoFilter<T> | SQL): SQL => {\n const filterQuery = isSQL(filter) ? filter : constructFilterQuery(filter);\n\n return sql('DELETE FROM %I %s', collectionName, where(filterQuery));\n },\n findOne: <T>(filter: PongoFilter<T> | SQL): SQL => {\n const filterQuery = isSQL(filter) ? filter : constructFilterQuery(filter);\n\n return sql(\n 'SELECT data FROM %I %s LIMIT 1;',\n collectionName,\n where(filterQuery),\n );\n },\n find: <T>(filter: PongoFilter<T> | SQL, options?: FindOptions): SQL => {\n const filterQuery = isSQL(filter) ? filter : constructFilterQuery(filter);\n const query: SQL[] = [];\n\n query.push(sql('SELECT data FROM %I', collectionName));\n\n const whereStmt = where(filterQuery);\n if (whereStmt.length > 0) {\n query.push(sql('%s', whereStmt));\n }\n\n if (options?.limit) {\n query.push(sql('LIMIT %s', options.limit));\n }\n\n if (options?.skip) {\n query.push(sql('OFFSET %s', options.skip));\n }\n\n return sql(query.join(' ') + ';');\n },\n countDocuments: <T>(filter: PongoFilter<T> | SQL): SQL => {\n const filterQuery = isSQL(filter) ? filter : constructFilterQuery(filter);\n return sql(\n 'SELECT COUNT(1) as count FROM %I %s;',\n collectionName,\n where(filterQuery),\n );\n },\n rename: (newName: string): SQL =>\n sql('ALTER TABLE %I RENAME TO %I;', collectionName, newName),\n drop: (targetName: string = collectionName): SQL =>\n sql('DROP TABLE IF EXISTS %I', targetName),\n});\n\nconst where = (filter: string): SQL =>\n filter.length > 0 ? sql('WHERE %s', filter) : rawSql('');\n","import {\n schemaComponent,\n single,\n type ConnectorType,\n type DatabaseTransaction,\n type Dumbo,\n type MigrationStyle,\n type QueryResult,\n type QueryResultRow,\n type SchemaComponent,\n type SQL,\n type SQLExecutor,\n type SQLMigration,\n} from '@event-driven-io/dumbo';\nimport { runPostgreSQLMigrations } from '@event-driven-io/dumbo/pg';\nimport { v7 as uuid } from 'uuid';\nimport {\n deepEquals,\n expectedVersionValue,\n operationResult,\n type CollectionOperationOptions,\n type DeleteManyOptions,\n type DeleteOneOptions,\n type DocumentHandler,\n type FindOptions,\n type HandleOptions,\n type InsertManyOptions,\n type InsertOneOptions,\n type OptionalUnlessRequiredIdAndVersion,\n type PongoCollection,\n type PongoDb,\n type PongoDeleteResult,\n type PongoDocument,\n type PongoFilter,\n type PongoHandleResult,\n type PongoInsertManyResult,\n type PongoInsertOneResult,\n type PongoUpdate,\n type PongoUpdateManyResult,\n type PongoUpdateResult,\n type ReplaceOneOptions,\n type UpdateManyOptions,\n type UpdateOneOptions,\n type WithIdAndVersion,\n type WithoutId,\n type WithVersion,\n} from '..';\nimport { pongoCollectionPostgreSQLMigrations } from '../../storage/postgresql';\n\nexport type PongoCollectionOptions<\n Connector extends ConnectorType = ConnectorType,\n> = {\n db: PongoDb<Connector>;\n collectionName: string;\n pool: Dumbo;\n sqlBuilder: PongoCollectionSQLBuilder;\n schema?: { autoMigration?: MigrationStyle };\n errors?: { throwOnOperationFailures?: boolean };\n};\n\nconst enlistIntoTransactionIfActive = async <\n Connector extends ConnectorType = ConnectorType,\n>(\n db: PongoDb<Connector>,\n options: CollectionOperationOptions | undefined,\n): Promise<DatabaseTransaction | null> => {\n const transaction = options?.session?.transaction;\n\n if (!transaction || !transaction.isActive) return null;\n\n return await transaction.enlistDatabase(db);\n};\n\nexport const transactionExecutorOrDefault = async <\n Connector extends ConnectorType = ConnectorType,\n>(\n db: PongoDb<Connector>,\n options: CollectionOperationOptions | undefined,\n defaultSqlExecutor: SQLExecutor,\n): Promise<SQLExecutor> => {\n const existingTransaction = await enlistIntoTransactionIfActive(db, options);\n return existingTransaction?.execute ?? defaultSqlExecutor;\n};\n\nexport const pongoCollection = <\n T extends PongoDocument,\n Connector extends ConnectorType = ConnectorType,\n>({\n db,\n collectionName,\n pool,\n sqlBuilder: SqlFor,\n schema,\n errors,\n}: PongoCollectionOptions<Connector>): PongoCollection<T> => {\n const sqlExecutor = pool.execute;\n const command = async <Result extends QueryResultRow = QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ) =>\n (\n await transactionExecutorOrDefault(db, options, sqlExecutor)\n ).command<Result>(sql);\n\n const query = async <T extends QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ) =>\n (await transactionExecutorOrDefault(db, options, sqlExecutor)).query<T>(\n sql,\n );\n\n let shouldMigrate = schema?.autoMigration !== 'None';\n\n const createCollection = (options?: CollectionOperationOptions) => {\n shouldMigrate = false;\n\n if (options?.session) return command(SqlFor.createCollection(), options);\n else return command(SqlFor.createCollection());\n };\n\n const ensureCollectionCreated = (options?: CollectionOperationOptions) => {\n if (!shouldMigrate) {\n return Promise.resolve();\n }\n\n return createCollection(options);\n };\n\n const collection = {\n dbName: db.databaseName,\n collectionName,\n createCollection: async (options?: CollectionOperationOptions) => {\n await createCollection(options);\n },\n insertOne: async (\n document: OptionalUnlessRequiredIdAndVersion<T>,\n options?: InsertOneOptions,\n ): Promise<PongoInsertOneResult> => {\n await ensureCollectionCreated(options);\n\n const _id = (document._id as string | undefined | null) ?? uuid();\n const _version = document._version ?? 1n;\n\n const result = await command(\n SqlFor.insertOne({\n ...document,\n _id,\n _version,\n } as OptionalUnlessRequiredIdAndVersion<T>),\n options,\n );\n\n const successful = (result.rowCount ?? 0) > 0;\n\n return operationResult<PongoInsertOneResult>(\n {\n successful,\n insertedId: successful ? _id : null,\n nextExpectedVersion: _version,\n },\n { operationName: 'insertOne', collectionName, errors },\n );\n },\n insertMany: async (\n documents: OptionalUnlessRequiredIdAndVersion<T>[],\n options?: InsertManyOptions,\n ): Promise<PongoInsertManyResult> => {\n await ensureCollectionCreated(options);\n\n const rows = documents.map((doc) => ({\n ...doc,\n _id: (doc._id as string | undefined | null) ?? uuid(),\n _version: doc._version ?? 1n,\n }));\n\n const result = await command(\n SqlFor.insertMany(rows as OptionalUnlessRequiredIdAndVersion<T>[]),\n options,\n );\n\n return operationResult<PongoInsertManyResult>(\n {\n successful: result.rowCount === rows.length,\n insertedCount: result.rowCount ?? 0,\n insertedIds: result.rows.map((d) => d._id as string),\n },\n { operationName: 'insertMany', collectionName, errors },\n );\n },\n updateOne: async (\n filter: PongoFilter<T>,\n update: PongoUpdate<T>,\n options?: UpdateOneOptions,\n ): Promise<PongoUpdateResult> => {\n await ensureCollectionCreated(options);\n\n const result = await command<UpdateSqlResult>(\n SqlFor.updateOne(filter, update, options),\n options,\n );\n\n return operationResult<PongoUpdateResult>(\n {\n successful:\n result.rows.length > 0 &&\n result.rows[0]!.modified === result.rows[0]!.matched,\n modifiedCount: Number(result.rows[0]?.modified ?? 0),\n matchedCount: Number(result.rows[0]?.matched ?? 0),\n nextExpectedVersion: result.rows[0]?.version ?? 0n,\n },\n { operationName: 'updateOne', collectionName, errors },\n );\n },\n replaceOne: async (\n filter: PongoFilter<T>,\n document: WithoutId<T>,\n options?: ReplaceOneOptions,\n ): Promise<PongoUpdateResult> => {\n await ensureCollectionCreated(options);\n\n const result = await command<UpdateSqlResult>(\n SqlFor.replaceOne(filter, document, options),\n options,\n );\n return operationResult<PongoUpdateResult>(\n {\n successful: result.rows.length > 0 && result.rows[0]!.modified > 0,\n modifiedCount: Number(result.rows[0]?.modified ?? 0),\n matchedCount: Number(result.rows[0]?.matched ?? 0),\n nextExpectedVersion: result.rows[0]?.version ?? 0n,\n },\n { operationName: 'replaceOne', collectionName, errors },\n );\n },\n updateMany: async (\n filter: PongoFilter<T>,\n update: PongoUpdate<T>,\n options?: UpdateManyOptions,\n ): Promise<PongoUpdateManyResult> => {\n await ensureCollectionCreated(options);\n\n const result = await command(SqlFor.updateMany(filter, update), options);\n\n return operationResult<PongoUpdateManyResult>(\n {\n successful: true,\n modifiedCount: result.rowCount ?? 0,\n matchedCount: result.rowCount ?? 0,\n },\n { operationName: 'updateMany', collectionName, errors },\n );\n },\n deleteOne: async (\n filter?: PongoFilter<T>,\n options?: DeleteOneOptions,\n ): Promise<PongoDeleteResult> => {\n await ensureCollectionCreated(options);\n\n const result = await command<DeleteSqlResult>(\n SqlFor.deleteOne(filter ?? {}, options),\n options,\n );\n return operationResult<PongoDeleteResult>(\n {\n successful: result.rows.length > 0 && result.rows[0]!.deleted! > 0,\n deletedCount: Number(result.rows[0]?.deleted ?? 0),\n matchedCount: Number(result.rows[0]?.matched ?? 0),\n },\n { operationName: 'deleteOne', collectionName, errors },\n );\n },\n deleteMany: async (\n filter?: PongoFilter<T>,\n options?: DeleteManyOptions,\n ): Promise<PongoDeleteResult> => {\n await ensureCollectionCreated(options);\n\n const result = await command(SqlFor.deleteMany(filter ?? {}), options);\n\n return operationResult<PongoDeleteResult>(\n {\n successful: (result.rowCount ?? 0) > 0,\n deletedCount: result.rowCount ?? 0,\n matchedCount: result.rowCount ?? 0,\n },\n { operationName: 'deleteMany', collectionName, errors },\n );\n },\n findOne: async (\n filter?: PongoFilter<T>,\n options?: CollectionOperationOptions,\n ): Promise<WithIdAndVersion<T> | null> => {\n await ensureCollectionCreated(options);\n\n const result = await query(SqlFor.findOne(filter ?? {}), options);\n return (result.rows[0]?.data ?? null) as WithIdAndVersion<T> | null;\n },\n findOneAndDelete: async (\n filter: PongoFilter<T>,\n options?: DeleteOneOptions,\n ): Promise<WithIdAndVersion<T> | null> => {\n await ensureCollectionCreated(options);\n\n const existingDoc = await collection.findOne(filter, options);\n\n if (existingDoc === null) return null;\n\n await collection.deleteOne(filter, options);\n return existingDoc;\n },\n findOneAndReplace: async (\n filter: PongoFilter<T>,\n replacement: WithoutId<T>,\n options?: ReplaceOneOptions,\n ): Promise<WithIdAndVersion<T> | null> => {\n await ensureCollectionCreated(options);\n\n const existingDoc = await collection.findOne(filter, options);\n\n if (existingDoc === null) return null;\n\n await collection.replaceOne(filter, replacement, options);\n\n return existingDoc;\n },\n findOneAndUpdate: async (\n filter: PongoFilter<T>,\n update: PongoUpdate<T>,\n options?: UpdateOneOptions,\n ): Promise<WithIdAndVersion<T> | null> => {\n await ensureCollectionCreated(options);\n\n const existingDoc = await collection.findOne(filter, options);\n\n if (existingDoc === null) return null;\n\n await collection.updateOne(filter, update, options);\n\n return existingDoc;\n },\n handle: async (\n id: string,\n handle: DocumentHandler<T>,\n options?: HandleOptions,\n ): Promise<PongoHandleResult<T>> => {\n const { expectedVersion: version, ...operationOptions } = options ?? {};\n await ensureCollectionCreated(options);\n\n const byId: PongoFilter<T> = { _id: id };\n\n const existing = (await collection.findOne(\n byId,\n options,\n )) as WithVersion<T> | null;\n\n const expectedVersion = expectedVersionValue(version);\n\n if (\n (existing == null && version === 'DOCUMENT_EXISTS') ||\n (existing == null && expectedVersion != null) ||\n (existing != null && version === 'DOCUMENT_DOES_NOT_EXIST') ||\n (existing != null &&\n expectedVersion !== null &&\n existing._version !== expectedVersion)\n ) {\n return operationResult<PongoHandleResult<T>>(\n {\n successful: false,\n document: existing as T,\n },\n { operationName: 'handle', collectionName, errors },\n );\n }\n\n const result = await handle(\n existing !== null ? ({ ...existing } as T) : null,\n );\n\n if (deepEquals(existing as T | null, result))\n return operationResult<PongoHandleResult<T>>(\n {\n successful: true,\n document: existing as T | null,\n },\n { operationName: 'handle', collectionName, errors },\n );\n\n if (!existing && result) {\n const newDoc = { ...result, _id: id };\n const insertResult = await collection.insertOne(\n { ...newDoc, _id: id } as OptionalUnlessRequiredIdAndVersion<T>,\n {\n ...operationOptions,\n expectedVersion: 'DOCUMENT_DOES_NOT_EXIST',\n },\n );\n return {\n ...insertResult,\n document: {\n ...newDoc,\n _version: insertResult.nextExpectedVersion,\n } as T,\n };\n }\n\n if (existing && !result) {\n const deleteResult = await collection.deleteOne(byId, {\n ...operationOptions,\n expectedVersion: expectedVersion ?? 'DOCUMENT_EXISTS',\n });\n return { ...deleteResult, document: null };\n }\n\n if (existing && result) {\n const replaceResult = await collection.replaceOne(byId, result, {\n ...operationOptions,\n expectedVersion: expectedVersion ?? 'DOCUMENT_EXISTS',\n });\n return {\n ...replaceResult,\n document: {\n ...result,\n _version: replaceResult.nextExpectedVersion,\n } as T,\n };\n }\n\n return operationResult<PongoHandleResult<T>>(\n {\n successful: true,\n document: existing as T,\n },\n { operationName: 'handle', collectionName, errors },\n );\n },\n find: async (\n filter?: PongoFilter<T>,\n options?: FindOptions,\n ): Promise<WithIdAndVersion<T>[]> => {\n await ensureCollectionCreated(options);\n\n const result = await query(SqlFor.find(filter ?? {}, options));\n return result.rows.map((row) => row.data as WithIdAndVersion<T>);\n },\n countDocuments: async (\n filter?: PongoFilter<T>,\n options?: CollectionOperationOptions,\n ): Promise<number> => {\n await ensureCollectionCreated(options);\n\n const { count } = await single(\n query<{ count: number }>(SqlFor.countDocuments(filter ?? {})),\n );\n return count;\n },\n drop: async (options?: CollectionOperationOptions): Promise<boolean> => {\n await ensureCollectionCreated(options);\n const result = await command(SqlFor.drop());\n return (result?.rowCount ?? 0) > 0;\n },\n rename: async (\n newName: string,\n options?: CollectionOperationOptions,\n ): Promise<PongoCollection<T>> => {\n await ensureCollectionCreated(options);\n await command(SqlFor.rename(newName));\n collectionName = newName;\n return collection;\n },\n\n sql: {\n async query<Result extends QueryResultRow = QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ): Promise<Result[]> {\n await ensureCollectionCreated(options);\n\n const result = await query<Result>(sql, options);\n return result.rows;\n },\n async command<Result extends QueryResultRow = QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ): Promise<QueryResult<Result>> {\n await ensureCollectionCreated(options);\n\n return command(sql, options);\n },\n },\n schema: {\n get component(): SchemaComponent {\n return schemaComponent('pongo:schema_component:collection', {\n migrations: SqlFor.migrations,\n });\n },\n migrate: () => runPostgreSQLMigrations(pool, SqlFor.migrations()), // TODO: This needs to change to support more connectors\n },\n };\n\n return collection;\n};\n\nexport const pongoCollectionSchemaComponent = (collectionName: string) =>\n schemaComponent('pongo:schema_component:collection', {\n migrations: () => pongoCollectionPostgreSQLMigrations(collectionName), // TODO: This needs to change to support more connectors\n });\n\nexport type PongoCollectionSQLBuilder = {\n migrations: () => SQLMigration[];\n createCollection: () => SQL;\n insertOne: <T>(document: OptionalUnlessRequiredIdAndVersion<T>) => SQL;\n insertMany: <T>(documents: OptionalUnlessRequiredIdAndVersion<T>[]) => SQL;\n updateOne: <T>(\n filter: PongoFilter<T> | SQL,\n update: PongoUpdate<T> | SQL,\n options?: UpdateOneOptions,\n ) => SQL;\n replaceOne: <T>(\n filter: PongoFilter<T> | SQL,\n document: WithoutId<T>,\n options?: ReplaceOneOptions,\n ) => SQL;\n updateMany: <T>(\n filter: PongoFilter<T> | SQL,\n update: PongoUpdate<T> | SQL,\n ) => SQL;\n deleteOne: <T>(\n filter: PongoFilter<T> | SQL,\n options?: DeleteOneOptions,\n ) => SQL;\n deleteMany: <T>(filter: PongoFilter<T> | SQL) => SQL;\n findOne: <T>(filter: PongoFilter<T> | SQL) => SQL;\n find: <T>(filter: PongoFilter<T> | SQL, options?: FindOptions) => SQL;\n countDocuments: <T>(filter: PongoFilter<T> | SQL) => SQL;\n rename: (newName: string) => SQL;\n drop: () => SQL;\n};\n\ntype UpdateSqlResult = {\n matched: bigint;\n modified: bigint;\n version: bigint;\n};\n\ntype DeleteSqlResult = {\n matched: bigint | null;\n deleted: bigint | null;\n};\n","import {\n schemaComponent,\n SQL,\n type QueryResult,\n type QueryResultRow,\n type SchemaComponent,\n} from '@event-driven-io/dumbo';\nimport {\n dumbo,\n getDatabaseNameOrDefault,\n NodePostgresConnectorType,\n runPostgreSQLMigrations,\n type PostgresConnector,\n type PostgresPoolOptions,\n} from '@event-driven-io/dumbo/pg';\nimport type { Document } from 'mongodb';\nimport {\n objectEntries,\n pongoCollection,\n pongoCollectionSchemaComponent,\n proxyPongoDbWithSchema,\n transactionExecutorOrDefault,\n type CollectionOperationOptions,\n type PongoCollection,\n type PongoDb,\n type PongoDbClientOptions,\n} from '../../core';\nimport { postgresSQLBuilder } from './sqlBuilder';\n\nexport type PostgresDbClientOptions = PongoDbClientOptions<PostgresConnector>;\n\nexport const isPostgresClientOptions = (\n options: PongoDbClientOptions,\n): options is PostgresDbClientOptions =>\n options.connector === NodePostgresConnectorType;\n\nexport const postgresDb = (\n options: PostgresDbClientOptions,\n): PongoDb<PostgresConnector> => {\n const { connectionString, dbName } = options;\n const databaseName = dbName ?? getDatabaseNameOrDefault(connectionString);\n\n const pool = dumbo<PostgresPoolOptions>({\n connectionString,\n ...options.connectionOptions,\n });\n\n const collections = new Map<string, PongoCollection<Document>>();\n\n const command = async <Result extends QueryResultRow = QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ) =>\n (\n await transactionExecutorOrDefault(db, options, pool.execute)\n ).command<Result>(sql);\n\n const query = async <T extends QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ) =>\n (await transactionExecutorOrDefault(db, options, pool.execute)).query<T>(\n sql,\n );\n\n const db: PongoDb<PostgresConnector> = {\n connector: options.connector,\n databaseName,\n connect: () => Promise.resolve(),\n close: () => pool.close(),\n\n collections: () => [...collections.values()],\n collection: (collectionName) =>\n pongoCollection({\n collectionName,\n db,\n pool,\n sqlBuilder: postgresSQLBuilder(collectionName),\n schema: options.schema ? options.schema : {},\n errors: options.errors ? options.errors : {},\n }),\n transaction: () => pool.transaction(),\n withTransaction: (handle) => pool.withTransaction(handle),\n\n schema: {\n get component(): SchemaComponent {\n return schemaComponent('pongoDb', {\n components: [...collections.values()].map((c) => c.schema.component),\n });\n },\n migrate: () =>\n runPostgreSQLMigrations(\n pool,\n [...collections.values()].flatMap((c) =>\n // TODO: This needs to change to support more connectors\n c.schema.component.migrations({ connector: 'PostgreSQL:pg' }),\n ),\n ),\n },\n\n sql: {\n async query<Result extends QueryResultRow = QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ): Promise<Result[]> {\n const result = await query<Result>(sql, options);\n return result.rows;\n },\n async command<Result extends QueryResultRow = QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ): Promise<QueryResult<Result>> {\n return command(sql, options);\n },\n },\n };\n\n const dbsSchema = options?.schema?.definition?.dbs;\n\n if (dbsSchema) {\n const dbSchema = objectEntries(dbsSchema)\n .map((e) => e[1])\n .find((db) => db.name === dbName || db.name === databaseName);\n\n if (dbSchema) return proxyPongoDbWithSchema(db, dbSchema, collections);\n }\n\n return db;\n};\n\nexport const pongoDbSchemaComponent = (\n collections: string[] | SchemaComponent[],\n) => {\n const components =\n collections.length > 0 && typeof collections[0] === 'string'\n ? collections.map((collectionName) =>\n pongoCollectionSchemaComponent(collectionName as string),\n )\n : (collections as SchemaComponent[]);\n\n return schemaComponent('pongo:schema_component:db', {\n components,\n });\n};\n","export const QueryOperators = {\n $eq: '$eq',\n $gt: '$gt',\n $gte: '$gte',\n $lt: '$lt',\n $lte: '$lte',\n $ne: '$ne',\n $in: '$in',\n $nin: '$nin',\n $elemMatch: '$elemMatch',\n $all: '$all',\n $size: '$size',\n};\n\nexport const OperatorMap = {\n $gt: '>',\n $gte: '>=',\n $lt: '<',\n $lte: '<=',\n $ne: '!=',\n};\n\nexport const isOperator = (key: string) => key.startsWith('$');\n\nexport const hasOperators = (value: Record<string, unknown>) =>\n Object.keys(value).some(isOperator);\n","export const isNumber = (val: unknown): val is number =>\n typeof val === 'number' && val === val;\n\nexport const isString = (val: unknown): val is string =>\n typeof val === 'string';\n\nexport class PongoError extends Error {\n public errorCode: number;\n\n constructor(\n options?: { errorCode: number; message?: string } | string | number,\n ) {\n const errorCode =\n options && typeof options === 'object' && 'errorCode' in options\n ? options.errorCode\n : isNumber(options)\n ? options\n : 500;\n const message =\n options && typeof options === 'object' && 'message' in options\n ? options.message\n : isString(options)\n ? options\n : `Error with status code '${errorCode}' ocurred during Pongo processing`;\n\n super(message);\n this.errorCode = errorCode;\n\n // 👇️ because we are extending a built-in class\n Object.setPrototypeOf(this, PongoError.prototype);\n }\n}\n\nexport class ConcurrencyError extends PongoError {\n constructor(message?: string) {\n super({\n errorCode: 412,\n message: message ?? `Expected document state does not match current one!`,\n });\n\n // 👇️ because we are extending a built-in class\n Object.setPrototypeOf(this, ConcurrencyError.prototype);\n }\n}\n","import { type MigrationStyle } from '@event-driven-io/dumbo';\nimport {\n NodePostgresConnectorType,\n type NodePostgresConnection,\n} from '@event-driven-io/dumbo/pg';\nimport pg from 'pg';\nimport type { PostgresDbClientOptions } from '../storage/postgresql';\nimport { getPongoDb, type AllowedDbClientOptions } from './pongoDb';\nimport { pongoSession } from './pongoSession';\nimport {\n proxyClientWithSchema,\n type PongoClientSchema,\n type PongoClientWithSchema,\n} from './schema';\nimport type { PongoClient, PongoDb, PongoSession } from './typing';\n\nexport type PooledPongoClientOptions =\n | {\n pool: pg.Pool;\n }\n | {\n pooled: true;\n }\n | {\n pool: pg.Pool;\n pooled: true;\n }\n | object;\n\nexport type NotPooledPongoOptions =\n | {\n client: pg.Client;\n }\n | {\n pooled: false;\n }\n | {\n client: pg.Client;\n pooled: false;\n }\n | {\n connection: NodePostgresConnection;\n pooled?: false;\n };\n\nexport type PongoClientOptions<\n TypedClientSchema extends PongoClientSchema = PongoClientSchema,\n> = {\n schema?: { autoMigration?: MigrationStyle; definition?: TypedClientSchema };\n errors?: { throwOnOperationFailures?: boolean };\n connectionOptions?: PooledPongoClientOptions | NotPooledPongoOptions;\n};\n\nexport const pongoClient = <\n TypedClientSchema extends PongoClientSchema = PongoClientSchema,\n DbClientOptions extends AllowedDbClientOptions = AllowedDbClientOptions,\n>(\n connectionString: string,\n options: PongoClientOptions<TypedClientSchema> = {},\n): PongoClient & PongoClientWithSchema<TypedClientSchema> => {\n const dbClients = new Map<string, PongoDb>();\n\n const dbClient = getPongoDb<DbClientOptions>(\n clientToDbOptions({\n connectionString,\n clientOptions: options,\n }),\n );\n dbClients.set(dbClient.databaseName, dbClient);\n\n const pongoClient: PongoClient = {\n connect: async () => {\n await dbClient.connect();\n return pongoClient;\n },\n close: async () => {\n for (const db of dbClients.values()) {\n await db.close();\n }\n },\n db: (dbName?: string): PongoDb => {\n if (!dbName) return dbClient;\n\n return (\n dbClients.get(dbName) ??\n dbClients\n .set(\n dbName,\n getPongoDb<DbClientOptions>(\n clientToDbOptions({\n connectionString,\n dbName,\n clientOptions: options,\n }),\n ),\n )\n .get(dbName)!\n );\n },\n startSession: pongoSession,\n withSession: async <T>(\n callback: (session: PongoSession) => Promise<T>,\n ): Promise<T> => {\n const session = pongoSession();\n\n try {\n return await callback(session);\n } finally {\n await session.endSession();\n }\n },\n };\n\n return proxyClientWithSchema(pongoClient, options?.schema?.definition);\n};\n\nexport const clientToDbOptions = <\n DbClientOptions extends AllowedDbClientOptions = AllowedDbClientOptions,\n>(options: {\n connectionString: string;\n dbName?: string;\n clientOptions: PongoClientOptions;\n}): DbClientOptions => {\n const postgreSQLOptions: PostgresDbClientOptions = {\n connector: NodePostgresConnectorType,\n connectionString: options.connectionString,\n dbName: options.dbName,\n ...options.clientOptions,\n };\n\n return postgreSQLOptions as DbClientOptions;\n};\n","import type { ConnectorType } from '@event-driven-io/dumbo/src';\nimport {\n isPostgresClientOptions,\n postgresDb,\n type PostgresDbClientOptions,\n} from '../storage/postgresql';\nimport type { PongoClientOptions } from './pongoClient';\nimport type { PongoDb } from './typing';\n\nexport type PongoDbClientOptions<\n Connector extends ConnectorType = ConnectorType,\n> = {\n connector: Connector;\n connectionString: string;\n dbName: string | undefined;\n} & PongoClientOptions;\n\nexport type AllowedDbClientOptions = PostgresDbClientOptions;\n\nexport const getPongoDb = <\n DbClientOptions extends AllowedDbClientOptions = AllowedDbClientOptions,\n>(\n options: DbClientOptions,\n): PongoDb => {\n const { connector } = options;\n // This is the place where in the future could come resolution of other database types\n if (!isPostgresClientOptions(options))\n throw new Error(`Unsupported db type: ${connector}`);\n\n return postgresDb(options);\n};\n","import type { DatabaseTransaction } from '@event-driven-io/dumbo';\nimport type {\n PongoDb,\n PongoDbTransaction,\n PongoTransactionOptions,\n} from './typing';\n\nexport const pongoTransaction = (\n options: PongoTransactionOptions,\n): PongoDbTransaction => {\n let isCommitted = false;\n let isRolledBack = false;\n let databaseName: string | null = null;\n let transaction: DatabaseTransaction | null = null;\n\n return {\n enlistDatabase: async (db: PongoDb): Promise<DatabaseTransaction> => {\n if (transaction && databaseName !== db.databaseName)\n throw new Error(\n \"There's already other database assigned to transaction\",\n );\n\n if (transaction && databaseName === db.databaseName) return transaction;\n\n databaseName = db.databaseName;\n transaction = db.transaction();\n await transaction.begin();\n\n return transaction;\n },\n commit: async () => {\n if (!transaction) throw new Error('No database transaction started!');\n if (isCommitted) return;\n if (isRolledBack) throw new Error('Transaction is not active!');\n\n isCommitted = true;\n\n await transaction.commit();\n\n transaction = null;\n },\n rollback: async (error?: unknown) => {\n if (!transaction) throw new Error('No database transaction started!');\n if (isCommitted) throw new Error('Cannot rollback commited transaction!');\n if (isRolledBack) return;\n\n isRolledBack = true;\n\n await transaction.rollback(error);\n\n transaction = null;\n },\n databaseName,\n isStarting: false,\n isCommitted,\n get isActive() {\n return !isCommitted && !isRolledBack;\n },\n get sqlExecutor() {\n if (transaction === null)\n throw new Error('No database transaction was started');\n\n return transaction.execute;\n },\n options,\n };\n};\n","import { pongoTransaction } from './pongoTransaction';\nimport type {\n PongoDbTransaction,\n PongoSession,\n PongoTransactionOptions,\n} from './typing';\n\nexport type PongoSessionOptions = {\n explicit?: boolean;\n defaultTransactionOptions: PongoTransactionOptions;\n};\n\nconst isActive = (\n transaction: PongoDbTransaction | null,\n): transaction is PongoDbTransaction => transaction?.isActive === true;\n\nfunction assertInActiveTransaction(\n transaction: PongoDbTransaction | null,\n): asserts transaction is PongoDbTransaction {\n if (!isActive(transaction)) throw new Error('No active transaction exists!');\n}\n\nfunction assertNotInActiveTransaction(\n transaction: PongoDbTransaction | null,\n): asserts transaction is null {\n if (isActive(transaction))\n throw new Error('Active transaction already exists!');\n}\n\nexport const pongoSession = (options?: PongoSessionOptions): PongoSession => {\n const explicit = options?.explicit === true;\n const defaultTransactionOptions: PongoTransactionOptions =\n options?.defaultTransactionOptions ?? {\n get snapshotEnabled() {\n return false;\n },\n };\n\n let transaction: PongoDbTransaction | null = null;\n let hasEnded = false;\n\n const startTransaction = (options?: PongoTransactionOptions) => {\n assertNotInActiveTransaction(transaction);\n\n transaction = pongoTransaction(options ?? defaultTransactionOptions);\n };\n const commitTransaction = async () => {\n assertInActiveTransaction(transaction);\n\n await transaction.commit();\n };\n const abortTransaction = async () => {\n assertInActiveTransaction(transaction);\n\n await transaction.rollback();\n };\n\n const endSession = async (): Promise<void> => {\n if (hasEnded) return;\n hasEnded = true;\n\n if (isActive(transaction)) await transaction.rollback();\n };\n\n const session = {\n get hasEnded() {\n return hasEnded;\n },\n explicit,\n defaultTransactionOptions: defaultTransactionOptions ?? {\n get snapshotEnabled() {\n return false;\n },\n },\n get transaction() {\n return transaction;\n },\n get snapshotEnabled() {\n return defaultTransactionOptions.snapshotEnabled;\n },\n endSession,\n incrementTransactionNumber: () => {},\n inTransaction: () => isActive(transaction),\n startTransaction,\n commitTransaction,\n abortTransaction,\n withTransaction: async <T = unknown>(\n fn: (session: PongoSession) => Promise<T>,\n options?: PongoTransactionOptions,\n ): Promise<T> => {\n startTransaction(options);\n\n try {\n const result = await fn(session);\n await commitTransaction();\n return result;\n } catch (error) {\n await abortTransaction();\n throw error;\n }\n },\n };\n\n return session;\n};\n","type Entry<T> = {\n [K in keyof Required<T>]: [K, Required<T>[K]];\n}[keyof Required<T>];\n\ntype IterableEntry<T> = Entry<T> & {\n [Symbol.iterator](): Iterator<Entry<T>>;\n};\n\nexport const objectEntries = <T extends object>(obj: T): IterableEntry<T>[] =>\n Object.entries(obj).map(([key, value]) => [key as keyof T, value]);\n\nexport type NonPartial<T> = { [K in keyof Required<T>]: T[K] };\n","import {\n type ConnectorType,\n type DatabaseTransaction,\n type DatabaseTransactionFactory,\n JSONSerializer,\n type QueryResult,\n type QueryResultRow,\n type SchemaComponent,\n type SQL,\n type SQLExecutor,\n} from '@event-driven-io/dumbo';\nimport { v7 as uuid } from 'uuid';\nimport { ConcurrencyError } from '../errors';\n\nexport interface PongoClient {\n connect(): Promise<this>;\n\n close(): Promise<void>;\n\n db(dbName?: string): PongoDb;\n\n startSession(): PongoSession;\n\n withSession<T = unknown>(\n callback: (session: PongoSession) => Promise<T>,\n ): Promise<T>;\n}\n\nexport declare interface PongoTransactionOptions {\n get snapshotEnabled(): boolean;\n maxCommitTimeMS?: number;\n}\n\nexport interface PongoDbTransaction {\n get databaseName(): string | null;\n options: PongoTransactionOptions;\n enlistDatabase: (database: PongoDb) => Promise<DatabaseTransaction>;\n commit: () => Promise<void>;\n rollback: (error?: unknown) => Promise<void>;\n get sqlExecutor(): SQLExecutor;\n get isStarting(): boolean;\n get isActive(): boolean;\n get isCommitted(): boolean;\n}\n\nexport interface PongoSession {\n hasEnded: boolean;\n explicit: boolean;\n defaultTransactionOptions: PongoTransactionOptions;\n transaction: PongoDbTransaction | null;\n get snapshotEnabled(): boolean;\n\n endSession(): Promise<void>;\n incrementTransactionNumber(): void;\n inTransaction(): boolean;\n startTransaction(options?: PongoTransactionOptions): void;\n commitTransaction(): Promise<void>;\n abortTransaction(): Promise<void>;\n withTransaction<T = unknown>(\n fn: (session: PongoSession) => Promise<T>,\n options?: PongoTransactionOptions,\n ): Promise<T>;\n}\n\nexport interface PongoDb<Connector extends ConnectorType = ConnectorType>\n extends DatabaseTransactionFactory<Connector> {\n get connector(): Connector;\n get databaseName(): string;\n connect(): Promise<void>;\n close(): Promise<void>;\n collection<T extends PongoDocument>(name: string): PongoCollection<T>;\n collections(): ReadonlyArray<PongoCollection<PongoDocument>>;\n readonly schema: Readonly<{\n component: SchemaComponent;\n migrate(): Promise<void>;\n }>;\n sql: {\n query<Result extends QueryResultRow = QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ): Promise<Result[]>;\n command<Result extends QueryResultRow = QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ): Promise<QueryResult<Result>>;\n };\n}\n\nexport type CollectionOperationOptions = {\n session?: PongoSession;\n};\n\nexport type InsertOneOptions = {\n expectedVersion?: Extract<\n ExpectedDocumentVersion,\n 'DOCUMENT_DOES_NOT_EXIST' | 'NO_CONCURRENCY_CHECK'\n >;\n} & CollectionOperationOptions;\n\nexport type InsertManyOptions = {\n expectedVersion?: Extract<\n ExpectedDocumentVersion,\n 'DOCUMENT_DOES_NOT_EXIST' | 'NO_CONCURRENCY_CHECK'\n >;\n} & CollectionOperationOptions;\n\nexport type UpdateOneOptions = {\n expectedVersion?: Exclude<ExpectedDocumentVersion, 'DOCUMENT_DOES_NOT_EXIST'>;\n} & CollectionOperationOptions;\n\nexport type UpdateManyOptions = {\n expectedVersion?: Extract<\n ExpectedDocumentVersion,\n 'DOCUMENT_EXISTS' | 'NO_CONCURRENCY_CHECK'\n >;\n} & CollectionOperationOptions;\n\nexport type HandleOptions = {\n expectedVersion?: ExpectedDocumentVersion;\n} & CollectionOperationOptions;\n\nexport type ReplaceOneOptions = {\n expectedVersion?: Exclude<ExpectedDocumentVersion, 'DOCUMENT_DOES_NOT_EXIST'>;\n} & CollectionOperationOptions;\n\nexport type DeleteOneOptions = {\n expectedVersion?: Exclude<ExpectedDocumentVersion, 'DOCUMENT_DOES_NOT_EXIST'>;\n} & CollectionOperationOptions;\n\nexport type DeleteManyOptions = {\n expectedVersion?: Extract<\n ExpectedDocumentVersion,\n 'DOCUMENT_EXISTS' | 'NO_CONCURRENCY_CHECK'\n >;\n} & CollectionOperationOptions;\n\nexport type FindOptions = {\n limit?: number;\n skip?: number;\n} & CollectionOperationOptions;\n\nexport interface PongoCollection<T extends PongoDocument> {\n readonly dbName: string;\n readonly collectionName: string;\n createCollection(options?: CollectionOperationOptions): Promise<void>;\n insertOne(\n document: OptionalUnlessRequiredId<T>,\n options?: InsertOneOptions,\n ): Promise<PongoInsertOneResult>;\n insertMany(\n documents: OptionalUnlessRequiredId<T>[],\n options?: CollectionOperationOptions,\n ): Promise<PongoInsertManyResult>;\n updateOne(\n filter: PongoFilter<T> | SQL,\n update: PongoUpdate<T> | SQL,\n options?: UpdateOneOptions,\n ): Promise<PongoUpdateResult>;\n replaceOne(\n filter: PongoFilter<T> | SQL,\n document: WithoutId<T>,\n options?: ReplaceOneOptions,\n ): Promise<PongoUpdateResult>;\n updateMany(\n filter: PongoFilter<T> | SQL,\n update: PongoUpdate<T> | SQL,\n options?: UpdateManyOptions,\n ): Promise<PongoUpdateManyResult>;\n deleteOne(\n filter?: PongoFilter<T> | SQL,\n options?: DeleteOneOptions,\n ): Promise<PongoDeleteResult>;\n deleteMany(\n filter?: PongoFilter<T> | SQL,\n options?: DeleteManyOptions,\n ): Promise<PongoDeleteResult>;\n findOne(\n filter?: PongoFilter<T> | SQL,\n options?: CollectionOperationOptions,\n ): Promise<WithIdAndVersion<T> | null>;\n find(\n filter?: PongoFilter<T> | SQL,\n options?: FindOptions,\n ): Promise<WithIdAndVersion<T>[]>;\n findOneAndDelete(\n filter: PongoFilter<T> | SQL,\n options?: DeleteOneOptions,\n ): Promise<WithIdAndVersion<T> | null>;\n findOneAndReplace(\n filter: PongoFilter<T> | SQL,\n replacement: WithoutId<T>,\n options?: ReplaceOneOptions,\n ): Promise<WithIdAndVersion<T> | null>;\n findOneAndUpdate(\n filter: PongoFilter<T> | SQL,\n update: PongoUpdate<T> | SQL,\n options?: UpdateOneOptions,\n ): Promise<WithIdAndVersion<T> | null>;\n countDocuments(\n filter?: PongoFilter<T> | SQL,\n options?: CollectionOperationOptions,\n ): Promise<number>;\n drop(options?: CollectionOperationOptions): Promise<boolean>;\n rename(\n newName: string,\n options?: CollectionOperationOptions,\n ): Promise<PongoCollection<T>>;\n handle(\n id: string,\n handle: DocumentHandler<T>,\n options?: HandleOptions,\n ): Promise<PongoHandleResult<T>>;\n readonly schema: Readonly<{\n component: SchemaComponent;\n migrate(): Promise<void>;\n }>;\n sql: {\n query<Result extends QueryResultRow = QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ): Promise<Result[]>;\n command<Result extends QueryResultRow = QueryResultRow>(\n sql: SQL,\n options?: CollectionOperationOptions,\n ): Promise<QueryResult<Result>>;\n };\n}\n\nexport type ObjectId = string & { __brandId: 'ObjectId' };\nexport const ObjectId = (value?: string) => value ?? uuid();\n\nexport type HasId = { _id: string };\n\nexport declare type InferIdType<TSchema> = TSchema extends {\n _id: infer IdType;\n}\n ? // eslint-disable-next-line @typescript-eslint/no-explicit-any\n Record<any, never> extends IdType\n ? never\n : IdType\n : TSchema extends {\n _id?: infer IdType;\n }\n ? unknown extends IdType\n ? ObjectId\n : IdType\n : ObjectId;\n\n/** TypeScript Omit (Exclude to be specific) does not work for objects with an \"any\" indexed type, and breaks discriminated unions @public */\nexport declare type EnhancedOmit<TRecordOrUnion, KeyUnion> =\n string extends keyof TRecordOrUnion\n ? TRecordOrUnion\n : // eslint-disable-next-line @typescript-eslint/no-explicit-any\n TRecordOrUnion extends any\n ? Pick<TRecordOrUnion, Exclude<keyof TRecordOrUnion, KeyUnion>>\n : never;\n\nexport declare type OptionalUnlessRequiredId<TSchema> = TSchema extends {\n _id: string | ObjectId;\n}\n ? TSchema\n : OptionalId<TSchema>;\n\nexport declare type OptionalUnlessRequiredVersion<TSchema> = TSchema extends {\n _version: bigint;\n}\n ? TSchema\n : OptionalVersion<TSchema>;\n\nexport declare type OptionalUnlessRequiredIdAndVersion<TSchema> =\n OptionalUnlessRequiredId<TSchema> & OptionalUnlessRequiredVersion<TSchema>;\n\nexport declare type WithId<TSchema> = EnhancedOmit<TSchema, '_id'> & {\n _id: string | ObjectId;\n};\nexport type WithoutId<T> = Omit<T, '_id'>;\n\nexport declare type WithVersion<TSchema> = EnhancedOmit<TSchema, '_version'> & {\n _version: bigint;\n};\nexport type WithoutVersion<T> = Omit<T, '_version'>;\n\nexport type WithIdAndVersion<T> = WithId<WithVersion<T>>;\nexport type WithoutIdAndVersion<T> = WithoutId<WithoutVersion<T>>;\n\n/** @public */\nexport declare type RegExpOrString<T> = T extends string ? RegExp | T : T;\n\nexport declare interface Document {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n [key: string]: any;\n}\n\nexport declare type OptionalId<TSchema> = EnhancedOmit<TSchema, '_id'> & {\n _id?: string | ObjectId;\n};\nexport declare type OptionalVersion<TSchema> = EnhancedOmit<\n TSchema,\n '_version'\n> & {\n _version?: bigint;\n};\n\nexport declare interface ObjectIdLike {\n __id?: string | ObjectId;\n}\n\nexport declare type NonObjectIdLikeDocument = {\n [key in keyof ObjectIdLike]?: never;\n} & Document;\n\nexport declare type AlternativeType<T> =\n T extends ReadonlyArray<infer U> ? T | RegExpOrString<U> : RegExpOrString<T>;\n\nexport declare type Condition<T> =\n | AlternativeType<T>\n | PongoFilterOperator<AlternativeType<T>>;\n\nexport declare type PongoFilter<TSchema> =\n | {\n [P in keyof WithId<TSchema>]?: Condition<WithId<TSchema>[P]>;\n }\n | HasId; // TODO: & RootFilterOperators<WithId<TSchema>>;\n\nexport declare interface RootFilterOperators<TSchema> extends Document {\n $and?: PongoFilter<TSchema>[];\n $nor?: PongoFilter<TSchema>[];\n $or?: PongoFilter<TSchema>[];\n $text?: {\n $search: string;\n $language?: string;\n $caseSensitive?: boolean;\n $diacriticSensitive?: boolean;\n };\n $where?: string | ((this: TSchema) => boolean);\n $comment?: string | Document;\n}\n\nexport declare interface PongoFilterOperator<TValue>\n extends NonObjectIdLikeDocument {\n $eq?: TValue;\n $gt?: TValue;\n $gte?: TValue;\n $lt?: TValue;\n $lte?: TValue;\n $ne?: TValue;\n $in?: TValue[];\n $nin?: TValue[];\n // $eq?: TValue;\n // $gt?: TValue;\n // $gte?: TValue;\n // $in?: ReadonlyArray<TValue>;\n // $lt?: TValue;\n // $lte?: TValue;\n // $ne?: TValue;\n // $nin?: ReadonlyArray<TValue>;\n // $not?: TValue extends string ? FilterOperators<TValue> | RegExp : FilterOperators<TValue>;\n // /**\n // * When `true`, `$exists` matches the documents that contain the field,\n // * including documents where the field value is null.\n // */\n // $exists?: boolean;\n // $type?: BSONType | BSONTypeAlias;\n // $expr?: Record<string, any>;\n // $jsonSchema?: Record<string, any>;\n // $mod?: TValue extends number ? [number, number] : never;\n // $regex?: TValue extends string ? RegExp | BSONRegExp | string : never;\n // $options?: TValue extends string ? string : never;\n // $geoIntersects?: {\n // $geometry: Document;\n // };\n // $geoWithin?: Document;\n // $near?: Document;\n // $nearSphere?: Document;\n // $maxDistance?: number;\n // $all?: ReadonlyArray<any>;\n // $elemMatch?: Document;\n // $size?: TValue extends ReadonlyArray<any> ? number : never;\n // $bitsAllClear?: BitwiseFilter;\n // $bitsAllSet?: BitwiseFilter;\n // $bitsAnyClear?: BitwiseFilter;\n // $bitsAnySet?: BitwiseFilter;\n // $rand?: Record<string, never>;\n}\n\nexport type $set<T> = Partial<T>;\nexport type $unset<T> = { [P in keyof T]?: '' };\nexport type $inc<T> = { [P in keyof T]?: number | bigint };\nexport type $push<T> = { [P in keyof T]?: T[P] };\n\nexport type ExpectedDocumentVersionGeneral =\n | 'DOCUMENT_EXISTS'\n | 'DOCUMENT_DOES_NOT_EXIST'\n | 'NO_CONCURRENCY_CHECK';\n\nexport type ExpectedDocumentVersionValue = bigint & { __brand: 'sql' };\n\nexport type ExpectedDocumentVersion =\n | (bigint & { __brand: 'sql' })\n | bigint\n | ExpectedDocumentVersionGeneral;\n\nexport const DOCUMENT_EXISTS =\n 'DOCUMENT_EXISTS' as ExpectedDocumentVersionGeneral;\nexport const DOCUMENT_DOES_NOT_EXIST =\n 'DOCUMENT_DOES_NOT_EXIST' as ExpectedDocumentVersionGeneral;\nexport const NO_CONCURRENCY_CHECK =\n 'NO_CONCURRENCY_CHECK' as ExpectedDocumentVersionGeneral;\n\nexport const isGeneralExpectedDocumentVersion = (\n version: ExpectedDocumentVersion,\n): version is ExpectedDocumentVersionGeneral =>\n version === 'DOCUMENT_DOES_NOT_EXIST' ||\n version === 'DOCUMENT_EXISTS' ||\n version === 'NO_CONCURRENCY_CHECK';\n\nexport const expectedVersionValue = (\n version: ExpectedDocumentVersion | undefined,\n): ExpectedDocumentVersionValue | null =>\n version === undefined || isGeneralExpectedDocumentVersion(version)\n ? null\n : (version as ExpectedDocumentVersionValue);\n\nexport const expectedVersion = (\n version: number | bigint | string | undefined | null,\n): ExpectedDocumentVersion => {\n return version\n ? (BigInt(version) as ExpectedDocumentVersion)\n : NO_CONCURRENCY_CHECK;\n};\n\nexport type PongoUpdate<T> = {\n $set?: Partial<T>;\n $unset?: $unset<T>;\n $inc?: $inc<T>;\n $push?: $push<T>;\n};\n\nexport type OperationResult = {\n acknowledged: boolean;\n successful: boolean;\n\n assertSuccessful: (errorMessage?: string) => void;\n};\n\nexport const operationResult = <T extends OperationResult>(\n result: Omit<T, 'assertSuccess' | 'acknowledged' | 'assertSuccessful'>,\n options: {\n operationName: string;\n collectionName: string;\n errors?: { throwOnOperationFailures?: boolean } | undefined;\n },\n): T => {\n const operationResult: T = {\n ...result,\n acknowledged: true,\n successful: result.successful,\n assertSuccessful: (errorMessage?: string) => {\n const { successful } = result;\n const { operationName, collectionName } = options;\n\n if (!successful)\n throw new ConcurrencyError(\n errorMessage ??\n `${operationName} on ${collectionName} failed. Expected document state does not match current one! Result: ${JSONSerializer.serialize(result)}!`,\n );\n },\n } as T;\n\n if (options.errors?.throwOnOperationFailures)\n operationResult.assertSuccessful();\n\n return operationResult;\n};\n\nexport interface PongoInsertOneResult extends OperationResult {\n insertedId: string | null;\n nextExpectedVersion: bigint;\n}\n\nexport interface PongoInsertManyResult extends OperationResult {\n insertedIds: string[];\n insertedCount: number;\n}\n\nexport interface PongoUpdateResult extends OperationResult {\n matchedCount: number;\n modifiedCount: number;\n nextExpectedVersion: bigint;\n}\n\nexport interface PongoUpdateManyResult extends OperationResult {\n matchedCount: number;\n modifiedCount: number;\n}\n\nexport interface PongoDeleteResult extends OperationResult {\n matchedCount: number;\n deletedCount: number;\n}\n\nexport interface PongoDeleteManyResult extends OperationResult {\n deletedCount: number;\n}\n\nexport type PongoHandleResult<T> =\n | (PongoInsertOneResult & { document: T })\n | (PongoUpdateResult & { document: T })\n | (PongoDeleteResult & { document: null })\n | (OperationResult & { document: null });\n\nexport type PongoDocument = Record<string, unknown>;\n\nexport type DocumentHandler<T extends PongoDocument> =\n | ((document: T | null) => T | null)\n | ((document: T | null) => Promise<T | null>);\n","import type { ConnectorType } from '@event-driven-io/dumbo/src';\nimport {\n type Document,\n type PongoClient,\n type PongoCollection,\n type PongoDb,\n type PongoDocument,\n objectEntries,\n} from '../typing';\n\nexport interface PongoCollectionSchema<\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n T extends PongoDocument = PongoDocument,\n> {\n name: string;\n}\n\n// Database schema interface\nexport interface PongoDbSchema<\n T extends Record<string, PongoCollectionSchema> = Record<\n string,\n PongoCollectionSchema\n >,\n> {\n name?: string;\n collections: T;\n}\n\nexport interface PongoClientSchema<\n T extends Record<string, PongoDbSchema> = Record<string, PongoDbSchema>,\n> {\n dbs: T;\n}\n\nexport type CollectionsMap<T extends Record<string, PongoCollectionSchema>> = {\n [K in keyof T]: PongoCollection<\n T[K] extends PongoCollectionSchema<infer U> ? U : PongoDocument\n >;\n};\n\nexport type PongoDbWithSchema<\n T extends Record<string, PongoCollectionSchema>,\n Connector extends ConnectorType = ConnectorType,\n> = CollectionsMap<T> & PongoDb<Connector>;\n\nexport type DBsMap<\n T extends Record<string, PongoDbSchema>,\n Connector extends ConnectorType = ConnectorType,\n> = {\n [K in keyof T]: CollectionsMap<T[K]['collections']> & PongoDb<Connector>;\n};\n\nexport type PongoClientWithSchema<\n T extends PongoClientSchema,\n Connector extends ConnectorType = ConnectorType,\n> = DBsMap<T['dbs'], Connector> & PongoClient;\n\nconst pongoCollectionSchema = <T extends PongoDocument>(\n name: string,\n): PongoCollectionSchema<T> => ({\n name,\n});\n\nfunction pongoDbSchema<T extends Record<string, PongoCollectionSchema>>(\n collections: T,\n): PongoDbSchema<T>;\nfunction pongoDbSchema<T extends Record<string, PongoCollectionSchema>>(\n name: string,\n collections: T,\n): PongoDbSchema<T>;\nfunction pongoDbSchema<T extends Record<string, PongoCollectionSchema>>(\n nameOrCollections: string | T,\n collections?: T,\n): PongoDbSchema<T> {\n if (collections === undefined) {\n if (typeof nameOrCollections === 'string') {\n throw new Error('You need to provide colleciton definition');\n }\n return {\n collections: nameOrCollections,\n };\n }\n\n return nameOrCollections && typeof nameOrCollections === 'string'\n ? {\n name: nameOrCollections,\n collections,\n }\n : { collections: collections };\n}\n\nconst pongoClientSchema = <T extends Record<string, PongoDbSchema>>(\n dbs: T,\n): PongoClientSchema<T> => ({\n dbs,\n});\n\nexport const pongoSchema = {\n client: pongoClientSchema,\n db: pongoDbSchema,\n collection: pongoCollectionSchema,\n};\n\n// Factory function to create DB instances\nexport const proxyPongoDbWithSchema = <\n T extends Record<string, PongoCollectionSchema>,\n Connector extends ConnectorType = ConnectorType,\n>(\n pongoDb: PongoDb<Connector>,\n dbSchema: PongoDbSchema<T>,\n collections: Map<string, PongoCollection<Document>>,\n): PongoDbWithSchema<T, Connector> => {\n const collectionNames = Object.keys(dbSchema.collections);\n\n for (const collectionName of collectionNames) {\n collections.set(collectionName, pongoDb.collection(collectionName));\n }\n\n return new Proxy(\n pongoDb as PongoDb<Connector> & {\n [key: string]: unknown;\n },\n {\n get(target, prop: string) {\n return collections.get(prop) ?? target[prop];\n },\n },\n ) as PongoDbWithSchema<T, Connector>;\n};\n\nexport const proxyClientWithSchema = <\n TypedClientSchema extends PongoClientSchema,\n>(\n client: PongoClient,\n schema: TypedClientSchema | undefined,\n): PongoClientWithSchema<TypedClientSchema> => {\n if (!schema) return client as PongoClientWithSchema<TypedClientSchema>;\n\n const dbNames = Object.keys(schema.dbs);\n\n return new Proxy(\n client as PongoClient & {\n [key: string]: unknown;\n },\n {\n get(target, prop: string) {\n if (dbNames.includes(prop)) return client.db(schema.dbs[prop]?.name);\n\n return target[prop];\n },\n },\n ) as PongoClientWithSchema<TypedClientSchema>;\n};\n\nexport type PongoCollectionSchemaMetadata = {\n name: string;\n};\n\nexport type PongoDbSchemaMetadata = {\n name?: string | undefined;\n collections: PongoCollectionSchemaMetadata[];\n};\n\nexport type PongoClientSchemaMetadata = {\n databases: PongoDbSchemaMetadata[];\n database: (name?: string) => PongoDbSchemaMetadata | undefined;\n};\n\nexport const toDbSchemaMetadata = <TypedDbSchema extends PongoDbSchema>(\n schema: TypedDbSchema,\n): PongoDbSchemaMetadata => ({\n name: schema.name,\n collections: objectEntries(schema.collections).map((c) => ({\n name: c[1].name,\n })),\n});\n\nexport const toClientSchemaMetadata = <\n TypedClientSchema extends PongoClientSchema,\n>(\n schema: TypedClientSchema,\n): PongoClientSchemaMetadata => {\n const databases = objectEntries(schema.dbs).map((e) =>\n toDbSchemaMetadata(e[1]),\n );\n\n return {\n databases,\n database: (name) => databases.find((db) => db.name === name),\n };\n};\n\nexport interface PongoSchemaConfig<\n TypedClientSchema extends PongoClientSchema = PongoClientSchema,\n> {\n schema: TypedClientSchema;\n}\n","export const deepEquals = <T>(left: T, right: T): boolean => {\n if (isEquatable(left)) {\n return left.equals(right);\n }\n\n if (Array.isArray(left)) {\n return (\n Array.isArray(right) &&\n left.length === right.length &&\n left.every((val, index) => deepEquals(val, right[index]))\n );\n }\n\n if (\n typeof left !== 'object' ||\n typeof right !== 'object' ||\n left === null ||\n right === null\n ) {\n return left === right;\n }\n\n if (Array.isArray(right)) return false;\n\n const keys1 = Object.keys(left);\n const keys2 = Object.keys(right);\n\n if (\n keys1.length !== keys2.length ||\n !keys1.every((key) => keys2.includes(key))\n )\n return false;\n\n for (const key in left) {\n if (left[key] instanceof Function && right[key] instanceof Function)\n continue;\n\n const isEqual = deepEquals(left[key], right[key]);\n if (!isEqual) {\n return false;\n }\n }\n\n return true;\n};\n\nexport type Equatable<T> = { equals: (right: T) => boolean } & T;\n\nexport const isEquatable = <T>(left: T): left is Equatable<T> => {\n return (\n left &&\n typeof left === 'object' &&\n 'equals' in left &&\n typeof left['equals'] === 'function'\n );\n};\n","import { JSONSerializer, sql } from '@event-driven-io/dumbo';\nimport { objectEntries, OperatorMap } from '../../../../core';\n\nexport const handleOperator = (\n path: string,\n operator: string,\n value: unknown,\n): string => {\n if (path === '_id' || path === '_version') {\n return handleMetadataOperator(path, operator, value);\n }\n\n switch (operator) {\n case '$eq':\n return sql(\n `(data @> %L::jsonb OR jsonb_path_exists(data, '$.%s[*] ? (@ == %s)'))`,\n JSONSerializer.serialize(buildNestedObject(path, value)),\n path,\n JSONSerializer.serialize(value),\n );\n case '$gt':\n case '$gte':\n case '$lt':\n case '$lte':\n case '$ne':\n return sql(\n `data #>> %L ${OperatorMap[operator]} %L`,\n `{${path.split('.').join(',')}}`,\n value,\n );\n case '$in':\n return sql(\n 'data #>> %L IN (%s)',\n `{${path.split('.').join(',')}}`,\n (value as unknown[]).map((v) => sql('%L', v)).join(', '),\n );\n case '$nin':\n return sql(\n 'data #>> %L NOT IN (%s)',\n `{${path.split('.').join(',')}}`,\n (value as unknown[]).map((v) => sql('%L', v)).join(', '),\n );\n case '$elemMatch': {\n const subQuery = objectEntries(value as Record<string, unknown>)\n .map(([subKey, subValue]) =>\n sql(`@.\"%s\" == %s`, subKey, JSONSerializer.serialize(subValue)),\n )\n .join(' && ');\n return sql(`jsonb_path_exists(data, '$.%s[*] ? (%s)')`, path, subQuery);\n }\n case '$all':\n return sql(\n 'data @> %L::jsonb',\n JSONSerializer.serialize(buildNestedObject(path, value)),\n );\n case '$size':\n return sql(\n 'jsonb_array_length(data #> %L) = %L',\n `{${path.split('.').join(',')}}`,\n value,\n );\n default:\n throw new Error(`Unsupported operator: ${operator}`);\n }\n};\n\nconst handleMetadataOperator = (\n fieldName: string,\n operator: string,\n value: unknown,\n): string => {\n switch (operator) {\n case '$eq':\n return sql(`${fieldName} = %L`, value);\n case '$gt':\n case '$gte':\n case '$lt':\n case '$lte':\n case '$ne':\n return sql(`${fieldName} ${OperatorMap[operator]} %L`, value);\n case '$in':\n return sql(\n `${fieldName} IN (%s)`,\n (value as unknown[]).map((v) => sql('%L', v)).join(', '),\n );\n case '$nin':\n return sql(\n `${fieldName} NOT IN (%s)`,\n (value as unknown[]).map((v) => sql('%L', v)).join(', '),\n );\n default:\n throw new Error(`Unsupported operator: ${operator}`);\n }\n};\n\nconst buildNestedObject = (\n path: string,\n value: unknown,\n): Record<string, unknown> =>\n path\n .split('.')\n .reverse()\n .reduce((acc, key) => ({ [key]: acc }), value as Record<string, unknown>);\n","import {\n hasOperators,\n objectEntries,\n QueryOperators,\n type PongoFilter,\n} from '../../../../core';\nimport { handleOperator } from './queryOperators';\n\nexport * from './queryOperators';\n\nconst AND = 'AND';\n\nexport const constructFilterQuery = <T>(filter: PongoFilter<T>): string =>\n Object.entries(filter)\n .map(([key, value]) =>\n isRecord(value)\n ? constructComplexFilterQuery(key, value)\n : handleOperator(key, '$eq', value),\n )\n .join(` ${AND} `);\n\nconst constructComplexFilterQuery = (\n key: string,\n value: Record<string, unknown>,\n): string => {\n const isEquality = !hasOperators(value);\n\n return objectEntries(value)\n .map(\n ([nestedKey, val]) =>\n isEquality\n ? handleOperator(`${key}.${nestedKey}`, QueryOperators.$eq, val) // regular value\n : handleOperator(key, nestedKey, val), // operator\n )\n .join(` ${AND} `);\n};\n\nconst isRecord = (value: unknown): value is Record<string, unknown> =>\n value !== null && typeof value === 'object' && !Array.isArray(value);\n","import { JSONSerializer, sql, type SQL } from '@event-driven-io/dumbo';\nimport {\n objectEntries,\n type $inc,\n type $push,\n type $set,\n type $unset,\n type PongoUpdate,\n} from '../../../../core';\n\nexport const buildUpdateQuery = <T>(update: PongoUpdate<T>): SQL =>\n objectEntries(update).reduce((currentUpdateQuery, [op, value]) => {\n switch (op) {\n case '$set':\n return buildSetQuery(value, currentUpdateQuery);\n case '$unset':\n return buildUnsetQuery(value, currentUpdateQuery);\n case '$inc':\n return buildIncQuery(value, currentUpdateQuery);\n case '$push':\n return buildPushQuery(value, currentUpdateQuery);\n default:\n return currentUpdateQuery;\n }\n }, sql('data'));\n\nexport const buildSetQuery = <T>(set: $set<T>, currentUpdateQuery: SQL): SQL =>\n sql('%s || %L::jsonb', currentUpdateQuery, JSONSerializer.serialize(set));\n\nexport const buildUnsetQuery = <T>(\n unset: $unset<T>,\n currentUpdateQuery: SQL,\n): SQL =>\n sql(\n '%s - %L',\n currentUpdateQuery,\n Object.keys(unset)\n .map((k) => `{${k}}`)\n .join(', '),\n );\n\nexport const buildIncQuery = <T>(\n inc: $inc<T>,\n currentUpdateQuery: SQL,\n): SQL => {\n for (const [key, value] of Object.entries(inc)) {\n currentUpdateQuery = sql(\n typeof value === 'bigint'\n ? \"jsonb_set(%s, '{%s}', to_jsonb((COALESCE((data->>'%s')::BIGINT, 0) + %L)::TEXT), true)\"\n : \"jsonb_set(%s, '{%s}', to_jsonb(COALESCE((data->>'%s')::NUMERIC, 0) + %L), true)\",\n currentUpdateQuery,\n key,\n key,\n value,\n );\n }\n return currentUpdateQuery;\n};\n\nexport const buildPushQuery = <T>(\n push: $push<T>,\n currentUpdateQuery: SQL,\n): SQL => {\n for (const [key, value] of Object.entries(push)) {\n currentUpdateQuery = sql(\n \"jsonb_set(%s, '{%s}', (coalesce(data->'%s', '[]'::jsonb) || %L::jsonb), true)\",\n currentUpdateQuery,\n key,\n key,\n JSONSerializer.serialize([value]),\n );\n }\n return currentUpdateQuery;\n};\n"],"mappings":"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","names":["JSONSerializer","sql","schemaComponent","runPostgreSQLMigrations","sql","options","db","sql","createCollection","expectedVersion","schemaComponent","runPostgreSQLMigrations","NodePostgresConnectorType","options","uuid","uuid","operationResult","pongoClient","NodePostgresConnectorType","JSONSerializer","JSONSerializer","JSONSerializer","sql","sql","JSONSerializer","sql","JSONSerializer","expectedVersion"]}
|
package/dist/pg-BfTNWLV9.d.ts
DELETED
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
import { P as PongoDb, W as OptionalUnlessRequiredIdAndVersion, a9 as PongoFilter, ap as PongoUpdate, U as UpdateOneOptions, Y as WithoutId, R as ReplaceOneOptions, J as DeleteOneOptions, L as FindOptions, E as CollectionOperationOptions, ay as PongoDocument, c as PongoCollection } from './pongoClient-D8jPedlZ.js';
|
|
2
|
-
import { ConnectorType, Dumbo, SQLMigration, SQL, MigrationStyle, SQLExecutor, SchemaComponent } from '@event-driven-io/dumbo';
|
|
3
|
-
|
|
4
|
-
type PongoCollectionOptions<Connector extends ConnectorType = ConnectorType> = {
|
|
5
|
-
db: PongoDb<Connector>;
|
|
6
|
-
collectionName: string;
|
|
7
|
-
pool: Dumbo;
|
|
8
|
-
sqlBuilder: PongoCollectionSQLBuilder;
|
|
9
|
-
schema?: {
|
|
10
|
-
autoMigration?: MigrationStyle;
|
|
11
|
-
};
|
|
12
|
-
errors?: {
|
|
13
|
-
throwOnOperationFailures?: boolean;
|
|
14
|
-
};
|
|
15
|
-
};
|
|
16
|
-
declare const transactionExecutorOrDefault: <Connector extends ConnectorType = ConnectorType>(db: PongoDb<Connector>, options: CollectionOperationOptions | undefined, defaultSqlExecutor: SQLExecutor) => Promise<SQLExecutor>;
|
|
17
|
-
declare const pongoCollection: <T extends PongoDocument, Connector extends ConnectorType = ConnectorType>({ db, collectionName, pool, sqlBuilder: SqlFor, schema, errors, }: PongoCollectionOptions<Connector>) => PongoCollection<T>;
|
|
18
|
-
declare const pongoCollectionSchemaComponent: (collectionName: string) => SchemaComponent;
|
|
19
|
-
type PongoCollectionSQLBuilder = {
|
|
20
|
-
migrations: () => SQLMigration[];
|
|
21
|
-
createCollection: () => SQL;
|
|
22
|
-
insertOne: <T>(document: OptionalUnlessRequiredIdAndVersion<T>) => SQL;
|
|
23
|
-
insertMany: <T>(documents: OptionalUnlessRequiredIdAndVersion<T>[]) => SQL;
|
|
24
|
-
updateOne: <T>(filter: PongoFilter<T> | SQL, update: PongoUpdate<T> | SQL, options?: UpdateOneOptions) => SQL;
|
|
25
|
-
replaceOne: <T>(filter: PongoFilter<T> | SQL, document: WithoutId<T>, options?: ReplaceOneOptions) => SQL;
|
|
26
|
-
updateMany: <T>(filter: PongoFilter<T> | SQL, update: PongoUpdate<T> | SQL) => SQL;
|
|
27
|
-
deleteOne: <T>(filter: PongoFilter<T> | SQL, options?: DeleteOneOptions) => SQL;
|
|
28
|
-
deleteMany: <T>(filter: PongoFilter<T> | SQL) => SQL;
|
|
29
|
-
findOne: <T>(filter: PongoFilter<T> | SQL) => SQL;
|
|
30
|
-
find: <T>(filter: PongoFilter<T> | SQL, options?: FindOptions) => SQL;
|
|
31
|
-
countDocuments: <T>(filter: PongoFilter<T> | SQL) => SQL;
|
|
32
|
-
rename: (newName: string) => SQL;
|
|
33
|
-
drop: () => SQL;
|
|
34
|
-
};
|
|
35
|
-
|
|
36
|
-
declare const pongoCollectionPostgreSQLMigrations: (collectionName: string) => SQLMigration[];
|
|
37
|
-
declare const postgresSQLBuilder: (collectionName: string) => PongoCollectionSQLBuilder;
|
|
38
|
-
|
|
39
|
-
export { type PongoCollectionOptions as P, pongoCollectionSchemaComponent as a, type PongoCollectionSQLBuilder as b, pongoCollectionPostgreSQLMigrations as c, postgresSQLBuilder as d, pongoCollection as p, transactionExecutorOrDefault as t };
|
package/dist/pg-C9NmCQe7.d.cts
DELETED
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
import { P as PongoDb, W as OptionalUnlessRequiredIdAndVersion, a9 as PongoFilter, ap as PongoUpdate, U as UpdateOneOptions, Y as WithoutId, R as ReplaceOneOptions, J as DeleteOneOptions, L as FindOptions, E as CollectionOperationOptions, ay as PongoDocument, c as PongoCollection } from './pongoClient-D8jPedlZ.cjs';
|
|
2
|
-
import { ConnectorType, Dumbo, SQLMigration, SQL, MigrationStyle, SQLExecutor, SchemaComponent } from '@event-driven-io/dumbo';
|
|
3
|
-
|
|
4
|
-
type PongoCollectionOptions<Connector extends ConnectorType = ConnectorType> = {
|
|
5
|
-
db: PongoDb<Connector>;
|
|
6
|
-
collectionName: string;
|
|
7
|
-
pool: Dumbo;
|
|
8
|
-
sqlBuilder: PongoCollectionSQLBuilder;
|
|
9
|
-
schema?: {
|
|
10
|
-
autoMigration?: MigrationStyle;
|
|
11
|
-
};
|
|
12
|
-
errors?: {
|
|
13
|
-
throwOnOperationFailures?: boolean;
|
|
14
|
-
};
|
|
15
|
-
};
|
|
16
|
-
declare const transactionExecutorOrDefault: <Connector extends ConnectorType = ConnectorType>(db: PongoDb<Connector>, options: CollectionOperationOptions | undefined, defaultSqlExecutor: SQLExecutor) => Promise<SQLExecutor>;
|
|
17
|
-
declare const pongoCollection: <T extends PongoDocument, Connector extends ConnectorType = ConnectorType>({ db, collectionName, pool, sqlBuilder: SqlFor, schema, errors, }: PongoCollectionOptions<Connector>) => PongoCollection<T>;
|
|
18
|
-
declare const pongoCollectionSchemaComponent: (collectionName: string) => SchemaComponent;
|
|
19
|
-
type PongoCollectionSQLBuilder = {
|
|
20
|
-
migrations: () => SQLMigration[];
|
|
21
|
-
createCollection: () => SQL;
|
|
22
|
-
insertOne: <T>(document: OptionalUnlessRequiredIdAndVersion<T>) => SQL;
|
|
23
|
-
insertMany: <T>(documents: OptionalUnlessRequiredIdAndVersion<T>[]) => SQL;
|
|
24
|
-
updateOne: <T>(filter: PongoFilter<T> | SQL, update: PongoUpdate<T> | SQL, options?: UpdateOneOptions) => SQL;
|
|
25
|
-
replaceOne: <T>(filter: PongoFilter<T> | SQL, document: WithoutId<T>, options?: ReplaceOneOptions) => SQL;
|
|
26
|
-
updateMany: <T>(filter: PongoFilter<T> | SQL, update: PongoUpdate<T> | SQL) => SQL;
|
|
27
|
-
deleteOne: <T>(filter: PongoFilter<T> | SQL, options?: DeleteOneOptions) => SQL;
|
|
28
|
-
deleteMany: <T>(filter: PongoFilter<T> | SQL) => SQL;
|
|
29
|
-
findOne: <T>(filter: PongoFilter<T> | SQL) => SQL;
|
|
30
|
-
find: <T>(filter: PongoFilter<T> | SQL, options?: FindOptions) => SQL;
|
|
31
|
-
countDocuments: <T>(filter: PongoFilter<T> | SQL) => SQL;
|
|
32
|
-
rename: (newName: string) => SQL;
|
|
33
|
-
drop: () => SQL;
|
|
34
|
-
};
|
|
35
|
-
|
|
36
|
-
declare const pongoCollectionPostgreSQLMigrations: (collectionName: string) => SQLMigration[];
|
|
37
|
-
declare const postgresSQLBuilder: (collectionName: string) => PongoCollectionSQLBuilder;
|
|
38
|
-
|
|
39
|
-
export { type PongoCollectionOptions as P, pongoCollectionSchemaComponent as a, type PongoCollectionSQLBuilder as b, pongoCollectionPostgreSQLMigrations as c, postgresSQLBuilder as d, pongoCollection as p, transactionExecutorOrDefault as t };
|