@event-driven-io/pongo 0.17.0-beta.35 → 0.17.0-beta.36
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli.cjs +311 -494
- package/dist/cli.cjs.map +1 -1
- package/dist/cli.d.cts +4 -4
- package/dist/cli.d.ts +4 -3
- package/dist/cli.js +279 -494
- package/dist/cli.js.map +1 -1
- package/dist/cloudflare.cjs +36 -48
- package/dist/cloudflare.cjs.map +1 -1
- package/dist/cloudflare.d.cts +7 -7
- package/dist/cloudflare.d.ts +7 -7
- package/dist/cloudflare.js +29 -47
- package/dist/cloudflare.js.map +1 -1
- package/dist/core-CwxxuUAn.cjs +1590 -0
- package/dist/core-CwxxuUAn.cjs.map +1 -0
- package/dist/core-D_iZiiYe.js +1308 -0
- package/dist/core-D_iZiiYe.js.map +1 -0
- package/dist/core-DwoTLYbR.cjs +319 -0
- package/dist/core-DwoTLYbR.cjs.map +1 -0
- package/dist/core-fsJmsQDa.js +307 -0
- package/dist/core-fsJmsQDa.js.map +1 -0
- package/dist/index-DMq6F3x9.d.ts +705 -0
- package/dist/index-Du_IHXAj.d.ts +10 -0
- package/dist/index-ZKOB86ub.d.cts +10 -0
- package/dist/index-qeC-p0Tq.d.cts +705 -0
- package/dist/index.cjs +61 -118
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +11 -130
- package/dist/index.d.ts +11 -130
- package/dist/index.js +14 -119
- package/dist/index.js.map +1 -1
- package/dist/pg.cjs +214 -320
- package/dist/pg.cjs.map +1 -1
- package/dist/pg.d.cts +24 -22
- package/dist/pg.d.ts +24 -22
- package/dist/pg.js +209 -321
- package/dist/pg.js.map +1 -1
- package/dist/shim.cjs +281 -367
- package/dist/shim.cjs.map +1 -1
- package/dist/shim.d.cts +140 -137
- package/dist/shim.d.ts +140 -137
- package/dist/shim.js +275 -366
- package/dist/shim.js.map +1 -1
- package/dist/sqlite3.cjs +41 -56
- package/dist/sqlite3.cjs.map +1 -1
- package/dist/sqlite3.d.cts +9 -9
- package/dist/sqlite3.d.ts +9 -9
- package/dist/sqlite3.js +35 -56
- package/dist/sqlite3.js.map +1 -1
- package/package.json +15 -15
- package/dist/chunk-EQ3T4XHT.cjs +0 -1583
- package/dist/chunk-EQ3T4XHT.cjs.map +0 -1
- package/dist/chunk-H6YIW5C5.js +0 -399
- package/dist/chunk-H6YIW5C5.js.map +0 -1
- package/dist/chunk-NTHMSHNG.cjs +0 -399
- package/dist/chunk-NTHMSHNG.cjs.map +0 -1
- package/dist/chunk-NWYI26VT.js +0 -1583
- package/dist/chunk-NWYI26VT.js.map +0 -1
- package/dist/index-BfBszcG4.d.ts +0 -8
- package/dist/index-a-fxODW1.d.cts +0 -8
- package/dist/pongoTransactionCache-CRuPGag3.d.cts +0 -556
- package/dist/pongoTransactionCache-CRuPGag3.d.ts +0 -556
|
@@ -0,0 +1,319 @@
|
|
|
1
|
+
const require_core = require('./core-CwxxuUAn.cjs');
|
|
2
|
+
const require_cli = require('./cli.cjs');
|
|
3
|
+
let _event_driven_io_dumbo = require("@event-driven-io/dumbo");
|
|
4
|
+
|
|
5
|
+
//#region src/storage/sqlite/core/sqlBuilder/filter/queryOperators.ts
|
|
6
|
+
const handleOperator = (path, operator, value, serializer) => {
|
|
7
|
+
if (path === "_id" || path === "_version") return handleMetadataOperator(path, operator, value);
|
|
8
|
+
switch (operator) {
|
|
9
|
+
case "$eq": {
|
|
10
|
+
const jsonPath = buildJsonPath(path);
|
|
11
|
+
return _event_driven_io_dumbo.SQL`(
|
|
12
|
+
json_extract(data, '${_event_driven_io_dumbo.SQL.plain(jsonPath)}') = ${value}
|
|
13
|
+
OR (
|
|
14
|
+
json_type(data, '${_event_driven_io_dumbo.SQL.plain(jsonPath)}') = 'array'
|
|
15
|
+
AND EXISTS(
|
|
16
|
+
SELECT 1 FROM json_each(data, '${_event_driven_io_dumbo.SQL.plain(jsonPath)}')
|
|
17
|
+
WHERE json_each.value = ${value}
|
|
18
|
+
)
|
|
19
|
+
)
|
|
20
|
+
)`;
|
|
21
|
+
}
|
|
22
|
+
case "$gt":
|
|
23
|
+
case "$gte":
|
|
24
|
+
case "$lt":
|
|
25
|
+
case "$lte":
|
|
26
|
+
case "$ne": {
|
|
27
|
+
const jsonPath = buildJsonPath(path);
|
|
28
|
+
return _event_driven_io_dumbo.SQL`json_extract(data, '${_event_driven_io_dumbo.SQL.plain(jsonPath)}') ${_event_driven_io_dumbo.SQL.plain(require_core.OperatorMap[operator])} ${value}`;
|
|
29
|
+
}
|
|
30
|
+
case "$in": {
|
|
31
|
+
const jsonPath = buildJsonPath(path);
|
|
32
|
+
const values = value;
|
|
33
|
+
const inClause = _event_driven_io_dumbo.SQL.merge(values.map((v) => _event_driven_io_dumbo.SQL`${v}`), ", ");
|
|
34
|
+
return _event_driven_io_dumbo.SQL`json_extract(data, '${_event_driven_io_dumbo.SQL.plain(jsonPath)}') IN (${inClause})`;
|
|
35
|
+
}
|
|
36
|
+
case "$nin": {
|
|
37
|
+
const jsonPath = buildJsonPath(path);
|
|
38
|
+
const values = value;
|
|
39
|
+
const inClause = _event_driven_io_dumbo.SQL.merge(values.map((v) => _event_driven_io_dumbo.SQL`${v}`), ", ");
|
|
40
|
+
return _event_driven_io_dumbo.SQL`json_extract(data, '${_event_driven_io_dumbo.SQL.plain(jsonPath)}') NOT IN (${inClause})`;
|
|
41
|
+
}
|
|
42
|
+
case "$elemMatch": {
|
|
43
|
+
const subConditions = require_core.objectEntries(value).map(([subKey, subValue]) => {
|
|
44
|
+
return `json_extract(value, '$.${subKey}') = json('${serializer.serialize(subValue)}')`;
|
|
45
|
+
}).join(" AND ");
|
|
46
|
+
const jsonPath = buildJsonPath(path);
|
|
47
|
+
return _event_driven_io_dumbo.SQL`EXISTS(SELECT 1 FROM json_each(data, '${_event_driven_io_dumbo.SQL.plain(jsonPath)}') WHERE ${_event_driven_io_dumbo.SQL.plain(subConditions)})`;
|
|
48
|
+
}
|
|
49
|
+
case "$all": {
|
|
50
|
+
const jsonPath = buildJsonPath(path);
|
|
51
|
+
return _event_driven_io_dumbo.SQL`(SELECT COUNT(*) FROM json_each(json(${serializer.serialize(value)})) WHERE json_each.value NOT IN (SELECT value FROM json_each(data, '${_event_driven_io_dumbo.SQL.plain(jsonPath)}'))) = 0`;
|
|
52
|
+
}
|
|
53
|
+
case "$size": {
|
|
54
|
+
const jsonPath = buildJsonPath(path);
|
|
55
|
+
return _event_driven_io_dumbo.SQL`json_array_length(json_extract(data, '${_event_driven_io_dumbo.SQL.plain(jsonPath)}')) = ${value}`;
|
|
56
|
+
}
|
|
57
|
+
default: throw new Error(`Unsupported operator: ${operator}`);
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
const handleMetadataOperator = (fieldName, operator, value) => {
|
|
61
|
+
switch (operator) {
|
|
62
|
+
case "$eq": return _event_driven_io_dumbo.SQL`${_event_driven_io_dumbo.SQL.plain(fieldName)} = ${value}`;
|
|
63
|
+
case "$gt":
|
|
64
|
+
case "$gte":
|
|
65
|
+
case "$lt":
|
|
66
|
+
case "$lte":
|
|
67
|
+
case "$ne": return _event_driven_io_dumbo.SQL`${_event_driven_io_dumbo.SQL.plain(fieldName)} ${_event_driven_io_dumbo.SQL.plain(require_core.OperatorMap[operator])} ${value}`;
|
|
68
|
+
case "$in": {
|
|
69
|
+
const values = value;
|
|
70
|
+
const inClause = _event_driven_io_dumbo.SQL.merge(values.map((v) => _event_driven_io_dumbo.SQL`${v}`), ", ");
|
|
71
|
+
return _event_driven_io_dumbo.SQL`${_event_driven_io_dumbo.SQL.plain(fieldName)} IN (${inClause})`;
|
|
72
|
+
}
|
|
73
|
+
case "$nin": {
|
|
74
|
+
const values = value;
|
|
75
|
+
const inClause = _event_driven_io_dumbo.SQL.merge(values.map((v) => _event_driven_io_dumbo.SQL`${v}`), ", ");
|
|
76
|
+
return _event_driven_io_dumbo.SQL`${_event_driven_io_dumbo.SQL.plain(fieldName)} NOT IN (${inClause})`;
|
|
77
|
+
}
|
|
78
|
+
default: throw new Error(`Unsupported operator: ${operator}`);
|
|
79
|
+
}
|
|
80
|
+
};
|
|
81
|
+
const buildJsonPath = (path) => {
|
|
82
|
+
return `$.${path}`;
|
|
83
|
+
};
|
|
84
|
+
|
|
85
|
+
//#endregion
|
|
86
|
+
//#region src/storage/sqlite/core/sqlBuilder/filter/index.ts
|
|
87
|
+
const AND = "AND";
|
|
88
|
+
const constructFilterQuery = (filter, serializer) => _event_driven_io_dumbo.SQL.merge(Object.entries(filter).map(([key, value]) => isRecord(value) ? constructComplexFilterQuery(key, value, serializer) : handleOperator(key, "$eq", value, serializer)), ` ${AND} `);
|
|
89
|
+
const constructComplexFilterQuery = (key, value, serializer) => {
|
|
90
|
+
const isEquality = !require_core.hasOperators(value);
|
|
91
|
+
return _event_driven_io_dumbo.SQL.merge(require_core.objectEntries(value).map(([nestedKey, val]) => isEquality ? handleOperator(`${key}.${nestedKey}`, require_core.QueryOperators.$eq, val, serializer) : handleOperator(key, nestedKey, val, serializer)), ` ${AND} `);
|
|
92
|
+
};
|
|
93
|
+
const isRecord = (value) => value !== null && typeof value === "object" && !Array.isArray(value);
|
|
94
|
+
|
|
95
|
+
//#endregion
|
|
96
|
+
//#region src/storage/sqlite/core/sqlBuilder/update/index.ts
|
|
97
|
+
const buildUpdateQuery = (update, serializer) => require_core.objectEntries(update).reduce((currentUpdateQuery, [op, value]) => {
|
|
98
|
+
switch (op) {
|
|
99
|
+
case "$set": return buildSetQuery(value, currentUpdateQuery, serializer);
|
|
100
|
+
case "$unset": return buildUnsetQuery(value, currentUpdateQuery);
|
|
101
|
+
case "$inc": return buildIncQuery(value, currentUpdateQuery);
|
|
102
|
+
case "$push": return buildPushQuery(value, currentUpdateQuery, serializer);
|
|
103
|
+
default: return currentUpdateQuery;
|
|
104
|
+
}
|
|
105
|
+
}, _event_driven_io_dumbo.SQL`data`);
|
|
106
|
+
const buildSetQuery = (set, currentUpdateQuery, serializer) => _event_driven_io_dumbo.SQL`json_patch(${currentUpdateQuery}, ${serializer.serialize(set)})`;
|
|
107
|
+
const buildUnsetQuery = (unset, currentUpdateQuery) => {
|
|
108
|
+
const keys = Object.keys(unset);
|
|
109
|
+
let query = currentUpdateQuery;
|
|
110
|
+
for (const key of keys) query = _event_driven_io_dumbo.SQL`json_remove(${query}, '$.${_event_driven_io_dumbo.SQL.plain(key)}')`;
|
|
111
|
+
return query;
|
|
112
|
+
};
|
|
113
|
+
const buildIncQuery = (inc, currentUpdateQuery) => {
|
|
114
|
+
for (const [key, value] of Object.entries(inc)) currentUpdateQuery = typeof value === "bigint" ? _event_driven_io_dumbo.SQL`json_set(${currentUpdateQuery}, '$.${_event_driven_io_dumbo.SQL.plain(key)}', CAST((COALESCE(json_extract(${currentUpdateQuery}, '$.${_event_driven_io_dumbo.SQL.plain(key)}'), 0) + ${value}) AS TEXT))` : _event_driven_io_dumbo.SQL`json_set(${currentUpdateQuery}, '$.${_event_driven_io_dumbo.SQL.plain(key)}', COALESCE(json_extract(${currentUpdateQuery}, '$.${_event_driven_io_dumbo.SQL.plain(key)}'), 0) + ${value})`;
|
|
115
|
+
return currentUpdateQuery;
|
|
116
|
+
};
|
|
117
|
+
const buildPushQuery = (push, currentUpdateQuery, serializer) => {
|
|
118
|
+
for (const [key, value] of Object.entries(push)) {
|
|
119
|
+
const serializedValue = serializer.serialize(value);
|
|
120
|
+
currentUpdateQuery = _event_driven_io_dumbo.SQL`json_set(${currentUpdateQuery}, '$.${_event_driven_io_dumbo.SQL.plain(key)}', CASE
|
|
121
|
+
WHEN json_type(json_extract(${currentUpdateQuery}, '$.${_event_driven_io_dumbo.SQL.plain(key)}')) = 'array'
|
|
122
|
+
THEN json_insert(json_extract(${currentUpdateQuery}, '$.${_event_driven_io_dumbo.SQL.plain(key)}'), '$[#]', json(${serializedValue}))
|
|
123
|
+
ELSE json_array(json(${serializedValue}))
|
|
124
|
+
END)`;
|
|
125
|
+
}
|
|
126
|
+
return currentUpdateQuery;
|
|
127
|
+
};
|
|
128
|
+
|
|
129
|
+
//#endregion
|
|
130
|
+
//#region src/storage/sqlite/core/sqlBuilder/index.ts
|
|
131
|
+
const createCollection = (collectionName) => _event_driven_io_dumbo.SQL`
|
|
132
|
+
CREATE TABLE IF NOT EXISTS ${_event_driven_io_dumbo.SQL.identifier(collectionName)} (
|
|
133
|
+
_id TEXT PRIMARY KEY,
|
|
134
|
+
data JSON NOT NULL,
|
|
135
|
+
metadata JSON NOT NULL DEFAULT '{}',
|
|
136
|
+
_version INTEGER NOT NULL DEFAULT 1,
|
|
137
|
+
_partition TEXT NOT NULL DEFAULT 'png_global',
|
|
138
|
+
_archived INTEGER NOT NULL DEFAULT 0,
|
|
139
|
+
_created TEXT NOT NULL DEFAULT (datetime('now')),
|
|
140
|
+
_updated TEXT NOT NULL DEFAULT (datetime('now'))
|
|
141
|
+
)`;
|
|
142
|
+
const pongoCollectionSQLiteMigrations = (collectionName) => [(0, _event_driven_io_dumbo.sqlMigration)(`pongoCollection:${collectionName}:001:createtable`, [createCollection(collectionName)])];
|
|
143
|
+
const sqliteSQLBuilder = (collectionName, serializer) => ({
|
|
144
|
+
createCollection: () => createCollection(collectionName),
|
|
145
|
+
insertOne: (document) => {
|
|
146
|
+
const serialized = document;
|
|
147
|
+
const id = document._id;
|
|
148
|
+
const version = document._version ?? 1n;
|
|
149
|
+
return _event_driven_io_dumbo.SQL`
|
|
150
|
+
INSERT OR IGNORE INTO ${_event_driven_io_dumbo.SQL.identifier(collectionName)} (_id, data, _version)
|
|
151
|
+
VALUES (${id}, ${serialized}, ${version})
|
|
152
|
+
RETURNING _id;`;
|
|
153
|
+
},
|
|
154
|
+
insertMany: (documents) => {
|
|
155
|
+
const values = _event_driven_io_dumbo.SQL.merge(documents.map((doc) => _event_driven_io_dumbo.SQL`(${doc._id}, ${serializer.serialize(doc)}, ${doc._version ?? 1n})`), ",");
|
|
156
|
+
return _event_driven_io_dumbo.SQL`
|
|
157
|
+
INSERT OR IGNORE INTO ${_event_driven_io_dumbo.SQL.identifier(collectionName)} (_id, data, _version) VALUES ${values}
|
|
158
|
+
RETURNING _id;`;
|
|
159
|
+
},
|
|
160
|
+
updateOne: (filter, update, options) => {
|
|
161
|
+
const expectedVersion = require_core.expectedVersionValue(options?.expectedVersion);
|
|
162
|
+
const expectedVersionCheck = expectedVersion != null ? _event_driven_io_dumbo.SQL`AND _version = ${expectedVersion}` : _event_driven_io_dumbo.SQL``;
|
|
163
|
+
const filterQuery = (0, _event_driven_io_dumbo.isSQL)(filter) ? filter : constructFilterQuery(filter, serializer);
|
|
164
|
+
const updateQuery = (0, _event_driven_io_dumbo.isSQL)(update) ? update : buildUpdateQuery(update, serializer);
|
|
165
|
+
return _event_driven_io_dumbo.SQL`
|
|
166
|
+
UPDATE ${_event_driven_io_dumbo.SQL.identifier(collectionName)}
|
|
167
|
+
SET
|
|
168
|
+
data = json_patch(${updateQuery}, json_object('_id', _id, '_version', cast(_version + 1 as TEXT))),
|
|
169
|
+
_version = _version + 1,
|
|
170
|
+
_updated = datetime('now')
|
|
171
|
+
WHERE _id = (
|
|
172
|
+
SELECT _id FROM ${_event_driven_io_dumbo.SQL.identifier(collectionName)}
|
|
173
|
+
${where(filterQuery)}
|
|
174
|
+
LIMIT 1
|
|
175
|
+
) ${expectedVersionCheck}
|
|
176
|
+
RETURNING
|
|
177
|
+
_id,
|
|
178
|
+
cast(_version as TEXT) as version,
|
|
179
|
+
1 as matched,
|
|
180
|
+
1 as modified;`;
|
|
181
|
+
},
|
|
182
|
+
replaceOne: (filter, document, options) => {
|
|
183
|
+
const expectedVersion = require_core.expectedVersionValue(options?.expectedVersion);
|
|
184
|
+
const expectedVersionCheck = expectedVersion != null ? _event_driven_io_dumbo.SQL`AND _version = ${expectedVersion}` : _event_driven_io_dumbo.SQL``;
|
|
185
|
+
const filterQuery = (0, _event_driven_io_dumbo.isSQL)(filter) ? filter : constructFilterQuery(filter, serializer);
|
|
186
|
+
return _event_driven_io_dumbo.SQL`
|
|
187
|
+
UPDATE ${_event_driven_io_dumbo.SQL.identifier(collectionName)}
|
|
188
|
+
SET
|
|
189
|
+
data = json_patch(${serializer.serialize(document)}, json_object('_id', _id, '_version', cast(_version + 1 as TEXT))),
|
|
190
|
+
_version = _version + 1,
|
|
191
|
+
_updated = datetime('now')
|
|
192
|
+
WHERE _id = (
|
|
193
|
+
SELECT _id FROM ${_event_driven_io_dumbo.SQL.identifier(collectionName)}
|
|
194
|
+
${where(filterQuery)}
|
|
195
|
+
LIMIT 1
|
|
196
|
+
) ${expectedVersionCheck}
|
|
197
|
+
RETURNING
|
|
198
|
+
_id,
|
|
199
|
+
cast(_version as TEXT) AS version,
|
|
200
|
+
1 AS matched,
|
|
201
|
+
1 AS modified;`;
|
|
202
|
+
},
|
|
203
|
+
updateMany: (filter, update) => {
|
|
204
|
+
const filterQuery = (0, _event_driven_io_dumbo.isSQL)(filter) ? filter : constructFilterQuery(filter, serializer);
|
|
205
|
+
const updateQuery = (0, _event_driven_io_dumbo.isSQL)(update) ? update : buildUpdateQuery(update, serializer);
|
|
206
|
+
return _event_driven_io_dumbo.SQL`
|
|
207
|
+
UPDATE ${_event_driven_io_dumbo.SQL.identifier(collectionName)}
|
|
208
|
+
SET
|
|
209
|
+
data = json_patch(${updateQuery}, json_object('_version', cast(_version + 1 as TEXT))),
|
|
210
|
+
_version = _version + 1,
|
|
211
|
+
_updated = datetime('now')
|
|
212
|
+
${where(filterQuery)}
|
|
213
|
+
RETURNING _id;`;
|
|
214
|
+
},
|
|
215
|
+
deleteOne: (filter, options) => {
|
|
216
|
+
const expectedVersion = require_core.expectedVersionValue(options?.expectedVersion);
|
|
217
|
+
const expectedVersionCheck = expectedVersion != null ? _event_driven_io_dumbo.SQL`AND _version = ${expectedVersion}` : _event_driven_io_dumbo.SQL``;
|
|
218
|
+
const filterQuery = (0, _event_driven_io_dumbo.isSQL)(filter) ? filter : constructFilterQuery(filter, serializer);
|
|
219
|
+
return _event_driven_io_dumbo.SQL`
|
|
220
|
+
DELETE FROM ${_event_driven_io_dumbo.SQL.identifier(collectionName)}
|
|
221
|
+
WHERE _id = (
|
|
222
|
+
SELECT _id FROM ${_event_driven_io_dumbo.SQL.identifier(collectionName)}
|
|
223
|
+
${where(filterQuery)}
|
|
224
|
+
LIMIT 1
|
|
225
|
+
) ${expectedVersionCheck}
|
|
226
|
+
RETURNING
|
|
227
|
+
_id,
|
|
228
|
+
1 AS matched,
|
|
229
|
+
1 AS deleted;`;
|
|
230
|
+
},
|
|
231
|
+
deleteMany: (filter) => {
|
|
232
|
+
const filterQuery = (0, _event_driven_io_dumbo.isSQL)(filter) ? filter : constructFilterQuery(filter, serializer);
|
|
233
|
+
return _event_driven_io_dumbo.SQL`DELETE FROM ${_event_driven_io_dumbo.SQL.identifier(collectionName)} ${where(filterQuery)} RETURNING _id`;
|
|
234
|
+
},
|
|
235
|
+
replaceMany: (documents) => {
|
|
236
|
+
const col = _event_driven_io_dumbo.SQL.identifier(collectionName);
|
|
237
|
+
if (documents.some((d) => "_version" in d && d._version !== void 0)) return _event_driven_io_dumbo.SQL`
|
|
238
|
+
WITH replacements(_id, data, expected_version) AS (
|
|
239
|
+
VALUES ${_event_driven_io_dumbo.SQL.merge(documents.map((d) => _event_driven_io_dumbo.SQL`(${d._id}, ${serializer.serialize(d)}, ${d._version ?? 0n})`), ",")}
|
|
240
|
+
)
|
|
241
|
+
UPDATE ${col}
|
|
242
|
+
SET
|
|
243
|
+
data = json_patch(r.data, json_object('_id', ${col}._id, '_version', cast(${col}._version + 1 as TEXT))),
|
|
244
|
+
_version = ${col}._version + 1,
|
|
245
|
+
_updated = datetime('now')
|
|
246
|
+
FROM replacements r
|
|
247
|
+
WHERE ${col}._id = r._id AND ${col}._version = r.expected_version
|
|
248
|
+
RETURNING ${col}._id, cast(${col}._version as TEXT) as version;`;
|
|
249
|
+
return _event_driven_io_dumbo.SQL`
|
|
250
|
+
WITH replacements(_id, data) AS (
|
|
251
|
+
VALUES ${_event_driven_io_dumbo.SQL.merge(documents.map((d) => _event_driven_io_dumbo.SQL`(${d._id}, ${serializer.serialize(d)})`), ",")}
|
|
252
|
+
)
|
|
253
|
+
UPDATE ${col}
|
|
254
|
+
SET
|
|
255
|
+
data = json_patch(r.data, json_object('_id', ${col}._id, '_version', cast(${col}._version + 1 as TEXT))),
|
|
256
|
+
_version = ${col}._version + 1,
|
|
257
|
+
_updated = datetime('now')
|
|
258
|
+
FROM replacements r
|
|
259
|
+
WHERE ${col}._id = r._id
|
|
260
|
+
RETURNING ${col}._id, cast(${col}._version as TEXT) as version;`;
|
|
261
|
+
},
|
|
262
|
+
deleteManyByIds: (ids) => {
|
|
263
|
+
if (ids.some((d) => d._version !== void 0)) return _event_driven_io_dumbo.SQL`
|
|
264
|
+
WITH targets(_id, expected_version) AS (
|
|
265
|
+
VALUES ${_event_driven_io_dumbo.SQL.merge(ids.map((d) => _event_driven_io_dumbo.SQL`(${d._id}, ${d._version ?? 0n})`), ",")}
|
|
266
|
+
)
|
|
267
|
+
DELETE FROM ${_event_driven_io_dumbo.SQL.identifier(collectionName)}
|
|
268
|
+
WHERE _id IN (SELECT _id FROM targets)
|
|
269
|
+
AND _version = (SELECT expected_version FROM targets WHERE targets._id = ${_event_driven_io_dumbo.SQL.identifier(collectionName)}._id)
|
|
270
|
+
RETURNING _id;`;
|
|
271
|
+
const idList = _event_driven_io_dumbo.SQL.merge(ids.map((d) => _event_driven_io_dumbo.SQL`${d._id}`), ",");
|
|
272
|
+
return _event_driven_io_dumbo.SQL`
|
|
273
|
+
DELETE FROM ${_event_driven_io_dumbo.SQL.identifier(collectionName)}
|
|
274
|
+
WHERE _id IN (${idList})
|
|
275
|
+
RETURNING _id;`;
|
|
276
|
+
},
|
|
277
|
+
findOne: (filter) => {
|
|
278
|
+
const filterQuery = (0, _event_driven_io_dumbo.isSQL)(filter) ? filter : constructFilterQuery(filter, serializer);
|
|
279
|
+
return _event_driven_io_dumbo.SQL`SELECT data, _version FROM ${_event_driven_io_dumbo.SQL.identifier(collectionName)} ${where(filterQuery)} LIMIT 1;`;
|
|
280
|
+
},
|
|
281
|
+
find: (filter, options) => {
|
|
282
|
+
const filterQuery = (0, _event_driven_io_dumbo.isSQL)(filter) ? filter : constructFilterQuery(filter, serializer);
|
|
283
|
+
const query = [];
|
|
284
|
+
query.push(_event_driven_io_dumbo.SQL`SELECT data, _version FROM ${_event_driven_io_dumbo.SQL.identifier(collectionName)}`);
|
|
285
|
+
query.push(where(filterQuery));
|
|
286
|
+
if (options?.sort && Object.keys(options.sort).length > 0) {
|
|
287
|
+
const clauses = Object.entries(options.sort).map(([field, dir]) => {
|
|
288
|
+
const accessor = field === "_id" || field === "_version" ? _event_driven_io_dumbo.SQL`${_event_driven_io_dumbo.SQL.plain(field)}` : _event_driven_io_dumbo.SQL`json_extract(data, '${_event_driven_io_dumbo.SQL.plain(`$.${field}`)}')`;
|
|
289
|
+
return dir === 1 ? _event_driven_io_dumbo.SQL`${accessor} ASC` : _event_driven_io_dumbo.SQL`${accessor} DESC`;
|
|
290
|
+
});
|
|
291
|
+
query.push(_event_driven_io_dumbo.SQL`ORDER BY ${_event_driven_io_dumbo.SQL.merge(clauses, ",")}`);
|
|
292
|
+
}
|
|
293
|
+
if (options?.limit) query.push(_event_driven_io_dumbo.SQL`LIMIT ${options.limit}`);
|
|
294
|
+
if (options?.skip) query.push(_event_driven_io_dumbo.SQL`OFFSET ${options.skip}`);
|
|
295
|
+
return _event_driven_io_dumbo.SQL.merge([...query, _event_driven_io_dumbo.SQL`;`]);
|
|
296
|
+
},
|
|
297
|
+
countDocuments: (filter) => {
|
|
298
|
+
const filterQuery = _event_driven_io_dumbo.SQL.check.isSQL(filter) ? filter : constructFilterQuery(filter, serializer);
|
|
299
|
+
return _event_driven_io_dumbo.SQL`SELECT COUNT(1) as count FROM ${_event_driven_io_dumbo.SQL.identifier(collectionName)} ${where(filterQuery)};`;
|
|
300
|
+
},
|
|
301
|
+
rename: (newName) => _event_driven_io_dumbo.SQL`ALTER TABLE ${_event_driven_io_dumbo.SQL.identifier(collectionName)} RENAME TO ${_event_driven_io_dumbo.SQL.identifier(newName)};`,
|
|
302
|
+
drop: (targetName = collectionName) => _event_driven_io_dumbo.SQL`DROP TABLE IF EXISTS ${_event_driven_io_dumbo.SQL.identifier(targetName)}`
|
|
303
|
+
});
|
|
304
|
+
const where = (filterQuery) => _event_driven_io_dumbo.SQL.check.isEmpty(filterQuery) ? _event_driven_io_dumbo.SQL.EMPTY : _event_driven_io_dumbo.SQL.merge([_event_driven_io_dumbo.SQL`WHERE `, filterQuery]);
|
|
305
|
+
|
|
306
|
+
//#endregion
|
|
307
|
+
Object.defineProperty(exports, 'pongoCollectionSQLiteMigrations', {
|
|
308
|
+
enumerable: true,
|
|
309
|
+
get: function () {
|
|
310
|
+
return pongoCollectionSQLiteMigrations;
|
|
311
|
+
}
|
|
312
|
+
});
|
|
313
|
+
Object.defineProperty(exports, 'sqliteSQLBuilder', {
|
|
314
|
+
enumerable: true,
|
|
315
|
+
get: function () {
|
|
316
|
+
return sqliteSQLBuilder;
|
|
317
|
+
}
|
|
318
|
+
});
|
|
319
|
+
//# sourceMappingURL=core-DwoTLYbR.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"core-DwoTLYbR.cjs","names":["SQL","OperatorMap","objectEntries","SQL","hasOperators","objectEntries","QueryOperators","objectEntries","SQL","SQL","expectedVersionValue"],"sources":["../src/storage/sqlite/core/sqlBuilder/filter/queryOperators.ts","../src/storage/sqlite/core/sqlBuilder/filter/index.ts","../src/storage/sqlite/core/sqlBuilder/update/index.ts","../src/storage/sqlite/core/sqlBuilder/index.ts"],"sourcesContent":["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 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 {\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","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 WithId,\n type WithIdAndVersion,\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 replaceMany: <T>(documents: Array<WithIdAndVersion<T> | WithId<T>>): SQL => {\n const col = SQL.identifier(collectionName);\n const hasVersions = documents.some(\n (d) => '_version' in d && d._version !== undefined,\n );\n\n if (hasVersions) {\n const values = SQL.merge(\n documents.map(\n (d) =>\n SQL`(${d._id}, ${serializer.serialize(d)}, ${(d as WithIdAndVersion<T>)._version ?? 0n})`,\n ),\n ',',\n );\n return SQL`\n WITH replacements(_id, data, expected_version) AS (\n VALUES ${values}\n )\n UPDATE ${col}\n SET\n data = json_patch(r.data, json_object('_id', ${col}._id, '_version', cast(${col}._version + 1 as TEXT))),\n _version = ${col}._version + 1,\n _updated = datetime('now')\n FROM replacements r\n WHERE ${col}._id = r._id AND ${col}._version = r.expected_version\n RETURNING ${col}._id, cast(${col}._version as TEXT) as version;`;\n }\n\n const values = SQL.merge(\n documents.map((d) => SQL`(${d._id}, ${serializer.serialize(d)})`),\n ',',\n );\n return SQL`\n WITH replacements(_id, data) AS (\n VALUES ${values}\n )\n UPDATE ${col}\n SET\n data = json_patch(r.data, json_object('_id', ${col}._id, '_version', cast(${col}._version + 1 as TEXT))),\n _version = ${col}._version + 1,\n _updated = datetime('now')\n FROM replacements r\n WHERE ${col}._id = r._id\n RETURNING ${col}._id, cast(${col}._version as TEXT) as version;`;\n },\n deleteManyByIds: (ids: Array<{ _id: string; _version?: bigint }>): SQL => {\n const hasVersions = ids.some((d) => d._version !== undefined);\n\n if (hasVersions) {\n const values = SQL.merge(\n ids.map((d) => SQL`(${d._id}, ${d._version ?? 0n})`),\n ',',\n );\n\n return SQL`\n WITH targets(_id, expected_version) AS (\n VALUES ${values}\n )\n DELETE FROM ${SQL.identifier(collectionName)}\n WHERE _id IN (SELECT _id FROM targets)\n AND _version = (SELECT expected_version FROM targets WHERE targets._id = ${SQL.identifier(collectionName)}._id)\n RETURNING _id;`;\n }\n\n const idList = SQL.merge(\n ids.map((d) => SQL`${d._id}`),\n ',',\n );\n\n return SQL`\n DELETE FROM ${SQL.identifier(collectionName)}\n WHERE _id IN (${idList})\n 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?.sort && Object.keys(options.sort).length > 0) {\n const clauses = Object.entries(options.sort).map(([field, dir]) => {\n // _id and _version are native columns, not JSON fields.\n const isMetadata = field === '_id' || field === '_version';\n const accessor = isMetadata\n ? SQL`${SQL.plain(field)}`\n : SQL`json_extract(data, '${SQL.plain(`$.${field}`)}')`;\n return dir === 1 ? SQL`${accessor} ASC` : SQL`${accessor} DESC`;\n });\n query.push(SQL`ORDER BY ${SQL.merge(clauses, ',')}`);\n }\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"],"mappings":"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"}
|