@event-driven-io/pongo 0.6.1 → 0.7.0

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/index.cjs CHANGED
@@ -1,4 +1,4 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } async function _asyncNullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return await rhsFn(); } } async function _asyncOptionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = await fn(value); } else if (op === 'call' || op === 'optionalCall') { value = await fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; } var _class;var _dumbo = require('@event-driven-io/dumbo');require('pg');var _pgformat = require('pg-format'); var _pgformat2 = _interopRequireDefault(_pgformat);var _uuid = require('uuid');var T=t=>Object.entries(t).map(([e,n])=>[e,n]);var D={$eq:"$eq",$gt:"$gt",$gte:"$gte",$lt:"$lt",$lte:"$lte",$ne:"$ne",$in:"$in",$nin:"$nin",$elemMatch:"$elemMatch",$all:"$all",$size:"$size"},F={$gt:">",$gte:">=",$lt:"<",$lte:"<=",$ne:"!="},M= exports.isOperator =t=>t.startsWith("$"),E= exports.hasOperators =t=>Object.keys(t).some(M),O= exports.handleOperator =(t,e,n)=>{if(t==="_id")return $(e,n);switch(e){case"$eq":return _pgformat2.default.call(void 0, "(data @> %L::jsonb OR jsonb_path_exists(data, '$.%s[*] ? (@ == %s)'))",JSON.stringify(x(t,n)),t,JSON.stringify(n));case"$gt":case"$gte":case"$lt":case"$lte":case"$ne":return _pgformat2.default.call(void 0, `data #>> %L ${F[e]} %L`,`{${t.split(".").join(",")}}`,n);case"$in":return _pgformat2.default.call(void 0, "data #>> %L IN (%s)",`{${t.split(".").join(",")}}`,n.map(o=>_pgformat2.default.call(void 0, "%L",o)).join(", "));case"$nin":return _pgformat2.default.call(void 0, "data #>> %L NOT IN (%s)",`{${t.split(".").join(",")}}`,n.map(o=>_pgformat2.default.call(void 0, "%L",o)).join(", "));case"$elemMatch":{let o=T(n).map(([r,d])=>_pgformat2.default.call(void 0, '@."%s" == %s',r,JSON.stringify(d))).join(" && ");return _pgformat2.default.call(void 0, "jsonb_path_exists(data, '$.%s[*] ? (%s)')",t,o)}case"$all":return _pgformat2.default.call(void 0, "data @> %L::jsonb",JSON.stringify(x(t,n)));case"$size":return _pgformat2.default.call(void 0, "jsonb_array_length(data #> %L) = %L",`{${t.split(".").join(",")}}`,n);default:throw new Error(`Unsupported operator: ${e}`)}},$=(t,e)=>{switch(t){case"$eq":return _pgformat2.default.call(void 0, "_id = %L",e);case"$gt":case"$gte":case"$lt":case"$lte":case"$ne":return _pgformat2.default.call(void 0, `_id ${F[t]} %L`,e);case"$in":return _pgformat2.default.call(void 0, "_id IN (%s)",e.map(n=>_pgformat2.default.call(void 0, "%L",n)).join(", "));case"$nin":return _pgformat2.default.call(void 0, "_id NOT IN (%s)",e.map(n=>_pgformat2.default.call(void 0, "%L",n)).join(", "));default:throw new Error(`Unsupported operator: ${t}`)}},x=(t,e)=>t.split(".").reverse().reduce((n,o)=>({[o]:n}),e);var b="AND",c= exports.constructFilterQuery =t=>Object.entries(t).map(([e,n])=>W(n)?A(e,n):O(e,"$eq",n)).join(` ${b} `),A=(t,e)=>{let n=!E(e);return T(e).map(([o,r])=>n?O(`${t}.${o}`,D.$eq,r):O(t,o,r)).join(` ${b} `)},W=t=>t!==null&&typeof t=="object"&&!Array.isArray(t);var h=t=>T(t).reduce((e,[n,o])=>{switch(n){case"$set":return U(o,e);case"$unset":return N(o,e);case"$inc":return Q(o,e);case"$push":return j(o,e);default:return e}},_dumbo.sql.call(void 0, "data")),U= exports.buildSetQuery =(t,e)=>_dumbo.sql.call(void 0, "%s || %L::jsonb",e,JSON.stringify(t)),N= exports.buildUnsetQuery =(t,e)=>_dumbo.sql.call(void 0, "%s - %L",e,Object.keys(t).map(n=>`{${n}}`).join(", ")),Q= exports.buildIncQuery =(t,e)=>{for(let[n,o]of Object.entries(t))e=_dumbo.sql.call(void 0, "jsonb_set(%s, '{%s}', to_jsonb((data->>'%s')::numeric + %L), true)",e,n,n,o);return e},j= exports.buildPushQuery =(t,e)=>{for(let[n,o]of Object.entries(t))e=_dumbo.sql.call(void 0, "jsonb_set(%s, '{%s}', (coalesce(data->'%s', '[]'::jsonb) || %L::jsonb), true)",e,n,n,JSON.stringify([o]));return e};var k=(t,{dbName:e,poolOrClient:n})=>{let o=i=>_dumbo.executeSQL.call(void 0, n,i),r=K(t),d=o(r.createCollection()),u={dbName:e,collectionName:t,createCollection:async()=>{await d},insertOne:async i=>{await d;let s=_uuid.v4.call(void 0, );return(await o(r.insertOne({_id:s,...i}))).rowCount?{insertedId:s,acknowledged:!0}:{insertedId:null,acknowledged:!1}},insertMany:async i=>{await d;let s=i.map(m=>({_id:_uuid.v4.call(void 0, ),...m})),a=await o(r.insertMany(s));return{acknowledged:a.rowCount===s.length,insertedCount:_nullishCoalesce(a.rowCount, () => (0)),insertedIds:s.map(m=>m._id)}},updateOne:async(i,s)=>{await d;let a=await o(r.updateOne(i,s));return a.rowCount?{acknowledged:!0,modifiedCount:a.rowCount}:{acknowledged:!1,modifiedCount:0}},replaceOne:async(i,s)=>{await d;let a=await o(r.replaceOne(i,s));return a.rowCount?{acknowledged:!0,modifiedCount:a.rowCount}:{acknowledged:!1,modifiedCount:0}},updateMany:async(i,s)=>{await d;let a=await o(r.updateMany(i,s));return a.rowCount?{acknowledged:!0,modifiedCount:a.rowCount}:{acknowledged:!1,modifiedCount:0}},deleteOne:async i=>{await d;let s=await o(r.deleteOne(_nullishCoalesce(i, () => ({}))));return s.rowCount?{acknowledged:!0,deletedCount:s.rowCount}:{acknowledged:!1,deletedCount:0}},deleteMany:async i=>{await d;let s=await o(r.deleteMany(_nullishCoalesce(i, () => ({}))));return s.rowCount?{acknowledged:!0,deletedCount:s.rowCount}:{acknowledged:!1,deletedCount:0}},findOne:async i=>(await d,await _asyncNullishCoalesce(await _asyncOptionalChain([(await o(r.findOne(_nullishCoalesce(i, () => ({}))))), 'access', async _2 => _2.rows, 'access', async _3 => _3[0], 'optionalAccess', async _4 => _4.data]), async () => (null))),findOneAndDelete:async i=>{await d;let s=await u.findOne(i);return s===null?null:(await u.deleteOne(i),s)},findOneAndReplace:async(i,s)=>{await d;let a=await u.findOne(i);return a===null?null:(await u.replaceOne(i,s),a)},findOneAndUpdate:async(i,s)=>{await d;let a=await u.findOne(i);return a===null?null:(await u.updateOne(i,s),a)},handle:async(i,s)=>{await d;let a={_id:i},m=await u.findOne(a),f=await s(m);if(!m&&f){let y={...f,_id:i};return await u.insertOne({...y,_id:i}),y}return m&&!f?(await u.deleteOne(a),null):(m&&f&&await u.replaceOne(a,f),f)},find:async i=>(await d,(await o(r.find(_nullishCoalesce(i, () => ({}))))).rows.map(a=>a.data)),countDocuments:async i=>{await d;let{count:s}=await _dumbo.single.call(void 0, o(r.countDocuments(_nullishCoalesce(i, () => ({})))));return s},drop:async()=>(await d,(await _asyncNullishCoalesce(await _asyncOptionalChain([(await o(r.drop())), 'optionalAccess', async _5 => _5.rowCount]), async () => (0)))>0),rename:async i=>(await d,await o(r.rename(i)),t=i,u)};return u},K= exports.collectionSQLBuilder =t=>({createCollection:()=>_dumbo.sql.call(void 0, `CREATE TABLE IF NOT EXISTS %I (
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } async function _asyncNullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return await rhsFn(); } } async function _asyncOptionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = await fn(value); } else if (op === 'call' || op === 'optionalCall') { value = await fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; } var _class;var _dumbo = require('@event-driven-io/dumbo');require('pg');var _pgformat = require('pg-format'); var _pgformat2 = _interopRequireDefault(_pgformat);var _uuid = require('uuid');var T=t=>Object.entries(t).map(([e,n])=>[e,n]);var D={$eq:"$eq",$gt:"$gt",$gte:"$gte",$lt:"$lt",$lte:"$lte",$ne:"$ne",$in:"$in",$nin:"$nin",$elemMatch:"$elemMatch",$all:"$all",$size:"$size"},F={$gt:">",$gte:">=",$lt:"<",$lte:"<=",$ne:"!="},M= exports.isOperator =t=>t.startsWith("$"),E= exports.hasOperators =t=>Object.keys(t).some(M),O= exports.handleOperator =(t,e,n)=>{if(t==="_id")return $(e,n);switch(e){case"$eq":return _pgformat2.default.call(void 0, "(data @> %L::jsonb OR jsonb_path_exists(data, '$.%s[*] ? (@ == %s)'))",JSON.stringify(x(t,n)),t,JSON.stringify(n));case"$gt":case"$gte":case"$lt":case"$lte":case"$ne":return _pgformat2.default.call(void 0, `data #>> %L ${F[e]} %L`,`{${t.split(".").join(",")}}`,n);case"$in":return _pgformat2.default.call(void 0, "data #>> %L IN (%s)",`{${t.split(".").join(",")}}`,n.map(o=>_pgformat2.default.call(void 0, "%L",o)).join(", "));case"$nin":return _pgformat2.default.call(void 0, "data #>> %L NOT IN (%s)",`{${t.split(".").join(",")}}`,n.map(o=>_pgformat2.default.call(void 0, "%L",o)).join(", "));case"$elemMatch":{let o=T(n).map(([i,d])=>_pgformat2.default.call(void 0, '@."%s" == %s',i,JSON.stringify(d))).join(" && ");return _pgformat2.default.call(void 0, "jsonb_path_exists(data, '$.%s[*] ? (%s)')",t,o)}case"$all":return _pgformat2.default.call(void 0, "data @> %L::jsonb",JSON.stringify(x(t,n)));case"$size":return _pgformat2.default.call(void 0, "jsonb_array_length(data #> %L) = %L",`{${t.split(".").join(",")}}`,n);default:throw new Error(`Unsupported operator: ${e}`)}},$=(t,e)=>{switch(t){case"$eq":return _pgformat2.default.call(void 0, "_id = %L",e);case"$gt":case"$gte":case"$lt":case"$lte":case"$ne":return _pgformat2.default.call(void 0, `_id ${F[t]} %L`,e);case"$in":return _pgformat2.default.call(void 0, "_id IN (%s)",e.map(n=>_pgformat2.default.call(void 0, "%L",n)).join(", "));case"$nin":return _pgformat2.default.call(void 0, "_id NOT IN (%s)",e.map(n=>_pgformat2.default.call(void 0, "%L",n)).join(", "));default:throw new Error(`Unsupported operator: ${t}`)}},x=(t,e)=>t.split(".").reverse().reduce((n,o)=>({[o]:n}),e);var b="AND",c= exports.constructFilterQuery =t=>Object.entries(t).map(([e,n])=>W(n)?A(e,n):O(e,"$eq",n)).join(` ${b} `),A=(t,e)=>{let n=!E(e);return T(e).map(([o,i])=>n?O(`${t}.${o}`,D.$eq,i):O(t,o,i)).join(` ${b} `)},W=t=>t!==null&&typeof t=="object"&&!Array.isArray(t);var h=t=>T(t).reduce((e,[n,o])=>{switch(n){case"$set":return U(o,e);case"$unset":return N(o,e);case"$inc":return Q(o,e);case"$push":return j(o,e);default:return e}},_dumbo.sql.call(void 0, "data")),U= exports.buildSetQuery =(t,e)=>_dumbo.sql.call(void 0, "%s || %L::jsonb",e,JSON.stringify(t)),N= exports.buildUnsetQuery =(t,e)=>_dumbo.sql.call(void 0, "%s - %L",e,Object.keys(t).map(n=>`{${n}}`).join(", ")),Q= exports.buildIncQuery =(t,e)=>{for(let[n,o]of Object.entries(t))e=_dumbo.sql.call(void 0, "jsonb_set(%s, '{%s}', to_jsonb((data->>'%s')::numeric + %L), true)",e,n,n,o);return e},j= exports.buildPushQuery =(t,e)=>{for(let[n,o]of Object.entries(t))e=_dumbo.sql.call(void 0, "jsonb_set(%s, '{%s}', (coalesce(data->'%s', '[]'::jsonb) || %L::jsonb), true)",e,n,n,JSON.stringify([o]));return e};var k=(t,{dbName:e,poolOrClient:n})=>{let o=r=>_dumbo.executeSQL.call(void 0, n,r),i=K(t),d=o(i.createCollection()),a={dbName:e,collectionName:t,createCollection:async()=>{await d},insertOne:async r=>{await d;let s=_uuid.v4.call(void 0, );return(await o(i.insertOne({_id:s,...r}))).rowCount?{insertedId:s,acknowledged:!0}:{insertedId:null,acknowledged:!1}},insertMany:async r=>{await d;let s=r.map(m=>({_id:_uuid.v4.call(void 0, ),...m})),l=await o(i.insertMany(s));return{acknowledged:l.rowCount===s.length,insertedCount:_nullishCoalesce(l.rowCount, () => (0)),insertedIds:s.map(m=>m._id)}},updateOne:async(r,s)=>{await d;let l=await o(i.updateOne(r,s));return l.rowCount?{acknowledged:!0,modifiedCount:l.rowCount}:{acknowledged:!1,modifiedCount:0}},replaceOne:async(r,s)=>{await d;let l=await o(i.replaceOne(r,s));return l.rowCount?{acknowledged:!0,modifiedCount:l.rowCount}:{acknowledged:!1,modifiedCount:0}},updateMany:async(r,s)=>{await d;let l=await o(i.updateMany(r,s));return l.rowCount?{acknowledged:!0,modifiedCount:l.rowCount}:{acknowledged:!1,modifiedCount:0}},deleteOne:async r=>{await d;let s=await o(i.deleteOne(_nullishCoalesce(r, () => ({}))));return s.rowCount?{acknowledged:!0,deletedCount:s.rowCount}:{acknowledged:!1,deletedCount:0}},deleteMany:async r=>{await d;let s=await o(i.deleteMany(_nullishCoalesce(r, () => ({}))));return s.rowCount?{acknowledged:!0,deletedCount:s.rowCount}:{acknowledged:!1,deletedCount:0}},findOne:async r=>(await d,await _asyncNullishCoalesce(await _asyncOptionalChain([(await o(i.findOne(_nullishCoalesce(r, () => ({}))))), 'access', async _2 => _2.rows, 'access', async _3 => _3[0], 'optionalAccess', async _4 => _4.data]), async () => (null))),findOneAndDelete:async r=>{await d;let s=await a.findOne(r);return s===null?null:(await a.deleteOne(r),s)},findOneAndReplace:async(r,s)=>{await d;let l=await a.findOne(r);return l===null?null:(await a.replaceOne(r,s),l)},findOneAndUpdate:async(r,s)=>{await d;let l=await a.findOne(r);return l===null?null:(await a.updateOne(r,s),l)},handle:async(r,s)=>{await d;let l={_id:r},m=await a.findOne(l),f=await s(m);if(!m&&f){let y={...f,_id:r};return await a.insertOne({...y,_id:r}),y}return m&&!f?(await a.deleteOne(l),null):(m&&f&&await a.replaceOne(l,f),f)},find:async r=>(await d,(await o(i.find(_nullishCoalesce(r, () => ({}))))).rows.map(l=>l.data)),countDocuments:async r=>{await d;let{count:s}=await _dumbo.single.call(void 0, o(i.countDocuments(_nullishCoalesce(r, () => ({})))));return s},drop:async()=>(await d,(await _asyncNullishCoalesce(await _asyncOptionalChain([(await o(i.drop())), 'optionalAccess', async _5 => _5.rowCount]), async () => (0)))>0),rename:async r=>(await d,await o(i.rename(r)),t=r,a)};return a},K= exports.collectionSQLBuilder =t=>({createCollection:()=>_dumbo.sql.call(void 0, `CREATE TABLE IF NOT EXISTS %I (
2
2
  _id TEXT PRIMARY KEY,
3
3
  data JSONB NOT NULL,
4
4
  metadata JSONB NOT NULL DEFAULT '{}',
@@ -7,8 +7,8 @@
7
7
  _archived BOOLEAN NOT NULL DEFAULT FALSE,
8
8
  _created TIMESTAMPTZ NOT NULL DEFAULT now(),
9
9
  _updated TIMESTAMPTZ NOT NULL DEFAULT now()
10
- )`,t),insertOne:e=>_dumbo.sql.call(void 0, "INSERT INTO %I (_id, data) VALUES (%L, %L)",t,e._id,JSON.stringify(e)),insertMany:e=>{let n=e.map(o=>_pgformat2.default.call(void 0, "(%L, %L)",o._id,JSON.stringify(o))).join(", ");return _dumbo.sql.call(void 0, "INSERT INTO %I (_id, data) VALUES %s",t,n)},updateOne:(e,n)=>{let o=c(e),r=h(n);return _dumbo.sql.call(void 0, `WITH cte AS (
10
+ )`,t),insertOne:e=>_dumbo.sql.call(void 0, "INSERT INTO %I (_id, data) VALUES (%L, %L)",t,e._id,JSON.stringify(e)),insertMany:e=>{let n=e.map(o=>_pgformat2.default.call(void 0, "(%L, %L)",o._id,JSON.stringify(o))).join(", ");return _dumbo.sql.call(void 0, "INSERT INTO %I (_id, data) VALUES %s",t,n)},updateOne:(e,n)=>{let o=c(e),i=h(n);return _dumbo.sql.call(void 0, `WITH cte AS (
11
11
  SELECT _id FROM %I WHERE %s LIMIT 1
12
12
  )
13
- UPDATE %I SET data = %s FROM cte WHERE %I._id = cte._id`,t,o,t,r,t)},replaceOne:(e,n)=>{let o=c(e);return _dumbo.sql.call(void 0, "UPDATE %I SET data = %L || jsonb_build_object('_id', data->>'_id') WHERE %s",t,JSON.stringify(n),o)},updateMany:(e,n)=>{let o=c(e),r=h(n);return _dumbo.sql.call(void 0, "UPDATE %I SET data = %s WHERE %s",t,r,o)},deleteOne:e=>{let n=c(e);return _dumbo.sql.call(void 0, "DELETE FROM %I WHERE %s",t,n)},deleteMany:e=>{let n=c(e);return _dumbo.sql.call(void 0, "DELETE FROM %I WHERE %s",t,n)},findOne:e=>{let n=c(e);return _dumbo.sql.call(void 0, "SELECT data FROM %I WHERE %s LIMIT 1",t,n)},find:e=>{let n=c(e);return _dumbo.sql.call(void 0, "SELECT data FROM %I WHERE %s",t,n)},countDocuments:e=>{let n=c(e);return _dumbo.sql.call(void 0, "SELECT COUNT(1) as count FROM %I WHERE %s",t,n)},rename:e=>_dumbo.sql.call(void 0, "ALTER TABLE %I RENAME TO %I",t,e),drop:(e=t)=>_dumbo.sql.call(void 0, "DROP TABLE IF EXISTS %I",e)});var L=t=>{let{connectionString:e,dbName:n,client:o}=t,r=!o,d=_nullishCoalesce(o, () => (_dumbo.getPool.call(void 0, {connectionString:e,database:n})));return{connect:()=>Promise.resolve(),close:()=>r?_dumbo.endPool.call(void 0, {connectionString:e,database:n}):Promise.resolve(),collection:u=>k(u,{dbName:_nullishCoalesce(n, () => (_dumbo.getDatabaseNameOrDefault.call(void 0, e))),poolOrClient:d})}};var C=t=>L(t);var R=t=>{let e=_dumbo.getDatabaseNameOrDefault.call(void 0, t),n=new Map,o=C({connectionString:t});n.set(e,o);let r={connect:async()=>(await o.connect(),r),close:async()=>{for(let d of n.values())await d.close()},db:d=>d?_nullishCoalesce(n.get(d), () => (n.set(d,C({connectionString:t,dbName:d})).get(d))):o};return r};var P= (_class =class{__init() {this.documents=null}__init2() {this.index=0}constructor(e){;_class.prototype.__init.call(this);_class.prototype.__init2.call(this);this.findDocumentsPromise=e}async toArray(){return this.findDocuments()}async forEach(e){let n=await this.findDocuments();for(let o of n)e(o);return Promise.resolve()}hasNext(){if(this.documents===null)throw Error("Error while fetching documents");return this.index<this.documents.length}async next(){let e=await this.findDocuments();return this.hasNext()?_nullishCoalesce(e[this.index++], () => (null)):null}async findDocuments(){return this.documents=await this.findDocumentsPromise,this.documents}}, _class);require('mongodb');var w=class{constructor(e){this.collection=e}get dbName(){return this.collection.dbName}get collectionName(){return this.collection.collectionName}get namespace(){return`${this.dbName}.${this.collectionName}`}get readConcern(){}get readPreference(){}get bsonOptions(){return{}}get writeConcern(){}get hint(){}set hint(e){throw new Error("Method not implemented.")}async insertOne(e,n){let o=await this.collection.insertOne(e);return{acknowledged:o.acknowledged,insertedId:o.insertedId}}async insertMany(e,n){let o=await this.collection.insertMany(e);return{acknowledged:o.acknowledged,insertedIds:o.insertedIds,insertedCount:o.insertedCount}}bulkWrite(e,n){throw new Error("Method not implemented.")}async updateOne(e,n,o){let r=await this.collection.updateOne(e,n);return{acknowledged:r.acknowledged,matchedCount:r.modifiedCount,modifiedCount:r.modifiedCount,upsertedCount:r.modifiedCount,upsertedId:null}}replaceOne(e,n,o){return this.collection.replaceOne(e,n)}async updateMany(e,n,o){let r=await this.collection.updateMany(e,n);return{acknowledged:r.acknowledged,matchedCount:r.modifiedCount,modifiedCount:r.modifiedCount,upsertedCount:r.modifiedCount,upsertedId:null}}async deleteOne(e,n){let o=await this.collection.deleteOne(e);return{acknowledged:o.acknowledged,deletedCount:o.deletedCount}}async deleteMany(e,n){let o=await this.collection.deleteMany(e);return{acknowledged:o.acknowledged,deletedCount:o.deletedCount}}async rename(e,n){return await this.collection.rename(e),this}drop(e){return this.collection.drop()}async findOne(e,n){return this.collection.findOne(e)}find(e,n){return new P(this.collection.find(e))}options(e){throw new Error("Method not implemented.")}isCapped(e){throw new Error("Method not implemented.")}createIndex(e,n){throw new Error("Method not implemented.")}createIndexes(e,n){throw new Error("Method not implemented.")}dropIndex(e,n){throw new Error("Method not implemented.")}dropIndexes(e){throw new Error("Method not implemented.")}listIndexes(e){throw new Error("Method not implemented.")}indexExists(e,n){throw new Error("Method not implemented.")}indexInformation(e){throw new Error("Method not implemented.")}estimatedDocumentCount(e){return this.collection.countDocuments()}countDocuments(e,n){return this.collection.countDocuments(e)}distinct(e,n,o){throw new Error("Method not implemented.")}indexes(e){throw new Error("Method not implemented.")}findOneAndDelete(e,n){return this.collection.findOneAndDelete(e)}findOneAndReplace(e,n,o){return this.collection.findOneAndReplace(e,n)}findOneAndUpdate(e,n,o){return this.collection.findOneAndUpdate(e,n)}aggregate(e,n){throw new Error("Method not implemented.")}watch(e,n){throw new Error("Method not implemented.")}initializeUnorderedBulkOp(e){throw new Error("Method not implemented.")}initializeOrderedBulkOp(e){throw new Error("Method not implemented.")}count(e,n){return this.collection.countDocuments(_nullishCoalesce(e, () => ({})))}listSearchIndexes(e,n){throw new Error("Method not implemented.")}createSearchIndex(e){throw new Error("Method not implemented.")}createSearchIndexes(e){throw new Error("Method not implemented.")}dropSearchIndex(e){throw new Error("Method not implemented.")}updateSearchIndex(e,n){throw new Error("Method not implemented.")}async createCollection(){await this.collection.createCollection()}async handle(e,n){return this.collection.handle(e.toString(),n)}};var I=class{constructor(e){this.pongoDb=e}collection(e){return new w(this.pongoDb.collection(e))}};var _=class{constructor(e){this.pongoClient=R(e)}async connect(){return await this.pongoClient.connect(),this}async close(){await this.pongoClient.close()}db(e){return new I(this.pongoClient.db(e))}};exports.Collection = w; exports.Db = I; exports.FindCursor = P; exports.MongoClient = _; exports.Operators = D; exports.buildIncQuery = Q; exports.buildPushQuery = j; exports.buildSetQuery = U; exports.buildUnsetQuery = N; exports.buildUpdateQuery = h; exports.collectionSQLBuilder = K; exports.constructFilterQuery = c; exports.entries = T; exports.getDbClient = C; exports.handleOperator = O; exports.hasOperators = E; exports.isOperator = M; exports.pongoClient = R; exports.postgresClient = L; exports.postgresCollection = k;
13
+ UPDATE %I SET data = %s FROM cte WHERE %I._id = cte._id`,t,o,t,i,t)},replaceOne:(e,n)=>{let o=c(e);return _dumbo.sql.call(void 0, "UPDATE %I SET data = %L || jsonb_build_object('_id', data->>'_id') WHERE %s",t,JSON.stringify(n),o)},updateMany:(e,n)=>{let o=c(e),i=h(n);return _dumbo.sql.call(void 0, "UPDATE %I SET data = %s WHERE %s",t,i,o)},deleteOne:e=>{let n=c(e);return _dumbo.sql.call(void 0, "DELETE FROM %I WHERE %s",t,n)},deleteMany:e=>{let n=c(e);return _dumbo.sql.call(void 0, "DELETE FROM %I WHERE %s",t,n)},findOne:e=>{let n=c(e);return _dumbo.sql.call(void 0, "SELECT data FROM %I WHERE %s LIMIT 1",t,n)},find:e=>{let n=c(e);return _dumbo.sql.call(void 0, "SELECT data FROM %I WHERE %s",t,n)},countDocuments:e=>{let n=c(e);return _dumbo.sql.call(void 0, "SELECT COUNT(1) as count FROM %I WHERE %s",t,n)},rename:e=>_dumbo.sql.call(void 0, "ALTER TABLE %I RENAME TO %I",t,e),drop:(e=t)=>_dumbo.sql.call(void 0, "DROP TABLE IF EXISTS %I",e)});var L=t=>{let{connectionString:e,dbName:n,client:o}=t,i=!o,d=_nullishCoalesce(o, () => (_dumbo.getPool.call(void 0, {connectionString:e,database:n})));return{connect:()=>Promise.resolve(),close:()=>i?_dumbo.endPool.call(void 0, {connectionString:e,database:n}):Promise.resolve(),collection:a=>k(a,{dbName:_nullishCoalesce(n, () => (_dumbo.getDatabaseNameOrDefault.call(void 0, e))),poolOrClient:d})}};var C=t=>L(t);var R=(t,e={})=>{let n=_dumbo.getDatabaseNameOrDefault.call(void 0, t),o=new Map,i=C({connectionString:t,client:e.client});o.set(n,i);let d={connect:async()=>(await i.connect(),d),close:async()=>{for(let a of o.values())await a.close()},db:a=>a?_nullishCoalesce(o.get(a), () => (o.set(a,C({connectionString:t,dbName:a,client:e.client})).get(a))):i};return d};var P= (_class =class{__init() {this.documents=null}__init2() {this.index=0}constructor(e){;_class.prototype.__init.call(this);_class.prototype.__init2.call(this);this.findDocumentsPromise=e}async toArray(){return this.findDocuments()}async forEach(e){let n=await this.findDocuments();for(let o of n)e(o);return Promise.resolve()}hasNext(){if(this.documents===null)throw Error("Error while fetching documents");return this.index<this.documents.length}async next(){let e=await this.findDocuments();return this.hasNext()?_nullishCoalesce(e[this.index++], () => (null)):null}async findDocuments(){return this.documents=await this.findDocumentsPromise,this.documents}}, _class);require('mongodb');var w=class{constructor(e){this.collection=e}get dbName(){return this.collection.dbName}get collectionName(){return this.collection.collectionName}get namespace(){return`${this.dbName}.${this.collectionName}`}get readConcern(){}get readPreference(){}get bsonOptions(){return{}}get writeConcern(){}get hint(){}set hint(e){throw new Error("Method not implemented.")}async insertOne(e,n){let o=await this.collection.insertOne(e);return{acknowledged:o.acknowledged,insertedId:o.insertedId}}async insertMany(e,n){let o=await this.collection.insertMany(e);return{acknowledged:o.acknowledged,insertedIds:o.insertedIds,insertedCount:o.insertedCount}}bulkWrite(e,n){throw new Error("Method not implemented.")}async updateOne(e,n,o){let i=await this.collection.updateOne(e,n);return{acknowledged:i.acknowledged,matchedCount:i.modifiedCount,modifiedCount:i.modifiedCount,upsertedCount:i.modifiedCount,upsertedId:null}}replaceOne(e,n,o){return this.collection.replaceOne(e,n)}async updateMany(e,n,o){let i=await this.collection.updateMany(e,n);return{acknowledged:i.acknowledged,matchedCount:i.modifiedCount,modifiedCount:i.modifiedCount,upsertedCount:i.modifiedCount,upsertedId:null}}async deleteOne(e,n){let o=await this.collection.deleteOne(e);return{acknowledged:o.acknowledged,deletedCount:o.deletedCount}}async deleteMany(e,n){let o=await this.collection.deleteMany(e);return{acknowledged:o.acknowledged,deletedCount:o.deletedCount}}async rename(e,n){return await this.collection.rename(e),this}drop(e){return this.collection.drop()}async findOne(e,n){return this.collection.findOne(e)}find(e,n){return new P(this.collection.find(e))}options(e){throw new Error("Method not implemented.")}isCapped(e){throw new Error("Method not implemented.")}createIndex(e,n){throw new Error("Method not implemented.")}createIndexes(e,n){throw new Error("Method not implemented.")}dropIndex(e,n){throw new Error("Method not implemented.")}dropIndexes(e){throw new Error("Method not implemented.")}listIndexes(e){throw new Error("Method not implemented.")}indexExists(e,n){throw new Error("Method not implemented.")}indexInformation(e){throw new Error("Method not implemented.")}estimatedDocumentCount(e){return this.collection.countDocuments()}countDocuments(e,n){return this.collection.countDocuments(e)}distinct(e,n,o){throw new Error("Method not implemented.")}indexes(e){throw new Error("Method not implemented.")}findOneAndDelete(e,n){return this.collection.findOneAndDelete(e)}findOneAndReplace(e,n,o){return this.collection.findOneAndReplace(e,n)}findOneAndUpdate(e,n,o){return this.collection.findOneAndUpdate(e,n)}aggregate(e,n){throw new Error("Method not implemented.")}watch(e,n){throw new Error("Method not implemented.")}initializeUnorderedBulkOp(e){throw new Error("Method not implemented.")}initializeOrderedBulkOp(e){throw new Error("Method not implemented.")}count(e,n){return this.collection.countDocuments(_nullishCoalesce(e, () => ({})))}listSearchIndexes(e,n){throw new Error("Method not implemented.")}createSearchIndex(e){throw new Error("Method not implemented.")}createSearchIndexes(e){throw new Error("Method not implemented.")}dropSearchIndex(e){throw new Error("Method not implemented.")}updateSearchIndex(e,n){throw new Error("Method not implemented.")}async createCollection(){await this.collection.createCollection()}async handle(e,n){return this.collection.handle(e.toString(),n)}};var I=class{constructor(e){this.pongoDb=e}collection(e){return new w(this.pongoDb.collection(e))}};var _=class{constructor(e,n={}){this.pongoClient=R(e,n)}async connect(){return await this.pongoClient.connect(),this}async close(){await this.pongoClient.close()}db(e){return new I(this.pongoClient.db(e))}};exports.Collection = w; exports.Db = I; exports.FindCursor = P; exports.MongoClient = _; exports.Operators = D; exports.buildIncQuery = Q; exports.buildPushQuery = j; exports.buildSetQuery = U; exports.buildUnsetQuery = N; exports.buildUpdateQuery = h; exports.collectionSQLBuilder = K; exports.constructFilterQuery = c; exports.entries = T; exports.getDbClient = C; exports.handleOperator = O; exports.hasOperators = E; exports.isOperator = M; exports.pongoClient = R; exports.postgresClient = L; exports.postgresCollection = k;
14
14
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/postgres/client.ts","../src/postgres/postgresCollection.ts","../src/main/typing/entries.ts","../src/postgres/filter/queryOperators.ts","../src/postgres/filter/index.ts","../src/postgres/update/index.ts","../src/main/dbClient.ts","../src/main/pongoClient.ts","../src/mongo/findCursor.ts","../src/mongo/mongoDb.ts","../src/mongo/mongoCollection.ts","../src/mongo/mongoClient.ts"],"names":["endPool","getDatabaseNameOrDefault","getPool","executeSQL","single","sql","format","uuid","entries","obj","key","value","Operators","OperatorMap","isOperator","hasOperators","handleOperator","path","operator","handleIdOperator","buildNestedObject","v","subQuery","subKey","subValue","acc","AND","constructFilterQuery","filter","isRecord","constructComplexFilterQuery","isEquality","nestedKey","val","buildUpdateQuery","update","currentUpdateQuery","op","buildSetQuery","buildUnsetQuery","buildIncQuery","buildPushQuery","set","unset","k","inc","push","postgresCollection","collectionName","dbName","clientOrPool","execute","SqlFor","collectionSQLBuilder","createCollection","collection","document","_id","documents","rows","doc","result","d","existingDoc","replacement","id","handle","byId","existing","newDoc","row","count","newName","values","filterQuery","updateQuery","targetName","postgresClient","options","connectionString","client","managesPoolLifetime","poolOrClient","name","getDbClient","pongoClient","defaultDbName","dbClients","dbClient","db","FindCursor","callback","docs","Collection","_options","_operations","_indexSpec","_indexSpecs","_indexName","_indexes","_key","_filter","_pipeline","_name","_description","_descriptions","_definition","Db","pongoDb","MongoClient"],"mappings":"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","sourcesContent":["import {\n endPool,\n getDatabaseNameOrDefault,\n getPool,\n} from '@event-driven-io/dumbo';\nimport pg from 'pg';\nimport { type DbClient, type PongoDocument } from '../main';\nimport { postgresCollection } from './postgresCollection';\n\nexport type PongoClientOptions = {\n connectionString: string;\n dbName?: string | undefined;\n client?: pg.PoolClient;\n};\n\nexport const postgresClient = (options: PongoClientOptions): DbClient => {\n const { connectionString, dbName, client } = options;\n const managesPoolLifetime = !client;\n const poolOrClient =\n client ?? getPool({ connectionString, database: dbName });\n\n return {\n connect: () => Promise.resolve(),\n close: () =>\n managesPoolLifetime\n ? endPool({ connectionString, database: dbName })\n : Promise.resolve(),\n collection: <T extends PongoDocument>(name: string) =>\n postgresCollection<T>(name, {\n dbName: dbName ?? getDatabaseNameOrDefault(connectionString),\n poolOrClient,\n }),\n };\n};\n","import { executeSQL, single, sql, type SQL } from '@event-driven-io/dumbo';\nimport pg from 'pg';\nimport format from 'pg-format';\nimport { v4 as uuid } from 'uuid';\nimport {\n type DocumentHandler,\n type PongoCollection,\n type PongoDeleteResult,\n type PongoDocument,\n type PongoFilter,\n type PongoInsertManyResult,\n type PongoInsertOneResult,\n type PongoUpdate,\n type PongoUpdateResult,\n type WithId,\n type WithoutId,\n} from '../main';\nimport { constructFilterQuery } from './filter';\nimport { buildUpdateQuery } from './update';\n\nexport const postgresCollection = <T extends PongoDocument>(\n collectionName: string,\n {\n dbName,\n poolOrClient: clientOrPool,\n }: { dbName: string; poolOrClient: pg.Pool | pg.PoolClient },\n): PongoCollection<T> => {\n const execute = <T extends pg.QueryResultRow = pg.QueryResultRow>(sql: SQL) =>\n executeSQL<T>(clientOrPool, sql);\n const SqlFor = collectionSQLBuilder(collectionName);\n\n const createCollection = execute(SqlFor.createCollection());\n\n const collection = {\n dbName,\n collectionName,\n createCollection: async () => {\n await createCollection;\n },\n insertOne: async (document: T): Promise<PongoInsertOneResult> => {\n await createCollection;\n\n const _id = uuid();\n\n const result = await execute(SqlFor.insertOne({ _id, ...document }));\n\n return result.rowCount\n ? { insertedId: _id, acknowledged: true }\n : { insertedId: null, acknowledged: false };\n },\n insertMany: async (documents: T[]): Promise<PongoInsertManyResult> => {\n await createCollection;\n\n const rows = documents.map((doc) => ({\n _id: uuid(),\n ...doc,\n }));\n\n const result = await execute(SqlFor.insertMany(rows));\n\n return {\n acknowledged: result.rowCount === rows.length,\n insertedCount: result.rowCount ?? 0,\n insertedIds: rows.map((d) => d._id),\n };\n },\n updateOne: async (\n filter: PongoFilter<T>,\n update: PongoUpdate<T>,\n ): Promise<PongoUpdateResult> => {\n await createCollection;\n\n const result = await execute(SqlFor.updateOne(filter, update));\n return result.rowCount\n ? { acknowledged: true, modifiedCount: result.rowCount }\n : { acknowledged: false, modifiedCount: 0 };\n },\n replaceOne: async (\n filter: PongoFilter<T>,\n document: WithoutId<T>,\n ): Promise<PongoUpdateResult> => {\n await createCollection;\n\n const result = await execute(SqlFor.replaceOne(filter, document));\n return result.rowCount\n ? { acknowledged: true, modifiedCount: result.rowCount }\n : { acknowledged: false, modifiedCount: 0 };\n },\n updateMany: async (\n filter: PongoFilter<T>,\n update: PongoUpdate<T>,\n ): Promise<PongoUpdateResult> => {\n await createCollection;\n\n const result = await execute(SqlFor.updateMany(filter, update));\n return result.rowCount\n ? { acknowledged: true, modifiedCount: result.rowCount }\n : { acknowledged: false, modifiedCount: 0 };\n },\n deleteOne: async (filter?: PongoFilter<T>): Promise<PongoDeleteResult> => {\n await createCollection;\n\n const result = await execute(SqlFor.deleteOne(filter ?? {}));\n return result.rowCount\n ? { acknowledged: true, deletedCount: result.rowCount }\n : { acknowledged: false, deletedCount: 0 };\n },\n deleteMany: async (filter?: PongoFilter<T>): Promise<PongoDeleteResult> => {\n await createCollection;\n\n const result = await execute(SqlFor.deleteMany(filter ?? {}));\n return result.rowCount\n ? { acknowledged: true, deletedCount: result.rowCount }\n : { acknowledged: false, deletedCount: 0 };\n },\n findOne: async (filter?: PongoFilter<T>): Promise<T | null> => {\n await createCollection;\n\n const result = await execute(SqlFor.findOne(filter ?? {}));\n return (result.rows[0]?.data ?? null) as T | null;\n },\n findOneAndDelete: async (filter: PongoFilter<T>): Promise<T | null> => {\n await createCollection;\n\n const existingDoc = await collection.findOne(filter);\n\n if (existingDoc === null) return null;\n\n await collection.deleteOne(filter);\n return existingDoc;\n },\n findOneAndReplace: async (\n filter: PongoFilter<T>,\n replacement: WithoutId<T>,\n ): Promise<T | null> => {\n await createCollection;\n\n const existingDoc = await collection.findOne(filter);\n\n if (existingDoc === null) return null;\n\n await collection.replaceOne(filter, replacement);\n\n return existingDoc;\n },\n findOneAndUpdate: async (\n filter: PongoFilter<T>,\n update: PongoUpdate<T>,\n ): Promise<T | null> => {\n await createCollection;\n\n const existingDoc = await collection.findOne(filter);\n\n if (existingDoc === null) return null;\n\n await collection.updateOne(filter, update);\n\n return existingDoc;\n },\n handle: async (\n id: string,\n handle: DocumentHandler<T>,\n ): Promise<T | null> => {\n await createCollection;\n\n const byId: PongoFilter<T> = { _id: id };\n\n const existing = await collection.findOne(byId);\n\n const result = await handle(existing);\n\n if (!existing && result) {\n const newDoc = { ...result, _id: id };\n await collection.insertOne({ ...newDoc, _id: id });\n return newDoc;\n }\n\n if (existing && !result) {\n await collection.deleteOne(byId);\n return null;\n }\n\n if (existing && result) await collection.replaceOne(byId, result);\n\n return result;\n },\n find: async (filter?: PongoFilter<T>): Promise<T[]> => {\n await createCollection;\n\n const result = await execute(SqlFor.find(filter ?? {}));\n return result.rows.map((row) => row.data as T);\n },\n countDocuments: async (filter?: PongoFilter<T>): Promise<number> => {\n await createCollection;\n\n const { count } = await single(\n execute<{ count: number }>(SqlFor.countDocuments(filter ?? {})),\n );\n return count;\n },\n drop: async (): Promise<boolean> => {\n await createCollection;\n const result = await execute(SqlFor.drop());\n return (result?.rowCount ?? 0) > 0;\n },\n rename: async (newName: string): Promise<PongoCollection<T>> => {\n await createCollection;\n await execute(SqlFor.rename(newName));\n collectionName = newName;\n return collection;\n },\n };\n\n return collection;\n};\n\nexport const collectionSQLBuilder = (collectionName: string) => ({\n createCollection: (): 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 insertOne: <T>(document: WithId<T>): SQL =>\n sql(\n 'INSERT INTO %I (_id, data) VALUES (%L, %L)',\n collectionName,\n document._id,\n JSON.stringify(document),\n ),\n insertMany: <T>(documents: WithId<T>[]): SQL => {\n const values = documents\n .map((doc) => format('(%L, %L)', doc._id, JSON.stringify(doc)))\n .join(', ');\n return sql('INSERT INTO %I (_id, data) VALUES %s', collectionName, values);\n },\n updateOne: <T>(filter: PongoFilter<T>, update: PongoUpdate<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n const updateQuery = buildUpdateQuery(update);\n\n return sql(\n `WITH cte AS (\n SELECT _id FROM %I WHERE %s LIMIT 1\n )\n UPDATE %I SET data = %s FROM cte WHERE %I._id = cte._id`,\n collectionName,\n filterQuery,\n collectionName,\n updateQuery,\n collectionName,\n );\n },\n replaceOne: <T>(filter: PongoFilter<T>, document: WithoutId<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n\n return sql(\n `UPDATE %I SET data = %L || jsonb_build_object('_id', data->>'_id') WHERE %s`,\n collectionName,\n JSON.stringify(document),\n filterQuery,\n );\n },\n updateMany: <T>(filter: PongoFilter<T>, update: PongoUpdate<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n const updateQuery = buildUpdateQuery(update);\n\n return sql(\n 'UPDATE %I SET data = %s WHERE %s',\n collectionName,\n updateQuery,\n filterQuery,\n );\n },\n deleteOne: <T>(filter: PongoFilter<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n return sql('DELETE FROM %I WHERE %s', collectionName, filterQuery);\n },\n deleteMany: <T>(filter: PongoFilter<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n return sql('DELETE FROM %I WHERE %s', collectionName, filterQuery);\n },\n findOne: <T>(filter: PongoFilter<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n return sql(\n 'SELECT data FROM %I WHERE %s LIMIT 1',\n collectionName,\n filterQuery,\n );\n },\n find: <T>(filter: PongoFilter<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n return sql('SELECT data FROM %I WHERE %s', collectionName, filterQuery);\n },\n countDocuments: <T>(filter: PongoFilter<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n return sql(\n 'SELECT COUNT(1) as count FROM %I WHERE %s',\n collectionName,\n 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","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 entries = <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 format from 'pg-format';\nimport { entries } from '../../main/typing';\n\nexport const Operators = {\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\nconst 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\nexport const handleOperator = (\n path: string,\n operator: string,\n value: unknown,\n): string => {\n if (path === '_id') {\n return handleIdOperator(operator, value);\n }\n\n switch (operator) {\n case '$eq':\n return format(\n `(data @> %L::jsonb OR jsonb_path_exists(data, '$.%s[*] ? (@ == %s)'))`,\n JSON.stringify(buildNestedObject(path, value)),\n path,\n JSON.stringify(value),\n );\n case '$gt':\n case '$gte':\n case '$lt':\n case '$lte':\n case '$ne':\n return format(\n `data #>> %L ${OperatorMap[operator]} %L`,\n `{${path.split('.').join(',')}}`,\n value,\n );\n case '$in':\n return format(\n 'data #>> %L IN (%s)',\n `{${path.split('.').join(',')}}`,\n (value as unknown[]).map((v) => format('%L', v)).join(', '),\n );\n case '$nin':\n return format(\n 'data #>> %L NOT IN (%s)',\n `{${path.split('.').join(',')}}`,\n (value as unknown[]).map((v) => format('%L', v)).join(', '),\n );\n case '$elemMatch': {\n const subQuery = entries(value as Record<string, unknown>)\n .map(([subKey, subValue]) =>\n format(`@.\"%s\" == %s`, subKey, JSON.stringify(subValue)),\n )\n .join(' && ');\n return format(\n `jsonb_path_exists(data, '$.%s[*] ? (%s)')`,\n path,\n subQuery,\n );\n }\n case '$all':\n return format(\n 'data @> %L::jsonb',\n JSON.stringify(buildNestedObject(path, value)),\n );\n case '$size':\n return format(\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 handleIdOperator = (operator: string, value: unknown): string => {\n switch (operator) {\n case '$eq':\n return format(`_id = %L`, value);\n case '$gt':\n case '$gte':\n case '$lt':\n case '$lte':\n case '$ne':\n return format(`_id ${OperatorMap[operator]} %L`, value);\n case '$in':\n return format(\n `_id IN (%s)`,\n (value as unknown[]).map((v) => format('%L', v)).join(', '),\n );\n case '$nin':\n return format(\n `_id NOT IN (%s)`,\n (value as unknown[]).map((v) => format('%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 type { PongoFilter } from '../../main';\nimport { entries } from '../../main/typing';\nimport { Operators, handleOperator, hasOperators } 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 entries(value)\n .map(\n ([nestedKey, val]) =>\n isEquality\n ? handleOperator(`${key}.${nestedKey}`, Operators.$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 { sql, type SQL } from '@event-driven-io/dumbo';\nimport type { $inc, $push, $set, $unset, PongoUpdate } from '../../main';\nimport { entries } from '../../main/typing';\n\nexport const buildUpdateQuery = <T>(update: PongoUpdate<T>): SQL =>\n entries(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, JSON.stringify(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 \"jsonb_set(%s, '{%s}', to_jsonb((data->>'%s')::numeric + %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 JSON.stringify([value]),\n );\n }\n return currentUpdateQuery;\n};\n","import { postgresClient, type PongoClientOptions } from '../postgres';\nimport type { PongoCollection, PongoDocument } from './typing/operations';\n\nexport interface DbClient {\n connect(): Promise<void>;\n close(): Promise<void>;\n collection: <T extends PongoDocument>(name: string) => PongoCollection<T>;\n}\n\nexport const getDbClient = (options: PongoClientOptions): DbClient => {\n // This is the place where in the future could come resolution of other database types\n return postgresClient(options);\n};\n","import { getDatabaseNameOrDefault } from '@event-driven-io/dumbo';\nimport { getDbClient, type DbClient } from './dbClient';\nimport type { PongoClient, PongoDb } from './typing/operations';\n\nexport const pongoClient = (connectionString: string): PongoClient => {\n const defaultDbName = getDatabaseNameOrDefault(connectionString);\n const dbClients: Map<string, DbClient> = new Map();\n\n const dbClient = getDbClient({ connectionString });\n dbClients.set(defaultDbName, 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(dbName, getDbClient({ connectionString, dbName: dbName }))\n .get(dbName)!\n );\n },\n };\n\n return pongoClient;\n};\n","export class FindCursor<T> {\n private findDocumentsPromise: Promise<T[]>;\n private documents: T[] | null = null;\n private index: number = 0;\n\n constructor(documents: Promise<T[]>) {\n this.findDocumentsPromise = documents;\n }\n\n async toArray(): Promise<T[]> {\n return this.findDocuments();\n }\n\n async forEach(callback: (doc: T) => void): Promise<void> {\n const docs = await this.findDocuments();\n\n for (const doc of docs) {\n callback(doc);\n }\n return Promise.resolve();\n }\n\n hasNext(): boolean {\n if (this.documents === null) throw Error('Error while fetching documents');\n return this.index < this.documents.length;\n }\n\n async next(): Promise<T | null> {\n const docs = await this.findDocuments();\n return this.hasNext() ? docs[this.index++] ?? null : null;\n }\n\n private async findDocuments(): Promise<T[]> {\n this.documents = await this.findDocumentsPromise;\n return this.documents;\n }\n}\n","import {\n Collection as MongoCollection,\n ObjectId,\n type Document,\n} from 'mongodb';\nimport type { DocumentHandler, PongoDb } from '../main';\nimport { Collection } from './mongoCollection';\n\nexport class Db {\n constructor(private pongoDb: PongoDb) {}\n\n collection<T extends Document>(\n collectionName: string,\n ): MongoCollection<T> & {\n handle(id: ObjectId, handle: DocumentHandler<T>): Promise<T | null>;\n } {\n return new Collection<T>(this.pongoDb.collection<T>(collectionName));\n }\n}\n","import type {\n AbstractCursorOptions,\n AggregateOptions,\n AggregationCursor,\n AnyBulkWriteOperation,\n BSONSerializeOptions,\n BulkWriteOptions,\n BulkWriteResult,\n ChangeStream,\n ChangeStreamDocument,\n ChangeStreamOptions,\n CommandOperationOptions,\n CountDocumentsOptions,\n CountOptions,\n CreateIndexesOptions,\n DeleteOptions,\n DeleteResult,\n Document,\n DropCollectionOptions,\n EnhancedOmit,\n EstimatedDocumentCountOptions,\n Filter,\n FindOneAndDeleteOptions,\n FindOneAndReplaceOptions,\n FindOneAndUpdateOptions,\n FindOptions,\n Flatten,\n Hint,\n IndexDescription,\n IndexDescriptionCompact,\n IndexDescriptionInfo,\n IndexInformationOptions,\n IndexSpecification,\n InferIdType,\n InsertManyResult,\n InsertOneOptions,\n InsertOneResult,\n ListIndexesCursor,\n ListSearchIndexesCursor,\n ListSearchIndexesOptions,\n ModifyResult,\n Collection as MongoCollection,\n FindCursor as MongoFindCursor,\n ObjectId,\n OperationOptions,\n OptionalUnlessRequiredId,\n OrderedBulkOperation,\n ReadConcern,\n ReadPreference,\n RenameOptions,\n ReplaceOptions,\n SearchIndexDescription,\n UnorderedBulkOperation,\n UpdateFilter,\n UpdateOptions,\n UpdateResult,\n WithId,\n WithoutId,\n WriteConcern,\n} from 'mongodb';\nimport type { Key } from 'readline';\nimport type {\n DocumentHandler,\n PongoCollection,\n PongoFilter,\n PongoUpdate,\n} from '../main';\nimport { FindCursor } from './findCursor';\n\nexport class Collection<T extends Document> implements MongoCollection<T> {\n private collection: PongoCollection<T>;\n\n constructor(collection: PongoCollection<T>) {\n this.collection = collection;\n }\n get dbName(): string {\n return this.collection.dbName;\n }\n get collectionName(): string {\n return this.collection.collectionName;\n }\n get namespace(): string {\n return `${this.dbName}.${this.collectionName}`;\n }\n get readConcern(): ReadConcern | undefined {\n return undefined;\n }\n get readPreference(): ReadPreference | undefined {\n return undefined;\n }\n get bsonOptions(): BSONSerializeOptions {\n return {};\n }\n get writeConcern(): WriteConcern | undefined {\n return undefined;\n }\n get hint(): Hint | undefined {\n return undefined;\n }\n set hint(v: Hint | undefined) {\n throw new Error('Method not implemented.');\n }\n async insertOne(\n doc: OptionalUnlessRequiredId<T>,\n _options?: InsertOneOptions | undefined,\n ): Promise<InsertOneResult<T>> {\n const result = await this.collection.insertOne(doc as T);\n return {\n acknowledged: result.acknowledged,\n insertedId: result.insertedId as unknown as InferIdType<T>,\n };\n }\n async insertMany(\n docs: OptionalUnlessRequiredId<T>[],\n _options?: BulkWriteOptions | undefined,\n ): Promise<InsertManyResult<T>> {\n const result = await this.collection.insertMany(docs as T[]);\n return {\n acknowledged: result.acknowledged,\n insertedIds: result.insertedIds as unknown as InferIdType<T>[],\n insertedCount: result.insertedCount,\n };\n }\n bulkWrite(\n _operations: AnyBulkWriteOperation<T>[],\n _options?: BulkWriteOptions | undefined,\n ): Promise<BulkWriteResult> {\n throw new Error('Method not implemented.');\n }\n async updateOne(\n filter: Filter<T>,\n update: Document[] | UpdateFilter<T>,\n _options?: UpdateOptions | undefined,\n ): Promise<UpdateResult<T>> {\n const result = await this.collection.updateOne(\n filter as unknown as PongoFilter<T>,\n update as unknown as PongoUpdate<T>,\n );\n\n return {\n acknowledged: result.acknowledged,\n matchedCount: result.modifiedCount,\n modifiedCount: result.modifiedCount,\n upsertedCount: result.modifiedCount,\n upsertedId: null,\n };\n }\n replaceOne(\n filter: Filter<T>,\n document: WithoutId<T>,\n _options?: ReplaceOptions | undefined,\n ): Promise<Document | UpdateResult<T>> {\n return this.collection.replaceOne(\n filter as unknown as PongoFilter<T>,\n document,\n );\n }\n async updateMany(\n filter: Filter<T>,\n update: Document[] | UpdateFilter<T>,\n _options?: UpdateOptions | undefined,\n ): Promise<UpdateResult<T>> {\n const result = await this.collection.updateMany(\n filter as unknown as PongoFilter<T>,\n update as unknown as PongoUpdate<T>,\n );\n\n return {\n acknowledged: result.acknowledged,\n matchedCount: result.modifiedCount,\n modifiedCount: result.modifiedCount,\n upsertedCount: result.modifiedCount,\n upsertedId: null,\n };\n }\n async deleteOne(\n filter?: Filter<T> | undefined,\n _options?: DeleteOptions | undefined,\n ): Promise<DeleteResult> {\n const result = await this.collection.deleteOne(filter as PongoFilter<T>);\n\n return {\n acknowledged: result.acknowledged,\n deletedCount: result.deletedCount,\n };\n }\n async deleteMany(\n filter?: Filter<T> | undefined,\n _options?: DeleteOptions | undefined,\n ): Promise<DeleteResult> {\n const result = await this.collection.deleteMany(filter as PongoFilter<T>);\n\n return {\n acknowledged: result.acknowledged,\n deletedCount: result.deletedCount,\n };\n }\n async rename(\n newName: string,\n _options?: RenameOptions | undefined,\n ): Promise<Collection<Document>> {\n await this.collection.rename(newName);\n\n return this as unknown as Collection<Document>;\n }\n drop(_options?: DropCollectionOptions | undefined): Promise<boolean> {\n return this.collection.drop();\n }\n findOne(): Promise<WithId<T> | null>;\n findOne(filter: Filter<T>): Promise<WithId<T> | null>;\n findOne(\n filter: Filter<T>,\n options: FindOptions<Document>,\n ): Promise<WithId<T> | null>;\n findOne<TS = T>(): Promise<TS | null>;\n findOne<TS = T>(filter: Filter<TS>): Promise<TS | null>;\n findOne<TS = T>(\n filter: Filter<TS>,\n options?: FindOptions<Document> | undefined,\n ): Promise<TS | null>;\n async findOne(\n filter?: unknown,\n _options?: unknown,\n ): Promise<import('mongodb').WithId<T> | T | null> {\n return this.collection.findOne(filter as PongoFilter<T>);\n }\n find(): MongoFindCursor<WithId<T>>;\n find(\n filter: Filter<T>,\n options?: FindOptions<Document> | undefined,\n ): MongoFindCursor<WithId<T>>;\n find<T extends Document>(\n filter: Filter<T>,\n options?: FindOptions<Document> | undefined,\n ): MongoFindCursor<T>;\n find(\n filter?: unknown,\n _options?: unknown,\n ): MongoFindCursor<WithId<T>> | MongoFindCursor<T> {\n return new FindCursor(\n this.collection.find(filter as PongoFilter<T>),\n ) as unknown as MongoFindCursor<T>;\n }\n options(_options?: OperationOptions | undefined): Promise<Document> {\n throw new Error('Method not implemented.');\n }\n isCapped(_options?: OperationOptions | undefined): Promise<boolean> {\n throw new Error('Method not implemented.');\n }\n createIndex(\n _indexSpec: IndexSpecification,\n _options?: CreateIndexesOptions | undefined,\n ): Promise<string> {\n throw new Error('Method not implemented.');\n }\n createIndexes(\n _indexSpecs: IndexDescription[],\n _options?: CreateIndexesOptions | undefined,\n ): Promise<string[]> {\n throw new Error('Method not implemented.');\n }\n dropIndex(\n _indexName: string,\n _options?: CommandOperationOptions | undefined,\n ): Promise<Document> {\n throw new Error('Method not implemented.');\n }\n dropIndexes(\n _options?: CommandOperationOptions | undefined,\n ): Promise<boolean> {\n throw new Error('Method not implemented.');\n }\n listIndexes(_options?: AbstractCursorOptions | undefined): ListIndexesCursor {\n throw new Error('Method not implemented.');\n }\n indexExists(\n _indexes: string | string[],\n _options?: AbstractCursorOptions | undefined,\n ): Promise<boolean> {\n throw new Error('Method not implemented.');\n }\n indexInformation(\n options: IndexInformationOptions & { full: true },\n ): Promise<IndexDescriptionInfo[]>;\n indexInformation(\n options: IndexInformationOptions & { full?: false | undefined },\n ): Promise<IndexDescriptionCompact>;\n indexInformation(\n options: IndexInformationOptions,\n ): Promise<IndexDescriptionCompact | IndexDescriptionInfo[]>;\n indexInformation(): Promise<IndexDescriptionCompact>;\n indexInformation(\n _options?: unknown,\n ):\n | Promise<import('mongodb').IndexDescriptionInfo[]>\n | Promise<import('mongodb').IndexDescriptionCompact>\n | Promise<\n | import('mongodb').IndexDescriptionCompact\n | import('mongodb').IndexDescriptionInfo[]\n > {\n throw new Error('Method not implemented.');\n }\n estimatedDocumentCount(\n _options?: EstimatedDocumentCountOptions | undefined,\n ): Promise<number> {\n return this.collection.countDocuments();\n }\n countDocuments(\n filter?: Filter<T> | undefined,\n _options?: CountDocumentsOptions | undefined,\n ): Promise<number> {\n return this.collection.countDocuments(filter as PongoFilter<T>);\n }\n distinct<Key extends '_id' | keyof EnhancedOmit<T, '_id'>>(\n key: Key,\n ): Promise<Flatten<WithId<T>[Key]>[]>;\n distinct<Key extends '_id' | keyof EnhancedOmit<T, '_id'>>(\n key: Key,\n filter: Filter<T>,\n ): Promise<Flatten<WithId<T>[Key]>[]>;\n distinct<Key extends '_id' | keyof EnhancedOmit<T, '_id'>>(\n key: Key,\n filter: Filter<T>,\n options: CommandOperationOptions,\n ): Promise<Flatten<WithId<T>[Key]>[]>;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n distinct(key: string): Promise<any[]>;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n distinct(key: string, filter: Filter<T>): Promise<any[]>;\n distinct(\n key: string,\n filter: Filter<T>,\n options: CommandOperationOptions, // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): Promise<any[]>;\n distinct(\n _key: unknown,\n _filter?: unknown,\n _options?: unknown,\n ): // eslint-disable-next-line @typescript-eslint/no-explicit-any\n | Promise<any[]>\n | Promise<import('mongodb').Flatten<import('mongodb').WithId<T>[Key]>[]> {\n throw new Error('Method not implemented.');\n }\n indexes(\n options: IndexInformationOptions & { full?: true | undefined },\n ): Promise<IndexDescriptionInfo[]>;\n indexes(\n options: IndexInformationOptions & { full: false },\n ): Promise<IndexDescriptionCompact>;\n indexes(\n options: IndexInformationOptions,\n ): Promise<IndexDescriptionCompact | IndexDescriptionInfo[]>;\n indexes(\n options?: AbstractCursorOptions | undefined,\n ): Promise<IndexDescriptionInfo[]>;\n indexes(\n _options?: unknown,\n ):\n | Promise<import('mongodb').IndexDescriptionInfo[]>\n | Promise<import('mongodb').IndexDescriptionCompact>\n | Promise<\n | import('mongodb').IndexDescriptionCompact\n | import('mongodb').IndexDescriptionInfo[]\n > {\n throw new Error('Method not implemented.');\n }\n findOneAndDelete(\n filter: Filter<T>,\n options: FindOneAndDeleteOptions & { includeResultMetadata: true },\n ): Promise<ModifyResult<T>>;\n findOneAndDelete(\n filter: Filter<T>,\n options: FindOneAndDeleteOptions & { includeResultMetadata: false },\n ): Promise<WithId<T> | null>;\n findOneAndDelete(\n filter: Filter<T>,\n options: FindOneAndDeleteOptions,\n ): Promise<WithId<T> | null>;\n findOneAndDelete(filter: Filter<T>): Promise<WithId<T> | null>;\n findOneAndDelete(\n filter: unknown,\n _options?: unknown,\n ): Promise<WithId<T> | null | ModifyResult<T>> {\n return this.collection.findOneAndDelete(\n filter as PongoFilter<T>,\n ) as Promise<WithId<T> | null>;\n }\n findOneAndReplace(\n filter: Filter<T>,\n replacement: WithoutId<T>,\n options: FindOneAndReplaceOptions & { includeResultMetadata: true },\n ): Promise<ModifyResult<T>>;\n findOneAndReplace(\n filter: Filter<T>,\n replacement: WithoutId<T>,\n options: FindOneAndReplaceOptions & { includeResultMetadata: false },\n ): Promise<WithId<T> | null>;\n findOneAndReplace(\n filter: Filter<T>,\n replacement: WithoutId<T>,\n options: FindOneAndReplaceOptions,\n ): Promise<WithId<T> | null>;\n findOneAndReplace(\n filter: Filter<T>,\n replacement: WithoutId<T>,\n ): Promise<WithId<T> | null>;\n findOneAndReplace(\n filter: unknown,\n replacement: unknown,\n _options?: unknown,\n ): Promise<WithId<T> | null | ModifyResult<T>> {\n return this.collection.findOneAndReplace(\n filter as PongoFilter<T>,\n replacement as WithoutId<T>,\n ) as Promise<WithId<T> | null>;\n }\n findOneAndUpdate(\n filter: Filter<T>,\n update: UpdateFilter<T>,\n options: FindOneAndUpdateOptions & { includeResultMetadata: true },\n ): Promise<ModifyResult<T>>;\n findOneAndUpdate(\n filter: Filter<T>,\n update: UpdateFilter<T>,\n options: FindOneAndUpdateOptions & { includeResultMetadata: false },\n ): Promise<WithId<T> | null>;\n findOneAndUpdate(\n filter: Filter<T>,\n update: UpdateFilter<T>,\n options: FindOneAndUpdateOptions,\n ): Promise<WithId<T> | null>;\n findOneAndUpdate(\n filter: Filter<T>,\n update: UpdateFilter<T>,\n ): Promise<WithId<T> | null>;\n findOneAndUpdate(\n filter: unknown,\n update: unknown,\n _options?: unknown,\n ): Promise<WithId<T> | null | ModifyResult<T>> {\n return this.collection.findOneAndUpdate(\n filter as PongoFilter<T>,\n update as PongoUpdate<T>,\n ) as Promise<WithId<T> | null>;\n }\n aggregate<T extends Document = Document>(\n _pipeline?: Document[] | undefined,\n _options?: AggregateOptions | undefined,\n ): AggregationCursor<T> {\n throw new Error('Method not implemented.');\n }\n watch<\n TLocal extends Document = T,\n TChange extends Document = ChangeStreamDocument<TLocal>,\n >(\n _pipeline?: Document[] | undefined,\n _options?: ChangeStreamOptions | undefined,\n ): ChangeStream<TLocal, TChange> {\n throw new Error('Method not implemented.');\n }\n initializeUnorderedBulkOp(\n _options?: BulkWriteOptions | undefined,\n ): UnorderedBulkOperation {\n throw new Error('Method not implemented.');\n }\n initializeOrderedBulkOp(\n _options?: BulkWriteOptions | undefined,\n ): OrderedBulkOperation {\n throw new Error('Method not implemented.');\n }\n count(\n filter?: Filter<T> | undefined,\n _options?: CountOptions | undefined,\n ): Promise<number> {\n return this.collection.countDocuments((filter as PongoFilter<T>) ?? {});\n }\n listSearchIndexes(\n options?: ListSearchIndexesOptions | undefined,\n ): ListSearchIndexesCursor;\n listSearchIndexes(\n name: string,\n options?: ListSearchIndexesOptions | undefined,\n ): ListSearchIndexesCursor;\n listSearchIndexes(\n _name?: unknown,\n _options?: unknown,\n ): import('mongodb').ListSearchIndexesCursor {\n throw new Error('Method not implemented.');\n }\n createSearchIndex(_description: SearchIndexDescription): Promise<string> {\n throw new Error('Method not implemented.');\n }\n createSearchIndexes(\n _descriptions: SearchIndexDescription[],\n ): Promise<string[]> {\n throw new Error('Method not implemented.');\n }\n dropSearchIndex(_name: string): Promise<void> {\n throw new Error('Method not implemented.');\n }\n updateSearchIndex(_name: string, _definition: Document): Promise<void> {\n throw new Error('Method not implemented.');\n }\n\n async createCollection(): Promise<void> {\n await this.collection.createCollection();\n }\n async handle(id: ObjectId, handle: DocumentHandler<T>): Promise<T | null> {\n return this.collection.handle(id.toString(), handle);\n }\n}\n","// src/MongoClientShim.ts\nimport { pongoClient, type PongoClient } from '../main';\nimport { Db } from './mongoDb';\n\nexport class MongoClient {\n private pongoClient: PongoClient;\n\n constructor(connectionString: string) {\n this.pongoClient = pongoClient(connectionString);\n }\n\n async connect() {\n await this.pongoClient.connect();\n return this;\n }\n\n async close() {\n await this.pongoClient.close();\n }\n\n db(dbName?: string): Db {\n return new Db(this.pongoClient.db(dbName));\n }\n}\n"]}
1
+ {"version":3,"sources":["../src/postgres/client.ts","../src/postgres/postgresCollection.ts","../src/main/typing/entries.ts","../src/postgres/filter/queryOperators.ts","../src/postgres/filter/index.ts","../src/postgres/update/index.ts","../src/main/dbClient.ts","../src/main/pongoClient.ts","../src/mongo/findCursor.ts","../src/mongo/mongoClient.ts","../src/mongo/mongoDb.ts","../src/mongo/mongoCollection.ts"],"names":["endPool","getDatabaseNameOrDefault","getPool","executeSQL","single","sql","format","uuid","entries","obj","key","value","Operators","OperatorMap","isOperator","hasOperators","handleOperator","path","operator","handleIdOperator","buildNestedObject","v","subQuery","subKey","subValue","acc","AND","constructFilterQuery","filter","isRecord","constructComplexFilterQuery","isEquality","nestedKey","val","buildUpdateQuery","update","currentUpdateQuery","op","buildSetQuery","buildUnsetQuery","buildIncQuery","buildPushQuery","set","unset","k","inc","push","postgresCollection","collectionName","dbName","clientOrPool","execute","SqlFor","collectionSQLBuilder","createCollection","collection","document","_id","documents","rows","doc","result","d","existingDoc","replacement","id","handle","byId","existing","newDoc","row","count","newName","values","filterQuery","updateQuery","targetName","postgresClient","options","connectionString","client","managesPoolLifetime","poolOrClient","name","getDbClient","pongoClient","defaultDbName","dbClients","dbClient","db","FindCursor","callback","docs","Collection","_options","_operations","_indexSpec","_indexSpecs","_indexName","_indexes","_key","_filter","_pipeline","_name","_description","_descriptions","_definition","Db","pongoDb","MongoClient"],"mappings":"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","sourcesContent":["import {\n endPool,\n getDatabaseNameOrDefault,\n getPool,\n} from '@event-driven-io/dumbo';\nimport pg from 'pg';\nimport { type DbClient, type PongoDocument } from '../main';\nimport { postgresCollection } from './postgresCollection';\n\nexport type PongoClientOptions = {\n connectionString: string;\n dbName?: string | undefined;\n client?: pg.PoolClient | undefined;\n};\n\nexport const postgresClient = (options: PongoClientOptions): DbClient => {\n const { connectionString, dbName, client } = options;\n const managesPoolLifetime = !client;\n const poolOrClient =\n client ?? getPool({ connectionString, database: dbName });\n\n return {\n connect: () => Promise.resolve(),\n close: () =>\n managesPoolLifetime\n ? endPool({ connectionString, database: dbName })\n : Promise.resolve(),\n collection: <T extends PongoDocument>(name: string) =>\n postgresCollection<T>(name, {\n dbName: dbName ?? getDatabaseNameOrDefault(connectionString),\n poolOrClient,\n }),\n };\n};\n","import { executeSQL, single, sql, type SQL } from '@event-driven-io/dumbo';\nimport pg from 'pg';\nimport format from 'pg-format';\nimport { v4 as uuid } from 'uuid';\nimport {\n type DocumentHandler,\n type PongoCollection,\n type PongoDeleteResult,\n type PongoDocument,\n type PongoFilter,\n type PongoInsertManyResult,\n type PongoInsertOneResult,\n type PongoUpdate,\n type PongoUpdateResult,\n type WithId,\n type WithoutId,\n} from '../main';\nimport { constructFilterQuery } from './filter';\nimport { buildUpdateQuery } from './update';\n\nexport const postgresCollection = <T extends PongoDocument>(\n collectionName: string,\n {\n dbName,\n poolOrClient: clientOrPool,\n }: { dbName: string; poolOrClient: pg.Pool | pg.PoolClient },\n): PongoCollection<T> => {\n const execute = <T extends pg.QueryResultRow = pg.QueryResultRow>(sql: SQL) =>\n executeSQL<T>(clientOrPool, sql);\n const SqlFor = collectionSQLBuilder(collectionName);\n\n const createCollection = execute(SqlFor.createCollection());\n\n const collection = {\n dbName,\n collectionName,\n createCollection: async () => {\n await createCollection;\n },\n insertOne: async (document: T): Promise<PongoInsertOneResult> => {\n await createCollection;\n\n const _id = uuid();\n\n const result = await execute(SqlFor.insertOne({ _id, ...document }));\n\n return result.rowCount\n ? { insertedId: _id, acknowledged: true }\n : { insertedId: null, acknowledged: false };\n },\n insertMany: async (documents: T[]): Promise<PongoInsertManyResult> => {\n await createCollection;\n\n const rows = documents.map((doc) => ({\n _id: uuid(),\n ...doc,\n }));\n\n const result = await execute(SqlFor.insertMany(rows));\n\n return {\n acknowledged: result.rowCount === rows.length,\n insertedCount: result.rowCount ?? 0,\n insertedIds: rows.map((d) => d._id),\n };\n },\n updateOne: async (\n filter: PongoFilter<T>,\n update: PongoUpdate<T>,\n ): Promise<PongoUpdateResult> => {\n await createCollection;\n\n const result = await execute(SqlFor.updateOne(filter, update));\n return result.rowCount\n ? { acknowledged: true, modifiedCount: result.rowCount }\n : { acknowledged: false, modifiedCount: 0 };\n },\n replaceOne: async (\n filter: PongoFilter<T>,\n document: WithoutId<T>,\n ): Promise<PongoUpdateResult> => {\n await createCollection;\n\n const result = await execute(SqlFor.replaceOne(filter, document));\n return result.rowCount\n ? { acknowledged: true, modifiedCount: result.rowCount }\n : { acknowledged: false, modifiedCount: 0 };\n },\n updateMany: async (\n filter: PongoFilter<T>,\n update: PongoUpdate<T>,\n ): Promise<PongoUpdateResult> => {\n await createCollection;\n\n const result = await execute(SqlFor.updateMany(filter, update));\n return result.rowCount\n ? { acknowledged: true, modifiedCount: result.rowCount }\n : { acknowledged: false, modifiedCount: 0 };\n },\n deleteOne: async (filter?: PongoFilter<T>): Promise<PongoDeleteResult> => {\n await createCollection;\n\n const result = await execute(SqlFor.deleteOne(filter ?? {}));\n return result.rowCount\n ? { acknowledged: true, deletedCount: result.rowCount }\n : { acknowledged: false, deletedCount: 0 };\n },\n deleteMany: async (filter?: PongoFilter<T>): Promise<PongoDeleteResult> => {\n await createCollection;\n\n const result = await execute(SqlFor.deleteMany(filter ?? {}));\n return result.rowCount\n ? { acknowledged: true, deletedCount: result.rowCount }\n : { acknowledged: false, deletedCount: 0 };\n },\n findOne: async (filter?: PongoFilter<T>): Promise<T | null> => {\n await createCollection;\n\n const result = await execute(SqlFor.findOne(filter ?? {}));\n return (result.rows[0]?.data ?? null) as T | null;\n },\n findOneAndDelete: async (filter: PongoFilter<T>): Promise<T | null> => {\n await createCollection;\n\n const existingDoc = await collection.findOne(filter);\n\n if (existingDoc === null) return null;\n\n await collection.deleteOne(filter);\n return existingDoc;\n },\n findOneAndReplace: async (\n filter: PongoFilter<T>,\n replacement: WithoutId<T>,\n ): Promise<T | null> => {\n await createCollection;\n\n const existingDoc = await collection.findOne(filter);\n\n if (existingDoc === null) return null;\n\n await collection.replaceOne(filter, replacement);\n\n return existingDoc;\n },\n findOneAndUpdate: async (\n filter: PongoFilter<T>,\n update: PongoUpdate<T>,\n ): Promise<T | null> => {\n await createCollection;\n\n const existingDoc = await collection.findOne(filter);\n\n if (existingDoc === null) return null;\n\n await collection.updateOne(filter, update);\n\n return existingDoc;\n },\n handle: async (\n id: string,\n handle: DocumentHandler<T>,\n ): Promise<T | null> => {\n await createCollection;\n\n const byId: PongoFilter<T> = { _id: id };\n\n const existing = await collection.findOne(byId);\n\n const result = await handle(existing);\n\n if (!existing && result) {\n const newDoc = { ...result, _id: id };\n await collection.insertOne({ ...newDoc, _id: id });\n return newDoc;\n }\n\n if (existing && !result) {\n await collection.deleteOne(byId);\n return null;\n }\n\n if (existing && result) await collection.replaceOne(byId, result);\n\n return result;\n },\n find: async (filter?: PongoFilter<T>): Promise<T[]> => {\n await createCollection;\n\n const result = await execute(SqlFor.find(filter ?? {}));\n return result.rows.map((row) => row.data as T);\n },\n countDocuments: async (filter?: PongoFilter<T>): Promise<number> => {\n await createCollection;\n\n const { count } = await single(\n execute<{ count: number }>(SqlFor.countDocuments(filter ?? {})),\n );\n return count;\n },\n drop: async (): Promise<boolean> => {\n await createCollection;\n const result = await execute(SqlFor.drop());\n return (result?.rowCount ?? 0) > 0;\n },\n rename: async (newName: string): Promise<PongoCollection<T>> => {\n await createCollection;\n await execute(SqlFor.rename(newName));\n collectionName = newName;\n return collection;\n },\n };\n\n return collection;\n};\n\nexport const collectionSQLBuilder = (collectionName: string) => ({\n createCollection: (): 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 insertOne: <T>(document: WithId<T>): SQL =>\n sql(\n 'INSERT INTO %I (_id, data) VALUES (%L, %L)',\n collectionName,\n document._id,\n JSON.stringify(document),\n ),\n insertMany: <T>(documents: WithId<T>[]): SQL => {\n const values = documents\n .map((doc) => format('(%L, %L)', doc._id, JSON.stringify(doc)))\n .join(', ');\n return sql('INSERT INTO %I (_id, data) VALUES %s', collectionName, values);\n },\n updateOne: <T>(filter: PongoFilter<T>, update: PongoUpdate<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n const updateQuery = buildUpdateQuery(update);\n\n return sql(\n `WITH cte AS (\n SELECT _id FROM %I WHERE %s LIMIT 1\n )\n UPDATE %I SET data = %s FROM cte WHERE %I._id = cte._id`,\n collectionName,\n filterQuery,\n collectionName,\n updateQuery,\n collectionName,\n );\n },\n replaceOne: <T>(filter: PongoFilter<T>, document: WithoutId<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n\n return sql(\n `UPDATE %I SET data = %L || jsonb_build_object('_id', data->>'_id') WHERE %s`,\n collectionName,\n JSON.stringify(document),\n filterQuery,\n );\n },\n updateMany: <T>(filter: PongoFilter<T>, update: PongoUpdate<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n const updateQuery = buildUpdateQuery(update);\n\n return sql(\n 'UPDATE %I SET data = %s WHERE %s',\n collectionName,\n updateQuery,\n filterQuery,\n );\n },\n deleteOne: <T>(filter: PongoFilter<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n return sql('DELETE FROM %I WHERE %s', collectionName, filterQuery);\n },\n deleteMany: <T>(filter: PongoFilter<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n return sql('DELETE FROM %I WHERE %s', collectionName, filterQuery);\n },\n findOne: <T>(filter: PongoFilter<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n return sql(\n 'SELECT data FROM %I WHERE %s LIMIT 1',\n collectionName,\n filterQuery,\n );\n },\n find: <T>(filter: PongoFilter<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n return sql('SELECT data FROM %I WHERE %s', collectionName, filterQuery);\n },\n countDocuments: <T>(filter: PongoFilter<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n return sql(\n 'SELECT COUNT(1) as count FROM %I WHERE %s',\n collectionName,\n 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","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 entries = <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 format from 'pg-format';\nimport { entries } from '../../main/typing';\n\nexport const Operators = {\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\nconst 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\nexport const handleOperator = (\n path: string,\n operator: string,\n value: unknown,\n): string => {\n if (path === '_id') {\n return handleIdOperator(operator, value);\n }\n\n switch (operator) {\n case '$eq':\n return format(\n `(data @> %L::jsonb OR jsonb_path_exists(data, '$.%s[*] ? (@ == %s)'))`,\n JSON.stringify(buildNestedObject(path, value)),\n path,\n JSON.stringify(value),\n );\n case '$gt':\n case '$gte':\n case '$lt':\n case '$lte':\n case '$ne':\n return format(\n `data #>> %L ${OperatorMap[operator]} %L`,\n `{${path.split('.').join(',')}}`,\n value,\n );\n case '$in':\n return format(\n 'data #>> %L IN (%s)',\n `{${path.split('.').join(',')}}`,\n (value as unknown[]).map((v) => format('%L', v)).join(', '),\n );\n case '$nin':\n return format(\n 'data #>> %L NOT IN (%s)',\n `{${path.split('.').join(',')}}`,\n (value as unknown[]).map((v) => format('%L', v)).join(', '),\n );\n case '$elemMatch': {\n const subQuery = entries(value as Record<string, unknown>)\n .map(([subKey, subValue]) =>\n format(`@.\"%s\" == %s`, subKey, JSON.stringify(subValue)),\n )\n .join(' && ');\n return format(\n `jsonb_path_exists(data, '$.%s[*] ? (%s)')`,\n path,\n subQuery,\n );\n }\n case '$all':\n return format(\n 'data @> %L::jsonb',\n JSON.stringify(buildNestedObject(path, value)),\n );\n case '$size':\n return format(\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 handleIdOperator = (operator: string, value: unknown): string => {\n switch (operator) {\n case '$eq':\n return format(`_id = %L`, value);\n case '$gt':\n case '$gte':\n case '$lt':\n case '$lte':\n case '$ne':\n return format(`_id ${OperatorMap[operator]} %L`, value);\n case '$in':\n return format(\n `_id IN (%s)`,\n (value as unknown[]).map((v) => format('%L', v)).join(', '),\n );\n case '$nin':\n return format(\n `_id NOT IN (%s)`,\n (value as unknown[]).map((v) => format('%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 type { PongoFilter } from '../../main';\nimport { entries } from '../../main/typing';\nimport { Operators, handleOperator, hasOperators } 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 entries(value)\n .map(\n ([nestedKey, val]) =>\n isEquality\n ? handleOperator(`${key}.${nestedKey}`, Operators.$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 { sql, type SQL } from '@event-driven-io/dumbo';\nimport type { $inc, $push, $set, $unset, PongoUpdate } from '../../main';\nimport { entries } from '../../main/typing';\n\nexport const buildUpdateQuery = <T>(update: PongoUpdate<T>): SQL =>\n entries(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, JSON.stringify(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 \"jsonb_set(%s, '{%s}', to_jsonb((data->>'%s')::numeric + %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 JSON.stringify([value]),\n );\n }\n return currentUpdateQuery;\n};\n","import { postgresClient, type PongoClientOptions } from '../postgres';\nimport type { PongoCollection, PongoDocument } from './typing/operations';\n\nexport interface DbClient {\n connect(): Promise<void>;\n close(): Promise<void>;\n collection: <T extends PongoDocument>(name: string) => PongoCollection<T>;\n}\n\nexport const getDbClient = (options: PongoClientOptions): DbClient => {\n // This is the place where in the future could come resolution of other database types\n return postgresClient(options);\n};\n","import { getDatabaseNameOrDefault } from '@event-driven-io/dumbo';\nimport pg from 'pg';\nimport { getDbClient, type DbClient } from './dbClient';\nimport type { PongoClient, PongoDb } from './typing/operations';\n\nexport const pongoClient = (\n connectionString: string,\n options: { client?: pg.PoolClient } = {},\n): PongoClient => {\n const defaultDbName = getDatabaseNameOrDefault(connectionString);\n const dbClients: Map<string, DbClient> = new Map();\n\n const dbClient = getDbClient({ connectionString, client: options.client });\n dbClients.set(defaultDbName, 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 getDbClient({\n connectionString,\n dbName: dbName,\n client: options.client,\n }),\n )\n .get(dbName)!\n );\n },\n };\n\n return pongoClient;\n};\n","export class FindCursor<T> {\n private findDocumentsPromise: Promise<T[]>;\n private documents: T[] | null = null;\n private index: number = 0;\n\n constructor(documents: Promise<T[]>) {\n this.findDocumentsPromise = documents;\n }\n\n async toArray(): Promise<T[]> {\n return this.findDocuments();\n }\n\n async forEach(callback: (doc: T) => void): Promise<void> {\n const docs = await this.findDocuments();\n\n for (const doc of docs) {\n callback(doc);\n }\n return Promise.resolve();\n }\n\n hasNext(): boolean {\n if (this.documents === null) throw Error('Error while fetching documents');\n return this.index < this.documents.length;\n }\n\n async next(): Promise<T | null> {\n const docs = await this.findDocuments();\n return this.hasNext() ? docs[this.index++] ?? null : null;\n }\n\n private async findDocuments(): Promise<T[]> {\n this.documents = await this.findDocumentsPromise;\n return this.documents;\n }\n}\n","// src/MongoClientShim.ts\nimport pg from 'pg';\nimport { pongoClient, type PongoClient } from '../main';\nimport { Db } from './mongoDb';\n\nexport class MongoClient {\n private pongoClient: PongoClient;\n\n constructor(\n connectionString: string,\n options: { client?: pg.PoolClient } = {},\n ) {\n this.pongoClient = pongoClient(connectionString, options);\n }\n\n async connect() {\n await this.pongoClient.connect();\n return this;\n }\n\n async close() {\n await this.pongoClient.close();\n }\n\n db(dbName?: string): Db {\n return new Db(this.pongoClient.db(dbName));\n }\n}\n","import {\n Collection as MongoCollection,\n ObjectId,\n type Document,\n} from 'mongodb';\nimport type { DocumentHandler, PongoDb } from '../main';\nimport { Collection } from './mongoCollection';\n\nexport class Db {\n constructor(private pongoDb: PongoDb) {}\n\n collection<T extends Document>(\n collectionName: string,\n ): MongoCollection<T> & {\n handle(id: ObjectId, handle: DocumentHandler<T>): Promise<T | null>;\n } {\n return new Collection<T>(this.pongoDb.collection<T>(collectionName));\n }\n}\n","import type {\n AbstractCursorOptions,\n AggregateOptions,\n AggregationCursor,\n AnyBulkWriteOperation,\n BSONSerializeOptions,\n BulkWriteOptions,\n BulkWriteResult,\n ChangeStream,\n ChangeStreamDocument,\n ChangeStreamOptions,\n CommandOperationOptions,\n CountDocumentsOptions,\n CountOptions,\n CreateIndexesOptions,\n DeleteOptions,\n DeleteResult,\n Document,\n DropCollectionOptions,\n EnhancedOmit,\n EstimatedDocumentCountOptions,\n Filter,\n FindOneAndDeleteOptions,\n FindOneAndReplaceOptions,\n FindOneAndUpdateOptions,\n FindOptions,\n Flatten,\n Hint,\n IndexDescription,\n IndexDescriptionCompact,\n IndexDescriptionInfo,\n IndexInformationOptions,\n IndexSpecification,\n InferIdType,\n InsertManyResult,\n InsertOneOptions,\n InsertOneResult,\n ListIndexesCursor,\n ListSearchIndexesCursor,\n ListSearchIndexesOptions,\n ModifyResult,\n Collection as MongoCollection,\n FindCursor as MongoFindCursor,\n ObjectId,\n OperationOptions,\n OptionalUnlessRequiredId,\n OrderedBulkOperation,\n ReadConcern,\n ReadPreference,\n RenameOptions,\n ReplaceOptions,\n SearchIndexDescription,\n UnorderedBulkOperation,\n UpdateFilter,\n UpdateOptions,\n UpdateResult,\n WithId,\n WithoutId,\n WriteConcern,\n} from 'mongodb';\nimport type { Key } from 'readline';\nimport type {\n DocumentHandler,\n PongoCollection,\n PongoFilter,\n PongoUpdate,\n} from '../main';\nimport { FindCursor } from './findCursor';\n\nexport class Collection<T extends Document> implements MongoCollection<T> {\n private collection: PongoCollection<T>;\n\n constructor(collection: PongoCollection<T>) {\n this.collection = collection;\n }\n get dbName(): string {\n return this.collection.dbName;\n }\n get collectionName(): string {\n return this.collection.collectionName;\n }\n get namespace(): string {\n return `${this.dbName}.${this.collectionName}`;\n }\n get readConcern(): ReadConcern | undefined {\n return undefined;\n }\n get readPreference(): ReadPreference | undefined {\n return undefined;\n }\n get bsonOptions(): BSONSerializeOptions {\n return {};\n }\n get writeConcern(): WriteConcern | undefined {\n return undefined;\n }\n get hint(): Hint | undefined {\n return undefined;\n }\n set hint(v: Hint | undefined) {\n throw new Error('Method not implemented.');\n }\n async insertOne(\n doc: OptionalUnlessRequiredId<T>,\n _options?: InsertOneOptions | undefined,\n ): Promise<InsertOneResult<T>> {\n const result = await this.collection.insertOne(doc as T);\n return {\n acknowledged: result.acknowledged,\n insertedId: result.insertedId as unknown as InferIdType<T>,\n };\n }\n async insertMany(\n docs: OptionalUnlessRequiredId<T>[],\n _options?: BulkWriteOptions | undefined,\n ): Promise<InsertManyResult<T>> {\n const result = await this.collection.insertMany(docs as T[]);\n return {\n acknowledged: result.acknowledged,\n insertedIds: result.insertedIds as unknown as InferIdType<T>[],\n insertedCount: result.insertedCount,\n };\n }\n bulkWrite(\n _operations: AnyBulkWriteOperation<T>[],\n _options?: BulkWriteOptions | undefined,\n ): Promise<BulkWriteResult> {\n throw new Error('Method not implemented.');\n }\n async updateOne(\n filter: Filter<T>,\n update: Document[] | UpdateFilter<T>,\n _options?: UpdateOptions | undefined,\n ): Promise<UpdateResult<T>> {\n const result = await this.collection.updateOne(\n filter as unknown as PongoFilter<T>,\n update as unknown as PongoUpdate<T>,\n );\n\n return {\n acknowledged: result.acknowledged,\n matchedCount: result.modifiedCount,\n modifiedCount: result.modifiedCount,\n upsertedCount: result.modifiedCount,\n upsertedId: null,\n };\n }\n replaceOne(\n filter: Filter<T>,\n document: WithoutId<T>,\n _options?: ReplaceOptions | undefined,\n ): Promise<Document | UpdateResult<T>> {\n return this.collection.replaceOne(\n filter as unknown as PongoFilter<T>,\n document,\n );\n }\n async updateMany(\n filter: Filter<T>,\n update: Document[] | UpdateFilter<T>,\n _options?: UpdateOptions | undefined,\n ): Promise<UpdateResult<T>> {\n const result = await this.collection.updateMany(\n filter as unknown as PongoFilter<T>,\n update as unknown as PongoUpdate<T>,\n );\n\n return {\n acknowledged: result.acknowledged,\n matchedCount: result.modifiedCount,\n modifiedCount: result.modifiedCount,\n upsertedCount: result.modifiedCount,\n upsertedId: null,\n };\n }\n async deleteOne(\n filter?: Filter<T> | undefined,\n _options?: DeleteOptions | undefined,\n ): Promise<DeleteResult> {\n const result = await this.collection.deleteOne(filter as PongoFilter<T>);\n\n return {\n acknowledged: result.acknowledged,\n deletedCount: result.deletedCount,\n };\n }\n async deleteMany(\n filter?: Filter<T> | undefined,\n _options?: DeleteOptions | undefined,\n ): Promise<DeleteResult> {\n const result = await this.collection.deleteMany(filter as PongoFilter<T>);\n\n return {\n acknowledged: result.acknowledged,\n deletedCount: result.deletedCount,\n };\n }\n async rename(\n newName: string,\n _options?: RenameOptions | undefined,\n ): Promise<Collection<Document>> {\n await this.collection.rename(newName);\n\n return this as unknown as Collection<Document>;\n }\n drop(_options?: DropCollectionOptions | undefined): Promise<boolean> {\n return this.collection.drop();\n }\n findOne(): Promise<WithId<T> | null>;\n findOne(filter: Filter<T>): Promise<WithId<T> | null>;\n findOne(\n filter: Filter<T>,\n options: FindOptions<Document>,\n ): Promise<WithId<T> | null>;\n findOne<TS = T>(): Promise<TS | null>;\n findOne<TS = T>(filter: Filter<TS>): Promise<TS | null>;\n findOne<TS = T>(\n filter: Filter<TS>,\n options?: FindOptions<Document> | undefined,\n ): Promise<TS | null>;\n async findOne(\n filter?: unknown,\n _options?: unknown,\n ): Promise<import('mongodb').WithId<T> | T | null> {\n return this.collection.findOne(filter as PongoFilter<T>);\n }\n find(): MongoFindCursor<WithId<T>>;\n find(\n filter: Filter<T>,\n options?: FindOptions<Document> | undefined,\n ): MongoFindCursor<WithId<T>>;\n find<T extends Document>(\n filter: Filter<T>,\n options?: FindOptions<Document> | undefined,\n ): MongoFindCursor<T>;\n find(\n filter?: unknown,\n _options?: unknown,\n ): MongoFindCursor<WithId<T>> | MongoFindCursor<T> {\n return new FindCursor(\n this.collection.find(filter as PongoFilter<T>),\n ) as unknown as MongoFindCursor<T>;\n }\n options(_options?: OperationOptions | undefined): Promise<Document> {\n throw new Error('Method not implemented.');\n }\n isCapped(_options?: OperationOptions | undefined): Promise<boolean> {\n throw new Error('Method not implemented.');\n }\n createIndex(\n _indexSpec: IndexSpecification,\n _options?: CreateIndexesOptions | undefined,\n ): Promise<string> {\n throw new Error('Method not implemented.');\n }\n createIndexes(\n _indexSpecs: IndexDescription[],\n _options?: CreateIndexesOptions | undefined,\n ): Promise<string[]> {\n throw new Error('Method not implemented.');\n }\n dropIndex(\n _indexName: string,\n _options?: CommandOperationOptions | undefined,\n ): Promise<Document> {\n throw new Error('Method not implemented.');\n }\n dropIndexes(\n _options?: CommandOperationOptions | undefined,\n ): Promise<boolean> {\n throw new Error('Method not implemented.');\n }\n listIndexes(_options?: AbstractCursorOptions | undefined): ListIndexesCursor {\n throw new Error('Method not implemented.');\n }\n indexExists(\n _indexes: string | string[],\n _options?: AbstractCursorOptions | undefined,\n ): Promise<boolean> {\n throw new Error('Method not implemented.');\n }\n indexInformation(\n options: IndexInformationOptions & { full: true },\n ): Promise<IndexDescriptionInfo[]>;\n indexInformation(\n options: IndexInformationOptions & { full?: false | undefined },\n ): Promise<IndexDescriptionCompact>;\n indexInformation(\n options: IndexInformationOptions,\n ): Promise<IndexDescriptionCompact | IndexDescriptionInfo[]>;\n indexInformation(): Promise<IndexDescriptionCompact>;\n indexInformation(\n _options?: unknown,\n ):\n | Promise<import('mongodb').IndexDescriptionInfo[]>\n | Promise<import('mongodb').IndexDescriptionCompact>\n | Promise<\n | import('mongodb').IndexDescriptionCompact\n | import('mongodb').IndexDescriptionInfo[]\n > {\n throw new Error('Method not implemented.');\n }\n estimatedDocumentCount(\n _options?: EstimatedDocumentCountOptions | undefined,\n ): Promise<number> {\n return this.collection.countDocuments();\n }\n countDocuments(\n filter?: Filter<T> | undefined,\n _options?: CountDocumentsOptions | undefined,\n ): Promise<number> {\n return this.collection.countDocuments(filter as PongoFilter<T>);\n }\n distinct<Key extends '_id' | keyof EnhancedOmit<T, '_id'>>(\n key: Key,\n ): Promise<Flatten<WithId<T>[Key]>[]>;\n distinct<Key extends '_id' | keyof EnhancedOmit<T, '_id'>>(\n key: Key,\n filter: Filter<T>,\n ): Promise<Flatten<WithId<T>[Key]>[]>;\n distinct<Key extends '_id' | keyof EnhancedOmit<T, '_id'>>(\n key: Key,\n filter: Filter<T>,\n options: CommandOperationOptions,\n ): Promise<Flatten<WithId<T>[Key]>[]>;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n distinct(key: string): Promise<any[]>;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n distinct(key: string, filter: Filter<T>): Promise<any[]>;\n distinct(\n key: string,\n filter: Filter<T>,\n options: CommandOperationOptions, // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): Promise<any[]>;\n distinct(\n _key: unknown,\n _filter?: unknown,\n _options?: unknown,\n ): // eslint-disable-next-line @typescript-eslint/no-explicit-any\n | Promise<any[]>\n | Promise<import('mongodb').Flatten<import('mongodb').WithId<T>[Key]>[]> {\n throw new Error('Method not implemented.');\n }\n indexes(\n options: IndexInformationOptions & { full?: true | undefined },\n ): Promise<IndexDescriptionInfo[]>;\n indexes(\n options: IndexInformationOptions & { full: false },\n ): Promise<IndexDescriptionCompact>;\n indexes(\n options: IndexInformationOptions,\n ): Promise<IndexDescriptionCompact | IndexDescriptionInfo[]>;\n indexes(\n options?: AbstractCursorOptions | undefined,\n ): Promise<IndexDescriptionInfo[]>;\n indexes(\n _options?: unknown,\n ):\n | Promise<import('mongodb').IndexDescriptionInfo[]>\n | Promise<import('mongodb').IndexDescriptionCompact>\n | Promise<\n | import('mongodb').IndexDescriptionCompact\n | import('mongodb').IndexDescriptionInfo[]\n > {\n throw new Error('Method not implemented.');\n }\n findOneAndDelete(\n filter: Filter<T>,\n options: FindOneAndDeleteOptions & { includeResultMetadata: true },\n ): Promise<ModifyResult<T>>;\n findOneAndDelete(\n filter: Filter<T>,\n options: FindOneAndDeleteOptions & { includeResultMetadata: false },\n ): Promise<WithId<T> | null>;\n findOneAndDelete(\n filter: Filter<T>,\n options: FindOneAndDeleteOptions,\n ): Promise<WithId<T> | null>;\n findOneAndDelete(filter: Filter<T>): Promise<WithId<T> | null>;\n findOneAndDelete(\n filter: unknown,\n _options?: unknown,\n ): Promise<WithId<T> | null | ModifyResult<T>> {\n return this.collection.findOneAndDelete(\n filter as PongoFilter<T>,\n ) as Promise<WithId<T> | null>;\n }\n findOneAndReplace(\n filter: Filter<T>,\n replacement: WithoutId<T>,\n options: FindOneAndReplaceOptions & { includeResultMetadata: true },\n ): Promise<ModifyResult<T>>;\n findOneAndReplace(\n filter: Filter<T>,\n replacement: WithoutId<T>,\n options: FindOneAndReplaceOptions & { includeResultMetadata: false },\n ): Promise<WithId<T> | null>;\n findOneAndReplace(\n filter: Filter<T>,\n replacement: WithoutId<T>,\n options: FindOneAndReplaceOptions,\n ): Promise<WithId<T> | null>;\n findOneAndReplace(\n filter: Filter<T>,\n replacement: WithoutId<T>,\n ): Promise<WithId<T> | null>;\n findOneAndReplace(\n filter: unknown,\n replacement: unknown,\n _options?: unknown,\n ): Promise<WithId<T> | null | ModifyResult<T>> {\n return this.collection.findOneAndReplace(\n filter as PongoFilter<T>,\n replacement as WithoutId<T>,\n ) as Promise<WithId<T> | null>;\n }\n findOneAndUpdate(\n filter: Filter<T>,\n update: UpdateFilter<T>,\n options: FindOneAndUpdateOptions & { includeResultMetadata: true },\n ): Promise<ModifyResult<T>>;\n findOneAndUpdate(\n filter: Filter<T>,\n update: UpdateFilter<T>,\n options: FindOneAndUpdateOptions & { includeResultMetadata: false },\n ): Promise<WithId<T> | null>;\n findOneAndUpdate(\n filter: Filter<T>,\n update: UpdateFilter<T>,\n options: FindOneAndUpdateOptions,\n ): Promise<WithId<T> | null>;\n findOneAndUpdate(\n filter: Filter<T>,\n update: UpdateFilter<T>,\n ): Promise<WithId<T> | null>;\n findOneAndUpdate(\n filter: unknown,\n update: unknown,\n _options?: unknown,\n ): Promise<WithId<T> | null | ModifyResult<T>> {\n return this.collection.findOneAndUpdate(\n filter as PongoFilter<T>,\n update as PongoUpdate<T>,\n ) as Promise<WithId<T> | null>;\n }\n aggregate<T extends Document = Document>(\n _pipeline?: Document[] | undefined,\n _options?: AggregateOptions | undefined,\n ): AggregationCursor<T> {\n throw new Error('Method not implemented.');\n }\n watch<\n TLocal extends Document = T,\n TChange extends Document = ChangeStreamDocument<TLocal>,\n >(\n _pipeline?: Document[] | undefined,\n _options?: ChangeStreamOptions | undefined,\n ): ChangeStream<TLocal, TChange> {\n throw new Error('Method not implemented.');\n }\n initializeUnorderedBulkOp(\n _options?: BulkWriteOptions | undefined,\n ): UnorderedBulkOperation {\n throw new Error('Method not implemented.');\n }\n initializeOrderedBulkOp(\n _options?: BulkWriteOptions | undefined,\n ): OrderedBulkOperation {\n throw new Error('Method not implemented.');\n }\n count(\n filter?: Filter<T> | undefined,\n _options?: CountOptions | undefined,\n ): Promise<number> {\n return this.collection.countDocuments((filter as PongoFilter<T>) ?? {});\n }\n listSearchIndexes(\n options?: ListSearchIndexesOptions | undefined,\n ): ListSearchIndexesCursor;\n listSearchIndexes(\n name: string,\n options?: ListSearchIndexesOptions | undefined,\n ): ListSearchIndexesCursor;\n listSearchIndexes(\n _name?: unknown,\n _options?: unknown,\n ): import('mongodb').ListSearchIndexesCursor {\n throw new Error('Method not implemented.');\n }\n createSearchIndex(_description: SearchIndexDescription): Promise<string> {\n throw new Error('Method not implemented.');\n }\n createSearchIndexes(\n _descriptions: SearchIndexDescription[],\n ): Promise<string[]> {\n throw new Error('Method not implemented.');\n }\n dropSearchIndex(_name: string): Promise<void> {\n throw new Error('Method not implemented.');\n }\n updateSearchIndex(_name: string, _definition: Document): Promise<void> {\n throw new Error('Method not implemented.');\n }\n\n async createCollection(): Promise<void> {\n await this.collection.createCollection();\n }\n async handle(id: ObjectId, handle: DocumentHandler<T>): Promise<T | null> {\n return this.collection.handle(id.toString(), handle);\n }\n}\n"]}
package/dist/index.d.cts CHANGED
@@ -5,7 +5,7 @@ import { SQL } from '@event-driven-io/dumbo';
5
5
  type PongoClientOptions = {
6
6
  connectionString: string;
7
7
  dbName?: string | undefined;
8
- client?: pg.PoolClient;
8
+ client?: pg.PoolClient | undefined;
9
9
  };
10
10
  declare const postgresClient: (options: PongoClientOptions) => DbClient;
11
11
 
@@ -152,7 +152,9 @@ interface DbClient {
152
152
  }
153
153
  declare const getDbClient: (options: PongoClientOptions) => DbClient;
154
154
 
155
- declare const pongoClient: (connectionString: string) => PongoClient;
155
+ declare const pongoClient: (connectionString: string, options?: {
156
+ client?: pg.PoolClient;
157
+ }) => PongoClient;
156
158
 
157
159
  type Entry<T> = {
158
160
  [K in keyof Required<T>]: [K, Required<T>[K]];
@@ -187,7 +189,9 @@ declare class Db {
187
189
 
188
190
  declare class MongoClient {
189
191
  private pongoClient;
190
- constructor(connectionString: string);
192
+ constructor(connectionString: string, options?: {
193
+ client?: pg.PoolClient;
194
+ });
191
195
  connect(): Promise<this>;
192
196
  close(): Promise<void>;
193
197
  db(dbName?: string): Db;
package/dist/index.d.ts CHANGED
@@ -5,7 +5,7 @@ import { SQL } from '@event-driven-io/dumbo';
5
5
  type PongoClientOptions = {
6
6
  connectionString: string;
7
7
  dbName?: string | undefined;
8
- client?: pg.PoolClient;
8
+ client?: pg.PoolClient | undefined;
9
9
  };
10
10
  declare const postgresClient: (options: PongoClientOptions) => DbClient;
11
11
 
@@ -152,7 +152,9 @@ interface DbClient {
152
152
  }
153
153
  declare const getDbClient: (options: PongoClientOptions) => DbClient;
154
154
 
155
- declare const pongoClient: (connectionString: string) => PongoClient;
155
+ declare const pongoClient: (connectionString: string, options?: {
156
+ client?: pg.PoolClient;
157
+ }) => PongoClient;
156
158
 
157
159
  type Entry<T> = {
158
160
  [K in keyof Required<T>]: [K, Required<T>[K]];
@@ -187,7 +189,9 @@ declare class Db {
187
189
 
188
190
  declare class MongoClient {
189
191
  private pongoClient;
190
- constructor(connectionString: string);
192
+ constructor(connectionString: string, options?: {
193
+ client?: pg.PoolClient;
194
+ });
191
195
  connect(): Promise<this>;
192
196
  close(): Promise<void>;
193
197
  db(dbName?: string): Db;
package/dist/index.js CHANGED
@@ -1,4 +1,4 @@
1
- import{endPool as J,getDatabaseNameOrDefault as v,getPool as z}from"@event-driven-io/dumbo";import"pg";import{executeSQL as B,single as H,sql as p}from"@event-driven-io/dumbo";import"pg";import q from"pg-format";import{v4 as S}from"uuid";var T=t=>Object.entries(t).map(([e,n])=>[e,n]);import l from"pg-format";var D={$eq:"$eq",$gt:"$gt",$gte:"$gte",$lt:"$lt",$lte:"$lte",$ne:"$ne",$in:"$in",$nin:"$nin",$elemMatch:"$elemMatch",$all:"$all",$size:"$size"},F={$gt:">",$gte:">=",$lt:"<",$lte:"<=",$ne:"!="},M=t=>t.startsWith("$"),E=t=>Object.keys(t).some(M),O=(t,e,n)=>{if(t==="_id")return $(e,n);switch(e){case"$eq":return l("(data @> %L::jsonb OR jsonb_path_exists(data, '$.%s[*] ? (@ == %s)'))",JSON.stringify(x(t,n)),t,JSON.stringify(n));case"$gt":case"$gte":case"$lt":case"$lte":case"$ne":return l(`data #>> %L ${F[e]} %L`,`{${t.split(".").join(",")}}`,n);case"$in":return l("data #>> %L IN (%s)",`{${t.split(".").join(",")}}`,n.map(o=>l("%L",o)).join(", "));case"$nin":return l("data #>> %L NOT IN (%s)",`{${t.split(".").join(",")}}`,n.map(o=>l("%L",o)).join(", "));case"$elemMatch":{let o=T(n).map(([r,d])=>l('@."%s" == %s',r,JSON.stringify(d))).join(" && ");return l("jsonb_path_exists(data, '$.%s[*] ? (%s)')",t,o)}case"$all":return l("data @> %L::jsonb",JSON.stringify(x(t,n)));case"$size":return l("jsonb_array_length(data #> %L) = %L",`{${t.split(".").join(",")}}`,n);default:throw new Error(`Unsupported operator: ${e}`)}},$=(t,e)=>{switch(t){case"$eq":return l("_id = %L",e);case"$gt":case"$gte":case"$lt":case"$lte":case"$ne":return l(`_id ${F[t]} %L`,e);case"$in":return l("_id IN (%s)",e.map(n=>l("%L",n)).join(", "));case"$nin":return l("_id NOT IN (%s)",e.map(n=>l("%L",n)).join(", "));default:throw new Error(`Unsupported operator: ${t}`)}},x=(t,e)=>t.split(".").reverse().reduce((n,o)=>({[o]:n}),e);var b="AND",c=t=>Object.entries(t).map(([e,n])=>W(n)?A(e,n):O(e,"$eq",n)).join(` ${b} `),A=(t,e)=>{let n=!E(e);return T(e).map(([o,r])=>n?O(`${t}.${o}`,D.$eq,r):O(t,o,r)).join(` ${b} `)},W=t=>t!==null&&typeof t=="object"&&!Array.isArray(t);import{sql as g}from"@event-driven-io/dumbo";var h=t=>T(t).reduce((e,[n,o])=>{switch(n){case"$set":return U(o,e);case"$unset":return N(o,e);case"$inc":return Q(o,e);case"$push":return j(o,e);default:return e}},g("data")),U=(t,e)=>g("%s || %L::jsonb",e,JSON.stringify(t)),N=(t,e)=>g("%s - %L",e,Object.keys(t).map(n=>`{${n}}`).join(", ")),Q=(t,e)=>{for(let[n,o]of Object.entries(t))e=g("jsonb_set(%s, '{%s}', to_jsonb((data->>'%s')::numeric + %L), true)",e,n,n,o);return e},j=(t,e)=>{for(let[n,o]of Object.entries(t))e=g("jsonb_set(%s, '{%s}', (coalesce(data->'%s', '[]'::jsonb) || %L::jsonb), true)",e,n,n,JSON.stringify([o]));return e};var k=(t,{dbName:e,poolOrClient:n})=>{let o=i=>B(n,i),r=K(t),d=o(r.createCollection()),u={dbName:e,collectionName:t,createCollection:async()=>{await d},insertOne:async i=>{await d;let s=S();return(await o(r.insertOne({_id:s,...i}))).rowCount?{insertedId:s,acknowledged:!0}:{insertedId:null,acknowledged:!1}},insertMany:async i=>{await d;let s=i.map(m=>({_id:S(),...m})),a=await o(r.insertMany(s));return{acknowledged:a.rowCount===s.length,insertedCount:a.rowCount??0,insertedIds:s.map(m=>m._id)}},updateOne:async(i,s)=>{await d;let a=await o(r.updateOne(i,s));return a.rowCount?{acknowledged:!0,modifiedCount:a.rowCount}:{acknowledged:!1,modifiedCount:0}},replaceOne:async(i,s)=>{await d;let a=await o(r.replaceOne(i,s));return a.rowCount?{acknowledged:!0,modifiedCount:a.rowCount}:{acknowledged:!1,modifiedCount:0}},updateMany:async(i,s)=>{await d;let a=await o(r.updateMany(i,s));return a.rowCount?{acknowledged:!0,modifiedCount:a.rowCount}:{acknowledged:!1,modifiedCount:0}},deleteOne:async i=>{await d;let s=await o(r.deleteOne(i??{}));return s.rowCount?{acknowledged:!0,deletedCount:s.rowCount}:{acknowledged:!1,deletedCount:0}},deleteMany:async i=>{await d;let s=await o(r.deleteMany(i??{}));return s.rowCount?{acknowledged:!0,deletedCount:s.rowCount}:{acknowledged:!1,deletedCount:0}},findOne:async i=>(await d,(await o(r.findOne(i??{}))).rows[0]?.data??null),findOneAndDelete:async i=>{await d;let s=await u.findOne(i);return s===null?null:(await u.deleteOne(i),s)},findOneAndReplace:async(i,s)=>{await d;let a=await u.findOne(i);return a===null?null:(await u.replaceOne(i,s),a)},findOneAndUpdate:async(i,s)=>{await d;let a=await u.findOne(i);return a===null?null:(await u.updateOne(i,s),a)},handle:async(i,s)=>{await d;let a={_id:i},m=await u.findOne(a),f=await s(m);if(!m&&f){let y={...f,_id:i};return await u.insertOne({...y,_id:i}),y}return m&&!f?(await u.deleteOne(a),null):(m&&f&&await u.replaceOne(a,f),f)},find:async i=>(await d,(await o(r.find(i??{}))).rows.map(a=>a.data)),countDocuments:async i=>{await d;let{count:s}=await H(o(r.countDocuments(i??{})));return s},drop:async()=>(await d,((await o(r.drop()))?.rowCount??0)>0),rename:async i=>(await d,await o(r.rename(i)),t=i,u)};return u},K=t=>({createCollection:()=>p(`CREATE TABLE IF NOT EXISTS %I (
1
+ import{endPool as J,getDatabaseNameOrDefault as v,getPool as z}from"@event-driven-io/dumbo";import"pg";import{executeSQL as B,single as H,sql as p}from"@event-driven-io/dumbo";import"pg";import q from"pg-format";import{v4 as S}from"uuid";var T=t=>Object.entries(t).map(([e,n])=>[e,n]);import u from"pg-format";var D={$eq:"$eq",$gt:"$gt",$gte:"$gte",$lt:"$lt",$lte:"$lte",$ne:"$ne",$in:"$in",$nin:"$nin",$elemMatch:"$elemMatch",$all:"$all",$size:"$size"},F={$gt:">",$gte:">=",$lt:"<",$lte:"<=",$ne:"!="},M=t=>t.startsWith("$"),E=t=>Object.keys(t).some(M),O=(t,e,n)=>{if(t==="_id")return $(e,n);switch(e){case"$eq":return u("(data @> %L::jsonb OR jsonb_path_exists(data, '$.%s[*] ? (@ == %s)'))",JSON.stringify(x(t,n)),t,JSON.stringify(n));case"$gt":case"$gte":case"$lt":case"$lte":case"$ne":return u(`data #>> %L ${F[e]} %L`,`{${t.split(".").join(",")}}`,n);case"$in":return u("data #>> %L IN (%s)",`{${t.split(".").join(",")}}`,n.map(o=>u("%L",o)).join(", "));case"$nin":return u("data #>> %L NOT IN (%s)",`{${t.split(".").join(",")}}`,n.map(o=>u("%L",o)).join(", "));case"$elemMatch":{let o=T(n).map(([i,d])=>u('@."%s" == %s',i,JSON.stringify(d))).join(" && ");return u("jsonb_path_exists(data, '$.%s[*] ? (%s)')",t,o)}case"$all":return u("data @> %L::jsonb",JSON.stringify(x(t,n)));case"$size":return u("jsonb_array_length(data #> %L) = %L",`{${t.split(".").join(",")}}`,n);default:throw new Error(`Unsupported operator: ${e}`)}},$=(t,e)=>{switch(t){case"$eq":return u("_id = %L",e);case"$gt":case"$gte":case"$lt":case"$lte":case"$ne":return u(`_id ${F[t]} %L`,e);case"$in":return u("_id IN (%s)",e.map(n=>u("%L",n)).join(", "));case"$nin":return u("_id NOT IN (%s)",e.map(n=>u("%L",n)).join(", "));default:throw new Error(`Unsupported operator: ${t}`)}},x=(t,e)=>t.split(".").reverse().reduce((n,o)=>({[o]:n}),e);var b="AND",c=t=>Object.entries(t).map(([e,n])=>W(n)?A(e,n):O(e,"$eq",n)).join(` ${b} `),A=(t,e)=>{let n=!E(e);return T(e).map(([o,i])=>n?O(`${t}.${o}`,D.$eq,i):O(t,o,i)).join(` ${b} `)},W=t=>t!==null&&typeof t=="object"&&!Array.isArray(t);import{sql as g}from"@event-driven-io/dumbo";var h=t=>T(t).reduce((e,[n,o])=>{switch(n){case"$set":return U(o,e);case"$unset":return N(o,e);case"$inc":return Q(o,e);case"$push":return j(o,e);default:return e}},g("data")),U=(t,e)=>g("%s || %L::jsonb",e,JSON.stringify(t)),N=(t,e)=>g("%s - %L",e,Object.keys(t).map(n=>`{${n}}`).join(", ")),Q=(t,e)=>{for(let[n,o]of Object.entries(t))e=g("jsonb_set(%s, '{%s}', to_jsonb((data->>'%s')::numeric + %L), true)",e,n,n,o);return e},j=(t,e)=>{for(let[n,o]of Object.entries(t))e=g("jsonb_set(%s, '{%s}', (coalesce(data->'%s', '[]'::jsonb) || %L::jsonb), true)",e,n,n,JSON.stringify([o]));return e};var k=(t,{dbName:e,poolOrClient:n})=>{let o=r=>B(n,r),i=K(t),d=o(i.createCollection()),a={dbName:e,collectionName:t,createCollection:async()=>{await d},insertOne:async r=>{await d;let s=S();return(await o(i.insertOne({_id:s,...r}))).rowCount?{insertedId:s,acknowledged:!0}:{insertedId:null,acknowledged:!1}},insertMany:async r=>{await d;let s=r.map(m=>({_id:S(),...m})),l=await o(i.insertMany(s));return{acknowledged:l.rowCount===s.length,insertedCount:l.rowCount??0,insertedIds:s.map(m=>m._id)}},updateOne:async(r,s)=>{await d;let l=await o(i.updateOne(r,s));return l.rowCount?{acknowledged:!0,modifiedCount:l.rowCount}:{acknowledged:!1,modifiedCount:0}},replaceOne:async(r,s)=>{await d;let l=await o(i.replaceOne(r,s));return l.rowCount?{acknowledged:!0,modifiedCount:l.rowCount}:{acknowledged:!1,modifiedCount:0}},updateMany:async(r,s)=>{await d;let l=await o(i.updateMany(r,s));return l.rowCount?{acknowledged:!0,modifiedCount:l.rowCount}:{acknowledged:!1,modifiedCount:0}},deleteOne:async r=>{await d;let s=await o(i.deleteOne(r??{}));return s.rowCount?{acknowledged:!0,deletedCount:s.rowCount}:{acknowledged:!1,deletedCount:0}},deleteMany:async r=>{await d;let s=await o(i.deleteMany(r??{}));return s.rowCount?{acknowledged:!0,deletedCount:s.rowCount}:{acknowledged:!1,deletedCount:0}},findOne:async r=>(await d,(await o(i.findOne(r??{}))).rows[0]?.data??null),findOneAndDelete:async r=>{await d;let s=await a.findOne(r);return s===null?null:(await a.deleteOne(r),s)},findOneAndReplace:async(r,s)=>{await d;let l=await a.findOne(r);return l===null?null:(await a.replaceOne(r,s),l)},findOneAndUpdate:async(r,s)=>{await d;let l=await a.findOne(r);return l===null?null:(await a.updateOne(r,s),l)},handle:async(r,s)=>{await d;let l={_id:r},m=await a.findOne(l),f=await s(m);if(!m&&f){let y={...f,_id:r};return await a.insertOne({...y,_id:r}),y}return m&&!f?(await a.deleteOne(l),null):(m&&f&&await a.replaceOne(l,f),f)},find:async r=>(await d,(await o(i.find(r??{}))).rows.map(l=>l.data)),countDocuments:async r=>{await d;let{count:s}=await H(o(i.countDocuments(r??{})));return s},drop:async()=>(await d,((await o(i.drop()))?.rowCount??0)>0),rename:async r=>(await d,await o(i.rename(r)),t=r,a)};return a},K=t=>({createCollection:()=>p(`CREATE TABLE IF NOT EXISTS %I (
2
2
  _id TEXT PRIMARY KEY,
3
3
  data JSONB NOT NULL,
4
4
  metadata JSONB NOT NULL DEFAULT '{}',
@@ -7,8 +7,8 @@ import{endPool as J,getDatabaseNameOrDefault as v,getPool as z}from"@event-drive
7
7
  _archived BOOLEAN NOT NULL DEFAULT FALSE,
8
8
  _created TIMESTAMPTZ NOT NULL DEFAULT now(),
9
9
  _updated TIMESTAMPTZ NOT NULL DEFAULT now()
10
- )`,t),insertOne:e=>p("INSERT INTO %I (_id, data) VALUES (%L, %L)",t,e._id,JSON.stringify(e)),insertMany:e=>{let n=e.map(o=>q("(%L, %L)",o._id,JSON.stringify(o))).join(", ");return p("INSERT INTO %I (_id, data) VALUES %s",t,n)},updateOne:(e,n)=>{let o=c(e),r=h(n);return p(`WITH cte AS (
10
+ )`,t),insertOne:e=>p("INSERT INTO %I (_id, data) VALUES (%L, %L)",t,e._id,JSON.stringify(e)),insertMany:e=>{let n=e.map(o=>q("(%L, %L)",o._id,JSON.stringify(o))).join(", ");return p("INSERT INTO %I (_id, data) VALUES %s",t,n)},updateOne:(e,n)=>{let o=c(e),i=h(n);return p(`WITH cte AS (
11
11
  SELECT _id FROM %I WHERE %s LIMIT 1
12
12
  )
13
- UPDATE %I SET data = %s FROM cte WHERE %I._id = cte._id`,t,o,t,r,t)},replaceOne:(e,n)=>{let o=c(e);return p("UPDATE %I SET data = %L || jsonb_build_object('_id', data->>'_id') WHERE %s",t,JSON.stringify(n),o)},updateMany:(e,n)=>{let o=c(e),r=h(n);return p("UPDATE %I SET data = %s WHERE %s",t,r,o)},deleteOne:e=>{let n=c(e);return p("DELETE FROM %I WHERE %s",t,n)},deleteMany:e=>{let n=c(e);return p("DELETE FROM %I WHERE %s",t,n)},findOne:e=>{let n=c(e);return p("SELECT data FROM %I WHERE %s LIMIT 1",t,n)},find:e=>{let n=c(e);return p("SELECT data FROM %I WHERE %s",t,n)},countDocuments:e=>{let n=c(e);return p("SELECT COUNT(1) as count FROM %I WHERE %s",t,n)},rename:e=>p("ALTER TABLE %I RENAME TO %I",t,e),drop:(e=t)=>p("DROP TABLE IF EXISTS %I",e)});var L=t=>{let{connectionString:e,dbName:n,client:o}=t,r=!o,d=o??z({connectionString:e,database:n});return{connect:()=>Promise.resolve(),close:()=>r?J({connectionString:e,database:n}):Promise.resolve(),collection:u=>k(u,{dbName:n??v(e),poolOrClient:d})}};var C=t=>L(t);import{getDatabaseNameOrDefault as X}from"@event-driven-io/dumbo";var R=t=>{let e=X(t),n=new Map,o=C({connectionString:t});n.set(e,o);let r={connect:async()=>(await o.connect(),r),close:async()=>{for(let d of n.values())await d.close()},db:d=>d?n.get(d)??n.set(d,C({connectionString:t,dbName:d})).get(d):o};return r};var P=class{findDocumentsPromise;documents=null;index=0;constructor(e){this.findDocumentsPromise=e}async toArray(){return this.findDocuments()}async forEach(e){let n=await this.findDocuments();for(let o of n)e(o);return Promise.resolve()}hasNext(){if(this.documents===null)throw Error("Error while fetching documents");return this.index<this.documents.length}async next(){let e=await this.findDocuments();return this.hasNext()?e[this.index++]??null:null}async findDocuments(){return this.documents=await this.findDocumentsPromise,this.documents}};import"mongodb";var w=class{collection;constructor(e){this.collection=e}get dbName(){return this.collection.dbName}get collectionName(){return this.collection.collectionName}get namespace(){return`${this.dbName}.${this.collectionName}`}get readConcern(){}get readPreference(){}get bsonOptions(){return{}}get writeConcern(){}get hint(){}set hint(e){throw new Error("Method not implemented.")}async insertOne(e,n){let o=await this.collection.insertOne(e);return{acknowledged:o.acknowledged,insertedId:o.insertedId}}async insertMany(e,n){let o=await this.collection.insertMany(e);return{acknowledged:o.acknowledged,insertedIds:o.insertedIds,insertedCount:o.insertedCount}}bulkWrite(e,n){throw new Error("Method not implemented.")}async updateOne(e,n,o){let r=await this.collection.updateOne(e,n);return{acknowledged:r.acknowledged,matchedCount:r.modifiedCount,modifiedCount:r.modifiedCount,upsertedCount:r.modifiedCount,upsertedId:null}}replaceOne(e,n,o){return this.collection.replaceOne(e,n)}async updateMany(e,n,o){let r=await this.collection.updateMany(e,n);return{acknowledged:r.acknowledged,matchedCount:r.modifiedCount,modifiedCount:r.modifiedCount,upsertedCount:r.modifiedCount,upsertedId:null}}async deleteOne(e,n){let o=await this.collection.deleteOne(e);return{acknowledged:o.acknowledged,deletedCount:o.deletedCount}}async deleteMany(e,n){let o=await this.collection.deleteMany(e);return{acknowledged:o.acknowledged,deletedCount:o.deletedCount}}async rename(e,n){return await this.collection.rename(e),this}drop(e){return this.collection.drop()}async findOne(e,n){return this.collection.findOne(e)}find(e,n){return new P(this.collection.find(e))}options(e){throw new Error("Method not implemented.")}isCapped(e){throw new Error("Method not implemented.")}createIndex(e,n){throw new Error("Method not implemented.")}createIndexes(e,n){throw new Error("Method not implemented.")}dropIndex(e,n){throw new Error("Method not implemented.")}dropIndexes(e){throw new Error("Method not implemented.")}listIndexes(e){throw new Error("Method not implemented.")}indexExists(e,n){throw new Error("Method not implemented.")}indexInformation(e){throw new Error("Method not implemented.")}estimatedDocumentCount(e){return this.collection.countDocuments()}countDocuments(e,n){return this.collection.countDocuments(e)}distinct(e,n,o){throw new Error("Method not implemented.")}indexes(e){throw new Error("Method not implemented.")}findOneAndDelete(e,n){return this.collection.findOneAndDelete(e)}findOneAndReplace(e,n,o){return this.collection.findOneAndReplace(e,n)}findOneAndUpdate(e,n,o){return this.collection.findOneAndUpdate(e,n)}aggregate(e,n){throw new Error("Method not implemented.")}watch(e,n){throw new Error("Method not implemented.")}initializeUnorderedBulkOp(e){throw new Error("Method not implemented.")}initializeOrderedBulkOp(e){throw new Error("Method not implemented.")}count(e,n){return this.collection.countDocuments(e??{})}listSearchIndexes(e,n){throw new Error("Method not implemented.")}createSearchIndex(e){throw new Error("Method not implemented.")}createSearchIndexes(e){throw new Error("Method not implemented.")}dropSearchIndex(e){throw new Error("Method not implemented.")}updateSearchIndex(e,n){throw new Error("Method not implemented.")}async createCollection(){await this.collection.createCollection()}async handle(e,n){return this.collection.handle(e.toString(),n)}};var I=class{constructor(e){this.pongoDb=e}collection(e){return new w(this.pongoDb.collection(e))}};var _=class{pongoClient;constructor(e){this.pongoClient=R(e)}async connect(){return await this.pongoClient.connect(),this}async close(){await this.pongoClient.close()}db(e){return new I(this.pongoClient.db(e))}};export{w as Collection,I as Db,P as FindCursor,_ as MongoClient,D as Operators,Q as buildIncQuery,j as buildPushQuery,U as buildSetQuery,N as buildUnsetQuery,h as buildUpdateQuery,K as collectionSQLBuilder,c as constructFilterQuery,T as entries,C as getDbClient,O as handleOperator,E as hasOperators,M as isOperator,R as pongoClient,L as postgresClient,k as postgresCollection};
13
+ UPDATE %I SET data = %s FROM cte WHERE %I._id = cte._id`,t,o,t,i,t)},replaceOne:(e,n)=>{let o=c(e);return p("UPDATE %I SET data = %L || jsonb_build_object('_id', data->>'_id') WHERE %s",t,JSON.stringify(n),o)},updateMany:(e,n)=>{let o=c(e),i=h(n);return p("UPDATE %I SET data = %s WHERE %s",t,i,o)},deleteOne:e=>{let n=c(e);return p("DELETE FROM %I WHERE %s",t,n)},deleteMany:e=>{let n=c(e);return p("DELETE FROM %I WHERE %s",t,n)},findOne:e=>{let n=c(e);return p("SELECT data FROM %I WHERE %s LIMIT 1",t,n)},find:e=>{let n=c(e);return p("SELECT data FROM %I WHERE %s",t,n)},countDocuments:e=>{let n=c(e);return p("SELECT COUNT(1) as count FROM %I WHERE %s",t,n)},rename:e=>p("ALTER TABLE %I RENAME TO %I",t,e),drop:(e=t)=>p("DROP TABLE IF EXISTS %I",e)});var L=t=>{let{connectionString:e,dbName:n,client:o}=t,i=!o,d=o??z({connectionString:e,database:n});return{connect:()=>Promise.resolve(),close:()=>i?J({connectionString:e,database:n}):Promise.resolve(),collection:a=>k(a,{dbName:n??v(e),poolOrClient:d})}};var C=t=>L(t);import{getDatabaseNameOrDefault as X}from"@event-driven-io/dumbo";import"pg";var R=(t,e={})=>{let n=X(t),o=new Map,i=C({connectionString:t,client:e.client});o.set(n,i);let d={connect:async()=>(await i.connect(),d),close:async()=>{for(let a of o.values())await a.close()},db:a=>a?o.get(a)??o.set(a,C({connectionString:t,dbName:a,client:e.client})).get(a):i};return d};var P=class{findDocumentsPromise;documents=null;index=0;constructor(e){this.findDocumentsPromise=e}async toArray(){return this.findDocuments()}async forEach(e){let n=await this.findDocuments();for(let o of n)e(o);return Promise.resolve()}hasNext(){if(this.documents===null)throw Error("Error while fetching documents");return this.index<this.documents.length}async next(){let e=await this.findDocuments();return this.hasNext()?e[this.index++]??null:null}async findDocuments(){return this.documents=await this.findDocumentsPromise,this.documents}};import"pg";import"mongodb";var w=class{collection;constructor(e){this.collection=e}get dbName(){return this.collection.dbName}get collectionName(){return this.collection.collectionName}get namespace(){return`${this.dbName}.${this.collectionName}`}get readConcern(){}get readPreference(){}get bsonOptions(){return{}}get writeConcern(){}get hint(){}set hint(e){throw new Error("Method not implemented.")}async insertOne(e,n){let o=await this.collection.insertOne(e);return{acknowledged:o.acknowledged,insertedId:o.insertedId}}async insertMany(e,n){let o=await this.collection.insertMany(e);return{acknowledged:o.acknowledged,insertedIds:o.insertedIds,insertedCount:o.insertedCount}}bulkWrite(e,n){throw new Error("Method not implemented.")}async updateOne(e,n,o){let i=await this.collection.updateOne(e,n);return{acknowledged:i.acknowledged,matchedCount:i.modifiedCount,modifiedCount:i.modifiedCount,upsertedCount:i.modifiedCount,upsertedId:null}}replaceOne(e,n,o){return this.collection.replaceOne(e,n)}async updateMany(e,n,o){let i=await this.collection.updateMany(e,n);return{acknowledged:i.acknowledged,matchedCount:i.modifiedCount,modifiedCount:i.modifiedCount,upsertedCount:i.modifiedCount,upsertedId:null}}async deleteOne(e,n){let o=await this.collection.deleteOne(e);return{acknowledged:o.acknowledged,deletedCount:o.deletedCount}}async deleteMany(e,n){let o=await this.collection.deleteMany(e);return{acknowledged:o.acknowledged,deletedCount:o.deletedCount}}async rename(e,n){return await this.collection.rename(e),this}drop(e){return this.collection.drop()}async findOne(e,n){return this.collection.findOne(e)}find(e,n){return new P(this.collection.find(e))}options(e){throw new Error("Method not implemented.")}isCapped(e){throw new Error("Method not implemented.")}createIndex(e,n){throw new Error("Method not implemented.")}createIndexes(e,n){throw new Error("Method not implemented.")}dropIndex(e,n){throw new Error("Method not implemented.")}dropIndexes(e){throw new Error("Method not implemented.")}listIndexes(e){throw new Error("Method not implemented.")}indexExists(e,n){throw new Error("Method not implemented.")}indexInformation(e){throw new Error("Method not implemented.")}estimatedDocumentCount(e){return this.collection.countDocuments()}countDocuments(e,n){return this.collection.countDocuments(e)}distinct(e,n,o){throw new Error("Method not implemented.")}indexes(e){throw new Error("Method not implemented.")}findOneAndDelete(e,n){return this.collection.findOneAndDelete(e)}findOneAndReplace(e,n,o){return this.collection.findOneAndReplace(e,n)}findOneAndUpdate(e,n,o){return this.collection.findOneAndUpdate(e,n)}aggregate(e,n){throw new Error("Method not implemented.")}watch(e,n){throw new Error("Method not implemented.")}initializeUnorderedBulkOp(e){throw new Error("Method not implemented.")}initializeOrderedBulkOp(e){throw new Error("Method not implemented.")}count(e,n){return this.collection.countDocuments(e??{})}listSearchIndexes(e,n){throw new Error("Method not implemented.")}createSearchIndex(e){throw new Error("Method not implemented.")}createSearchIndexes(e){throw new Error("Method not implemented.")}dropSearchIndex(e){throw new Error("Method not implemented.")}updateSearchIndex(e,n){throw new Error("Method not implemented.")}async createCollection(){await this.collection.createCollection()}async handle(e,n){return this.collection.handle(e.toString(),n)}};var I=class{constructor(e){this.pongoDb=e}collection(e){return new w(this.pongoDb.collection(e))}};var _=class{pongoClient;constructor(e,n={}){this.pongoClient=R(e,n)}async connect(){return await this.pongoClient.connect(),this}async close(){await this.pongoClient.close()}db(e){return new I(this.pongoClient.db(e))}};export{w as Collection,I as Db,P as FindCursor,_ as MongoClient,D as Operators,Q as buildIncQuery,j as buildPushQuery,U as buildSetQuery,N as buildUnsetQuery,h as buildUpdateQuery,K as collectionSQLBuilder,c as constructFilterQuery,T as entries,C as getDbClient,O as handleOperator,E as hasOperators,M as isOperator,R as pongoClient,L as postgresClient,k as postgresCollection};
14
14
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/postgres/client.ts","../src/postgres/postgresCollection.ts","../src/main/typing/entries.ts","../src/postgres/filter/queryOperators.ts","../src/postgres/filter/index.ts","../src/postgres/update/index.ts","../src/main/dbClient.ts","../src/main/pongoClient.ts","../src/mongo/findCursor.ts","../src/mongo/mongoDb.ts","../src/mongo/mongoCollection.ts","../src/mongo/mongoClient.ts"],"sourcesContent":["import {\n endPool,\n getDatabaseNameOrDefault,\n getPool,\n} from '@event-driven-io/dumbo';\nimport pg from 'pg';\nimport { type DbClient, type PongoDocument } from '../main';\nimport { postgresCollection } from './postgresCollection';\n\nexport type PongoClientOptions = {\n connectionString: string;\n dbName?: string | undefined;\n client?: pg.PoolClient;\n};\n\nexport const postgresClient = (options: PongoClientOptions): DbClient => {\n const { connectionString, dbName, client } = options;\n const managesPoolLifetime = !client;\n const poolOrClient =\n client ?? getPool({ connectionString, database: dbName });\n\n return {\n connect: () => Promise.resolve(),\n close: () =>\n managesPoolLifetime\n ? endPool({ connectionString, database: dbName })\n : Promise.resolve(),\n collection: <T extends PongoDocument>(name: string) =>\n postgresCollection<T>(name, {\n dbName: dbName ?? getDatabaseNameOrDefault(connectionString),\n poolOrClient,\n }),\n };\n};\n","import { executeSQL, single, sql, type SQL } from '@event-driven-io/dumbo';\nimport pg from 'pg';\nimport format from 'pg-format';\nimport { v4 as uuid } from 'uuid';\nimport {\n type DocumentHandler,\n type PongoCollection,\n type PongoDeleteResult,\n type PongoDocument,\n type PongoFilter,\n type PongoInsertManyResult,\n type PongoInsertOneResult,\n type PongoUpdate,\n type PongoUpdateResult,\n type WithId,\n type WithoutId,\n} from '../main';\nimport { constructFilterQuery } from './filter';\nimport { buildUpdateQuery } from './update';\n\nexport const postgresCollection = <T extends PongoDocument>(\n collectionName: string,\n {\n dbName,\n poolOrClient: clientOrPool,\n }: { dbName: string; poolOrClient: pg.Pool | pg.PoolClient },\n): PongoCollection<T> => {\n const execute = <T extends pg.QueryResultRow = pg.QueryResultRow>(sql: SQL) =>\n executeSQL<T>(clientOrPool, sql);\n const SqlFor = collectionSQLBuilder(collectionName);\n\n const createCollection = execute(SqlFor.createCollection());\n\n const collection = {\n dbName,\n collectionName,\n createCollection: async () => {\n await createCollection;\n },\n insertOne: async (document: T): Promise<PongoInsertOneResult> => {\n await createCollection;\n\n const _id = uuid();\n\n const result = await execute(SqlFor.insertOne({ _id, ...document }));\n\n return result.rowCount\n ? { insertedId: _id, acknowledged: true }\n : { insertedId: null, acknowledged: false };\n },\n insertMany: async (documents: T[]): Promise<PongoInsertManyResult> => {\n await createCollection;\n\n const rows = documents.map((doc) => ({\n _id: uuid(),\n ...doc,\n }));\n\n const result = await execute(SqlFor.insertMany(rows));\n\n return {\n acknowledged: result.rowCount === rows.length,\n insertedCount: result.rowCount ?? 0,\n insertedIds: rows.map((d) => d._id),\n };\n },\n updateOne: async (\n filter: PongoFilter<T>,\n update: PongoUpdate<T>,\n ): Promise<PongoUpdateResult> => {\n await createCollection;\n\n const result = await execute(SqlFor.updateOne(filter, update));\n return result.rowCount\n ? { acknowledged: true, modifiedCount: result.rowCount }\n : { acknowledged: false, modifiedCount: 0 };\n },\n replaceOne: async (\n filter: PongoFilter<T>,\n document: WithoutId<T>,\n ): Promise<PongoUpdateResult> => {\n await createCollection;\n\n const result = await execute(SqlFor.replaceOne(filter, document));\n return result.rowCount\n ? { acknowledged: true, modifiedCount: result.rowCount }\n : { acknowledged: false, modifiedCount: 0 };\n },\n updateMany: async (\n filter: PongoFilter<T>,\n update: PongoUpdate<T>,\n ): Promise<PongoUpdateResult> => {\n await createCollection;\n\n const result = await execute(SqlFor.updateMany(filter, update));\n return result.rowCount\n ? { acknowledged: true, modifiedCount: result.rowCount }\n : { acknowledged: false, modifiedCount: 0 };\n },\n deleteOne: async (filter?: PongoFilter<T>): Promise<PongoDeleteResult> => {\n await createCollection;\n\n const result = await execute(SqlFor.deleteOne(filter ?? {}));\n return result.rowCount\n ? { acknowledged: true, deletedCount: result.rowCount }\n : { acknowledged: false, deletedCount: 0 };\n },\n deleteMany: async (filter?: PongoFilter<T>): Promise<PongoDeleteResult> => {\n await createCollection;\n\n const result = await execute(SqlFor.deleteMany(filter ?? {}));\n return result.rowCount\n ? { acknowledged: true, deletedCount: result.rowCount }\n : { acknowledged: false, deletedCount: 0 };\n },\n findOne: async (filter?: PongoFilter<T>): Promise<T | null> => {\n await createCollection;\n\n const result = await execute(SqlFor.findOne(filter ?? {}));\n return (result.rows[0]?.data ?? null) as T | null;\n },\n findOneAndDelete: async (filter: PongoFilter<T>): Promise<T | null> => {\n await createCollection;\n\n const existingDoc = await collection.findOne(filter);\n\n if (existingDoc === null) return null;\n\n await collection.deleteOne(filter);\n return existingDoc;\n },\n findOneAndReplace: async (\n filter: PongoFilter<T>,\n replacement: WithoutId<T>,\n ): Promise<T | null> => {\n await createCollection;\n\n const existingDoc = await collection.findOne(filter);\n\n if (existingDoc === null) return null;\n\n await collection.replaceOne(filter, replacement);\n\n return existingDoc;\n },\n findOneAndUpdate: async (\n filter: PongoFilter<T>,\n update: PongoUpdate<T>,\n ): Promise<T | null> => {\n await createCollection;\n\n const existingDoc = await collection.findOne(filter);\n\n if (existingDoc === null) return null;\n\n await collection.updateOne(filter, update);\n\n return existingDoc;\n },\n handle: async (\n id: string,\n handle: DocumentHandler<T>,\n ): Promise<T | null> => {\n await createCollection;\n\n const byId: PongoFilter<T> = { _id: id };\n\n const existing = await collection.findOne(byId);\n\n const result = await handle(existing);\n\n if (!existing && result) {\n const newDoc = { ...result, _id: id };\n await collection.insertOne({ ...newDoc, _id: id });\n return newDoc;\n }\n\n if (existing && !result) {\n await collection.deleteOne(byId);\n return null;\n }\n\n if (existing && result) await collection.replaceOne(byId, result);\n\n return result;\n },\n find: async (filter?: PongoFilter<T>): Promise<T[]> => {\n await createCollection;\n\n const result = await execute(SqlFor.find(filter ?? {}));\n return result.rows.map((row) => row.data as T);\n },\n countDocuments: async (filter?: PongoFilter<T>): Promise<number> => {\n await createCollection;\n\n const { count } = await single(\n execute<{ count: number }>(SqlFor.countDocuments(filter ?? {})),\n );\n return count;\n },\n drop: async (): Promise<boolean> => {\n await createCollection;\n const result = await execute(SqlFor.drop());\n return (result?.rowCount ?? 0) > 0;\n },\n rename: async (newName: string): Promise<PongoCollection<T>> => {\n await createCollection;\n await execute(SqlFor.rename(newName));\n collectionName = newName;\n return collection;\n },\n };\n\n return collection;\n};\n\nexport const collectionSQLBuilder = (collectionName: string) => ({\n createCollection: (): 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 insertOne: <T>(document: WithId<T>): SQL =>\n sql(\n 'INSERT INTO %I (_id, data) VALUES (%L, %L)',\n collectionName,\n document._id,\n JSON.stringify(document),\n ),\n insertMany: <T>(documents: WithId<T>[]): SQL => {\n const values = documents\n .map((doc) => format('(%L, %L)', doc._id, JSON.stringify(doc)))\n .join(', ');\n return sql('INSERT INTO %I (_id, data) VALUES %s', collectionName, values);\n },\n updateOne: <T>(filter: PongoFilter<T>, update: PongoUpdate<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n const updateQuery = buildUpdateQuery(update);\n\n return sql(\n `WITH cte AS (\n SELECT _id FROM %I WHERE %s LIMIT 1\n )\n UPDATE %I SET data = %s FROM cte WHERE %I._id = cte._id`,\n collectionName,\n filterQuery,\n collectionName,\n updateQuery,\n collectionName,\n );\n },\n replaceOne: <T>(filter: PongoFilter<T>, document: WithoutId<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n\n return sql(\n `UPDATE %I SET data = %L || jsonb_build_object('_id', data->>'_id') WHERE %s`,\n collectionName,\n JSON.stringify(document),\n filterQuery,\n );\n },\n updateMany: <T>(filter: PongoFilter<T>, update: PongoUpdate<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n const updateQuery = buildUpdateQuery(update);\n\n return sql(\n 'UPDATE %I SET data = %s WHERE %s',\n collectionName,\n updateQuery,\n filterQuery,\n );\n },\n deleteOne: <T>(filter: PongoFilter<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n return sql('DELETE FROM %I WHERE %s', collectionName, filterQuery);\n },\n deleteMany: <T>(filter: PongoFilter<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n return sql('DELETE FROM %I WHERE %s', collectionName, filterQuery);\n },\n findOne: <T>(filter: PongoFilter<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n return sql(\n 'SELECT data FROM %I WHERE %s LIMIT 1',\n collectionName,\n filterQuery,\n );\n },\n find: <T>(filter: PongoFilter<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n return sql('SELECT data FROM %I WHERE %s', collectionName, filterQuery);\n },\n countDocuments: <T>(filter: PongoFilter<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n return sql(\n 'SELECT COUNT(1) as count FROM %I WHERE %s',\n collectionName,\n 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","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 entries = <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 format from 'pg-format';\nimport { entries } from '../../main/typing';\n\nexport const Operators = {\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\nconst 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\nexport const handleOperator = (\n path: string,\n operator: string,\n value: unknown,\n): string => {\n if (path === '_id') {\n return handleIdOperator(operator, value);\n }\n\n switch (operator) {\n case '$eq':\n return format(\n `(data @> %L::jsonb OR jsonb_path_exists(data, '$.%s[*] ? (@ == %s)'))`,\n JSON.stringify(buildNestedObject(path, value)),\n path,\n JSON.stringify(value),\n );\n case '$gt':\n case '$gte':\n case '$lt':\n case '$lte':\n case '$ne':\n return format(\n `data #>> %L ${OperatorMap[operator]} %L`,\n `{${path.split('.').join(',')}}`,\n value,\n );\n case '$in':\n return format(\n 'data #>> %L IN (%s)',\n `{${path.split('.').join(',')}}`,\n (value as unknown[]).map((v) => format('%L', v)).join(', '),\n );\n case '$nin':\n return format(\n 'data #>> %L NOT IN (%s)',\n `{${path.split('.').join(',')}}`,\n (value as unknown[]).map((v) => format('%L', v)).join(', '),\n );\n case '$elemMatch': {\n const subQuery = entries(value as Record<string, unknown>)\n .map(([subKey, subValue]) =>\n format(`@.\"%s\" == %s`, subKey, JSON.stringify(subValue)),\n )\n .join(' && ');\n return format(\n `jsonb_path_exists(data, '$.%s[*] ? (%s)')`,\n path,\n subQuery,\n );\n }\n case '$all':\n return format(\n 'data @> %L::jsonb',\n JSON.stringify(buildNestedObject(path, value)),\n );\n case '$size':\n return format(\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 handleIdOperator = (operator: string, value: unknown): string => {\n switch (operator) {\n case '$eq':\n return format(`_id = %L`, value);\n case '$gt':\n case '$gte':\n case '$lt':\n case '$lte':\n case '$ne':\n return format(`_id ${OperatorMap[operator]} %L`, value);\n case '$in':\n return format(\n `_id IN (%s)`,\n (value as unknown[]).map((v) => format('%L', v)).join(', '),\n );\n case '$nin':\n return format(\n `_id NOT IN (%s)`,\n (value as unknown[]).map((v) => format('%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 type { PongoFilter } from '../../main';\nimport { entries } from '../../main/typing';\nimport { Operators, handleOperator, hasOperators } 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 entries(value)\n .map(\n ([nestedKey, val]) =>\n isEquality\n ? handleOperator(`${key}.${nestedKey}`, Operators.$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 { sql, type SQL } from '@event-driven-io/dumbo';\nimport type { $inc, $push, $set, $unset, PongoUpdate } from '../../main';\nimport { entries } from '../../main/typing';\n\nexport const buildUpdateQuery = <T>(update: PongoUpdate<T>): SQL =>\n entries(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, JSON.stringify(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 \"jsonb_set(%s, '{%s}', to_jsonb((data->>'%s')::numeric + %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 JSON.stringify([value]),\n );\n }\n return currentUpdateQuery;\n};\n","import { postgresClient, type PongoClientOptions } from '../postgres';\nimport type { PongoCollection, PongoDocument } from './typing/operations';\n\nexport interface DbClient {\n connect(): Promise<void>;\n close(): Promise<void>;\n collection: <T extends PongoDocument>(name: string) => PongoCollection<T>;\n}\n\nexport const getDbClient = (options: PongoClientOptions): DbClient => {\n // This is the place where in the future could come resolution of other database types\n return postgresClient(options);\n};\n","import { getDatabaseNameOrDefault } from '@event-driven-io/dumbo';\nimport { getDbClient, type DbClient } from './dbClient';\nimport type { PongoClient, PongoDb } from './typing/operations';\n\nexport const pongoClient = (connectionString: string): PongoClient => {\n const defaultDbName = getDatabaseNameOrDefault(connectionString);\n const dbClients: Map<string, DbClient> = new Map();\n\n const dbClient = getDbClient({ connectionString });\n dbClients.set(defaultDbName, 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(dbName, getDbClient({ connectionString, dbName: dbName }))\n .get(dbName)!\n );\n },\n };\n\n return pongoClient;\n};\n","export class FindCursor<T> {\n private findDocumentsPromise: Promise<T[]>;\n private documents: T[] | null = null;\n private index: number = 0;\n\n constructor(documents: Promise<T[]>) {\n this.findDocumentsPromise = documents;\n }\n\n async toArray(): Promise<T[]> {\n return this.findDocuments();\n }\n\n async forEach(callback: (doc: T) => void): Promise<void> {\n const docs = await this.findDocuments();\n\n for (const doc of docs) {\n callback(doc);\n }\n return Promise.resolve();\n }\n\n hasNext(): boolean {\n if (this.documents === null) throw Error('Error while fetching documents');\n return this.index < this.documents.length;\n }\n\n async next(): Promise<T | null> {\n const docs = await this.findDocuments();\n return this.hasNext() ? docs[this.index++] ?? null : null;\n }\n\n private async findDocuments(): Promise<T[]> {\n this.documents = await this.findDocumentsPromise;\n return this.documents;\n }\n}\n","import {\n Collection as MongoCollection,\n ObjectId,\n type Document,\n} from 'mongodb';\nimport type { DocumentHandler, PongoDb } from '../main';\nimport { Collection } from './mongoCollection';\n\nexport class Db {\n constructor(private pongoDb: PongoDb) {}\n\n collection<T extends Document>(\n collectionName: string,\n ): MongoCollection<T> & {\n handle(id: ObjectId, handle: DocumentHandler<T>): Promise<T | null>;\n } {\n return new Collection<T>(this.pongoDb.collection<T>(collectionName));\n }\n}\n","import type {\n AbstractCursorOptions,\n AggregateOptions,\n AggregationCursor,\n AnyBulkWriteOperation,\n BSONSerializeOptions,\n BulkWriteOptions,\n BulkWriteResult,\n ChangeStream,\n ChangeStreamDocument,\n ChangeStreamOptions,\n CommandOperationOptions,\n CountDocumentsOptions,\n CountOptions,\n CreateIndexesOptions,\n DeleteOptions,\n DeleteResult,\n Document,\n DropCollectionOptions,\n EnhancedOmit,\n EstimatedDocumentCountOptions,\n Filter,\n FindOneAndDeleteOptions,\n FindOneAndReplaceOptions,\n FindOneAndUpdateOptions,\n FindOptions,\n Flatten,\n Hint,\n IndexDescription,\n IndexDescriptionCompact,\n IndexDescriptionInfo,\n IndexInformationOptions,\n IndexSpecification,\n InferIdType,\n InsertManyResult,\n InsertOneOptions,\n InsertOneResult,\n ListIndexesCursor,\n ListSearchIndexesCursor,\n ListSearchIndexesOptions,\n ModifyResult,\n Collection as MongoCollection,\n FindCursor as MongoFindCursor,\n ObjectId,\n OperationOptions,\n OptionalUnlessRequiredId,\n OrderedBulkOperation,\n ReadConcern,\n ReadPreference,\n RenameOptions,\n ReplaceOptions,\n SearchIndexDescription,\n UnorderedBulkOperation,\n UpdateFilter,\n UpdateOptions,\n UpdateResult,\n WithId,\n WithoutId,\n WriteConcern,\n} from 'mongodb';\nimport type { Key } from 'readline';\nimport type {\n DocumentHandler,\n PongoCollection,\n PongoFilter,\n PongoUpdate,\n} from '../main';\nimport { FindCursor } from './findCursor';\n\nexport class Collection<T extends Document> implements MongoCollection<T> {\n private collection: PongoCollection<T>;\n\n constructor(collection: PongoCollection<T>) {\n this.collection = collection;\n }\n get dbName(): string {\n return this.collection.dbName;\n }\n get collectionName(): string {\n return this.collection.collectionName;\n }\n get namespace(): string {\n return `${this.dbName}.${this.collectionName}`;\n }\n get readConcern(): ReadConcern | undefined {\n return undefined;\n }\n get readPreference(): ReadPreference | undefined {\n return undefined;\n }\n get bsonOptions(): BSONSerializeOptions {\n return {};\n }\n get writeConcern(): WriteConcern | undefined {\n return undefined;\n }\n get hint(): Hint | undefined {\n return undefined;\n }\n set hint(v: Hint | undefined) {\n throw new Error('Method not implemented.');\n }\n async insertOne(\n doc: OptionalUnlessRequiredId<T>,\n _options?: InsertOneOptions | undefined,\n ): Promise<InsertOneResult<T>> {\n const result = await this.collection.insertOne(doc as T);\n return {\n acknowledged: result.acknowledged,\n insertedId: result.insertedId as unknown as InferIdType<T>,\n };\n }\n async insertMany(\n docs: OptionalUnlessRequiredId<T>[],\n _options?: BulkWriteOptions | undefined,\n ): Promise<InsertManyResult<T>> {\n const result = await this.collection.insertMany(docs as T[]);\n return {\n acknowledged: result.acknowledged,\n insertedIds: result.insertedIds as unknown as InferIdType<T>[],\n insertedCount: result.insertedCount,\n };\n }\n bulkWrite(\n _operations: AnyBulkWriteOperation<T>[],\n _options?: BulkWriteOptions | undefined,\n ): Promise<BulkWriteResult> {\n throw new Error('Method not implemented.');\n }\n async updateOne(\n filter: Filter<T>,\n update: Document[] | UpdateFilter<T>,\n _options?: UpdateOptions | undefined,\n ): Promise<UpdateResult<T>> {\n const result = await this.collection.updateOne(\n filter as unknown as PongoFilter<T>,\n update as unknown as PongoUpdate<T>,\n );\n\n return {\n acknowledged: result.acknowledged,\n matchedCount: result.modifiedCount,\n modifiedCount: result.modifiedCount,\n upsertedCount: result.modifiedCount,\n upsertedId: null,\n };\n }\n replaceOne(\n filter: Filter<T>,\n document: WithoutId<T>,\n _options?: ReplaceOptions | undefined,\n ): Promise<Document | UpdateResult<T>> {\n return this.collection.replaceOne(\n filter as unknown as PongoFilter<T>,\n document,\n );\n }\n async updateMany(\n filter: Filter<T>,\n update: Document[] | UpdateFilter<T>,\n _options?: UpdateOptions | undefined,\n ): Promise<UpdateResult<T>> {\n const result = await this.collection.updateMany(\n filter as unknown as PongoFilter<T>,\n update as unknown as PongoUpdate<T>,\n );\n\n return {\n acknowledged: result.acknowledged,\n matchedCount: result.modifiedCount,\n modifiedCount: result.modifiedCount,\n upsertedCount: result.modifiedCount,\n upsertedId: null,\n };\n }\n async deleteOne(\n filter?: Filter<T> | undefined,\n _options?: DeleteOptions | undefined,\n ): Promise<DeleteResult> {\n const result = await this.collection.deleteOne(filter as PongoFilter<T>);\n\n return {\n acknowledged: result.acknowledged,\n deletedCount: result.deletedCount,\n };\n }\n async deleteMany(\n filter?: Filter<T> | undefined,\n _options?: DeleteOptions | undefined,\n ): Promise<DeleteResult> {\n const result = await this.collection.deleteMany(filter as PongoFilter<T>);\n\n return {\n acknowledged: result.acknowledged,\n deletedCount: result.deletedCount,\n };\n }\n async rename(\n newName: string,\n _options?: RenameOptions | undefined,\n ): Promise<Collection<Document>> {\n await this.collection.rename(newName);\n\n return this as unknown as Collection<Document>;\n }\n drop(_options?: DropCollectionOptions | undefined): Promise<boolean> {\n return this.collection.drop();\n }\n findOne(): Promise<WithId<T> | null>;\n findOne(filter: Filter<T>): Promise<WithId<T> | null>;\n findOne(\n filter: Filter<T>,\n options: FindOptions<Document>,\n ): Promise<WithId<T> | null>;\n findOne<TS = T>(): Promise<TS | null>;\n findOne<TS = T>(filter: Filter<TS>): Promise<TS | null>;\n findOne<TS = T>(\n filter: Filter<TS>,\n options?: FindOptions<Document> | undefined,\n ): Promise<TS | null>;\n async findOne(\n filter?: unknown,\n _options?: unknown,\n ): Promise<import('mongodb').WithId<T> | T | null> {\n return this.collection.findOne(filter as PongoFilter<T>);\n }\n find(): MongoFindCursor<WithId<T>>;\n find(\n filter: Filter<T>,\n options?: FindOptions<Document> | undefined,\n ): MongoFindCursor<WithId<T>>;\n find<T extends Document>(\n filter: Filter<T>,\n options?: FindOptions<Document> | undefined,\n ): MongoFindCursor<T>;\n find(\n filter?: unknown,\n _options?: unknown,\n ): MongoFindCursor<WithId<T>> | MongoFindCursor<T> {\n return new FindCursor(\n this.collection.find(filter as PongoFilter<T>),\n ) as unknown as MongoFindCursor<T>;\n }\n options(_options?: OperationOptions | undefined): Promise<Document> {\n throw new Error('Method not implemented.');\n }\n isCapped(_options?: OperationOptions | undefined): Promise<boolean> {\n throw new Error('Method not implemented.');\n }\n createIndex(\n _indexSpec: IndexSpecification,\n _options?: CreateIndexesOptions | undefined,\n ): Promise<string> {\n throw new Error('Method not implemented.');\n }\n createIndexes(\n _indexSpecs: IndexDescription[],\n _options?: CreateIndexesOptions | undefined,\n ): Promise<string[]> {\n throw new Error('Method not implemented.');\n }\n dropIndex(\n _indexName: string,\n _options?: CommandOperationOptions | undefined,\n ): Promise<Document> {\n throw new Error('Method not implemented.');\n }\n dropIndexes(\n _options?: CommandOperationOptions | undefined,\n ): Promise<boolean> {\n throw new Error('Method not implemented.');\n }\n listIndexes(_options?: AbstractCursorOptions | undefined): ListIndexesCursor {\n throw new Error('Method not implemented.');\n }\n indexExists(\n _indexes: string | string[],\n _options?: AbstractCursorOptions | undefined,\n ): Promise<boolean> {\n throw new Error('Method not implemented.');\n }\n indexInformation(\n options: IndexInformationOptions & { full: true },\n ): Promise<IndexDescriptionInfo[]>;\n indexInformation(\n options: IndexInformationOptions & { full?: false | undefined },\n ): Promise<IndexDescriptionCompact>;\n indexInformation(\n options: IndexInformationOptions,\n ): Promise<IndexDescriptionCompact | IndexDescriptionInfo[]>;\n indexInformation(): Promise<IndexDescriptionCompact>;\n indexInformation(\n _options?: unknown,\n ):\n | Promise<import('mongodb').IndexDescriptionInfo[]>\n | Promise<import('mongodb').IndexDescriptionCompact>\n | Promise<\n | import('mongodb').IndexDescriptionCompact\n | import('mongodb').IndexDescriptionInfo[]\n > {\n throw new Error('Method not implemented.');\n }\n estimatedDocumentCount(\n _options?: EstimatedDocumentCountOptions | undefined,\n ): Promise<number> {\n return this.collection.countDocuments();\n }\n countDocuments(\n filter?: Filter<T> | undefined,\n _options?: CountDocumentsOptions | undefined,\n ): Promise<number> {\n return this.collection.countDocuments(filter as PongoFilter<T>);\n }\n distinct<Key extends '_id' | keyof EnhancedOmit<T, '_id'>>(\n key: Key,\n ): Promise<Flatten<WithId<T>[Key]>[]>;\n distinct<Key extends '_id' | keyof EnhancedOmit<T, '_id'>>(\n key: Key,\n filter: Filter<T>,\n ): Promise<Flatten<WithId<T>[Key]>[]>;\n distinct<Key extends '_id' | keyof EnhancedOmit<T, '_id'>>(\n key: Key,\n filter: Filter<T>,\n options: CommandOperationOptions,\n ): Promise<Flatten<WithId<T>[Key]>[]>;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n distinct(key: string): Promise<any[]>;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n distinct(key: string, filter: Filter<T>): Promise<any[]>;\n distinct(\n key: string,\n filter: Filter<T>,\n options: CommandOperationOptions, // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): Promise<any[]>;\n distinct(\n _key: unknown,\n _filter?: unknown,\n _options?: unknown,\n ): // eslint-disable-next-line @typescript-eslint/no-explicit-any\n | Promise<any[]>\n | Promise<import('mongodb').Flatten<import('mongodb').WithId<T>[Key]>[]> {\n throw new Error('Method not implemented.');\n }\n indexes(\n options: IndexInformationOptions & { full?: true | undefined },\n ): Promise<IndexDescriptionInfo[]>;\n indexes(\n options: IndexInformationOptions & { full: false },\n ): Promise<IndexDescriptionCompact>;\n indexes(\n options: IndexInformationOptions,\n ): Promise<IndexDescriptionCompact | IndexDescriptionInfo[]>;\n indexes(\n options?: AbstractCursorOptions | undefined,\n ): Promise<IndexDescriptionInfo[]>;\n indexes(\n _options?: unknown,\n ):\n | Promise<import('mongodb').IndexDescriptionInfo[]>\n | Promise<import('mongodb').IndexDescriptionCompact>\n | Promise<\n | import('mongodb').IndexDescriptionCompact\n | import('mongodb').IndexDescriptionInfo[]\n > {\n throw new Error('Method not implemented.');\n }\n findOneAndDelete(\n filter: Filter<T>,\n options: FindOneAndDeleteOptions & { includeResultMetadata: true },\n ): Promise<ModifyResult<T>>;\n findOneAndDelete(\n filter: Filter<T>,\n options: FindOneAndDeleteOptions & { includeResultMetadata: false },\n ): Promise<WithId<T> | null>;\n findOneAndDelete(\n filter: Filter<T>,\n options: FindOneAndDeleteOptions,\n ): Promise<WithId<T> | null>;\n findOneAndDelete(filter: Filter<T>): Promise<WithId<T> | null>;\n findOneAndDelete(\n filter: unknown,\n _options?: unknown,\n ): Promise<WithId<T> | null | ModifyResult<T>> {\n return this.collection.findOneAndDelete(\n filter as PongoFilter<T>,\n ) as Promise<WithId<T> | null>;\n }\n findOneAndReplace(\n filter: Filter<T>,\n replacement: WithoutId<T>,\n options: FindOneAndReplaceOptions & { includeResultMetadata: true },\n ): Promise<ModifyResult<T>>;\n findOneAndReplace(\n filter: Filter<T>,\n replacement: WithoutId<T>,\n options: FindOneAndReplaceOptions & { includeResultMetadata: false },\n ): Promise<WithId<T> | null>;\n findOneAndReplace(\n filter: Filter<T>,\n replacement: WithoutId<T>,\n options: FindOneAndReplaceOptions,\n ): Promise<WithId<T> | null>;\n findOneAndReplace(\n filter: Filter<T>,\n replacement: WithoutId<T>,\n ): Promise<WithId<T> | null>;\n findOneAndReplace(\n filter: unknown,\n replacement: unknown,\n _options?: unknown,\n ): Promise<WithId<T> | null | ModifyResult<T>> {\n return this.collection.findOneAndReplace(\n filter as PongoFilter<T>,\n replacement as WithoutId<T>,\n ) as Promise<WithId<T> | null>;\n }\n findOneAndUpdate(\n filter: Filter<T>,\n update: UpdateFilter<T>,\n options: FindOneAndUpdateOptions & { includeResultMetadata: true },\n ): Promise<ModifyResult<T>>;\n findOneAndUpdate(\n filter: Filter<T>,\n update: UpdateFilter<T>,\n options: FindOneAndUpdateOptions & { includeResultMetadata: false },\n ): Promise<WithId<T> | null>;\n findOneAndUpdate(\n filter: Filter<T>,\n update: UpdateFilter<T>,\n options: FindOneAndUpdateOptions,\n ): Promise<WithId<T> | null>;\n findOneAndUpdate(\n filter: Filter<T>,\n update: UpdateFilter<T>,\n ): Promise<WithId<T> | null>;\n findOneAndUpdate(\n filter: unknown,\n update: unknown,\n _options?: unknown,\n ): Promise<WithId<T> | null | ModifyResult<T>> {\n return this.collection.findOneAndUpdate(\n filter as PongoFilter<T>,\n update as PongoUpdate<T>,\n ) as Promise<WithId<T> | null>;\n }\n aggregate<T extends Document = Document>(\n _pipeline?: Document[] | undefined,\n _options?: AggregateOptions | undefined,\n ): AggregationCursor<T> {\n throw new Error('Method not implemented.');\n }\n watch<\n TLocal extends Document = T,\n TChange extends Document = ChangeStreamDocument<TLocal>,\n >(\n _pipeline?: Document[] | undefined,\n _options?: ChangeStreamOptions | undefined,\n ): ChangeStream<TLocal, TChange> {\n throw new Error('Method not implemented.');\n }\n initializeUnorderedBulkOp(\n _options?: BulkWriteOptions | undefined,\n ): UnorderedBulkOperation {\n throw new Error('Method not implemented.');\n }\n initializeOrderedBulkOp(\n _options?: BulkWriteOptions | undefined,\n ): OrderedBulkOperation {\n throw new Error('Method not implemented.');\n }\n count(\n filter?: Filter<T> | undefined,\n _options?: CountOptions | undefined,\n ): Promise<number> {\n return this.collection.countDocuments((filter as PongoFilter<T>) ?? {});\n }\n listSearchIndexes(\n options?: ListSearchIndexesOptions | undefined,\n ): ListSearchIndexesCursor;\n listSearchIndexes(\n name: string,\n options?: ListSearchIndexesOptions | undefined,\n ): ListSearchIndexesCursor;\n listSearchIndexes(\n _name?: unknown,\n _options?: unknown,\n ): import('mongodb').ListSearchIndexesCursor {\n throw new Error('Method not implemented.');\n }\n createSearchIndex(_description: SearchIndexDescription): Promise<string> {\n throw new Error('Method not implemented.');\n }\n createSearchIndexes(\n _descriptions: SearchIndexDescription[],\n ): Promise<string[]> {\n throw new Error('Method not implemented.');\n }\n dropSearchIndex(_name: string): Promise<void> {\n throw new Error('Method not implemented.');\n }\n updateSearchIndex(_name: string, _definition: Document): Promise<void> {\n throw new Error('Method not implemented.');\n }\n\n async createCollection(): Promise<void> {\n await this.collection.createCollection();\n }\n async handle(id: ObjectId, handle: DocumentHandler<T>): Promise<T | null> {\n return this.collection.handle(id.toString(), handle);\n }\n}\n","// src/MongoClientShim.ts\nimport { pongoClient, type PongoClient } from '../main';\nimport { Db } from './mongoDb';\n\nexport class MongoClient {\n private pongoClient: PongoClient;\n\n constructor(connectionString: string) {\n this.pongoClient = pongoClient(connectionString);\n }\n\n async connect() {\n await this.pongoClient.connect();\n return this;\n }\n\n async close() {\n await this.pongoClient.close();\n }\n\n db(dbName?: string): Db {\n return new Db(this.pongoClient.db(dbName));\n }\n}\n"],"mappings":"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","names":["endPool","getDatabaseNameOrDefault","getPool","executeSQL","single","sql","format","uuid","entries","obj","key","value","format","Operators","OperatorMap","isOperator","key","hasOperators","value","handleOperator","path","operator","handleIdOperator","format","buildNestedObject","v","subQuery","entries","subKey","subValue","acc","AND","constructFilterQuery","filter","key","value","isRecord","constructComplexFilterQuery","handleOperator","isEquality","hasOperators","entries","nestedKey","val","Operators","sql","buildUpdateQuery","update","entries","currentUpdateQuery","op","value","buildSetQuery","buildUnsetQuery","buildIncQuery","buildPushQuery","sql","set","unset","k","inc","key","push","postgresCollection","collectionName","dbName","clientOrPool","execute","sql","executeSQL","SqlFor","collectionSQLBuilder","createCollection","collection","document","_id","uuid","documents","rows","doc","result","d","filter","update","existingDoc","replacement","id","handle","byId","existing","newDoc","row","count","single","newName","values","format","filterQuery","constructFilterQuery","updateQuery","buildUpdateQuery","targetName","postgresClient","options","connectionString","dbName","client","managesPoolLifetime","poolOrClient","getPool","endPool","name","postgresCollection","getDatabaseNameOrDefault","getDbClient","options","postgresClient","getDatabaseNameOrDefault","pongoClient","connectionString","defaultDbName","getDatabaseNameOrDefault","dbClients","dbClient","getDbClient","db","dbName","FindCursor","documents","callback","docs","doc","Collection","collection","v","doc","_options","result","docs","_operations","filter","update","document","newName","FindCursor","_indexSpec","_indexSpecs","_indexName","_indexes","_key","_filter","replacement","_pipeline","_name","_description","_descriptions","_definition","id","handle","Db","pongoDb","collectionName","Collection","MongoClient","connectionString","pongoClient","dbName","Db"]}
1
+ {"version":3,"sources":["../src/postgres/client.ts","../src/postgres/postgresCollection.ts","../src/main/typing/entries.ts","../src/postgres/filter/queryOperators.ts","../src/postgres/filter/index.ts","../src/postgres/update/index.ts","../src/main/dbClient.ts","../src/main/pongoClient.ts","../src/mongo/findCursor.ts","../src/mongo/mongoClient.ts","../src/mongo/mongoDb.ts","../src/mongo/mongoCollection.ts"],"sourcesContent":["import {\n endPool,\n getDatabaseNameOrDefault,\n getPool,\n} from '@event-driven-io/dumbo';\nimport pg from 'pg';\nimport { type DbClient, type PongoDocument } from '../main';\nimport { postgresCollection } from './postgresCollection';\n\nexport type PongoClientOptions = {\n connectionString: string;\n dbName?: string | undefined;\n client?: pg.PoolClient | undefined;\n};\n\nexport const postgresClient = (options: PongoClientOptions): DbClient => {\n const { connectionString, dbName, client } = options;\n const managesPoolLifetime = !client;\n const poolOrClient =\n client ?? getPool({ connectionString, database: dbName });\n\n return {\n connect: () => Promise.resolve(),\n close: () =>\n managesPoolLifetime\n ? endPool({ connectionString, database: dbName })\n : Promise.resolve(),\n collection: <T extends PongoDocument>(name: string) =>\n postgresCollection<T>(name, {\n dbName: dbName ?? getDatabaseNameOrDefault(connectionString),\n poolOrClient,\n }),\n };\n};\n","import { executeSQL, single, sql, type SQL } from '@event-driven-io/dumbo';\nimport pg from 'pg';\nimport format from 'pg-format';\nimport { v4 as uuid } from 'uuid';\nimport {\n type DocumentHandler,\n type PongoCollection,\n type PongoDeleteResult,\n type PongoDocument,\n type PongoFilter,\n type PongoInsertManyResult,\n type PongoInsertOneResult,\n type PongoUpdate,\n type PongoUpdateResult,\n type WithId,\n type WithoutId,\n} from '../main';\nimport { constructFilterQuery } from './filter';\nimport { buildUpdateQuery } from './update';\n\nexport const postgresCollection = <T extends PongoDocument>(\n collectionName: string,\n {\n dbName,\n poolOrClient: clientOrPool,\n }: { dbName: string; poolOrClient: pg.Pool | pg.PoolClient },\n): PongoCollection<T> => {\n const execute = <T extends pg.QueryResultRow = pg.QueryResultRow>(sql: SQL) =>\n executeSQL<T>(clientOrPool, sql);\n const SqlFor = collectionSQLBuilder(collectionName);\n\n const createCollection = execute(SqlFor.createCollection());\n\n const collection = {\n dbName,\n collectionName,\n createCollection: async () => {\n await createCollection;\n },\n insertOne: async (document: T): Promise<PongoInsertOneResult> => {\n await createCollection;\n\n const _id = uuid();\n\n const result = await execute(SqlFor.insertOne({ _id, ...document }));\n\n return result.rowCount\n ? { insertedId: _id, acknowledged: true }\n : { insertedId: null, acknowledged: false };\n },\n insertMany: async (documents: T[]): Promise<PongoInsertManyResult> => {\n await createCollection;\n\n const rows = documents.map((doc) => ({\n _id: uuid(),\n ...doc,\n }));\n\n const result = await execute(SqlFor.insertMany(rows));\n\n return {\n acknowledged: result.rowCount === rows.length,\n insertedCount: result.rowCount ?? 0,\n insertedIds: rows.map((d) => d._id),\n };\n },\n updateOne: async (\n filter: PongoFilter<T>,\n update: PongoUpdate<T>,\n ): Promise<PongoUpdateResult> => {\n await createCollection;\n\n const result = await execute(SqlFor.updateOne(filter, update));\n return result.rowCount\n ? { acknowledged: true, modifiedCount: result.rowCount }\n : { acknowledged: false, modifiedCount: 0 };\n },\n replaceOne: async (\n filter: PongoFilter<T>,\n document: WithoutId<T>,\n ): Promise<PongoUpdateResult> => {\n await createCollection;\n\n const result = await execute(SqlFor.replaceOne(filter, document));\n return result.rowCount\n ? { acknowledged: true, modifiedCount: result.rowCount }\n : { acknowledged: false, modifiedCount: 0 };\n },\n updateMany: async (\n filter: PongoFilter<T>,\n update: PongoUpdate<T>,\n ): Promise<PongoUpdateResult> => {\n await createCollection;\n\n const result = await execute(SqlFor.updateMany(filter, update));\n return result.rowCount\n ? { acknowledged: true, modifiedCount: result.rowCount }\n : { acknowledged: false, modifiedCount: 0 };\n },\n deleteOne: async (filter?: PongoFilter<T>): Promise<PongoDeleteResult> => {\n await createCollection;\n\n const result = await execute(SqlFor.deleteOne(filter ?? {}));\n return result.rowCount\n ? { acknowledged: true, deletedCount: result.rowCount }\n : { acknowledged: false, deletedCount: 0 };\n },\n deleteMany: async (filter?: PongoFilter<T>): Promise<PongoDeleteResult> => {\n await createCollection;\n\n const result = await execute(SqlFor.deleteMany(filter ?? {}));\n return result.rowCount\n ? { acknowledged: true, deletedCount: result.rowCount }\n : { acknowledged: false, deletedCount: 0 };\n },\n findOne: async (filter?: PongoFilter<T>): Promise<T | null> => {\n await createCollection;\n\n const result = await execute(SqlFor.findOne(filter ?? {}));\n return (result.rows[0]?.data ?? null) as T | null;\n },\n findOneAndDelete: async (filter: PongoFilter<T>): Promise<T | null> => {\n await createCollection;\n\n const existingDoc = await collection.findOne(filter);\n\n if (existingDoc === null) return null;\n\n await collection.deleteOne(filter);\n return existingDoc;\n },\n findOneAndReplace: async (\n filter: PongoFilter<T>,\n replacement: WithoutId<T>,\n ): Promise<T | null> => {\n await createCollection;\n\n const existingDoc = await collection.findOne(filter);\n\n if (existingDoc === null) return null;\n\n await collection.replaceOne(filter, replacement);\n\n return existingDoc;\n },\n findOneAndUpdate: async (\n filter: PongoFilter<T>,\n update: PongoUpdate<T>,\n ): Promise<T | null> => {\n await createCollection;\n\n const existingDoc = await collection.findOne(filter);\n\n if (existingDoc === null) return null;\n\n await collection.updateOne(filter, update);\n\n return existingDoc;\n },\n handle: async (\n id: string,\n handle: DocumentHandler<T>,\n ): Promise<T | null> => {\n await createCollection;\n\n const byId: PongoFilter<T> = { _id: id };\n\n const existing = await collection.findOne(byId);\n\n const result = await handle(existing);\n\n if (!existing && result) {\n const newDoc = { ...result, _id: id };\n await collection.insertOne({ ...newDoc, _id: id });\n return newDoc;\n }\n\n if (existing && !result) {\n await collection.deleteOne(byId);\n return null;\n }\n\n if (existing && result) await collection.replaceOne(byId, result);\n\n return result;\n },\n find: async (filter?: PongoFilter<T>): Promise<T[]> => {\n await createCollection;\n\n const result = await execute(SqlFor.find(filter ?? {}));\n return result.rows.map((row) => row.data as T);\n },\n countDocuments: async (filter?: PongoFilter<T>): Promise<number> => {\n await createCollection;\n\n const { count } = await single(\n execute<{ count: number }>(SqlFor.countDocuments(filter ?? {})),\n );\n return count;\n },\n drop: async (): Promise<boolean> => {\n await createCollection;\n const result = await execute(SqlFor.drop());\n return (result?.rowCount ?? 0) > 0;\n },\n rename: async (newName: string): Promise<PongoCollection<T>> => {\n await createCollection;\n await execute(SqlFor.rename(newName));\n collectionName = newName;\n return collection;\n },\n };\n\n return collection;\n};\n\nexport const collectionSQLBuilder = (collectionName: string) => ({\n createCollection: (): 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 insertOne: <T>(document: WithId<T>): SQL =>\n sql(\n 'INSERT INTO %I (_id, data) VALUES (%L, %L)',\n collectionName,\n document._id,\n JSON.stringify(document),\n ),\n insertMany: <T>(documents: WithId<T>[]): SQL => {\n const values = documents\n .map((doc) => format('(%L, %L)', doc._id, JSON.stringify(doc)))\n .join(', ');\n return sql('INSERT INTO %I (_id, data) VALUES %s', collectionName, values);\n },\n updateOne: <T>(filter: PongoFilter<T>, update: PongoUpdate<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n const updateQuery = buildUpdateQuery(update);\n\n return sql(\n `WITH cte AS (\n SELECT _id FROM %I WHERE %s LIMIT 1\n )\n UPDATE %I SET data = %s FROM cte WHERE %I._id = cte._id`,\n collectionName,\n filterQuery,\n collectionName,\n updateQuery,\n collectionName,\n );\n },\n replaceOne: <T>(filter: PongoFilter<T>, document: WithoutId<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n\n return sql(\n `UPDATE %I SET data = %L || jsonb_build_object('_id', data->>'_id') WHERE %s`,\n collectionName,\n JSON.stringify(document),\n filterQuery,\n );\n },\n updateMany: <T>(filter: PongoFilter<T>, update: PongoUpdate<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n const updateQuery = buildUpdateQuery(update);\n\n return sql(\n 'UPDATE %I SET data = %s WHERE %s',\n collectionName,\n updateQuery,\n filterQuery,\n );\n },\n deleteOne: <T>(filter: PongoFilter<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n return sql('DELETE FROM %I WHERE %s', collectionName, filterQuery);\n },\n deleteMany: <T>(filter: PongoFilter<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n return sql('DELETE FROM %I WHERE %s', collectionName, filterQuery);\n },\n findOne: <T>(filter: PongoFilter<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n return sql(\n 'SELECT data FROM %I WHERE %s LIMIT 1',\n collectionName,\n filterQuery,\n );\n },\n find: <T>(filter: PongoFilter<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n return sql('SELECT data FROM %I WHERE %s', collectionName, filterQuery);\n },\n countDocuments: <T>(filter: PongoFilter<T>): SQL => {\n const filterQuery = constructFilterQuery(filter);\n return sql(\n 'SELECT COUNT(1) as count FROM %I WHERE %s',\n collectionName,\n 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","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 entries = <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 format from 'pg-format';\nimport { entries } from '../../main/typing';\n\nexport const Operators = {\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\nconst 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\nexport const handleOperator = (\n path: string,\n operator: string,\n value: unknown,\n): string => {\n if (path === '_id') {\n return handleIdOperator(operator, value);\n }\n\n switch (operator) {\n case '$eq':\n return format(\n `(data @> %L::jsonb OR jsonb_path_exists(data, '$.%s[*] ? (@ == %s)'))`,\n JSON.stringify(buildNestedObject(path, value)),\n path,\n JSON.stringify(value),\n );\n case '$gt':\n case '$gte':\n case '$lt':\n case '$lte':\n case '$ne':\n return format(\n `data #>> %L ${OperatorMap[operator]} %L`,\n `{${path.split('.').join(',')}}`,\n value,\n );\n case '$in':\n return format(\n 'data #>> %L IN (%s)',\n `{${path.split('.').join(',')}}`,\n (value as unknown[]).map((v) => format('%L', v)).join(', '),\n );\n case '$nin':\n return format(\n 'data #>> %L NOT IN (%s)',\n `{${path.split('.').join(',')}}`,\n (value as unknown[]).map((v) => format('%L', v)).join(', '),\n );\n case '$elemMatch': {\n const subQuery = entries(value as Record<string, unknown>)\n .map(([subKey, subValue]) =>\n format(`@.\"%s\" == %s`, subKey, JSON.stringify(subValue)),\n )\n .join(' && ');\n return format(\n `jsonb_path_exists(data, '$.%s[*] ? (%s)')`,\n path,\n subQuery,\n );\n }\n case '$all':\n return format(\n 'data @> %L::jsonb',\n JSON.stringify(buildNestedObject(path, value)),\n );\n case '$size':\n return format(\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 handleIdOperator = (operator: string, value: unknown): string => {\n switch (operator) {\n case '$eq':\n return format(`_id = %L`, value);\n case '$gt':\n case '$gte':\n case '$lt':\n case '$lte':\n case '$ne':\n return format(`_id ${OperatorMap[operator]} %L`, value);\n case '$in':\n return format(\n `_id IN (%s)`,\n (value as unknown[]).map((v) => format('%L', v)).join(', '),\n );\n case '$nin':\n return format(\n `_id NOT IN (%s)`,\n (value as unknown[]).map((v) => format('%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 type { PongoFilter } from '../../main';\nimport { entries } from '../../main/typing';\nimport { Operators, handleOperator, hasOperators } 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 entries(value)\n .map(\n ([nestedKey, val]) =>\n isEquality\n ? handleOperator(`${key}.${nestedKey}`, Operators.$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 { sql, type SQL } from '@event-driven-io/dumbo';\nimport type { $inc, $push, $set, $unset, PongoUpdate } from '../../main';\nimport { entries } from '../../main/typing';\n\nexport const buildUpdateQuery = <T>(update: PongoUpdate<T>): SQL =>\n entries(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, JSON.stringify(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 \"jsonb_set(%s, '{%s}', to_jsonb((data->>'%s')::numeric + %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 JSON.stringify([value]),\n );\n }\n return currentUpdateQuery;\n};\n","import { postgresClient, type PongoClientOptions } from '../postgres';\nimport type { PongoCollection, PongoDocument } from './typing/operations';\n\nexport interface DbClient {\n connect(): Promise<void>;\n close(): Promise<void>;\n collection: <T extends PongoDocument>(name: string) => PongoCollection<T>;\n}\n\nexport const getDbClient = (options: PongoClientOptions): DbClient => {\n // This is the place where in the future could come resolution of other database types\n return postgresClient(options);\n};\n","import { getDatabaseNameOrDefault } from '@event-driven-io/dumbo';\nimport pg from 'pg';\nimport { getDbClient, type DbClient } from './dbClient';\nimport type { PongoClient, PongoDb } from './typing/operations';\n\nexport const pongoClient = (\n connectionString: string,\n options: { client?: pg.PoolClient } = {},\n): PongoClient => {\n const defaultDbName = getDatabaseNameOrDefault(connectionString);\n const dbClients: Map<string, DbClient> = new Map();\n\n const dbClient = getDbClient({ connectionString, client: options.client });\n dbClients.set(defaultDbName, 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 getDbClient({\n connectionString,\n dbName: dbName,\n client: options.client,\n }),\n )\n .get(dbName)!\n );\n },\n };\n\n return pongoClient;\n};\n","export class FindCursor<T> {\n private findDocumentsPromise: Promise<T[]>;\n private documents: T[] | null = null;\n private index: number = 0;\n\n constructor(documents: Promise<T[]>) {\n this.findDocumentsPromise = documents;\n }\n\n async toArray(): Promise<T[]> {\n return this.findDocuments();\n }\n\n async forEach(callback: (doc: T) => void): Promise<void> {\n const docs = await this.findDocuments();\n\n for (const doc of docs) {\n callback(doc);\n }\n return Promise.resolve();\n }\n\n hasNext(): boolean {\n if (this.documents === null) throw Error('Error while fetching documents');\n return this.index < this.documents.length;\n }\n\n async next(): Promise<T | null> {\n const docs = await this.findDocuments();\n return this.hasNext() ? docs[this.index++] ?? null : null;\n }\n\n private async findDocuments(): Promise<T[]> {\n this.documents = await this.findDocumentsPromise;\n return this.documents;\n }\n}\n","// src/MongoClientShim.ts\nimport pg from 'pg';\nimport { pongoClient, type PongoClient } from '../main';\nimport { Db } from './mongoDb';\n\nexport class MongoClient {\n private pongoClient: PongoClient;\n\n constructor(\n connectionString: string,\n options: { client?: pg.PoolClient } = {},\n ) {\n this.pongoClient = pongoClient(connectionString, options);\n }\n\n async connect() {\n await this.pongoClient.connect();\n return this;\n }\n\n async close() {\n await this.pongoClient.close();\n }\n\n db(dbName?: string): Db {\n return new Db(this.pongoClient.db(dbName));\n }\n}\n","import {\n Collection as MongoCollection,\n ObjectId,\n type Document,\n} from 'mongodb';\nimport type { DocumentHandler, PongoDb } from '../main';\nimport { Collection } from './mongoCollection';\n\nexport class Db {\n constructor(private pongoDb: PongoDb) {}\n\n collection<T extends Document>(\n collectionName: string,\n ): MongoCollection<T> & {\n handle(id: ObjectId, handle: DocumentHandler<T>): Promise<T | null>;\n } {\n return new Collection<T>(this.pongoDb.collection<T>(collectionName));\n }\n}\n","import type {\n AbstractCursorOptions,\n AggregateOptions,\n AggregationCursor,\n AnyBulkWriteOperation,\n BSONSerializeOptions,\n BulkWriteOptions,\n BulkWriteResult,\n ChangeStream,\n ChangeStreamDocument,\n ChangeStreamOptions,\n CommandOperationOptions,\n CountDocumentsOptions,\n CountOptions,\n CreateIndexesOptions,\n DeleteOptions,\n DeleteResult,\n Document,\n DropCollectionOptions,\n EnhancedOmit,\n EstimatedDocumentCountOptions,\n Filter,\n FindOneAndDeleteOptions,\n FindOneAndReplaceOptions,\n FindOneAndUpdateOptions,\n FindOptions,\n Flatten,\n Hint,\n IndexDescription,\n IndexDescriptionCompact,\n IndexDescriptionInfo,\n IndexInformationOptions,\n IndexSpecification,\n InferIdType,\n InsertManyResult,\n InsertOneOptions,\n InsertOneResult,\n ListIndexesCursor,\n ListSearchIndexesCursor,\n ListSearchIndexesOptions,\n ModifyResult,\n Collection as MongoCollection,\n FindCursor as MongoFindCursor,\n ObjectId,\n OperationOptions,\n OptionalUnlessRequiredId,\n OrderedBulkOperation,\n ReadConcern,\n ReadPreference,\n RenameOptions,\n ReplaceOptions,\n SearchIndexDescription,\n UnorderedBulkOperation,\n UpdateFilter,\n UpdateOptions,\n UpdateResult,\n WithId,\n WithoutId,\n WriteConcern,\n} from 'mongodb';\nimport type { Key } from 'readline';\nimport type {\n DocumentHandler,\n PongoCollection,\n PongoFilter,\n PongoUpdate,\n} from '../main';\nimport { FindCursor } from './findCursor';\n\nexport class Collection<T extends Document> implements MongoCollection<T> {\n private collection: PongoCollection<T>;\n\n constructor(collection: PongoCollection<T>) {\n this.collection = collection;\n }\n get dbName(): string {\n return this.collection.dbName;\n }\n get collectionName(): string {\n return this.collection.collectionName;\n }\n get namespace(): string {\n return `${this.dbName}.${this.collectionName}`;\n }\n get readConcern(): ReadConcern | undefined {\n return undefined;\n }\n get readPreference(): ReadPreference | undefined {\n return undefined;\n }\n get bsonOptions(): BSONSerializeOptions {\n return {};\n }\n get writeConcern(): WriteConcern | undefined {\n return undefined;\n }\n get hint(): Hint | undefined {\n return undefined;\n }\n set hint(v: Hint | undefined) {\n throw new Error('Method not implemented.');\n }\n async insertOne(\n doc: OptionalUnlessRequiredId<T>,\n _options?: InsertOneOptions | undefined,\n ): Promise<InsertOneResult<T>> {\n const result = await this.collection.insertOne(doc as T);\n return {\n acknowledged: result.acknowledged,\n insertedId: result.insertedId as unknown as InferIdType<T>,\n };\n }\n async insertMany(\n docs: OptionalUnlessRequiredId<T>[],\n _options?: BulkWriteOptions | undefined,\n ): Promise<InsertManyResult<T>> {\n const result = await this.collection.insertMany(docs as T[]);\n return {\n acknowledged: result.acknowledged,\n insertedIds: result.insertedIds as unknown as InferIdType<T>[],\n insertedCount: result.insertedCount,\n };\n }\n bulkWrite(\n _operations: AnyBulkWriteOperation<T>[],\n _options?: BulkWriteOptions | undefined,\n ): Promise<BulkWriteResult> {\n throw new Error('Method not implemented.');\n }\n async updateOne(\n filter: Filter<T>,\n update: Document[] | UpdateFilter<T>,\n _options?: UpdateOptions | undefined,\n ): Promise<UpdateResult<T>> {\n const result = await this.collection.updateOne(\n filter as unknown as PongoFilter<T>,\n update as unknown as PongoUpdate<T>,\n );\n\n return {\n acknowledged: result.acknowledged,\n matchedCount: result.modifiedCount,\n modifiedCount: result.modifiedCount,\n upsertedCount: result.modifiedCount,\n upsertedId: null,\n };\n }\n replaceOne(\n filter: Filter<T>,\n document: WithoutId<T>,\n _options?: ReplaceOptions | undefined,\n ): Promise<Document | UpdateResult<T>> {\n return this.collection.replaceOne(\n filter as unknown as PongoFilter<T>,\n document,\n );\n }\n async updateMany(\n filter: Filter<T>,\n update: Document[] | UpdateFilter<T>,\n _options?: UpdateOptions | undefined,\n ): Promise<UpdateResult<T>> {\n const result = await this.collection.updateMany(\n filter as unknown as PongoFilter<T>,\n update as unknown as PongoUpdate<T>,\n );\n\n return {\n acknowledged: result.acknowledged,\n matchedCount: result.modifiedCount,\n modifiedCount: result.modifiedCount,\n upsertedCount: result.modifiedCount,\n upsertedId: null,\n };\n }\n async deleteOne(\n filter?: Filter<T> | undefined,\n _options?: DeleteOptions | undefined,\n ): Promise<DeleteResult> {\n const result = await this.collection.deleteOne(filter as PongoFilter<T>);\n\n return {\n acknowledged: result.acknowledged,\n deletedCount: result.deletedCount,\n };\n }\n async deleteMany(\n filter?: Filter<T> | undefined,\n _options?: DeleteOptions | undefined,\n ): Promise<DeleteResult> {\n const result = await this.collection.deleteMany(filter as PongoFilter<T>);\n\n return {\n acknowledged: result.acknowledged,\n deletedCount: result.deletedCount,\n };\n }\n async rename(\n newName: string,\n _options?: RenameOptions | undefined,\n ): Promise<Collection<Document>> {\n await this.collection.rename(newName);\n\n return this as unknown as Collection<Document>;\n }\n drop(_options?: DropCollectionOptions | undefined): Promise<boolean> {\n return this.collection.drop();\n }\n findOne(): Promise<WithId<T> | null>;\n findOne(filter: Filter<T>): Promise<WithId<T> | null>;\n findOne(\n filter: Filter<T>,\n options: FindOptions<Document>,\n ): Promise<WithId<T> | null>;\n findOne<TS = T>(): Promise<TS | null>;\n findOne<TS = T>(filter: Filter<TS>): Promise<TS | null>;\n findOne<TS = T>(\n filter: Filter<TS>,\n options?: FindOptions<Document> | undefined,\n ): Promise<TS | null>;\n async findOne(\n filter?: unknown,\n _options?: unknown,\n ): Promise<import('mongodb').WithId<T> | T | null> {\n return this.collection.findOne(filter as PongoFilter<T>);\n }\n find(): MongoFindCursor<WithId<T>>;\n find(\n filter: Filter<T>,\n options?: FindOptions<Document> | undefined,\n ): MongoFindCursor<WithId<T>>;\n find<T extends Document>(\n filter: Filter<T>,\n options?: FindOptions<Document> | undefined,\n ): MongoFindCursor<T>;\n find(\n filter?: unknown,\n _options?: unknown,\n ): MongoFindCursor<WithId<T>> | MongoFindCursor<T> {\n return new FindCursor(\n this.collection.find(filter as PongoFilter<T>),\n ) as unknown as MongoFindCursor<T>;\n }\n options(_options?: OperationOptions | undefined): Promise<Document> {\n throw new Error('Method not implemented.');\n }\n isCapped(_options?: OperationOptions | undefined): Promise<boolean> {\n throw new Error('Method not implemented.');\n }\n createIndex(\n _indexSpec: IndexSpecification,\n _options?: CreateIndexesOptions | undefined,\n ): Promise<string> {\n throw new Error('Method not implemented.');\n }\n createIndexes(\n _indexSpecs: IndexDescription[],\n _options?: CreateIndexesOptions | undefined,\n ): Promise<string[]> {\n throw new Error('Method not implemented.');\n }\n dropIndex(\n _indexName: string,\n _options?: CommandOperationOptions | undefined,\n ): Promise<Document> {\n throw new Error('Method not implemented.');\n }\n dropIndexes(\n _options?: CommandOperationOptions | undefined,\n ): Promise<boolean> {\n throw new Error('Method not implemented.');\n }\n listIndexes(_options?: AbstractCursorOptions | undefined): ListIndexesCursor {\n throw new Error('Method not implemented.');\n }\n indexExists(\n _indexes: string | string[],\n _options?: AbstractCursorOptions | undefined,\n ): Promise<boolean> {\n throw new Error('Method not implemented.');\n }\n indexInformation(\n options: IndexInformationOptions & { full: true },\n ): Promise<IndexDescriptionInfo[]>;\n indexInformation(\n options: IndexInformationOptions & { full?: false | undefined },\n ): Promise<IndexDescriptionCompact>;\n indexInformation(\n options: IndexInformationOptions,\n ): Promise<IndexDescriptionCompact | IndexDescriptionInfo[]>;\n indexInformation(): Promise<IndexDescriptionCompact>;\n indexInformation(\n _options?: unknown,\n ):\n | Promise<import('mongodb').IndexDescriptionInfo[]>\n | Promise<import('mongodb').IndexDescriptionCompact>\n | Promise<\n | import('mongodb').IndexDescriptionCompact\n | import('mongodb').IndexDescriptionInfo[]\n > {\n throw new Error('Method not implemented.');\n }\n estimatedDocumentCount(\n _options?: EstimatedDocumentCountOptions | undefined,\n ): Promise<number> {\n return this.collection.countDocuments();\n }\n countDocuments(\n filter?: Filter<T> | undefined,\n _options?: CountDocumentsOptions | undefined,\n ): Promise<number> {\n return this.collection.countDocuments(filter as PongoFilter<T>);\n }\n distinct<Key extends '_id' | keyof EnhancedOmit<T, '_id'>>(\n key: Key,\n ): Promise<Flatten<WithId<T>[Key]>[]>;\n distinct<Key extends '_id' | keyof EnhancedOmit<T, '_id'>>(\n key: Key,\n filter: Filter<T>,\n ): Promise<Flatten<WithId<T>[Key]>[]>;\n distinct<Key extends '_id' | keyof EnhancedOmit<T, '_id'>>(\n key: Key,\n filter: Filter<T>,\n options: CommandOperationOptions,\n ): Promise<Flatten<WithId<T>[Key]>[]>;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n distinct(key: string): Promise<any[]>;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n distinct(key: string, filter: Filter<T>): Promise<any[]>;\n distinct(\n key: string,\n filter: Filter<T>,\n options: CommandOperationOptions, // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ): Promise<any[]>;\n distinct(\n _key: unknown,\n _filter?: unknown,\n _options?: unknown,\n ): // eslint-disable-next-line @typescript-eslint/no-explicit-any\n | Promise<any[]>\n | Promise<import('mongodb').Flatten<import('mongodb').WithId<T>[Key]>[]> {\n throw new Error('Method not implemented.');\n }\n indexes(\n options: IndexInformationOptions & { full?: true | undefined },\n ): Promise<IndexDescriptionInfo[]>;\n indexes(\n options: IndexInformationOptions & { full: false },\n ): Promise<IndexDescriptionCompact>;\n indexes(\n options: IndexInformationOptions,\n ): Promise<IndexDescriptionCompact | IndexDescriptionInfo[]>;\n indexes(\n options?: AbstractCursorOptions | undefined,\n ): Promise<IndexDescriptionInfo[]>;\n indexes(\n _options?: unknown,\n ):\n | Promise<import('mongodb').IndexDescriptionInfo[]>\n | Promise<import('mongodb').IndexDescriptionCompact>\n | Promise<\n | import('mongodb').IndexDescriptionCompact\n | import('mongodb').IndexDescriptionInfo[]\n > {\n throw new Error('Method not implemented.');\n }\n findOneAndDelete(\n filter: Filter<T>,\n options: FindOneAndDeleteOptions & { includeResultMetadata: true },\n ): Promise<ModifyResult<T>>;\n findOneAndDelete(\n filter: Filter<T>,\n options: FindOneAndDeleteOptions & { includeResultMetadata: false },\n ): Promise<WithId<T> | null>;\n findOneAndDelete(\n filter: Filter<T>,\n options: FindOneAndDeleteOptions,\n ): Promise<WithId<T> | null>;\n findOneAndDelete(filter: Filter<T>): Promise<WithId<T> | null>;\n findOneAndDelete(\n filter: unknown,\n _options?: unknown,\n ): Promise<WithId<T> | null | ModifyResult<T>> {\n return this.collection.findOneAndDelete(\n filter as PongoFilter<T>,\n ) as Promise<WithId<T> | null>;\n }\n findOneAndReplace(\n filter: Filter<T>,\n replacement: WithoutId<T>,\n options: FindOneAndReplaceOptions & { includeResultMetadata: true },\n ): Promise<ModifyResult<T>>;\n findOneAndReplace(\n filter: Filter<T>,\n replacement: WithoutId<T>,\n options: FindOneAndReplaceOptions & { includeResultMetadata: false },\n ): Promise<WithId<T> | null>;\n findOneAndReplace(\n filter: Filter<T>,\n replacement: WithoutId<T>,\n options: FindOneAndReplaceOptions,\n ): Promise<WithId<T> | null>;\n findOneAndReplace(\n filter: Filter<T>,\n replacement: WithoutId<T>,\n ): Promise<WithId<T> | null>;\n findOneAndReplace(\n filter: unknown,\n replacement: unknown,\n _options?: unknown,\n ): Promise<WithId<T> | null | ModifyResult<T>> {\n return this.collection.findOneAndReplace(\n filter as PongoFilter<T>,\n replacement as WithoutId<T>,\n ) as Promise<WithId<T> | null>;\n }\n findOneAndUpdate(\n filter: Filter<T>,\n update: UpdateFilter<T>,\n options: FindOneAndUpdateOptions & { includeResultMetadata: true },\n ): Promise<ModifyResult<T>>;\n findOneAndUpdate(\n filter: Filter<T>,\n update: UpdateFilter<T>,\n options: FindOneAndUpdateOptions & { includeResultMetadata: false },\n ): Promise<WithId<T> | null>;\n findOneAndUpdate(\n filter: Filter<T>,\n update: UpdateFilter<T>,\n options: FindOneAndUpdateOptions,\n ): Promise<WithId<T> | null>;\n findOneAndUpdate(\n filter: Filter<T>,\n update: UpdateFilter<T>,\n ): Promise<WithId<T> | null>;\n findOneAndUpdate(\n filter: unknown,\n update: unknown,\n _options?: unknown,\n ): Promise<WithId<T> | null | ModifyResult<T>> {\n return this.collection.findOneAndUpdate(\n filter as PongoFilter<T>,\n update as PongoUpdate<T>,\n ) as Promise<WithId<T> | null>;\n }\n aggregate<T extends Document = Document>(\n _pipeline?: Document[] | undefined,\n _options?: AggregateOptions | undefined,\n ): AggregationCursor<T> {\n throw new Error('Method not implemented.');\n }\n watch<\n TLocal extends Document = T,\n TChange extends Document = ChangeStreamDocument<TLocal>,\n >(\n _pipeline?: Document[] | undefined,\n _options?: ChangeStreamOptions | undefined,\n ): ChangeStream<TLocal, TChange> {\n throw new Error('Method not implemented.');\n }\n initializeUnorderedBulkOp(\n _options?: BulkWriteOptions | undefined,\n ): UnorderedBulkOperation {\n throw new Error('Method not implemented.');\n }\n initializeOrderedBulkOp(\n _options?: BulkWriteOptions | undefined,\n ): OrderedBulkOperation {\n throw new Error('Method not implemented.');\n }\n count(\n filter?: Filter<T> | undefined,\n _options?: CountOptions | undefined,\n ): Promise<number> {\n return this.collection.countDocuments((filter as PongoFilter<T>) ?? {});\n }\n listSearchIndexes(\n options?: ListSearchIndexesOptions | undefined,\n ): ListSearchIndexesCursor;\n listSearchIndexes(\n name: string,\n options?: ListSearchIndexesOptions | undefined,\n ): ListSearchIndexesCursor;\n listSearchIndexes(\n _name?: unknown,\n _options?: unknown,\n ): import('mongodb').ListSearchIndexesCursor {\n throw new Error('Method not implemented.');\n }\n createSearchIndex(_description: SearchIndexDescription): Promise<string> {\n throw new Error('Method not implemented.');\n }\n createSearchIndexes(\n _descriptions: SearchIndexDescription[],\n ): Promise<string[]> {\n throw new Error('Method not implemented.');\n }\n dropSearchIndex(_name: string): Promise<void> {\n throw new Error('Method not implemented.');\n }\n updateSearchIndex(_name: string, _definition: Document): Promise<void> {\n throw new Error('Method not implemented.');\n }\n\n async createCollection(): Promise<void> {\n await this.collection.createCollection();\n }\n async handle(id: ObjectId, handle: DocumentHandler<T>): Promise<T | null> {\n return this.collection.handle(id.toString(), handle);\n }\n}\n"],"mappings":"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","names":["endPool","getDatabaseNameOrDefault","getPool","executeSQL","single","sql","format","uuid","entries","obj","key","value","format","Operators","OperatorMap","isOperator","key","hasOperators","value","handleOperator","path","operator","handleIdOperator","format","buildNestedObject","v","subQuery","entries","subKey","subValue","acc","AND","constructFilterQuery","filter","key","value","isRecord","constructComplexFilterQuery","handleOperator","isEquality","hasOperators","entries","nestedKey","val","Operators","sql","buildUpdateQuery","update","entries","currentUpdateQuery","op","value","buildSetQuery","buildUnsetQuery","buildIncQuery","buildPushQuery","sql","set","unset","k","inc","key","push","postgresCollection","collectionName","dbName","clientOrPool","execute","sql","executeSQL","SqlFor","collectionSQLBuilder","createCollection","collection","document","_id","uuid","documents","rows","doc","result","d","filter","update","existingDoc","replacement","id","handle","byId","existing","newDoc","row","count","single","newName","values","format","filterQuery","constructFilterQuery","updateQuery","buildUpdateQuery","targetName","postgresClient","options","connectionString","dbName","client","managesPoolLifetime","poolOrClient","getPool","endPool","name","postgresCollection","getDatabaseNameOrDefault","getDbClient","options","postgresClient","getDatabaseNameOrDefault","pongoClient","connectionString","options","defaultDbName","getDatabaseNameOrDefault","dbClients","dbClient","getDbClient","db","dbName","FindCursor","documents","callback","docs","doc","Collection","collection","v","doc","_options","result","docs","_operations","filter","update","document","newName","FindCursor","_indexSpec","_indexSpecs","_indexName","_indexes","_key","_filter","replacement","_pipeline","_name","_description","_descriptions","_definition","id","handle","Db","pongoDb","collectionName","Collection","MongoClient","connectionString","options","pongoClient","dbName","Db"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@event-driven-io/pongo",
3
- "version": "0.6.1",
3
+ "version": "0.7.0",
4
4
  "description": "Pongo - Mongo with strong consistency on top of Postgres",
5
5
  "type": "module",
6
6
  "scripts": {