@op-engineering/op-sqlite 14.1.4 → 15.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,387 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.IOS_LIBRARY_PATH = exports.IOS_DOCUMENT_PATH = exports.ANDROID_FILES_PATH = exports.ANDROID_EXTERNAL_FILES_PATH = exports.ANDROID_DATABASE_PATH = void 0;
7
- Object.defineProperty(exports, "Storage", {
8
- enumerable: true,
9
- get: function () {
10
- return _Storage.Storage;
11
- }
12
- });
13
- exports.openSync = exports.openRemote = exports.open = exports.moveAssetsDatabase = exports.isSQLCipher = exports.isLibsql = exports.isIOSEmbeeded = exports.getDylibPath = void 0;
14
- var _reactNative = require("react-native");
15
- var _Storage = require("./Storage");
16
- /**
17
- * Object returned by SQL Query executions {
18
- * insertId: Represent the auto-generated row id if applicable
19
- * rowsAffected: Number of affected rows if result of a update query
20
- * message: if status === 1, here you will find error description
21
- * rows: if status is undefined or 0 this object will contain the query results
22
- * }
23
- *
24
- * @interface QueryResult
25
- */
26
-
27
- /**
28
- * Column metadata
29
- * Describes some information about columns fetched by the query
30
- */
31
-
32
- /**
33
- * Allows the execution of bulk of sql commands
34
- * inside a transaction
35
- * If a single query must be executed many times with different arguments, its preferred
36
- * to declare it a single time, and use an array of array parameters.
37
- */
38
-
39
- /**
40
- * status: 0 or undefined for correct execution, 1 for error
41
- * message: if status === 1, here you will find error description
42
- * rowsAffected: Number of affected rows if status == 0
43
- */
44
-
45
- /**
46
- * Result of loading a file and executing every line as a SQL command
47
- * Similar to BatchQueryResult
48
- */
49
-
50
- if (global.__OPSQLiteProxy == null) {
51
- if (_reactNative.NativeModules.OPSQLite == null) {
52
- throw new Error('Base module not found. Did you do a pod install/clear the gradle cache?');
53
- }
54
-
55
- // Call the synchronous blocking install() function
56
- const installed = _reactNative.NativeModules.OPSQLite.install();
57
- if (!installed) {
58
- throw new Error(`Failed to install op-sqlite: The native OPSQLite Module could not be installed! Looks like something went wrong when installing JSI bindings, check the native logs for more info`);
59
- }
60
-
61
- // Check again if the constructor now exists. If not, throw an error.
62
- if (global.__OPSQLiteProxy == null) {
63
- throw new Error('OPSqlite native object is not available. Something is wrong. Check the native logs for more information.');
64
- }
65
- }
66
- const proxy = global.__OPSQLiteProxy;
67
- const OPSQLite = proxy;
68
- const {
69
- IOS_DOCUMENT_PATH,
70
- IOS_LIBRARY_PATH,
71
- ANDROID_DATABASE_PATH,
72
- ANDROID_FILES_PATH,
73
- ANDROID_EXTERNAL_FILES_PATH
74
- } = !!_reactNative.NativeModules.OPSQLite.getConstants ? _reactNative.NativeModules.OPSQLite.getConstants() : _reactNative.NativeModules.OPSQLite;
75
- exports.ANDROID_EXTERNAL_FILES_PATH = ANDROID_EXTERNAL_FILES_PATH;
76
- exports.ANDROID_FILES_PATH = ANDROID_FILES_PATH;
77
- exports.ANDROID_DATABASE_PATH = ANDROID_DATABASE_PATH;
78
- exports.IOS_LIBRARY_PATH = IOS_LIBRARY_PATH;
79
- exports.IOS_DOCUMENT_PATH = IOS_DOCUMENT_PATH;
80
- function enhanceDB(db, options) {
81
- const lock = {
82
- queue: [],
83
- inProgress: false
84
- };
85
- const startNextTransaction = () => {
86
- if (lock.inProgress) {
87
- // Transaction is already in process bail out
88
- return;
89
- }
90
- if (lock.queue.length) {
91
- lock.inProgress = true;
92
- const tx = lock.queue.shift();
93
- if (!tx) {
94
- throw new Error('Could not get a operation on database');
95
- }
96
- setImmediate(() => {
97
- tx.start();
98
- });
99
- }
100
- };
101
- function sanitizeArrayBuffersInArray(params) {
102
- if (!params) {
103
- return params;
104
- }
105
- return params.map(p => {
106
- if (Array.isArray(p)) {
107
- return sanitizeArrayBuffersInArray(p);
108
- }
109
- if (ArrayBuffer.isView(p)) {
110
- return p.buffer;
111
- }
112
- return p;
113
- });
114
- }
115
-
116
- // spreading the object does not work with HostObjects (db)
117
- // We need to manually assign the fields
118
- let enhancedDb = {
119
- delete: db.delete,
120
- attach: db.attach,
121
- detach: db.detach,
122
- executeBatch: async commands => {
123
- const sanitizedCommands = commands.map(([query, params]) => {
124
- if (params) {
125
- return [query, sanitizeArrayBuffersInArray(params)];
126
- }
127
- return [query];
128
- });
129
- async function run() {
130
- try {
131
- enhancedDb.executeSync('BEGIN TRANSACTION;');
132
- let res = await db.executeBatch(sanitizedCommands);
133
- enhancedDb.executeSync('COMMIT;');
134
- return res;
135
- } catch (executionError) {
136
- try {
137
- enhancedDb.executeSync('ROLLBACK;');
138
- } catch (rollbackError) {
139
- throw rollbackError;
140
- }
141
- throw executionError;
142
- } finally {
143
- lock.inProgress = false;
144
- startNextTransaction();
145
- }
146
- }
147
- return await new Promise((resolve, reject) => {
148
- const tx = {
149
- start: () => {
150
- run().then(resolve).catch(reject);
151
- }
152
- };
153
- lock.queue.push(tx);
154
- startNextTransaction();
155
- });
156
- },
157
- loadFile: db.loadFile,
158
- updateHook: db.updateHook,
159
- commitHook: db.commitHook,
160
- rollbackHook: db.rollbackHook,
161
- loadExtension: db.loadExtension,
162
- getDbPath: db.getDbPath,
163
- reactiveExecute: db.reactiveExecute,
164
- sync: db.sync,
165
- close: db.close,
166
- executeWithHostObjects: async (query, params) => {
167
- const sanitizedParams = sanitizeArrayBuffersInArray(params);
168
- return sanitizedParams ? await db.executeWithHostObjects(query, sanitizedParams) : await db.executeWithHostObjects(query);
169
- },
170
- executeRaw: async (query, params) => {
171
- const sanitizedParams = sanitizeArrayBuffersInArray(params);
172
- return db.executeRaw(query, sanitizedParams);
173
- },
174
- // Wrapper for executeRaw, drizzleORM uses this function
175
- // at some point I changed the API but they did not pin their dependency to a specific version
176
- // so re-inserting this so it starts working again
177
- executeRawAsync: async (query, params) => {
178
- const sanitizedParams = sanitizeArrayBuffersInArray(params);
179
- return db.executeRaw(query, sanitizedParams);
180
- },
181
- executeSync: (query, params) => {
182
- const sanitizedParams = sanitizeArrayBuffersInArray(params);
183
- let intermediateResult = sanitizedParams ? db.executeSync(query, sanitizedParams) : db.executeSync(query);
184
- let rows = [];
185
- for (let i = 0; i < (intermediateResult.rawRows?.length ?? 0); i++) {
186
- let row = {};
187
- let rawRow = intermediateResult.rawRows[i];
188
- for (let j = 0; j < intermediateResult.columnNames.length; j++) {
189
- let columnName = intermediateResult.columnNames[j];
190
- let value = rawRow[j];
191
- row[columnName] = value;
192
- }
193
- rows.push(row);
194
- }
195
- let res = {
196
- ...intermediateResult,
197
- rows
198
- };
199
- delete res.rawRows;
200
- return res;
201
- },
202
- executeAsync: async (query, params) => {
203
- return db.execute(query, params);
204
- },
205
- execute: async (query, params) => {
206
- const sanitizedParams = sanitizeArrayBuffersInArray(params);
207
- let intermediateResult = await db.execute(query, sanitizedParams);
208
- let rows = [];
209
- for (let i = 0; i < (intermediateResult.rawRows?.length ?? 0); i++) {
210
- let row = {};
211
- let rawRow = intermediateResult.rawRows[i];
212
- for (let j = 0; j < intermediateResult.columnNames.length; j++) {
213
- let columnName = intermediateResult.columnNames[j];
214
- let value = rawRow[j];
215
- row[columnName] = value;
216
- }
217
- rows.push(row);
218
- }
219
- let res = {
220
- ...intermediateResult,
221
- rows
222
- };
223
- delete res.rawRows;
224
- return res;
225
- },
226
- prepareStatement: query => {
227
- const stmt = db.prepareStatement(query);
228
- return {
229
- bindSync: params => {
230
- const sanitizedParams = sanitizeArrayBuffersInArray(params);
231
- stmt.bindSync(sanitizedParams);
232
- },
233
- bind: async params => {
234
- const sanitizedParams = sanitizeArrayBuffersInArray(params);
235
- await stmt.bind(sanitizedParams);
236
- },
237
- execute: stmt.execute
238
- };
239
- },
240
- transaction: async fn => {
241
- let isFinalized = false;
242
- const execute = async (query, params) => {
243
- if (isFinalized) {
244
- throw Error(`OP-Sqlite Error: Database: ${options.name || options.url}. Cannot execute query on finalized transaction`);
245
- }
246
- return await enhancedDb.execute(query, params);
247
- };
248
- const commit = async () => {
249
- if (isFinalized) {
250
- throw Error(`OP-Sqlite Error: Database: ${options.name || options.url}. Cannot execute query on finalized transaction`);
251
- }
252
- const result = enhancedDb.executeSync('COMMIT;');
253
- await db.flushPendingReactiveQueries();
254
- isFinalized = true;
255
- return result;
256
- };
257
- const rollback = () => {
258
- if (isFinalized) {
259
- throw Error(`OP-Sqlite Error: Database: ${options.name || options.url}. Cannot execute query on finalized transaction`);
260
- }
261
- const result = enhancedDb.executeSync('ROLLBACK;');
262
- isFinalized = true;
263
- return result;
264
- };
265
- async function run() {
266
- try {
267
- enhancedDb.executeSync('BEGIN TRANSACTION;');
268
- await fn({
269
- commit,
270
- execute,
271
- rollback
272
- });
273
- if (!isFinalized) {
274
- commit();
275
- }
276
- } catch (executionError) {
277
- if (!isFinalized) {
278
- try {
279
- rollback();
280
- } catch (rollbackError) {
281
- throw rollbackError;
282
- }
283
- }
284
- throw executionError;
285
- } finally {
286
- lock.inProgress = false;
287
- isFinalized = false;
288
- startNextTransaction();
289
- }
290
- }
291
- return await new Promise((resolve, reject) => {
292
- const tx = {
293
- start: () => {
294
- run().then(resolve).catch(reject);
295
- }
296
- };
297
- lock.queue.push(tx);
298
- startNextTransaction();
299
- });
300
- }
301
- };
302
- return enhancedDb;
303
- }
304
-
305
- /**
306
- * Open a replicating connection via libsql to a turso db
307
- * libsql needs to be enabled on your package.json
308
- */
309
- const openSync = params => {
310
- if (!isLibsql()) {
311
- throw new Error('This function is only available for libsql');
312
- }
313
- const db = OPSQLite.openSync(params);
314
- const enhancedDb = enhanceDB(db, params);
315
- return enhancedDb;
316
- };
317
-
318
- /**
319
- * Open a remote connection via libsql to a turso db
320
- * libsql needs to be enabled on your package.json
321
- */
322
- exports.openSync = openSync;
323
- const openRemote = params => {
324
- if (!isLibsql()) {
325
- throw new Error('This function is only available for libsql');
326
- }
327
- const db = OPSQLite.openRemote(params);
328
- const enhancedDb = enhanceDB(db, params);
329
- return enhancedDb;
330
- };
331
-
332
- /**
333
- * Open a connection to a local sqlite or sqlcipher database
334
- * If you want libsql remote or sync connections, use openSync or openRemote
335
- */
336
- exports.openRemote = openRemote;
337
- const open = params => {
338
- if (params.location?.startsWith('file://')) {
339
- console.warn("[op-sqlite] You are passing a path with 'file://' prefix, it's automatically removed");
340
- params.location = params.location.substring(7);
341
- }
342
- const db = OPSQLite.open(params);
343
- const enhancedDb = enhanceDB(db, params);
344
- return enhancedDb;
345
- };
346
-
347
- /**
348
- * Moves the database from the assets folder to the default path (check the docs) or to a custom path
349
- * It DOES NOT OVERWRITE the database if it already exists in the destination path
350
- * if you want to overwrite the database, you need to pass the overwrite flag as true
351
- * @param args object with the parameters for the operaiton
352
- * @returns promise, rejects if failed to move the database, resolves if the operation was successful
353
- */
354
- exports.open = open;
355
- const moveAssetsDatabase = async args => {
356
- return _reactNative.NativeModules.OPSQLite.moveAssetsDatabase(args);
357
- };
358
-
359
- /**
360
- * Used to load a dylib file that contains a sqlite 3 extension/plugin
361
- * It returns the raw path to the actual file which then needs to be passed to the loadExtension function
362
- * Check the docs for more information
363
- * @param bundle the iOS bundle identifier of the .framework
364
- * @param name the file name of the dylib file
365
- * @returns
366
- */
367
- exports.moveAssetsDatabase = moveAssetsDatabase;
368
- const getDylibPath = (bundle, name) => {
369
- return _reactNative.NativeModules.OPSQLite.getDylibPath(bundle, name);
370
- };
371
- exports.getDylibPath = getDylibPath;
372
- const isSQLCipher = () => {
373
- return OPSQLite.isSQLCipher();
374
- };
375
- exports.isSQLCipher = isSQLCipher;
376
- const isLibsql = () => {
377
- return OPSQLite.isLibsql();
378
- };
379
- exports.isLibsql = isLibsql;
380
- const isIOSEmbeeded = () => {
381
- if (_reactNative.Platform.OS !== 'ios') {
382
- return false;
383
- }
384
- return OPSQLite.isIOSEmbedded();
385
- };
386
- exports.isIOSEmbeeded = isIOSEmbeeded;
387
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["_reactNative","require","_Storage","global","__OPSQLiteProxy","NativeModules","OPSQLite","Error","installed","install","proxy","IOS_DOCUMENT_PATH","IOS_LIBRARY_PATH","ANDROID_DATABASE_PATH","ANDROID_FILES_PATH","ANDROID_EXTERNAL_FILES_PATH","getConstants","exports","enhanceDB","db","options","lock","queue","inProgress","startNextTransaction","length","tx","shift","setImmediate","start","sanitizeArrayBuffersInArray","params","map","p","Array","isArray","ArrayBuffer","isView","buffer","enhancedDb","delete","attach","detach","executeBatch","commands","sanitizedCommands","query","run","executeSync","res","executionError","rollbackError","Promise","resolve","reject","then","catch","push","loadFile","updateHook","commitHook","rollbackHook","loadExtension","getDbPath","reactiveExecute","sync","close","executeWithHostObjects","sanitizedParams","executeRaw","executeRawAsync","intermediateResult","rows","i","rawRows","row","rawRow","j","columnNames","columnName","value","executeAsync","execute","prepareStatement","stmt","bindSync","bind","transaction","fn","isFinalized","name","url","commit","result","flushPendingReactiveQueries","rollback","openSync","isLibsql","openRemote","open","location","startsWith","console","warn","substring","moveAssetsDatabase","args","getDylibPath","bundle","isSQLCipher","isIOSEmbeeded","Platform","OS","isIOSEmbedded"],"sourceRoot":"../../src","sources":["index.ts"],"mappings":"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","ignoreList":[]}
@@ -1 +0,0 @@
1
- {"type":"commonjs"}