@event-driven-io/pongo 0.17.0-beta.3 → 0.17.0-beta.30
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{chunk-ECQ2CKZE.cjs → chunk-A4DCNQJR.cjs} +45 -43
- package/dist/chunk-A4DCNQJR.cjs.map +1 -0
- package/dist/{chunk-4BL6YWLW.cjs → chunk-BZRKCNRY.cjs} +105 -72
- package/dist/chunk-BZRKCNRY.cjs.map +1 -0
- package/dist/{chunk-NCNRRYVE.js → chunk-H637RRXS.js} +85 -52
- package/dist/chunk-H637RRXS.js.map +1 -0
- package/dist/{chunk-Y7LRKJLJ.js → chunk-TTZGGAZV.js} +40 -38
- package/dist/chunk-TTZGGAZV.js.map +1 -0
- package/dist/cli.cjs +43 -37
- package/dist/cli.cjs.map +1 -1
- package/dist/cli.js +34 -28
- package/dist/cli.js.map +1 -1
- package/dist/cloudflare.cjs +53 -0
- package/dist/cloudflare.cjs.map +1 -0
- package/dist/cloudflare.d.cts +11 -0
- package/dist/cloudflare.d.ts +11 -0
- package/dist/{d1.js → cloudflare.js} +19 -20
- package/dist/cloudflare.js.map +1 -0
- package/dist/index-DxHXL62G.d.cts +8 -0
- package/dist/index-gHRYr05w.d.ts +8 -0
- package/dist/index.cjs +27 -3
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +17 -9
- package/dist/index.d.ts +17 -9
- package/dist/index.js +30 -6
- package/dist/index.js.map +1 -1
- package/dist/pg.cjs +344 -4
- package/dist/pg.cjs.map +1 -1
- package/dist/pg.d.cts +10 -9
- package/dist/pg.d.ts +10 -9
- package/dist/pg.js +350 -10
- package/dist/pg.js.map +1 -1
- package/dist/{pongoCollectionSchemaComponent-t_e9n2Wc.d.cts → pongoCollectionSchemaComponent-B5Oatwu0.d.cts} +44 -34
- package/dist/{pongoCollectionSchemaComponent-t_e9n2Wc.d.ts → pongoCollectionSchemaComponent-B5Oatwu0.d.ts} +44 -34
- package/dist/shim.cjs +12 -14
- package/dist/shim.cjs.map +1 -1
- package/dist/shim.d.cts +4 -4
- package/dist/shim.d.ts +4 -4
- package/dist/shim.js +7 -9
- package/dist/shim.js.map +1 -1
- package/dist/sqlite3.cjs +21 -26
- package/dist/sqlite3.cjs.map +1 -1
- package/dist/sqlite3.d.cts +6 -6
- package/dist/sqlite3.d.ts +6 -6
- package/dist/sqlite3.js +20 -25
- package/dist/sqlite3.js.map +1 -1
- package/package.json +34 -38
- package/dist/chunk-4BL6YWLW.cjs.map +0 -1
- package/dist/chunk-ECQ2CKZE.cjs.map +0 -1
- package/dist/chunk-EYQDS752.js +0 -364
- package/dist/chunk-EYQDS752.js.map +0 -1
- package/dist/chunk-NCNRRYVE.js.map +0 -1
- package/dist/chunk-WH26IXHN.js +0 -10
- package/dist/chunk-WH26IXHN.js.map +0 -1
- package/dist/chunk-WKW4LGF6.cjs +0 -10
- package/dist/chunk-WKW4LGF6.cjs.map +0 -1
- package/dist/chunk-Y7LRKJLJ.js.map +0 -1
- package/dist/chunk-ZPWKWNK2.cjs +0 -364
- package/dist/chunk-ZPWKWNK2.cjs.map +0 -1
- package/dist/d1.cjs +0 -54
- package/dist/d1.cjs.map +0 -1
- package/dist/d1.d.cts +0 -11
- package/dist/d1.d.ts +0 -11
- package/dist/d1.js.map +0 -1
- package/dist/index-BJopB-em.d.cts +0 -7
- package/dist/index-G5DECNb_.d.ts +0 -7
- package/dist/pg-73DOKU64.js +0 -11
- package/dist/pg-73DOKU64.js.map +0 -1
- package/dist/pg-I267A7IL.cjs +0 -11
- package/dist/pg-I267A7IL.cjs.map +0 -1
|
@@ -4,14 +4,9 @@
|
|
|
4
4
|
|
|
5
5
|
|
|
6
6
|
|
|
7
|
-
var
|
|
7
|
+
var _chunkBZRKCNRYcjs = require('./chunk-BZRKCNRY.cjs');
|
|
8
8
|
|
|
9
9
|
// src/storage/sqlite/core/sqlBuilder/index.ts
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
10
|
var _dumbo = require('@event-driven-io/dumbo');
|
|
16
11
|
|
|
17
12
|
// src/storage/sqlite/core/sqlBuilder/filter/index.ts
|
|
@@ -19,7 +14,7 @@ var _dumbo = require('@event-driven-io/dumbo');
|
|
|
19
14
|
|
|
20
15
|
// src/storage/sqlite/core/sqlBuilder/filter/queryOperators.ts
|
|
21
16
|
|
|
22
|
-
var handleOperator = (path, operator, value) => {
|
|
17
|
+
var handleOperator = (path, operator, value, serializer) => {
|
|
23
18
|
if (path === "_id" || path === "_version") {
|
|
24
19
|
return handleMetadataOperator(path, operator, value);
|
|
25
20
|
}
|
|
@@ -43,7 +38,7 @@ var handleOperator = (path, operator, value) => {
|
|
|
43
38
|
case "$lte":
|
|
44
39
|
case "$ne": {
|
|
45
40
|
const jsonPath = buildJsonPath(path);
|
|
46
|
-
return _dumbo.SQL`json_extract(data, '${_dumbo.SQL.plain(jsonPath)}') ${_dumbo.SQL.plain(
|
|
41
|
+
return _dumbo.SQL`json_extract(data, '${_dumbo.SQL.plain(jsonPath)}') ${_dumbo.SQL.plain(_chunkBZRKCNRYcjs.OperatorMap[operator])} ${value}`;
|
|
47
42
|
}
|
|
48
43
|
case "$in": {
|
|
49
44
|
const jsonPath = buildJsonPath(path);
|
|
@@ -64,8 +59,8 @@ var handleOperator = (path, operator, value) => {
|
|
|
64
59
|
return _dumbo.SQL`json_extract(data, '${_dumbo.SQL.plain(jsonPath)}') NOT IN (${inClause})`;
|
|
65
60
|
}
|
|
66
61
|
case "$elemMatch": {
|
|
67
|
-
const subConditions =
|
|
68
|
-
const serializedValue =
|
|
62
|
+
const subConditions = _chunkBZRKCNRYcjs.objectEntries.call(void 0, value).map(([subKey, subValue]) => {
|
|
63
|
+
const serializedValue = serializer.serialize(subValue);
|
|
69
64
|
return `json_extract(value, '$.${subKey}') = json('${serializedValue}')`;
|
|
70
65
|
}).join(" AND ");
|
|
71
66
|
const jsonPath = buildJsonPath(path);
|
|
@@ -73,7 +68,7 @@ var handleOperator = (path, operator, value) => {
|
|
|
73
68
|
}
|
|
74
69
|
case "$all": {
|
|
75
70
|
const jsonPath = buildJsonPath(path);
|
|
76
|
-
const serializedValue =
|
|
71
|
+
const serializedValue = serializer.serialize(value);
|
|
77
72
|
return _dumbo.SQL`(SELECT COUNT(*) FROM json_each(json(${serializedValue})) WHERE json_each.value NOT IN (SELECT value FROM json_each(data, '${_dumbo.SQL.plain(jsonPath)}'))) = 0`;
|
|
78
73
|
}
|
|
79
74
|
case "$size": {
|
|
@@ -93,7 +88,7 @@ var handleMetadataOperator = (fieldName, operator, value) => {
|
|
|
93
88
|
case "$lt":
|
|
94
89
|
case "$lte":
|
|
95
90
|
case "$ne":
|
|
96
|
-
return _dumbo.SQL`${_dumbo.SQL.plain(fieldName)} ${_dumbo.SQL.plain(
|
|
91
|
+
return _dumbo.SQL`${_dumbo.SQL.plain(fieldName)} ${_dumbo.SQL.plain(_chunkBZRKCNRYcjs.OperatorMap[operator])} ${value}`;
|
|
97
92
|
case "$in": {
|
|
98
93
|
const values = value;
|
|
99
94
|
const inClause = _dumbo.SQL.merge(
|
|
@@ -120,17 +115,22 @@ var buildJsonPath = (path) => {
|
|
|
120
115
|
|
|
121
116
|
// src/storage/sqlite/core/sqlBuilder/filter/index.ts
|
|
122
117
|
var AND = "AND";
|
|
123
|
-
var constructFilterQuery = (filter) => _dumbo.SQL.merge(
|
|
118
|
+
var constructFilterQuery = (filter, serializer) => _dumbo.SQL.merge(
|
|
124
119
|
Object.entries(filter).map(
|
|
125
|
-
([key, value]) => isRecord(value) ? constructComplexFilterQuery(key, value) : handleOperator(key, "$eq", value)
|
|
120
|
+
([key, value]) => isRecord(value) ? constructComplexFilterQuery(key, value, serializer) : handleOperator(key, "$eq", value, serializer)
|
|
126
121
|
),
|
|
127
122
|
` ${AND} `
|
|
128
123
|
);
|
|
129
|
-
var constructComplexFilterQuery = (key, value) => {
|
|
130
|
-
const isEquality = !
|
|
124
|
+
var constructComplexFilterQuery = (key, value, serializer) => {
|
|
125
|
+
const isEquality = !_chunkBZRKCNRYcjs.hasOperators.call(void 0, value);
|
|
131
126
|
return _dumbo.SQL.merge(
|
|
132
|
-
|
|
133
|
-
([nestedKey, val]) => isEquality ? handleOperator(
|
|
127
|
+
_chunkBZRKCNRYcjs.objectEntries.call(void 0, value).map(
|
|
128
|
+
([nestedKey, val]) => isEquality ? handleOperator(
|
|
129
|
+
`${key}.${nestedKey}`,
|
|
130
|
+
_chunkBZRKCNRYcjs.QueryOperators.$eq,
|
|
131
|
+
val,
|
|
132
|
+
serializer
|
|
133
|
+
) : handleOperator(key, nestedKey, val, serializer)
|
|
134
134
|
),
|
|
135
135
|
` ${AND} `
|
|
136
136
|
);
|
|
@@ -139,24 +139,24 @@ var isRecord = (value) => value !== null && typeof value === "object" && !Array.
|
|
|
139
139
|
|
|
140
140
|
// src/storage/sqlite/core/sqlBuilder/update/index.ts
|
|
141
141
|
|
|
142
|
-
var buildUpdateQuery = (update) =>
|
|
142
|
+
var buildUpdateQuery = (update, serializer) => _chunkBZRKCNRYcjs.objectEntries.call(void 0, update).reduce(
|
|
143
143
|
(currentUpdateQuery, [op, value]) => {
|
|
144
144
|
switch (op) {
|
|
145
145
|
case "$set":
|
|
146
|
-
return buildSetQuery(value, currentUpdateQuery);
|
|
146
|
+
return buildSetQuery(value, currentUpdateQuery, serializer);
|
|
147
147
|
case "$unset":
|
|
148
148
|
return buildUnsetQuery(value, currentUpdateQuery);
|
|
149
149
|
case "$inc":
|
|
150
150
|
return buildIncQuery(value, currentUpdateQuery);
|
|
151
151
|
case "$push":
|
|
152
|
-
return buildPushQuery(value, currentUpdateQuery);
|
|
152
|
+
return buildPushQuery(value, currentUpdateQuery, serializer);
|
|
153
153
|
default:
|
|
154
154
|
return currentUpdateQuery;
|
|
155
155
|
}
|
|
156
156
|
},
|
|
157
157
|
_dumbo.SQL`data`
|
|
158
158
|
);
|
|
159
|
-
var buildSetQuery = (set, currentUpdateQuery) => _dumbo.SQL`json_patch(${currentUpdateQuery}, ${
|
|
159
|
+
var buildSetQuery = (set, currentUpdateQuery, serializer) => _dumbo.SQL`json_patch(${currentUpdateQuery}, ${serializer.serialize(set)})`;
|
|
160
160
|
var buildUnsetQuery = (unset, currentUpdateQuery) => {
|
|
161
161
|
const keys = Object.keys(unset);
|
|
162
162
|
let query = currentUpdateQuery;
|
|
@@ -171,9 +171,9 @@ var buildIncQuery = (inc, currentUpdateQuery) => {
|
|
|
171
171
|
}
|
|
172
172
|
return currentUpdateQuery;
|
|
173
173
|
};
|
|
174
|
-
var buildPushQuery = (push, currentUpdateQuery) => {
|
|
174
|
+
var buildPushQuery = (push, currentUpdateQuery, serializer) => {
|
|
175
175
|
for (const [key, value] of Object.entries(push)) {
|
|
176
|
-
const serializedValue =
|
|
176
|
+
const serializedValue = serializer.serialize(value);
|
|
177
177
|
currentUpdateQuery = _dumbo.SQL`json_set(${currentUpdateQuery}, '$.${_dumbo.SQL.plain(key)}', CASE
|
|
178
178
|
WHEN json_type(json_extract(${currentUpdateQuery}, '$.${_dumbo.SQL.plain(key)}')) = 'array'
|
|
179
179
|
THEN json_insert(json_extract(${currentUpdateQuery}, '$.${_dumbo.SQL.plain(key)}'), '$[#]', json(${serializedValue}))
|
|
@@ -200,7 +200,7 @@ var pongoCollectionSQLiteMigrations = (collectionName) => [
|
|
|
200
200
|
createCollection(collectionName)
|
|
201
201
|
])
|
|
202
202
|
];
|
|
203
|
-
var sqliteSQLBuilder = (collectionName) => ({
|
|
203
|
+
var sqliteSQLBuilder = (collectionName, serializer) => ({
|
|
204
204
|
createCollection: () => createCollection(collectionName),
|
|
205
205
|
insertOne: (document) => {
|
|
206
206
|
const serialized = document;
|
|
@@ -214,7 +214,7 @@ var sqliteSQLBuilder = (collectionName) => ({
|
|
|
214
214
|
insertMany: (documents) => {
|
|
215
215
|
const values = _dumbo.SQL.merge(
|
|
216
216
|
documents.map(
|
|
217
|
-
(doc) => _dumbo.SQL`(${doc._id}, ${
|
|
217
|
+
(doc) => _dumbo.SQL`(${doc._id}, ${serializer.serialize(doc)}, ${_nullishCoalesce(doc._version, () => ( 1n))})`
|
|
218
218
|
),
|
|
219
219
|
","
|
|
220
220
|
);
|
|
@@ -223,10 +223,10 @@ var sqliteSQLBuilder = (collectionName) => ({
|
|
|
223
223
|
RETURNING _id;`;
|
|
224
224
|
},
|
|
225
225
|
updateOne: (filter, update, options) => {
|
|
226
|
-
const expectedVersion =
|
|
226
|
+
const expectedVersion = _chunkBZRKCNRYcjs.expectedVersionValue.call(void 0, _optionalChain([options, 'optionalAccess', _ => _.expectedVersion]));
|
|
227
227
|
const expectedVersionCheck = expectedVersion != null ? _dumbo.SQL`AND _version = ${expectedVersion}` : _dumbo.SQL``;
|
|
228
|
-
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter);
|
|
229
|
-
const updateQuery = _dumbo.isSQL.call(void 0, update) ? update : buildUpdateQuery(update);
|
|
228
|
+
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter, serializer);
|
|
229
|
+
const updateQuery = _dumbo.isSQL.call(void 0, update) ? update : buildUpdateQuery(update, serializer);
|
|
230
230
|
return _dumbo.SQL`
|
|
231
231
|
UPDATE ${_dumbo.SQL.identifier(collectionName)}
|
|
232
232
|
SET
|
|
@@ -245,13 +245,13 @@ var sqliteSQLBuilder = (collectionName) => ({
|
|
|
245
245
|
1 as modified;`;
|
|
246
246
|
},
|
|
247
247
|
replaceOne: (filter, document, options) => {
|
|
248
|
-
const expectedVersion =
|
|
248
|
+
const expectedVersion = _chunkBZRKCNRYcjs.expectedVersionValue.call(void 0, _optionalChain([options, 'optionalAccess', _2 => _2.expectedVersion]));
|
|
249
249
|
const expectedVersionCheck = expectedVersion != null ? _dumbo.SQL`AND _version = ${expectedVersion}` : _dumbo.SQL``;
|
|
250
|
-
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter);
|
|
250
|
+
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter, serializer);
|
|
251
251
|
return _dumbo.SQL`
|
|
252
252
|
UPDATE ${_dumbo.SQL.identifier(collectionName)}
|
|
253
253
|
SET
|
|
254
|
-
data = json_patch(${
|
|
254
|
+
data = json_patch(${serializer.serialize(document)}, json_object('_id', _id, '_version', cast(_version + 1 as TEXT))),
|
|
255
255
|
_version = _version + 1,
|
|
256
256
|
_updated = datetime('now')
|
|
257
257
|
WHERE _id = (
|
|
@@ -266,8 +266,8 @@ var sqliteSQLBuilder = (collectionName) => ({
|
|
|
266
266
|
1 AS modified;`;
|
|
267
267
|
},
|
|
268
268
|
updateMany: (filter, update) => {
|
|
269
|
-
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter);
|
|
270
|
-
const updateQuery = _dumbo.isSQL.call(void 0, update) ? update : buildUpdateQuery(update);
|
|
269
|
+
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter, serializer);
|
|
270
|
+
const updateQuery = _dumbo.isSQL.call(void 0, update) ? update : buildUpdateQuery(update, serializer);
|
|
271
271
|
return _dumbo.SQL`
|
|
272
272
|
UPDATE ${_dumbo.SQL.identifier(collectionName)}
|
|
273
273
|
SET
|
|
@@ -278,9 +278,9 @@ var sqliteSQLBuilder = (collectionName) => ({
|
|
|
278
278
|
RETURNING _id;`;
|
|
279
279
|
},
|
|
280
280
|
deleteOne: (filter, options) => {
|
|
281
|
-
const expectedVersion =
|
|
281
|
+
const expectedVersion = _chunkBZRKCNRYcjs.expectedVersionValue.call(void 0, _optionalChain([options, 'optionalAccess', _3 => _3.expectedVersion]));
|
|
282
282
|
const expectedVersionCheck = expectedVersion != null ? _dumbo.SQL`AND _version = ${expectedVersion}` : _dumbo.SQL``;
|
|
283
|
-
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter);
|
|
283
|
+
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter, serializer);
|
|
284
284
|
return _dumbo.SQL`
|
|
285
285
|
DELETE FROM ${_dumbo.SQL.identifier(collectionName)}
|
|
286
286
|
WHERE _id = (
|
|
@@ -294,17 +294,19 @@ var sqliteSQLBuilder = (collectionName) => ({
|
|
|
294
294
|
1 AS deleted;`;
|
|
295
295
|
},
|
|
296
296
|
deleteMany: (filter) => {
|
|
297
|
-
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter);
|
|
297
|
+
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter, serializer);
|
|
298
298
|
return _dumbo.SQL`DELETE FROM ${_dumbo.SQL.identifier(collectionName)} ${where(filterQuery)} RETURNING _id`;
|
|
299
299
|
},
|
|
300
300
|
findOne: (filter) => {
|
|
301
|
-
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter);
|
|
302
|
-
return _dumbo.SQL`SELECT data FROM ${_dumbo.SQL.identifier(collectionName)} ${where(filterQuery)} LIMIT 1;`;
|
|
301
|
+
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter, serializer);
|
|
302
|
+
return _dumbo.SQL`SELECT data, _version FROM ${_dumbo.SQL.identifier(collectionName)} ${where(filterQuery)} LIMIT 1;`;
|
|
303
303
|
},
|
|
304
304
|
find: (filter, options) => {
|
|
305
|
-
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter);
|
|
305
|
+
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter, serializer);
|
|
306
306
|
const query = [];
|
|
307
|
-
query.push(
|
|
307
|
+
query.push(
|
|
308
|
+
_dumbo.SQL`SELECT data, _version FROM ${_dumbo.SQL.identifier(collectionName)}`
|
|
309
|
+
);
|
|
308
310
|
query.push(where(filterQuery));
|
|
309
311
|
if (_optionalChain([options, 'optionalAccess', _4 => _4.limit])) {
|
|
310
312
|
query.push(_dumbo.SQL`LIMIT ${options.limit}`);
|
|
@@ -315,7 +317,7 @@ var sqliteSQLBuilder = (collectionName) => ({
|
|
|
315
317
|
return _dumbo.SQL.merge([...query, _dumbo.SQL`;`]);
|
|
316
318
|
},
|
|
317
319
|
countDocuments: (filter) => {
|
|
318
|
-
const filterQuery = _dumbo.SQL.check.isSQL(filter) ? filter : constructFilterQuery(filter);
|
|
320
|
+
const filterQuery = _dumbo.SQL.check.isSQL(filter) ? filter : constructFilterQuery(filter, serializer);
|
|
319
321
|
return _dumbo.SQL`SELECT COUNT(1) as count FROM ${_dumbo.SQL.identifier(collectionName)} ${where(filterQuery)};`;
|
|
320
322
|
},
|
|
321
323
|
rename: (newName) => _dumbo.SQL`ALTER TABLE ${_dumbo.SQL.identifier(collectionName)} RENAME TO ${_dumbo.SQL.identifier(newName)};`,
|
|
@@ -327,4 +329,4 @@ var where = (filterQuery) => _dumbo.SQL.check.isEmpty(filterQuery) ? _dumbo.SQL.
|
|
|
327
329
|
|
|
328
330
|
|
|
329
331
|
exports.pongoCollectionSQLiteMigrations = pongoCollectionSQLiteMigrations; exports.sqliteSQLBuilder = sqliteSQLBuilder;
|
|
330
|
-
//# sourceMappingURL=chunk-
|
|
332
|
+
//# sourceMappingURL=chunk-A4DCNQJR.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/home/runner/work/Pongo/Pongo/src/packages/pongo/dist/chunk-A4DCNQJR.cjs","../src/storage/sqlite/core/sqlBuilder/index.ts","../src/storage/sqlite/core/sqlBuilder/filter/index.ts","../src/storage/sqlite/core/sqlBuilder/filter/queryOperators.ts","../src/storage/sqlite/core/sqlBuilder/update/index.ts"],"names":["SQL"],"mappings":"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","file":"/home/runner/work/Pongo/Pongo/src/packages/pongo/dist/chunk-A4DCNQJR.cjs","sourcesContent":[null,"import type { JSONSerializer } from '@event-driven-io/dumbo';\nimport { isSQL, SQL, sqlMigration } from '@event-driven-io/dumbo';\nimport {\n expectedVersionValue,\n type DeleteOneOptions,\n type FindOptions,\n type OptionalUnlessRequiredIdAndVersion,\n type PongoCollectionSQLBuilder,\n type PongoFilter,\n type PongoUpdate,\n type ReplaceOneOptions,\n type UpdateOneOptions,\n type WithoutId,\n} from '../../../../core';\nimport { constructFilterQuery } from './filter';\nimport { buildUpdateQuery } from './update';\n\nconst createCollection = (collectionName: string): SQL =>\n SQL`\n CREATE TABLE IF NOT EXISTS ${SQL.identifier(collectionName)} (\n _id TEXT PRIMARY KEY,\n data JSON NOT NULL,\n metadata JSON NOT NULL DEFAULT '{}',\n _version INTEGER NOT NULL DEFAULT 1,\n _partition TEXT NOT NULL DEFAULT 'png_global',\n _archived INTEGER NOT NULL DEFAULT 0,\n _created TEXT NOT NULL DEFAULT (datetime('now')),\n _updated TEXT NOT NULL DEFAULT (datetime('now'))\n )`;\n\nexport const pongoCollectionSQLiteMigrations = (collectionName: string) => [\n sqlMigration(`pongoCollection:${collectionName}:001:createtable`, [\n createCollection(collectionName),\n ]),\n];\n\nexport const sqliteSQLBuilder = (\n collectionName: string,\n serializer: JSONSerializer,\n): PongoCollectionSQLBuilder => ({\n createCollection: (): SQL => createCollection(collectionName),\n insertOne: <T>(document: OptionalUnlessRequiredIdAndVersion<T>): SQL => {\n const serialized = document;\n const id = document._id;\n const version = document._version ?? 1n;\n\n return SQL`\n INSERT OR IGNORE INTO ${SQL.identifier(collectionName)} (_id, data, _version)\n VALUES (${id}, ${serialized}, ${version})\n RETURNING _id;`;\n },\n insertMany: <T>(documents: OptionalUnlessRequiredIdAndVersion<T>[]): SQL => {\n const values = SQL.merge(\n documents.map(\n (doc) =>\n SQL`(${doc._id}, ${serializer.serialize(doc)}, ${doc._version ?? 1n})`,\n ),\n ',',\n );\n\n return SQL`\n INSERT OR IGNORE INTO ${SQL.identifier(collectionName)} (_id, data, _version) VALUES ${values}\n RETURNING _id;`;\n },\n updateOne: <T>(\n filter: PongoFilter<T> | SQL,\n update: PongoUpdate<T> | SQL,\n options?: UpdateOneOptions,\n ): SQL => {\n const expectedVersion = expectedVersionValue(options?.expectedVersion);\n const expectedVersionCheck =\n expectedVersion != null ? SQL`AND _version = ${expectedVersion}` : SQL``;\n\n const filterQuery = isSQL(filter)\n ? filter\n : constructFilterQuery(filter, serializer);\n const updateQuery = isSQL(update)\n ? update\n : buildUpdateQuery(update, serializer);\n\n return SQL`\n UPDATE ${SQL.identifier(collectionName)}\n SET\n data = json_patch(${updateQuery}, json_object('_id', _id, '_version', cast(_version + 1 as TEXT))),\n _version = _version + 1,\n _updated = datetime('now')\n WHERE _id = (\n SELECT _id FROM ${SQL.identifier(collectionName)}\n ${where(filterQuery)}\n LIMIT 1\n ) ${expectedVersionCheck}\n RETURNING\n _id,\n cast(_version as TEXT) as version,\n 1 as matched,\n 1 as modified;`;\n },\n replaceOne: <T>(\n filter: PongoFilter<T> | SQL,\n document: WithoutId<T>,\n options?: ReplaceOneOptions,\n ): SQL => {\n const expectedVersion = expectedVersionValue(options?.expectedVersion);\n const expectedVersionCheck =\n expectedVersion != null ? SQL`AND _version = ${expectedVersion}` : SQL``;\n\n const filterQuery = isSQL(filter)\n ? filter\n : constructFilterQuery(filter, serializer);\n\n return SQL`\n UPDATE ${SQL.identifier(collectionName)}\n SET\n data = json_patch(${serializer.serialize(document)}, json_object('_id', _id, '_version', cast(_version + 1 as TEXT))),\n _version = _version + 1,\n _updated = datetime('now')\n WHERE _id = (\n SELECT _id FROM ${SQL.identifier(collectionName)}\n ${where(filterQuery)}\n LIMIT 1\n ) ${expectedVersionCheck}\n RETURNING\n _id,\n cast(_version as TEXT) AS version,\n 1 AS matched,\n 1 AS modified;`;\n },\n updateMany: <T>(\n filter: PongoFilter<T> | SQL,\n update: PongoUpdate<T> | SQL,\n ): SQL => {\n const filterQuery = isSQL(filter)\n ? filter\n : constructFilterQuery(filter, serializer);\n const updateQuery = isSQL(update)\n ? update\n : buildUpdateQuery(update, serializer);\n\n return SQL`\n UPDATE ${SQL.identifier(collectionName)}\n SET\n data = json_patch(${updateQuery}, json_object('_version', cast(_version + 1 as TEXT))),\n _version = _version + 1,\n _updated = datetime('now')\n ${where(filterQuery)}\n RETURNING _id;`;\n },\n deleteOne: <T>(\n filter: PongoFilter<T> | SQL,\n options?: DeleteOneOptions,\n ): SQL => {\n const expectedVersion = expectedVersionValue(options?.expectedVersion);\n const expectedVersionCheck =\n expectedVersion != null ? SQL`AND _version = ${expectedVersion}` : SQL``;\n\n const filterQuery = isSQL(filter)\n ? filter\n : constructFilterQuery(filter, serializer);\n\n return SQL`\n DELETE FROM ${SQL.identifier(collectionName)}\n WHERE _id = (\n SELECT _id FROM ${SQL.identifier(collectionName)}\n ${where(filterQuery)}\n LIMIT 1\n ) ${expectedVersionCheck}\n RETURNING\n _id,\n 1 AS matched,\n 1 AS deleted;`;\n },\n deleteMany: <T>(filter: PongoFilter<T> | SQL): SQL => {\n const filterQuery = isSQL(filter)\n ? filter\n : constructFilterQuery(filter, serializer);\n\n return SQL`DELETE FROM ${SQL.identifier(collectionName)} ${where(filterQuery)} RETURNING _id`;\n },\n findOne: <T>(filter: PongoFilter<T> | SQL): SQL => {\n const filterQuery = isSQL(filter)\n ? filter\n : constructFilterQuery(filter, serializer);\n\n return SQL`SELECT data, _version FROM ${SQL.identifier(collectionName)} ${where(filterQuery)} LIMIT 1;`;\n },\n find: <T>(filter: PongoFilter<T> | SQL, options?: FindOptions): SQL => {\n const filterQuery = isSQL(filter)\n ? filter\n : constructFilterQuery(filter, serializer);\n const query: SQL[] = [];\n\n query.push(\n SQL`SELECT data, _version FROM ${SQL.identifier(collectionName)}`,\n );\n\n query.push(where(filterQuery));\n\n if (options?.limit) {\n query.push(SQL`LIMIT ${options.limit}`);\n }\n\n if (options?.skip) {\n query.push(SQL`OFFSET ${options.skip}`);\n }\n\n return SQL.merge([...query, SQL`;`]);\n },\n countDocuments: <T>(filter: PongoFilter<T> | SQL): SQL => {\n const filterQuery = SQL.check.isSQL(filter)\n ? filter\n : constructFilterQuery(filter, serializer);\n return SQL`SELECT COUNT(1) as count FROM ${SQL.identifier(collectionName)} ${where(filterQuery)};`;\n },\n rename: (newName: string): SQL =>\n SQL`ALTER TABLE ${SQL.identifier(collectionName)} RENAME TO ${SQL.identifier(newName)};`,\n drop: (targetName: string = collectionName): SQL =>\n SQL`DROP TABLE IF EXISTS ${SQL.identifier(targetName)}`,\n});\n\nconst where = (filterQuery: SQL): SQL =>\n SQL.check.isEmpty(filterQuery)\n ? SQL.EMPTY\n : SQL.merge([SQL`WHERE `, filterQuery]);\n","import type { JSONSerializer } from '@event-driven-io/dumbo';\nimport { SQL } from '@event-driven-io/dumbo';\nimport {\n hasOperators,\n objectEntries,\n QueryOperators,\n type PongoFilter,\n} from '../../../../../core';\nimport { handleOperator } from './queryOperators';\n\nexport * from './queryOperators';\n\nconst AND = 'AND';\n\nexport const constructFilterQuery = <T>(\n filter: PongoFilter<T>,\n serializer: JSONSerializer,\n): SQL =>\n SQL.merge(\n Object.entries(filter).map(([key, value]) =>\n isRecord(value)\n ? constructComplexFilterQuery(key, value, serializer)\n : handleOperator(key, '$eq', value, serializer),\n ),\n ` ${AND} `,\n );\n\nconst constructComplexFilterQuery = (\n key: string,\n value: Record<string, unknown>,\n serializer: JSONSerializer,\n): SQL => {\n const isEquality = !hasOperators(value);\n\n return SQL.merge(\n objectEntries(value).map(([nestedKey, val]) =>\n isEquality\n ? handleOperator(\n `${key}.${nestedKey}`,\n QueryOperators.$eq,\n val,\n serializer,\n )\n : handleOperator(key, nestedKey, val, serializer),\n ),\n ` ${AND} `,\n );\n};\n\nconst isRecord = (value: unknown): value is Record<string, unknown> =>\n value !== null && typeof value === 'object' && !Array.isArray(value);\n","import type { JSONSerializer } from '@event-driven-io/dumbo';\nimport { SQL } from '@event-driven-io/dumbo';\nimport { objectEntries, OperatorMap } from '../../../../../core';\n\nexport const handleOperator = (\n path: string,\n operator: string,\n value: unknown,\n serializer: JSONSerializer,\n): SQL => {\n if (path === '_id' || path === '_version') {\n return handleMetadataOperator(path, operator, value);\n }\n\n switch (operator) {\n case '$eq': {\n const jsonPath = buildJsonPath(path);\n\n return SQL`(\n json_extract(data, '${SQL.plain(jsonPath)}') = ${value}\n OR (\n json_type(data, '${SQL.plain(jsonPath)}') = 'array'\n AND EXISTS(\n SELECT 1 FROM json_each(data, '${SQL.plain(jsonPath)}')\n WHERE json_each.value = ${value}\n )\n )\n )`;\n }\n case '$gt':\n case '$gte':\n case '$lt':\n case '$lte':\n case '$ne': {\n const jsonPath = buildJsonPath(path);\n\n return SQL`json_extract(data, '${SQL.plain(jsonPath)}') ${SQL.plain(OperatorMap[operator])} ${value}`;\n }\n case '$in': {\n const jsonPath = buildJsonPath(path);\n const values = value as unknown[];\n const inClause = SQL.merge(\n values.map((v) => SQL`${v}`),\n ', ',\n );\n\n return SQL`json_extract(data, '${SQL.plain(jsonPath)}') IN (${inClause})`;\n }\n case '$nin': {\n const jsonPath = buildJsonPath(path);\n const values = value as unknown[];\n const inClause = SQL.merge(\n values.map((v) => SQL`${v}`),\n ', ',\n );\n\n return SQL`json_extract(data, '${SQL.plain(jsonPath)}') NOT IN (${inClause})`;\n }\n case '$elemMatch': {\n const subConditions = objectEntries(value as Record<string, unknown>)\n .map(([subKey, subValue]) => {\n const serializedValue = serializer.serialize(subValue);\n return `json_extract(value, '$.${subKey}') = json('${serializedValue}')`;\n })\n .join(' AND ');\n\n const jsonPath = buildJsonPath(path);\n return SQL`EXISTS(SELECT 1 FROM json_each(data, '${SQL.plain(jsonPath)}') WHERE ${SQL.plain(subConditions)})`;\n }\n case '$all': {\n const jsonPath = buildJsonPath(path);\n const serializedValue = serializer.serialize(value);\n\n return SQL`(SELECT COUNT(*) FROM json_each(json(${serializedValue})) WHERE json_each.value NOT IN (SELECT value FROM json_each(data, '${SQL.plain(jsonPath)}'))) = 0`;\n }\n case '$size': {\n const jsonPath = buildJsonPath(path);\n\n return SQL`json_array_length(json_extract(data, '${SQL.plain(jsonPath)}')) = ${value}`;\n }\n default:\n throw new Error(`Unsupported operator: ${operator}`);\n }\n};\n\nconst handleMetadataOperator = (\n fieldName: string,\n operator: string,\n value: unknown,\n): SQL => {\n switch (operator) {\n case '$eq':\n return SQL`${SQL.plain(fieldName)} = ${value}`;\n case '$gt':\n case '$gte':\n case '$lt':\n case '$lte':\n case '$ne':\n return SQL`${SQL.plain(fieldName)} ${SQL.plain(OperatorMap[operator])} ${value}`;\n case '$in': {\n const values = value as unknown[];\n const inClause = SQL.merge(\n values.map((v) => SQL`${v}`),\n ', ',\n );\n return SQL`${SQL.plain(fieldName)} IN (${inClause})`;\n }\n case '$nin': {\n const values = value as unknown[];\n const inClause = SQL.merge(\n values.map((v) => SQL`${v}`),\n ', ',\n );\n return SQL`${SQL.plain(fieldName)} NOT IN (${inClause})`;\n }\n default:\n throw new Error(`Unsupported operator: ${operator}`);\n }\n};\n\nconst buildJsonPath = (path: string): string => {\n return `$.${path}`;\n};\n","import type { JSONSerializer } from '@event-driven-io/dumbo';\nimport { SQL } from '@event-driven-io/dumbo';\nimport {\n objectEntries,\n type $inc,\n type $push,\n type $set,\n type $unset,\n type PongoUpdate,\n} from '../../../../../core';\n\nexport const buildUpdateQuery = <T>(\n update: PongoUpdate<T>,\n serializer: JSONSerializer,\n): SQL =>\n objectEntries(update).reduce(\n (currentUpdateQuery, [op, value]) => {\n switch (op) {\n case '$set':\n return buildSetQuery(value, currentUpdateQuery, serializer);\n case '$unset':\n return buildUnsetQuery(value, currentUpdateQuery);\n case '$inc':\n return buildIncQuery(value, currentUpdateQuery);\n case '$push':\n return buildPushQuery(value, currentUpdateQuery, serializer);\n default:\n return currentUpdateQuery;\n }\n },\n SQL`data`,\n );\n\nexport const buildSetQuery = <T>(\n set: $set<T>,\n currentUpdateQuery: SQL,\n serializer: JSONSerializer,\n): SQL => SQL`json_patch(${currentUpdateQuery}, ${serializer.serialize(set)})`;\n\nexport const buildUnsetQuery = <T>(\n unset: $unset<T>,\n currentUpdateQuery: SQL,\n): SQL => {\n const keys = Object.keys(unset);\n let query = currentUpdateQuery;\n for (const key of keys) {\n query = SQL`json_remove(${query}, '$.${SQL.plain(key)}')`;\n }\n return query;\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 =\n typeof value === 'bigint'\n ? SQL`json_set(${currentUpdateQuery}, '$.${SQL.plain(key)}', CAST((COALESCE(json_extract(${currentUpdateQuery}, '$.${SQL.plain(key)}'), 0) + ${value}) AS TEXT))`\n : SQL`json_set(${currentUpdateQuery}, '$.${SQL.plain(key)}', COALESCE(json_extract(${currentUpdateQuery}, '$.${SQL.plain(key)}'), 0) + ${value})`;\n }\n return currentUpdateQuery;\n};\n\nexport const buildPushQuery = <T>(\n push: $push<T>,\n currentUpdateQuery: SQL,\n serializer: JSONSerializer,\n): SQL => {\n for (const [key, value] of Object.entries(push)) {\n const serializedValue = serializer.serialize(value);\n currentUpdateQuery = SQL`json_set(${currentUpdateQuery}, '$.${SQL.plain(key)}', CASE\n WHEN json_type(json_extract(${currentUpdateQuery}, '$.${SQL.plain(key)}')) = 'array'\n THEN json_insert(json_extract(${currentUpdateQuery}, '$.${SQL.plain(key)}'), '$[#]', json(${serializedValue}))\n ELSE json_array(json(${serializedValue}))\n END)`;\n }\n return currentUpdateQuery;\n};\n"]}
|