@powersync/op-sqlite 0.0.0-dev-20250121114305 → 0.0.0-dev-20250121122709
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/android/build.gradle +124 -0
- package/android/gradle.properties +5 -0
- package/android/src/main/AndroidManifest.xml +3 -0
- package/android/src/main/AndroidManifestNew.xml +2 -0
- package/android/src/main/java/com/powersync/opsqlite/PowerSyncOpSqlitePackage.kt +31 -0
- package/ios/PowerSyncOpSqlite.h +5 -0
- package/ios/PowerSyncOpSqlite.mm +6 -0
- package/lib/commonjs/db/OPSQLiteConnection.js +103 -0
- package/lib/commonjs/db/OPSQLiteConnection.js.map +1 -0
- package/lib/commonjs/db/OPSqliteAdapter.js +250 -0
- package/lib/commonjs/db/OPSqliteAdapter.js.map +1 -0
- package/lib/commonjs/db/OPSqliteDBOpenFactory.js +26 -0
- package/lib/commonjs/db/OPSqliteDBOpenFactory.js.map +1 -0
- package/lib/commonjs/db/SqliteOptions.js +33 -0
- package/lib/commonjs/db/SqliteOptions.js.map +1 -0
- package/lib/commonjs/index.js +19 -0
- package/lib/commonjs/index.js.map +1 -0
- package/lib/module/db/OPSQLiteConnection.js +98 -0
- package/lib/module/db/OPSQLiteConnection.js.map +1 -0
- package/lib/module/db/OPSqliteAdapter.js +245 -0
- package/lib/module/db/OPSqliteAdapter.js.map +1 -0
- package/lib/module/db/OPSqliteDBOpenFactory.js +21 -0
- package/lib/module/db/OPSqliteDBOpenFactory.js.map +1 -0
- package/lib/module/db/SqliteOptions.js +29 -0
- package/lib/module/db/SqliteOptions.js.map +1 -0
- package/lib/module/index.js +4 -0
- package/lib/module/index.js.map +1 -0
- package/lib/typescript/commonjs/package.json +1 -0
- package/lib/{src → typescript/commonjs/src}/db/OPSQLiteConnection.d.ts +1 -0
- package/lib/typescript/commonjs/src/db/OPSQLiteConnection.d.ts.map +1 -0
- package/lib/{src → typescript/commonjs/src}/db/OPSqliteAdapter.d.ts +1 -0
- package/lib/typescript/commonjs/src/db/OPSqliteAdapter.d.ts.map +1 -0
- package/lib/{src → typescript/commonjs/src}/db/OPSqliteDBOpenFactory.d.ts +1 -0
- package/lib/typescript/commonjs/src/db/OPSqliteDBOpenFactory.d.ts.map +1 -0
- package/lib/{src → typescript/commonjs/src}/db/SqliteOptions.d.ts +1 -0
- package/lib/typescript/commonjs/src/db/SqliteOptions.d.ts.map +1 -0
- package/lib/{src → typescript/commonjs/src}/index.d.ts +1 -0
- package/lib/typescript/commonjs/src/index.d.ts.map +1 -0
- package/lib/typescript/commonjs/tsconfig.build.tsbuildinfo +1 -0
- package/lib/typescript/module/package.json +1 -0
- package/lib/typescript/module/src/db/OPSQLiteConnection.d.ts +27 -0
- package/lib/typescript/module/src/db/OPSQLiteConnection.d.ts.map +1 -0
- package/lib/typescript/module/src/db/OPSqliteAdapter.d.ts +45 -0
- package/lib/typescript/module/src/db/OPSqliteAdapter.d.ts.map +1 -0
- package/lib/typescript/module/src/db/OPSqliteDBOpenFactory.d.ts +12 -0
- package/lib/typescript/module/src/db/OPSqliteDBOpenFactory.d.ts.map +1 -0
- package/lib/typescript/module/src/db/SqliteOptions.d.ts +52 -0
- package/lib/typescript/module/src/db/SqliteOptions.d.ts.map +1 -0
- package/lib/typescript/module/src/index.d.ts +2 -0
- package/lib/typescript/module/src/index.d.ts.map +1 -0
- package/lib/typescript/module/tsconfig.build.tsbuildinfo +1 -0
- package/package.json +75 -6
- package/powersync-op-sqlite.podspec +26 -0
- package/src/db/OPSQLiteConnection.ts +131 -0
- package/src/db/OPSqliteAdapter.ts +301 -0
- package/src/db/OPSqliteDBOpenFactory.ts +25 -0
- package/src/db/SqliteOptions.ts +71 -0
- package/src/index.ts +4 -0
- package/lib/src/db/OPSQLiteConnection.js +0 -118
- package/lib/src/db/OPSqliteAdapter.js +0 -267
- package/lib/src/db/OPSqliteDBOpenFactory.js +0 -15
- package/lib/src/db/SqliteOptions.js +0 -29
- package/lib/src/index.js +0 -1
- package/lib/tsconfig.tsbuildinfo +0 -1
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import { BaseObserver, RowUpdateType } from '@powersync/common';
|
|
4
|
+
export class OPSQLiteConnection extends BaseObserver {
|
|
5
|
+
constructor(options) {
|
|
6
|
+
super();
|
|
7
|
+
this.options = options;
|
|
8
|
+
this.DB = options.baseDB;
|
|
9
|
+
this.updateBuffer = [];
|
|
10
|
+
this.DB.rollbackHook(() => {
|
|
11
|
+
this.updateBuffer = [];
|
|
12
|
+
});
|
|
13
|
+
this.DB.updateHook(update => {
|
|
14
|
+
this.addTableUpdate(update);
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
addTableUpdate(update) {
|
|
18
|
+
let opType;
|
|
19
|
+
switch (update.operation) {
|
|
20
|
+
case 'INSERT':
|
|
21
|
+
opType = RowUpdateType.SQLITE_INSERT;
|
|
22
|
+
break;
|
|
23
|
+
case 'DELETE':
|
|
24
|
+
opType = RowUpdateType.SQLITE_DELETE;
|
|
25
|
+
break;
|
|
26
|
+
case 'UPDATE':
|
|
27
|
+
opType = RowUpdateType.SQLITE_UPDATE;
|
|
28
|
+
break;
|
|
29
|
+
}
|
|
30
|
+
this.updateBuffer.push({
|
|
31
|
+
table: update.table,
|
|
32
|
+
opType,
|
|
33
|
+
rowId: update.rowId
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
flushUpdates() {
|
|
37
|
+
if (!this.updateBuffer.length) {
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
const groupedUpdates = this.updateBuffer.reduce((grouping, update) => {
|
|
41
|
+
const {
|
|
42
|
+
table
|
|
43
|
+
} = update;
|
|
44
|
+
const updateGroup = grouping[table] || (grouping[table] = []);
|
|
45
|
+
updateGroup.push(update);
|
|
46
|
+
return grouping;
|
|
47
|
+
}, {});
|
|
48
|
+
const batchedUpdate = {
|
|
49
|
+
groupedUpdates,
|
|
50
|
+
rawUpdates: this.updateBuffer,
|
|
51
|
+
tables: Object.keys(groupedUpdates)
|
|
52
|
+
};
|
|
53
|
+
this.updateBuffer = [];
|
|
54
|
+
this.iterateListeners(l => l.tablesUpdated?.(batchedUpdate));
|
|
55
|
+
}
|
|
56
|
+
close() {
|
|
57
|
+
return this.DB.close();
|
|
58
|
+
}
|
|
59
|
+
async execute(query, params) {
|
|
60
|
+
const res = await this.DB.execute(query, params);
|
|
61
|
+
return {
|
|
62
|
+
insertId: res.insertId,
|
|
63
|
+
rowsAffected: res.rowsAffected,
|
|
64
|
+
rows: {
|
|
65
|
+
_array: res.rows ?? [],
|
|
66
|
+
length: res.rows?.length ?? 0,
|
|
67
|
+
item: index => res.rows?.[index]
|
|
68
|
+
}
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
async executeBatch(query, params = []) {
|
|
72
|
+
const tuple = [[query, params[0]]];
|
|
73
|
+
params.slice(1).forEach(p => tuple.push([query, p]));
|
|
74
|
+
const result = await this.DB.executeBatch(tuple);
|
|
75
|
+
return {
|
|
76
|
+
rowsAffected: result.rowsAffected ?? 0
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
async getAll(sql, parameters) {
|
|
80
|
+
const result = await this.DB.execute(sql, parameters);
|
|
81
|
+
return result.rows ?? [];
|
|
82
|
+
}
|
|
83
|
+
async getOptional(sql, parameters) {
|
|
84
|
+
const result = await this.DB.execute(sql, parameters);
|
|
85
|
+
return result.rows?.[0] ?? null;
|
|
86
|
+
}
|
|
87
|
+
async get(sql, parameters) {
|
|
88
|
+
const result = await this.getOptional(sql, parameters);
|
|
89
|
+
if (!result) {
|
|
90
|
+
throw new Error('Result set is empty');
|
|
91
|
+
}
|
|
92
|
+
return result;
|
|
93
|
+
}
|
|
94
|
+
async refreshSchema() {
|
|
95
|
+
await this.get("PRAGMA table_info('sqlite_master')");
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
//# sourceMappingURL=OPSQLiteConnection.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["BaseObserver","RowUpdateType","OPSQLiteConnection","constructor","options","DB","baseDB","updateBuffer","rollbackHook","updateHook","update","addTableUpdate","opType","operation","SQLITE_INSERT","SQLITE_DELETE","SQLITE_UPDATE","push","table","rowId","flushUpdates","length","groupedUpdates","reduce","grouping","updateGroup","batchedUpdate","rawUpdates","tables","Object","keys","iterateListeners","l","tablesUpdated","close","execute","query","params","res","insertId","rowsAffected","rows","_array","item","index","executeBatch","tuple","slice","forEach","p","result","getAll","sql","parameters","getOptional","get","Error","refreshSchema"],"sourceRoot":"../../../src","sources":["db/OPSQLiteConnection.ts"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,245 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import { BaseObserver } from '@powersync/common';
|
|
4
|
+
import { ANDROID_DATABASE_PATH, getDylibPath, IOS_LIBRARY_PATH, open } from '@op-engineering/op-sqlite';
|
|
5
|
+
import Lock from 'async-lock';
|
|
6
|
+
import { OPSQLiteConnection } from "./OPSQLiteConnection.js";
|
|
7
|
+
import { Platform } from 'react-native';
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Adapter for React Native Quick SQLite
|
|
11
|
+
*/
|
|
12
|
+
var LockType = /*#__PURE__*/function (LockType) {
|
|
13
|
+
LockType["READ"] = "read";
|
|
14
|
+
LockType["WRITE"] = "write";
|
|
15
|
+
return LockType;
|
|
16
|
+
}(LockType || {});
|
|
17
|
+
const READ_CONNECTIONS = 5;
|
|
18
|
+
export class OPSQLiteDBAdapter extends BaseObserver {
|
|
19
|
+
readQueue = [];
|
|
20
|
+
constructor(options) {
|
|
21
|
+
super();
|
|
22
|
+
this.options = options;
|
|
23
|
+
this.name = this.options.name;
|
|
24
|
+
this.locks = new Lock();
|
|
25
|
+
this.readConnections = null;
|
|
26
|
+
this.writeConnection = null;
|
|
27
|
+
this.initialized = this.init();
|
|
28
|
+
}
|
|
29
|
+
async init() {
|
|
30
|
+
const {
|
|
31
|
+
lockTimeoutMs,
|
|
32
|
+
journalMode,
|
|
33
|
+
journalSizeLimit,
|
|
34
|
+
synchronous
|
|
35
|
+
} = this.options.sqliteOptions;
|
|
36
|
+
const dbFilename = this.options.name;
|
|
37
|
+
this.writeConnection = await this.openConnection(dbFilename);
|
|
38
|
+
const statements = [`PRAGMA busy_timeout = ${lockTimeoutMs}`, `PRAGMA journal_mode = ${journalMode}`, `PRAGMA journal_size_limit = ${journalSizeLimit}`, `PRAGMA synchronous = ${synchronous}`];
|
|
39
|
+
for (const statement of statements) {
|
|
40
|
+
for (let tries = 0; tries < 30; tries++) {
|
|
41
|
+
try {
|
|
42
|
+
await this.writeConnection.execute(statement);
|
|
43
|
+
break;
|
|
44
|
+
} catch (e) {
|
|
45
|
+
if (e instanceof Error && e.message.includes('database is locked') && tries < 29) {
|
|
46
|
+
continue;
|
|
47
|
+
} else {
|
|
48
|
+
throw e;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
// Changes should only occur in the write connection
|
|
55
|
+
this.writeConnection.registerListener({
|
|
56
|
+
tablesUpdated: notification => this.iterateListeners(cb => cb.tablesUpdated?.(notification))
|
|
57
|
+
});
|
|
58
|
+
this.readConnections = [];
|
|
59
|
+
for (let i = 0; i < READ_CONNECTIONS; i++) {
|
|
60
|
+
const conn = await this.openConnection(dbFilename);
|
|
61
|
+
await conn.execute('PRAGMA query_only = true');
|
|
62
|
+
this.readConnections.push({
|
|
63
|
+
busy: false,
|
|
64
|
+
connection: conn
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
async openConnection(filenameOverride) {
|
|
69
|
+
const dbFilename = filenameOverride ?? this.options.name;
|
|
70
|
+
const DB = this.openDatabase(dbFilename, this.options.sqliteOptions?.encryptionKey ?? undefined);
|
|
71
|
+
|
|
72
|
+
//Load extensions for all connections
|
|
73
|
+
this.loadAdditionalExtensions(DB);
|
|
74
|
+
this.loadPowerSyncExtension(DB);
|
|
75
|
+
await DB.execute('SELECT powersync_init()');
|
|
76
|
+
return new OPSQLiteConnection({
|
|
77
|
+
baseDB: DB
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
getDbLocation(dbLocation) {
|
|
81
|
+
if (Platform.OS === 'ios') {
|
|
82
|
+
return dbLocation ?? IOS_LIBRARY_PATH;
|
|
83
|
+
} else {
|
|
84
|
+
return dbLocation ?? ANDROID_DATABASE_PATH;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
openDatabase(dbFilename, encryptionKey) {
|
|
88
|
+
//This is needed because an undefined/null dbLocation will cause the open function to fail
|
|
89
|
+
const location = this.getDbLocation(this.options.dbLocation);
|
|
90
|
+
//Simarlily if the encryption key is undefined/null when using SQLCipher it will cause the open function to fail
|
|
91
|
+
if (encryptionKey) {
|
|
92
|
+
return open({
|
|
93
|
+
name: dbFilename,
|
|
94
|
+
location: location,
|
|
95
|
+
encryptionKey: encryptionKey
|
|
96
|
+
});
|
|
97
|
+
} else {
|
|
98
|
+
return open({
|
|
99
|
+
name: dbFilename,
|
|
100
|
+
location: location
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
loadAdditionalExtensions(DB) {
|
|
105
|
+
if (this.options.sqliteOptions?.extensions && this.options.sqliteOptions.extensions.length > 0) {
|
|
106
|
+
for (const extension of this.options.sqliteOptions.extensions) {
|
|
107
|
+
DB.loadExtension(extension.path, extension.entryPoint);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
async loadPowerSyncExtension(DB) {
|
|
112
|
+
if (Platform.OS === 'ios') {
|
|
113
|
+
const libPath = getDylibPath('co.powersync.sqlitecore', 'powersync-sqlite-core');
|
|
114
|
+
DB.loadExtension(libPath, 'sqlite3_powersync_init');
|
|
115
|
+
} else {
|
|
116
|
+
DB.loadExtension('libpowersync', 'sqlite3_powersync_init');
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
close() {
|
|
120
|
+
this.initialized.then(() => {
|
|
121
|
+
this.writeConnection.close();
|
|
122
|
+
this.readConnections.forEach(c => c.connection.close());
|
|
123
|
+
});
|
|
124
|
+
}
|
|
125
|
+
async readLock(fn, options) {
|
|
126
|
+
await this.initialized;
|
|
127
|
+
return new Promise(async (resolve, reject) => {
|
|
128
|
+
const execute = async () => {
|
|
129
|
+
// Find an available connection that is not busy
|
|
130
|
+
const availableConnection = this.readConnections.find(conn => !conn.busy);
|
|
131
|
+
|
|
132
|
+
// If we have an available connection, use it
|
|
133
|
+
if (availableConnection) {
|
|
134
|
+
availableConnection.busy = true;
|
|
135
|
+
try {
|
|
136
|
+
resolve(await fn(availableConnection.connection));
|
|
137
|
+
} catch (error) {
|
|
138
|
+
reject(error);
|
|
139
|
+
} finally {
|
|
140
|
+
availableConnection.busy = false;
|
|
141
|
+
// After query execution, process any queued tasks
|
|
142
|
+
this.processQueue();
|
|
143
|
+
}
|
|
144
|
+
} else {
|
|
145
|
+
// If no available connections, add to the queue
|
|
146
|
+
this.readQueue.push(execute);
|
|
147
|
+
}
|
|
148
|
+
};
|
|
149
|
+
execute();
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
async processQueue() {
|
|
153
|
+
if (this.readQueue.length > 0) {
|
|
154
|
+
const next = this.readQueue.shift();
|
|
155
|
+
if (next) {
|
|
156
|
+
next();
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
async writeLock(fn, options) {
|
|
161
|
+
await this.initialized;
|
|
162
|
+
return new Promise(async (resolve, reject) => {
|
|
163
|
+
try {
|
|
164
|
+
await this.locks.acquire(LockType.WRITE, async () => {
|
|
165
|
+
resolve(await fn(this.writeConnection));
|
|
166
|
+
}, {
|
|
167
|
+
timeout: options?.timeoutMs
|
|
168
|
+
}).then(() => {
|
|
169
|
+
// flush updates once a write lock has been released
|
|
170
|
+
this.writeConnection.flushUpdates();
|
|
171
|
+
});
|
|
172
|
+
} catch (ex) {
|
|
173
|
+
reject(ex);
|
|
174
|
+
}
|
|
175
|
+
});
|
|
176
|
+
}
|
|
177
|
+
readTransaction(fn, options) {
|
|
178
|
+
return this.readLock(ctx => this.internalTransaction(ctx, fn));
|
|
179
|
+
}
|
|
180
|
+
writeTransaction(fn, options) {
|
|
181
|
+
return this.writeLock(ctx => this.internalTransaction(ctx, fn));
|
|
182
|
+
}
|
|
183
|
+
getAll(sql, parameters) {
|
|
184
|
+
return this.readLock(ctx => ctx.getAll(sql, parameters));
|
|
185
|
+
}
|
|
186
|
+
getOptional(sql, parameters) {
|
|
187
|
+
return this.readLock(ctx => ctx.getOptional(sql, parameters));
|
|
188
|
+
}
|
|
189
|
+
get(sql, parameters) {
|
|
190
|
+
return this.readLock(ctx => ctx.get(sql, parameters));
|
|
191
|
+
}
|
|
192
|
+
execute(query, params) {
|
|
193
|
+
return this.writeLock(ctx => ctx.execute(query, params));
|
|
194
|
+
}
|
|
195
|
+
async executeBatch(query, params = []) {
|
|
196
|
+
return this.writeLock(ctx => ctx.executeBatch(query, params));
|
|
197
|
+
}
|
|
198
|
+
async internalTransaction(connection, fn) {
|
|
199
|
+
let finalized = false;
|
|
200
|
+
const commit = async () => {
|
|
201
|
+
if (finalized) {
|
|
202
|
+
return {
|
|
203
|
+
rowsAffected: 0
|
|
204
|
+
};
|
|
205
|
+
}
|
|
206
|
+
finalized = true;
|
|
207
|
+
return connection.execute('COMMIT');
|
|
208
|
+
};
|
|
209
|
+
const rollback = async () => {
|
|
210
|
+
if (finalized) {
|
|
211
|
+
return {
|
|
212
|
+
rowsAffected: 0
|
|
213
|
+
};
|
|
214
|
+
}
|
|
215
|
+
finalized = true;
|
|
216
|
+
return connection.execute('ROLLBACK');
|
|
217
|
+
};
|
|
218
|
+
try {
|
|
219
|
+
await connection.execute('BEGIN');
|
|
220
|
+
const result = await fn({
|
|
221
|
+
execute: (query, params) => connection.execute(query, params),
|
|
222
|
+
get: (query, params) => connection.get(query, params),
|
|
223
|
+
getAll: (query, params) => connection.getAll(query, params),
|
|
224
|
+
getOptional: (query, params) => connection.getOptional(query, params),
|
|
225
|
+
commit,
|
|
226
|
+
rollback
|
|
227
|
+
});
|
|
228
|
+
await commit();
|
|
229
|
+
return result;
|
|
230
|
+
} catch (ex) {
|
|
231
|
+
await rollback();
|
|
232
|
+
throw ex;
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
async refreshSchema() {
|
|
236
|
+
await this.initialized;
|
|
237
|
+
await this.writeConnection.refreshSchema();
|
|
238
|
+
if (this.readConnections) {
|
|
239
|
+
for (let readConnection of this.readConnections) {
|
|
240
|
+
await readConnection.connection.refreshSchema();
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
//# sourceMappingURL=OPSqliteAdapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["BaseObserver","ANDROID_DATABASE_PATH","getDylibPath","IOS_LIBRARY_PATH","open","Lock","OPSQLiteConnection","Platform","LockType","READ_CONNECTIONS","OPSQLiteDBAdapter","readQueue","constructor","options","name","locks","readConnections","writeConnection","initialized","init","lockTimeoutMs","journalMode","journalSizeLimit","synchronous","sqliteOptions","dbFilename","openConnection","statements","statement","tries","execute","e","Error","message","includes","registerListener","tablesUpdated","notification","iterateListeners","cb","i","conn","push","busy","connection","filenameOverride","DB","openDatabase","encryptionKey","undefined","loadAdditionalExtensions","loadPowerSyncExtension","baseDB","getDbLocation","dbLocation","OS","location","extensions","length","extension","loadExtension","path","entryPoint","libPath","close","then","forEach","c","readLock","fn","Promise","resolve","reject","availableConnection","find","error","processQueue","next","shift","writeLock","acquire","WRITE","timeout","timeoutMs","flushUpdates","ex","readTransaction","ctx","internalTransaction","writeTransaction","getAll","sql","parameters","getOptional","get","query","params","executeBatch","finalized","commit","rowsAffected","rollback","result","refreshSchema","readConnection"],"sourceRoot":"../../../src","sources":["db/OPSqliteAdapter.ts"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import { OPSQLiteDBAdapter } from "./OPSqliteAdapter.js";
|
|
4
|
+
import { DEFAULT_SQLITE_OPTIONS } from "./SqliteOptions.js";
|
|
5
|
+
export class OPSqliteOpenFactory {
|
|
6
|
+
constructor(options) {
|
|
7
|
+
this.options = options;
|
|
8
|
+
this.sqliteOptions = {
|
|
9
|
+
...DEFAULT_SQLITE_OPTIONS,
|
|
10
|
+
...this.options.sqliteOptions
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
openDB() {
|
|
14
|
+
return new OPSQLiteDBAdapter({
|
|
15
|
+
name: this.options.dbFilename,
|
|
16
|
+
dbLocation: this.options.dbLocation,
|
|
17
|
+
sqliteOptions: this.sqliteOptions
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=OPSqliteDBOpenFactory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["OPSQLiteDBAdapter","DEFAULT_SQLITE_OPTIONS","OPSqliteOpenFactory","constructor","options","sqliteOptions","openDB","name","dbFilename","dbLocation"],"sourceRoot":"../../../src","sources":["db/OPSqliteDBOpenFactory.ts"],"mappings":";;AACA,SAASA,iBAAiB,QAAQ,sBAAmB;AACrD,SAASC,sBAAsB,QAAuB,oBAAiB;AAKvE,OAAO,MAAMC,mBAAmB,CAA2B;EAGzDC,WAAWA,CAAWC,OAAmC,EAAE;IAAA,KAArCA,OAAmC,GAAnCA,OAAmC;IACvD,IAAI,CAACC,aAAa,GAAG;MACnB,GAAGJ,sBAAsB;MACzB,GAAG,IAAI,CAACG,OAAO,CAACC;IAClB,CAAC;EACH;EAEAC,MAAMA,CAAA,EAAc;IAClB,OAAO,IAAIN,iBAAiB,CAAC;MAC3BO,IAAI,EAAE,IAAI,CAACH,OAAO,CAACI,UAAU;MAC7BC,UAAU,EAAE,IAAI,CAACL,OAAO,CAACK,UAAU;MACnCJ,aAAa,EAAE,IAAI,CAACA;IACtB,CAAC,CAAC;EACJ;AACF","ignoreList":[]}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
// SQLite journal mode. Set on the primary connection.
|
|
4
|
+
// This library is written with WAL mode in mind - other modes may cause
|
|
5
|
+
// unexpected locking behavior.
|
|
6
|
+
var SqliteJournalMode = /*#__PURE__*/function (SqliteJournalMode) {
|
|
7
|
+
SqliteJournalMode["wal"] = "WAL";
|
|
8
|
+
SqliteJournalMode["delete"] = "DELETE";
|
|
9
|
+
SqliteJournalMode["truncate"] = "TRUNCATE";
|
|
10
|
+
SqliteJournalMode["persist"] = "PERSIST";
|
|
11
|
+
SqliteJournalMode["memory"] = "MEMORY";
|
|
12
|
+
SqliteJournalMode["off"] = "OFF";
|
|
13
|
+
return SqliteJournalMode;
|
|
14
|
+
}(SqliteJournalMode || {}); // SQLite file commit mode.
|
|
15
|
+
var SqliteSynchronous = /*#__PURE__*/function (SqliteSynchronous) {
|
|
16
|
+
SqliteSynchronous["normal"] = "NORMAL";
|
|
17
|
+
SqliteSynchronous["full"] = "FULL";
|
|
18
|
+
SqliteSynchronous["off"] = "OFF";
|
|
19
|
+
return SqliteSynchronous;
|
|
20
|
+
}(SqliteSynchronous || {});
|
|
21
|
+
export const DEFAULT_SQLITE_OPTIONS = {
|
|
22
|
+
journalMode: SqliteJournalMode.wal,
|
|
23
|
+
synchronous: SqliteSynchronous.normal,
|
|
24
|
+
journalSizeLimit: 6 * 1024 * 1024,
|
|
25
|
+
lockTimeoutMs: 30000,
|
|
26
|
+
encryptionKey: null,
|
|
27
|
+
extensions: []
|
|
28
|
+
};
|
|
29
|
+
//# sourceMappingURL=SqliteOptions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["SqliteJournalMode","SqliteSynchronous","DEFAULT_SQLITE_OPTIONS","journalMode","wal","synchronous","normal","journalSizeLimit","lockTimeoutMs","encryptionKey","extensions"],"sourceRoot":"../../../src","sources":["db/SqliteOptions.ts"],"mappings":";;AA0CA;AACA;AACA;AAAA,IACKA,iBAAiB,0BAAjBA,iBAAiB;EAAjBA,iBAAiB;EAAjBA,iBAAiB;EAAjBA,iBAAiB;EAAjBA,iBAAiB;EAAjBA,iBAAiB;EAAjBA,iBAAiB;EAAA,OAAjBA,iBAAiB;AAAA,EAAjBA,iBAAiB,SAWtB;AAAA,IACKC,iBAAiB,0BAAjBA,iBAAiB;EAAjBA,iBAAiB;EAAjBA,iBAAiB;EAAjBA,iBAAiB;EAAA,OAAjBA,iBAAiB;AAAA,EAAjBA,iBAAiB;AAMtB,OAAO,MAAMC,sBAA+C,GAAG;EAC7DC,WAAW,EAAEH,iBAAiB,CAACI,GAAG;EAClCC,WAAW,EAAEJ,iBAAiB,CAACK,MAAM;EACrCC,gBAAgB,EAAE,CAAC,GAAG,IAAI,GAAG,IAAI;EACjCC,aAAa,EAAE,KAAK;EACpBC,aAAa,EAAE,IAAI;EACnBC,UAAU,EAAE;AACd,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["OPSqliteOpenFactory","OPSQLiteOpenFactoryOptions"],"sourceRoot":"../../src","sources":["index.ts"],"mappings":";;AAAA,SACEA,mBAAmB,EACnBC,0BAA0B,QACrB,+BAA4B","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"type":"commonjs"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"OPSQLiteConnection.d.ts","sourceRoot":"","sources":["../../../../../src/db/OPSQLiteConnection.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAiB,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AACnF,OAAO,EACL,YAAY,EAEZ,iBAAiB,EACjB,WAAW,EAGZ,MAAM,mBAAmB,CAAC;AAE3B,MAAM,MAAM,yBAAyB,GAAG;IACtC,MAAM,EAAE,EAAE,CAAC;CACZ,CAAC;AAEF,MAAM,MAAM,0BAA0B,GAAG;IACvC,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,mBAAmB,CAAC;IAC/B,GAAG,CAAC,EAAE,GAAG,CAAC;IACV,KAAK,EAAE,MAAM,CAAC;CACf,CAAC;AAEF,qBAAa,kBAAmB,SAAQ,YAAY,CAAC,iBAAiB,CAAC;IAIzD,SAAS,CAAC,OAAO,EAAE,yBAAyB;IAHxD,SAAS,CAAC,EAAE,EAAE,EAAE,CAAC;IACjB,OAAO,CAAC,YAAY,CAAuB;gBAErB,OAAO,EAAE,yBAAyB;IAcxD,cAAc,CAAC,MAAM,EAAE,0BAA0B;IAqBjD,YAAY;IAsBZ,KAAK;IAIC,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC;IAa5D,YAAY,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,GAAE,GAAG,EAAE,EAAO,GAAG,OAAO,CAAC,WAAW,CAAC;IAUvE,MAAM,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;IAKxD,WAAW,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC;IAKlE,GAAG,CAAC,CAAC,EAAE,GAAG,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,CAAC,CAAC;IAQnD,aAAa;CAGpB"}
|
|
@@ -42,3 +42,4 @@ export declare class OPSQLiteDBAdapter extends BaseObserver<DBAdapterListener> i
|
|
|
42
42
|
protected internalTransaction<T>(connection: OPSQLiteConnection, fn: (tx: Transaction) => Promise<T>): Promise<T>;
|
|
43
43
|
refreshSchema(): Promise<void>;
|
|
44
44
|
}
|
|
45
|
+
//# sourceMappingURL=OPSqliteAdapter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"OPSqliteAdapter.d.ts","sourceRoot":"","sources":["../../../../../src/db/OPSqliteAdapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"OPSqliteDBOpenFactory.d.ts","sourceRoot":"","sources":["../../../../../src/db/OPSqliteDBOpenFactory.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAE9E,OAAO,EAA0B,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAExE,MAAM,WAAW,0BAA2B,SAAQ,cAAc;IAChE,aAAa,CAAC,EAAE,aAAa,CAAC;CAC/B;AACD,qBAAa,mBAAoB,YAAW,cAAc;IAG5C,SAAS,CAAC,OAAO,EAAE,0BAA0B;IAFzD,OAAO,CAAC,aAAa,CAA0B;gBAEzB,OAAO,EAAE,0BAA0B;IAOzD,MAAM,IAAI,SAAS;CAOpB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SqliteOptions.d.ts","sourceRoot":"","sources":["../../../../../src/db/SqliteOptions.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,aAAa;IAC5B;;OAEG;IACH,WAAW,CAAC,EAAE,iBAAiB,CAAC;IAEhC;;;OAGG;IACH,WAAW,CAAC,EAAE,iBAAiB,CAAC;IAEhC;;;;OAIG;IACH,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAE1B;;;;OAIG;IACH,aAAa,CAAC,EAAE,MAAM,CAAC;IAEvB;;;OAGG;IACH,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAE9B;;;OAGG;IACH,UAAU,CAAC,EAAE,KAAK,CAAC;QACjB,IAAI,EAAE,MAAM,CAAC;QACb,UAAU,CAAC,EAAE,MAAM,CAAC;KACrB,CAAC,CAAC;CACJ;AAKD,aAAK,iBAAiB;IAGpB,GAAG,QAAQ;IACX,MAAM,WAAW;IACjB,QAAQ,aAAa;IACrB,OAAO,YAAY;IACnB,MAAM,WAAW;IACjB,GAAG,QAAQ;CACZ;AAGD,aAAK,iBAAiB;IACpB,MAAM,WAAW;IACjB,IAAI,SAAS;IACb,GAAG,QAAQ;CACZ;AAED,eAAO,MAAM,sBAAsB,EAAE,QAAQ,CAAC,aAAa,CAO1D,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,mBAAmB,EACnB,0BAA0B,EAC3B,MAAM,4BAA4B,CAAC"}
|