@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.
Files changed (2) hide show
  1. package/lib/dbDao.js +84 -0
  2. 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.136",
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.136",
33
- "@live-change/db": "^0.9.136",
34
- "@live-change/db-store-indexeddb": "^0.9.136",
35
- "@live-change/db-store-localstorage": "^0.9.136",
36
- "@live-change/db-store-rbtree": "^0.9.136",
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": "3c5a53a4aae1125cde51d4d262a6e7b041a05f25"
39
+ "gitHead": "af56bfe0ca7899934a4c563ead788318832336de"
40
40
  }