@fireproof/core 0.19.8-dev-global → 0.19.8-dev-series-2

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 (64) hide show
  1. package/README.md +34 -0
  2. package/chunk-7EWIAXTM.js +7 -0
  3. package/chunk-7EWIAXTM.js.map +1 -0
  4. package/chunk-OFGPKRCM.js +290 -0
  5. package/chunk-OFGPKRCM.js.map +1 -0
  6. package/chunk-PB4BKL4O.js +7 -0
  7. package/chunk-PB4BKL4O.js.map +1 -0
  8. package/chunk-WS3YRPIA.js +75 -0
  9. package/chunk-WS3YRPIA.js.map +1 -0
  10. package/deno.json +22 -0
  11. package/gateway-5FCWPX5W.js +144 -0
  12. package/gateway-5FCWPX5W.js.map +1 -0
  13. package/{store-indexdb-WLRSICCB.js → gateway-H7UD6TNB.js} +49 -82
  14. package/gateway-H7UD6TNB.js.map +1 -0
  15. package/index.cjs +2365 -1875
  16. package/index.cjs.map +1 -1
  17. package/index.d.cts +663 -535
  18. package/index.d.ts +663 -535
  19. package/index.global.js +26742 -20717
  20. package/index.global.js.map +1 -1
  21. package/index.js +1691 -1094
  22. package/index.js.map +1 -1
  23. package/key-bag-file-WADZBHYG.js +54 -0
  24. package/key-bag-file-WADZBHYG.js.map +1 -0
  25. package/key-bag-indexdb-PGVAI3FJ.js +50 -0
  26. package/key-bag-indexdb-PGVAI3FJ.js.map +1 -0
  27. package/mem-filesystem-YPPJV7Q2.js +41 -0
  28. package/mem-filesystem-YPPJV7Q2.js.map +1 -0
  29. package/metafile-cjs.json +1 -1
  30. package/metafile-esm.json +1 -1
  31. package/metafile-iife.json +1 -1
  32. package/node-filesystem-INX4ZTHE.js +45 -0
  33. package/node-filesystem-INX4ZTHE.js.map +1 -0
  34. package/package.json +14 -8
  35. package/tests/blockstore/fragment-gateway.test.ts +107 -0
  36. package/tests/blockstore/keyed-crypto.test.ts +332 -0
  37. package/tests/blockstore/loader.test.ts +24 -19
  38. package/tests/blockstore/store.test.ts +51 -40
  39. package/tests/blockstore/transaction.test.ts +19 -15
  40. package/tests/fireproof/all-gateway.test.ts +394 -0
  41. package/tests/fireproof/cars/bafkreidxwt2nhvbl4fnqfw3ctlt6zbrir4kqwmjo5im6rf4q5si27kgo2i.car +0 -0
  42. package/tests/fireproof/cars/bafkreidxwt2nhvbl4fnqfw3ctlt6zbrir4kqwmjo5im6rf4q5si27kgo2i.ts +316 -0
  43. package/tests/fireproof/config.test.ts +94 -78
  44. package/tests/fireproof/crdt.test.ts +34 -28
  45. package/tests/fireproof/database.test.ts +22 -14
  46. package/tests/fireproof/fireproof.test.fixture.ts +133 -0
  47. package/tests/fireproof/fireproof.test.ts +331 -219
  48. package/tests/fireproof/hello.test.ts +34 -18
  49. package/tests/fireproof/indexer.test.ts +34 -27
  50. package/tests/fireproof/utils.test.ts +84 -0
  51. package/tests/helpers.ts +28 -57
  52. package/tests/www/todo-local.html +1 -1
  53. package/tests/www/todo.html +12 -15
  54. package/utils-QO2HIWGI.js +14 -0
  55. package/utils-QO2HIWGI.js.map +1 -0
  56. package/chunk-BNL4PVBF.js +0 -314
  57. package/chunk-BNL4PVBF.js.map +0 -1
  58. package/chunk-JW2QT6BF.js +0 -184
  59. package/chunk-JW2QT6BF.js.map +0 -1
  60. package/node-sys-container-MIEX6ELJ.js +0 -29
  61. package/node-sys-container-MIEX6ELJ.js.map +0 -1
  62. package/store-file-VJ6BI4II.js +0 -191
  63. package/store-file-VJ6BI4II.js.map +0 -1
  64. package/store-indexdb-WLRSICCB.js.map +0 -1
@@ -1,191 +0,0 @@
1
- import {
2
- FILESTORE_VERSION,
3
- NotFoundError,
4
- ensureIndexName,
5
- ensureLogger,
6
- exception2Result,
7
- exceptionWrapper,
8
- getFileName,
9
- getPath,
10
- getStore,
11
- isNotFoundError
12
- } from "./chunk-BNL4PVBF.js";
13
- import {
14
- SysContainer
15
- } from "./chunk-JW2QT6BF.js";
16
-
17
- // src/runtime/store-file.ts
18
- import { ResolveOnce, Result } from "@adviser/cement";
19
- var versionFiles = /* @__PURE__ */ new Map();
20
- async function ensureVersionFile(path, logger) {
21
- let once = versionFiles.get(path);
22
- if (!once) {
23
- once = new ResolveOnce();
24
- versionFiles.set(path, once);
25
- }
26
- await once.once(async () => {
27
- await SysContainer.mkdir(path, { recursive: true });
28
- const vFile = SysContainer.join(path, "version");
29
- const vFileStat = await SysContainer.stat(vFile).catch(() => void 0);
30
- if (!vFileStat) {
31
- await SysContainer.writefile(SysContainer.join(path, "version"), FILESTORE_VERSION);
32
- return;
33
- } else if (!vFileStat.isFile()) {
34
- throw logger.Error().Str("file", vFile).Msg(`version file is a directory`).AsError();
35
- }
36
- const v = await SysContainer.readfile(vFile);
37
- if (v.toString() !== FILESTORE_VERSION) {
38
- console.warn(`version mismatch:${vFile}: ${v.toString()}!=${FILESTORE_VERSION}`);
39
- }
40
- });
41
- return path;
42
- }
43
- var FileGateway = class {
44
- constructor(logger) {
45
- this.logger = logger;
46
- }
47
- start(baseURL) {
48
- return exception2Result(async () => {
49
- await SysContainer.start();
50
- baseURL.searchParams.set("version", baseURL.searchParams.get("version") || FILESTORE_VERSION);
51
- const url = await this.buildUrl(baseURL, "dummy");
52
- if (url.isErr()) return url;
53
- const dbdir = this.getFilePath(url.Ok());
54
- await SysContainer.mkdir(SysContainer.dirname(dbdir), { recursive: true });
55
- const dbroot = SysContainer.dirname(dbdir);
56
- this.logger.Debug().Str("url", url.Ok().toString()).Str("dbroot", SysContainer.dirname(dbroot)).Msg("start");
57
- await ensureVersionFile(dbroot, this.logger);
58
- });
59
- }
60
- async close() {
61
- return Result.Ok(void 0);
62
- }
63
- getFilePath(url) {
64
- const path = url.toString().replace(/^file:\/\//, "").replace(/\?.*$/, "");
65
- this.logger.Debug().Str("url", url.toString()).Str("path", path).Msg("getFilePath");
66
- return path;
67
- }
68
- async put(url, body) {
69
- return exception2Result(async () => {
70
- const file = this.getFilePath(url);
71
- this.logger.Debug().Str("url", url.toString()).Str("file", file).Msg("put");
72
- await SysContainer.writefile(file, body);
73
- });
74
- }
75
- async get(url) {
76
- return exceptionWrapper(async () => {
77
- const file = this.getFilePath(url);
78
- try {
79
- const res = await SysContainer.readfile(file);
80
- this.logger.Debug().Url(url).Str("file", file).Msg("get");
81
- return Result.Ok(new Uint8Array(res));
82
- } catch (e) {
83
- if (isNotFoundError(e)) {
84
- return Result.Err(new NotFoundError(`file not found: ${file}`));
85
- }
86
- return Result.Err(e);
87
- }
88
- });
89
- }
90
- async delete(url) {
91
- return exception2Result(async () => {
92
- await SysContainer.unlink(this.getFilePath(url));
93
- });
94
- }
95
- async destroyDir(baseURL) {
96
- const url = await this.buildUrl(baseURL, "x");
97
- if (url.isErr()) return url;
98
- const filepath = SysContainer.dirname(this.getFilePath(url.Ok()));
99
- let dir = [];
100
- try {
101
- dir = await SysContainer.readdir(filepath);
102
- } catch (e) {
103
- if (!isNotFoundError(e)) {
104
- throw this.logger.Error().Err(e).Str("dir", filepath).Msg("destroy:readdir").AsError();
105
- }
106
- }
107
- for (const file of dir) {
108
- const pathed = SysContainer.join(filepath, file);
109
- try {
110
- await SysContainer.unlink(pathed);
111
- } catch (e) {
112
- if (!isNotFoundError(e)) {
113
- throw this.logger.Error().Err(e).Str("file", pathed).Msg("destroy:unlink").AsError();
114
- }
115
- }
116
- }
117
- return Result.Ok(void 0);
118
- }
119
- };
120
- var FileWALGateway = class extends FileGateway {
121
- constructor(logger) {
122
- super(ensureLogger(logger, "FileWALGateway"));
123
- }
124
- async destroy(baseURL) {
125
- return this.destroyDir(baseURL);
126
- }
127
- async buildUrl(baseUrl, key) {
128
- const url = new URL(baseUrl.toString());
129
- url.pathname = SysContainer.join(await getPath(baseUrl, this.logger), ensureIndexName(baseUrl, "wal"), key + ".json");
130
- return Result.Ok(url);
131
- }
132
- };
133
- var FileMetaGateway = class extends FileGateway {
134
- constructor(logger) {
135
- super(ensureLogger(logger, "FileMetaGateway"));
136
- }
137
- async destroy(baseURL) {
138
- return this.destroyDir(baseURL);
139
- }
140
- async buildUrl(baseUrl, key) {
141
- const url = new URL(baseUrl.toString());
142
- url.pathname = SysContainer.join(await getPath(baseUrl, this.logger), ensureIndexName(baseUrl, "meta"), key + ".json");
143
- return Result.Ok(url);
144
- }
145
- };
146
- var FileDataGateway = class extends FileGateway {
147
- constructor(logger) {
148
- super(ensureLogger(logger, "FileDataGateway"));
149
- this.branches = /* @__PURE__ */ new Set();
150
- }
151
- async destroy(baseURL) {
152
- return this.destroyDir(baseURL);
153
- }
154
- async buildUrl(baseUrl, key) {
155
- const url = new URL(baseUrl.toString());
156
- url.pathname = SysContainer.join(await getPath(baseUrl, this.logger), ensureIndexName(baseUrl, "data"), key + ".car");
157
- return Result.Ok(url);
158
- }
159
- };
160
- function toArrayBuffer(buffer) {
161
- const ab = new ArrayBuffer(buffer.length);
162
- const view = new Uint8Array(ab);
163
- for (let i = 0; i < buffer.length; ++i) {
164
- view[i] = buffer[i];
165
- }
166
- return view;
167
- }
168
- var FileTestStore = class {
169
- constructor(logger) {
170
- this.logger = ensureLogger(logger, "FileTestStore");
171
- }
172
- async get(url, key) {
173
- const logger = ensureLogger(this.logger, "get", { url: url.toString(), key });
174
- const dbFile = SysContainer.join(
175
- await getPath(url, this.logger),
176
- getStore(url, this.logger, SysContainer.join),
177
- getFileName(url, key, this.logger)
178
- );
179
- logger.Debug().Str("dbFile", dbFile).Msg("get");
180
- const buffer = await SysContainer.readfile(dbFile);
181
- logger.Debug().Str("dbFile", dbFile).Len(buffer).Msg("got");
182
- return toArrayBuffer(buffer);
183
- }
184
- };
185
- export {
186
- FileDataGateway,
187
- FileMetaGateway,
188
- FileTestStore,
189
- FileWALGateway
190
- };
191
- //# sourceMappingURL=store-file-VJ6BI4II.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/runtime/store-file.ts"],"sourcesContent":["import { SysContainer } from \"./sys-container.js\";\nimport { TestStore } from \"../blockstore/types.js\";\nimport { FILESTORE_VERSION } from \"./store-file-version.js\";\nimport { Logger, ResolveOnce, Result } from \"@adviser/cement\";\nimport { ensureLogger, exception2Result, exceptionWrapper, getStore } from \"../utils.js\";\nimport { Gateway, GetResult, isNotFoundError, NotFoundError } from \"../blockstore/gateway.js\";\nimport { ensureIndexName, getFileName, getPath } from \"./store-file-utils.js\";\n\nconst versionFiles = new Map<string, ResolveOnce<void>>();\nasync function ensureVersionFile(path: string, logger: Logger): Promise<string> {\n let once = versionFiles.get(path);\n if (!once) {\n once = new ResolveOnce<void>();\n versionFiles.set(path, once);\n }\n await once.once(async () => {\n await SysContainer.mkdir(path, { recursive: true });\n const vFile = SysContainer.join(path, \"version\");\n const vFileStat = await SysContainer.stat(vFile).catch(() => undefined);\n if (!vFileStat) {\n await SysContainer.writefile(SysContainer.join(path, \"version\"), FILESTORE_VERSION);\n return;\n } else if (!vFileStat.isFile()) {\n throw logger.Error().Str(\"file\", vFile).Msg(`version file is a directory`).AsError();\n }\n const v = await SysContainer.readfile(vFile);\n if (v.toString() !== FILESTORE_VERSION) {\n console.warn(`version mismatch:${vFile}: ${v.toString()}!=${FILESTORE_VERSION}`);\n }\n });\n return path;\n}\n\nabstract class FileGateway implements Gateway {\n readonly logger: Logger;\n constructor(logger: Logger) {\n this.logger = logger;\n }\n start(baseURL: URL): Promise<Result<void>> {\n return exception2Result(async () => {\n await SysContainer.start();\n baseURL.searchParams.set(\"version\", baseURL.searchParams.get(\"version\") || FILESTORE_VERSION);\n const url = await this.buildUrl(baseURL, \"dummy\");\n if (url.isErr()) return url;\n const dbdir = this.getFilePath(url.Ok());\n // remove dummy\n await SysContainer.mkdir(SysContainer.dirname(dbdir), { recursive: true });\n const dbroot = SysContainer.dirname(dbdir);\n this.logger.Debug().Str(\"url\", url.Ok().toString()).Str(\"dbroot\", SysContainer.dirname(dbroot)).Msg(\"start\");\n await ensureVersionFile(dbroot, this.logger);\n });\n }\n async close(): Promise<Result<void>> {\n return Result.Ok(undefined);\n }\n abstract destroy(baseUrl: URL): Promise<Result<void>>;\n abstract buildUrl(baseUrl: URL, key: string): Promise<Result<URL>>;\n\n getFilePath(url: URL): string {\n const path = url\n .toString()\n .replace(/^file:\\/\\//, \"\")\n .replace(/\\?.*$/, \"\");\n this.logger.Debug().Str(\"url\", url.toString()).Str(\"path\", path).Msg(\"getFilePath\");\n return path;\n }\n\n async put(url: URL, body: Uint8Array): Promise<Result<void>> {\n return exception2Result(async () => {\n const file = this.getFilePath(url);\n this.logger.Debug().Str(\"url\", url.toString()).Str(\"file\", file).Msg(\"put\");\n await SysContainer.writefile(file, body);\n });\n }\n async get(url: URL): Promise<GetResult> {\n return exceptionWrapper(async () => {\n const file = this.getFilePath(url);\n try {\n const res = await SysContainer.readfile(file);\n this.logger.Debug().Url(url).Str(\"file\", file).Msg(\"get\");\n return Result.Ok(new Uint8Array(res));\n } catch (e: unknown) {\n // this.logger.Error().Err(e).Str(\"file\", file).Msg(\"get\");\n if (isNotFoundError(e)) {\n return Result.Err(new NotFoundError(`file not found: ${file}`));\n }\n return Result.Err(e as Error);\n }\n });\n }\n async delete(url: URL): Promise<Result<void>> {\n return exception2Result(async () => {\n await SysContainer.unlink(this.getFilePath(url));\n });\n }\n\n async destroyDir(baseURL: URL): Promise<Result<void>> {\n const url = await this.buildUrl(baseURL, \"x\");\n if (url.isErr()) return url;\n const filepath = SysContainer.dirname(this.getFilePath(url.Ok()));\n let dir: string[] = [];\n try {\n dir = await SysContainer.readdir(filepath);\n } catch (e: unknown) {\n if (!isNotFoundError(e)) {\n throw this.logger.Error().Err(e).Str(\"dir\", filepath).Msg(\"destroy:readdir\").AsError();\n }\n }\n for (const file of dir) {\n const pathed = SysContainer.join(filepath, file);\n try {\n await SysContainer.unlink(pathed);\n } catch (e: unknown) {\n if (!isNotFoundError(e)) {\n throw this.logger.Error().Err(e).Str(\"file\", pathed).Msg(\"destroy:unlink\").AsError();\n }\n }\n }\n return Result.Ok(undefined);\n }\n}\n\nexport class FileWALGateway extends FileGateway {\n constructor(logger: Logger) {\n super(ensureLogger(logger, \"FileWALGateway\"));\n }\n\n async destroy(baseURL: URL): Promise<Result<void>> {\n return this.destroyDir(baseURL);\n }\n async buildUrl(baseUrl: URL, key: string): Promise<Result<URL>> {\n const url = new URL(baseUrl.toString());\n url.pathname = SysContainer.join(await getPath(baseUrl, this.logger), ensureIndexName(baseUrl, \"wal\"), key + \".json\");\n return Result.Ok(url);\n }\n}\n\nexport class FileMetaGateway extends FileGateway {\n constructor(logger: Logger) {\n super(ensureLogger(logger, \"FileMetaGateway\"));\n }\n\n async destroy(baseURL: URL): Promise<Result<void>> {\n return this.destroyDir(baseURL);\n }\n async buildUrl(baseUrl: URL, key: string): Promise<Result<URL>> {\n const url = new URL(baseUrl.toString());\n url.pathname = SysContainer.join(await getPath(baseUrl, this.logger), ensureIndexName(baseUrl, \"meta\"), key + \".json\");\n return Result.Ok(url);\n }\n}\n\nexport class FileDataGateway extends FileGateway {\n readonly branches = new Set<string>();\n constructor(logger: Logger) {\n // console.log(\"FileDataGateway->\", logger);\n super(ensureLogger(logger, \"FileDataGateway\"));\n }\n\n async destroy(baseURL: URL): Promise<Result<void>> {\n return this.destroyDir(baseURL);\n }\n async buildUrl(baseUrl: URL, key: string): Promise<Result<URL>> {\n const url = new URL(baseUrl.toString());\n url.pathname = SysContainer.join(await getPath(baseUrl, this.logger), ensureIndexName(baseUrl, \"data\"), key + \".car\");\n return Result.Ok(url);\n }\n}\n\nfunction toArrayBuffer(buffer: Buffer) {\n const ab = new ArrayBuffer(buffer.length);\n const view = new Uint8Array(ab);\n for (let i = 0; i < buffer.length; ++i) {\n view[i] = buffer[i];\n }\n return view;\n}\n\nexport class FileTestStore implements TestStore {\n readonly logger: Logger;\n constructor(\n // readonly url: URL,\n logger: Logger,\n ) {\n this.logger = ensureLogger(logger, \"FileTestStore\");\n }\n\n async get(url: URL, key: string) {\n const logger = ensureLogger(this.logger, \"get\", { url: url.toString(), key });\n const dbFile = SysContainer.join(\n await getPath(url, this.logger),\n getStore(url, this.logger, SysContainer.join),\n getFileName(url, key, this.logger),\n );\n logger.Debug().Str(\"dbFile\", dbFile).Msg(\"get\");\n const buffer = await SysContainer.readfile(dbFile);\n logger.Debug().Str(\"dbFile\", dbFile).Len(buffer).Msg(\"got\");\n return toArrayBuffer(buffer);\n }\n}\n"],"mappings":"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","names":[]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/runtime/store-indexdb.ts"],"sourcesContent":["import { openDB, IDBPDatabase } from \"idb\";\nimport { KeyedResolvOnce, Logger, Result } from \"@adviser/cement\";\n\nimport { TestStore } from \"../blockstore/types.js\";\nimport { INDEXDB_VERSION } from \"./store-indexdb-version.js\";\nimport { ensureLogger, exception2Result, exceptionWrapper, getKey, getStore } from \"../utils.js\";\nimport { Gateway, NotFoundError } from \"../blockstore/gateway.js\";\nimport { SysContainer } from \"./sys-container.js\";\n\nfunction ensureVersion(url: URL): URL {\n const ret = new URL(url.toString());\n ret.searchParams.set(\"version\", url.searchParams.get(\"version\") || INDEXDB_VERSION);\n return ret;\n}\n\nconst onceIndexDB = new KeyedResolvOnce<{\n readonly db: IDBPDatabase<unknown>;\n readonly dbName: DbName;\n readonly version: string;\n}>();\n\nfunction sanitzeKey(key: string | string[]): string | string[] {\n if (key.length === 1) {\n key = key[0];\n }\n return key;\n}\n\nasync function connectIdb(url: URL, logger: Logger): Promise<IDBPDatabase<unknown>> {\n const dbName = getIndexDBName(url, logger); // `fp.${this.STORAGE_VERSION}.${this.name}`;\n // const urlStr = url.toString().replace(/\\?.*$/, \"\");\n // console.log(`get:${this.id}`);\n // console.log(`connectIdb:pre:`, dbName, url.toString());\n const once = await onceIndexDB.get(dbName.fullDb).once(async () => {\n // console.log(`connectIdb:once:`, dbName, url.toString());\n const db = await openDB(dbName.fullDb, 1, {\n upgrade(db) {\n // console.log('upgrade:', dbName);\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 = url.searchParams.get(\"version\") || INDEXDB_VERSION;\n if (!found) {\n await db.put(\"version\", { version }, \"version\");\n } else if (found.version !== version) {\n logger\n .Warn()\n .Str(\"url\", url.toString())\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n .Str(\"version\", version!)\n .Str(\"found\", found.version)\n .Msg(\"version mismatch\");\n }\n return { db, dbName, version };\n });\n url.searchParams.set(\"version\", once.version);\n return once.db;\n}\n\nexport interface DbName {\n readonly fullDb: string;\n readonly objStore: string;\n readonly connectionKey: string;\n // readonly version: number;\n // readonly type: \"data\" | \"meta\" | \"wal\";\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: URL, logger: Logger): 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.searchParams.get(\"name\");\n if (!dbName) throw logger.Error().Str(\"url\", url.toString()).Msg(`name not found`).AsError();\n const result = joinDBName(fullDb, dbName);\n const objStore = getStore(url, logger, joinDBName);\n const connectionKey = [result, objStore].join(\":\");\n return {\n fullDb: result,\n objStore,\n connectionKey,\n dbName,\n };\n}\n\nabstract class IndexDBGateway implements Gateway {\n readonly logger: Logger;\n constructor(logger: Logger) {\n this.logger = logger;\n }\n db: IDBPDatabase<unknown> = {} as IDBPDatabase<unknown>;\n idb() {\n this.db;\n }\n\n async start(baseURL: URL): Promise<Result<void>> {\n return exception2Result(async () => {\n this.logger.Debug().Url(baseURL).Msg(\"starting\");\n await SysContainer.start();\n this.db = await connectIdb(baseURL, this.logger);\n this.logger.Debug().Url(baseURL).Msg(\"started\");\n });\n }\n async close(): Promise<Result<void>> {\n return Result.Ok(undefined);\n }\n async destroy(baseUrl: URL): Promise<Result<void>> {\n return exception2Result(async () => {\n // return deleteDB(getIndexDBName(this.url).fullDb);\n const type = getStore(baseUrl, this.logger, joinDBName);\n // console.log(\"IndexDBDataStore:destroy\", type);\n const idb = this.db;\n const trans = idb.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 abstract buildUrl(baseUrl: URL, key: string): Promise<Result<URL>>;\n\n async get(url: URL) {\n return exceptionWrapper(async () => {\n const key = getKey(url, this.logger);\n const store = getStore(url, this.logger, joinDBName);\n this.logger.Debug().Url(url).Str(\"key\", key).Str(\"store\", store).Msg(\"getting\");\n const tx = this.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: URL, value: Uint8Array) {\n return exception2Result(async () => {\n const key = getKey(url, this.logger);\n const store = getStore(url, this.logger, joinDBName);\n this.logger.Debug().Url(url).Str(\"key\", key).Str(\"store\", store).Msg(\"putting\");\n const tx = this.db.transaction([store], \"readwrite\");\n await tx.objectStore(store).put(value, sanitzeKey(key));\n await tx.done;\n });\n }\n async delete(url: URL) {\n return exception2Result(async () => {\n const key = getKey(url, this.logger);\n const store = getStore(url, this.logger, joinDBName);\n this.logger.Debug().Url(url).Str(\"key\", key).Str(\"store\", store).Msg(\"deleting\");\n const tx = this.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\nexport class IndexDBDataGateway extends IndexDBGateway {\n constructor(logger: Logger) {\n super(ensureLogger(logger, \"IndexDBDataGateway\", {}));\n }\n\n buildUrl(baseUrl: URL, key: string): Promise<Result<URL>> {\n const url = new URL(baseUrl.toString());\n url.searchParams.set(\"key\", key);\n return Promise.resolve(Result.Ok(url));\n }\n}\n\nexport class IndexDBWalGateway extends IndexDBGateway {\n constructor(logger: Logger) {\n super(ensureLogger(logger, \"IndexDBWalGateway\", {}));\n }\n buildUrl(baseUrl: URL, key: string): Promise<Result<URL>> {\n const url = new URL(baseUrl.toString());\n url.searchParams.set(\"key\", key);\n return Promise.resolve(Result.Ok(url));\n }\n}\nexport class IndexDBMetaGateway extends IndexDBGateway {\n constructor(logger: Logger) {\n super(ensureLogger(logger, \"IndexDBDataGateway\", {}));\n }\n\n readonly branches = new Set<string>();\n async buildUrl(baseUrl: URL, key: string): Promise<Result<URL>> {\n const url = new URL(baseUrl.toString());\n this.branches.add(key);\n url.searchParams.set(\"key\", key);\n return Result.Ok(url);\n }\n}\n\nconst txtEncoder = new TextEncoder();\nexport class IndexDBTestStore implements TestStore {\n readonly logger: Logger;\n constructor(logger: Logger) {\n this.logger = ensureLogger(logger, \"IndexDBTestStore\", {});\n }\n async get(url: URL, key: string) {\n const db = await connectIdb(url, this.logger);\n const store = getStore(url, this.logger, joinDBName);\n this.logger.Debug().Str(\"key\", key).Str(\"store\", store).Msg(\"getting\");\n let bytes = await 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 = txtEncoder.encode(bytes);\n }\n return bytes as Uint8Array;\n }\n}\n"],"mappings":"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","names":["db"]}