@fireproof/core 0.19.121-dev → 0.19.122

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 (70) hide show
  1. package/deno.json +3 -3
  2. package/index.cjs +600 -1004
  3. package/index.cjs.map +1 -1
  4. package/index.d.cts +26 -60
  5. package/index.d.ts +26 -60
  6. package/index.js +392 -97
  7. package/index.js.map +1 -1
  8. package/metafile-cjs.json +1 -1
  9. package/metafile-esm.json +1 -1
  10. package/node/index.cjs +374 -0
  11. package/node/index.cjs.map +1 -0
  12. package/node/index.d.cts +43 -0
  13. package/node/index.d.ts +43 -0
  14. package/node/index.js +279 -0
  15. package/node/index.js.map +1 -0
  16. package/node/{mem-filesystem.js → mem-filesystem-LPPT7QV5.js} +1 -1
  17. package/node/metafile-cjs.json +1 -1
  18. package/node/metafile-esm.json +1 -1
  19. package/package.json +17 -15
  20. package/react/index.cjs +91 -26
  21. package/react/index.cjs.map +1 -1
  22. package/react/index.d.cts +16 -1
  23. package/react/index.d.ts +16 -1
  24. package/react/index.js +92 -27
  25. package/react/index.js.map +1 -1
  26. package/react/metafile-cjs.json +1 -1
  27. package/react/metafile-esm.json +1 -1
  28. package/tests/blockstore/keyed-crypto.test.ts +4 -2
  29. package/tests/fireproof/config.test.ts +133 -142
  30. package/web/{gateway-impl.cjs → index.cjs} +58 -9
  31. package/web/index.cjs.map +1 -0
  32. package/web/index.d.cts +44 -0
  33. package/web/index.d.ts +44 -0
  34. package/web/{gateway-impl.js → index.js} +52 -5
  35. package/web/index.js.map +1 -0
  36. package/web/metafile-cjs.json +1 -1
  37. package/web/metafile-esm.json +1 -1
  38. package/chunk-7EWIAXTM.js +0 -7
  39. package/chunk-7EWIAXTM.js.map +0 -1
  40. package/chunk-F4FC6B2T.js +0 -63
  41. package/chunk-F4FC6B2T.js.map +0 -1
  42. package/chunk-PZ5AY32C.js +0 -10
  43. package/chunk-PZ5AY32C.js.map +0 -1
  44. package/chunk-RXC4JGJT.js +0 -301
  45. package/chunk-RXC4JGJT.js.map +0 -1
  46. package/gateway-C62S56GY.js +0 -66
  47. package/gateway-C62S56GY.js.map +0 -1
  48. package/gateway-VVS4QWDA.js +0 -145
  49. package/gateway-VVS4QWDA.js.map +0 -1
  50. package/key-bag-file-PWZ3QE7B.js +0 -55
  51. package/key-bag-file-PWZ3QE7B.js.map +0 -1
  52. package/key-bag-indexdb-SYG3YD4D.js +0 -51
  53. package/key-bag-indexdb-SYG3YD4D.js.map +0 -1
  54. package/node/mem-filesystem.cjs +0 -72
  55. package/node/mem-filesystem.cjs.map +0 -1
  56. package/node/mem-filesystem.d.cts +0 -25
  57. package/node/mem-filesystem.d.ts +0 -25
  58. package/node/node-filesystem.cjs +0 -86
  59. package/node/node-filesystem.cjs.map +0 -1
  60. package/node/node-filesystem.d.cts +0 -35
  61. package/node/node-filesystem.d.ts +0 -35
  62. package/node/node-filesystem.js +0 -44
  63. package/node/node-filesystem.js.map +0 -1
  64. package/utils-ZVVGAXFE.js +0 -13
  65. package/utils-ZVVGAXFE.js.map +0 -1
  66. package/web/gateway-impl.cjs.map +0 -1
  67. package/web/gateway-impl.d.cts +0 -31
  68. package/web/gateway-impl.d.ts +0 -31
  69. package/web/gateway-impl.js.map +0 -1
  70. /package/node/{mem-filesystem.js.map → mem-filesystem-LPPT7QV5.js.map} +0 -0
@@ -1,172 +1,163 @@
1
1
  import { describe, it, expect, beforeAll } from "vitest";
2
- import { dataDir, ensureSuperThis, fireproof, rt } from "@fireproof/core";
2
+ import { dataDir, ensureSuperThis, fireproof, rt, SysFileSystem } from "@fireproof/core";
3
3
  import { runtimeFn, URI } from "@adviser/cement";
4
4
 
5
- describe("runtime", () => {
6
- it("runtime", () => {
7
- const isNode = !!(typeof process === "object" && process.versions?.node);
8
- expect(runtimeFn()).toEqual({
9
- isBrowser: !isNode,
10
- isCFWorker: false,
11
- isDeno: false,
12
- isNodeIsh: isNode,
13
- isReactNative: false,
14
- });
15
- });
16
- });
17
-
18
- describe("fireproof/config", () => {
19
- let _my_app = "my-app";
20
- function my_app() {
21
- return _my_app;
22
- }
23
- function params(store: string) {
24
- return Object.entries({
25
- store,
26
- name: my_app(),
27
- storekey: `@${my_app()}:${store}@`,
28
- version: rt.FILESTORE_VERSION,
29
- });
30
- }
31
- const sthis = ensureSuperThis();
32
- beforeAll(async () => {
33
- await sthis.start();
34
- if (runtimeFn().isNodeIsh) {
35
- const fpStorageUrl = sthis.env.get("FP_STORAGE_URL");
36
- if (fpStorageUrl) {
37
- const url = URI.from(fpStorageUrl);
38
- _my_app = `my-app-${url.protocol.replace(/:$/, "")}:${url.getParam("fs") || "fs"}`;
39
- }
5
+ let _my_app = "my-app";
6
+ function my_app() {
7
+ return _my_app;
8
+ }
9
+
10
+ if (runtimeFn().isNodeIsh) {
11
+ describe("fireproof/config", () => {
12
+ function params(store: string) {
13
+ return Object.entries({
14
+ store,
15
+ name: my_app(),
16
+ storekey: `@${my_app()}:${store}@`,
17
+ version: rt.FILESTORE_VERSION,
18
+ });
40
19
  }
41
- });
20
+ const sthis = ensureSuperThis();
21
+ let getFileSystem: (url: URI) => Promise<SysFileSystem>;
22
+ beforeAll(async () => {
23
+ await sthis.start();
24
+ if (runtimeFn().isNodeIsh) {
25
+ const fpStorageUrl = sthis.env.get("FP_STORAGE_URL");
26
+ if (fpStorageUrl) {
27
+ const url = URI.from(fpStorageUrl);
28
+ _my_app = `my-app-${url.protocol.replace(/:$/, "")}:${url.getParam("fs") || "fs"}`;
29
+ }
30
+ }
31
+ const node = await import("@fireproof/core/node");
32
+ getFileSystem = node.getFileSystem;
33
+ });
34
+
35
+ it("node default", async () => {
36
+ const old = sthis.env.get("FP_STORAGE_URL");
37
+ sthis.env.delete("FP_STORAGE_URL");
38
+ let baseDir = dataDir(sthis, my_app()).pathname;
39
+ baseDir = sthis.pathOps.join(baseDir, rt.FILESTORE_VERSION, my_app());
40
+
41
+ const sysfs = await getFileSystem(URI.from(baseDir));
42
+ await sysfs.rm(baseDir, { recursive: true }).catch(() => {
43
+ /* */
44
+ });
45
+
46
+ expect(baseDir).toMatch(new RegExp(`/\\.fireproof/${rt.FILESTORE_VERSION}/${my_app()}`));
42
47
 
43
- if (!runtimeFn().isNodeIsh) {
44
- it("default", async () => {
45
48
  const db = fireproof(my_app());
46
49
  await db.put({ name: "my-app" });
47
50
  expect(db.name).toBe(my_app());
51
+ const carStore = await db.blockstore.loader?.carStore();
52
+
53
+ for (const [param, value] of Object.entries({
54
+ store: "data",
55
+ name: my_app(),
56
+ storekey: `@${my_app()}:data@`,
57
+ version: rt.FILESTORE_VERSION,
58
+ })) {
59
+ expect(carStore?.url().getParam(param)).toBe(value);
60
+ }
61
+ expect((await sysfs.stat(sthis.pathOps.join(baseDir, "data"))).isDirectory()).toBeTruthy();
48
62
 
49
63
  const fileStore = await db.blockstore.loader?.fileStore();
50
- expect(fileStore?.url().toString()).toMatch(
51
- new RegExp(`indexdb://fp\\?name=my-app&store=data&storekey=%40my-app%3Adata%40&version=${rt.INDEXDB_VERSION}`),
52
- );
64
+ for (const [param, value] of params("data")) {
65
+ expect(fileStore?.url().getParam(param)).toBe(value);
66
+ }
53
67
  const metaStore = await db.blockstore.loader?.metaStore();
54
- expect(metaStore?.url().toString()).toMatch(
55
- new RegExp(`indexdb://fp\\?name=my-app&store=meta&storekey=%40my-app%3Ameta%40&version=${rt.INDEXDB_VERSION}`),
56
- );
57
-
58
- const carStore = await db.blockstore.loader?.carStore();
59
- expect(carStore?.url().toString()).toMatch(
60
- new RegExp(`indexdb://fp\\?name=my-app&store=data&storekey=%40my-app%3Adata%40&version=${rt.INDEXDB_VERSION}`),
61
- );
62
-
68
+ for (const [param, value] of params("meta")) {
69
+ expect(metaStore?.url().getParam(param)).toBe(value);
70
+ }
71
+ expect((await sysfs.stat(sthis.pathOps.join(baseDir, "meta"))).isDirectory()).toBeTruthy();
72
+ sthis.env.set("FP_STORAGE_URL", old);
63
73
  await db.close();
64
74
  });
65
- return;
66
- }
67
- it("node default", async () => {
68
- const old = sthis.env.get("FP_STORAGE_URL");
69
- sthis.env.delete("FP_STORAGE_URL");
70
- let baseDir = dataDir(sthis, my_app()).pathname;
71
- baseDir = sthis.pathOps.join(baseDir, rt.FILESTORE_VERSION, my_app());
72
-
73
- const sysfs = await rt.getFileSystem(URI.from(baseDir));
74
- await sysfs.rm(baseDir, { recursive: true }).catch(() => {
75
- /* */
76
- });
77
75
 
78
- expect(baseDir).toMatch(new RegExp(`/\\.fireproof/${rt.FILESTORE_VERSION}/${my_app()}`));
76
+ it("set by env", async () => {
77
+ const old = sthis.env.get("FP_STORAGE_URL");
78
+ const testUrl = URI.merge(`./dist/env`, old);
79
+ sthis.env.set("FP_STORAGE_URL", testUrl.toString());
79
80
 
80
- const db = fireproof(my_app());
81
- await db.put({ name: "my-app" });
82
- expect(db.name).toBe(my_app());
83
- const carStore = await db.blockstore.loader?.carStore();
81
+ let baseDir = dataDir(sthis, my_app()).pathname;
82
+ baseDir = sthis.pathOps.join(baseDir, rt.FILESTORE_VERSION, my_app());
84
83
 
85
- for (const [param, value] of Object.entries({
86
- store: "data",
87
- name: my_app(),
88
- storekey: `@${my_app()}:data@`,
89
- version: rt.FILESTORE_VERSION,
90
- })) {
91
- expect(carStore?.url().getParam(param)).toBe(value);
92
- }
93
- expect((await sysfs.stat(sthis.pathOps.join(baseDir, "data"))).isDirectory()).toBeTruthy();
84
+ const sysfs = await getFileSystem(testUrl);
85
+ await sysfs.rm(baseDir, { recursive: true }).catch(() => {
86
+ /* */
87
+ });
94
88
 
95
- const fileStore = await db.blockstore.loader?.fileStore();
96
- for (const [param, value] of params("data")) {
97
- expect(fileStore?.url().getParam(param)).toBe(value);
98
- }
99
- const metaStore = await db.blockstore.loader?.metaStore();
100
- for (const [param, value] of params("meta")) {
101
- expect(metaStore?.url().getParam(param)).toBe(value);
102
- }
103
- expect((await sysfs.stat(sthis.pathOps.join(baseDir, "meta"))).isDirectory()).toBeTruthy();
104
- sthis.env.set("FP_STORAGE_URL", old);
105
- await db.close();
106
- });
89
+ const db = fireproof(my_app());
90
+ await db.put({ name: "my-app" });
91
+ expect(db.name).toBe(my_app());
92
+ const carStore = await db.blockstore.loader?.carStore();
93
+ for (const [param, value] of params("data")) {
94
+ expect(carStore?.url().getParam(param)).toBe(value);
95
+ }
96
+ expect((await sysfs.stat(sthis.pathOps.join(baseDir, "data"))).isDirectory()).toBeTruthy();
97
+ const fileStore = await db.blockstore.loader?.fileStore();
98
+ for (const [param, value] of params("data")) {
99
+ expect(fileStore?.url().getParam(param)).toBe(value);
100
+ }
101
+ const metaStore = await db.blockstore.loader?.metaStore();
102
+ for (const [param, value] of params("meta")) {
103
+ expect(metaStore?.url().getParam(param)).toBe(value);
104
+ }
105
+ expect((await sysfs.stat(sthis.pathOps.join(baseDir, "meta"))).isDirectory()).toBeTruthy();
106
+ await db.close();
107
+ sthis.env.set("FP_STORAGE_URL", old);
108
+ });
107
109
 
108
- it("set by env", async () => {
109
- const old = sthis.env.get("FP_STORAGE_URL");
110
- const testUrl = URI.merge(`./dist/env`, old);
111
- sthis.env.set("FP_STORAGE_URL", testUrl.toString());
110
+ it("file path", async () => {
111
+ let baseDir = "./dist/data".replace(/\?.*$/, "").replace(/^file:\/\//, "");
112
+ baseDir = sthis.pathOps.join(baseDir, rt.FILESTORE_VERSION, my_app());
112
113
 
113
- let baseDir = dataDir(sthis, my_app()).pathname;
114
- baseDir = sthis.pathOps.join(baseDir, rt.FILESTORE_VERSION, my_app());
114
+ const base = "./dist/data";
115
+ const sysfs = await getFileSystem(URI.from(base));
116
+ await sysfs.rm(baseDir, { recursive: true }).catch(() => {
117
+ /* */
118
+ });
115
119
 
116
- const sysfs = await rt.getFileSystem(testUrl);
117
- await sysfs.rm(baseDir, { recursive: true }).catch(() => {
118
- /* */
120
+ const db = fireproof(my_app(), { store: { stores: { base } } });
121
+ // console.log(`>>>>>>>>>>>>>>>file-path`)
122
+ await db.put({ name: "my-app" });
123
+ expect(db.name).toBe(my_app());
124
+ const carStore = await db.blockstore.loader?.carStore();
125
+ for (const [param, value] of params("data")) {
126
+ expect(carStore?.url().getParam(param)).toBe(value);
127
+ }
128
+ const fileStore = await db.blockstore.loader?.fileStore();
129
+ for (const [param, value] of params("data")) {
130
+ expect(fileStore?.url().getParam(param)).toBe(value);
131
+ }
132
+ expect((await sysfs.stat(sthis.pathOps.join(baseDir, "data"))).isDirectory()).toBeTruthy();
133
+ const metaStore = await db.blockstore.loader?.metaStore();
134
+ for (const [param, value] of params("meta")) {
135
+ expect(metaStore?.url().getParam(param)).toBe(value);
136
+ }
137
+ expect((await sysfs.stat(sthis.pathOps.join(baseDir, "meta"))).isDirectory()).toBeTruthy();
138
+ await db.close();
119
139
  });
120
-
140
+ });
141
+ } else {
142
+ it("default", async () => {
121
143
  const db = fireproof(my_app());
122
144
  await db.put({ name: "my-app" });
123
145
  expect(db.name).toBe(my_app());
124
- const carStore = await db.blockstore.loader?.carStore();
125
- for (const [param, value] of params("data")) {
126
- expect(carStore?.url().getParam(param)).toBe(value);
127
- }
128
- expect((await sysfs.stat(sthis.pathOps.join(baseDir, "data"))).isDirectory()).toBeTruthy();
146
+
129
147
  const fileStore = await db.blockstore.loader?.fileStore();
130
- for (const [param, value] of params("data")) {
131
- expect(fileStore?.url().getParam(param)).toBe(value);
132
- }
148
+ expect(fileStore?.url().toString()).toMatch(
149
+ new RegExp(`indexdb://fp\\?name=my-app&store=data&storekey=%40my-app%3Adata%40&version=${rt.INDEXDB_VERSION}`),
150
+ );
133
151
  const metaStore = await db.blockstore.loader?.metaStore();
134
- for (const [param, value] of params("meta")) {
135
- expect(metaStore?.url().getParam(param)).toBe(value);
136
- }
137
- expect((await sysfs.stat(sthis.pathOps.join(baseDir, "meta"))).isDirectory()).toBeTruthy();
138
- await db.close();
139
- sthis.env.set("FP_STORAGE_URL", old);
140
- });
141
-
142
- it("file path", async () => {
143
- let baseDir = "./dist/data".replace(/\?.*$/, "").replace(/^file:\/\//, "");
144
- baseDir = sthis.pathOps.join(baseDir, rt.FILESTORE_VERSION, my_app());
145
-
146
- const base = "./dist/data";
147
- const sysfs = await rt.getFileSystem(URI.from(base));
148
- await sysfs.rm(baseDir, { recursive: true }).catch(() => {
149
- /* */
150
- });
152
+ expect(metaStore?.url().toString()).toMatch(
153
+ new RegExp(`indexdb://fp\\?name=my-app&store=meta&storekey=%40my-app%3Ameta%40&version=${rt.INDEXDB_VERSION}`),
154
+ );
151
155
 
152
- const db = fireproof(my_app(), { store: { stores: { base } } });
153
- // console.log(`>>>>>>>>>>>>>>>file-path`)
154
- await db.put({ name: "my-app" });
155
- expect(db.name).toBe(my_app());
156
156
  const carStore = await db.blockstore.loader?.carStore();
157
- for (const [param, value] of params("data")) {
158
- expect(carStore?.url().getParam(param)).toBe(value);
159
- }
160
- const fileStore = await db.blockstore.loader?.fileStore();
161
- for (const [param, value] of params("data")) {
162
- expect(fileStore?.url().getParam(param)).toBe(value);
163
- }
164
- expect((await sysfs.stat(sthis.pathOps.join(baseDir, "data"))).isDirectory()).toBeTruthy();
165
- const metaStore = await db.blockstore.loader?.metaStore();
166
- for (const [param, value] of params("meta")) {
167
- expect(metaStore?.url().getParam(param)).toBe(value);
168
- }
169
- expect((await sysfs.stat(sthis.pathOps.join(baseDir, "meta"))).isDirectory()).toBeTruthy();
157
+ expect(carStore?.url().toString()).toMatch(
158
+ new RegExp(`indexdb://fp\\?name=my-app&store=data&storekey=%40my-app%3Adata%40&version=${rt.INDEXDB_VERSION}`),
159
+ );
160
+
170
161
  await db.close();
171
162
  });
172
- });
163
+ }
@@ -17,14 +17,20 @@ var __copyProps = (to, from, except, desc) => {
17
17
  };
18
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
19
 
20
- // src/runtime/gateways/indexdb/web/gateway-impl.ts
21
- var gateway_impl_exports = {};
22
- __export(gateway_impl_exports, {
23
- IndexDBGatewayImpl: () => IndexDBGatewayImpl,
24
- IndexDBTestStore: () => IndexDBTestStore,
20
+ // src/runtime/gateways/indexdb/web/index.ts
21
+ var index_exports = {};
22
+ __export(index_exports, {
23
+ GatewayImpl: () => IndexDBGateway,
24
+ GatewayTestImpl: () => IndexDBTestGateway,
25
+ IndexDBGateway: () => IndexDBGateway,
26
+ IndexDBTestGateway: () => IndexDBTestGateway,
27
+ KeyBagProviderImpl: () => KeyBagProviderIndexDB,
28
+ KeyBagProviderIndexDB: () => KeyBagProviderIndexDB,
25
29
  getIndexDBName: () => getIndexDBName
26
30
  });
27
- module.exports = __toCommonJS(gateway_impl_exports);
31
+ module.exports = __toCommonJS(index_exports);
32
+
33
+ // src/runtime/gateways/indexdb/web/gateway-impl.ts
28
34
  var import_idb = require("idb");
29
35
  var import_cement = require("@adviser/cement");
30
36
 
@@ -87,7 +93,7 @@ function getIndexDBName(iurl, sthis) {
87
93
  dbName
88
94
  };
89
95
  }
90
- var IndexDBGatewayImpl = class {
96
+ var IndexDBGateway = class {
91
97
  constructor(sthis) {
92
98
  this.logger = (0, import_core.ensureLogger)(sthis, "IndexDBGateway");
93
99
  this.sthis = sthis;
@@ -163,7 +169,7 @@ var IndexDBGatewayImpl = class {
163
169
  });
164
170
  }
165
171
  };
166
- var IndexDBTestStore = class {
172
+ var IndexDBTestGateway = class {
167
173
  constructor(sthis) {
168
174
  this.sthis = sthis;
169
175
  this.logger = (0, import_core.ensureLogger)(sthis, "IndexDBTestStore", {});
@@ -180,4 +186,47 @@ var IndexDBTestStore = class {
180
186
  return bytes;
181
187
  }
182
188
  };
183
- //# sourceMappingURL=gateway-impl.cjs.map
189
+
190
+ // src/runtime/gateways/indexdb/web/key-bag-indexdb.ts
191
+ var import_idb2 = require("idb");
192
+ var import_cement2 = require("@adviser/cement");
193
+ var import_core2 = require("@fireproof/core");
194
+ var KeyBagProviderIndexDB = class {
195
+ constructor(url, sthis) {
196
+ this._db = new import_cement2.ResolveOnce();
197
+ this.sthis = sthis;
198
+ this.logger = sthis.logger;
199
+ this.url = url;
200
+ this.dbName = import_core2.rt.getPath(this.url, this.sthis);
201
+ }
202
+ async _prepare() {
203
+ return this._db.once(async () => {
204
+ return await (0, import_idb2.openDB)(this.dbName, 1, {
205
+ upgrade(db) {
206
+ ["bag"].map((store) => {
207
+ db.createObjectStore(store, {
208
+ autoIncrement: false
209
+ });
210
+ });
211
+ }
212
+ });
213
+ });
214
+ }
215
+ async get(id) {
216
+ const db = await this._prepare();
217
+ const tx = db.transaction(["bag"], "readonly");
218
+ const keyItem = await tx.objectStore("bag").get(id);
219
+ await tx.done;
220
+ if (!keyItem) {
221
+ return void 0;
222
+ }
223
+ return keyItem;
224
+ }
225
+ async set(id, item) {
226
+ const db = await this._prepare();
227
+ const tx = db.transaction(["bag"], "readwrite");
228
+ await tx.objectStore("bag").put(item, id);
229
+ await tx.done;
230
+ }
231
+ };
232
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/runtime/gateways/indexdb/web/index.ts","../../../src/runtime/gateways/indexdb/web/gateway-impl.ts","../../../src/runtime/gateways/indexdb/version.ts","../../../src/runtime/gateways/indexdb/web/key-bag-indexdb.ts"],"sourcesContent":["export * from \"./gateway-impl.js\";\nexport * from \"./key-bag-indexdb.js\";\n\nimport { KeyBagProviderIndexDB as KeyBagProviderImpl } from \"./key-bag-indexdb.js\";\n\nexport { KeyBagProviderImpl };\n\nimport { IndexDBGateway as GatewayImpl, IndexDBTestGateway as GatewayTestImpl } from \"./gateway-impl.js\";\nexport { GatewayImpl, GatewayTestImpl };\n","import { openDB, IDBPDatabase } from \"idb\";\nimport { exception2Result, KeyedResolvOnce, Logger, Result, URI } from \"@adviser/cement\";\n\nimport { INDEXDB_VERSION } from \"../version.js\";\nimport { ensureLogger, exceptionWrapper, getKey, getStore, NotFoundError } from \"@fireproof/core\";\nimport type { bs } from \"@fireproof/core\";\nimport type { SuperThis } from \"@fireproof/core\";\n\nfunction ensureVersion(url: URI): URI {\n return url.build().defParam(\"version\", INDEXDB_VERSION).URI();\n}\n\ninterface IDBConn {\n readonly db: IDBPDatabase<unknown>;\n readonly dbName: DbName;\n readonly version: string;\n readonly url: URI;\n}\n\nfunction sanitzeKey(key: string | string[]): string | string[] {\n if (key.length === 1) {\n key = key[0];\n }\n return key;\n}\n\nconst onceConn = new KeyedResolvOnce<IDBConn>();\nasync function connectIdb(url: URI, sthis: SuperThis): Promise<IDBConn> {\n const dbName = getIndexDBName(url, sthis);\n const once = await onceConn.get(dbName.fullDb).once(async () => {\n const db = await openDB(dbName.fullDb, 1, {\n upgrade(db) {\n [\"version\", \"data\", \"wal\", \"meta\", \"idx.data\", \"idx.wal\", \"idx.meta\"].map((store) => {\n db.createObjectStore(store, {\n autoIncrement: false,\n });\n });\n },\n });\n const found = await db.get(\"version\", \"version\");\n const version = ensureVersion(url).getParam(\"version\") as string;\n if (!found) {\n await db.put(\"version\", { version }, \"version\");\n } else if (found.version !== version) {\n sthis.logger.Warn().Str(\"url\", url.toString()).Str(\"version\", version).Str(\"found\", found.version).Msg(\"version mismatch\");\n }\n return { db, dbName, version, url };\n });\n return {\n ...once,\n url: url.build().setParam(\"version\", once.version).URI(),\n };\n}\n\nexport interface DbName {\n readonly fullDb: string;\n readonly objStore: string;\n readonly connectionKey: string;\n readonly dbName: string;\n}\n\nfunction joinDBName(...names: string[]): string {\n return names\n .map((i) => i.replace(/^[^a-zA-Z0-9]+/g, \"\").replace(/[^a-zA-Z0-9-]+/g, \"_\"))\n .filter((i) => i.length)\n .join(\".\");\n}\n\n// const schemaVersion = new Map<string, number>();\nexport function getIndexDBName(iurl: URI, sthis: SuperThis): DbName {\n const url = ensureVersion(iurl);\n const fullDb = url.pathname.replace(/^\\/+/, \"\").replace(/\\?.*$/, \"\"); // cut leading slashes\n // const type = getStore(url);\n // const storageVersion = url.searchParams.get(\"version\");\n // not nice but we need to pass the version to the db name\n // url.searchParams.set(\"version\", storageVersion);\n // console.log(\"getIndexDBName:\", url.toString(), { fullDb, type, branch });\n // const dbName = fullDb.replace(new RegExp(`^fp.${storageVersion}.`), \"\"); // cut fp prefix\n const dbName = url.getParam(\"name\");\n if (!dbName) throw sthis.logger.Error().Str(\"url\", url.toString()).Msg(`name not found`).AsError();\n const result = joinDBName(fullDb, dbName);\n const objStore = getStore(url, sthis, joinDBName).name;\n const connectionKey = [result, objStore].join(\":\");\n return {\n fullDb: result,\n objStore,\n connectionKey,\n dbName,\n };\n}\n\nexport class IndexDBGateway implements bs.Gateway {\n readonly logger: Logger;\n readonly sthis: SuperThis;\n constructor(sthis: SuperThis) {\n this.logger = ensureLogger(sthis, \"IndexDBGateway\");\n this.sthis = sthis;\n }\n\n // _db: IDBPDatabase<unknown> = {} as IDBPDatabase<unknown>;\n\n async start(baseURL: URI): Promise<Result<URI>> {\n return exception2Result(async () => {\n this.logger.Debug().Url(baseURL).Msg(\"starting\");\n await this.sthis.start();\n const ic = await connectIdb(baseURL, this.sthis);\n this.logger.Debug().Url(ic.url).Msg(\"started\");\n return ic.url;\n });\n }\n async close(): Promise<Result<void>> {\n return Result.Ok(undefined);\n }\n async destroy(baseUrl: URI): Promise<Result<void>> {\n return exception2Result(async () => {\n // return deleteDB(getIndexDBName(this.url).fullDb);\n const type = getStore(baseUrl, this.sthis, joinDBName).name;\n // console.log(\"IndexDBDataStore:destroy\", type);\n const idb = await connectIdb(baseUrl, this.sthis);\n const trans = idb.db.transaction(type, \"readwrite\");\n const object_store = trans.objectStore(type);\n const toDelete = [];\n for (let cursor = await object_store.openCursor(); cursor; cursor = await cursor.continue()) {\n toDelete.push(cursor.primaryKey);\n }\n for (const key of toDelete) {\n await trans.db.delete(type, key);\n }\n await trans.done;\n });\n }\n\n buildUrl(baseUrl: URI, key: string): Promise<Result<URI>> {\n return Promise.resolve(Result.Ok(baseUrl.build().setParam(\"key\", key).URI()));\n }\n\n async get(url: URI): Promise<bs.GetResult> {\n return exceptionWrapper(async () => {\n const key = getKey(url, this.logger);\n const store = getStore(url, this.sthis, joinDBName).name;\n this.logger.Debug().Url(url).Str(\"key\", key).Str(\"store\", store).Msg(\"getting\");\n const { db } = await connectIdb(url, this.sthis);\n const tx = db.transaction([store], \"readonly\");\n const bytes = await tx.objectStore(store).get(sanitzeKey(key));\n await tx.done;\n if (!bytes) {\n return Result.Err(new NotFoundError(`missing ${key}`));\n }\n return Result.Ok(bytes as Uint8Array);\n });\n }\n async put(url: URI, value: Uint8Array) {\n return exception2Result(async () => {\n const key = getKey(url, this.logger);\n const store = getStore(url, this.sthis, joinDBName).name;\n this.logger.Debug().Url(url).Str(\"key\", key).Str(\"store\", store).Msg(\"putting\");\n const { db } = await connectIdb(url, this.sthis);\n const tx = db.transaction([store], \"readwrite\");\n await tx.objectStore(store).put(value, sanitzeKey(key));\n await tx.done;\n });\n }\n async delete(url: URI) {\n return exception2Result(async () => {\n const key = getKey(url, this.logger);\n const store = getStore(url, this.sthis, joinDBName).name;\n this.logger.Debug().Url(url).Str(\"key\", key).Str(\"store\", store).Msg(\"deleting\");\n const { db } = await connectIdb(url, this.sthis);\n const tx = db.transaction([store], \"readwrite\");\n await tx.objectStore(store).delete(sanitzeKey(key));\n await tx.done;\n return Result.Ok(undefined);\n });\n }\n}\n\n// export class IndexDBDataGateway extends IndexDBGateway {\n// readonly storeType = \"data\";\n// constructor(logger: Logger) {\n// super(ensureLogger(logger, \"IndexDBDataGateway\"));\n// }\n// }\n\n// export class IndexDBWalGateway extends IndexDBGateway {\n// readonly storeType = \"wal\";\n// constructor(logger: Logger) {\n// super(ensureLogger(logger, \"IndexDBWalGateway\"));\n// }\n// }\n// export class IndexDBMetaGateway extends IndexDBGateway {\n// readonly storeType = \"meta\";\n// constructor(logger: Logger) {\n// super(ensureLogger(logger, \"IndexDBMetaGateway\"));\n// }\n// }\n\nexport class IndexDBTestGateway implements bs.TestGateway {\n readonly logger: Logger;\n readonly sthis: SuperThis;\n constructor(sthis: SuperThis) {\n this.sthis = sthis;\n this.logger = ensureLogger(sthis, \"IndexDBTestStore\", {});\n }\n async get(url: URI, key: string) {\n const ic = await connectIdb(url, this.sthis);\n const store = getStore(ic.url, this.sthis, joinDBName).name;\n this.logger.Debug().Str(\"key\", key).Str(\"store\", store).Msg(\"getting\");\n let bytes = await ic.db.get(store, sanitzeKey(key));\n this.logger.Debug().Str(\"key\", key).Str(\"store\", store).Int(\"len\", bytes.length).Msg(\"got\");\n if (typeof bytes === \"string\") {\n bytes = this.sthis.txt.encode(bytes);\n }\n return bytes as Uint8Array;\n }\n}\n","export const INDEXDB_VERSION = \"v0.19-indexdb\";\n","import { IDBPDatabase, openDB } from \"idb\";\nimport { Logger, ResolveOnce, URI } from \"@adviser/cement\";\nimport { SuperThis, rt } from \"@fireproof/core\";\n\nexport class KeyBagProviderIndexDB implements rt.kb.KeyBagProvider {\n readonly _db: ResolveOnce<IDBPDatabase<unknown>> = new ResolveOnce<IDBPDatabase<unknown>>();\n\n readonly dbName: string;\n readonly url: URI;\n readonly logger: Logger;\n readonly sthis: SuperThis;\n constructor(url: URI, sthis: SuperThis) {\n this.sthis = sthis;\n this.logger = sthis.logger;\n this.url = url;\n this.dbName = rt.getPath(this.url, this.sthis);\n }\n\n async _prepare(): Promise<IDBPDatabase<unknown>> {\n return this._db.once(async () => {\n return await openDB(this.dbName, 1, {\n upgrade(db) {\n // console.log('upgrade:', dbName);\n [\"bag\"].map((store) => {\n db.createObjectStore(store, {\n autoIncrement: false,\n });\n });\n },\n });\n });\n }\n\n async get(id: string): Promise<rt.kb.KeyItem | undefined> {\n const db = await this._prepare();\n const tx = db.transaction([\"bag\"], \"readonly\");\n const keyItem = await tx.objectStore(\"bag\").get(id);\n await tx.done;\n if (!keyItem) {\n return undefined;\n }\n return keyItem;\n }\n\n async set(id: string, item: rt.kb.KeyItem): Promise<void> {\n const db = await this._prepare();\n const tx = db.transaction([\"bag\"], \"readwrite\");\n await tx.objectStore(\"bag\").put(item, id);\n await tx.done;\n }\n}\n"],"mappings":"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","names":["db","import_idb","import_cement","import_core"]}
@@ -0,0 +1,44 @@
1
+ import { URI, Logger, Result, ResolveOnce } from '@adviser/cement';
2
+ import { SuperThis, bs, rt } from '@fireproof/core';
3
+ import { IDBPDatabase } from 'idb';
4
+
5
+ interface DbName {
6
+ readonly fullDb: string;
7
+ readonly objStore: string;
8
+ readonly connectionKey: string;
9
+ readonly dbName: string;
10
+ }
11
+ declare function getIndexDBName(iurl: URI, sthis: SuperThis): DbName;
12
+ declare class IndexDBGateway implements bs.Gateway {
13
+ readonly logger: Logger;
14
+ readonly sthis: SuperThis;
15
+ constructor(sthis: SuperThis);
16
+ start(baseURL: URI): Promise<Result<URI>>;
17
+ close(): Promise<Result<void>>;
18
+ destroy(baseUrl: URI): Promise<Result<void>>;
19
+ buildUrl(baseUrl: URI, key: string): Promise<Result<URI>>;
20
+ get(url: URI): Promise<bs.GetResult>;
21
+ put(url: URI, value: Uint8Array): Promise<Result<void, Error>>;
22
+ delete(url: URI): Promise<Result<Result<undefined, Error>, Error>>;
23
+ }
24
+ declare class IndexDBTestGateway implements bs.TestGateway {
25
+ readonly logger: Logger;
26
+ readonly sthis: SuperThis;
27
+ constructor(sthis: SuperThis);
28
+ get(url: URI, key: string): Promise<Uint8Array<ArrayBufferLike>>;
29
+ }
30
+
31
+ declare class KeyBagProviderIndexDB implements rt.kb.KeyBagProvider {
32
+ readonly _db: ResolveOnce<IDBPDatabase<unknown>>;
33
+ readonly dbName: string;
34
+ readonly url: URI;
35
+ readonly logger: Logger;
36
+ readonly sthis: SuperThis;
37
+ constructor(url: URI, sthis: SuperThis);
38
+ _prepare(): Promise<IDBPDatabase<unknown>>;
39
+ get(id: string): Promise<rt.kb.KeyItem | undefined>;
40
+ set(id: string, item: rt.kb.KeyItem): Promise<void>;
41
+ }
42
+
43
+ export { type DbName, IndexDBGateway as GatewayImpl, IndexDBTestGateway as GatewayTestImpl, IndexDBGateway, IndexDBTestGateway, KeyBagProviderIndexDB as KeyBagProviderImpl, KeyBagProviderIndexDB, getIndexDBName };
44
+ declare module '@fireproof/core/web'
package/web/index.d.ts ADDED
@@ -0,0 +1,44 @@
1
+ import { URI, Logger, Result, ResolveOnce } from '@adviser/cement';
2
+ import { SuperThis, bs, rt } from '@fireproof/core';
3
+ import { IDBPDatabase } from 'idb';
4
+
5
+ interface DbName {
6
+ readonly fullDb: string;
7
+ readonly objStore: string;
8
+ readonly connectionKey: string;
9
+ readonly dbName: string;
10
+ }
11
+ declare function getIndexDBName(iurl: URI, sthis: SuperThis): DbName;
12
+ declare class IndexDBGateway implements bs.Gateway {
13
+ readonly logger: Logger;
14
+ readonly sthis: SuperThis;
15
+ constructor(sthis: SuperThis);
16
+ start(baseURL: URI): Promise<Result<URI>>;
17
+ close(): Promise<Result<void>>;
18
+ destroy(baseUrl: URI): Promise<Result<void>>;
19
+ buildUrl(baseUrl: URI, key: string): Promise<Result<URI>>;
20
+ get(url: URI): Promise<bs.GetResult>;
21
+ put(url: URI, value: Uint8Array): Promise<Result<void, Error>>;
22
+ delete(url: URI): Promise<Result<Result<undefined, Error>, Error>>;
23
+ }
24
+ declare class IndexDBTestGateway implements bs.TestGateway {
25
+ readonly logger: Logger;
26
+ readonly sthis: SuperThis;
27
+ constructor(sthis: SuperThis);
28
+ get(url: URI, key: string): Promise<Uint8Array<ArrayBufferLike>>;
29
+ }
30
+
31
+ declare class KeyBagProviderIndexDB implements rt.kb.KeyBagProvider {
32
+ readonly _db: ResolveOnce<IDBPDatabase<unknown>>;
33
+ readonly dbName: string;
34
+ readonly url: URI;
35
+ readonly logger: Logger;
36
+ readonly sthis: SuperThis;
37
+ constructor(url: URI, sthis: SuperThis);
38
+ _prepare(): Promise<IDBPDatabase<unknown>>;
39
+ get(id: string): Promise<rt.kb.KeyItem | undefined>;
40
+ set(id: string, item: rt.kb.KeyItem): Promise<void>;
41
+ }
42
+
43
+ export { type DbName, IndexDBGateway as GatewayImpl, IndexDBTestGateway as GatewayTestImpl, IndexDBGateway, IndexDBTestGateway, KeyBagProviderIndexDB as KeyBagProviderImpl, KeyBagProviderIndexDB, getIndexDBName };
44
+ declare module '@fireproof/core/web'
@@ -61,7 +61,7 @@ function getIndexDBName(iurl, sthis) {
61
61
  dbName
62
62
  };
63
63
  }
64
- var IndexDBGatewayImpl = class {
64
+ var IndexDBGateway = class {
65
65
  constructor(sthis) {
66
66
  this.logger = ensureLogger(sthis, "IndexDBGateway");
67
67
  this.sthis = sthis;
@@ -137,7 +137,7 @@ var IndexDBGatewayImpl = class {
137
137
  });
138
138
  }
139
139
  };
140
- var IndexDBTestStore = class {
140
+ var IndexDBTestGateway = class {
141
141
  constructor(sthis) {
142
142
  this.sthis = sthis;
143
143
  this.logger = ensureLogger(sthis, "IndexDBTestStore", {});
@@ -154,9 +154,56 @@ var IndexDBTestStore = class {
154
154
  return bytes;
155
155
  }
156
156
  };
157
+
158
+ // src/runtime/gateways/indexdb/web/key-bag-indexdb.ts
159
+ import { openDB as openDB2 } from "idb";
160
+ import { ResolveOnce } from "@adviser/cement";
161
+ import { rt } from "@fireproof/core";
162
+ var KeyBagProviderIndexDB = class {
163
+ constructor(url, sthis) {
164
+ this._db = new ResolveOnce();
165
+ this.sthis = sthis;
166
+ this.logger = sthis.logger;
167
+ this.url = url;
168
+ this.dbName = rt.getPath(this.url, this.sthis);
169
+ }
170
+ async _prepare() {
171
+ return this._db.once(async () => {
172
+ return await openDB2(this.dbName, 1, {
173
+ upgrade(db) {
174
+ ["bag"].map((store) => {
175
+ db.createObjectStore(store, {
176
+ autoIncrement: false
177
+ });
178
+ });
179
+ }
180
+ });
181
+ });
182
+ }
183
+ async get(id) {
184
+ const db = await this._prepare();
185
+ const tx = db.transaction(["bag"], "readonly");
186
+ const keyItem = await tx.objectStore("bag").get(id);
187
+ await tx.done;
188
+ if (!keyItem) {
189
+ return void 0;
190
+ }
191
+ return keyItem;
192
+ }
193
+ async set(id, item) {
194
+ const db = await this._prepare();
195
+ const tx = db.transaction(["bag"], "readwrite");
196
+ await tx.objectStore("bag").put(item, id);
197
+ await tx.done;
198
+ }
199
+ };
157
200
  export {
158
- IndexDBGatewayImpl,
159
- IndexDBTestStore,
201
+ IndexDBGateway as GatewayImpl,
202
+ IndexDBTestGateway as GatewayTestImpl,
203
+ IndexDBGateway,
204
+ IndexDBTestGateway,
205
+ KeyBagProviderIndexDB as KeyBagProviderImpl,
206
+ KeyBagProviderIndexDB,
160
207
  getIndexDBName
161
208
  };
162
- //# sourceMappingURL=gateway-impl.js.map
209
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/runtime/gateways/indexdb/web/gateway-impl.ts","../../../src/runtime/gateways/indexdb/version.ts","../../../src/runtime/gateways/indexdb/web/key-bag-indexdb.ts"],"sourcesContent":["import { openDB, IDBPDatabase } from \"idb\";\nimport { exception2Result, KeyedResolvOnce, Logger, Result, URI } from \"@adviser/cement\";\n\nimport { INDEXDB_VERSION } from \"../version.js\";\nimport { ensureLogger, exceptionWrapper, getKey, getStore, NotFoundError } from \"@fireproof/core\";\nimport type { bs } from \"@fireproof/core\";\nimport type { SuperThis } from \"@fireproof/core\";\n\nfunction ensureVersion(url: URI): URI {\n return url.build().defParam(\"version\", INDEXDB_VERSION).URI();\n}\n\ninterface IDBConn {\n readonly db: IDBPDatabase<unknown>;\n readonly dbName: DbName;\n readonly version: string;\n readonly url: URI;\n}\n\nfunction sanitzeKey(key: string | string[]): string | string[] {\n if (key.length === 1) {\n key = key[0];\n }\n return key;\n}\n\nconst onceConn = new KeyedResolvOnce<IDBConn>();\nasync function connectIdb(url: URI, sthis: SuperThis): Promise<IDBConn> {\n const dbName = getIndexDBName(url, sthis);\n const once = await onceConn.get(dbName.fullDb).once(async () => {\n const db = await openDB(dbName.fullDb, 1, {\n upgrade(db) {\n [\"version\", \"data\", \"wal\", \"meta\", \"idx.data\", \"idx.wal\", \"idx.meta\"].map((store) => {\n db.createObjectStore(store, {\n autoIncrement: false,\n });\n });\n },\n });\n const found = await db.get(\"version\", \"version\");\n const version = ensureVersion(url).getParam(\"version\") as string;\n if (!found) {\n await db.put(\"version\", { version }, \"version\");\n } else if (found.version !== version) {\n sthis.logger.Warn().Str(\"url\", url.toString()).Str(\"version\", version).Str(\"found\", found.version).Msg(\"version mismatch\");\n }\n return { db, dbName, version, url };\n });\n return {\n ...once,\n url: url.build().setParam(\"version\", once.version).URI(),\n };\n}\n\nexport interface DbName {\n readonly fullDb: string;\n readonly objStore: string;\n readonly connectionKey: string;\n readonly dbName: string;\n}\n\nfunction joinDBName(...names: string[]): string {\n return names\n .map((i) => i.replace(/^[^a-zA-Z0-9]+/g, \"\").replace(/[^a-zA-Z0-9-]+/g, \"_\"))\n .filter((i) => i.length)\n .join(\".\");\n}\n\n// const schemaVersion = new Map<string, number>();\nexport function getIndexDBName(iurl: URI, sthis: SuperThis): DbName {\n const url = ensureVersion(iurl);\n const fullDb = url.pathname.replace(/^\\/+/, \"\").replace(/\\?.*$/, \"\"); // cut leading slashes\n // const type = getStore(url);\n // const storageVersion = url.searchParams.get(\"version\");\n // not nice but we need to pass the version to the db name\n // url.searchParams.set(\"version\", storageVersion);\n // console.log(\"getIndexDBName:\", url.toString(), { fullDb, type, branch });\n // const dbName = fullDb.replace(new RegExp(`^fp.${storageVersion}.`), \"\"); // cut fp prefix\n const dbName = url.getParam(\"name\");\n if (!dbName) throw sthis.logger.Error().Str(\"url\", url.toString()).Msg(`name not found`).AsError();\n const result = joinDBName(fullDb, dbName);\n const objStore = getStore(url, sthis, joinDBName).name;\n const connectionKey = [result, objStore].join(\":\");\n return {\n fullDb: result,\n objStore,\n connectionKey,\n dbName,\n };\n}\n\nexport class IndexDBGateway implements bs.Gateway {\n readonly logger: Logger;\n readonly sthis: SuperThis;\n constructor(sthis: SuperThis) {\n this.logger = ensureLogger(sthis, \"IndexDBGateway\");\n this.sthis = sthis;\n }\n\n // _db: IDBPDatabase<unknown> = {} as IDBPDatabase<unknown>;\n\n async start(baseURL: URI): Promise<Result<URI>> {\n return exception2Result(async () => {\n this.logger.Debug().Url(baseURL).Msg(\"starting\");\n await this.sthis.start();\n const ic = await connectIdb(baseURL, this.sthis);\n this.logger.Debug().Url(ic.url).Msg(\"started\");\n return ic.url;\n });\n }\n async close(): Promise<Result<void>> {\n return Result.Ok(undefined);\n }\n async destroy(baseUrl: URI): Promise<Result<void>> {\n return exception2Result(async () => {\n // return deleteDB(getIndexDBName(this.url).fullDb);\n const type = getStore(baseUrl, this.sthis, joinDBName).name;\n // console.log(\"IndexDBDataStore:destroy\", type);\n const idb = await connectIdb(baseUrl, this.sthis);\n const trans = idb.db.transaction(type, \"readwrite\");\n const object_store = trans.objectStore(type);\n const toDelete = [];\n for (let cursor = await object_store.openCursor(); cursor; cursor = await cursor.continue()) {\n toDelete.push(cursor.primaryKey);\n }\n for (const key of toDelete) {\n await trans.db.delete(type, key);\n }\n await trans.done;\n });\n }\n\n buildUrl(baseUrl: URI, key: string): Promise<Result<URI>> {\n return Promise.resolve(Result.Ok(baseUrl.build().setParam(\"key\", key).URI()));\n }\n\n async get(url: URI): Promise<bs.GetResult> {\n return exceptionWrapper(async () => {\n const key = getKey(url, this.logger);\n const store = getStore(url, this.sthis, joinDBName).name;\n this.logger.Debug().Url(url).Str(\"key\", key).Str(\"store\", store).Msg(\"getting\");\n const { db } = await connectIdb(url, this.sthis);\n const tx = db.transaction([store], \"readonly\");\n const bytes = await tx.objectStore(store).get(sanitzeKey(key));\n await tx.done;\n if (!bytes) {\n return Result.Err(new NotFoundError(`missing ${key}`));\n }\n return Result.Ok(bytes as Uint8Array);\n });\n }\n async put(url: URI, value: Uint8Array) {\n return exception2Result(async () => {\n const key = getKey(url, this.logger);\n const store = getStore(url, this.sthis, joinDBName).name;\n this.logger.Debug().Url(url).Str(\"key\", key).Str(\"store\", store).Msg(\"putting\");\n const { db } = await connectIdb(url, this.sthis);\n const tx = db.transaction([store], \"readwrite\");\n await tx.objectStore(store).put(value, sanitzeKey(key));\n await tx.done;\n });\n }\n async delete(url: URI) {\n return exception2Result(async () => {\n const key = getKey(url, this.logger);\n const store = getStore(url, this.sthis, joinDBName).name;\n this.logger.Debug().Url(url).Str(\"key\", key).Str(\"store\", store).Msg(\"deleting\");\n const { db } = await connectIdb(url, this.sthis);\n const tx = db.transaction([store], \"readwrite\");\n await tx.objectStore(store).delete(sanitzeKey(key));\n await tx.done;\n return Result.Ok(undefined);\n });\n }\n}\n\n// export class IndexDBDataGateway extends IndexDBGateway {\n// readonly storeType = \"data\";\n// constructor(logger: Logger) {\n// super(ensureLogger(logger, \"IndexDBDataGateway\"));\n// }\n// }\n\n// export class IndexDBWalGateway extends IndexDBGateway {\n// readonly storeType = \"wal\";\n// constructor(logger: Logger) {\n// super(ensureLogger(logger, \"IndexDBWalGateway\"));\n// }\n// }\n// export class IndexDBMetaGateway extends IndexDBGateway {\n// readonly storeType = \"meta\";\n// constructor(logger: Logger) {\n// super(ensureLogger(logger, \"IndexDBMetaGateway\"));\n// }\n// }\n\nexport class IndexDBTestGateway implements bs.TestGateway {\n readonly logger: Logger;\n readonly sthis: SuperThis;\n constructor(sthis: SuperThis) {\n this.sthis = sthis;\n this.logger = ensureLogger(sthis, \"IndexDBTestStore\", {});\n }\n async get(url: URI, key: string) {\n const ic = await connectIdb(url, this.sthis);\n const store = getStore(ic.url, this.sthis, joinDBName).name;\n this.logger.Debug().Str(\"key\", key).Str(\"store\", store).Msg(\"getting\");\n let bytes = await ic.db.get(store, sanitzeKey(key));\n this.logger.Debug().Str(\"key\", key).Str(\"store\", store).Int(\"len\", bytes.length).Msg(\"got\");\n if (typeof bytes === \"string\") {\n bytes = this.sthis.txt.encode(bytes);\n }\n return bytes as Uint8Array;\n }\n}\n","export const INDEXDB_VERSION = \"v0.19-indexdb\";\n","import { IDBPDatabase, openDB } from \"idb\";\nimport { Logger, ResolveOnce, URI } from \"@adviser/cement\";\nimport { SuperThis, rt } from \"@fireproof/core\";\n\nexport class KeyBagProviderIndexDB implements rt.kb.KeyBagProvider {\n readonly _db: ResolveOnce<IDBPDatabase<unknown>> = new ResolveOnce<IDBPDatabase<unknown>>();\n\n readonly dbName: string;\n readonly url: URI;\n readonly logger: Logger;\n readonly sthis: SuperThis;\n constructor(url: URI, sthis: SuperThis) {\n this.sthis = sthis;\n this.logger = sthis.logger;\n this.url = url;\n this.dbName = rt.getPath(this.url, this.sthis);\n }\n\n async _prepare(): Promise<IDBPDatabase<unknown>> {\n return this._db.once(async () => {\n return await openDB(this.dbName, 1, {\n upgrade(db) {\n // console.log('upgrade:', dbName);\n [\"bag\"].map((store) => {\n db.createObjectStore(store, {\n autoIncrement: false,\n });\n });\n },\n });\n });\n }\n\n async get(id: string): Promise<rt.kb.KeyItem | undefined> {\n const db = await this._prepare();\n const tx = db.transaction([\"bag\"], \"readonly\");\n const keyItem = await tx.objectStore(\"bag\").get(id);\n await tx.done;\n if (!keyItem) {\n return undefined;\n }\n return keyItem;\n }\n\n async set(id: string, item: rt.kb.KeyItem): Promise<void> {\n const db = await this._prepare();\n const tx = db.transaction([\"bag\"], \"readwrite\");\n await tx.objectStore(\"bag\").put(item, id);\n await tx.done;\n }\n}\n"],"mappings":"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","names":["db","openDB"]}