@event-driven-io/pongo 0.17.0-beta.1 → 0.17.0-beta.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{chunk-YLV7YIPZ.cjs → chunk-4BL6YWLW.cjs} +3 -7
- package/dist/chunk-4BL6YWLW.cjs.map +1 -0
- package/dist/chunk-ECQ2CKZE.cjs +330 -0
- package/dist/chunk-ECQ2CKZE.cjs.map +1 -0
- package/dist/{chunk-5LN762VW.js → chunk-EYQDS752.js} +5 -3
- package/dist/chunk-EYQDS752.js.map +1 -0
- package/dist/{chunk-DL4E3N6J.js → chunk-NCNRRYVE.js} +3 -7
- package/dist/chunk-NCNRRYVE.js.map +1 -0
- package/dist/chunk-WH26IXHN.js +10 -0
- package/dist/{chunk-7W6X4QGY.cjs → chunk-WKW4LGF6.cjs} +4 -4
- package/dist/{chunk-7W6X4QGY.cjs.map → chunk-WKW4LGF6.cjs.map} +1 -1
- package/dist/chunk-Y7LRKJLJ.js +330 -0
- package/dist/chunk-Y7LRKJLJ.js.map +1 -0
- package/dist/{chunk-3KNMMQUV.cjs → chunk-ZPWKWNK2.cjs} +20 -18
- package/dist/chunk-ZPWKWNK2.cjs.map +1 -0
- package/dist/cli.cjs +38 -21
- package/dist/cli.cjs.map +1 -1
- package/dist/cli.js +29 -12
- package/dist/cli.js.map +1 -1
- package/dist/d1.cjs +54 -0
- package/dist/d1.cjs.map +1 -0
- package/dist/d1.d.cts +11 -0
- package/dist/d1.d.ts +11 -0
- package/dist/d1.js +54 -0
- package/dist/d1.js.map +1 -0
- package/dist/index-BJopB-em.d.cts +7 -0
- package/dist/index-G5DECNb_.d.ts +7 -0
- package/dist/index.cjs +3 -3
- package/dist/index.d.cts +4 -4
- package/dist/index.d.ts +4 -4
- package/dist/index.js +2 -2
- package/dist/{pg-WUYRNGST.js → pg-73DOKU64.js} +3 -3
- package/dist/pg-I267A7IL.cjs +11 -0
- package/dist/{pg-XCWP4FAM.cjs.map → pg-I267A7IL.cjs.map} +1 -1
- package/dist/pg.cjs +4 -4
- package/dist/pg.d.cts +5 -2
- package/dist/pg.d.ts +5 -2
- package/dist/pg.js +3 -3
- package/dist/{pongoCollectionSchemaComponent-BsHlVyN-.d.cts → pongoCollectionSchemaComponent-t_e9n2Wc.d.cts} +12 -8
- package/dist/{pongoCollectionSchemaComponent-BsHlVyN-.d.ts → pongoCollectionSchemaComponent-t_e9n2Wc.d.ts} +12 -8
- package/dist/shim.cjs +16 -11
- package/dist/shim.cjs.map +1 -1
- package/dist/shim.d.cts +4 -3
- package/dist/shim.d.ts +4 -3
- package/dist/shim.js +12 -7
- package/dist/shim.js.map +1 -1
- package/dist/sqlite3.cjs +16 -332
- package/dist/sqlite3.cjs.map +1 -1
- package/dist/sqlite3.d.cts +8 -7
- package/dist/sqlite3.d.ts +8 -7
- package/dist/sqlite3.js +9 -325
- package/dist/sqlite3.js.map +1 -1
- package/package.json +16 -2
- package/dist/chunk-3KNMMQUV.cjs.map +0 -1
- package/dist/chunk-5LN762VW.js.map +0 -1
- package/dist/chunk-DL4E3N6J.js.map +0 -1
- package/dist/chunk-IBJKZ6TS.js +0 -10
- package/dist/chunk-YLV7YIPZ.cjs.map +0 -1
- package/dist/pg-XCWP4FAM.cjs +0 -11
- /package/dist/{chunk-IBJKZ6TS.js.map → chunk-WH26IXHN.js.map} +0 -0
- /package/dist/{pg-WUYRNGST.js.map → pg-73DOKU64.js.map} +0 -0
package/dist/sqlite3.cjs
CHANGED
|
@@ -1,336 +1,18 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } } function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
|
|
2
2
|
|
|
3
3
|
|
|
4
|
+
var _chunkECQ2CKZEcjs = require('./chunk-ECQ2CKZE.cjs');
|
|
5
|
+
require('./chunk-WKW4LGF6.cjs');
|
|
4
6
|
|
|
5
7
|
|
|
6
8
|
|
|
7
9
|
|
|
8
10
|
|
|
9
11
|
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
var _chunkYLV7YIPZcjs = require('./chunk-YLV7YIPZ.cjs');
|
|
14
|
-
|
|
15
|
-
// src/storage/sqlite/core/sqlBuilder/index.ts
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
var _dumbo = require('@event-driven-io/dumbo');
|
|
22
|
-
|
|
23
|
-
// src/storage/sqlite/core/sqlBuilder/filter/index.ts
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
// src/storage/sqlite/core/sqlBuilder/filter/queryOperators.ts
|
|
27
|
-
|
|
28
|
-
var handleOperator = (path, operator, value) => {
|
|
29
|
-
if (path === "_id" || path === "_version") {
|
|
30
|
-
return handleMetadataOperator(path, operator, value);
|
|
31
|
-
}
|
|
32
|
-
switch (operator) {
|
|
33
|
-
case "$eq": {
|
|
34
|
-
const jsonPath = buildJsonPath(path);
|
|
35
|
-
return _dumbo.SQL`(
|
|
36
|
-
json_extract(data, '${_dumbo.SQL.plain(jsonPath)}') = ${value}
|
|
37
|
-
OR (
|
|
38
|
-
json_type(data, '${_dumbo.SQL.plain(jsonPath)}') = 'array'
|
|
39
|
-
AND EXISTS(
|
|
40
|
-
SELECT 1 FROM json_each(data, '${_dumbo.SQL.plain(jsonPath)}')
|
|
41
|
-
WHERE json_each.value = ${value}
|
|
42
|
-
)
|
|
43
|
-
)
|
|
44
|
-
)`;
|
|
45
|
-
}
|
|
46
|
-
case "$gt":
|
|
47
|
-
case "$gte":
|
|
48
|
-
case "$lt":
|
|
49
|
-
case "$lte":
|
|
50
|
-
case "$ne": {
|
|
51
|
-
const jsonPath = buildJsonPath(path);
|
|
52
|
-
return _dumbo.SQL`json_extract(data, '${_dumbo.SQL.plain(jsonPath)}') ${_dumbo.SQL.plain(_chunkYLV7YIPZcjs.OperatorMap[operator])} ${value}`;
|
|
53
|
-
}
|
|
54
|
-
case "$in": {
|
|
55
|
-
const jsonPath = buildJsonPath(path);
|
|
56
|
-
const values = value;
|
|
57
|
-
const inClause = _dumbo.SQL.merge(
|
|
58
|
-
values.map((v) => _dumbo.SQL`${v}`),
|
|
59
|
-
", "
|
|
60
|
-
);
|
|
61
|
-
return _dumbo.SQL`json_extract(data, '${_dumbo.SQL.plain(jsonPath)}') IN (${inClause})`;
|
|
62
|
-
}
|
|
63
|
-
case "$nin": {
|
|
64
|
-
const jsonPath = buildJsonPath(path);
|
|
65
|
-
const values = value;
|
|
66
|
-
const inClause = _dumbo.SQL.merge(
|
|
67
|
-
values.map((v) => _dumbo.SQL`${v}`),
|
|
68
|
-
", "
|
|
69
|
-
);
|
|
70
|
-
return _dumbo.SQL`json_extract(data, '${_dumbo.SQL.plain(jsonPath)}') NOT IN (${inClause})`;
|
|
71
|
-
}
|
|
72
|
-
case "$elemMatch": {
|
|
73
|
-
const subConditions = _chunkYLV7YIPZcjs.objectEntries.call(void 0, value).map(([subKey, subValue]) => {
|
|
74
|
-
const serializedValue = _dumbo.JSONSerializer.serialize(subValue);
|
|
75
|
-
return `json_extract(value, '$.${subKey}') = json('${serializedValue}')`;
|
|
76
|
-
}).join(" AND ");
|
|
77
|
-
const jsonPath = buildJsonPath(path);
|
|
78
|
-
return _dumbo.SQL`EXISTS(SELECT 1 FROM json_each(data, '${_dumbo.SQL.plain(jsonPath)}') WHERE ${_dumbo.SQL.plain(subConditions)})`;
|
|
79
|
-
}
|
|
80
|
-
case "$all": {
|
|
81
|
-
const jsonPath = buildJsonPath(path);
|
|
82
|
-
const serializedValue = _dumbo.JSONSerializer.serialize(value);
|
|
83
|
-
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`;
|
|
84
|
-
}
|
|
85
|
-
case "$size": {
|
|
86
|
-
const jsonPath = buildJsonPath(path);
|
|
87
|
-
return _dumbo.SQL`json_array_length(json_extract(data, '${_dumbo.SQL.plain(jsonPath)}')) = ${value}`;
|
|
88
|
-
}
|
|
89
|
-
default:
|
|
90
|
-
throw new Error(`Unsupported operator: ${operator}`);
|
|
91
|
-
}
|
|
92
|
-
};
|
|
93
|
-
var handleMetadataOperator = (fieldName, operator, value) => {
|
|
94
|
-
switch (operator) {
|
|
95
|
-
case "$eq":
|
|
96
|
-
return _dumbo.SQL`${_dumbo.SQL.plain(fieldName)} = ${value}`;
|
|
97
|
-
case "$gt":
|
|
98
|
-
case "$gte":
|
|
99
|
-
case "$lt":
|
|
100
|
-
case "$lte":
|
|
101
|
-
case "$ne":
|
|
102
|
-
return _dumbo.SQL`${_dumbo.SQL.plain(fieldName)} ${_dumbo.SQL.plain(_chunkYLV7YIPZcjs.OperatorMap[operator])} ${value}`;
|
|
103
|
-
case "$in": {
|
|
104
|
-
const values = value;
|
|
105
|
-
const inClause = _dumbo.SQL.merge(
|
|
106
|
-
values.map((v) => _dumbo.SQL`${v}`),
|
|
107
|
-
", "
|
|
108
|
-
);
|
|
109
|
-
return _dumbo.SQL`${_dumbo.SQL.plain(fieldName)} IN (${inClause})`;
|
|
110
|
-
}
|
|
111
|
-
case "$nin": {
|
|
112
|
-
const values = value;
|
|
113
|
-
const inClause = _dumbo.SQL.merge(
|
|
114
|
-
values.map((v) => _dumbo.SQL`${v}`),
|
|
115
|
-
", "
|
|
116
|
-
);
|
|
117
|
-
return _dumbo.SQL`${_dumbo.SQL.plain(fieldName)} NOT IN (${inClause})`;
|
|
118
|
-
}
|
|
119
|
-
default:
|
|
120
|
-
throw new Error(`Unsupported operator: ${operator}`);
|
|
121
|
-
}
|
|
122
|
-
};
|
|
123
|
-
var buildJsonPath = (path) => {
|
|
124
|
-
return `$.${path}`;
|
|
125
|
-
};
|
|
126
|
-
|
|
127
|
-
// src/storage/sqlite/core/sqlBuilder/filter/index.ts
|
|
128
|
-
var AND = "AND";
|
|
129
|
-
var constructFilterQuery = (filter) => _dumbo.SQL.merge(
|
|
130
|
-
Object.entries(filter).map(
|
|
131
|
-
([key, value]) => isRecord(value) ? constructComplexFilterQuery(key, value) : handleOperator(key, "$eq", value)
|
|
132
|
-
),
|
|
133
|
-
` ${AND} `
|
|
134
|
-
);
|
|
135
|
-
var constructComplexFilterQuery = (key, value) => {
|
|
136
|
-
const isEquality = !_chunkYLV7YIPZcjs.hasOperators.call(void 0, value);
|
|
137
|
-
return _dumbo.SQL.merge(
|
|
138
|
-
_chunkYLV7YIPZcjs.objectEntries.call(void 0, value).map(
|
|
139
|
-
([nestedKey, val]) => isEquality ? handleOperator(`${key}.${nestedKey}`, _chunkYLV7YIPZcjs.QueryOperators.$eq, val) : handleOperator(key, nestedKey, val)
|
|
140
|
-
),
|
|
141
|
-
` ${AND} `
|
|
142
|
-
);
|
|
143
|
-
};
|
|
144
|
-
var isRecord = (value) => value !== null && typeof value === "object" && !Array.isArray(value);
|
|
145
|
-
|
|
146
|
-
// src/storage/sqlite/core/sqlBuilder/update/index.ts
|
|
147
|
-
|
|
148
|
-
var buildUpdateQuery = (update) => _chunkYLV7YIPZcjs.objectEntries.call(void 0, update).reduce(
|
|
149
|
-
(currentUpdateQuery, [op, value]) => {
|
|
150
|
-
switch (op) {
|
|
151
|
-
case "$set":
|
|
152
|
-
return buildSetQuery(value, currentUpdateQuery);
|
|
153
|
-
case "$unset":
|
|
154
|
-
return buildUnsetQuery(value, currentUpdateQuery);
|
|
155
|
-
case "$inc":
|
|
156
|
-
return buildIncQuery(value, currentUpdateQuery);
|
|
157
|
-
case "$push":
|
|
158
|
-
return buildPushQuery(value, currentUpdateQuery);
|
|
159
|
-
default:
|
|
160
|
-
return currentUpdateQuery;
|
|
161
|
-
}
|
|
162
|
-
},
|
|
163
|
-
_dumbo.SQL`data`
|
|
164
|
-
);
|
|
165
|
-
var buildSetQuery = (set, currentUpdateQuery) => _dumbo.SQL`json_patch(${currentUpdateQuery}, ${_dumbo.JSONSerializer.serialize(set)})`;
|
|
166
|
-
var buildUnsetQuery = (unset, currentUpdateQuery) => {
|
|
167
|
-
const keys = Object.keys(unset);
|
|
168
|
-
let query = currentUpdateQuery;
|
|
169
|
-
for (const key of keys) {
|
|
170
|
-
query = _dumbo.SQL`json_remove(${query}, '$.${_dumbo.SQL.plain(key)}')`;
|
|
171
|
-
}
|
|
172
|
-
return query;
|
|
173
|
-
};
|
|
174
|
-
var buildIncQuery = (inc, currentUpdateQuery) => {
|
|
175
|
-
for (const [key, value] of Object.entries(inc)) {
|
|
176
|
-
currentUpdateQuery = typeof value === "bigint" ? _dumbo.SQL`json_set(${currentUpdateQuery}, '$.${_dumbo.SQL.plain(key)}', CAST((COALESCE(json_extract(${currentUpdateQuery}, '$.${_dumbo.SQL.plain(key)}'), 0) + ${value}) AS TEXT))` : _dumbo.SQL`json_set(${currentUpdateQuery}, '$.${_dumbo.SQL.plain(key)}', COALESCE(json_extract(${currentUpdateQuery}, '$.${_dumbo.SQL.plain(key)}'), 0) + ${value})`;
|
|
177
|
-
}
|
|
178
|
-
return currentUpdateQuery;
|
|
179
|
-
};
|
|
180
|
-
var buildPushQuery = (push, currentUpdateQuery) => {
|
|
181
|
-
for (const [key, value] of Object.entries(push)) {
|
|
182
|
-
const serializedValue = _dumbo.JSONSerializer.serialize(value);
|
|
183
|
-
currentUpdateQuery = _dumbo.SQL`json_set(${currentUpdateQuery}, '$.${_dumbo.SQL.plain(key)}', CASE
|
|
184
|
-
WHEN json_type(json_extract(${currentUpdateQuery}, '$.${_dumbo.SQL.plain(key)}')) = 'array'
|
|
185
|
-
THEN json_insert(json_extract(${currentUpdateQuery}, '$.${_dumbo.SQL.plain(key)}'), '$[#]', json(${serializedValue}))
|
|
186
|
-
ELSE json_array(json(${serializedValue}))
|
|
187
|
-
END)`;
|
|
188
|
-
}
|
|
189
|
-
return currentUpdateQuery;
|
|
190
|
-
};
|
|
191
|
-
|
|
192
|
-
// src/storage/sqlite/core/sqlBuilder/index.ts
|
|
193
|
-
var createCollection = (collectionName) => _dumbo.SQL`
|
|
194
|
-
CREATE TABLE IF NOT EXISTS ${_dumbo.SQL.identifier(collectionName)} (
|
|
195
|
-
_id TEXT PRIMARY KEY,
|
|
196
|
-
data JSON NOT NULL,
|
|
197
|
-
metadata JSON NOT NULL DEFAULT '{}',
|
|
198
|
-
_version INTEGER NOT NULL DEFAULT 1,
|
|
199
|
-
_partition TEXT NOT NULL DEFAULT 'png_global',
|
|
200
|
-
_archived INTEGER NOT NULL DEFAULT 0,
|
|
201
|
-
_created TEXT NOT NULL DEFAULT (datetime('now')),
|
|
202
|
-
_updated TEXT NOT NULL DEFAULT (datetime('now'))
|
|
203
|
-
)`;
|
|
204
|
-
var pongoCollectionSQLiteMigrations = (collectionName) => [
|
|
205
|
-
_dumbo.sqlMigration.call(void 0, `pongoCollection:${collectionName}:001:createtable`, [
|
|
206
|
-
createCollection(collectionName)
|
|
207
|
-
])
|
|
208
|
-
];
|
|
209
|
-
var sqliteSQLBuilder = (collectionName) => ({
|
|
210
|
-
createCollection: () => createCollection(collectionName),
|
|
211
|
-
insertOne: (document) => {
|
|
212
|
-
const serialized = document;
|
|
213
|
-
const id = document._id;
|
|
214
|
-
const version = _nullishCoalesce(document._version, () => ( 1n));
|
|
215
|
-
return _dumbo.SQL`
|
|
216
|
-
INSERT OR IGNORE INTO ${_dumbo.SQL.identifier(collectionName)} (_id, data, _version)
|
|
217
|
-
VALUES (${id}, ${serialized}, ${version})
|
|
218
|
-
RETURNING _id;`;
|
|
219
|
-
},
|
|
220
|
-
insertMany: (documents) => {
|
|
221
|
-
const values = _dumbo.SQL.merge(
|
|
222
|
-
documents.map(
|
|
223
|
-
(doc) => _dumbo.SQL`(${doc._id}, ${_dumbo.JSONSerializer.serialize(doc)}, ${_nullishCoalesce(doc._version, () => ( 1n))})`
|
|
224
|
-
),
|
|
225
|
-
","
|
|
226
|
-
);
|
|
227
|
-
return _dumbo.SQL`
|
|
228
|
-
INSERT OR IGNORE INTO ${_dumbo.SQL.identifier(collectionName)} (_id, data, _version) VALUES ${values}
|
|
229
|
-
RETURNING _id;`;
|
|
230
|
-
},
|
|
231
|
-
updateOne: (filter, update, options) => {
|
|
232
|
-
const expectedVersion = _chunkYLV7YIPZcjs.expectedVersionValue.call(void 0, _optionalChain([options, 'optionalAccess', _ => _.expectedVersion]));
|
|
233
|
-
const expectedVersionCheck = expectedVersion != null ? _dumbo.SQL`AND _version = ${expectedVersion}` : _dumbo.SQL``;
|
|
234
|
-
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter);
|
|
235
|
-
const updateQuery = _dumbo.isSQL.call(void 0, update) ? update : buildUpdateQuery(update);
|
|
236
|
-
return _dumbo.SQL`
|
|
237
|
-
UPDATE ${_dumbo.SQL.identifier(collectionName)}
|
|
238
|
-
SET
|
|
239
|
-
data = json_patch(${updateQuery}, json_object('_id', _id, '_version', cast(_version + 1 as TEXT))),
|
|
240
|
-
_version = _version + 1,
|
|
241
|
-
_updated = datetime('now')
|
|
242
|
-
WHERE _id = (
|
|
243
|
-
SELECT _id FROM ${_dumbo.SQL.identifier(collectionName)}
|
|
244
|
-
${where(filterQuery)}
|
|
245
|
-
LIMIT 1
|
|
246
|
-
) ${expectedVersionCheck}
|
|
247
|
-
RETURNING
|
|
248
|
-
_id,
|
|
249
|
-
cast(_version as TEXT) as version,
|
|
250
|
-
1 as matched,
|
|
251
|
-
1 as modified;`;
|
|
252
|
-
},
|
|
253
|
-
replaceOne: (filter, document, options) => {
|
|
254
|
-
const expectedVersion = _chunkYLV7YIPZcjs.expectedVersionValue.call(void 0, _optionalChain([options, 'optionalAccess', _2 => _2.expectedVersion]));
|
|
255
|
-
const expectedVersionCheck = expectedVersion != null ? _dumbo.SQL`AND _version = ${expectedVersion}` : _dumbo.SQL``;
|
|
256
|
-
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter);
|
|
257
|
-
return _dumbo.SQL`
|
|
258
|
-
UPDATE ${_dumbo.SQL.identifier(collectionName)}
|
|
259
|
-
SET
|
|
260
|
-
data = json_patch(${_dumbo.JSONSerializer.serialize(document)}, json_object('_id', _id, '_version', cast(_version + 1 as TEXT))),
|
|
261
|
-
_version = _version + 1,
|
|
262
|
-
_updated = datetime('now')
|
|
263
|
-
WHERE _id = (
|
|
264
|
-
SELECT _id FROM ${_dumbo.SQL.identifier(collectionName)}
|
|
265
|
-
${where(filterQuery)}
|
|
266
|
-
LIMIT 1
|
|
267
|
-
) ${expectedVersionCheck}
|
|
268
|
-
RETURNING
|
|
269
|
-
_id,
|
|
270
|
-
cast(_version as TEXT) AS version,
|
|
271
|
-
1 AS matched,
|
|
272
|
-
1 AS modified;`;
|
|
273
|
-
},
|
|
274
|
-
updateMany: (filter, update) => {
|
|
275
|
-
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter);
|
|
276
|
-
const updateQuery = _dumbo.isSQL.call(void 0, update) ? update : buildUpdateQuery(update);
|
|
277
|
-
return _dumbo.SQL`
|
|
278
|
-
UPDATE ${_dumbo.SQL.identifier(collectionName)}
|
|
279
|
-
SET
|
|
280
|
-
data = json_patch(${updateQuery}, json_object('_version', cast(_version + 1 as TEXT))),
|
|
281
|
-
_version = _version + 1,
|
|
282
|
-
_updated = datetime('now')
|
|
283
|
-
${where(filterQuery)}
|
|
284
|
-
RETURNING _id;`;
|
|
285
|
-
},
|
|
286
|
-
deleteOne: (filter, options) => {
|
|
287
|
-
const expectedVersion = _chunkYLV7YIPZcjs.expectedVersionValue.call(void 0, _optionalChain([options, 'optionalAccess', _3 => _3.expectedVersion]));
|
|
288
|
-
const expectedVersionCheck = expectedVersion != null ? _dumbo.SQL`AND _version = ${expectedVersion}` : _dumbo.SQL``;
|
|
289
|
-
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter);
|
|
290
|
-
return _dumbo.SQL`
|
|
291
|
-
DELETE FROM ${_dumbo.SQL.identifier(collectionName)}
|
|
292
|
-
WHERE _id = (
|
|
293
|
-
SELECT _id FROM ${_dumbo.SQL.identifier(collectionName)}
|
|
294
|
-
${where(filterQuery)}
|
|
295
|
-
LIMIT 1
|
|
296
|
-
) ${expectedVersionCheck}
|
|
297
|
-
RETURNING
|
|
298
|
-
_id,
|
|
299
|
-
1 AS matched,
|
|
300
|
-
1 AS deleted;`;
|
|
301
|
-
},
|
|
302
|
-
deleteMany: (filter) => {
|
|
303
|
-
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter);
|
|
304
|
-
return _dumbo.SQL`DELETE FROM ${_dumbo.SQL.identifier(collectionName)} ${where(filterQuery)} RETURNING _id`;
|
|
305
|
-
},
|
|
306
|
-
findOne: (filter) => {
|
|
307
|
-
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter);
|
|
308
|
-
return _dumbo.SQL`SELECT data FROM ${_dumbo.SQL.identifier(collectionName)} ${where(filterQuery)} LIMIT 1;`;
|
|
309
|
-
},
|
|
310
|
-
find: (filter, options) => {
|
|
311
|
-
const filterQuery = _dumbo.isSQL.call(void 0, filter) ? filter : constructFilterQuery(filter);
|
|
312
|
-
const query = [];
|
|
313
|
-
query.push(_dumbo.SQL`SELECT data FROM ${_dumbo.SQL.identifier(collectionName)}`);
|
|
314
|
-
query.push(where(filterQuery));
|
|
315
|
-
if (_optionalChain([options, 'optionalAccess', _4 => _4.limit])) {
|
|
316
|
-
query.push(_dumbo.SQL`LIMIT ${options.limit}`);
|
|
317
|
-
}
|
|
318
|
-
if (_optionalChain([options, 'optionalAccess', _5 => _5.skip])) {
|
|
319
|
-
query.push(_dumbo.SQL`OFFSET ${options.skip}`);
|
|
320
|
-
}
|
|
321
|
-
return _dumbo.SQL.merge([...query, _dumbo.SQL`;`]);
|
|
322
|
-
},
|
|
323
|
-
countDocuments: (filter) => {
|
|
324
|
-
const filterQuery = _dumbo.SQL.check.isSQL(filter) ? filter : constructFilterQuery(filter);
|
|
325
|
-
return _dumbo.SQL`SELECT COUNT(1) as count FROM ${_dumbo.SQL.identifier(collectionName)} ${where(filterQuery)};`;
|
|
326
|
-
},
|
|
327
|
-
rename: (newName) => _dumbo.SQL`ALTER TABLE ${_dumbo.SQL.identifier(collectionName)} RENAME TO ${_dumbo.SQL.identifier(newName)};`,
|
|
328
|
-
drop: (targetName = collectionName) => _dumbo.SQL`DROP TABLE IF EXISTS ${_dumbo.SQL.identifier(targetName)}`
|
|
329
|
-
});
|
|
330
|
-
var where = (filterQuery) => _dumbo.SQL.check.isEmpty(filterQuery) ? _dumbo.SQL.EMPTY : _dumbo.SQL.merge([_dumbo.SQL`WHERE `, filterQuery]);
|
|
12
|
+
var _chunk4BL6YWLWcjs = require('./chunk-4BL6YWLW.cjs');
|
|
331
13
|
|
|
332
14
|
// src/storage/sqlite/sqlite3/index.ts
|
|
333
|
-
|
|
15
|
+
var _dumbo = require('@event-driven-io/dumbo');
|
|
334
16
|
|
|
335
17
|
|
|
336
18
|
|
|
@@ -340,33 +22,35 @@ var sqlite3DatabaseDriver = {
|
|
|
340
22
|
driverType: _sqlite3.SQLite3DriverType,
|
|
341
23
|
databaseFactory: (options) => {
|
|
342
24
|
const databaseName = _nullishCoalesce(options.databaseName, () => ( getDatabaseNameOrDefault(options.connectionString)));
|
|
343
|
-
return
|
|
25
|
+
return _chunk4BL6YWLWcjs.PongoDatabase.call(void 0, {
|
|
344
26
|
...options,
|
|
345
27
|
pool: _dumbo.dumbo.call(void 0, {
|
|
346
28
|
connectionString: options.connectionString,
|
|
347
29
|
driver: _sqlite3.sqlite3DatabaseDriver,
|
|
348
30
|
...options.connectionOptions
|
|
349
31
|
}),
|
|
350
|
-
schemaComponent:
|
|
32
|
+
schemaComponent: _chunk4BL6YWLWcjs.PongoDatabaseSchemaComponent.call(void 0, {
|
|
351
33
|
driverType: _sqlite3.SQLite3DriverType,
|
|
352
|
-
collectionFactory: (schema) =>
|
|
34
|
+
collectionFactory: (schema) => _chunk4BL6YWLWcjs.PongoCollectionSchemaComponent.call(void 0, {
|
|
353
35
|
driverType: _sqlite3.SQLite3DriverType,
|
|
354
36
|
definition: schema,
|
|
355
37
|
migrationsOrSchemaComponents: {
|
|
356
|
-
migrations: pongoCollectionSQLiteMigrations(schema.name)
|
|
38
|
+
migrations: _chunkECQ2CKZEcjs.pongoCollectionSQLiteMigrations.call(void 0, schema.name)
|
|
357
39
|
},
|
|
358
|
-
sqlBuilder: sqliteSQLBuilder(schema.name)
|
|
40
|
+
sqlBuilder: _chunkECQ2CKZEcjs.sqliteSQLBuilder.call(void 0, schema.name)
|
|
359
41
|
}),
|
|
360
|
-
definition: _nullishCoalesce(_optionalChain([options, 'access',
|
|
42
|
+
definition: _nullishCoalesce(_optionalChain([options, 'access', _ => _.schema, 'optionalAccess', _2 => _2.definition]), () => ( _chunk4BL6YWLWcjs.pongoSchema.db(databaseName, {})))
|
|
361
43
|
}),
|
|
362
44
|
databaseName
|
|
363
45
|
});
|
|
364
46
|
},
|
|
365
|
-
getDatabaseNameOrDefault
|
|
47
|
+
getDatabaseNameOrDefault: (options) => {
|
|
48
|
+
return _nullishCoalesce(options.databaseName, () => ( getDatabaseNameOrDefault(options.connectionString)));
|
|
49
|
+
},
|
|
366
50
|
defaultConnectionString: ":memory:"
|
|
367
51
|
};
|
|
368
52
|
var useSqlite3DatabaseDriver = () => {
|
|
369
|
-
|
|
53
|
+
_chunk4BL6YWLWcjs.pongoDatabaseDriverRegistry.register(
|
|
370
54
|
_sqlite3.SQLite3DriverType,
|
|
371
55
|
sqlite3DatabaseDriver
|
|
372
56
|
);
|
|
@@ -378,5 +62,5 @@ useSqlite3DatabaseDriver();
|
|
|
378
62
|
|
|
379
63
|
|
|
380
64
|
|
|
381
|
-
exports.databaseDriver = sqlite3DatabaseDriver; exports.pongoCollectionSQLiteMigrations = pongoCollectionSQLiteMigrations; exports.sqlite3Driver = sqlite3DatabaseDriver; exports.sqliteSQLBuilder = sqliteSQLBuilder; exports.useSqlite3DatabaseDriver = useSqlite3DatabaseDriver;
|
|
65
|
+
exports.databaseDriver = sqlite3DatabaseDriver; exports.pongoCollectionSQLiteMigrations = _chunkECQ2CKZEcjs.pongoCollectionSQLiteMigrations; exports.sqlite3Driver = sqlite3DatabaseDriver; exports.sqliteSQLBuilder = _chunkECQ2CKZEcjs.sqliteSQLBuilder; exports.useSqlite3DatabaseDriver = useSqlite3DatabaseDriver;
|
|
382
66
|
//# sourceMappingURL=sqlite3.cjs.map
|
package/dist/sqlite3.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/home/runner/work/Pongo/Pongo/src/packages/pongo/dist/sqlite3.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","../src/storage/sqlite/sqlite3/index.ts"],"names":["SQL"],"mappings":"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","file":"/home/runner/work/Pongo/Pongo/src/packages/pongo/dist/sqlite3.cjs","sourcesContent":[null,"import {\n isSQL,\n JSONSerializer,\n SQL,\n sqlMigration,\n} from '@event-driven-io/dumbo';\nimport {\n expectedVersionValue,\n type DeleteOneOptions,\n type FindOptions,\n type OptionalUnlessRequiredIdAndVersion,\n type PongoCollectionSQLBuilder,\n type PongoFilter,\n type PongoUpdate,\n type ReplaceOneOptions,\n type UpdateOneOptions,\n type WithoutId,\n} from '../../../../core';\nimport { constructFilterQuery } from './filter';\nimport { buildUpdateQuery } from './update';\n\nconst createCollection = (collectionName: string): SQL =>\n SQL`\n CREATE TABLE IF NOT EXISTS ${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): 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}, ${JSONSerializer.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) ? filter : constructFilterQuery(filter);\n const updateQuery = isSQL(update) ? update : buildUpdateQuery(update);\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) ? filter : constructFilterQuery(filter);\n\n return SQL`\n UPDATE ${SQL.identifier(collectionName)}\n SET\n data = json_patch(${JSONSerializer.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) ? filter : constructFilterQuery(filter);\n const updateQuery = isSQL(update) ? update : buildUpdateQuery(update);\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) ? filter : constructFilterQuery(filter);\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) ? filter : constructFilterQuery(filter);\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) ? filter : constructFilterQuery(filter);\n\n return SQL`SELECT data FROM ${SQL.identifier(collectionName)} ${where(filterQuery)} LIMIT 1;`;\n },\n find: <T>(filter: PongoFilter<T> | SQL, options?: FindOptions): SQL => {\n const filterQuery = isSQL(filter) ? filter : constructFilterQuery(filter);\n const query: SQL[] = [];\n\n query.push(SQL`SELECT data FROM ${SQL.identifier(collectionName)}`);\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);\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 { 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>(filter: PongoFilter<T>): SQL =>\n SQL.merge(\n Object.entries(filter).map(([key, value]) =>\n isRecord(value)\n ? constructComplexFilterQuery(key, value)\n : handleOperator(key, '$eq', value),\n ),\n ` ${AND} `,\n );\n\nconst constructComplexFilterQuery = (\n key: string,\n value: Record<string, unknown>,\n): SQL => {\n const isEquality = !hasOperators(value);\n\n return SQL.merge(\n objectEntries(value).map(([nestedKey, val]) =>\n isEquality\n ? handleOperator(`${key}.${nestedKey}`, QueryOperators.$eq, val)\n : handleOperator(key, nestedKey, val),\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 { JSONSerializer, SQL } from '@event-driven-io/dumbo';\nimport { objectEntries, OperatorMap } from '../../../../../core';\n\nexport const handleOperator = (\n path: string,\n operator: string,\n value: unknown,\n): 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 = JSONSerializer.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 = JSONSerializer.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 { JSONSerializer, SQL } from '@event-driven-io/dumbo';\nimport {\n objectEntries,\n type $inc,\n type $push,\n type $set,\n type $unset,\n type PongoUpdate,\n} from '../../../../../core';\n\nexport const buildUpdateQuery = <T>(update: PongoUpdate<T>): SQL =>\n objectEntries(update).reduce(\n (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 },\n SQL`data`,\n );\n\nexport const buildSetQuery = <T>(set: $set<T>, currentUpdateQuery: SQL): SQL =>\n SQL`json_patch(${currentUpdateQuery}, ${JSONSerializer.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): SQL => {\n for (const [key, value] of Object.entries(push)) {\n const serializedValue = JSONSerializer.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 { dumbo } from '@event-driven-io/dumbo';\nimport {\n sqlite3DatabaseDriver as dumboDriver,\n SQLite3DriverType,\n} from '@event-driven-io/dumbo/sqlite3';\nimport {\n PongoCollectionSchemaComponent,\n PongoDatabase,\n pongoDatabaseDriverRegistry,\n PongoDatabaseSchemaComponent,\n pongoSchema,\n type PongoDatabaseDriver,\n type PongoDatabaseDriverOptions,\n type PongoDb,\n} from '../../../core';\nimport { pongoCollectionSQLiteMigrations, sqliteSQLBuilder } from '../core';\n\nexport type SQLitePongoClientOptions = object;\n\ntype SQLiteDatabaseDriverOptions =\n PongoDatabaseDriverOptions<SQLitePongoClientOptions>;\n\nconst getDatabaseNameOrDefault = (connectionString?: string) =>\n connectionString || ':memory:';\n\nconst sqlite3DatabaseDriver: PongoDatabaseDriver<\n PongoDb<SQLite3DriverType>,\n SQLiteDatabaseDriverOptions\n> = {\n driverType: SQLite3DriverType,\n databaseFactory: (options) => {\n const databaseName =\n options.databaseName ??\n getDatabaseNameOrDefault(options.connectionString);\n\n return PongoDatabase({\n ...options,\n pool: dumbo({\n connectionString: options.connectionString,\n driver: dumboDriver,\n ...options.connectionOptions,\n }),\n schemaComponent: PongoDatabaseSchemaComponent({\n driverType: SQLite3DriverType,\n collectionFactory: (schema) =>\n PongoCollectionSchemaComponent({\n driverType: SQLite3DriverType,\n definition: schema,\n migrationsOrSchemaComponents: {\n migrations: pongoCollectionSQLiteMigrations(schema.name),\n },\n sqlBuilder: sqliteSQLBuilder(schema.name),\n }),\n definition:\n options.schema?.definition ?? pongoSchema.db(databaseName, {}),\n }),\n databaseName,\n });\n },\n getDatabaseNameOrDefault,\n defaultConnectionString: ':memory:',\n};\n\nexport const useSqlite3DatabaseDriver = () => {\n pongoDatabaseDriverRegistry.register(\n SQLite3DriverType,\n sqlite3DatabaseDriver,\n );\n};\n\nuseSqlite3DatabaseDriver();\n\nexport {\n sqlite3DatabaseDriver as databaseDriver,\n sqlite3DatabaseDriver as sqlite3Driver,\n};\n"]}
|
|
1
|
+
{"version":3,"sources":["/home/runner/work/Pongo/Pongo/src/packages/pongo/dist/sqlite3.cjs","../src/storage/sqlite/sqlite3/index.ts"],"names":[],"mappings":"AAAA;AACE;AACA;AACF,wDAA6B;AAC7B,gCAA6B;AAC7B;AACE;AACA;AACA;AACA;AACA;AACF,wDAA6B;AAC7B;AACA;ACbA,+CAAsB;AACtB;AACE;AACA;AAAA,yDACK;AAqBP,IAAM,yBAAA,EAA2B,CAAC,gBAAA,EAAA,GAChC,iBAAA,GAAoB,UAAA;AAEtB,IAAM,sBAAA,EAGF;AAAA,EACF,UAAA,EAAY,0BAAA;AAAA,EACZ,eAAA,EAAiB,CAAC,OAAA,EAAA,GAAY;AAC5B,IAAA,MAAM,aAAA,mBACJ,OAAA,CAAQ,YAAA,UACR,wBAAA,CAAyB,OAAA,CAAQ,gBAAgB,GAAA;AAEnD,IAAA,OAAO,6CAAA;AAAc,MACnB,GAAG,OAAA;AAAA,MACH,IAAA,EAAM,0BAAA;AAAM,QACV,gBAAA,EAAkB,OAAA,CAAQ,gBAAA;AAAA,QAC1B,MAAA,EAAQ,8BAAA;AAAA,QACR,GAAG,OAAA,CAAQ;AAAA,MACb,CAAC,CAAA;AAAA,MACD,eAAA,EAAiB,4DAAA;AAA6B,QAC5C,UAAA,EAAY,0BAAA;AAAA,QACZ,iBAAA,EAAmB,CAAC,MAAA,EAAA,GAClB,8DAAA;AAA+B,UAC7B,UAAA,EAAY,0BAAA;AAAA,UACZ,UAAA,EAAY,MAAA;AAAA,UACZ,4BAAA,EAA8B;AAAA,YAC5B,UAAA,EAAY,+DAAA,MAAgC,CAAO,IAAI;AAAA,UACzD,CAAA;AAAA,UACA,UAAA,EAAY,gDAAA,MAAiB,CAAO,IAAI;AAAA,QAC1C,CAAC,CAAA;AAAA,QACH,UAAA,mCACE,OAAA,mBAAQ,MAAA,6BAAQ,YAAA,UAAc,6BAAA,CAAY,EAAA,CAAG,YAAA,EAAc,CAAC,CAAC;AAAA,MACjE,CAAC,CAAA;AAAA,MACD;AAAA,IACF,CAAC,CAAA;AAAA,EACH,CAAA;AAAA,EACA,wBAAA,EAA0B,CAAC,OAAA,EAAA,GAAY;AACrC,IAAA,wBACE,OAAA,CAAQ,YAAA,UAAgB,wBAAA,CAAyB,OAAA,CAAQ,gBAAgB,GAAA;AAAA,EAE7E,CAAA;AAAA,EACA,uBAAA,EAAyB;AAC3B,CAAA;AAEO,IAAM,yBAAA,EAA2B,CAAA,EAAA,GAAM;AAC5C,EAAA,6CAAA,CAA4B,QAAA;AAAA,IAC1B,0BAAA;AAAA,IACA;AAAA,EACF,CAAA;AACF,CAAA;AAEA,wBAAA,CAAyB,CAAA;ADnBzB;AACE;AACA;AACA;AACA;AACA;AACF,uTAAC","file":"/home/runner/work/Pongo/Pongo/src/packages/pongo/dist/sqlite3.cjs","sourcesContent":[null,"import { dumbo } from '@event-driven-io/dumbo';\nimport {\n sqlite3DatabaseDriver as dumboDriver,\n SQLite3DriverType,\n} from '@event-driven-io/dumbo/sqlite3';\nimport {\n PongoCollectionSchemaComponent,\n PongoDatabase,\n pongoDatabaseDriverRegistry,\n PongoDatabaseSchemaComponent,\n pongoSchema,\n type PongoDatabaseDriver,\n type PongoDatabaseDriverOptions,\n type PongoDb,\n} from '../../../core';\nimport { pongoCollectionSQLiteMigrations, sqliteSQLBuilder } from '../core';\n\nexport type SQLitePongoClientOptions = object;\n\ntype SQLiteDatabaseDriverOptions =\n PongoDatabaseDriverOptions<SQLitePongoClientOptions> & {\n databaseName?: string | undefined;\n connectionString: string;\n };\n\nconst getDatabaseNameOrDefault = (connectionString?: string) =>\n connectionString || ':memory:';\n\nconst sqlite3DatabaseDriver: PongoDatabaseDriver<\n PongoDb<SQLite3DriverType>,\n SQLiteDatabaseDriverOptions\n> = {\n driverType: SQLite3DriverType,\n databaseFactory: (options) => {\n const databaseName =\n options.databaseName ??\n getDatabaseNameOrDefault(options.connectionString);\n\n return PongoDatabase({\n ...options,\n pool: dumbo({\n connectionString: options.connectionString,\n driver: dumboDriver,\n ...options.connectionOptions,\n }),\n schemaComponent: PongoDatabaseSchemaComponent({\n driverType: SQLite3DriverType,\n collectionFactory: (schema) =>\n PongoCollectionSchemaComponent({\n driverType: SQLite3DriverType,\n definition: schema,\n migrationsOrSchemaComponents: {\n migrations: pongoCollectionSQLiteMigrations(schema.name),\n },\n sqlBuilder: sqliteSQLBuilder(schema.name),\n }),\n definition:\n options.schema?.definition ?? pongoSchema.db(databaseName, {}),\n }),\n databaseName,\n });\n },\n getDatabaseNameOrDefault: (options) => {\n return (\n options.databaseName ?? getDatabaseNameOrDefault(options.connectionString)\n );\n },\n defaultConnectionString: ':memory:',\n};\n\nexport const useSqlite3DatabaseDriver = () => {\n pongoDatabaseDriverRegistry.register(\n SQLite3DriverType,\n sqlite3DatabaseDriver,\n );\n};\n\nuseSqlite3DatabaseDriver();\n\nexport {\n sqlite3DatabaseDriver as databaseDriver,\n sqlite3DatabaseDriver as sqlite3Driver,\n};\n"]}
|
package/dist/sqlite3.d.cts
CHANGED
|
@@ -1,13 +1,14 @@
|
|
|
1
|
-
|
|
2
|
-
import { q as PongoCollectionSQLBuilder, e as PongoDatabaseDriver, P as PongoDb, y as PongoDatabaseDriverOptions } from './pongoCollectionSchemaComponent-BsHlVyN-.cjs';
|
|
1
|
+
export { p as pongoCollectionSQLiteMigrations, s as sqliteSQLBuilder } from './index-BJopB-em.cjs';
|
|
3
2
|
import { SQLite3DriverType } from '@event-driven-io/dumbo/sqlite3';
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
declare const sqliteSQLBuilder: (collectionName: string) => PongoCollectionSQLBuilder;
|
|
3
|
+
import { P as PongoDatabaseDriver, a as PongoDb, b as PongoDatabaseDriverOptions } from './pongoCollectionSchemaComponent-t_e9n2Wc.cjs';
|
|
4
|
+
import '@event-driven-io/dumbo';
|
|
7
5
|
|
|
8
6
|
type SQLitePongoClientOptions = object;
|
|
9
|
-
type SQLiteDatabaseDriverOptions = PongoDatabaseDriverOptions<SQLitePongoClientOptions
|
|
7
|
+
type SQLiteDatabaseDriverOptions = PongoDatabaseDriverOptions<SQLitePongoClientOptions> & {
|
|
8
|
+
databaseName?: string | undefined;
|
|
9
|
+
connectionString: string;
|
|
10
|
+
};
|
|
10
11
|
declare const sqlite3DatabaseDriver: PongoDatabaseDriver<PongoDb<SQLite3DriverType>, SQLiteDatabaseDriverOptions>;
|
|
11
12
|
declare const useSqlite3DatabaseDriver: () => void;
|
|
12
13
|
|
|
13
|
-
export { type SQLitePongoClientOptions, sqlite3DatabaseDriver as databaseDriver,
|
|
14
|
+
export { type SQLitePongoClientOptions, sqlite3DatabaseDriver as databaseDriver, sqlite3DatabaseDriver as sqlite3Driver, useSqlite3DatabaseDriver };
|
package/dist/sqlite3.d.ts
CHANGED
|
@@ -1,13 +1,14 @@
|
|
|
1
|
-
|
|
2
|
-
import { q as PongoCollectionSQLBuilder, e as PongoDatabaseDriver, P as PongoDb, y as PongoDatabaseDriverOptions } from './pongoCollectionSchemaComponent-BsHlVyN-.js';
|
|
1
|
+
export { p as pongoCollectionSQLiteMigrations, s as sqliteSQLBuilder } from './index-G5DECNb_.js';
|
|
3
2
|
import { SQLite3DriverType } from '@event-driven-io/dumbo/sqlite3';
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
declare const sqliteSQLBuilder: (collectionName: string) => PongoCollectionSQLBuilder;
|
|
3
|
+
import { P as PongoDatabaseDriver, a as PongoDb, b as PongoDatabaseDriverOptions } from './pongoCollectionSchemaComponent-t_e9n2Wc.js';
|
|
4
|
+
import '@event-driven-io/dumbo';
|
|
7
5
|
|
|
8
6
|
type SQLitePongoClientOptions = object;
|
|
9
|
-
type SQLiteDatabaseDriverOptions = PongoDatabaseDriverOptions<SQLitePongoClientOptions
|
|
7
|
+
type SQLiteDatabaseDriverOptions = PongoDatabaseDriverOptions<SQLitePongoClientOptions> & {
|
|
8
|
+
databaseName?: string | undefined;
|
|
9
|
+
connectionString: string;
|
|
10
|
+
};
|
|
10
11
|
declare const sqlite3DatabaseDriver: PongoDatabaseDriver<PongoDb<SQLite3DriverType>, SQLiteDatabaseDriverOptions>;
|
|
11
12
|
declare const useSqlite3DatabaseDriver: () => void;
|
|
12
13
|
|
|
13
|
-
export { type SQLitePongoClientOptions, sqlite3DatabaseDriver as databaseDriver,
|
|
14
|
+
export { type SQLitePongoClientOptions, sqlite3DatabaseDriver as databaseDriver, sqlite3DatabaseDriver as sqlite3Driver, useSqlite3DatabaseDriver };
|