@fireproof/core 0.19.121 → 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 +2 -3
- package/index.cjs +1827 -1059
- package/index.cjs.map +1 -1
- package/index.d.cts +747 -334
- package/index.d.ts +747 -334
- package/index.js +1800 -1034
- package/index.js.map +1 -1
- package/metafile-cjs.json +1 -1
- package/metafile-esm.json +1 -1
- package/node/index.cjs +16 -293
- package/node/index.cjs.map +1 -1
- package/node/index.d.cts +4 -40
- package/node/index.d.ts +4 -40
- package/node/index.js +22 -237
- package/node/index.js.map +1 -1
- package/node/metafile-cjs.json +1 -1
- package/node/metafile-esm.json +1 -1
- package/package.json +14 -6
- 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 +73 -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 +102 -116
- package/web/index.cjs.map +1 -1
- package/web/index.d.cts +15 -29
- package/web/index.d.ts +15 -29
- package/web/index.js +91 -105
- package/web/index.js.map +1 -1
- package/web/metafile-cjs.json +1 -1
- package/web/metafile-esm.json +1 -1
- package/node/chunk-4A4RAVNS.js +0 -17
- package/node/chunk-4A4RAVNS.js.map +0 -1
- package/node/mem-filesystem-LPPT7QV5.js +0 -40
- package/node/mem-filesystem-LPPT7QV5.js.map +0 -1
- package/tests/fireproof/config.test.ts +0 -163
- /package/tests/blockstore/{fragment-gateway.test.ts → fragment-gateway.test.ts-off} +0 -0
package/web/index.d.ts
CHANGED
@@ -1,32 +1,6 @@
|
|
1
|
-
import { URI, Logger, Result, ResolveOnce } from '@adviser/cement';
|
2
|
-
import { SuperThis, bs, rt } from '@fireproof/core';
|
3
1
|
import { IDBPDatabase } from 'idb';
|
4
|
-
|
5
|
-
|
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
|
-
}
|
2
|
+
import { ResolveOnce, URI, Logger, Result } from '@adviser/cement';
|
3
|
+
import { rt, SuperThis, bs } from '@fireproof/core';
|
30
4
|
|
31
5
|
declare class KeyBagProviderIndexDB implements rt.kb.KeyBagProvider {
|
32
6
|
readonly _db: ResolveOnce<IDBPDatabase<unknown>>;
|
@@ -40,5 +14,17 @@ declare class KeyBagProviderIndexDB implements rt.kb.KeyBagProvider {
|
|
40
14
|
set(id: string, item: rt.kb.KeyItem): Promise<void>;
|
41
15
|
}
|
42
16
|
|
43
|
-
|
17
|
+
declare class IndexDBGateway implements bs.Gateway {
|
18
|
+
_db: IDBPDatabase<unknown>;
|
19
|
+
start(baseURL: URI, sthis: SuperThis): Promise<Result<URI>>;
|
20
|
+
close(): Promise<Result<void>>;
|
21
|
+
destroy(baseUrl: URI, sthis: SuperThis): Promise<Result<void>>;
|
22
|
+
buildUrl(baseUrl: URI, key: string): Promise<Result<URI>>;
|
23
|
+
get(url: URI, sthis: SuperThis): Promise<bs.GetResult>;
|
24
|
+
put(url: URI, bytes: Uint8Array, sthis: SuperThis): Promise<Result<void>>;
|
25
|
+
delete(url: URI, sthis: SuperThis): Promise<Result<Result<undefined, Error>, Error>>;
|
26
|
+
getPlain(url: URI, key: string, sthis: SuperThis): Promise<Result<Uint8Array>>;
|
27
|
+
}
|
28
|
+
|
29
|
+
export { IndexDBGateway as GatewayImpl, KeyBagProviderIndexDB as KeyBagProviderImpl, KeyBagProviderIndexDB };
|
44
30
|
declare module '@fireproof/core/web'
|
package/web/index.js
CHANGED
@@ -1,26 +1,69 @@
|
|
1
|
-
// src/runtime/gateways/indexdb/web/
|
1
|
+
// src/runtime/gateways/indexdb/web/key-bag-indexdb.ts
|
2
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";
|
3
46
|
import { exception2Result, KeyedResolvOnce, Result } from "@adviser/cement";
|
4
47
|
|
5
48
|
// src/runtime/gateways/indexdb/version.ts
|
6
49
|
var INDEXDB_VERSION = "v0.19-indexdb";
|
7
50
|
|
8
51
|
// src/runtime/gateways/indexdb/web/gateway-impl.ts
|
9
|
-
import {
|
52
|
+
import { NotFoundError, PARAM, exceptionWrapper, getKey, getStore } from "@fireproof/core";
|
10
53
|
function ensureVersion(url) {
|
11
|
-
return url.build().defParam(
|
54
|
+
return url.build().defParam(PARAM.VERSION, INDEXDB_VERSION).URI();
|
12
55
|
}
|
56
|
+
var onceIndexDB = new KeyedResolvOnce();
|
13
57
|
function sanitzeKey(key) {
|
14
58
|
if (key.length === 1) {
|
15
59
|
key = key[0];
|
16
60
|
}
|
17
61
|
return key;
|
18
62
|
}
|
19
|
-
var onceConn = new KeyedResolvOnce();
|
20
63
|
async function connectIdb(url, sthis) {
|
21
64
|
const dbName = getIndexDBName(url, sthis);
|
22
|
-
const once = await
|
23
|
-
const db = await
|
65
|
+
const once = await onceIndexDB.get(dbName.fullDb).once(async () => {
|
66
|
+
const db = await openDB2(dbName.fullDb, 1, {
|
24
67
|
upgrade(db2) {
|
25
68
|
["version", "data", "wal", "meta", "idx.data", "idx.wal", "idx.meta"].map((store) => {
|
26
69
|
db2.createObjectStore(store, {
|
@@ -30,17 +73,17 @@ async function connectIdb(url, sthis) {
|
|
30
73
|
}
|
31
74
|
});
|
32
75
|
const found = await db.get("version", "version");
|
33
|
-
const version = ensureVersion(url).getParam(
|
76
|
+
const version = ensureVersion(url).getParam(PARAM.VERSION);
|
34
77
|
if (!found) {
|
35
78
|
await db.put("version", { version }, "version");
|
36
79
|
} else if (found.version !== version) {
|
37
|
-
sthis.logger.Warn().
|
80
|
+
sthis.logger.Warn().Url(url).Str("version", version).Str("found", found.version).Msg("version mismatch");
|
38
81
|
}
|
39
82
|
return { db, dbName, version, url };
|
40
83
|
});
|
41
84
|
return {
|
42
85
|
...once,
|
43
|
-
url: url.build().setParam(
|
86
|
+
url: url.build().setParam(PARAM.VERSION, once.version).URI()
|
44
87
|
};
|
45
88
|
}
|
46
89
|
function joinDBName(...names) {
|
@@ -49,7 +92,7 @@ function joinDBName(...names) {
|
|
49
92
|
function getIndexDBName(iurl, sthis) {
|
50
93
|
const url = ensureVersion(iurl);
|
51
94
|
const fullDb = url.pathname.replace(/^\/+/, "").replace(/\?.*$/, "");
|
52
|
-
const dbName = url.getParam(
|
95
|
+
const dbName = url.getParam(PARAM.NAME);
|
53
96
|
if (!dbName) throw sthis.logger.Error().Str("url", url.toString()).Msg(`name not found`).AsError();
|
54
97
|
const result = joinDBName(fullDb, dbName);
|
55
98
|
const objStore = getStore(url, sthis, joinDBName).name;
|
@@ -62,28 +105,27 @@ function getIndexDBName(iurl, sthis) {
|
|
62
105
|
};
|
63
106
|
}
|
64
107
|
var IndexDBGateway = class {
|
65
|
-
constructor(
|
66
|
-
this.
|
67
|
-
this.sthis = sthis;
|
108
|
+
constructor() {
|
109
|
+
this._db = {};
|
68
110
|
}
|
69
|
-
|
70
|
-
async start(baseURL) {
|
111
|
+
async start(baseURL, sthis) {
|
71
112
|
return exception2Result(async () => {
|
72
|
-
|
73
|
-
|
74
|
-
const ic = await connectIdb(baseURL,
|
75
|
-
this.
|
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");
|
76
118
|
return ic.url;
|
77
119
|
});
|
78
120
|
}
|
79
121
|
async close() {
|
80
122
|
return Result.Ok(void 0);
|
81
123
|
}
|
82
|
-
async destroy(baseUrl) {
|
124
|
+
async destroy(baseUrl, sthis) {
|
83
125
|
return exception2Result(async () => {
|
84
|
-
const type = getStore(baseUrl,
|
85
|
-
const idb =
|
86
|
-
const trans = idb.
|
126
|
+
const type = getStore(baseUrl, sthis, joinDBName).name;
|
127
|
+
const idb = this._db;
|
128
|
+
const trans = idb.transaction(type, "readwrite");
|
87
129
|
const object_store = trans.objectStore(type);
|
88
130
|
const toDelete = [];
|
89
131
|
for (let cursor = await object_store.openCursor(); cursor; cursor = await cursor.continue()) {
|
@@ -96,114 +138,58 @@ var IndexDBGateway = class {
|
|
96
138
|
});
|
97
139
|
}
|
98
140
|
buildUrl(baseUrl, key) {
|
99
|
-
return Promise.resolve(Result.Ok(baseUrl.build().setParam(
|
141
|
+
return Promise.resolve(Result.Ok(baseUrl.build().setParam(PARAM.KEY, key).URI()));
|
100
142
|
}
|
101
|
-
async get(url) {
|
143
|
+
async get(url, sthis) {
|
102
144
|
return exceptionWrapper(async () => {
|
103
|
-
const key = getKey(url,
|
104
|
-
const store = getStore(url,
|
105
|
-
|
106
|
-
const
|
107
|
-
const tx = db.transaction([store], "readonly");
|
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");
|
108
149
|
const bytes = await tx.objectStore(store).get(sanitzeKey(key));
|
109
150
|
await tx.done;
|
110
151
|
if (!bytes) {
|
111
152
|
return Result.Err(new NotFoundError(`missing ${key}`));
|
112
153
|
}
|
113
|
-
return Result.Ok(bytes);
|
154
|
+
return Promise.resolve(Result.Ok(bytes));
|
114
155
|
});
|
115
156
|
}
|
116
|
-
async put(url,
|
157
|
+
async put(url, bytes, sthis) {
|
117
158
|
return exception2Result(async () => {
|
118
|
-
const key = getKey(url,
|
119
|
-
const store = getStore(url,
|
120
|
-
|
121
|
-
const
|
122
|
-
|
123
|
-
await tx.objectStore(store).put(value, sanitzeKey(key));
|
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));
|
124
164
|
await tx.done;
|
125
165
|
});
|
126
166
|
}
|
127
|
-
async delete(url) {
|
167
|
+
async delete(url, sthis) {
|
128
168
|
return exception2Result(async () => {
|
129
|
-
const key = getKey(url,
|
130
|
-
const store = getStore(url,
|
131
|
-
|
132
|
-
const
|
133
|
-
const tx = db.transaction([store], "readwrite");
|
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");
|
134
173
|
await tx.objectStore(store).delete(sanitzeKey(key));
|
135
174
|
await tx.done;
|
136
175
|
return Result.Ok(void 0);
|
137
176
|
});
|
138
177
|
}
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
this.logger = ensureLogger(sthis, "IndexDBTestStore", {});
|
144
|
-
}
|
145
|
-
async get(url, key) {
|
146
|
-
const ic = await connectIdb(url, this.sthis);
|
147
|
-
const store = getStore(ic.url, this.sthis, joinDBName).name;
|
148
|
-
this.logger.Debug().Str("key", key).Str("store", store).Msg("getting");
|
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");
|
149
182
|
let bytes = await ic.db.get(store, sanitzeKey(key));
|
150
|
-
|
183
|
+
sthis.logger.Debug().Str("key", key).Str("store", store).Int("len", bytes.length).Msg("got");
|
151
184
|
if (typeof bytes === "string") {
|
152
|
-
bytes =
|
185
|
+
bytes = sthis.txt.encode(bytes);
|
153
186
|
}
|
154
|
-
return bytes;
|
155
|
-
}
|
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;
|
187
|
+
return Result.Ok(bytes);
|
198
188
|
}
|
199
189
|
};
|
200
190
|
export {
|
201
191
|
IndexDBGateway as GatewayImpl,
|
202
|
-
IndexDBTestGateway as GatewayTestImpl,
|
203
|
-
IndexDBGateway,
|
204
|
-
IndexDBTestGateway,
|
205
192
|
KeyBagProviderIndexDB as KeyBagProviderImpl,
|
206
|
-
KeyBagProviderIndexDB
|
207
|
-
getIndexDBName
|
193
|
+
KeyBagProviderIndexDB
|
208
194
|
};
|
209
195
|
//# sourceMappingURL=index.js.map
|
package/web/index.js.map
CHANGED
@@ -1 +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"]}
|
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/
|
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/
|
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/node/chunk-4A4RAVNS.js
DELETED
@@ -1,17 +0,0 @@
|
|
1
|
-
// src/runtime/gateways/file/node/to-array-buffer.ts
|
2
|
-
function toArrayBuffer(buffer) {
|
3
|
-
if (typeof buffer === "string") {
|
4
|
-
buffer = Buffer.from(buffer);
|
5
|
-
}
|
6
|
-
const ab = new ArrayBuffer(buffer.length);
|
7
|
-
const view = new Uint8Array(ab);
|
8
|
-
for (let i = 0; i < buffer.length; ++i) {
|
9
|
-
view[i] = buffer[i];
|
10
|
-
}
|
11
|
-
return view;
|
12
|
-
}
|
13
|
-
|
14
|
-
export {
|
15
|
-
toArrayBuffer
|
16
|
-
};
|
17
|
-
//# sourceMappingURL=chunk-4A4RAVNS.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"sources":["../../../src/runtime/gateways/file/node/to-array-buffer.ts"],"sourcesContent":["export function toArrayBuffer(buffer: Buffer | string): Uint8Array {\n if (typeof buffer === \"string\") {\n buffer = Buffer.from(buffer);\n }\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"],"mappings":";AAAO,SAAS,cAAc,QAAqC;AACjE,MAAI,OAAO,WAAW,UAAU;AAC9B,aAAS,OAAO,KAAK,MAAM;AAAA,EAC7B;AACA,QAAM,KAAK,IAAI,YAAY,OAAO,MAAM;AACxC,QAAM,OAAO,IAAI,WAAW,EAAE;AAC9B,WAAS,IAAI,GAAG,IAAI,OAAO,QAAQ,EAAE,GAAG;AACtC,SAAK,CAAC,IAAI,OAAO,CAAC;AAAA,EACpB;AACA,SAAO;AACT;","names":[]}
|
@@ -1,40 +0,0 @@
|
|
1
|
-
import {
|
2
|
-
toArrayBuffer
|
3
|
-
} from "./chunk-4A4RAVNS.js";
|
4
|
-
|
5
|
-
// src/runtime/gateways/file/node/mem-filesystem.ts
|
6
|
-
import { fs } from "memfs";
|
7
|
-
var MemFileSystem = class {
|
8
|
-
async start() {
|
9
|
-
return this;
|
10
|
-
}
|
11
|
-
mkdir(path, options) {
|
12
|
-
return fs.promises.mkdir(path, options);
|
13
|
-
}
|
14
|
-
readdir(path, options) {
|
15
|
-
return fs.promises.readdir(path, options);
|
16
|
-
}
|
17
|
-
rm(path, options) {
|
18
|
-
return fs.promises.rm(path, options);
|
19
|
-
}
|
20
|
-
copyFile(source, destination) {
|
21
|
-
return fs.promises.copyFile(source, destination);
|
22
|
-
}
|
23
|
-
async readfile(path, options) {
|
24
|
-
const ret = await fs.promises.readFile(path, options);
|
25
|
-
return toArrayBuffer(ret);
|
26
|
-
}
|
27
|
-
stat(path) {
|
28
|
-
return fs.promises.stat(path);
|
29
|
-
}
|
30
|
-
unlink(path) {
|
31
|
-
return fs.promises.unlink(path);
|
32
|
-
}
|
33
|
-
writefile(path, data) {
|
34
|
-
return fs.promises.writeFile(path, Buffer.from(data));
|
35
|
-
}
|
36
|
-
};
|
37
|
-
export {
|
38
|
-
MemFileSystem
|
39
|
-
};
|
40
|
-
//# sourceMappingURL=mem-filesystem-LPPT7QV5.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"sources":["../../../src/runtime/gateways/file/node/mem-filesystem.ts"],"sourcesContent":["import type { PathLike, MakeDirectoryOptions, Stats } from \"fs\";\nimport { fs } from \"memfs\";\nimport { IReaddirOptions } from \"memfs/lib/node/types/options.js\";\nimport { toArrayBuffer } from \"./to-array-buffer.js\";\nimport type { SysFileSystem } from \"@fireproof/core\";\n\nexport class MemFileSystem implements SysFileSystem {\n async start(): Promise<SysFileSystem> {\n return this;\n }\n mkdir(path: PathLike, options?: { recursive: boolean }): Promise<string | undefined> {\n return fs.promises.mkdir(path, options);\n }\n readdir(path: PathLike, options?: IReaddirOptions): Promise<string[]> {\n return fs.promises.readdir(path, options) as Promise<string[]>;\n }\n rm(path: PathLike, options?: MakeDirectoryOptions & { recursive: boolean }): Promise<void> {\n return fs.promises.rm(path, options);\n }\n copyFile(source: PathLike, destination: PathLike): Promise<void> {\n return fs.promises.copyFile(source, destination);\n }\n async readfile(path: PathLike, options?: { encoding: BufferEncoding; flag?: string }): Promise<Uint8Array> {\n const ret = await fs.promises.readFile(path, options);\n return toArrayBuffer(ret);\n }\n stat(path: PathLike): Promise<Stats> {\n return fs.promises.stat(path) as Promise<Stats>;\n }\n unlink(path: PathLike): Promise<void> {\n return fs.promises.unlink(path);\n }\n writefile(path: PathLike, data: Uint8Array | string): Promise<void> {\n return fs.promises.writeFile(path, Buffer.from(data));\n }\n}\n"],"mappings":";;;;;AACA,SAAS,UAAU;AAKZ,IAAM,gBAAN,MAA6C;AAAA,EAClD,MAAM,QAAgC;AACpC,WAAO;AAAA,EACT;AAAA,EACA,MAAM,MAAgB,SAA+D;AACnF,WAAO,GAAG,SAAS,MAAM,MAAM,OAAO;AAAA,EACxC;AAAA,EACA,QAAQ,MAAgB,SAA8C;AACpE,WAAO,GAAG,SAAS,QAAQ,MAAM,OAAO;AAAA,EAC1C;AAAA,EACA,GAAG,MAAgB,SAAwE;AACzF,WAAO,GAAG,SAAS,GAAG,MAAM,OAAO;AAAA,EACrC;AAAA,EACA,SAAS,QAAkB,aAAsC;AAC/D,WAAO,GAAG,SAAS,SAAS,QAAQ,WAAW;AAAA,EACjD;AAAA,EACA,MAAM,SAAS,MAAgB,SAA4E;AACzG,UAAM,MAAM,MAAM,GAAG,SAAS,SAAS,MAAM,OAAO;AACpD,WAAO,cAAc,GAAG;AAAA,EAC1B;AAAA,EACA,KAAK,MAAgC;AACnC,WAAO,GAAG,SAAS,KAAK,IAAI;AAAA,EAC9B;AAAA,EACA,OAAO,MAA+B;AACpC,WAAO,GAAG,SAAS,OAAO,IAAI;AAAA,EAChC;AAAA,EACA,UAAU,MAAgB,MAA0C;AAClE,WAAO,GAAG,SAAS,UAAU,MAAM,OAAO,KAAK,IAAI,CAAC;AAAA,EACtD;AACF;","names":[]}
|