@live-change/db-web 0.9.136 → 0.9.138
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/lib/dbDao.js +84 -0
- package/package.json +7 -7
package/lib/dbDao.js
CHANGED
|
@@ -241,6 +241,22 @@ function localRequests(server, scriptContext) {
|
|
|
241
241
|
if(!db) throw new Error('databaseNotFound')
|
|
242
242
|
const queryFunction = scriptContext.getOrCreateFunction(code, `query`)
|
|
243
243
|
return db.queryUpdate((input, output) => queryFunction(input, output, params))
|
|
244
|
+
},
|
|
245
|
+
runQuery: async (dbName, queryCodeTable, queryCodeId, params) => {
|
|
246
|
+
if(!dbName) throw new Error("databaseNameRequired")
|
|
247
|
+
const db = server.databases.get(dbName)
|
|
248
|
+
if(!db) throw new Error('databaseNotFound')
|
|
249
|
+
const table = db.table(queryCodeTable)
|
|
250
|
+
if(!table) throw new Error("tableNotFound")
|
|
251
|
+
const queryData = await table.objectGet(queryCodeId)
|
|
252
|
+
if(!queryData) throw new Error("queryCodeNotFound")
|
|
253
|
+
const queryCode = queryData.code
|
|
254
|
+
const querySourceName = queryData.sourceName
|
|
255
|
+
const queryFunction = scriptContext.getOrCreateFunction(
|
|
256
|
+
queryCode,
|
|
257
|
+
querySourceName ? querySourceName : 'queryCode:' + queryCodeId
|
|
258
|
+
)
|
|
259
|
+
return db.queryUpdate((input, output) => queryFunction(input, output, params))
|
|
244
260
|
}
|
|
245
261
|
}
|
|
246
262
|
}
|
|
@@ -723,6 +739,74 @@ function localReads(server, scriptContext) {
|
|
|
723
739
|
const queryFunction = scriptContext.getOrCreateFunction(code, 'queryCode:' + sourceName)
|
|
724
740
|
return db.queryObjectGet((input, output) => queryFunction(input, output, params))
|
|
725
741
|
}
|
|
742
|
+
},
|
|
743
|
+
runQuery: {
|
|
744
|
+
get: async (dbName, queryCodeTable, queryCodeId, params) => {
|
|
745
|
+
if(!dbName) throw new Error("databaseNameRequired")
|
|
746
|
+
const db = server.databases.get(dbName)
|
|
747
|
+
if(!db) throw new Error('databaseNotFound')
|
|
748
|
+
const table = db.table(queryCodeTable)
|
|
749
|
+
if(!table) throw new Error("tableNotFound")
|
|
750
|
+
const queryData = await table.objectGet(queryCodeId)
|
|
751
|
+
if(!queryData) throw new Error("queryCodeNotFound")
|
|
752
|
+
const queryCode = queryData.code
|
|
753
|
+
const querySourceName = queryData.sourceName
|
|
754
|
+
const queryFunction = scriptContext.getOrCreateFunction(
|
|
755
|
+
queryCode,
|
|
756
|
+
querySourceName ? querySourceName : 'queryCode:' + queryCodeId
|
|
757
|
+
)
|
|
758
|
+
return table.queryGet((input, output) => queryFunction(input, output, params))
|
|
759
|
+
},
|
|
760
|
+
observable: async (dbName, queryCodeTable, queryCodeId, params) => {
|
|
761
|
+
if(!dbName) return new ReactiveDao.ObservableError("databaseNameRequired")
|
|
762
|
+
const db = server.databases.get(dbName)
|
|
763
|
+
if(!db) return new ReactiveDao.ObservableError('databaseNotFound')
|
|
764
|
+
const table = db.table(queryCodeTable)
|
|
765
|
+
if(!table) return new ReactiveDao.ObservableError('tableNotFound')
|
|
766
|
+
const queryData = await table.objectGet(queryCodeId)
|
|
767
|
+
if(!queryData) throw new Error("queryCodeNotFound")
|
|
768
|
+
const queryCode = queryData.code
|
|
769
|
+
const querySourceName = queryData.sourceName
|
|
770
|
+
const queryFunction = scriptContext.getOrCreateFunction(
|
|
771
|
+
queryCode,
|
|
772
|
+
querySourceName ? querySourceName : 'queryCode:' + queryCodeId
|
|
773
|
+
)
|
|
774
|
+
return table.queryObservable((input, output) => queryFunction(input, output, params))
|
|
775
|
+
}
|
|
776
|
+
},
|
|
777
|
+
runQueryObject: {
|
|
778
|
+
get: async (dbName, queryCodeTable, queryCodeId, params) => {
|
|
779
|
+
if(!dbName) throw new Error("databaseNameRequired")
|
|
780
|
+
const db = server.databases.get(dbName)
|
|
781
|
+
if(!db) throw new Error('databaseNotFound')
|
|
782
|
+
const table = db.table(queryCodeTable)
|
|
783
|
+
if(!table) throw new Error("tableNotFound")
|
|
784
|
+
const queryData = await table.objectGet(queryCodeId)
|
|
785
|
+
if(!queryData) throw new Error("queryCodeNotFound")
|
|
786
|
+
const queryCode = queryData.code
|
|
787
|
+
const querySourceName = queryData.sourceName
|
|
788
|
+
const queryFunction = scriptContext.getOrCreateFunction(
|
|
789
|
+
queryCode,
|
|
790
|
+
querySourceName ? querySourceName : 'queryCode:' + queryCodeId
|
|
791
|
+
)
|
|
792
|
+
return table.queryObjectGet((input, output) => queryFunction(input, output, params))
|
|
793
|
+
},
|
|
794
|
+
observable: async (dbName, queryCodeTable, queryCodeId, params) => {
|
|
795
|
+
if(!dbName) return new ReactiveDao.ObservableError("databaseNameRequired")
|
|
796
|
+
const db = server.databases.get(dbName)
|
|
797
|
+
if(!db) return new ReactiveDao.ObservableError('databaseNotFound')
|
|
798
|
+
const table = db.table(queryCodeTable)
|
|
799
|
+
if(!table) return new ReactiveDao.ObservableError('tableNotFound')
|
|
800
|
+
const queryData = await table.objectGet(queryCodeId)
|
|
801
|
+
if(!queryData) throw new Error("queryCodeNotFound")
|
|
802
|
+
const queryCode = queryData.code
|
|
803
|
+
const querySourceName = queryData.sourceName
|
|
804
|
+
const queryFunction = scriptContext.getOrCreateFunction(
|
|
805
|
+
queryCode,
|
|
806
|
+
querySourceName ? querySourceName : 'queryCode:' + queryCodeId
|
|
807
|
+
)
|
|
808
|
+
return table.queryObjectObservable((input, output) => queryFunction(input, output, params))
|
|
809
|
+
}
|
|
726
810
|
}
|
|
727
811
|
}
|
|
728
812
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@live-change/db-web",
|
|
3
|
-
"version": "0.9.
|
|
3
|
+
"version": "0.9.138",
|
|
4
4
|
"author": {
|
|
5
5
|
"email": "michal@laszczewski.com",
|
|
6
6
|
"name": "Michał Łaszczewski",
|
|
@@ -29,12 +29,12 @@
|
|
|
29
29
|
},
|
|
30
30
|
"type": "module",
|
|
31
31
|
"dependencies": {
|
|
32
|
-
"@live-change/dao": "^0.9.
|
|
33
|
-
"@live-change/db": "^0.9.
|
|
34
|
-
"@live-change/db-store-indexeddb": "^0.9.
|
|
35
|
-
"@live-change/db-store-localstorage": "^0.9.
|
|
36
|
-
"@live-change/db-store-rbtree": "^0.9.
|
|
32
|
+
"@live-change/dao": "^0.9.138",
|
|
33
|
+
"@live-change/db": "^0.9.138",
|
|
34
|
+
"@live-change/db-store-indexeddb": "^0.9.138",
|
|
35
|
+
"@live-change/db-store-localstorage": "^0.9.138",
|
|
36
|
+
"@live-change/db-store-rbtree": "^0.9.138",
|
|
37
37
|
"debug": "^4.3.4"
|
|
38
38
|
},
|
|
39
|
-
"gitHead": "
|
|
39
|
+
"gitHead": "af56bfe0ca7899934a4c563ead788318832336de"
|
|
40
40
|
}
|