@fireproof/core 0.19.121-dev → 0.20.0-dev-preview-05
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/README.md +13 -12
- package/deno/index.d.ts +7 -0
- package/deno/index.js +66 -0
- package/deno/index.js.map +1 -0
- package/deno/metafile-esm.json +1 -0
- package/deno.json +3 -4
- package/index.cjs +1797 -1431
- package/index.cjs.map +1 -1
- package/index.d.cts +760 -381
- package/index.d.ts +760 -381
- package/index.js +1976 -913
- package/index.js.map +1 -1
- package/metafile-cjs.json +1 -1
- package/metafile-esm.json +1 -1
- package/node/{node-filesystem.cjs → index.cjs} +17 -6
- package/node/index.cjs.map +1 -0
- package/node/index.d.cts +7 -0
- package/node/index.d.ts +7 -0
- package/node/{node-filesystem.js → index.js} +25 -5
- package/node/index.js.map +1 -0
- package/node/metafile-cjs.json +1 -1
- package/node/metafile-esm.json +1 -1
- package/package.json +27 -17
- package/react/index.cjs +22 -22
- package/react/index.cjs.map +1 -1
- package/react/index.d.cts +7 -7
- package/react/index.d.ts +7 -7
- package/react/index.js +22 -22
- package/react/index.js.map +1 -1
- package/react/metafile-cjs.json +1 -1
- package/react/metafile-esm.json +1 -1
- package/tests/blockstore/fp-envelope.test.ts-off +65 -0
- package/tests/blockstore/interceptor-gateway.test.ts +122 -0
- package/tests/blockstore/keyed-crypto-indexdb-file.test.ts +130 -0
- package/tests/blockstore/keyed-crypto.test.ts +75 -118
- package/tests/blockstore/loader.test.ts +18 -9
- package/tests/blockstore/store.test.ts +40 -31
- package/tests/blockstore/transaction.test.ts +14 -13
- package/tests/fireproof/all-gateway.test.ts +286 -216
- package/tests/fireproof/cars/bafkreidxwt2nhvbl4fnqfw3ctlt6zbrir4kqwmjo5im6rf4q5si27kgo2i.ts +324 -316
- package/tests/fireproof/crdt.test.ts +78 -19
- package/tests/fireproof/fireproof.test.ts +111 -92
- package/tests/fireproof/hello.test.ts +21 -17
- package/tests/fireproof/indexer.test.ts +74 -50
- package/tests/fireproof/{database.test.ts → ledger.test.ts} +241 -45
- package/tests/fireproof/multiple-ledger.test.ts +2 -2
- package/tests/fireproof/utils.test.ts +47 -6
- package/tests/gateway/file/loader-config.test.ts +307 -0
- package/tests/gateway/fp-envelope-serialize.test.ts +256 -0
- package/tests/gateway/indexdb/loader-config.test.ts +79 -0
- package/tests/helpers.ts +44 -17
- package/tests/react/useFireproof.test.tsx +2 -2
- package/tests/www/gallery.html +2 -2
- package/tests/www/todo-aws.html +1 -1
- package/tests/www/todo-ipfs.html +1 -1
- package/tests/www/todo-local.html +1 -1
- package/tests/www/todo.html +25 -4
- package/web/index.cjs +218 -0
- package/web/index.cjs.map +1 -0
- package/web/index.d.cts +30 -0
- package/web/index.d.ts +30 -0
- package/web/index.js +195 -0
- package/web/index.js.map +1 -0
- package/web/metafile-cjs.json +1 -1
- package/web/metafile-esm.json +1 -1
- package/chunk-7EWIAXTM.js +0 -7
- package/chunk-7EWIAXTM.js.map +0 -1
- package/chunk-F4FC6B2T.js +0 -63
- package/chunk-F4FC6B2T.js.map +0 -1
- package/chunk-PZ5AY32C.js +0 -10
- package/chunk-PZ5AY32C.js.map +0 -1
- package/chunk-RXC4JGJT.js +0 -301
- package/chunk-RXC4JGJT.js.map +0 -1
- package/gateway-C62S56GY.js +0 -66
- package/gateway-C62S56GY.js.map +0 -1
- package/gateway-VVS4QWDA.js +0 -145
- package/gateway-VVS4QWDA.js.map +0 -1
- package/key-bag-file-PWZ3QE7B.js +0 -55
- package/key-bag-file-PWZ3QE7B.js.map +0 -1
- package/key-bag-indexdb-SYG3YD4D.js +0 -51
- package/key-bag-indexdb-SYG3YD4D.js.map +0 -1
- package/node/chunk-4A4RAVNS.js +0 -17
- package/node/chunk-4A4RAVNS.js.map +0 -1
- package/node/mem-filesystem.cjs +0 -72
- package/node/mem-filesystem.cjs.map +0 -1
- package/node/mem-filesystem.d.cts +0 -25
- package/node/mem-filesystem.d.ts +0 -25
- package/node/mem-filesystem.js +0 -40
- package/node/mem-filesystem.js.map +0 -1
- package/node/node-filesystem.cjs.map +0 -1
- package/node/node-filesystem.d.cts +0 -35
- package/node/node-filesystem.d.ts +0 -35
- package/node/node-filesystem.js.map +0 -1
- package/tests/fireproof/config.test.ts +0 -172
- package/utils-ZVVGAXFE.js +0 -13
- package/utils-ZVVGAXFE.js.map +0 -1
- package/web/gateway-impl.cjs +0 -183
- package/web/gateway-impl.cjs.map +0 -1
- package/web/gateway-impl.d.cts +0 -31
- package/web/gateway-impl.d.ts +0 -31
- package/web/gateway-impl.js +0 -162
- package/web/gateway-impl.js.map +0 -1
- /package/tests/blockstore/{fragment-gateway.test.ts → fragment-gateway.test.ts-off} +0 -0
package/web/index.js
ADDED
@@ -0,0 +1,195 @@
|
|
1
|
+
// src/runtime/gateways/indexdb/web/key-bag-indexdb.ts
|
2
|
+
import { openDB } from "idb";
|
3
|
+
import { ResolveOnce } from "@adviser/cement";
|
4
|
+
import { rt } from "@fireproof/core";
|
5
|
+
var KeyBagProviderIndexDB = class {
|
6
|
+
constructor(url, sthis) {
|
7
|
+
this._db = new ResolveOnce();
|
8
|
+
this.sthis = sthis;
|
9
|
+
this.logger = sthis.logger;
|
10
|
+
this.url = url;
|
11
|
+
this.dbName = rt.getPath(this.url, this.sthis);
|
12
|
+
}
|
13
|
+
async _prepare() {
|
14
|
+
return this._db.once(async () => {
|
15
|
+
return await openDB(this.dbName, 1, {
|
16
|
+
upgrade(db) {
|
17
|
+
["bag"].map((store) => {
|
18
|
+
db.createObjectStore(store, {
|
19
|
+
autoIncrement: false
|
20
|
+
});
|
21
|
+
});
|
22
|
+
}
|
23
|
+
});
|
24
|
+
});
|
25
|
+
}
|
26
|
+
async get(id) {
|
27
|
+
const db = await this._prepare();
|
28
|
+
const tx = db.transaction(["bag"], "readonly");
|
29
|
+
const keyItem = await tx.objectStore("bag").get(id);
|
30
|
+
await tx.done;
|
31
|
+
if (!keyItem) {
|
32
|
+
return void 0;
|
33
|
+
}
|
34
|
+
return keyItem;
|
35
|
+
}
|
36
|
+
async set(id, item) {
|
37
|
+
const db = await this._prepare();
|
38
|
+
const tx = db.transaction(["bag"], "readwrite");
|
39
|
+
await tx.objectStore("bag").put(item, id);
|
40
|
+
await tx.done;
|
41
|
+
}
|
42
|
+
};
|
43
|
+
|
44
|
+
// src/runtime/gateways/indexdb/web/gateway-impl.ts
|
45
|
+
import { openDB as openDB2 } from "idb";
|
46
|
+
import { exception2Result, KeyedResolvOnce, Result } from "@adviser/cement";
|
47
|
+
|
48
|
+
// src/runtime/gateways/indexdb/version.ts
|
49
|
+
var INDEXDB_VERSION = "v0.19-indexdb";
|
50
|
+
|
51
|
+
// src/runtime/gateways/indexdb/web/gateway-impl.ts
|
52
|
+
import { NotFoundError, PARAM, exceptionWrapper, getKey, getStore } from "@fireproof/core";
|
53
|
+
function ensureVersion(url) {
|
54
|
+
return url.build().defParam(PARAM.VERSION, INDEXDB_VERSION).URI();
|
55
|
+
}
|
56
|
+
var onceIndexDB = new KeyedResolvOnce();
|
57
|
+
function sanitzeKey(key) {
|
58
|
+
if (key.length === 1) {
|
59
|
+
key = key[0];
|
60
|
+
}
|
61
|
+
return key;
|
62
|
+
}
|
63
|
+
async function connectIdb(url, sthis) {
|
64
|
+
const dbName = getIndexDBName(url, sthis);
|
65
|
+
const once = await onceIndexDB.get(dbName.fullDb).once(async () => {
|
66
|
+
const db = await openDB2(dbName.fullDb, 1, {
|
67
|
+
upgrade(db2) {
|
68
|
+
["version", "data", "wal", "meta", "idx.data", "idx.wal", "idx.meta"].map((store) => {
|
69
|
+
db2.createObjectStore(store, {
|
70
|
+
autoIncrement: false
|
71
|
+
});
|
72
|
+
});
|
73
|
+
}
|
74
|
+
});
|
75
|
+
const found = await db.get("version", "version");
|
76
|
+
const version = ensureVersion(url).getParam(PARAM.VERSION);
|
77
|
+
if (!found) {
|
78
|
+
await db.put("version", { version }, "version");
|
79
|
+
} else if (found.version !== version) {
|
80
|
+
sthis.logger.Warn().Url(url).Str("version", version).Str("found", found.version).Msg("version mismatch");
|
81
|
+
}
|
82
|
+
return { db, dbName, version, url };
|
83
|
+
});
|
84
|
+
return {
|
85
|
+
...once,
|
86
|
+
url: url.build().setParam(PARAM.VERSION, once.version).URI()
|
87
|
+
};
|
88
|
+
}
|
89
|
+
function joinDBName(...names) {
|
90
|
+
return names.map((i) => i.replace(/^[^a-zA-Z0-9]+/g, "").replace(/[^a-zA-Z0-9-]+/g, "_")).filter((i) => i.length).join(".");
|
91
|
+
}
|
92
|
+
function getIndexDBName(iurl, sthis) {
|
93
|
+
const url = ensureVersion(iurl);
|
94
|
+
const fullDb = url.pathname.replace(/^\/+/, "").replace(/\?.*$/, "");
|
95
|
+
const dbName = url.getParam(PARAM.NAME);
|
96
|
+
if (!dbName) throw sthis.logger.Error().Str("url", url.toString()).Msg(`name not found`).AsError();
|
97
|
+
const result = joinDBName(fullDb, dbName);
|
98
|
+
const objStore = getStore(url, sthis, joinDBName).name;
|
99
|
+
const connectionKey = [result, objStore].join(":");
|
100
|
+
return {
|
101
|
+
fullDb: result,
|
102
|
+
objStore,
|
103
|
+
connectionKey,
|
104
|
+
dbName
|
105
|
+
};
|
106
|
+
}
|
107
|
+
var IndexDBGateway = class {
|
108
|
+
constructor() {
|
109
|
+
this._db = {};
|
110
|
+
}
|
111
|
+
async start(baseURL, sthis) {
|
112
|
+
return exception2Result(async () => {
|
113
|
+
await sthis.start();
|
114
|
+
sthis.logger.Debug().Url(baseURL).Msg("starting");
|
115
|
+
const ic = await connectIdb(baseURL, sthis);
|
116
|
+
this._db = ic.db;
|
117
|
+
sthis.logger.Debug().Url(ic.url).Msg("started");
|
118
|
+
return ic.url;
|
119
|
+
});
|
120
|
+
}
|
121
|
+
async close() {
|
122
|
+
return Result.Ok(void 0);
|
123
|
+
}
|
124
|
+
async destroy(baseUrl, sthis) {
|
125
|
+
return exception2Result(async () => {
|
126
|
+
const type = getStore(baseUrl, sthis, joinDBName).name;
|
127
|
+
const idb = this._db;
|
128
|
+
const trans = idb.transaction(type, "readwrite");
|
129
|
+
const object_store = trans.objectStore(type);
|
130
|
+
const toDelete = [];
|
131
|
+
for (let cursor = await object_store.openCursor(); cursor; cursor = await cursor.continue()) {
|
132
|
+
toDelete.push(cursor.primaryKey);
|
133
|
+
}
|
134
|
+
for (const key of toDelete) {
|
135
|
+
await trans.db.delete(type, key);
|
136
|
+
}
|
137
|
+
await trans.done;
|
138
|
+
});
|
139
|
+
}
|
140
|
+
buildUrl(baseUrl, key) {
|
141
|
+
return Promise.resolve(Result.Ok(baseUrl.build().setParam(PARAM.KEY, key).URI()));
|
142
|
+
}
|
143
|
+
async get(url, sthis) {
|
144
|
+
return exceptionWrapper(async () => {
|
145
|
+
const key = getKey(url, sthis.logger);
|
146
|
+
const store = getStore(url, sthis, joinDBName).name;
|
147
|
+
sthis.logger.Debug().Url(url).Str("key", key).Str("store", store).Msg("getting");
|
148
|
+
const tx = this._db.transaction([store], "readonly");
|
149
|
+
const bytes = await tx.objectStore(store).get(sanitzeKey(key));
|
150
|
+
await tx.done;
|
151
|
+
if (!bytes) {
|
152
|
+
return Result.Err(new NotFoundError(`missing ${key}`));
|
153
|
+
}
|
154
|
+
return Promise.resolve(Result.Ok(bytes));
|
155
|
+
});
|
156
|
+
}
|
157
|
+
async put(url, bytes, sthis) {
|
158
|
+
return exception2Result(async () => {
|
159
|
+
const key = getKey(url, sthis.logger);
|
160
|
+
const store = getStore(url, sthis, joinDBName).name;
|
161
|
+
sthis.logger.Debug().Url(url).Str("key", key).Str("store", store).Msg("putting");
|
162
|
+
const tx = this._db.transaction([store], "readwrite");
|
163
|
+
await tx.objectStore(store).put(bytes, sanitzeKey(key));
|
164
|
+
await tx.done;
|
165
|
+
});
|
166
|
+
}
|
167
|
+
async delete(url, sthis) {
|
168
|
+
return exception2Result(async () => {
|
169
|
+
const key = getKey(url, sthis.logger);
|
170
|
+
const store = getStore(url, sthis, joinDBName).name;
|
171
|
+
sthis.logger.Debug().Url(url).Str("key", key).Str("store", store).Msg("deleting");
|
172
|
+
const tx = this._db.transaction([store], "readwrite");
|
173
|
+
await tx.objectStore(store).delete(sanitzeKey(key));
|
174
|
+
await tx.done;
|
175
|
+
return Result.Ok(void 0);
|
176
|
+
});
|
177
|
+
}
|
178
|
+
async getPlain(url, key, sthis) {
|
179
|
+
const ic = await connectIdb(url, sthis);
|
180
|
+
const store = getStore(ic.url, sthis, joinDBName).name;
|
181
|
+
sthis.logger.Debug().Str("key", key).Str("store", store).Msg("getting");
|
182
|
+
let bytes = await ic.db.get(store, sanitzeKey(key));
|
183
|
+
sthis.logger.Debug().Str("key", key).Str("store", store).Int("len", bytes.length).Msg("got");
|
184
|
+
if (typeof bytes === "string") {
|
185
|
+
bytes = sthis.txt.encode(bytes);
|
186
|
+
}
|
187
|
+
return Result.Ok(bytes);
|
188
|
+
}
|
189
|
+
};
|
190
|
+
export {
|
191
|
+
IndexDBGateway as GatewayImpl,
|
192
|
+
KeyBagProviderIndexDB as KeyBagProviderImpl,
|
193
|
+
KeyBagProviderIndexDB
|
194
|
+
};
|
195
|
+
//# sourceMappingURL=index.js.map
|
package/web/index.js.map
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"sources":["../../../src/runtime/gateways/indexdb/web/key-bag-indexdb.ts","../../../src/runtime/gateways/indexdb/web/gateway-impl.ts","../../../src/runtime/gateways/indexdb/version.ts"],"sourcesContent":["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","import { openDB, IDBPDatabase } from \"idb\";\nimport { exception2Result, KeyedResolvOnce, Result, URI } from \"@adviser/cement\";\n\nimport { INDEXDB_VERSION } from \"../version.js\";\nimport { NotFoundError, PARAM, exceptionWrapper, getKey, getStore, type SuperThis, bs } from \"@fireproof/core\";\n\nfunction ensureVersion(url: URI): URI {\n return url.build().defParam(PARAM.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}\nconst onceIndexDB = new KeyedResolvOnce<IDBConn>();\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: URI, sthis: SuperThis): Promise<IDBConn> {\n const dbName = getIndexDBName(url, sthis);\n const once = await onceIndexDB.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(PARAM.VERSION) as string;\n if (!found) {\n await db.put(\"version\", { version }, \"version\");\n } else if (found.version !== version) {\n sthis.logger.Warn().Url(url).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(PARAM.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\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 dbName = url.getParam(PARAM.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 _db: IDBPDatabase<unknown> = {} as IDBPDatabase<unknown>;\n\n async start(baseURL: URI, sthis: SuperThis): Promise<Result<URI>> {\n return exception2Result(async () => {\n await sthis.start();\n sthis.logger.Debug().Url(baseURL).Msg(\"starting\");\n const ic = await connectIdb(baseURL, sthis);\n this._db = ic.db;\n sthis.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, sthis: SuperThis): Promise<Result<void>> {\n return exception2Result(async () => {\n // return deleteDB(getIndexDBName(this.url).fullDb);\n const type = getStore(baseUrl, sthis, joinDBName).name;\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 buildUrl(baseUrl: URI, key: string): Promise<Result<URI>> {\n return Promise.resolve(Result.Ok(baseUrl.build().setParam(PARAM.KEY, key).URI()));\n }\n\n async get(url: URI, sthis: SuperThis): Promise<bs.GetResult> {\n return exceptionWrapper(async () => {\n const key = getKey(url, sthis.logger);\n const store = getStore(url, sthis, joinDBName).name;\n sthis.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 Promise.resolve(Result.Ok(bytes));\n });\n }\n async put(url: URI, bytes: Uint8Array, sthis: SuperThis): Promise<Result<void>> {\n return exception2Result(async () => {\n const key = getKey(url, sthis.logger);\n const store = getStore(url, sthis, joinDBName).name;\n sthis.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(bytes, sanitzeKey(key));\n await tx.done;\n });\n }\n async delete(url: URI, sthis: SuperThis) {\n return exception2Result(async () => {\n const key = getKey(url, sthis.logger);\n const store = getStore(url, sthis, joinDBName).name;\n sthis.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 async getPlain(url: URI, key: string, sthis: SuperThis): Promise<Result<Uint8Array>> {\n const ic = await connectIdb(url, sthis);\n const store = getStore(ic.url, sthis, joinDBName).name;\n sthis.logger.Debug().Str(\"key\", key).Str(\"store\", store).Msg(\"getting\");\n let bytes = await ic.db.get(store, sanitzeKey(key));\n sthis.logger.Debug().Str(\"key\", key).Str(\"store\", store).Int(\"len\", bytes.length).Msg(\"got\");\n if (typeof bytes === \"string\") {\n bytes = sthis.txt.encode(bytes);\n }\n return Result.Ok(bytes as Uint8Array);\n }\n}\n","export const INDEXDB_VERSION = \"v0.19-indexdb\";\n"],"mappings":"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","names":["openDB","openDB","db"]}
|
package/web/metafile-cjs.json
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"inputs":{"src/runtime/gateways/indexdb/version.ts":{"bytes":48,"imports":[],"format":"esm"},"src/runtime/gateways/indexdb/web/gateway-impl.ts":{"bytes":
|
1
|
+
{"inputs":{"src/runtime/gateways/indexdb/web/key-bag-indexdb.ts":{"bytes":1509,"imports":[{"path":"idb","kind":"import-statement","external":true},{"path":"@adviser/cement","kind":"import-statement","external":true},{"path":"@fireproof/core","kind":"import-statement","external":true}],"format":"esm"},"src/runtime/gateways/indexdb/version.ts":{"bytes":48,"imports":[],"format":"esm"},"src/runtime/gateways/indexdb/web/gateway-impl.ts":{"bytes":6161,"imports":[{"path":"idb","kind":"import-statement","external":true},{"path":"@adviser/cement","kind":"import-statement","external":true},{"path":"src/runtime/gateways/indexdb/version.ts","kind":"import-statement","original":"../version.js"},{"path":"@fireproof/core","kind":"import-statement","external":true}],"format":"esm"},"src/runtime/gateways/indexdb/web/index.ts":{"bytes":285,"imports":[{"path":"src/runtime/gateways/indexdb/web/key-bag-indexdb.ts","kind":"import-statement","original":"./key-bag-indexdb.js"},{"path":"src/runtime/gateways/indexdb/web/key-bag-indexdb.ts","kind":"import-statement","original":"./key-bag-indexdb.js"},{"path":"src/runtime/gateways/indexdb/web/gateway-impl.ts","kind":"import-statement","original":"./gateway-impl.js"}],"format":"esm"}},"outputs":{"dist/fireproof-core/web/index.cjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":14054},"dist/fireproof-core/web/index.cjs":{"imports":[{"path":"idb","kind":"require-call","external":true},{"path":"@adviser/cement","kind":"require-call","external":true},{"path":"@fireproof/core","kind":"require-call","external":true},{"path":"idb","kind":"require-call","external":true},{"path":"@adviser/cement","kind":"require-call","external":true},{"path":"@fireproof/core","kind":"require-call","external":true}],"exports":[],"entryPoint":"src/runtime/gateways/indexdb/web/index.ts","inputs":{"src/runtime/gateways/indexdb/web/index.ts":{"bytesInOutput":241},"src/runtime/gateways/indexdb/web/key-bag-indexdb.ts":{"bytesInOutput":1142},"src/runtime/gateways/indexdb/web/gateway-impl.ts":{"bytesInOutput":5508},"src/runtime/gateways/indexdb/version.ts":{"bytesInOutput":39}},"bytes":7981}}}
|
package/web/metafile-esm.json
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"inputs":{"src/runtime/gateways/indexdb/version.ts":{"bytes":48,"imports":[],"format":"esm"},"src/runtime/gateways/indexdb/web/gateway-impl.ts":{"bytes":
|
1
|
+
{"inputs":{"src/runtime/gateways/indexdb/web/key-bag-indexdb.ts":{"bytes":1509,"imports":[{"path":"idb","kind":"import-statement","external":true},{"path":"@adviser/cement","kind":"import-statement","external":true},{"path":"@fireproof/core","kind":"import-statement","external":true}],"format":"esm"},"src/runtime/gateways/indexdb/version.ts":{"bytes":48,"imports":[],"format":"esm"},"src/runtime/gateways/indexdb/web/gateway-impl.ts":{"bytes":6161,"imports":[{"path":"idb","kind":"import-statement","external":true},{"path":"@adviser/cement","kind":"import-statement","external":true},{"path":"src/runtime/gateways/indexdb/version.ts","kind":"import-statement","original":"../version.js"},{"path":"@fireproof/core","kind":"import-statement","external":true}],"format":"esm"},"src/runtime/gateways/indexdb/web/index.ts":{"bytes":285,"imports":[{"path":"src/runtime/gateways/indexdb/web/key-bag-indexdb.ts","kind":"import-statement","original":"./key-bag-indexdb.js"},{"path":"src/runtime/gateways/indexdb/web/key-bag-indexdb.ts","kind":"import-statement","original":"./key-bag-indexdb.js"},{"path":"src/runtime/gateways/indexdb/web/gateway-impl.ts","kind":"import-statement","original":"./gateway-impl.js"}],"format":"esm"}},"outputs":{"dist/fireproof-core/web/index.js.map":{"imports":[],"exports":[],"inputs":{},"bytes":13642},"dist/fireproof-core/web/index.js":{"imports":[{"path":"idb","kind":"import-statement","external":true},{"path":"@adviser/cement","kind":"import-statement","external":true},{"path":"@fireproof/core","kind":"import-statement","external":true},{"path":"idb","kind":"import-statement","external":true},{"path":"@adviser/cement","kind":"import-statement","external":true},{"path":"@fireproof/core","kind":"import-statement","external":true}],"exports":["GatewayImpl","KeyBagProviderImpl","KeyBagProviderIndexDB"],"entryPoint":"src/runtime/gateways/indexdb/web/index.ts","inputs":{"src/runtime/gateways/indexdb/web/key-bag-indexdb.ts":{"bytesInOutput":1088},"src/runtime/gateways/indexdb/web/index.ts":{"bytesInOutput":0},"src/runtime/gateways/indexdb/web/gateway-impl.ts":{"bytesInOutput":5129},"src/runtime/gateways/indexdb/version.ts":{"bytesInOutput":39}},"bytes":6577}}}
|
package/chunk-7EWIAXTM.js
DELETED
package/chunk-7EWIAXTM.js.map
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"sources":["../../src/runtime/gateways/file/version.ts"],"sourcesContent":["export const FILESTORE_VERSION = \"v0.19-file\";\n"],"mappings":";AAAO,IAAM,oBAAoB;","names":[]}
|
package/chunk-F4FC6B2T.js
DELETED
@@ -1,63 +0,0 @@
|
|
1
|
-
import {
|
2
|
-
getStore
|
3
|
-
} from "./chunk-RXC4JGJT.js";
|
4
|
-
|
5
|
-
// src/runtime/gateways/file/get-file-system-static.ts
|
6
|
-
import { KeyedResolvOnce } from "@adviser/cement";
|
7
|
-
var externalLoaders = new KeyedResolvOnce();
|
8
|
-
async function getFileSystem(url) {
|
9
|
-
const name = url.getParam("fs", "node");
|
10
|
-
let fs;
|
11
|
-
switch (name) {
|
12
|
-
case "mem":
|
13
|
-
fs = await externalLoaders.get(name).once(async () => {
|
14
|
-
const { MemFileSystem } = await import("@fireproof/core/mem");
|
15
|
-
return new MemFileSystem();
|
16
|
-
});
|
17
|
-
break;
|
18
|
-
// case 'deno': {
|
19
|
-
// const { DenoFileSystem } = await import("./deno-filesystem.js");
|
20
|
-
// fs = new DenoFileSystem();
|
21
|
-
// break;
|
22
|
-
// }
|
23
|
-
default:
|
24
|
-
fs = await externalLoaders.get(name).once(async () => {
|
25
|
-
const { NodeFileSystem } = await import("@fireproof/core/node");
|
26
|
-
return new NodeFileSystem();
|
27
|
-
});
|
28
|
-
}
|
29
|
-
return fs.start();
|
30
|
-
}
|
31
|
-
|
32
|
-
// src/runtime/gateways/file/utils.ts
|
33
|
-
function getPath(url, sthis) {
|
34
|
-
const basePath = url.pathname;
|
35
|
-
const name = url.getParam("name");
|
36
|
-
if (name) {
|
37
|
-
const version = url.getParam("version");
|
38
|
-
if (!version) throw sthis.logger.Error().Url(url).Msg(`version not found`).AsError();
|
39
|
-
return sthis.pathOps.join(basePath, version, name);
|
40
|
-
}
|
41
|
-
return sthis.pathOps.join(basePath);
|
42
|
-
}
|
43
|
-
function getFileName(url, sthis) {
|
44
|
-
const key = url.getParam("key");
|
45
|
-
if (!key) throw sthis.logger.Error().Url(url).Msg(`key not found`).AsError();
|
46
|
-
const res = getStore(url, sthis, (...a) => a.join("-"));
|
47
|
-
switch (res.store) {
|
48
|
-
case "data":
|
49
|
-
return sthis.pathOps.join(res.name, key + ".car");
|
50
|
-
case "wal":
|
51
|
-
case "meta":
|
52
|
-
return sthis.pathOps.join(res.name, key + ".json");
|
53
|
-
default:
|
54
|
-
throw sthis.logger.Error().Url(url).Msg(`unsupported store type`).AsError();
|
55
|
-
}
|
56
|
-
}
|
57
|
-
|
58
|
-
export {
|
59
|
-
getFileSystem,
|
60
|
-
getPath,
|
61
|
-
getFileName
|
62
|
-
};
|
63
|
-
//# sourceMappingURL=chunk-F4FC6B2T.js.map
|
package/chunk-F4FC6B2T.js.map
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"sources":["../../src/runtime/gateways/file/get-file-system-static.ts","../../src/runtime/gateways/file/utils.ts"],"sourcesContent":["import { KeyedResolvOnce, type URI } from \"@adviser/cement\";\nimport type { SysFileSystem } from \"../../../types.js\";\n\nconst externalLoaders = new KeyedResolvOnce<SysFileSystem>();\nexport async function getFileSystem(url: URI): Promise<SysFileSystem> {\n const name = url.getParam(\"fs\", \"node\");\n let fs: SysFileSystem;\n switch (name) {\n case \"mem\":\n fs = await externalLoaders.get(name).once(async () => {\n const { MemFileSystem } = await import(\"@fireproof/core/mem\");\n return new MemFileSystem();\n });\n break;\n // case 'deno': {\n // const { DenoFileSystem } = await import(\"./deno-filesystem.js\");\n // fs = new DenoFileSystem();\n // break;\n // }\n default:\n fs = await externalLoaders.get(name).once(async () => {\n const { NodeFileSystem } = await import(\"@fireproof/core/node\");\n return new NodeFileSystem();\n });\n }\n return fs.start();\n}\n","import { URI } from \"@adviser/cement\";\nimport { getStore } from \"../../../utils.js\";\nimport { SuperThis } from \"../../../types.js\";\nexport * from \"./get-file-system-static.js\";\n\nexport function getPath(url: URI, sthis: SuperThis): string {\n const basePath = url.pathname;\n // .toString()\n // .replace(new RegExp(`^${url.protocol}//`), \"\")\n // .replace(/\\?.*$/, \"\");\n const name = url.getParam(\"name\");\n if (name) {\n const version = url.getParam(\"version\");\n if (!version) throw sthis.logger.Error().Url(url).Msg(`version not found`).AsError();\n return sthis.pathOps.join(basePath, version, name);\n }\n return sthis.pathOps.join(basePath);\n}\n\nexport function getFileName(url: URI, sthis: SuperThis): string {\n const key = url.getParam(\"key\");\n if (!key) throw sthis.logger.Error().Url(url).Msg(`key not found`).AsError();\n const res = getStore(url, sthis, (...a: string[]) => a.join(\"-\"));\n switch (res.store) {\n case \"data\":\n return sthis.pathOps.join(res.name, key + \".car\");\n case \"wal\":\n case \"meta\":\n return sthis.pathOps.join(res.name, key + \".json\");\n default:\n throw sthis.logger.Error().Url(url).Msg(`unsupported store type`).AsError();\n }\n}\n"],"mappings":";;;;;AAAA,SAAS,uBAAiC;AAG1C,IAAM,kBAAkB,IAAI,gBAA+B;AAC3D,eAAsB,cAAc,KAAkC;AACpE,QAAM,OAAO,IAAI,SAAS,MAAM,MAAM;AACtC,MAAI;AACJ,UAAQ,MAAM;AAAA,IACZ,KAAK;AACH,WAAK,MAAM,gBAAgB,IAAI,IAAI,EAAE,KAAK,YAAY;AACpD,cAAM,EAAE,cAAc,IAAI,MAAM,OAAO,qBAAqB;AAC5D,eAAO,IAAI,cAAc;AAAA,MAC3B,CAAC;AACD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMF;AACE,WAAK,MAAM,gBAAgB,IAAI,IAAI,EAAE,KAAK,YAAY;AACpD,cAAM,EAAE,eAAe,IAAI,MAAM,OAAO,sBAAsB;AAC9D,eAAO,IAAI,eAAe;AAAA,MAC5B,CAAC;AAAA,EACL;AACA,SAAO,GAAG,MAAM;AAClB;;;ACrBO,SAAS,QAAQ,KAAU,OAA0B;AAC1D,QAAM,WAAW,IAAI;AAIrB,QAAM,OAAO,IAAI,SAAS,MAAM;AAChC,MAAI,MAAM;AACR,UAAM,UAAU,IAAI,SAAS,SAAS;AACtC,QAAI,CAAC,QAAS,OAAM,MAAM,OAAO,MAAM,EAAE,IAAI,GAAG,EAAE,IAAI,mBAAmB,EAAE,QAAQ;AACnF,WAAO,MAAM,QAAQ,KAAK,UAAU,SAAS,IAAI;AAAA,EACnD;AACA,SAAO,MAAM,QAAQ,KAAK,QAAQ;AACpC;AAEO,SAAS,YAAY,KAAU,OAA0B;AAC9D,QAAM,MAAM,IAAI,SAAS,KAAK;AAC9B,MAAI,CAAC,IAAK,OAAM,MAAM,OAAO,MAAM,EAAE,IAAI,GAAG,EAAE,IAAI,eAAe,EAAE,QAAQ;AAC3E,QAAM,MAAM,SAAS,KAAK,OAAO,IAAI,MAAgB,EAAE,KAAK,GAAG,CAAC;AAChE,UAAQ,IAAI,OAAO;AAAA,IACjB,KAAK;AACH,aAAO,MAAM,QAAQ,KAAK,IAAI,MAAM,MAAM,MAAM;AAAA,IAClD,KAAK;AAAA,IACL,KAAK;AACH,aAAO,MAAM,QAAQ,KAAK,IAAI,MAAM,MAAM,OAAO;AAAA,IACnD;AACE,YAAM,MAAM,OAAO,MAAM,EAAE,IAAI,GAAG,EAAE,IAAI,wBAAwB,EAAE,QAAQ;AAAA,EAC9E;AACF;","names":[]}
|
package/chunk-PZ5AY32C.js
DELETED
package/chunk-PZ5AY32C.js.map
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
package/chunk-RXC4JGJT.js
DELETED
@@ -1,301 +0,0 @@
|
|
1
|
-
// src/utils.ts
|
2
|
-
import {
|
3
|
-
LoggerImpl,
|
4
|
-
IsLogger,
|
5
|
-
Result,
|
6
|
-
ResolveOnce,
|
7
|
-
isURL,
|
8
|
-
URI,
|
9
|
-
runtimeFn,
|
10
|
-
envFactory,
|
11
|
-
toCryptoRuntime,
|
12
|
-
JSONFormatter,
|
13
|
-
YAMLFormatter
|
14
|
-
} from "@adviser/cement";
|
15
|
-
import { base58btc } from "multiformats/bases/base58";
|
16
|
-
var _globalLogger = new ResolveOnce();
|
17
|
-
function globalLogger() {
|
18
|
-
return _globalLogger.once(() => new LoggerImpl());
|
19
|
-
}
|
20
|
-
var registerFP_DEBUG = new ResolveOnce();
|
21
|
-
var SuperThisImpl = class _SuperThisImpl {
|
22
|
-
constructor(opts) {
|
23
|
-
this.logger = opts.logger;
|
24
|
-
this.env = opts.env;
|
25
|
-
this.crypto = opts.crypto;
|
26
|
-
this.pathOps = opts.pathOps;
|
27
|
-
this.txt = opts.txt;
|
28
|
-
this.ctx = { ...opts.ctx };
|
29
|
-
}
|
30
|
-
nextId(bytes = 6) {
|
31
|
-
const bin = this.crypto.randomBytes(bytes);
|
32
|
-
return {
|
33
|
-
str: base58btc.encode(bin),
|
34
|
-
bin
|
35
|
-
};
|
36
|
-
}
|
37
|
-
timeOrderedNextId(now) {
|
38
|
-
now = typeof now === "number" ? now : (/* @__PURE__ */ new Date()).getTime();
|
39
|
-
const t = (281474976710656 + now).toString(16).replace(/^1/, "");
|
40
|
-
const bin = this.crypto.randomBytes(10);
|
41
|
-
bin[1] = bin[1] & 240 | (bin[1] | 8 && 11);
|
42
|
-
const hex = Array.from(bin).map((i) => i.toString(16).padStart(2, "0")).join("");
|
43
|
-
return {
|
44
|
-
str: `${t.slice(0, 8)}-${t.slice(8)}-7${hex.slice(0, 3)}-${hex.slice(3, 7)}-${hex.slice(7, 19)}`
|
45
|
-
};
|
46
|
-
}
|
47
|
-
start() {
|
48
|
-
return Promise.resolve();
|
49
|
-
}
|
50
|
-
clone(override) {
|
51
|
-
return new _SuperThisImpl({
|
52
|
-
logger: override.logger || this.logger,
|
53
|
-
env: envFactory(override.env) || this.env,
|
54
|
-
crypto: override.crypto || this.crypto,
|
55
|
-
pathOps: override.pathOps || this.pathOps,
|
56
|
-
txt: override.txt || this.txt,
|
57
|
-
ctx: { ...this.ctx, ...override.ctx }
|
58
|
-
});
|
59
|
-
}
|
60
|
-
};
|
61
|
-
function presetEnv() {
|
62
|
-
const penv = new Map([
|
63
|
-
// ["FP_DEBUG", "xxx"],
|
64
|
-
// ["FP_ENV", "development"],
|
65
|
-
...Array.from(
|
66
|
-
Object.entries(
|
67
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
68
|
-
globalThis[Symbol.for("FP_PRESET_ENV")] || {}
|
69
|
-
)
|
70
|
-
)
|
71
|
-
// .map(([k, v]) => [k, v as string])
|
72
|
-
]);
|
73
|
-
return penv;
|
74
|
-
}
|
75
|
-
var pathOpsImpl = class {
|
76
|
-
join(...paths) {
|
77
|
-
return paths.map((i) => i.replace(/\/+$/, "")).join("/");
|
78
|
-
}
|
79
|
-
dirname(path) {
|
80
|
-
return path.split("/").slice(0, -1).join("/");
|
81
|
-
}
|
82
|
-
// homedir() {
|
83
|
-
// throw new Error("SysContainer:homedir is not available in seeded state");
|
84
|
-
// }
|
85
|
-
};
|
86
|
-
var pathOps = new pathOpsImpl();
|
87
|
-
var txtOps = {
|
88
|
-
// eslint-disable-next-line no-restricted-globals
|
89
|
-
encode: (input) => new TextEncoder().encode(input),
|
90
|
-
// eslint-disable-next-line no-restricted-globals
|
91
|
-
decode: (input) => new TextDecoder().decode(input)
|
92
|
-
};
|
93
|
-
var _onSuperThis = /* @__PURE__ */ new Map();
|
94
|
-
function onSuperThis(fn) {
|
95
|
-
const key = `onSuperThis-${Math.random().toString(36).slice(2)}`;
|
96
|
-
_onSuperThis.set(key, fn);
|
97
|
-
return () => {
|
98
|
-
_onSuperThis.delete(key);
|
99
|
-
};
|
100
|
-
}
|
101
|
-
function ensureSuperThis(osthis) {
|
102
|
-
const env = envFactory({
|
103
|
-
symbol: osthis?.env?.symbol || "FP_ENV",
|
104
|
-
presetEnv: osthis?.env?.presetEnv || presetEnv()
|
105
|
-
});
|
106
|
-
const ret = new SuperThisImpl({
|
107
|
-
logger: osthis?.logger || globalLogger(),
|
108
|
-
env,
|
109
|
-
crypto: osthis?.crypto || toCryptoRuntime(),
|
110
|
-
ctx: osthis?.ctx || {},
|
111
|
-
pathOps,
|
112
|
-
txt: osthis?.txt || txtOps
|
113
|
-
});
|
114
|
-
_onSuperThis.forEach((fn) => fn(ret));
|
115
|
-
return ret;
|
116
|
-
}
|
117
|
-
function ensureSuperLog(sthis, componentName, ctx) {
|
118
|
-
return sthis.clone({
|
119
|
-
logger: ensureLogger(sthis, componentName, ctx)
|
120
|
-
});
|
121
|
-
}
|
122
|
-
function ensureLogger(sthis, componentName, ctx) {
|
123
|
-
let logger;
|
124
|
-
if (IsLogger(sthis)) {
|
125
|
-
logger = sthis;
|
126
|
-
} else if (sthis && IsLogger(sthis.logger)) {
|
127
|
-
logger = sthis.logger;
|
128
|
-
} else {
|
129
|
-
logger = globalLogger();
|
130
|
-
}
|
131
|
-
const cLogger = logger.With().Module(componentName);
|
132
|
-
const debug = [];
|
133
|
-
let exposeStack = false;
|
134
|
-
if (ctx) {
|
135
|
-
if ("debug" in ctx) {
|
136
|
-
if (typeof ctx.debug === "string" && ctx.debug.length > 0) {
|
137
|
-
debug.push(ctx.debug);
|
138
|
-
} else {
|
139
|
-
debug.push(componentName);
|
140
|
-
}
|
141
|
-
delete ctx.debug;
|
142
|
-
}
|
143
|
-
if ("exposeStack" in ctx) {
|
144
|
-
exposeStack = true;
|
145
|
-
delete ctx.exposeStack;
|
146
|
-
}
|
147
|
-
if ("this" in ctx) {
|
148
|
-
cLogger.Str("this", sthis.nextId(4).str);
|
149
|
-
delete ctx.this;
|
150
|
-
}
|
151
|
-
for (const [key, value] of Object.entries(ctx)) {
|
152
|
-
switch (typeof value) {
|
153
|
-
case "string":
|
154
|
-
cLogger.Str(key, value);
|
155
|
-
break;
|
156
|
-
case "number":
|
157
|
-
cLogger.Uint64(key, value);
|
158
|
-
break;
|
159
|
-
default:
|
160
|
-
if (value instanceof Date) {
|
161
|
-
cLogger.Str(key, value.toISOString());
|
162
|
-
} else if (isURL(value)) {
|
163
|
-
cLogger.Str(key, value.toString());
|
164
|
-
} else if (typeof value === "function") {
|
165
|
-
cLogger.Ref(key, value);
|
166
|
-
} else {
|
167
|
-
cLogger.Any(key, value);
|
168
|
-
}
|
169
|
-
break;
|
170
|
-
}
|
171
|
-
}
|
172
|
-
}
|
173
|
-
registerFP_DEBUG.once(async () => {
|
174
|
-
sthis.env.onSet(
|
175
|
-
(key, value) => {
|
176
|
-
switch (key) {
|
177
|
-
case "FP_FORMAT": {
|
178
|
-
switch (value) {
|
179
|
-
case "jsonice":
|
180
|
-
logger.SetFormatter(new JSONFormatter(logger.TxtEnDe(), 2));
|
181
|
-
break;
|
182
|
-
case "yaml":
|
183
|
-
logger.SetFormatter(new YAMLFormatter(logger.TxtEnDe(), 2));
|
184
|
-
break;
|
185
|
-
case "json":
|
186
|
-
default:
|
187
|
-
logger.SetFormatter(new JSONFormatter(logger.TxtEnDe()));
|
188
|
-
break;
|
189
|
-
}
|
190
|
-
break;
|
191
|
-
}
|
192
|
-
case "FP_DEBUG":
|
193
|
-
logger.SetDebug(value || []);
|
194
|
-
break;
|
195
|
-
case "FP_STACK":
|
196
|
-
logger.SetExposeStack(!!value);
|
197
|
-
break;
|
198
|
-
}
|
199
|
-
},
|
200
|
-
"FP_FORMAT",
|
201
|
-
"FP_DEBUG",
|
202
|
-
"FP_STACK"
|
203
|
-
);
|
204
|
-
}).finally(() => {
|
205
|
-
});
|
206
|
-
if (debug.length > 0) {
|
207
|
-
logger.SetDebug(debug);
|
208
|
-
}
|
209
|
-
if (exposeStack) {
|
210
|
-
logger.SetExposeStack(true);
|
211
|
-
}
|
212
|
-
const out = cLogger.Logger();
|
213
|
-
return out;
|
214
|
-
}
|
215
|
-
function getStore(url, sthis, joiner) {
|
216
|
-
const store = url.getParam("store");
|
217
|
-
switch (store) {
|
218
|
-
case "data":
|
219
|
-
case "wal":
|
220
|
-
case "meta":
|
221
|
-
break;
|
222
|
-
default:
|
223
|
-
throw sthis.logger.Error().Url(url).Msg(`store not found`).AsError();
|
224
|
-
}
|
225
|
-
let name = store;
|
226
|
-
if (url.hasParam("index")) {
|
227
|
-
name = joiner(url.getParam("index") || "idx", name);
|
228
|
-
}
|
229
|
-
return { store, name };
|
230
|
-
}
|
231
|
-
function getKey(url, logger) {
|
232
|
-
const result = url.getParam("key");
|
233
|
-
if (!result) throw logger.Error().Str("url", url.toString()).Msg(`key not found`).AsError();
|
234
|
-
return result;
|
235
|
-
}
|
236
|
-
function getName(sthis, url) {
|
237
|
-
let result = url.getParam("name");
|
238
|
-
if (!result) {
|
239
|
-
result = sthis.pathOps.dirname(url.pathname);
|
240
|
-
if (result.length === 0) {
|
241
|
-
throw sthis.logger.Error().Str("url", url.toString()).Msg(`name not found`).AsError();
|
242
|
-
}
|
243
|
-
}
|
244
|
-
return result;
|
245
|
-
}
|
246
|
-
async function exceptionWrapper(fn) {
|
247
|
-
return fn().catch((e) => Result.Err(e));
|
248
|
-
}
|
249
|
-
var NotFoundError = class extends Error {
|
250
|
-
constructor() {
|
251
|
-
super(...arguments);
|
252
|
-
this.code = "ENOENT";
|
253
|
-
}
|
254
|
-
};
|
255
|
-
function isNotFoundError(e) {
|
256
|
-
if (Result.Is(e)) {
|
257
|
-
if (e.isOk()) return false;
|
258
|
-
e = e.Err();
|
259
|
-
}
|
260
|
-
if (e.code === "ENOENT") return true;
|
261
|
-
return false;
|
262
|
-
}
|
263
|
-
function dataDir(sthis, name, base) {
|
264
|
-
if (!base) {
|
265
|
-
if (!runtimeFn().isBrowser) {
|
266
|
-
const home = sthis.env.get("HOME") || "./";
|
267
|
-
base = sthis.env.get("FP_STORAGE_URL") || `file://${sthis.pathOps.join(home, ".fireproof")}`;
|
268
|
-
} else {
|
269
|
-
base = sthis.env.get("FP_STORAGE_URL") || `indexdb://fp`;
|
270
|
-
}
|
271
|
-
}
|
272
|
-
return URI.from(base.toString()).build().setParam("name", name || "").URI();
|
273
|
-
}
|
274
|
-
function UInt8ArrayEqual(a, b) {
|
275
|
-
if (a.length !== b.length) {
|
276
|
-
return false;
|
277
|
-
}
|
278
|
-
for (let i = 0; i < a.length; i++) {
|
279
|
-
if (a[i] !== b[i]) {
|
280
|
-
return false;
|
281
|
-
}
|
282
|
-
}
|
283
|
-
return true;
|
284
|
-
}
|
285
|
-
|
286
|
-
export {
|
287
|
-
Result,
|
288
|
-
onSuperThis,
|
289
|
-
ensureSuperThis,
|
290
|
-
ensureSuperLog,
|
291
|
-
ensureLogger,
|
292
|
-
getStore,
|
293
|
-
getKey,
|
294
|
-
getName,
|
295
|
-
exceptionWrapper,
|
296
|
-
NotFoundError,
|
297
|
-
isNotFoundError,
|
298
|
-
dataDir,
|
299
|
-
UInt8ArrayEqual
|
300
|
-
};
|
301
|
-
//# sourceMappingURL=chunk-RXC4JGJT.js.map
|