@fireproof/core 0.20.0-dev-preview-05 → 0.20.0-dev-preview-10

Sign up to get free protection for your applications and to get access to all the features.
package/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/ledger.ts","../../src/utils.ts","../../src/types.ts","../../src/write-queue.ts","../../src/crdt.ts","../../src/blockstore/index.ts","../../src/blockstore/types.ts","../../src/blockstore/store-factory.ts","../../src/runtime/files.ts","../../src/blockstore/store.ts","../../src/blockstore/loader.ts","../../src/runtime/wait-pr-multiformats/block.ts","../../src/blockstore/loader-helpers.ts","../../src/blockstore/transaction.ts","../../src/blockstore/commit-queue.ts","../../src/runtime/key-bag.ts","../../src/runtime/gateways/file/sys-file-system-factory.ts","../../src/runtime/gateways/file/key-bag-file.ts","../../src/runtime/key-bag-memory.ts","../../src/blockstore/commitor.ts","../../src/blockstore/task-manager.ts","../../src/runtime/keyed-crypto.ts","../../src/blockstore/fp-envelope.ts","../../src/blockstore/interceptor-gateway.ts","../../src/blockstore/register-store-protocol.ts","../../src/runtime/gateways/file/version.ts","../../src/runtime/gateways/memory/gateway.ts","../../src/runtime/gateways/memory/version.ts","../../src/runtime/index.ts","../../src/runtime/gateways/file/utils.ts","../../src/runtime/wait-pr-multiformats/index.ts","../../src/runtime/wait-pr-multiformats/codec-interface.ts","../../src/runtime/gateways/index.ts","../../src/runtime/gateways/fp-envelope-serialize.ts","../../src/runtime/gateways/file/index.ts","../../src/runtime/gateways/indexdb/version.ts","../../src/runtime/gateways/file/gateway-impl.ts","../../src/runtime/gateways/def-serde-gateway.ts","../../src/blockstore/store-remote.ts","../../src/blockstore/connection-base.ts","../../src/crdt-helpers.ts","../../src/indexer-helpers.ts","../../src/indexer.ts","../../src/crdt-clock.ts","../../src/apply-head-queue.ts","../../src/version.ts"],"sourcesContent":["import { BuildURI, CoerceURI, KeyedResolvOnce, Logger, ResolveOnce, URI } from \"@adviser/cement\";\n\nimport { defaultWriteQueueOpts, WriteQueue, writeQueue, WriteQueueParams } from \"./write-queue.js\";\nimport { CRDT, HasCRDT } from \"./crdt.js\";\nimport { index } from \"./indexer.js\";\nimport {\n type DocUpdate,\n type ClockHead,\n type ConfigOpts,\n type MapFn,\n type QueryOpts,\n type ChangesOptions,\n type DocSet,\n type DocWithId,\n type IndexKeyType,\n type ListenerFn,\n type DocResponse,\n type BulkResponse,\n type ChangesResponse,\n type DocTypes,\n type IndexRows,\n type DocFragment,\n type ChangesResponseRow,\n type CRDTMeta,\n type AllDocsQueryOpts,\n type AllDocsResponse,\n type SuperThis,\n PARAM,\n} from \"./types.js\";\nimport { DbMeta, SerdeGatewayInterceptor, StoreEnDeFile, StoreURIRuntime, StoreUrlsOpts } from \"./blockstore/index.js\";\nimport { ensureLogger, ensureSuperThis, NotFoundError, toSortedArray } from \"./utils.js\";\n\nimport { decodeFile, encodeFile } from \"./runtime/files.js\";\nimport { defaultKeyBagOpts, KeyBagRuntime } from \"./runtime/key-bag.js\";\nimport { getDefaultURI } from \"./blockstore/register-store-protocol.js\";\n\nconst ledgers = new KeyedResolvOnce<Ledger>();\n\nexport function keyConfigOpts(sthis: SuperThis, name?: string, opts?: ConfigOpts): string {\n return JSON.stringify(\n toSortedArray({\n name,\n stores: toSortedArray(JSON.parse(JSON.stringify(toStoreURIRuntime(sthis, name, opts?.storeUrls)))),\n }),\n );\n}\n\nexport interface LedgerOpts {\n readonly name?: string;\n // readonly public?: boolean;\n readonly meta?: DbMeta;\n readonly gatewayInterceptor?: SerdeGatewayInterceptor;\n\n readonly writeQueue: WriteQueueParams;\n // readonly factoryUnreg?: () => void;\n // readonly persistIndexes?: boolean;\n // readonly autoCompact?: number;\n readonly storeUrls: StoreURIRuntime;\n readonly storeEnDe: StoreEnDeFile;\n readonly keyBag: KeyBagRuntime;\n // readonly threshold?: number;\n}\n\nexport interface Ledger<DT extends DocTypes = NonNullable<unknown>> extends HasCRDT<DT> {\n // readonly name: string;\n readonly logger: Logger;\n readonly sthis: SuperThis;\n readonly id: string;\n\n readonly name: string;\n\n onClosed(fn: () => void): void;\n\n close(): Promise<void>;\n destroy(): Promise<void>;\n ready(): Promise<void>;\n\n get<T extends DocTypes>(id: string): Promise<DocWithId<T>>;\n put<T extends DocTypes>(doc: DocSet<T>): Promise<DocResponse>;\n bulk<T extends DocTypes>(docs: DocSet<T>[]): Promise<BulkResponse>;\n del(id: string): Promise<DocResponse>;\n changes<T extends DocTypes>(since?: ClockHead, opts?: ChangesOptions): Promise<ChangesResponse<T>>;\n allDocs<T extends DocTypes>(opts?: AllDocsQueryOpts): Promise<AllDocsResponse<T>>;\n allDocuments<T extends DocTypes>(): Promise<{\n rows: {\n key: string;\n value: DocWithId<T>;\n }[];\n clock: ClockHead;\n }>;\n subscribe<T extends DocTypes>(listener: ListenerFn<T>, updates?: boolean): () => void;\n\n query<K extends IndexKeyType, T extends DocTypes, R extends DocFragment = T>(\n field: string | MapFn<T>,\n opts?: QueryOpts<K>,\n ): Promise<IndexRows<K, T, R>>;\n compact(): Promise<void>;\n}\n\nexport function isLedger<T extends DocTypes = NonNullable<unknown>>(db: unknown): db is Ledger<T> {\n return db instanceof LedgerImpl || db instanceof LedgerShell;\n}\n\nexport function LedgerFactory<T extends DocTypes = NonNullable<unknown>>(name: string | undefined, opts?: ConfigOpts): Ledger<T> {\n const sthis = ensureSuperThis(opts);\n return new LedgerShell<T>(\n ledgers.get(keyConfigOpts(sthis, name, opts)).once((key) => {\n const db = new LedgerImpl<T>(sthis, {\n name,\n meta: opts?.meta,\n keyBag: defaultKeyBagOpts(sthis, opts?.keyBag),\n storeUrls: toStoreURIRuntime(sthis, name, opts?.storeUrls),\n gatewayInterceptor: opts?.gatewayInterceptor,\n writeQueue: defaultWriteQueueOpts(opts?.writeQueue),\n storeEnDe: {\n encodeFile,\n decodeFile,\n ...opts?.storeEnDe,\n },\n });\n db.onClosed(() => {\n ledgers.unget(key);\n });\n return db;\n }),\n );\n}\n\nexport class LedgerShell<DT extends DocTypes = NonNullable<unknown>> implements Ledger<DT> {\n readonly ref: LedgerImpl<DT>;\n constructor(ref: LedgerImpl<DT>) {\n this.ref = ref;\n ref.addShell(this);\n }\n\n get id(): string {\n return this.ref.id;\n }\n get logger(): Logger {\n return this.ref.logger;\n }\n get sthis(): SuperThis {\n return this.ref.sthis;\n }\n get crdt(): CRDT<DT> {\n return this.ref.crdt;\n }\n\n get name(): string {\n return this.ref.name;\n }\n onClosed(fn: () => void): void {\n return this.ref.onClosed(fn);\n }\n close(): Promise<void> {\n return this.ref.shellClose(this);\n }\n destroy(): Promise<void> {\n return this.ref.destroy();\n }\n ready(): Promise<void> {\n return this.ref.ready();\n }\n get<T extends DocTypes>(id: string): Promise<DocWithId<T>> {\n return this.ref.get(id);\n }\n put<T extends DocTypes>(doc: DocSet<T>): Promise<DocResponse> {\n return this.ref.put(doc);\n }\n bulk<T extends DocTypes>(docs: DocSet<T>[]): Promise<BulkResponse> {\n return this.ref.bulk(docs);\n }\n del(id: string): Promise<DocResponse> {\n return this.ref.del(id);\n }\n changes<T extends DocTypes>(since?: ClockHead, opts?: ChangesOptions): Promise<ChangesResponse<T>> {\n return this.ref.changes(since, opts);\n }\n allDocs<T extends DocTypes>(opts?: AllDocsQueryOpts): Promise<AllDocsResponse<T>> {\n return this.ref.allDocs(opts);\n }\n allDocuments<T extends DocTypes>(): Promise<{\n rows: {\n key: string;\n value: DocWithId<T>;\n }[];\n clock: ClockHead;\n }> {\n return this.ref.allDocuments();\n }\n subscribe<T extends DocTypes>(listener: ListenerFn<T>, updates?: boolean): () => void {\n return this.ref.subscribe(listener, updates);\n }\n query<K extends IndexKeyType, T extends DocTypes, R extends DocFragment = T>(\n field: string | MapFn<T>,\n opts?: QueryOpts<K>,\n ): Promise<IndexRows<K, T, R>> {\n return this.ref.query(field, opts);\n }\n compact(): Promise<void> {\n return this.ref.compact();\n }\n}\n\nclass LedgerImpl<DT extends DocTypes = NonNullable<unknown>> implements Ledger<DT> {\n // readonly name: string;\n readonly opts: LedgerOpts;\n\n _listening = false;\n readonly _listeners = new Set<ListenerFn<DT>>();\n readonly _noupdate_listeners = new Set<ListenerFn<DT>>();\n readonly crdt: CRDT<DT>;\n readonly _writeQueue: WriteQueue<DT>;\n // readonly blockstore: BaseBlockstore;\n\n readonly shells: Set<LedgerShell<DT>> = new Set<LedgerShell<DT>>();\n\n addShell(shell: LedgerShell<DT>) {\n this.shells.add(shell);\n }\n\n readonly _onClosedFns = new Set<() => void>();\n onClosed(fn: () => void) {\n this._onClosedFns.add(fn);\n }\n async close() {\n throw this.logger.Error().Str(\"db\", this.name).Msg(`use shellClose`).AsError();\n }\n async shellClose(db: LedgerShell<DT>) {\n if (!this.shells.has(db)) {\n throw this.logger.Error().Str(\"db\", this.name).Msg(`LedgerShell mismatch`).AsError();\n }\n this.shells.delete(db);\n if (this.shells.size === 0) {\n await this.ready();\n await this.crdt.close();\n await this._writeQueue.close();\n this._onClosedFns.forEach((fn) => fn());\n }\n // await this.blockstore.close();\n }\n\n async destroy() {\n await this.ready();\n await this.crdt.destroy();\n // await this.blockstore.destroy();\n }\n\n readonly _ready: ResolveOnce<void> = new ResolveOnce<void>();\n async ready(): Promise<void> {\n const ret = await this._ready.once(async () => {\n await this.sthis.start();\n await this.crdt.ready();\n // await this.blockstore.ready();\n });\n return ret;\n }\n\n readonly logger: Logger;\n readonly sthis: SuperThis;\n readonly id: string;\n\n constructor(sthis: SuperThis, opts: LedgerOpts) {\n this.opts = opts; // || this.opts;\n // this.name = opts.storeUrls.data.data.getParam(PARAM.NAME) || \"default\";\n this.sthis = sthis;\n this.id = sthis.timeOrderedNextId().str;\n this.logger = ensureLogger(this.sthis, \"Ledger\");\n this.crdt = new CRDT(this.sthis, this.opts);\n this._writeQueue = writeQueue(this.sthis, async (updates: DocUpdate<DT>[]) => this.crdt.bulk(updates), this.opts.writeQueue);\n this.crdt.clock.onTock(() => this._no_update_notify());\n }\n\n get name(): string {\n return this.opts.storeUrls.data.data.getParam(PARAM.NAME) || \"default\";\n }\n\n async get<T extends DocTypes>(id: string): Promise<DocWithId<T>> {\n if (!id) throw this.logger.Error().Str(\"db\", this.name).Msg(`Doc id is required`).AsError();\n\n await this.ready();\n this.logger.Debug().Str(\"id\", id).Msg(\"get\");\n const got = await this.crdt.get(id).catch((e) => {\n throw new NotFoundError(`Not found: ${id} - ${e.message}`);\n });\n if (!got) throw new NotFoundError(`Not found: ${id}`);\n const { doc } = got;\n return { ...(doc as unknown as DocWithId<T>), _id: id };\n }\n\n async put<T extends DocTypes>(doc: DocSet<T>): Promise<DocResponse> {\n await this.ready();\n this.logger.Debug().Str(\"id\", doc._id).Msg(\"put\");\n const { _id, ...value } = doc;\n const docId = _id || this.sthis.timeOrderedNextId().str;\n const result = (await this._writeQueue.push({\n id: docId,\n value: {\n ...(value as unknown as DocSet<DT>),\n _id: docId,\n },\n })) as CRDTMeta;\n return { id: docId, clock: result?.head, name: this.name } as DocResponse;\n }\n\n async bulk<T extends DocTypes>(docs: DocSet<T>[]): Promise<BulkResponse> {\n await this.ready();\n\n const updates = docs.map((doc) => {\n const id = doc._id || this.sthis.timeOrderedNextId().str;\n return {\n id,\n value: {\n ...(doc as unknown as DocSet<DT>),\n _id: id,\n },\n };\n });\n const result = (await this._writeQueue.bulk(updates)) as CRDTMeta;\n return { ids: updates.map((u) => u.id), clock: result.head, name: this.name } as BulkResponse;\n }\n\n async del(id: string): Promise<DocResponse> {\n await this.ready();\n this.logger.Debug().Str(\"id\", id).Msg(\"del\");\n const result = (await this._writeQueue.push({ id: id, del: true })) as CRDTMeta;\n return { id, clock: result?.head, name: this.name } as DocResponse;\n }\n\n async changes<T extends DocTypes>(since: ClockHead = [], opts: ChangesOptions = {}): Promise<ChangesResponse<T>> {\n await this.ready();\n this.logger.Debug().Any(\"since\", since).Any(\"opts\", opts).Msg(\"changes\");\n const { result, head } = await this.crdt.changes(since, opts);\n const rows: ChangesResponseRow<T>[] = result.map(({ id: key, value, del, clock }) => ({\n key,\n value: (del ? { _id: key, _deleted: true } : { _id: key, ...value }) as DocWithId<T>,\n clock,\n }));\n return { rows, clock: head, name: this.name };\n }\n\n async allDocs<T extends DocTypes>(opts: AllDocsQueryOpts = {}): Promise<AllDocsResponse<T>> {\n await this.ready();\n void opts;\n this.logger.Debug().Msg(\"allDocs\");\n const { result, head } = await this.crdt.allDocs();\n const rows = result.map(({ id: key, value, del }) => ({\n key,\n value: (del ? { _id: key, _deleted: true } : { _id: key, ...value }) as DocWithId<T>,\n }));\n return { rows, clock: head, name: this.name };\n }\n\n async allDocuments<T extends DocTypes>(): Promise<{\n rows: {\n key: string;\n value: DocWithId<T>;\n }[];\n clock: ClockHead;\n }> {\n return this.allDocs<T>();\n }\n\n subscribe<T extends DocTypes>(listener: ListenerFn<T>, updates?: boolean): () => void {\n this.logger.Debug().Bool(\"updates\", updates).Msg(\"subscribe\");\n if (updates) {\n if (!this._listening) {\n this._listening = true;\n this.crdt.clock.onTick((updates: DocUpdate<NonNullable<unknown>>[]) => {\n void this._notify(updates);\n });\n }\n this._listeners.add(listener as ListenerFn<NonNullable<unknown>>);\n return () => {\n this._listeners.delete(listener as ListenerFn<NonNullable<unknown>>);\n };\n } else {\n this._noupdate_listeners.add(listener as ListenerFn<NonNullable<unknown>>);\n return () => {\n this._noupdate_listeners.delete(listener as ListenerFn<NonNullable<unknown>>);\n };\n }\n }\n\n // todo if we add this onto dbs in fireproof.ts then we can make index.ts a separate package\n async query<K extends IndexKeyType, T extends DocTypes, R extends DocFragment = T>(\n field: string | MapFn<T>,\n opts: QueryOpts<K> = {},\n ): Promise<IndexRows<K, T, R>> {\n await this.ready();\n this.logger.Debug().Any(\"field\", field).Any(\"opts\", opts).Msg(\"query\");\n const _crdt = this.crdt as unknown as CRDT<T>;\n const idx =\n typeof field === \"string\"\n ? index<K, T, R>({ crdt: _crdt }, field)\n : index<K, T, R>({ crdt: _crdt }, makeName(field.toString()), field);\n return await idx.query(opts);\n }\n\n async compact() {\n await this.ready();\n await this.crdt.compact();\n }\n\n async _notify(updates: DocUpdate<NonNullable<unknown>>[]) {\n await this.ready();\n if (this._listeners.size) {\n const docs: DocWithId<NonNullable<unknown>>[] = updates.map(({ id, value }) => ({ ...value, _id: id }));\n for (const listener of this._listeners) {\n await (async () => await listener(docs as DocWithId<DT>[]))().catch((e: Error) => {\n this.logger.Error().Err(e).Msg(\"subscriber error\");\n });\n }\n }\n }\n\n async _no_update_notify() {\n await this.ready();\n if (this._noupdate_listeners.size) {\n for (const listener of this._noupdate_listeners) {\n await (async () => await listener([]))().catch((e: Error) => {\n this.logger.Error().Err(e).Msg(\"subscriber error\");\n });\n }\n }\n }\n}\n\nfunction defaultURI(\n sthis: SuperThis,\n curi: CoerceURI | undefined,\n uri: URI,\n store: \"data\" | \"meta\" | \"wal\",\n ctx?: Partial<{\n readonly idx: boolean;\n readonly file: boolean;\n }>,\n): URI {\n ctx = ctx || {};\n const ret = (curi ? URI.from(curi) : uri).build().setParam(PARAM.STORE, store);\n if (!ret.hasParam(PARAM.NAME)) {\n const name = sthis.pathOps.basename(ret.URI().pathname);\n if (!name) {\n throw sthis.logger.Error().Url(ret).Any(\"ctx\", ctx).Msg(\"Ledger name is required\").AsError();\n }\n ret.setParam(PARAM.NAME, name);\n }\n if (ctx.idx) {\n ret.defParam(PARAM.INDEX, \"idx\");\n ret.defParam(PARAM.STORE_KEY, `@${ret.getParam(PARAM.NAME)}-${store}-idx@`);\n } else {\n ret.defParam(PARAM.STORE_KEY, `@${ret.getParam(PARAM.NAME)}-${store}@`);\n }\n if (store === \"data\") {\n if (ctx.file) {\n // ret.defParam(PARAM.SUFFIX, \"\");\n } else {\n ret.defParam(PARAM.SUFFIX, \".car\");\n }\n }\n return ret.URI();\n}\n\nexport function toStoreURIRuntime(sthis: SuperThis, name?: string, sopts?: StoreUrlsOpts): StoreURIRuntime {\n sopts = sopts || {};\n if (!sopts.base) {\n const fp_env = sthis.env.get(\"FP_STORAGE_URL\");\n if (fp_env) {\n sopts = { ...sopts, base: BuildURI.from(fp_env).setParam(PARAM.URL_GEN, \"fromEnv\") };\n } else {\n sopts = { ...sopts, base: getDefaultURI(sthis).build().setParam(PARAM.URL_GEN, \"default\") };\n }\n }\n const bbase = BuildURI.from(sopts.base);\n if (name) {\n bbase.setParam(PARAM.NAME, name);\n }\n const base = bbase.URI();\n // readonly public?: boolean;\n // readonly meta?: DbMeta;\n // readonly persistIndexes?: boolean;\n // readonly autoCompact?: number;\n // readonly threshold?: number;\n return {\n idx: {\n data: defaultURI(sthis, sopts.idx?.data, base, \"data\", { idx: true }),\n file: defaultURI(sthis, sopts.idx?.data, base, \"data\", { file: true, idx: true }),\n meta: defaultURI(sthis, sopts.idx?.meta, base, \"meta\", { idx: true }),\n wal: defaultURI(sthis, sopts.idx?.wal, base, \"wal\", { idx: true }),\n },\n data: {\n data: defaultURI(sthis, sopts.data?.data, base, \"data\"),\n file: defaultURI(sthis, sopts.data?.data, base, \"data\", { file: true }),\n meta: defaultURI(sthis, sopts.data?.meta, base, \"meta\"),\n wal: defaultURI(sthis, sopts.data?.wal, base, \"wal\"),\n },\n };\n}\n\nexport function fireproof(name: string, opts?: ConfigOpts): Ledger {\n return LedgerFactory(name, opts);\n}\n\nfunction makeName(fnString: string) {\n const regex = /\\(([^,()]+,\\s*[^,()]+|\\[[^\\]]+\\],\\s*[^,()]+)\\)/g;\n let found: RegExpExecArray | null = null;\n const matches = Array.from(fnString.matchAll(regex), (match) => match[1].trim());\n if (matches.length === 0) {\n found = /=>\\s*{?\\s*([^{}]+)\\s*}?/.exec(fnString);\n if (found && found[1].includes(\"return\")) {\n found = null;\n }\n }\n if (!found) {\n return fnString;\n } else {\n // it's a consise arrow function, match everything after the arrow\n return found[1];\n }\n}\n","import {\n Logger,\n LoggerImpl,\n IsLogger,\n Result,\n ResolveOnce,\n isURL,\n URI,\n envFactory,\n Env,\n toCryptoRuntime,\n CryptoRuntime,\n JSONFormatter,\n YAMLFormatter,\n} from \"@adviser/cement\";\nimport { PARAM, PathOps, StoreType, SuperThis, SuperThisOpts, TextEndeCoder, PromiseToUInt8, ToUInt8 } from \"./types.js\";\nimport { base58btc } from \"multiformats/bases/base58\";\n\n//export type { Logger };\n//export { Result };\n\nconst _globalLogger = new ResolveOnce();\nfunction globalLogger(): Logger {\n return _globalLogger.once(() => new LoggerImpl());\n}\n\nconst registerFP_DEBUG = new ResolveOnce();\n\ninterface superThisOpts {\n readonly logger: Logger;\n readonly env: Env;\n readonly pathOps: PathOps;\n readonly crypto: CryptoRuntime;\n readonly ctx: Record<string, unknown>;\n readonly txt: TextEndeCoder;\n}\n\nclass SuperThisImpl implements SuperThis {\n readonly logger: Logger;\n readonly env: Env;\n readonly pathOps: PathOps;\n readonly ctx: Record<string, unknown>;\n readonly txt: TextEndeCoder;\n readonly crypto: CryptoRuntime;\n\n constructor(opts: superThisOpts) {\n this.logger = opts.logger;\n this.env = opts.env;\n this.crypto = opts.crypto;\n this.pathOps = opts.pathOps;\n this.txt = opts.txt;\n this.ctx = { ...opts.ctx };\n // console.log(\"superThis\", this);\n }\n\n nextId(bytes = 6): { str: string; bin: Uint8Array } {\n const bin = this.crypto.randomBytes(bytes);\n return {\n str: base58btc.encode(bin),\n bin,\n };\n }\n\n timeOrderedNextId(now?: number): { str: string } {\n now = typeof now === \"number\" ? now : new Date().getTime();\n // 49th bit\n const t = (0x1000000000000 + now).toString(16).replace(/^1/, \"\");\n const bin = this.crypto.randomBytes(10);\n bin[1] = (bin[1] & 0xf0) | (bin[1] | 0x08 && 0x0b);\n const hex = Array.from(bin)\n .map((i) => i.toString(16).padStart(2, \"0\"))\n .join(\"\");\n return {\n str: `${t.slice(0, 8)}-${t.slice(8)}-7${hex.slice(0, 3)}-${hex.slice(3, 7)}-${hex.slice(7, 19)}`,\n };\n }\n\n start(): Promise<void> {\n return Promise.resolve();\n }\n\n clone(override: Partial<SuperThisOpts>): SuperThis {\n return new SuperThisImpl({\n logger: override.logger || this.logger,\n env: envFactory(override.env) || this.env,\n crypto: override.crypto || this.crypto,\n pathOps: override.pathOps || this.pathOps,\n txt: override.txt || this.txt,\n ctx: { ...this.ctx, ...override.ctx },\n });\n }\n}\n\n// const pathOps =\nfunction presetEnv() {\n const penv = new Map([\n // [\"FP_DEBUG\", \"xxx\"],\n // [\"FP_ENV\", \"development\"],\n ...Array.from(\n Object.entries(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ((globalThis as any)[Symbol.for(\"FP_PRESET_ENV\")] || {}) as Record<string, string>,\n ),\n ), // .map(([k, v]) => [k, v as string])\n ]);\n // console.log(\">>>>>>\", penv)\n return penv;\n}\n// const envImpl = envFactory({\n// symbol: \"FP_ENV\",\n// presetEnv: presetEnv(),\n// });\nclass pathOpsImpl implements PathOps {\n join(...paths: string[]): string {\n return paths.map((i) => i.replace(/\\/+$/, \"\")).join(\"/\");\n }\n dirname(path: string) {\n return path.split(\"/\").slice(0, -1).join(\"/\");\n }\n basename(path: string): string {\n return path.split(\"/\").pop() || \"\";\n }\n // homedir() {\n // throw new Error(\"SysContainer:homedir is not available in seeded state\");\n // }\n}\nconst pathOps = new pathOpsImpl();\nconst txtOps = ((txtEncoder, txtDecoder) => ({\n encode: (input: string) => txtEncoder.encode(input),\n decode: (input: ToUInt8) => txtDecoder.decode(coerceIntoUint8(input).Ok()),\n // eslint-disable-next-line no-restricted-globals\n}))(new TextEncoder(), new TextDecoder());\n\nconst _onSuperThis = new Map<string, (sthis: SuperThis) => void>();\nexport function onSuperThis(fn: (sthis: SuperThis) => void): () => void {\n const key = `onSuperThis-${Math.random().toString(36).slice(2)}`;\n _onSuperThis.set(key, fn);\n return () => {\n _onSuperThis.delete(key);\n };\n}\n\nexport function ensureSuperThis(osthis?: Partial<SuperThisOpts>): SuperThis {\n const env = envFactory({\n symbol: osthis?.env?.symbol || \"FP_ENV\",\n presetEnv: osthis?.env?.presetEnv || presetEnv(),\n });\n const ret = new SuperThisImpl({\n logger: osthis?.logger || globalLogger(),\n env,\n crypto: osthis?.crypto || toCryptoRuntime(),\n ctx: osthis?.ctx || {},\n pathOps,\n txt: osthis?.txt || txtOps,\n });\n _onSuperThis.forEach((fn) => fn(ret));\n return ret;\n}\n\n// // eslint-disable-next-line @typescript-eslint/no-unused-vars\nexport function ensureSuperLog(sthis: SuperThis, componentName: string, ctx?: Record<string, unknown>): SuperThis {\n return sthis.clone({\n logger: ensureLogger(sthis, componentName, ctx),\n });\n}\n\nexport function ensureLogger(\n sthis: SuperThis /* Partial<LoggerOpts> | Logger */,\n componentName: string,\n ctx?: Record<string, unknown>,\n): Logger {\n // if (!opts?.logger) {\n // throw new Error(\"logger is required\");\n // }\n let logger: Logger;\n if (sthis && IsLogger(sthis.logger)) {\n logger = sthis.logger;\n } else {\n logger = globalLogger();\n }\n const cLogger = logger.With().Module(componentName); //.Str(\"this\", uuidv7());\n const debug: string[] = [];\n let exposeStack = false;\n if (ctx) {\n if (\"debug\" in ctx) {\n if (typeof ctx.debug === \"string\" && ctx.debug.length > 0) {\n debug.push(ctx.debug);\n } else {\n debug.push(componentName);\n }\n delete ctx.debug;\n }\n if (\"exposeStack\" in ctx) {\n exposeStack = true;\n delete ctx.exposeStack;\n }\n if (\"exposeStack\" in ctx) {\n exposeStack = true;\n delete ctx.exposeStack;\n }\n if (\"this\" in ctx) {\n cLogger.Str(\"this\", sthis.nextId(4).str);\n delete ctx.this;\n }\n for (const [key, value] of Object.entries(ctx)) {\n switch (typeof value) {\n case \"string\":\n cLogger.Str(key, value);\n break;\n case \"number\":\n cLogger.Uint64(key, value);\n break;\n default:\n if (value instanceof Date) {\n cLogger.Str(key, value.toISOString());\n } else if (isURL(value)) {\n cLogger.Str(key, value.toString());\n } else if (typeof value === \"function\") {\n cLogger.Ref(key, value);\n } else {\n cLogger.Any(key, value);\n }\n break;\n }\n }\n }\n registerFP_DEBUG\n .once(async () => {\n // console.log(\"registerFP_DEBUG\", SysContainer.env)\n sthis.env.onSet(\n (key, value) => {\n // console.log(\"FP_DEBUG\", key, value, debug)\n switch (key) {\n case \"FP_FORMAT\": {\n switch (value) {\n case \"jsonice\":\n logger.SetFormatter(new JSONFormatter(logger.TxtEnDe(), 2));\n break;\n case \"yaml\":\n logger.SetFormatter(new YAMLFormatter(logger.TxtEnDe(), 2));\n break;\n case \"json\":\n default:\n logger.SetFormatter(new JSONFormatter(logger.TxtEnDe()));\n break;\n }\n break;\n }\n case \"FP_DEBUG\":\n logger.SetDebug(value || []);\n break;\n case \"FP_STACK\":\n logger.SetExposeStack(!!value);\n break;\n }\n },\n \"FP_FORMAT\",\n \"FP_DEBUG\",\n \"FP_STACK\",\n );\n })\n .finally(() => {\n /* do nothing */\n });\n\n if (debug.length > 0) {\n logger.SetDebug(debug);\n }\n if (exposeStack) {\n logger.SetExposeStack(true);\n }\n const out = cLogger.Logger();\n if (sthis.env.get(\"FP_CONSTRUCTOR_DEBUG\")) {\n out.Debug().Msg(\"constructor\");\n }\n return out;\n}\n\nexport type Joiner = (...toJoin: string[]) => string;\n\nexport interface Store {\n readonly store: StoreType;\n readonly name: string;\n}\n\nexport function getStore(url: URI, sthis: SuperThis, joiner: Joiner): Store {\n const store = url.getParam(PARAM.STORE);\n switch (store) {\n case \"data\":\n case \"wal\":\n case \"meta\":\n break;\n default:\n throw sthis.logger.Error().Url(url).Msg(`store not found`).AsError();\n throw sthis.logger.Error().Url(url).Msg(`store not found`).AsError();\n }\n let name: string = store;\n if (url.hasParam(\"index\")) {\n name = joiner(url.getParam(PARAM.INDEX) || \"idx\", name);\n }\n return { store, name };\n}\n\nexport function getKey(url: URI, logger: Logger): string {\n const result = url.getParam(PARAM.KEY);\n if (!result) throw logger.Error().Str(\"url\", url.toString()).Msg(`key not found`).AsError();\n return result;\n}\n\nexport function getName(sthis: SuperThis, url: URI): string {\n let result = url.getParam(PARAM.NAME);\n if (!result) {\n result = sthis.pathOps.dirname(url.pathname);\n if (result.length === 0) {\n throw sthis.logger.Error().Str(\"url\", url.toString()).Msg(`name not found`).AsError();\n }\n }\n return result;\n}\n\n// export function exception2Result<T = void>(fn: () => Promise<T>): Promise<Result<T>> {\n// return fn()\n// .then((value) => Result.Ok(value))\n// .catch((e) => Result.Err(e));\n// }\n\nexport async function exceptionWrapper<T, E extends Error>(fn: () => Promise<Result<T, E>>): Promise<Result<T, E>> {\n return fn().catch((e) => Result.Err(e));\n}\n\n// // the big side effect party --- hate it\n// export function sanitizeURL(url: URL) {\n// url.searchParams.sort();\n// // const searchParams = Object.entries(url.searchParams).sort(([a], [b]) => a.localeCompare(b));\n// // console.log(\"searchParams\", searchParams);\n// // for (const [key] of searchParams) {\n// // url.searchParams.delete(key);\n// // }\n// // for (const [key, value] of searchParams) {\n// // url.searchParams.set(key, value);\n// // }\n// }\n\nexport class NotFoundError extends Error {\n readonly code = \"ENOENT\";\n}\n\nexport function isNotFoundError(e: Error | Result<unknown> | unknown): e is NotFoundError {\n if (Result.Is(e)) {\n if (e.isOk()) return false;\n e = e.Err();\n }\n if ((e as NotFoundError).code === \"ENOENT\") return true;\n return false;\n}\n\nexport function UInt8ArrayEqual(a: Uint8Array, b: Uint8Array): boolean {\n if (a.length !== b.length) {\n return false;\n }\n for (let i = 0; i < a.length; i++) {\n if (a[i] !== b[i]) {\n return false;\n }\n }\n return true;\n}\n\nexport function inplaceFilter<T>(i: T[], pred: (i: T, idx: number) => boolean): T[] {\n const founds: number[] = [];\n for (let j = 0; j < i.length; j++) {\n if (!pred(i[j], j)) {\n founds.push(j);\n }\n }\n for (let j = founds.length - 1; j >= 0; j--) {\n i.splice(founds[j], 1);\n }\n return i;\n}\n\nexport function toSortedArray(set?: Record<string, unknown>): Record<string, unknown>[] {\n if (!set) return [];\n return Object.entries(set)\n .sort(([a], [b]) => a.localeCompare(b))\n .map(([k, v]) => ({ [k]: v }));\n}\n\nexport function coerceIntoUint8(raw: ToUInt8): Result<Uint8Array> {\n if (raw instanceof Uint8Array) {\n return Result.Ok(raw);\n }\n if (Result.Is(raw)) {\n return raw;\n }\n return Result.Err(\"Not a Uint8Array\");\n}\n\nexport async function coercePromiseIntoUint8(raw: PromiseToUInt8): Promise<Result<Uint8Array>> {\n if (raw instanceof Uint8Array) {\n return Result.Ok(raw);\n }\n if (Result.Is(raw)) {\n return raw;\n }\n if (typeof raw.then === \"function\") {\n try {\n return coercePromiseIntoUint8(await raw);\n } catch (e) {\n return Result.Err(e as Error);\n }\n }\n return Result.Err(\"Not a Uint8Array\");\n}\n","import type { EventLink } from \"@fireproof/vendor/@web3-storage/pail/clock/api\";\nimport type { Operation } from \"@fireproof/vendor/@web3-storage/pail/crdt/api\";\n\nimport type { DbMeta, AnyLink, StoreUrlsOpts, StoreEnDeFile, SerdeGatewayInterceptor } from \"./blockstore/index.js\";\nimport { EnvFactoryOpts, Env, Logger, CryptoRuntime, Result } from \"@adviser/cement\";\n\n// import type { MakeDirectoryOptions, PathLike, Stats } from \"fs\";\nimport { KeyBagOpts } from \"./runtime/key-bag.js\";\nimport { WriteQueueParams } from \"./write-queue.js\";\n\nexport type { DbMeta };\n\nexport type Falsy = false | null | undefined;\n\nexport function isFalsy(value: unknown): value is Falsy {\n return value === false && value === null && value === undefined;\n}\n\nexport enum PARAM {\n SUFFIX = \"suffix\",\n URL_GEN = \"urlGen\", // \"urlGen\" | \"default\"\n STORE_KEY = \"storekey\",\n STORE = \"store\",\n KEY = \"key\",\n INDEX = \"index\",\n NAME = \"name\",\n VERSION = \"version\",\n RUNTIME = \"runtime\", // \"node\" | \"deno\" | \"browser\"\n FRAG_SIZE = \"fragSize\",\n IV_VERIFY = \"ivVerify\",\n IV_HASH = \"ivHash\",\n FRAG_FID = \"fid\",\n FRAG_OFS = \"ofs\",\n FRAG_LEN = \"len\",\n FRAG_HEAD = \"headerSize\",\n EXTRACTKEY = \"extractKey\",\n // FS = \"fs\",\n}\n\nexport function throwFalsy<T>(value: T | Falsy): T {\n if (isFalsy(value)) {\n throw new Error(\"value is Falsy\");\n }\n return value;\n}\n\nexport function falsyToUndef<T>(value: T | Falsy): T | undefined {\n if (isFalsy(value)) {\n return undefined;\n }\n return value;\n}\n\nexport type StoreType = \"data\" | \"wal\" | \"meta\";\nexport interface FPStats {\n isFile(): boolean;\n isDirectory(): boolean;\n isBlockDevice(): boolean;\n isCharacterDevice(): boolean;\n isSymbolicLink(): boolean;\n isFIFO(): boolean;\n isSocket(): boolean;\n uid: number | Falsy;\n gid: number | Falsy;\n size: number | Falsy;\n atime: Date | Falsy;\n mtime: Date | Falsy;\n ctime: Date | Falsy;\n birthtime: Date | Falsy;\n}\n\nexport interface SysFileSystem {\n start(): Promise<SysFileSystem>;\n mkdir(path: string, options?: { recursive: boolean }): Promise<string | undefined>;\n readdir(path: string /*, options?: unknown*/): Promise<string[]>;\n rm(path: string, options?: { recursive: boolean }): Promise<void>;\n copyFile(source: string, destination: string): Promise<void>;\n readfile(path: string /*, options?: { encoding: BufferEncoding; flag?: string }*/): Promise<Uint8Array>;\n stat(path: string): Promise<FPStats>;\n unlink(path: string): Promise<void>;\n writefile(path: string, data: Uint8Array | string): Promise<void>;\n}\n\nexport interface PathOps {\n join(...args: string[]): string;\n dirname(path: string): string;\n basename(path: string): string;\n}\n\nexport type ToUInt8 = Uint8Array | Result<Uint8Array>;\nexport type PromiseToUInt8 = ToUInt8 | Promise<Uint8Array> | Promise<Result<Uint8Array>>;\n\nexport interface TextEndeCoder {\n encode(input: string): Uint8Array;\n decode(input: ToUInt8): string;\n}\nexport interface SuperThisOpts {\n // readonly crypto?: CryptoRuntime;\n readonly logger: Logger;\n readonly pathOps: PathOps;\n readonly crypto: CryptoRuntime;\n readonly env: EnvFactoryOpts;\n readonly txt: TextEndeCoder;\n readonly ctx: Record<string, unknown>;\n}\n\nexport interface SuperThis {\n readonly logger: Logger;\n readonly loggerCollector?: Logger;\n readonly env: Env;\n readonly pathOps: PathOps;\n readonly ctx: Record<string, unknown>;\n readonly txt: TextEndeCoder;\n timeOrderedNextId(time?: number): { str: string; toString: () => string };\n nextId(bytes?: number): { str: string; bin: Uint8Array; toString: () => string };\n start(): Promise<void>;\n clone(override: Partial<SuperThisOpts>): SuperThis;\n}\n\nexport interface ConfigOpts extends Partial<SuperThisOpts> {\n readonly public?: boolean;\n readonly meta?: DbMeta;\n // readonly persistIndexes?: boolean;\n readonly writeQueue?: Partial<WriteQueueParams>;\n readonly gatewayInterceptor?: SerdeGatewayInterceptor;\n readonly autoCompact?: number;\n readonly storeUrls?: StoreUrlsOpts;\n readonly storeEnDe?: StoreEnDeFile;\n readonly threshold?: number;\n readonly keyBag?: Partial<KeyBagOpts>;\n}\n\nexport type ClockLink = EventLink<Operation>;\n\nexport type ClockHead = ClockLink[];\n\nexport type DocFragment = Uint8Array | string | number | boolean | null | AnyLink | DocFragment[] | object;\n// | { [key: string]: DocFragment };\n\nexport type DocLiteral = string | number | boolean | Uint8Array | unknown;\n\nexport type DocObject = NonNullable<unknown>;\nexport type DocTypes = DocObject;\n\nexport type DocRecord<T extends DocObject> = T;\n\nexport type UnknownDoc = DocRecord<never>;\n\nexport type DocFiles = Record<string, DocFileMeta | File>;\n\nexport interface DocBase {\n readonly _id: string;\n readonly _files?: DocFiles;\n readonly _publicFiles?: DocFiles;\n readonly _deleted?: boolean;\n}\n\nexport type DocWithId<T extends DocTypes> = DocBase & T;\n\nexport type DocSet<T extends DocTypes> = Partial<DocBase> & T;\n\nexport interface DocFileMeta {\n readonly type: string;\n readonly size: number;\n readonly cid: AnyLink;\n readonly car?: AnyLink;\n url?: string;\n file?: () => Promise<File>;\n}\n\nexport interface DocUpdate<T extends DocTypes> {\n readonly id: string;\n readonly value?: DocSet<T>;\n readonly del?: boolean;\n readonly clock?: ClockLink; // would be useful to give ClockLinks a type\n}\n\n// todo merge into above\nexport interface DocValue<T extends DocTypes> {\n readonly doc: DocWithId<T>;\n readonly del: boolean;\n readonly cid: AnyLink;\n}\n\nexport type KeyLiteral = string | number | boolean;\nexport type IndexKeyType = KeyLiteral | KeyLiteral[];\nexport type IndexKey<K extends IndexKeyType> = [K, string];\n\nexport interface IndexUpdate<K extends IndexKeyType> {\n readonly key: IndexKey<K>;\n readonly value?: DocFragment;\n readonly del?: boolean;\n}\n\nexport interface IndexUpdateString {\n readonly key: string;\n readonly value?: DocFragment;\n readonly del?: boolean;\n}\n\n// export interface IndexRowObject<K extends IndexKeyType, T extends DocObject> {\n// readonly id: string;\n// readonly key: K;\n// readonly value: T\n// // readonly row: T // DocFragment;\n// // readonly doc?: DocWithId<T>;\n// // value?: T;\n// // readonly del?: boolean;\n// }\n\n// export interface IndexRowLiteral<K extends IndexKeyType, T extends DocLiteral> {\n// readonly id: string;\n// readonly key: IndexKey<K>;\n// readonly value: T\n// }\n\n// export type IndexRow<K extends IndexKeyType, T extends DocTypes> =\n// T extends DocLiteral ? IndexRowLiteral<K, T> : IndexRowObject<K, T>\n\nexport interface IndexRow<K extends IndexKeyType, T extends DocObject, R extends DocFragment> {\n readonly id: string;\n readonly key: K; // IndexKey<K>;\n readonly value: R;\n readonly doc?: DocWithId<T>;\n}\n\nexport interface IndexRows<K extends IndexKeyType, T extends DocObject, R extends DocFragment = T> {\n readonly rows: IndexRow<K, T, R>[];\n}\nexport interface CRDTMeta {\n readonly head: ClockHead;\n}\n\nexport interface IndexTransactionMeta {\n readonly indexes: Record<string, IdxMeta>;\n}\n\nexport interface FileTransactionMeta {\n readonly files?: AnyLink[];\n}\n\nexport type MetaType = CRDTMeta | IndexTransactionMeta | FileTransactionMeta;\n\nexport interface IdxMeta {\n readonly byId: AnyLink;\n readonly byKey: AnyLink;\n readonly map: string;\n readonly name: string;\n readonly head: ClockHead;\n}\n\nexport interface IdxMetaMap {\n readonly indexes?: Map<string, IdxMeta>;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nexport interface QueryOpts<K extends IndexKeyType> {\n readonly descending?: boolean;\n readonly limit?: number;\n includeDocs?: boolean;\n readonly range?: [IndexKeyType, IndexKeyType];\n readonly key?: DocFragment;\n readonly keys?: DocFragment[];\n prefix?: IndexKeyType;\n}\n\nexport interface AllDocsQueryOpts extends QueryOpts<string> {\n readonly key?: string;\n readonly keys?: string[];\n prefix?: string;\n}\n\nexport interface AllDocsResponse<T extends DocTypes> {\n readonly rows: {\n readonly key: string;\n readonly value: DocWithId<T>;\n }[];\n readonly clock: ClockHead;\n readonly name?: string;\n}\n\ntype EmitFn = (k: IndexKeyType, v?: DocFragment) => void;\nexport type MapFn<T extends DocTypes> = (doc: DocWithId<T>, emit: EmitFn) => DocFragment | unknown;\n\nexport interface ChangesOptions {\n readonly dirty?: boolean;\n readonly limit?: number;\n}\n\nexport interface ChangesResponseRow<T extends DocTypes> {\n readonly key: string;\n readonly value: DocWithId<T>;\n readonly clock?: ClockLink;\n}\n\nexport interface ChangesResponse<T extends DocTypes> {\n readonly clock: ClockHead;\n readonly rows: ChangesResponseRow<T>[];\n readonly name?: string;\n}\n\nexport interface DocResponse {\n readonly id: string;\n readonly clock: ClockHead;\n readonly name?: string;\n}\n\nexport interface BulkResponse {\n readonly ids: string[];\n readonly clock: ClockHead;\n readonly name?: string;\n}\n\nexport type UpdateListenerFn<T extends DocTypes> = (docs: DocWithId<T>[]) => Promise<void> | void;\nexport type NoUpdateListenerFn = () => Promise<void> | void;\nexport type ListenerFn<T extends DocTypes> = UpdateListenerFn<T> | NoUpdateListenerFn;\n\nexport interface CRDTEntry {\n readonly data: string;\n readonly parents: string[];\n readonly cid: string;\n}\n","import { ensureLogger } from \"./utils.js\";\nimport { DocTypes, MetaType, DocUpdate, SuperThis } from \"./types.js\";\nimport { Future, Logger } from \"@adviser/cement\";\n\ntype WorkerFunction<T extends DocTypes> = (tasks: DocUpdate<T>[]) => Promise<MetaType>;\n\nexport interface WriteQueue<T extends DocTypes> {\n push(task: DocUpdate<T>): Promise<MetaType>;\n bulk(tasks: DocUpdate<T>[]): Promise<MetaType>;\n close(): Promise<void>;\n}\n\ninterface WriteQueueItem<T extends DocTypes> {\n // readonly task?: DocUpdate<T>;\n readonly tasks?: DocUpdate<T>[];\n resolve(result: MetaType): void;\n reject(error: Error): void;\n}\n\nexport interface WriteQueueParams {\n // default 32\n // if chunkSize is 1 the result will be ordered in time\n readonly chunkSize: number;\n}\n\nexport function defaultWriteQueueOpts(opts: Partial<WriteQueueParams> = {}): WriteQueueParams {\n return {\n ...opts,\n chunkSize: opts.chunkSize && opts.chunkSize > 0 ? opts.chunkSize : 32,\n };\n}\n\nclass WriteQueueImpl<T extends DocTypes> implements WriteQueue<T> {\n private readonly opts: WriteQueueParams;\n\n private readonly queue: WriteQueueItem<T>[] = [];\n private readonly worker: WorkerFunction<T>;\n private isProcessing = false;\n private readonly logger: Logger;\n\n constructor(sthis: SuperThis, worker: WorkerFunction<T>, opts: WriteQueueParams) {\n this.logger = ensureLogger(sthis, \"WriteQueueImpl\");\n this.worker = worker;\n this.opts = defaultWriteQueueOpts(opts);\n }\n\n private waitForEmptyQueue?: Future<void>;\n private testEmptyQueue() {\n if (this.waitForEmptyQueue && this.queue.length === 0) {\n this.waitForEmptyQueue.resolve();\n }\n }\n\n private async process() {\n if (this.isProcessing || this.queue.length === 0) {\n this.testEmptyQueue();\n return;\n }\n this.isProcessing = true;\n try {\n this.logger.Debug().Any(\"opts\", this.opts).Len(this.queue).Msg(\"Processing tasks\");\n const tasksToProcess = this.queue.splice(0, this.opts.chunkSize);\n const updates = tasksToProcess.map((item) => item.tasks).filter((item) => item) as DocUpdate<T>[][];\n const promises = updates.map(async (update, index) => {\n try {\n const result = await this.worker(update);\n tasksToProcess[index].resolve(result);\n } catch (error) {\n tasksToProcess[index].reject(this.logger.Error().Err(error).Msg(\"Error processing task\").AsError());\n }\n });\n await Promise.allSettled(promises);\n this.logger.Debug().Any(\"opts\", this.opts).Len(this.queue).Msg(\"Processed tasks\");\n } catch (error) {\n this.logger.Error().Err(error).Msg(\"Error processing tasks\");\n } finally {\n this.isProcessing = false;\n setTimeout(() => this.process(), 0);\n }\n }\n\n bulk(tasks: DocUpdate<T>[]): Promise<MetaType> {\n return new Promise<MetaType>((resolve, reject) => {\n this.queue.push({ tasks, resolve, reject });\n this.process();\n });\n }\n push(task: DocUpdate<T>): Promise<MetaType> {\n return this.bulk([task]);\n }\n close(): Promise<void> {\n this.waitForEmptyQueue = new Future();\n this.testEmptyQueue();\n return this.waitForEmptyQueue.asPromise();\n }\n}\n\nexport function writeQueue<T extends DocTypes>(sthis: SuperThis, worker: WorkerFunction<T>, opts: WriteQueueParams): WriteQueue<T> {\n return new WriteQueueImpl<T>(sthis, worker, opts);\n}\n","import { Block } from \"multiformats\";\nimport { Logger, ResolveOnce } from \"@adviser/cement\";\nimport {\n EncryptedBlockstore,\n type TransactionMeta,\n type CarTransaction,\n BaseBlockstore,\n CompactFetcher,\n toStoreRuntime,\n} from \"./blockstore/index.js\";\nimport {\n clockChangesSince,\n applyBulkUpdateToCrdt,\n getValueFromCrdt,\n readFiles,\n getAllEntries,\n clockVis,\n getBlock,\n doCompact,\n} from \"./crdt-helpers.js\";\nimport type {\n DocUpdate,\n CRDTMeta,\n ClockHead,\n ChangesOptions,\n DocValue,\n IndexKeyType,\n DocWithId,\n DocTypes,\n Falsy,\n SuperThis,\n IndexTransactionMeta,\n} from \"./types.js\";\nimport { index, type Index } from \"./indexer.js\";\nimport { CRDTClock } from \"./crdt-clock.js\";\n// import { blockstoreFactory } from \"./blockstore/transaction.js\";\nimport { ensureLogger } from \"./utils.js\";\nimport { LedgerOpts } from \"./ledger.js\";\n\nexport interface HasCRDT<T extends DocTypes> {\n readonly crdt: CRDT<T> | CRDT<NonNullable<unknown>>;\n}\n\nexport class CRDT<T extends DocTypes> {\n readonly opts: LedgerOpts;\n\n readonly blockstore: BaseBlockstore;\n readonly indexBlockstore: BaseBlockstore;\n readonly indexers: Map<string, Index<IndexKeyType, NonNullable<unknown>>> = new Map<\n string,\n Index<IndexKeyType, NonNullable<unknown>>\n >();\n readonly clock: CRDTClock<T>;\n\n readonly logger: Logger;\n readonly sthis: SuperThis;\n\n constructor(sthis: SuperThis, opts: LedgerOpts) {\n this.sthis = sthis;\n this.logger = ensureLogger(sthis, \"CRDT\");\n this.opts = opts;\n this.blockstore = new EncryptedBlockstore(sthis, {\n applyMeta: async (meta: TransactionMeta) => {\n const crdtMeta = meta as CRDTMeta;\n if (!crdtMeta.head) throw this.logger.Error().Msg(\"missing head\").AsError();\n await this.clock.applyHead(crdtMeta.head, []);\n },\n compact: async (blocks: CompactFetcher) => {\n await doCompact(blocks, this.clock.head, this.logger);\n return { head: this.clock.head } as TransactionMeta;\n },\n gatewayInterceptor: opts.gatewayInterceptor,\n // autoCompact: this.opts.autoCompact || 100,\n storeRuntime: toStoreRuntime(this.sthis, this.opts.storeEnDe),\n storeUrls: this.opts.storeUrls.data,\n keyBag: this.opts.keyBag,\n // public: this.opts.public,\n meta: this.opts.meta,\n // threshold: this.opts.threshold,\n });\n this.indexBlockstore = new EncryptedBlockstore(sthis, {\n // name: opts.name,\n applyMeta: async (meta: TransactionMeta) => {\n const idxCarMeta = meta as IndexTransactionMeta;\n if (!idxCarMeta.indexes) throw this.logger.Error().Msg(\"missing indexes\").AsError();\n for (const [name, idx] of Object.entries(idxCarMeta.indexes)) {\n index({ crdt: this }, name, undefined, idx);\n }\n },\n gatewayInterceptor: opts.gatewayInterceptor,\n storeRuntime: toStoreRuntime(this.sthis, this.opts.storeEnDe),\n storeUrls: this.opts.storeUrls.idx,\n keyBag: this.opts.keyBag,\n // public: this.opts.public,\n });\n this.clock = new CRDTClock<T>(this.blockstore);\n this.clock.onZoom(() => {\n for (const idx of this.indexers.values()) {\n idx._resetIndex();\n }\n });\n }\n\n async bulk(updates: DocUpdate<T>[]): Promise<CRDTMeta> {\n await this.ready();\n const prevHead = [...this.clock.head];\n\n const done = await this.blockstore.transaction<CRDTMeta>(async (blocks: CarTransaction): Promise<CRDTMeta> => {\n const { head } = await applyBulkUpdateToCrdt<T>(\n this.blockstore.ebOpts.storeRuntime,\n blocks,\n this.clock.head,\n updates,\n this.logger,\n );\n updates = updates.map((dupdate: DocUpdate<T>) => {\n // if (!dupdate.value) throw new Error(\"missing value\");\n readFiles(this.blockstore, { doc: dupdate.value as DocWithId<T> });\n return dupdate;\n });\n return { head };\n });\n await this.clock.applyHead(done.meta.head, prevHead, updates);\n return done.meta;\n }\n\n readonly onceReady: ResolveOnce<void> = new ResolveOnce<void>();\n async ready(): Promise<void> {\n return this.onceReady.once(async () => {\n try {\n // await this.blockstore.ready();\n // await this.indexBlockstore.ready();\n // await this.clock.ready();\n await Promise.all([this.blockstore.ready(), this.indexBlockstore.ready(), this.clock.ready()]);\n } catch (e) {\n throw this.logger.Error().Err(e).Msg(`CRDT is not ready`).AsError();\n }\n });\n }\n\n async close(): Promise<void> {\n // await this.blockstore.close();\n // await this.indexBlockstore.close();\n // await this.clock.close();\n await Promise.all([this.blockstore.close(), this.indexBlockstore.close(), this.clock.close()]);\n }\n\n async destroy(): Promise<void> {\n await Promise.all([this.blockstore.destroy(), this.indexBlockstore.destroy()]);\n }\n\n // if (snap) await this.clock.applyHead(crdtMeta.head, this.clock.head)\n\n async allDocs(): Promise<{ result: DocUpdate<T>[]; head: ClockHead }> {\n await this.ready();\n const result: DocUpdate<T>[] = [];\n for await (const entry of getAllEntries<T>(this.blockstore, this.clock.head, this.logger)) {\n result.push(entry);\n }\n return { result, head: this.clock.head };\n }\n\n async vis(): Promise<string> {\n await this.ready();\n const txt: string[] = [];\n for await (const line of clockVis(this.blockstore, this.clock.head)) {\n txt.push(line);\n }\n return txt.join(\"\\n\");\n }\n\n async getBlock(cidString: string): Promise<Block> {\n await this.ready();\n return await getBlock(this.blockstore, cidString);\n }\n\n async get(key: string): Promise<DocValue<T> | Falsy> {\n await this.ready();\n const result = await getValueFromCrdt<T>(this.blockstore, this.clock.head, key, this.logger);\n if (result.del) return undefined;\n return result;\n }\n\n async changes(\n since: ClockHead = [],\n opts: ChangesOptions = {},\n ): Promise<{\n result: DocUpdate<T>[];\n head: ClockHead;\n }> {\n await this.ready();\n return await clockChangesSince<T>(this.blockstore, this.clock.head, since, opts, this.logger);\n }\n\n async compact(): Promise<void> {\n const blocks = this.blockstore as EncryptedBlockstore;\n return await blocks.compact();\n }\n}\n","export * from \"./types.js\";\n\nexport * from \"./store-factory.js\";\nexport * from \"./serde-gateway.js\";\nexport * from \"./gateway.js\";\n\nexport * from \"./fp-envelope.js\";\n\nexport * from \"./store-factory.js\";\nexport * from \"./interceptor-gateway.js\";\n\nexport { createDbMetaEvent } from \"./store.js\";\n\nexport * from \"./register-store-protocol.js\";\n\nexport { EncryptedBlockstore, BaseBlockstore, CompactionFetcher, type BlockFetcher, CarTransaction } from \"./transaction.js\";\nexport { Loader } from \"./loader.js\";\nexport { parseCarFile } from \"./loader-helpers.js\";\nexport { ConnectionBase } from \"./connection-base.js\";\n// export { setCryptoKeyFromGatewayMetaPayload, addCryptoKeyToGatewayMetaPayload } from \"./meta-key-helper.js\";\n","import type { CID, Link, Version } from \"multiformats\";\nimport type { BlockCodec } from \"../runtime/wait-pr-multiformats/codec-interface.js\";\nimport { DocFileMeta, Falsy, StoreType, SuperThis } from \"../types.js\";\nimport { BlockFetcher, CarTransaction } from \"./transaction.js\";\nimport { CommitQueue } from \"./commit-queue.js\";\nimport { KeyBag, KeyBagRuntime } from \"../runtime/key-bag.js\";\nimport { CoerceURI, CryptoRuntime, CTCryptoKey, Logger, Result, URI } from \"@adviser/cement\";\nimport { EventBlock } from \"@fireproof/vendor/@web3-storage/pail/clock\";\nimport { TaskManager } from \"./task-manager.js\";\nimport { SerdeGateway, SerdeGatewayInterceptor } from \"./serde-gateway.js\";\nimport { CarReader } from \"@fireproof/vendor/@ipld/car\";\n\nexport type AnyLink = Link<unknown, number, number, Version>;\nexport type CarGroup = AnyLink[];\nexport type CarLog = CarGroup[];\nexport type AnyAnyLink = Link<unknown, number, number, Version>;\n\nexport type AnyLinkFn = (cid: AnyLink) => Promise<AnyBlock | undefined>;\n\nexport interface AnyBlock {\n readonly cid: Link<unknown, number, number, Version>;\n readonly bytes: Uint8Array;\n}\n\nexport interface CIDBlock {\n readonly cid: CID<unknown, number, number, Version>;\n readonly bytes: Uint8Array;\n}\n\nexport function toCIDBlock(block: AnyBlock): CIDBlock {\n return block as CIDBlock;\n}\nexport interface AnyAnyBlock {\n readonly cid: AnyAnyLink;\n readonly bytes: Uint8Array;\n}\n\n// export interface EncryptOpts {\n// readonly key: ArrayBuffer;\n// readonly cid: AnyLink;\n// readonly bytes: Uint8Array;\n// }\n\nexport interface IvKeyIdData {\n readonly iv: Uint8Array;\n readonly keyId: Uint8Array;\n readonly data: Uint8Array;\n}\n\nexport interface IvAndBytes {\n readonly bytes: Uint8Array;\n readonly iv: Uint8Array;\n}\n\nexport interface BytesWithIv {\n readonly bytes: Uint8Array;\n readonly iv?: Uint8Array;\n}\n\n// export interface DecryptOpts {\n// readonly key: ArrayBuffer;\n// readonly value: IvAndBytes;\n// }\n\nexport interface AnyDecodedBlock {\n readonly cid: AnyLink;\n readonly bytes: Uint8Array;\n readonly value: Uint8Array;\n}\n\nexport interface CarMakeable {\n entries(): Iterable<AnyBlock>;\n get(cid: AnyLink): Promise<AnyBlock | undefined>;\n}\n\nexport interface CarHeader<T> {\n readonly cars: CarLog;\n readonly compact: CarLog;\n readonly meta: T;\n}\n\n// type NestedData =\n// | Uint8Array\n// | string\n// | number\n// | boolean\n// | undefined\n// | null\n// | AnyLink\n// | NestedData[]\n// | { [key: string]: NestedData };\n\nexport interface TransactionWrapper<M extends TransactionMeta> {\n meta: M;\n cars?: CarGroup;\n t: CarTransaction;\n}\n\nexport type TransactionMeta = unknown;\n//CRDTMeta | IndexTransactionMeta | FileTransactionMeta;\n\n// export interface MakeCodecCrypto {\n// subtle: {\n// decrypt: (algo: { name: string; iv: Uint8Array; tagLength: number }, key: CryptoKey, data: Uint8Array) => Promise<ArrayBuffer>;\n// encrypt: (algo: { name: string; iv: Uint8Array; tagLength: number }, key: CryptoKey, data: Uint8Array) => Promise<ArrayBuffer>;\n// };\n// }\n\n// an implementation of this Interface contains the keymaterial\n// so that the fp-core can use the decrypt and encrypt without knowing the key\nexport interface EncryptedBlock {\n readonly value: IvAndBytes;\n}\n\nexport interface KeyMaterial {\n readonly key: Uint8Array;\n readonly keyStr: string;\n}\n\nexport interface KeyWithFingerPrint {\n readonly fingerPrint: string;\n readonly key: CTCryptoKey;\n}\n\nexport interface KeyWithFingerExtract extends KeyWithFingerPrint {\n extract(): Promise<KeyMaterial>;\n}\n\nexport interface CodecOpts {\n readonly ivCalc: \"random\" | \"hash\";\n readonly noIVVerify: boolean;\n}\nexport interface KeyedCrypto {\n readonly ivLength: number; // in bytes only 12 and 16 are allowed\n readonly logger: Logger;\n readonly crypto: CryptoRuntime;\n readonly url: URI;\n // readonly codec: BlockCodec<number, IvAndBytes>;\n // readonly isEncrypting: boolean;\n fingerPrint(): Promise<string>;\n algo(iv?: Uint8Array): { name: string; iv: Uint8Array; tagLength: number };\n codec(iv?: Uint8Array, codecOpts?: Partial<CodecOpts>): BlockCodec<number, Uint8Array>;\n _decrypt(data: IvAndBytes): Promise<Uint8Array>;\n _encrypt(data: BytesWithIv): Promise<Uint8Array>;\n // encode(data: Uint8Array): Promise<Uint8Array>;\n // decode(bytes: Uint8Array | ArrayBuffer): Promise<Uint8Array>;\n}\n\nexport interface BlobLike {\n /**\n * Returns a ReadableStream which yields the Blob data.\n */\n stream: () => ReadableStream;\n}\n\nexport interface StoreFactory {\n makeMetaStore?: (loader: Loadable) => Promise<MetaStore>;\n makeDataStore?: (loader: Loadable) => Promise<DataStore>;\n makeWALStore?: (loader: Loadable) => Promise<WALStore>;\n\n encodeFile?: (blob: BlobLike) => Promise<{ cid: AnyLink; blocks: AnyBlock[] }>;\n decodeFile?: (blocks: unknown, cid: AnyLink, meta: DocFileMeta) => Promise<File>;\n}\n\nexport interface StoreUrls {\n // string means local storage\n // URL means schema selects the storeType\n // readonly base: CoerceURI;\n readonly meta: CoerceURI;\n readonly data: CoerceURI;\n // readonly index: CoerceURI;\n readonly wal: CoerceURI;\n}\n\n// export interface StoreUrlBaseOpts {\n// readonly base?: CoerceURI;\n// readonly data?: Partial<StoreUrls>\n// readonly idx?: Partial<StoreUrls>\n// }\n\nexport interface StoreEnDeFile {\n readonly encodeFile: (blob: BlobLike) => Promise<{ cid: AnyLink; blocks: AnyBlock[] }>;\n readonly decodeFile: (blocks: unknown, cid: AnyLink, meta: DocFileMeta) => Promise<File>;\n}\n\nexport interface StoreUrlsOpts {\n // readonly urls?: StoreUrlBaseOpts;\n // readonly func?: StoreFactory;\n readonly base?: CoerceURI;\n readonly data?: Partial<StoreUrls>;\n readonly idx?: Partial<StoreUrls>;\n}\n\nexport interface StoreURIs {\n readonly meta: URI;\n readonly data: URI;\n readonly file: URI;\n readonly wal: URI;\n}\n\nexport interface StoreURIRuntime {\n readonly data: StoreURIs;\n readonly idx: StoreURIs;\n}\n\nexport interface StoreFactoryItem {\n readonly sthis: SuperThis;\n readonly url: URI;\n readonly gatewayInterceptor?: SerdeGatewayInterceptor;\n // readonly keybag: KeyBag;\n readonly loader: Loadable;\n}\n\nexport interface StoreRuntime {\n // readonly isIndex?: string; // index prefix\n //xx readonly stores: Partial<Stores>;\n // the factories should produce ready-to-use stores\n // which means they have to call start() on the store\n // to fullfill lifecycle requirements\n // to release resources, like one ledger connection\n // for all stores a refcount on close() should be used\n makeMetaStore(sfi: StoreFactoryItem): Promise<MetaStore>;\n makeDataStore(sfi: StoreFactoryItem): Promise<DataStore>;\n makeWALStore(sfi: StoreFactoryItem): Promise<WALStore>;\n encodeFile(blob: BlobLike): Promise<{ cid: AnyLink; blocks: AnyBlock[] }>;\n decodeFile(blocks: unknown, cid: AnyLink, meta: DocFileMeta): Promise<File>;\n}\n\nexport interface CommitOpts {\n readonly noLoader?: boolean;\n readonly compact?: boolean;\n // readonly public?: boolean;\n}\n\nexport interface DbMeta {\n readonly cars: CarGroup;\n // key?: string;\n}\n\n// export interface UploadMetaFnParams {\n// readonly name: string;\n// readonly branch: string;\n// }\n\n// export type FnParamTypes = \"data\" | \"file\";\n\n// export interface UploadDataFnParams {\n// readonly type: FnParamTypes;\n// readonly name: string;\n// readonly car: string;\n// readonly size: string;\n// }\n\n// export interface DownloadDataFnParams {\n// readonly type: FnParamTypes;\n// readonly name: string;\n// readonly car: string;\n// }\n\n// export interface DownloadMetaFnParams {\n// readonly name: string;\n// readonly branch: string;\n// }\n\nexport type LoadHandler = (dbMetas: DbMeta[]) => Promise<void>;\n\nexport interface RefLoadable {\n readonly loader: Loadable;\n}\nexport interface RefBlockstore {\n readonly blockstore: RefLoadable;\n}\n\nexport interface Connection {\n // readonly loader?: Loadable;\n readonly loaded: Promise<void>;\n // connectMeta(ref: RefLoadable | RefBlockstore): void;\n connectStorage(ref: RefLoadable | RefBlockstore): void;\n\n // metaUpload(bytes: Uint8Array, params: UploadMetaFnParams): Promise<Uint8Array[] | Falsy>;\n // dataUpload(bytes: Uint8Array, params: UploadDataFnParams, opts?: { public?: boolean }): Promise<void>;\n // metaDownload(params: DownloadMetaFnParams): Promise<Uint8Array[] | Falsy>;\n // dataDownload(params: DownloadDataFnParams): Promise<Uint8Array | Falsy>;\n}\n\nexport interface BaseStore {\n readonly storeType: StoreType;\n readonly realGateway: SerdeGateway;\n // readonly url: URI\n url(): URI;\n // readonly name: string;\n onStarted(fn: () => void): void;\n onClosed(fn: () => void): void;\n\n keyedCrypto(): Promise<KeyedCrypto>;\n\n close(): Promise<Result<void>>;\n destroy(): Promise<Result<void>>;\n readonly ready?: () => Promise<void>;\n start(): Promise<Result<URI>>;\n}\n\nexport interface DbMetaEvent {\n readonly eventCid: CarClockLink;\n readonly parents: CarClockHead;\n readonly dbMeta: DbMeta;\n}\n\nexport function DbMetaEventEqual(a: DbMetaEvent, b: DbMetaEvent): boolean {\n return (\n a.eventCid.equals(b.eventCid) &&\n a.parents.length === b.parents.length &&\n a.parents.every((p, i) => p.equals(b.parents[i])) &&\n a.dbMeta.cars.length === b.dbMeta.cars.length &&\n a.dbMeta.cars.every((c, i) => c.equals(b.dbMeta.cars[i]))\n );\n}\n\nexport function DbMetaEventsEqual(a: DbMetaEvent[], b: DbMetaEvent[]): boolean {\n return a.length === b.length && a.every((e, i) => DbMetaEventEqual(e, b[i]));\n}\n\nexport interface MetaStore extends BaseStore {\n readonly storeType: \"meta\";\n load(branch?: string): Promise<DbMeta[] | Falsy>;\n // branch is defaulted to \"main\"\n save(meta: DbMeta, branch?: string): Promise<Result<void>>;\n // onLoad(branch: string, loadHandler: LoadHandler): () => void;\n // handleByteHeads(byteHeads: Uint8Array, branch?: string): Promise<DbMetaEvent[]>;\n}\n\n// export interface RemoteMetaStore extends MetaStore {\n// }\n\nexport interface DataSaveOpts {\n readonly public: boolean;\n}\n\nexport interface DataStore extends BaseStore {\n readonly storeType: \"data\";\n load(cid: AnyLink): Promise<AnyBlock>;\n save(car: AnyBlock, opts?: DataSaveOpts): Promise</*AnyLink | */ void>;\n remove(cid: AnyLink): Promise<Result<void>>;\n}\n\nexport interface WALState {\n readonly operations: DbMeta[];\n readonly noLoaderOps: DbMeta[];\n readonly fileOperations: {\n readonly cid: AnyLink;\n readonly public: boolean;\n }[];\n}\n\nexport interface WALStore extends BaseStore {\n readonly storeType: \"wal\";\n ready(): Promise<void>;\n readonly processing?: Promise<void> | undefined;\n readonly processQueue: CommitQueue<void>;\n\n process(): Promise<void>;\n enqueue(dbMeta: DbMeta, opts: CommitOpts): Promise<void>;\n enqueueFile(fileCid: AnyLink /*, publicFile?: boolean*/): Promise<void>;\n load(): Promise<WALState | Falsy>;\n save(state: WALState): Promise<void>;\n}\n\nexport type CompactFetcher = BlockFetcher & {\n readonly loggedBlocks: CarTransaction;\n};\nexport type CompactFn = (blocks: CompactFetcher) => Promise<TransactionMeta>;\n\nexport interface StoreRuntimeUrls {\n readonly meta: URI;\n readonly data: URI;\n readonly wal: URI;\n}\n\nexport interface BlockstoreParams {\n readonly logger: Logger;\n readonly applyMeta: (meta: TransactionMeta, snap?: boolean) => Promise<void>;\n readonly compact: CompactFn;\n readonly autoCompact: number;\n readonly crypto: CryptoRuntime;\n readonly public: boolean;\n readonly meta: DbMeta;\n readonly threshold: number;\n readonly gatewayInterceptor?: SerdeGatewayInterceptor;\n readonly storeEnDeFile: Partial<StoreEnDeFile>;\n readonly keyBag: KeyBagRuntime;\n readonly storeUrls: StoreURIs;\n readonly storeRuntime: StoreRuntime;\n}\n\nexport type BlockstoreOpts = Partial<BlockstoreParams> & {\n readonly keyBag: KeyBagRuntime;\n readonly storeUrls: StoreURIs;\n readonly storeRuntime: StoreRuntime;\n};\n\nexport interface BlockstoreRuntime {\n readonly logger: Logger;\n readonly applyMeta: (meta: TransactionMeta, snap?: boolean) => Promise<void>;\n readonly compact: CompactFn;\n readonly autoCompact: number;\n readonly crypto: CryptoRuntime;\n readonly storeRuntime: StoreRuntime;\n readonly keyBag: KeyBagRuntime;\n readonly storeUrls: StoreURIs;\n readonly gatewayInterceptor?: SerdeGatewayInterceptor;\n // readonly storeEnDeFile: StoreEnDeFile;\n // readonly public: boolean;\n readonly meta?: DbMeta;\n // readonly name?: string;\n readonly threshold: number;\n}\n\nexport interface Loadable {\n // readonly name: string; // = \"\";\n readonly sthis: SuperThis;\n readonly ebOpts: BlockstoreRuntime;\n carLog: CarLog;\n remoteMetaStore?: MetaStore;\n remoteFileStore?: DataStore;\n remoteCarStore?: DataStore;\n readonly taskManager: TaskManager;\n\n ready(): Promise<void>;\n close(): Promise<void>;\n\n keyBag(): Promise<KeyBag>;\n metaStore(): Promise<MetaStore>;\n fileStore(): Promise<DataStore>;\n WALStore(): Promise<WALStore>;\n carStore(): Promise<DataStore>;\n\n handleDbMetasFromStore(metas: DbMeta[]): Promise<void>;\n\n commit<T = TransactionMeta>(t: CarTransaction, done: T, opts: CommitOpts): Promise<CarGroup>;\n destroy(): Promise<void>;\n getBlock(cid: AnyLink): Promise<AnyBlock | Falsy>;\n loadFileCar(cid: AnyLink /*, isPublic = false*/): Promise<CarReader>;\n loadCar(cid: AnyLink): Promise<CarReader>;\n commitFiles(\n t: CarTransaction,\n done: TransactionMeta /* opts: CommitOpts = { noLoader: false, compact: false } */,\n ): Promise<CarGroup>;\n entries(cache?: boolean): AsyncIterableIterator<AnyBlock>;\n}\n\nexport interface DbMetaBinary {\n readonly dbMeta: Uint8Array;\n}\nexport type DbMetaEventBlock = EventBlock<DbMetaBinary>;\nexport type CarClockLink = Link<DbMetaEventBlock, number, number, Version>;\nexport type CarClockHead = CarClockLink[];\n","import { Logger, KeyedResolvOnce, URI, Result } from \"@adviser/cement\";\n\nimport { decodeFile, encodeFile } from \"../runtime/files.js\";\nimport { DataStoreImpl, MetaStoreImpl, WALStoreImpl } from \"./store.js\";\nimport { StoreEnDeFile, StoreFactoryItem, StoreRuntime } from \"./types.js\";\nimport { PARAM, SuperThis } from \"../types.js\";\nimport { getGatewayFactoryItem } from \"./register-store-protocol.js\";\nimport { SerdeGateway } from \"./serde-gateway.js\";\n\ninterface SerdeGatewayInstances {\n readonly gateway: SerdeGateway;\n}\ninterface GatewayReady extends SerdeGatewayInstances {\n readonly url: URI;\n}\n\nconst onceGateway = new KeyedResolvOnce<GatewayReady>();\nconst gatewayInstances = new KeyedResolvOnce<SerdeGatewayInstances>();\nexport async function getStartedGateway(sthis: SuperThis, url: URI): Promise<Result<GatewayReady>> {\n return onceGateway.get(url.toString()).once(async () => {\n const item = getGatewayFactoryItem(url.protocol);\n if (item) {\n const ret = {\n url,\n ...(await gatewayInstances.get(url.protocol).once(async () => ({}))),\n gateway: await item.serdegateway(sthis),\n };\n const res = await ret.gateway.start(sthis, url);\n if (res.isErr()) {\n return Result.Err(sthis.logger.Error().Result(\"start\", res).Msg(\"start failed\").AsError());\n }\n ret.url = res.Ok();\n return Result.Ok(ret);\n }\n return Result.Err(sthis.logger.Warn().Url(url).Msg(\"unsupported protocol\").AsError());\n });\n}\n\nasync function dataStoreFactory(sfi: StoreFactoryItem): Promise<DataStoreImpl> {\n const storeUrl = sfi.url.build().setParam(PARAM.STORE, \"data\").URI();\n const rgateway = await getStartedGateway(sfi.sthis, storeUrl);\n if (rgateway.isErr()) {\n throw sfi.sthis.logger.Error().Result(\"err\", rgateway).Url(sfi.url).Msg(\"notfound\").AsError();\n }\n const gateway = rgateway.Ok();\n const store = new DataStoreImpl(sfi.sthis, gateway.url, {\n gateway: gateway.gateway,\n gatewayInterceptor: sfi.gatewayInterceptor,\n loader: sfi.loader,\n });\n return store;\n}\n\n// const onceLoadMetaGateway = new KeyedResolvOnce<Gateway>();\n// function loadMetaGateway(url: URI, logger: Logger) {\n// return onceLoadMetaGateway.get(url.protocol).once(async () => {\n// return await getGatewayFromURL(url, logger).then((item) => {\n// if (!item) {\n// throw logger.Error().Url(url).Msg(\"unsupported protocol or store\").AsError();\n// }\n// return item;\n// });\n// });\n// }\n\n// const onceMetaStoreFactory = new KeyedResolvOnce<MetaStoreImpl>();\nasync function metaStoreFactory(sfi: StoreFactoryItem): Promise<MetaStoreImpl> {\n const storeUrl = sfi.url.build().setParam(PARAM.STORE, \"meta\").URI();\n const rgateway = await getStartedGateway(sfi.sthis, storeUrl);\n if (rgateway.isErr()) {\n throw sfi.sthis.logger.Error().Result(\"err\", rgateway).Url(sfi.url).Msg(\"notfound\").AsError();\n }\n const gateway = rgateway.Ok();\n const store = new MetaStoreImpl(sfi.sthis, gateway.url, {\n gateway: gateway.gateway,\n gatewayInterceptor: sfi.gatewayInterceptor,\n loader: sfi.loader,\n });\n return store;\n}\n\n// const onceWalGateway = new KeyedResolvOnce<Gateway>();\n// function loadWalGateway(url: URI, logger: Logger) {\n// return onceWalGateway.get(url.protocol).once(async () => {\n// return await getGatewayFromURL(url, logger).then((item) => {\n// if (!item) {\n// throw logger.Error().Url(url).Msg(\"unsupported protocol or store\").AsError();\n// }\n// return item;\n// });\n// });\n// }\n\n// const onceRemoteWalFactory = new KeyedResolvOnce<WALStoreImpl>();\nasync function WALStoreFactory(sfi: StoreFactoryItem): Promise<WALStoreImpl> {\n const storeUrl = sfi.url.build().setParam(PARAM.STORE, \"wal\").URI();\n const rgateway = await getStartedGateway(sfi.sthis, storeUrl);\n if (rgateway.isErr()) {\n throw sfi.sthis.logger.Error().Result(\"err\", rgateway).Url(sfi.url).Msg(\"notfound\").AsError();\n }\n const gateway = rgateway.Ok();\n const store = new WALStoreImpl(sfi.sthis, gateway.url, {\n gateway: gateway.gateway,\n gatewayInterceptor: sfi.gatewayInterceptor,\n loader: sfi.loader,\n });\n return store;\n}\n\nasync function ensureStart<T>(store: T & { start: () => Promise<Result<URI>>; logger: Logger }): Promise<T> {\n const ret = await store.start();\n if (ret.isErr()) {\n throw store.logger.Error().Result(\"start\", ret).Msg(\"start failed\").AsError();\n }\n store.logger.Debug().Url(ret.Ok(), \"prepared\").Msg(\"produced\");\n return store;\n}\n\nexport function ensureStoreEnDeFile(ende?: Partial<StoreEnDeFile>): StoreEnDeFile {\n ende = ende || {};\n return {\n encodeFile: ende.encodeFile || encodeFile,\n decodeFile: ende.decodeFile || decodeFile,\n };\n}\n\nexport function toStoreRuntime(sthis: SuperThis, endeOpts: Partial<StoreEnDeFile> = {}): StoreRuntime {\n // const logger = ensureLogger(sthis, \"toStoreRuntime\", {});\n return {\n makeMetaStore: async (sfi: StoreFactoryItem) => ensureStart(await metaStoreFactory(sfi)),\n // async (loader: Loadable) => {\n // logger\n // .Debug()\n // .Str(\"fromOpts\", \"\" + !!endeOpts.func?.makeMetaStore)\n // .Msg(\"makeMetaStore\");\n // return ensureStart(await (endeOpts.func?.makeMetaStore || metaStoreFactory)(loader), logger);\n // },\n makeDataStore: async (sfi: StoreFactoryItem) => ensureStart(await dataStoreFactory(sfi)),\n // async (loader: Loadable) => {\n // logger\n // .Debug()\n // .Str(\"fromOpts\", \"\" + !!endeOpts.func?.makeDataStore)\n // .Msg(\"makeDataStore\");\n // return ensureStart(await (endeOpts.func?.makeDataStore || dataStoreFactory)(loader), logger);\n // },\n makeWALStore: async (sfi: StoreFactoryItem) => ensureStart(await WALStoreFactory(sfi)),\n // async (loader: Loadable) => {\n // logger\n // .Debug()\n // .Str(\"fromOpts\", \"\" + !!endeOpts.func?.makeWALStore)\n // .Msg(\"makeRemoteWAL\");\n // return ensureStart(await (endeOpts.func?.makeWALStore || remoteWalFactory)(loader), logger);\n // },\n\n ...ensureStoreEnDeFile(endeOpts),\n };\n}\n","import * as UnixFS from \"@ipld/unixfs\";\nimport * as raw from \"multiformats/codecs/raw\";\nimport { withMaxChunkSize } from \"@ipld/unixfs/file/chunker/fixed\";\nimport { withWidth } from \"@ipld/unixfs/file/layout/balanced\";\n\nimport type { View } from \"@ipld/unixfs\";\nimport { DocFileMeta } from \"../types.js\";\n\nimport { exporter, ReadableStorage } from \"@fireproof/vendor/ipfs-unixfs-exporter\";\nimport { BlobLike, AnyLink, AnyBlock } from \"../blockstore/index.js\";\n\nconst queuingStrategy = UnixFS.withCapacity();\n\nconst settings = UnixFS.configure({\n fileChunkEncoder: raw,\n smallFileEncoder: raw,\n chunker: withMaxChunkSize(1024 * 1024),\n fileLayout: withWidth(1024),\n});\n\nasync function collect<T>(collectable: ReadableStream<T>): Promise<T[]> {\n const chunks: T[] = [];\n await collectable.pipeTo(\n new WritableStream({\n write(chunk) {\n chunks.push(chunk);\n },\n }),\n );\n return chunks;\n}\n\nexport async function encodeFile(blob: BlobLike): Promise<{ cid: AnyLink; blocks: AnyBlock[] }> {\n const readable = createFileEncoderStream(blob);\n const blocks = await collect(readable);\n return { cid: blocks.at(-1).cid, blocks };\n}\n\nexport async function decodeFile(blocks: unknown, cid: AnyLink, meta: DocFileMeta): Promise<File> {\n const entry = await exporter(cid.toString(), blocks as ReadableStorage, { length: meta.size });\n const chunks = [];\n for await (const chunk of entry.content()) {\n chunks.push(chunk);\n }\n return new File(chunks, entry.name, { type: meta.type, lastModified: 0 });\n}\n\nfunction createFileEncoderStream(blob: BlobLike) {\n const { readable, writable } = new TransformStream({}, queuingStrategy);\n const unixfsWriter = UnixFS.createWriter({ writable, settings });\n const fileBuilder = new UnixFSFileBuilder(\"\", blob);\n void (async () => {\n await fileBuilder.finalize(unixfsWriter);\n await unixfsWriter.close();\n })();\n return readable;\n}\n\nclass UnixFSFileBuilder {\n #file;\n readonly name: string;\n constructor(name: string, file: BlobLike) {\n this.name = name;\n this.#file = file;\n }\n\n async finalize(writer: View) {\n const unixfsFileWriter = UnixFS.createFileWriter(writer);\n await this.#file.stream().pipeTo(\n new WritableStream({\n async write(chunk) {\n await unixfsFileWriter.write(chunk as Uint8Array);\n },\n }),\n );\n return await unixfsFileWriter.close();\n }\n}\n","import { exception2Result, Logger, ResolveOnce, Result, URI } from \"@adviser/cement\";\nimport type {\n AnyBlock,\n AnyLink,\n CommitOpts,\n DataSaveOpts,\n DataStore,\n DbMeta,\n WALStore as WALStore,\n WALState,\n LoadHandler,\n KeyedCrypto,\n Loadable,\n CarClockHead,\n DbMetaBinary,\n CarClockLink,\n DbMetaEvent,\n MetaStore,\n} from \"./types.js\";\nimport { Falsy, PARAM, StoreType, SuperThis, throwFalsy } from \"../types.js\";\nimport { SerdeGateway, SerdeGatewayInterceptor } from \"./serde-gateway.js\";\nimport { ensureLogger, inplaceFilter, isNotFoundError } from \"../utils.js\";\nimport { carLogIncludesGroup } from \"./loader.js\";\nimport { CommitQueue } from \"./commit-queue.js\";\nimport { keyedCryptoFactory } from \"../runtime/keyed-crypto.js\";\nimport { Car2FPMsg, File2FPMsg, FPEnvelopeCar, FPEnvelopeFile, FPEnvelopeMeta, FPEnvelopeWAL } from \"./fp-envelope.js\";\nimport { EventView } from \"@fireproof/vendor/@web3-storage/pail/clock/api\";\nimport { EventBlock } from \"@fireproof/vendor/@web3-storage/pail/clock\";\nimport { format } from \"@fireproof/vendor/@ipld/dag-json\";\n// import { createDbMetaEventBlock } from \"./meta-key-helper.js\";\nimport pRetry from \"p-retry\";\nimport pMap from \"p-map\";\nimport { Link } from \"multiformats\";\nimport { InterceptorGateway } from \"./interceptor-gateway.js\";\n\nfunction guardVersion(url: URI): Result<URI> {\n if (!url.hasParam(\"version\")) {\n return Result.Err(`missing version: ${url.toString()}`);\n }\n return Result.Ok(url);\n}\n\nexport interface StoreOpts {\n readonly gateway: SerdeGateway;\n // readonly keybag: KeyBag;\n readonly gatewayInterceptor?: SerdeGatewayInterceptor;\n readonly loader: Loadable;\n}\n\nexport abstract class BaseStoreImpl {\n // should be injectable\n\n abstract readonly storeType: StoreType;\n // readonly name: string;\n\n private _url: URI;\n readonly logger: Logger;\n readonly sthis: SuperThis;\n readonly gateway: SerdeGateway;\n readonly realGateway: SerdeGateway;\n // readonly keybag: KeyBag;\n readonly opts: StoreOpts;\n readonly loader: Loadable;\n // readonly loader: Loadable;\n constructor(sthis: SuperThis, url: URI, opts: StoreOpts, logger: Logger) {\n // this.name = name;\n this._url = url;\n this.opts = opts;\n // this.keybag = opts.keybag;\n this.loader = opts.loader;\n this.sthis = sthis;\n const name = this._url.getParam(PARAM.NAME);\n if (!name) {\n throw logger.Error().Url(this._url).Msg(\"missing name\").AsError();\n }\n this.logger = logger\n .With()\n .Str(\"this\", this.sthis.nextId().str)\n .Ref(\"url\", () => this._url.toString())\n // .Str(\"name\", name)\n .Logger();\n this.realGateway = opts.gateway;\n this.gateway = new InterceptorGateway(this.sthis, opts.gateway, opts.gatewayInterceptor);\n }\n\n url(): URI {\n return this._url;\n }\n\n readonly _onStarted: (() => void)[] = [];\n onStarted(fn: () => void) {\n this._onStarted.push(fn);\n }\n readonly _onClosed: (() => void)[] = [];\n onClosed(fn: () => void) {\n this._onClosed.push(fn);\n }\n abstract close(): Promise<Result<void>>;\n\n async ready() {\n return;\n }\n\n async keyedCrypto(): Promise<KeyedCrypto> {\n return keyedCryptoFactory(this._url, await this.loader.keyBag(), this.sthis);\n }\n\n async start(): Promise<Result<URI>> {\n this.logger.Debug().Str(\"storeType\", this.storeType).Msg(\"starting-gateway-pre\");\n this._url = this._url.build().setParam(PARAM.STORE, this.storeType).URI();\n const res = await this.gateway.start(this.sthis, this._url, this.loader);\n if (res.isErr()) {\n this.logger.Error().Result(\"gw-start\", res).Msg(\"started-gateway\");\n return res as Result<URI>;\n }\n this._url = res.Ok();\n // add storekey to url\n const kb = await this.loader.keyBag();\n const skRes = await kb.ensureKeyFromUrl(this._url, () => {\n const idx = this._url.getParam(PARAM.INDEX);\n const storeKeyName = [this.url().getParam(PARAM.NAME)];\n if (idx) {\n storeKeyName.push(idx);\n }\n storeKeyName.push(this.storeType);\n return storeKeyName.join(\":\");\n });\n if (skRes.isErr()) {\n return skRes as Result<URI>;\n }\n this._url = skRes.Ok();\n const version = guardVersion(this._url);\n if (version.isErr()) {\n this.logger.Error().Result(\"version\", version).Msg(\"guardVersion\");\n await this.close();\n return version;\n }\n if (this.ready) {\n const fn = this.ready.bind(this);\n const ready = await exception2Result(fn);\n if (ready.isErr()) {\n await this.close();\n return ready as Result<URI>;\n }\n }\n this._onStarted.forEach((fn) => fn());\n this.logger.Debug().Msg(\"started\");\n return version;\n }\n}\n\nexport async function createDbMetaEvent(sthis: SuperThis, dbMeta: DbMeta, parents: CarClockHead): Promise<DbMetaEvent> {\n const event = await EventBlock.create<DbMetaBinary>(\n {\n dbMeta: sthis.txt.encode(format(dbMeta)),\n },\n parents as unknown as Link<EventView<DbMetaBinary>, number, number, 1>[],\n );\n return {\n eventCid: event.cid as CarClockLink,\n dbMeta,\n parents,\n };\n}\n\nexport class MetaStoreImpl extends BaseStoreImpl implements MetaStore {\n readonly storeType = \"meta\";\n readonly subscribers = new Map<string, LoadHandler[]>();\n parents: CarClockHead = [];\n // remote: boolean;\n\n constructor(sthis: SuperThis, url: URI, opts: StoreOpts) {\n // const my = new URL(url.toString());\n // my.searchParams.set(\"storekey\", 'insecure');\n super(sthis, url, { ...opts }, ensureLogger(sthis, \"MetaStoreImpl\"));\n // this.remote = !!remote;\n if (/*this.remote && */ opts.gateway.subscribe) {\n this.onStarted(async () => {\n this.logger.Debug().Str(\"url\", this.url().toString()).Msg(\"Subscribing to the gateway\");\n opts.gateway.subscribe?.(\n this.sthis,\n this.url(),\n async ({ payload: dbMetas }: FPEnvelopeMeta) => {\n this.logger.Debug().Msg(\"Received message from gateway\");\n await Promise.all(\n dbMetas.map((dbMeta) => this.loader.taskManager?.handleEvent(dbMeta.eventCid, dbMeta.parents, dbMeta.dbMeta)),\n );\n this.updateParentsFromDbMetas(dbMetas);\n },\n this.loader,\n );\n });\n }\n }\n\n private updateParentsFromDbMetas(dbMetas: DbMetaEvent[]) {\n const cids = dbMetas.map((m) => m.eventCid);\n const dbMetaParents = dbMetas.flatMap((m) => m.parents);\n const uniqueParentsMap = new Map([...this.parents, ...cids].map((p) => [p.toString(), p]));\n const dbMetaParentsSet = new Set(dbMetaParents.map((p) => p.toString()));\n this.parents = Array.from(uniqueParentsMap.values()).filter((p) => !dbMetaParentsSet.has(p.toString()));\n }\n\n // async handleByteHeads(byteHeads: Uint8Array) {\n // // return await decodeGatewayMetaBytesToDbMeta(this.sthis, byteHeads);\n // const rDbMeta = await fpDeserialize(this.sthis, byteHeads, this.url());\n // if (rDbMeta.isErr()) {\n // throw this.logger.Error().Err(rDbMeta).Msg(\"error deserializing\").AsError();\n // }\n // return (rDbMeta.Ok() as FPEnvelopeMeta).payload;\n // }\n\n async load(): Promise<DbMeta[] | Falsy> {\n const branch = \"main\";\n const url = await this.gateway.buildUrl(this.sthis, this.url(), branch, this.loader);\n if (url.isErr()) {\n throw this.logger.Error().Result(\"buildUrl\", url).Str(\"branch\", branch).Msg(\"got error from gateway.buildUrl\").AsError();\n }\n const rfpEnv = await this.gateway.get(this.sthis, url.Ok(), this.loader);\n if (rfpEnv.isErr()) {\n if (isNotFoundError(rfpEnv)) {\n return undefined;\n }\n throw this.logger.Error().Url(url.Ok()).Err(rfpEnv).Msg(\"gateway get\").AsError();\n }\n const dbMetas = (rfpEnv.Ok() as FPEnvelopeMeta).payload;\n // const dbMetas = await this.handleByteHeads(fpMeta.payload);\n await this.loader.handleDbMetasFromStore(dbMetas.map((m) => m.dbMeta)); // the old one didn't await\n this.updateParentsFromDbMetas(dbMetas);\n return dbMetas.map((m) => m.dbMeta);\n }\n\n async save(meta: DbMeta, branch?: string): Promise<Result<void>> {\n branch = branch || \"main\";\n this.logger.Debug().Str(\"branch\", branch).Any(\"meta\", meta).Msg(\"saving meta\");\n\n // const fpMetas = await encodeEventsWithParents(this.sthis, [event], this.parents);\n const url = await this.gateway.buildUrl(this.sthis, this.url(), branch, this.loader);\n if (url.isErr()) {\n throw this.logger.Error().Err(url.Err()).Str(\"branch\", branch).Msg(\"got error from gateway.buildUrl\").AsError();\n }\n const dbMetaEvent = await createDbMetaEvent(this.sthis, meta, this.parents);\n const res = await this.gateway.put(\n this.sthis,\n url.Ok(),\n {\n type: \"meta\",\n payload: [dbMetaEvent],\n } as FPEnvelopeMeta,\n this.loader,\n );\n if (res.isErr()) {\n throw this.logger.Error().Err(res.Err()).Msg(\"got error from gateway.put\").AsError();\n }\n // await this.loader.handleDbMetasFromStore([meta]);\n // this.loader.taskManager?.eventsWeHandled.add(event.cid.toString());\n return res;\n }\n\n async close(): Promise<Result<void>> {\n await this.gateway.close(this.sthis, this.url(), this.loader);\n this._onClosed.forEach((fn) => fn());\n return Result.Ok(undefined);\n }\n async destroy(): Promise<Result<void>> {\n this.logger.Debug().Msg(\"destroy\");\n return this.gateway.destroy(this.sthis, this.url(), this.loader);\n }\n}\n\nexport class DataStoreImpl extends BaseStoreImpl implements DataStore {\n readonly storeType = \"data\";\n\n constructor(sthis: SuperThis, url: URI, opts: StoreOpts) {\n super(sthis, url, { ...opts }, ensureLogger(sthis, \"DataStoreImpl\"));\n }\n\n async load(cid: AnyLink): Promise<AnyBlock> {\n this.logger.Debug().Any(\"cid\", cid).Msg(\"loading\");\n const url = await this.gateway.buildUrl(this.sthis, this.url(), cid.toString(), this.loader);\n if (url.isErr()) {\n throw this.logger.Error().Err(url.Err()).Str(\"cid\", cid.toString()).Msg(\"got error from gateway.buildUrl\").AsError();\n }\n const res = await this.gateway.get(this.sthis, url.Ok(), this.loader);\n if (res.isErr()) {\n throw res.Err();\n }\n const fpenv = res.Ok() as FPEnvelopeFile | FPEnvelopeCar;\n switch (fpenv.type) {\n case \"car\":\n return { cid, bytes: fpenv.payload };\n case \"file\":\n return { cid, bytes: fpenv.payload };\n default:\n throw this.logger.Error().Msg(\"unexpected type\").AsError();\n }\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n async save(car: AnyBlock, opts?: DataSaveOpts): Promise</*AnyLink | */ void> {\n this.logger.Debug().Any(\"cid\", car.cid.toString()).Msg(\"saving\");\n const url = await this.gateway.buildUrl(this.sthis, this.url(), car.cid.toString(), this.loader);\n if (url.isErr()) {\n throw this.logger.Error().Err(url.Err()).Ref(\"cid\", car.cid).Msg(\"got error from gateway.buildUrl\").AsError();\n }\n // without URL changes in super-this branch we\n // can distinguish between car and file\n let fpMsg: Result<FPEnvelopeCar | FPEnvelopeFile>;\n switch (url.Ok().getParam(PARAM.STORE)) {\n case \"data\":\n if (url.Ok().getParam(PARAM.SUFFIX)) {\n fpMsg = Car2FPMsg(car.bytes);\n } else {\n fpMsg = File2FPMsg(car.bytes);\n }\n break;\n default:\n throw this.logger.Error().Str(\"store\", url.Ok().getParam(PARAM.STORE)).Msg(\"unexpected store\").AsError();\n }\n if (fpMsg.isErr()) {\n throw this.logger.Error().Err(fpMsg).Msg(\"got error from FPMsg2Car\").AsError();\n }\n const res = await this.gateway.put(this.sthis, url.Ok(), fpMsg.Ok(), this.loader);\n if (res.isErr()) {\n throw this.logger.Error().Err(res.Err()).Msg(\"got error from gateway.put\").AsError();\n }\n return res.Ok();\n }\n async remove(cid: AnyLink): Promise<Result<void>> {\n const url = await this.gateway.buildUrl(this.sthis, this.url(), cid.toString(), this.loader);\n if (url.isErr()) {\n return url;\n }\n return this.gateway.delete(this.sthis, url.Ok(), this.loader);\n }\n async close(): Promise<Result<void>> {\n await this.gateway.close(this.sthis, this.url(), this.loader);\n this._onClosed.forEach((fn) => fn());\n return Result.Ok(undefined);\n }\n destroy(): Promise<Result<void>> {\n this.logger.Debug().Msg(\"destroy\");\n return this.gateway.destroy(this.sthis, this.url(), this.loader);\n }\n}\n\nexport class WALStoreImpl extends BaseStoreImpl implements WALStore {\n readonly storeType = \"wal\";\n // readonly tag: string = \"rwal-base\";\n\n // readonly loader: Loadable;\n\n readonly _ready = new ResolveOnce<void>();\n\n readonly walState: WALState = { operations: [], noLoaderOps: [], fileOperations: [] };\n readonly processing: Promise<void> | undefined = undefined;\n readonly processQueue: CommitQueue<void> = new CommitQueue<void>();\n\n constructor(sthis: SuperThis, url: URI, opts: StoreOpts) {\n // const my = new URL(url.toString());\n // my.searchParams.set(\"storekey\", 'insecure');\n super(sthis, url, { ...opts }, ensureLogger(sthis, \"WALStoreImpl\"));\n // this.loader = loader;\n }\n\n async ready(): Promise<void> {\n return this._ready.once(async () => {\n const walState = await this.load().catch((e) => {\n this.logger.Error().Err(e).Msg(\"error loading wal\");\n return undefined;\n });\n this.walState.operations.splice(0, this.walState.operations.length);\n this.walState.fileOperations.splice(0, this.walState.fileOperations.length);\n if (walState) {\n this.walState.operations.push(...walState.operations);\n this.walState.fileOperations.push(...walState.fileOperations);\n }\n });\n }\n\n async enqueue(dbMeta: DbMeta, opts: CommitOpts) {\n await this.ready();\n if (opts.compact) {\n this.walState.operations.splice(0, this.walState.operations.length);\n this.walState.noLoaderOps.splice(0, this.walState.noLoaderOps.length);\n this.walState.noLoaderOps.push(dbMeta);\n } else if (opts.noLoader) {\n this.walState.noLoaderOps.push(dbMeta);\n } else {\n this.walState.operations.push(dbMeta);\n }\n await this.save(this.walState);\n if (!opts.noLoader) {\n void this.process();\n }\n }\n\n async enqueueFile(fileCid: AnyLink, publicFile = false) {\n await this.ready();\n this.walState.fileOperations.push({ cid: fileCid, public: publicFile });\n // await this.save(this.walState)\n }\n\n async process() {\n await this.ready();\n if (!this.loader.remoteCarStore) return;\n await this.processQueue.enqueue(async () => {\n try {\n await this._doProcess();\n } catch (e) {\n this.logger.Error().Any(\"error\", e).Msg(\"error processing wal\");\n }\n if (this.walState.operations.length || this.walState.fileOperations.length || this.walState.noLoaderOps.length) {\n setTimeout(() => void this.process(), 0);\n }\n });\n }\n\n async _doProcess() {\n if (!this.loader) return;\n if (!this.loader.remoteCarStore) return;\n\n const operations = [...this.walState.operations];\n const noLoaderOps = [...this.walState.noLoaderOps];\n const fileOperations = [...this.walState.fileOperations];\n\n if (operations.length + noLoaderOps.length + fileOperations.length === 0) return;\n\n const concurrencyLimit = 3;\n\n // Helper function to retry uploads\n const retryableUpload = <T>(fn: () => Promise<T>, description: string) =>\n pRetry(fn, {\n retries: 5,\n onFailedAttempt: (error) => {\n this.logger\n .Warn()\n .Msg(`Attempt ${error.attemptNumber} failed for ${description}. There are ${error.retriesLeft} retries left.`);\n },\n });\n\n try {\n // Process noLoaderOps\n await pMap(\n noLoaderOps,\n async (dbMeta) => {\n await retryableUpload(async () => {\n if (!this.loader) {\n return;\n }\n for (const cid of dbMeta.cars) {\n const car = await (await this.loader.carStore()).load(cid);\n if (!car) {\n if (carLogIncludesGroup(this.loader.carLog, dbMeta.cars)) {\n throw this.logger.Error().Ref(\"cid\", cid).Msg(\"missing local car\").AsError();\n }\n } else {\n await throwFalsy(this.loader.remoteCarStore).save(car);\n }\n }\n // Remove from walState after successful upload\n inplaceFilter(this.walState.noLoaderOps, (op) => op !== dbMeta);\n }, `noLoaderOp with dbMeta.cars=${dbMeta.cars.toString()}`);\n },\n { concurrency: concurrencyLimit },\n );\n\n // Process operations\n await pMap(\n operations,\n async (dbMeta) => {\n await retryableUpload(async () => {\n if (!this.loader) {\n return;\n }\n for (const cid of dbMeta.cars) {\n const car = await (await this.loader.carStore()).load(cid);\n if (!car) {\n if (carLogIncludesGroup(this.loader.carLog, dbMeta.cars)) {\n throw this.logger.Error().Ref(\"cid\", cid).Msg(`missing local car`).AsError();\n }\n } else {\n await throwFalsy(this.loader.remoteCarStore).save(car);\n }\n }\n // Remove from walState after successful upload\n inplaceFilter(this.walState.operations, (op) => op !== dbMeta);\n }, `operation with dbMeta.cars=${dbMeta.cars.toString()}`);\n },\n { concurrency: concurrencyLimit },\n );\n\n // Process fileOperations\n await pMap(\n fileOperations,\n async ({ cid: fileCid, public: publicFile }) => {\n await retryableUpload(async () => {\n if (!this.loader) {\n return;\n }\n const fileBlock = await (await this.loader.fileStore()).load(fileCid);\n if (!fileBlock) {\n throw this.logger.Error().Ref(\"cid\", fileCid).Msg(\"missing file block\").AsError();\n }\n await this.loader.remoteFileStore?.save(fileBlock, { public: publicFile });\n // Remove from walState after successful upload\n inplaceFilter(this.walState.fileOperations, (op) => op.cid !== fileCid);\n }, `fileOperation with cid=${fileCid.toString()}`);\n },\n { concurrency: concurrencyLimit },\n );\n\n // If all uploads succeeded, send the last dbMeta to remoteMetaStore\n if (operations.length) {\n const lastOp = operations[operations.length - 1];\n await retryableUpload(async () => {\n if (!this.loader) {\n return;\n }\n await this.loader.remoteMetaStore?.save(lastOp);\n }, `remoteMetaStore save with dbMeta.cars=${lastOp.cars.toString()}`);\n }\n } catch (error) {\n // Log the error\n this.logger.Error().Any(\"error\", error).Msg(\"Processing failed\");\n // Do not proceed to send metadata if any uploads failed\n return;\n } finally {\n // Always save the WAL state\n await this.save(this.walState);\n }\n }\n\n async load(): Promise<WALState | Falsy> {\n this.logger.Debug().Msg(\"loading\");\n const filepath = await this.gateway.buildUrl(this.sthis, this.url(), \"main\", this.loader);\n if (filepath.isErr()) {\n throw this.logger.Error().Err(filepath.Err()).Url(this.url()).Msg(\"error building url\").AsError();\n }\n const bytes = (await this.gateway.get(this.sthis, filepath.Ok(), this.loader)) as Result<FPEnvelopeWAL>;\n if (bytes.isErr()) {\n if (isNotFoundError(bytes)) {\n return undefined;\n }\n throw this.logger.Error().Err(bytes.Err()).Msg(\"error get\").AsError();\n }\n if (bytes.Ok().type !== \"wal\") {\n throw this.logger.Error().Str(\"type\", bytes.Ok().type).Msg(\"unexpected type\").AsError();\n }\n return bytes.Ok().payload;\n }\n\n async save(state: WALState) {\n const filepath = await this.gateway.buildUrl(this.sthis, this.url(), \"main\", this.loader);\n if (filepath.isErr()) {\n throw this.logger.Error().Err(filepath.Err()).Url(this.url()).Msg(\"error building url\").AsError();\n }\n // let encoded: ToString<WALState>;\n // try {\n // encoded = format(state);\n // } catch (e) {\n // throw this.logger.Error().Err(e).Any(\"state\", state).Msg(\"error format\").AsError();\n // }\n const res = await this.gateway.put(\n this.sthis,\n filepath.Ok(),\n {\n type: \"wal\",\n payload: state,\n } as FPEnvelopeWAL,\n this.loader,\n );\n if (res.isErr()) {\n throw this.logger.Error().Err(res.Err()).Str(\"filePath\", filepath.Ok().toString()).Msg(\"error saving\").AsError();\n }\n }\n\n async close() {\n await this.gateway.close(this.sthis, this.url(), this.loader);\n this._onClosed.forEach((fn) => fn());\n return Result.Ok(undefined);\n }\n\n destroy() {\n this.logger.Debug().Msg(\"destroy\");\n return this.gateway.destroy(this.sthis, this.url(), this.loader);\n }\n}\n","import pLimit from \"p-limit\";\nimport { CarReader } from \"@fireproof/vendor/@ipld/car/reader\";\nimport { Logger, ResolveOnce } from \"@adviser/cement\";\n// import { uuidv4 } from \"uuidv7\";\n\nimport {\n type AnyBlock,\n type AnyLink,\n type CarHeader,\n type CommitOpts,\n type DbMeta,\n type TransactionMeta,\n type CarGroup,\n type CarLog,\n DataStore,\n WALStore,\n // RemoteMetaStore,\n // RemoteMetaStore,\n MetaStore,\n BaseStore,\n type Loadable,\n BlockstoreRuntime,\n BlockstoreOpts,\n} from \"./types.js\";\n\nimport { parseCarFile } from \"./loader-helpers.js\";\n\nimport { CarTransaction, defaultedBlockstoreRuntime } from \"./transaction.js\";\nimport { CommitQueue } from \"./commit-queue.js\";\nimport type { Falsy, SuperThis } from \"../types.js\";\nimport { getKeyBag, KeyBag } from \"../runtime/key-bag.js\";\nimport { commit, commitFiles, CommitParams } from \"./commitor.js\";\nimport { decode } from \"../runtime/wait-pr-multiformats/block.js\";\nimport { sha256 as hasher } from \"multiformats/hashes/sha2\";\nimport { TaskManager } from \"./task-manager.js\";\n\nexport function carLogIncludesGroup(list: CarLog, cids: CarGroup) {\n return list.some((arr: CarGroup) => {\n return arr.toString() === cids.toString();\n });\n}\n\n// this works for car groups because toString looks like bafy,bafy\nfunction uniqueCids(list: CarLog, remove = new Set<string>()): CarLog {\n const byString = new Map<string, CarGroup>();\n for (const cid of list) {\n if (remove.has(cid.toString())) continue;\n byString.set(cid.toString(), cid);\n }\n return [...byString.values()];\n}\n\n// export interface DecoderAndCarReader extends CarReader {\n// readonly decoder: BlockDecoder<number, Uint8Array>;\n// }\n\nexport class Loader implements Loadable {\n // readonly name: string;\n readonly ebOpts: BlockstoreRuntime;\n readonly commitQueue: CommitQueue<CarGroup> = new CommitQueue<CarGroup>();\n readonly isCompacting = false;\n readonly carReaders: Map<string, Promise<CarReader>> = new Map<string, Promise<CarReader>>();\n readonly seenCompacted: Set<string> = new Set<string>();\n readonly processedCars: Set<string> = new Set<string>();\n readonly sthis: SuperThis;\n readonly taskManager: TaskManager;\n\n carLog: CarLog = [];\n // key?: string;\n // keyId?: string;\n remoteMetaStore?: MetaStore;\n remoteCarStore?: DataStore;\n remoteFileStore?: DataStore;\n\n private getBlockCache = new Map<string, AnyBlock>();\n private seenMeta = new Set<string>();\n private writeLimit = pLimit(1);\n\n private readonly _carStore = new ResolveOnce<DataStore>();\n async carStore(): Promise<DataStore> {\n return this._carStore.once(async () =>\n this.ebOpts.storeRuntime.makeDataStore({\n sthis: this.sthis,\n gatewayInterceptor: this.ebOpts.gatewayInterceptor,\n url: this.ebOpts.storeUrls.data,\n // keybag: await this.keyBag(),\n loader: this,\n }),\n );\n }\n\n private readonly _fileStore = new ResolveOnce<DataStore>();\n async fileStore(): Promise<DataStore> {\n return this._fileStore.once(async () =>\n this.ebOpts.storeRuntime.makeDataStore({\n sthis: this.sthis,\n gatewayInterceptor: this.ebOpts.gatewayInterceptor,\n url: this.ebOpts.storeUrls.file,\n // keybag: await this.keyBag(),\n loader: this,\n }),\n );\n }\n private readonly _WALStore = new ResolveOnce<WALStore>();\n async WALStore(): Promise<WALStore> {\n return this._WALStore.once(async () =>\n this.ebOpts.storeRuntime.makeWALStore({\n sthis: this.sthis,\n gatewayInterceptor: this.ebOpts.gatewayInterceptor,\n url: this.ebOpts.storeUrls.wal,\n // keybag: await this.keyBag(),\n loader: this,\n }),\n );\n }\n\n private readonly _metaStore = new ResolveOnce<MetaStore>();\n async metaStore(): Promise<MetaStore> {\n return this._metaStore.once(async () =>\n this.ebOpts.storeRuntime.makeMetaStore({\n sthis: this.sthis,\n gatewayInterceptor: this.ebOpts.gatewayInterceptor,\n url: this.ebOpts.storeUrls.meta,\n // keybag: await this.keyBag(),\n loader: this,\n }),\n );\n }\n\n keyBag(): Promise<KeyBag> {\n return getKeyBag(this.sthis, this.ebOpts.keyBag);\n }\n\n private readonly onceReady: ResolveOnce<void> = new ResolveOnce<void>();\n async ready(): Promise<void> {\n return this.onceReady.once(async () => {\n const metas = await (await this.metaStore()).load();\n if (this.ebOpts.meta) {\n await this.handleDbMetasFromStore([this.ebOpts.meta]);\n } else if (metas) {\n await this.handleDbMetasFromStore(metas);\n }\n });\n }\n\n async close() {\n await this.commitQueue.waitIdle();\n const toClose = await Promise.all([this.carStore(), this.metaStore(), this.fileStore(), this.WALStore()]);\n await Promise.all(toClose.map((store) => store.close()));\n }\n\n async destroy() {\n const toDestroy = await Promise.all([this.carStore(), this.metaStore(), this.fileStore(), this.WALStore()]);\n await Promise.all(toDestroy.map((store) => store.destroy()));\n }\n\n readonly logger: Logger;\n constructor(sthis: SuperThis, ebOpts: BlockstoreOpts) {\n // this.name = name;\n // console.log(\"Loader\", name, ebOpts)\n this.sthis = sthis;\n this.ebOpts = defaultedBlockstoreRuntime(\n sthis,\n {\n ...ebOpts,\n // name,\n },\n \"Loader\",\n );\n this.logger = this.ebOpts.logger;\n this.taskManager = new TaskManager(sthis, async (dbMeta: DbMeta) => {\n await this.handleDbMetasFromStore([dbMeta]);\n });\n }\n\n // async snapToCar(carCid: AnyLink | string) {\n // await this.ready\n // if (typeof carCid === 'string') {\n // carCid = CID.parse(carCid)\n // }\n // const carHeader = await this.loadCarHeaderFromMeta({ car: carCid, key: this.key || null })\n // this.carLog = [carCid, ...carHeader.cars]\n // await this.getMoreReaders(carHeader.cars)\n // await this._applyCarHeader(carHeader, true)\n // }\n\n async handleDbMetasFromStore(metas: DbMeta[]): Promise<void> {\n this.logger.Debug().Any(\"metas\", metas).Msg(\"handleDbMetasFromStore\");\n for (const meta of metas) {\n await this.writeLimit(async () => {\n await this.mergeDbMetaIntoClock(meta);\n });\n }\n }\n\n async mergeDbMetaIntoClock(meta: DbMeta): Promise<void> {\n if (this.isCompacting) {\n throw this.logger.Error().Msg(\"cannot merge while compacting\").AsError();\n }\n\n if (this.seenMeta.has(meta.cars.toString())) return;\n this.seenMeta.add(meta.cars.toString());\n\n // if (meta.key) {\n // await this.setKey(meta.key);\n // }\n if (carLogIncludesGroup(this.carLog, meta.cars)) {\n return;\n }\n const carHeader = await this.loadCarHeaderFromMeta<TransactionMeta>(meta);\n // fetch other cars down the compact log?\n // todo we should use a CID set for the compacted cids (how to expire?)\n // console.log('merge carHeader', carHeader.head.length, carHeader.head.toString(), meta.car.toString())\n carHeader.compact.map((c) => c.toString()).forEach(this.seenCompacted.add, this.seenCompacted);\n await this.getMoreReaders(carHeader.cars.flat());\n this.carLog = [...uniqueCids([meta.cars, ...this.carLog, ...carHeader.cars], this.seenCompacted)];\n await this.ebOpts.applyMeta?.(carHeader.meta);\n }\n\n // protected async ingestKeyFromMeta(meta: DbMeta): Promise<void> {\n // const { key } = meta;\n // if (key) {\n // await this.setKey(key);\n // }\n // }\n\n async loadCarHeaderFromMeta<T>({ cars: cids }: DbMeta): Promise<CarHeader<T>> {\n //Call loadCar for every cid\n const reader = await this.loadCar(cids[0]);\n return await parseCarFile(reader, this.logger);\n }\n\n // async _getKey(): Promise<string | undefined> {\n // if (this.key) return this.key;\n // // generate a random key\n // if (!this.ebOpts.public) {\n // await this.setKey(toHexString(this.ebOpts.crypto.randomBytes(32)));\n // }\n // return this.key || undefined;\n // }\n\n async commitFiles(\n t: CarTransaction,\n done: TransactionMeta,\n // opts: CommitOpts = { noLoader: false, compact: false },\n ): Promise<CarGroup> {\n await this.ready();\n const fstore = await this.fileStore();\n const wstore = await this.WALStore();\n return this.commitQueue.enqueue(() => commitFiles(fstore, wstore, t, done));\n }\n\n async loadFileCar(cid: AnyLink /*, isPublic = false*/): Promise<CarReader> {\n return await this.storesLoadCar(cid, await this.fileStore(), this.remoteFileStore);\n }\n\n async commit<T = TransactionMeta>(\n t: CarTransaction,\n done: T,\n opts: CommitOpts = { noLoader: false, compact: false },\n ): Promise<CarGroup> {\n await this.ready();\n const carStore = await this.carStore();\n const params: CommitParams = {\n encoder: (await carStore.keyedCrypto()).codec(),\n carLog: this.carLog,\n carStore: carStore,\n WALStore: await this.WALStore(),\n metaStore: await this.metaStore(),\n threshold: this.ebOpts.threshold,\n };\n return this.commitQueue.enqueue(async () => {\n await this.cacheTransaction(t);\n const ret = await commit(params, t, done, opts);\n await this.updateCarLog(ret.cgrp, ret.header, !!opts.compact);\n return ret.cgrp;\n });\n }\n\n async updateCarLog<T>(cids: CarGroup, fp: CarHeader<T>, compact: boolean): Promise<void> {\n if (compact) {\n const previousCompactCid = fp.compact[fp.compact.length - 1];\n fp.compact.map((c) => c.toString()).forEach(this.seenCompacted.add, this.seenCompacted);\n this.carLog = [...uniqueCids([...this.carLog, ...fp.cars, cids], this.seenCompacted)];\n await this.removeCidsForCompact(previousCompactCid[0]).catch((e) => e);\n } else {\n this.carLog.unshift(cids);\n }\n }\n\n async cacheTransaction(t: CarTransaction) {\n for await (const block of t.entries()) {\n const sBlock = block.cid.toString();\n if (!this.getBlockCache.has(sBlock)) {\n this.getBlockCache.set(sBlock, block);\n }\n }\n }\n\n async cacheCarReader(carCidStr: string, reader: CarReader) {\n if (this.processedCars.has(carCidStr)) return;\n this.processedCars.add(carCidStr);\n for await (const block of reader.blocks()) {\n const sBlock = block.cid.toString();\n if (!this.getBlockCache.has(sBlock)) {\n this.getBlockCache.set(sBlock, block);\n }\n }\n }\n\n async removeCidsForCompact(cid: AnyLink) {\n const carHeader = await this.loadCarHeaderFromMeta({\n cars: [cid],\n } as unknown as DbMeta);\n for (const cids of carHeader.compact) {\n for (const cid of cids) {\n await (await this.carStore()).remove(cid);\n }\n }\n }\n\n // async flushCars() {\n // await this.ready\n // // for each cid in car log, make a dbMeta\n // for (const cid of this.carLog) {\n // const dbMeta = { car: cid, key: this.key || null } as DbMeta\n // await this.remoteWAL!.enqueue(dbMeta, { public: false })\n // }\n // }\n\n async *entries(cache = true): AsyncIterableIterator<AnyBlock> {\n await this.ready();\n if (cache) {\n for (const [, block] of this.getBlockCache) {\n yield block;\n }\n } else {\n for (const [, block] of this.getBlockCache) {\n yield block;\n }\n for (const cids of this.carLog) {\n for (const cid of cids) {\n const reader = await this.loadCar(cid);\n if (!reader) throw this.logger.Error().Ref(\"cid\", cid).Msg(\"missing car reader\").AsError();\n for await (const block of reader.blocks()) {\n const sCid = block.cid.toString();\n if (!this.getBlockCache.has(sCid)) {\n yield block;\n }\n }\n }\n }\n }\n }\n\n async getBlock(cid: AnyLink): Promise<AnyBlock | Falsy> {\n await this.ready();\n const sCid = cid.toString();\n if (this.getBlockCache.has(sCid)) return this.getBlockCache.get(sCid);\n\n const getCarCid = async (carCid: AnyLink) => {\n if (this.getBlockCache.has(sCid)) return this.getBlockCache.get(sCid);\n const reader = await this.loadCar(carCid);\n if (!reader) {\n throw this.logger.Error().Ref(\"cid\", carCid).Msg(\"missing car reader\").AsError();\n }\n await this.cacheCarReader(carCid.toString(), reader).catch(() => {\n return;\n });\n if (this.getBlockCache.has(sCid)) return this.getBlockCache.get(sCid);\n throw this.logger.Error().Str(\"cid\", sCid).Msg(\"block not in reader\").AsError();\n };\n\n const getCompactCarCids = async (carCid: AnyLink) => {\n // console.log(\"getCompactCarCids\", carCid.toString())\n\n const reader = await this.loadCar(carCid);\n if (!reader) {\n throw this.logger.Error().Str(\"cid\", carCid.toString()).Msg(\"missing car reader\").AsError();\n }\n\n const header = await parseCarFile(reader, this.logger);\n\n const compacts = header.compact;\n\n let got: AnyBlock | undefined;\n const batchSize = 5;\n for (let i = 0; i < compacts.length; i += batchSize) {\n const promises: Promise<AnyBlock | undefined>[] = [];\n for (let j = i; j < Math.min(i + batchSize, compacts.length); j++) {\n for (const cid of compacts[j]) {\n promises.push(getCarCid(cid));\n }\n }\n try {\n got = await Promise.any(promises);\n } catch {\n // Ignore the error and continue with the next iteration\n }\n if (got) break;\n }\n\n if (this.getBlockCache.has(sCid)) return this.getBlockCache.get(sCid);\n throw this.logger.Error().Str(\"cid\", sCid).Msg(\"block not in compact reader\").AsError();\n };\n\n let got;\n const batchSize = 5;\n for (let i = 0; i < this.carLog.length; i += batchSize) {\n const batch = this.carLog.slice(i, i + batchSize);\n const promises: Promise<AnyBlock | undefined>[] = batch.flatMap((slice) => slice.map(getCarCid));\n try {\n got = await Promise.any(promises);\n } catch {\n // Ignore the error and continue with the next iteration\n }\n if (got) break;\n }\n\n if (!got) {\n try {\n got = await getCompactCarCids(this.carLog[this.carLog.length - 1][0]);\n } catch {\n // Ignore the error and continue with the next iteration\n }\n }\n\n return got;\n }\n\n async loadCar(cid: AnyLink): Promise<CarReader> {\n if (!this.carStore) {\n throw this.logger.Error().Msg(\"car store not initialized\").AsError();\n }\n const loaded = await this.storesLoadCar(cid, await this.carStore(), this.remoteCarStore);\n return loaded;\n }\n\n async makeDecoderAndCarReader(cid: AnyLink, local: DataStore, remote?: DataStore): Promise<CarReader> {\n const cidsString = cid.toString();\n let loadedCar: AnyBlock | undefined = undefined;\n let activeStore: BaseStore = local;\n try {\n //loadedCar now is an array of AnyBlocks\n this.logger.Debug().Str(\"cid\", cidsString).Msg(\"loading car\");\n loadedCar = await local.load(cid);\n this.logger.Debug().Bool(\"loadedCar\", loadedCar).Msg(\"loaded\");\n } catch (e) {\n if (remote) {\n const remoteCar = await remote.load(cid);\n if (remoteCar) {\n // todo test for this\n this.logger.Debug().Ref(\"cid\", remoteCar.cid).Msg(\"saving remote car locally\");\n await local.save(remoteCar);\n loadedCar = remoteCar;\n activeStore = remote;\n }\n } else {\n this.logger.Error().Str(\"cid\", cidsString).Err(e).Msg(\"loading car\");\n }\n }\n if (!loadedCar) {\n throw this.logger.Error().Url(local.url()).Str(\"cid\", cidsString).Msg(\"missing car files\").AsError();\n }\n //This needs a fix as well as the fromBytes function expects a Uint8Array\n //Either we can merge the bytes or return an array of rawReaders\n const bytes = await decode({ bytes: loadedCar.bytes, hasher, codec: (await activeStore.keyedCrypto()).codec() }); // as Uint8Array,\n const rawReader = await CarReader.fromBytes(bytes.value);\n const readerP = Promise.resolve(rawReader);\n // const kc = await activeStore.keyedCrypto()\n // const readerP = !kc.isEncrypting ? Promise.resolve(rawReader) : this.ensureDecryptedReader(activeStore, rawReader);\n\n const cachedReaderP = readerP.then(async (reader) => {\n await this.cacheCarReader(cidsString, reader).catch((e) => {\n this.logger.Error().Err(e).Str(\"cid\", cidsString).Msg(\"error caching car reader\");\n return;\n });\n return reader;\n });\n this.carReaders.set(cidsString, cachedReaderP);\n return readerP;\n }\n\n //What if instead it returns an Array of CarHeader\n protected async storesLoadCar(cid: AnyLink, local: DataStore, remote?: DataStore): Promise<CarReader> {\n const cidsString = cid.toString();\n let dacr = this.carReaders.get(cidsString);\n if (!dacr) {\n dacr = this.makeDecoderAndCarReader(cid, local, remote);\n this.carReaders.set(cidsString, dacr);\n }\n return dacr;\n }\n\n protected async getMoreReaders(cids: AnyLink[]) {\n const limit = pLimit(5);\n const missing = cids.filter((cid) => !this.carReaders.has(cid.toString()));\n await Promise.all(missing.map((cid) => limit(() => this.loadCar(cid))));\n }\n}\n","// this enable async codec\n// it should be gone if this in multiformats is merged:\n// https://github.com/multiformats/js-multiformats/pull/305\nimport { bytes as binary, CID, MultihashHasher, BlockView, ByteView, Version, Link } from \"multiformats\";\nimport { Block as mfBlock } from \"multiformats/block\";\nimport { BlockDecoder, BlockEncoder } from \"./codec-interface.js\";\n\n// export type Block<T, C extends number, A extends number, V extends Version> = mfBlock<T, C, A, V>\n\nexport const Block = mfBlock;\n\ninterface DecodeInput<T, Code extends number, Alg extends number> {\n bytes: ByteView<T>;\n codec: BlockDecoder<Code, T>;\n hasher: MultihashHasher<Alg>;\n}\n\nexport async function decode<T, Code extends number, Alg extends number>({\n bytes,\n codec,\n hasher,\n}: DecodeInput<T, Code, Alg>): Promise<BlockView<T, Code, Alg>> {\n if (bytes == null) throw new Error('Missing required argument \"bytes\"');\n if (codec == null || hasher == null) throw new Error(\"Missing required argument: codec or hasher\");\n\n const value = await Promise.resolve(codec.decode(bytes));\n const hash = await hasher.digest(bytes);\n const cid = CID.create(1, codec.code, hash) as CID<T, Code, Alg, 1>;\n\n return new mfBlock({ value, bytes, cid });\n}\n\ninterface EncodeInput<T, Code extends number, Alg extends number> {\n value: T;\n codec: BlockEncoder<Code, T>;\n hasher: MultihashHasher<Alg>;\n}\n\nexport async function encode<T, Code extends number, Alg extends number>({\n value,\n codec,\n hasher,\n}: EncodeInput<T, Code, Alg>): Promise<BlockView<T, Code, Alg>> {\n if (typeof value === \"undefined\") throw new Error('Missing required argument \"value\"');\n if (codec == null || hasher == null) throw new Error(\"Missing required argument: codec or hasher\");\n\n const bytes = await Promise.resolve(codec.encode(value));\n const hash = await hasher.digest(bytes);\n const cid = CID.create(1, codec.code, hash) as CID<T, Code, Alg, 1>;\n\n return new mfBlock({ value, bytes, cid });\n}\n\ninterface CreateInput<T, Code extends number, Alg extends number, V extends Version> {\n bytes: ByteView<T>;\n cid: Link<T, Code, Alg, V>;\n hasher: MultihashHasher<Alg>;\n codec: BlockDecoder<Code, T>;\n}\n\nexport async function create<T, Code extends number, Alg extends number, V extends Version>({\n bytes,\n cid,\n hasher,\n codec,\n}: CreateInput<T, Code, Alg, V>): Promise<BlockView<T, Code, Alg, V>> {\n if (bytes == null) throw new Error('Missing required argument \"bytes\"');\n if (hasher == null) throw new Error('Missing required argument \"hasher\"');\n const value = await Promise.resolve(codec.decode(bytes));\n const hash = await hasher.digest(bytes);\n if (!binary.equals(cid.multihash.bytes, hash.bytes)) {\n throw new Error(\"CID hash does not match bytes\");\n }\n\n return createUnsafe({\n bytes,\n cid,\n value,\n codec,\n });\n}\n\ntype CreateUnsafeInput<T, Code extends number, Alg extends number, V extends Version> =\n | {\n cid: Link<T, Code, Alg, V>;\n value: T;\n codec?: BlockDecoder<Code, T>;\n bytes: ByteView<T>;\n }\n | {\n cid: Link<T, Code, Alg, V>;\n value?: undefined;\n codec: BlockDecoder<Code, T>;\n bytes: ByteView<T>;\n };\n\n/**\n * @template T - Logical type of the data encoded in the block\n * @template Code - multicodec code corresponding to codec used to encode the block\n * @template Alg - multicodec code corresponding to the hashing algorithm used in CID creation.\n * @template V - CID version\n */\nexport async function createUnsafe<T, Code extends number, Alg extends number, V extends Version>({\n bytes,\n cid,\n value: maybeValue,\n codec,\n}: CreateUnsafeInput<T, Code, Alg, V>): Promise<BlockView<T, Code, Alg, V>> {\n const value = await Promise.resolve(maybeValue !== undefined ? maybeValue : codec?.decode(bytes));\n\n if (value === undefined) throw new Error('Missing required argument, must either provide \"value\" or \"codec\"');\n\n return new Block({\n cid: cid as CID<T, Code, Alg, V>,\n bytes,\n value,\n });\n}\n","import { decode } from \"../runtime/wait-pr-multiformats/block.js\";\nimport { sha256 as hasher } from \"multiformats/hashes/sha2\";\nimport * as dagCodec from \"@fireproof/vendor/@ipld/dag-cbor\";\nimport type { Logger } from \"@adviser/cement\";\n\nimport { CarHeader } from \"./types.js\";\n// import { decodeRunLength } from \"../runtime/keyed-crypto.js\";\n// import { base58btc } from \"multiformats/bases/base58\";\nimport { CarReader } from \"@fireproof/vendor/@ipld/car/reader\";\n\n// export async function encodeCarHeader<T>(fp: CarHeader<T>) {\n// return (await encode({\n// value: { fp },\n// hasher,\n// codec: dagCodec,\n// })) as AnyBlock;\n// }\n\n// function wrapDagDecoder<T>(dec: BlockDecoder<number, Uint8Array>): BlockDecoder<number, CarDecoded<T>> {\n// return {\n// code: dec.code,\n// decode: async (block: Uint8Array) => dagCodec.decode(await dec.decode(block))\n// }\n// }\n\ninterface CarDecoded<T> {\n readonly fp: CarHeader<T>;\n}\n\nexport async function parseCarFile<T>(reader: CarReader, logger: Logger): Promise<CarHeader<T>> {\n const roots = await reader.getRoots();\n const header = await reader.get(roots[0]);\n if (!header) throw logger.Error().Msg(\"missing header block\").AsError();\n const dec = await decode({ bytes: header.bytes, hasher, codec: dagCodec });\n // console.log(\"parseCarFile-done\", roots[0].toString(), header)\n // const { value } = await decode({\n // bytes: header.bytes,\n // hasher,\n // codec: await wrapDagDecoder<T>({\n // code: dagCodec.code,\n // decode: (block) => {\n // const ui = new Uint8Array(block);\n // const iv = decodeRunLength(ui, 0, logger);\n // const key = decodeRunLength(ui, iv.next, logger);\n // // const fp = decodeRunLength(ui, key.next, logger);\n // console.log(\"parseCarFile\", { iv: iv.data.length, key: base58btc.encode(key.data) }, (new Error()).stack);\n // return ui\n // }\n // })\n // });\n const fpvalue = dec.value as CarDecoded<T>;\n // @jchris where is the fp attribute coming from?\n if (fpvalue && !fpvalue.fp) {\n throw logger.Error().Msg(\"missing fp\").AsError();\n }\n return fpvalue.fp;\n}\n","import { MemoryBlockstore } from \"@fireproof/vendor/@web3-storage/pail/block\";\nimport { BlockFetcher as BlockFetcherApi } from \"@fireproof/vendor/@web3-storage/pail/api\";\n\nimport {\n AnyAnyLink,\n AnyBlock,\n AnyLink,\n CarMakeable,\n TransactionMeta,\n TransactionWrapper,\n BlockstoreOpts,\n BlockstoreRuntime,\n Loadable,\n} from \"./types.js\";\n\nimport { Loader } from \"./loader.js\";\nimport type { CID, Block, Version } from \"multiformats\";\nimport { falsyToUndef, SuperThis } from \"../types.js\";\nimport { ensureStoreEnDeFile, toStoreRuntime } from \"./store-factory.js\";\nimport { Logger, toCryptoRuntime } from \"@adviser/cement\";\nimport { ensureLogger, ensureSuperThis } from \"../utils.js\";\n\nexport type BlockFetcher = BlockFetcherApi;\n\nexport interface CarTransactionOpts {\n readonly add: boolean;\n readonly noLoader: boolean;\n}\n\nexport interface CarTransactionOpts {\n readonly add: boolean;\n readonly noLoader: boolean;\n}\n\nexport class CarTransaction extends MemoryBlockstore implements CarMakeable {\n readonly parent: BaseBlockstore;\n constructor(parent: BaseBlockstore, opts: CarTransactionOpts = { add: true, noLoader: false }) {\n super();\n if (opts.add) {\n parent.transactions.add(this);\n }\n this.parent = parent;\n }\n\n async get<T, C extends number, A extends number, V extends Version>(cid: AnyLink): Promise<Block<T, C, A, V> | undefined> {\n return ((await this.superGet(cid)) || falsyToUndef(await this.parent.get(cid))) as Block<T, C, A, V>;\n }\n\n async superGet(cid: AnyLink): Promise<AnyBlock | undefined> {\n return super.get(cid);\n }\n}\n\nexport function defaultedBlockstoreRuntime(\n sthis: SuperThis,\n opts: BlockstoreOpts,\n component: string,\n ctx?: Record<string, unknown>,\n): BlockstoreRuntime {\n const logger = ensureLogger(sthis, component, ctx);\n // const store = opts.store || {};\n return {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n applyMeta: (meta: TransactionMeta, snap?: boolean): Promise<void> => {\n return Promise.resolve();\n },\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n compact: async (blocks: BlockFetcher) => {\n return {} as unknown as TransactionMeta;\n },\n autoCompact: 100,\n public: false,\n // name: undefined,\n threshold: 1000 * 1000,\n ...opts,\n logger,\n keyBag: opts.keyBag || {},\n crypto: toCryptoRuntime(opts.crypto),\n storeUrls: opts.storeUrls,\n // storeEnDeFile: ensureStoreEnDeFile(opts.storeEnDeFile),\n // store,\n storeRuntime: toStoreRuntime(sthis, ensureStoreEnDeFile(opts.storeEnDeFile)),\n };\n}\n\n// export function blockstoreFactory(sthis: SuperThis, opts: BlockstoreOpts): BaseBlockstore | EncryptedBlockstore {\n// // if (opts.name) {\n// return new EncryptedBlockstore(sthis, opts);\n// // } else {\n// // return new BaseBlockstore(opts);\n// // }\n// }\n\nexport class BaseBlockstore implements BlockFetcher {\n readonly transactions: Set<CarTransaction> = new Set<CarTransaction>();\n readonly ebOpts: BlockstoreRuntime;\n readonly sthis: SuperThis;\n\n readonly loader: Loadable;\n // readonly name?: string;\n\n // ready: Promise<void>;\n ready(): Promise<void> {\n return Promise.resolve();\n }\n\n async close(): Promise<void> {\n // no-op\n }\n\n async destroy(): Promise<void> {\n // no-op\n }\n\n async compact(): Promise<void> {\n // no-op\n }\n\n readonly logger: Logger;\n constructor(ebOpts: BlockstoreOpts) {\n this.sthis = ensureSuperThis(ebOpts);\n this.ebOpts = defaultedBlockstoreRuntime(this.sthis, ebOpts, \"BaseBlockstore\");\n this.logger = this.ebOpts.logger;\n this.loader = new Loader(this.sthis, ebOpts);\n }\n\n async get<T, C extends number, A extends number, V extends Version>(cid: AnyAnyLink): Promise<Block<T, C, A, V> | undefined> {\n if (!cid) throw this.logger.Error().Msg(\"required cid\").AsError();\n for (const f of this.transactions) {\n // if (Math.random() < 0.001) console.log('get', cid.toString(), this.transactions.size)\n const v = await f.superGet(cid);\n if (v) return v as Block<T, C, A, V>;\n }\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n async put(cid: AnyAnyLink, block: Uint8Array): Promise<void> {\n throw this.logger.Error().Msg(\"use a transaction to put\").AsError();\n }\n\n lastTxMeta?: unknown; // TransactionMeta\n\n async transaction<M extends TransactionMeta>(\n fn: (t: CarTransaction) => Promise<M>,\n _opts?: CarTransactionOpts,\n ): Promise<TransactionWrapper<M>> {\n this.logger.Debug().Msg(\"enter transaction\");\n const t = new CarTransaction(this, _opts);\n this.logger.Debug().Msg(\"post CarTransaction\");\n const done: M = await fn(t);\n this.logger.Debug().Msg(\"post fn\");\n this.lastTxMeta = done;\n return { t, meta: done };\n }\n\n openTransaction(opts: CarTransactionOpts = { add: true, noLoader: false }): CarTransaction {\n return new CarTransaction(this, opts);\n }\n\n async commitTransaction<M extends TransactionMeta>(\n t: CarTransaction,\n done: M,\n opts: CarTransactionOpts,\n ): Promise<TransactionWrapper<M>> {\n if (!this.loader) throw this.logger.Error().Msg(\"loader required to commit\").AsError();\n const cars = await this.loader.commit<M>(t, done, opts);\n if (this.ebOpts.autoCompact && this.loader.carLog.length > this.ebOpts.autoCompact) {\n setTimeout(() => void this.compact(), 10);\n }\n if (cars) {\n this.transactions.delete(t);\n return { meta: done, cars, t };\n }\n throw this.logger.Error().Msg(\"failed to commit car files\").AsError();\n }\n\n async *entries(): AsyncIterableIterator<AnyBlock> {\n const seen = new Set<string>();\n for (const t of this.transactions) {\n for await (const blk of t.entries()) {\n if (seen.has(blk.cid.toString())) continue;\n seen.add(blk.cid.toString());\n yield blk;\n }\n }\n }\n}\n\nexport class EncryptedBlockstore extends BaseBlockstore {\n // readonly name: string;\n\n ready(): Promise<void> {\n return this.loader.ready();\n }\n\n close(): Promise<void> {\n return this.loader.close();\n }\n\n destroy(): Promise<void> {\n return this.loader.destroy();\n }\n\n compacting = false;\n readonly logger: Logger;\n\n constructor(sthis: SuperThis, ebOpts: BlockstoreOpts) {\n super(ebOpts);\n this.logger = ensureLogger(this.sthis, \"EncryptedBlockstore\", {\n this: 1,\n });\n }\n\n async get<T, C extends number, A extends number, V extends Version>(cid: AnyAnyLink): Promise<Block<T, C, A, V> | undefined> {\n const got = await super.get(cid);\n if (got) return got as Block<T, C, A, V>;\n if (!this.loader) {\n return;\n }\n return falsyToUndef(await this.loader.getBlock(cid)) as Block<T, C, A, V>;\n }\n\n async transaction<M extends TransactionMeta>(\n fn: (t: CarTransaction) => Promise<M>,\n opts = { noLoader: false },\n ): Promise<TransactionWrapper<M>> {\n this.logger.Debug().Msg(\"enter transaction\");\n const { t, meta: done } = await super.transaction<M>(fn);\n this.logger.Debug().Msg(\"post super.transaction\");\n const cars = await this.loader.commit<M>(t, done, opts);\n this.logger.Debug().Msg(\"post this.loader.commit\");\n if (this.ebOpts.autoCompact && this.loader.carLog.length > this.ebOpts.autoCompact) {\n setTimeout(() => void this.compact(), 10);\n }\n if (cars) {\n this.transactions.delete(t);\n return { meta: done, cars, t };\n }\n throw this.logger.Error().Msg(\"failed to commit car files\").AsError();\n }\n\n async getFile(car: AnyLink, cid: AnyLink /*, isPublic = false*/): Promise<Uint8Array> {\n await this.ready();\n if (!this.loader) throw this.logger.Error().Msg(\"loader required to get file, ledger must be named\").AsError();\n const reader = await this.loader.loadFileCar(car /*, isPublic */);\n const block = await reader.get(cid as CID);\n if (!block) throw this.logger.Error().Str(\"cid\", cid.toString()).Msg(`Missing block`).AsError();\n return block.bytes;\n }\n\n async compact() {\n await this.ready();\n if (!this.loader) throw this.logger.Error().Msg(\"loader required to compact\").AsError();\n if (this.loader.carLog.length < 2) return;\n const compactFn = this.ebOpts.compact || ((blocks: CompactionFetcher) => this.defaultCompact(blocks, this.logger));\n if (!compactFn || this.compacting) return;\n const blockLog = new CompactionFetcher(this);\n this.compacting = true;\n const meta = await compactFn(blockLog);\n await this.loader.commit(blockLog.loggedBlocks, meta, {\n compact: true,\n noLoader: true,\n });\n this.compacting = false;\n }\n\n async defaultCompact(blocks: CompactionFetcher, logger: Logger): Promise<TransactionMeta> {\n // console.log('eb compact')\n if (!this.loader) {\n throw logger.Error().Msg(\"no loader\").AsError();\n }\n if (!this.lastTxMeta) {\n throw logger.Error().Msg(\"no lastTxMeta\").AsError();\n }\n for await (const blk of this.loader.entries(false)) {\n blocks.loggedBlocks.putSync(blk.cid, blk.bytes);\n }\n for (const t of this.transactions) {\n for await (const blk of t.entries()) {\n blocks.loggedBlocks.putSync(blk.cid, blk.bytes);\n }\n }\n return this.lastTxMeta as TransactionMeta;\n }\n\n async *entries(): AsyncIterableIterator<AnyBlock> {\n // const seen = new Set<string>();\n for await (const blk of this.loader.entries()) {\n // if (seen.has(blk.cid.toString())) continue\n // seen.add(blk.cid.toString())\n yield blk;\n }\n }\n}\n\nexport class CompactionFetcher implements BlockFetcher {\n readonly blockstore: EncryptedBlockstore;\n // loader: Loader | null = null\n readonly loggedBlocks: CarTransaction;\n\n constructor(blocks: EncryptedBlockstore) {\n this.blockstore = blocks;\n // this.loader = blocks.loader\n this.loggedBlocks = new CarTransaction(blocks);\n }\n\n async get<T, C extends number, A extends number, V extends Version>(cid: AnyLink): Promise<Block<T, C, A, V> | undefined> {\n const block = await this.blockstore.get(cid);\n if (block) this.loggedBlocks.putSync(cid, block.bytes);\n return falsyToUndef(block) as Block<T, C, A, V>;\n }\n}\n","import { Future } from \"@adviser/cement\";\n\ntype QueueFunction<T = void> = () => Promise<T>;\n\nexport class CommitQueue<T = void> {\n readonly queue: QueueFunction<void>[] = [];\n processing = false;\n\n readonly _waitIdleItems: Set<Future<void>> = new Set<Future<void>>();\n waitIdle(): Promise<void> {\n if (this.queue.length === 0 && !this.processing) {\n return Promise.resolve();\n }\n const fn = new Future<void>();\n this._waitIdleItems.add(fn);\n return fn.asPromise();\n }\n\n async enqueue(fn: QueueFunction<T>): Promise<T> {\n return new Promise<T>((resolve, reject) => {\n const queueFn = async () => {\n try {\n resolve(await fn());\n } catch (e) {\n reject(e);\n } finally {\n this.processing = false;\n this.processNext();\n }\n };\n this.queue.push(queueFn);\n if (!this.processing) {\n this.processNext();\n }\n });\n }\n\n processNext() {\n if (this.queue.length > 0 && !this.processing) {\n this.processing = true;\n const queueFn = this.queue.shift();\n if (queueFn) {\n queueFn().finally(() => {\n /**/\n });\n }\n }\n if (this.queue.length === 0 && !this.processing) {\n const toResolve = Array.from(this._waitIdleItems);\n this._waitIdleItems.clear();\n toResolve.map((fn) => fn.resolve());\n }\n }\n}\n","import {\n CoerceURI,\n CryptoRuntime,\n KeyedResolvOnce,\n Logger,\n ResolveOnce,\n ResolveSeq,\n Result,\n runtimeFn,\n toCryptoRuntime,\n URI,\n} from \"@adviser/cement\";\nimport { KeyWithFingerExtract, KeyWithFingerPrint } from \"../blockstore/types.js\";\nimport { ensureLogger } from \"../utils.js\";\nimport { base58btc } from \"multiformats/bases/base58\";\nimport { PARAM, SuperThis } from \"../types.js\";\nimport { KeyBagProviderFile } from \"./gateways/file/key-bag-file.js\";\nimport { KeyBagProviderMemory } from \"./key-bag-memory.js\";\n\nexport class KeyBag {\n readonly logger: Logger;\n constructor(readonly rt: KeyBagRuntime) {\n this.logger = ensureLogger(rt.sthis, \"KeyBag\", {\n // id: rt.id(),\n });\n this.logger.Debug().Msg(\"KeyBag created\");\n }\n\n readonly _warnOnce: ResolveOnce<void> = new ResolveOnce<void>();\n async subtleKey(key: string): Promise<CryptoKey> {\n const extractable = this.rt.url.getParam(PARAM.EXTRACTKEY) === \"_deprecated_internal_api\";\n if (extractable) {\n this._warnOnce.once(() =>\n this.logger.Warn().Msg(\"extractKey is enabled via _deprecated_internal_api --- handle keys safely!!!\"),\n );\n }\n return await this.rt.crypto.importKey(\n \"raw\", // raw or jwk\n base58btc.decode(key),\n // hexStringToUint8Array(key), // raw data\n \"AES-GCM\",\n extractable,\n [\"encrypt\", \"decrypt\"],\n );\n }\n\n async ensureKeyFromUrl(url: URI, keyFactory: () => string): Promise<Result<URI>> {\n // add storekey to url\n const storeKey = url.getParam(PARAM.STORE_KEY);\n if (storeKey === \"insecure\") {\n return Result.Ok(url);\n }\n if (!storeKey) {\n const keyName = `@${keyFactory()}@`;\n const ret = await this.getNamedKey(keyName);\n if (ret.isErr()) {\n return ret as unknown as Result<URI>;\n }\n const urb = url.build().setParam(PARAM.STORE_KEY, keyName);\n return Result.Ok(urb.URI());\n }\n if (storeKey.startsWith(\"@\") && storeKey.endsWith(\"@\")) {\n const ret = await this.getNamedKey(storeKey);\n if (ret.isErr()) {\n return ret as unknown as Result<URI>;\n }\n }\n return Result.Ok(url);\n }\n\n async toKeyWithFingerPrint(keyStr: string): Promise<Result<KeyWithFingerPrint>> {\n const material = base58btc.decode(keyStr); //\n const key = await this.subtleKey(keyStr);\n const fpr = await this.rt.crypto.digestSHA256(material);\n return Result.Ok({\n key,\n fingerPrint: base58btc.encode(new Uint8Array(fpr)),\n });\n }\n\n readonly _seq: ResolveSeq<Result<KeyWithFingerPrint>> = new ResolveSeq<Result<KeyWithFingerPrint>>();\n async setNamedKey(name: string, key: string): Promise<Result<KeyWithFingerPrint>> {\n return this._seq.add(() => this._setNamedKey(name, key));\n }\n\n // avoid deadlock\n async _setNamedKey(name: string, key: string): Promise<Result<KeyWithFingerPrint>> {\n const item = {\n name,\n key: key,\n };\n const bag = await this.rt.getBag();\n this.logger.Debug().Str(\"name\", name).Msg(\"setNamedKey\");\n // there should be a version that throws if key exists\n await bag.set(name, item);\n return await this.toKeyWithFingerPrint(item.key);\n }\n\n async getNamedExtractableKey(name: string, failIfNotFound = false): Promise<Result<KeyWithFingerExtract>> {\n const ret = await this.getNamedKey(name, failIfNotFound);\n if (ret.isErr()) {\n return ret as unknown as Result<KeyWithFingerExtract>;\n }\n const named = ret.Ok();\n return Result.Ok({\n ...named,\n extract: async () => {\n const ext = new Uint8Array((await this.rt.crypto.exportKey(\"raw\", named.key)) as ArrayBuffer);\n return {\n key: ext,\n keyStr: base58btc.encode(ext),\n };\n },\n });\n }\n\n async getNamedKey(name: string, failIfNotFound = false): Promise<Result<KeyWithFingerPrint>> {\n const id = this.rt.sthis.nextId(4).str;\n return this._seq.add(async () => {\n const bag = await this.rt.getBag();\n const named = await bag.get(name);\n if (named) {\n const fpr = await this.toKeyWithFingerPrint(named.key);\n this.logger.Debug().Str(\"id\", id).Str(\"name\", name).Result(\"fpr\", fpr).Msg(\"fingerPrint getNamedKey\");\n return fpr;\n }\n if (failIfNotFound) {\n this.logger.Debug().Str(\"id\", id).Str(\"name\", name).Msg(\"failIfNotFound getNamedKey\");\n return Result.Err(new Error(`Key not found: ${name}`));\n }\n // this.logger.Debug().Str(\"id\", id).Str(\"name\", name).Msg(\"createKey getNamedKey-pre\");\n const ret = await this._setNamedKey(name, base58btc.encode(this.rt.crypto.randomBytes(this.rt.keyLength)));\n this.logger.Debug().Str(\"id\", id).Str(\"name\", name).Result(\"fpr\", ret).Msg(\"createKey getNamedKey-post\");\n return ret;\n });\n }\n}\n\nexport interface KeyItem {\n readonly name: string;\n readonly key: string;\n}\nexport type KeyBagFile = Record<string, KeyItem>;\n\nexport interface KeyBagOpts {\n // in future you can encrypt the keybag with ?masterkey=xxxxx\n readonly url: CoerceURI;\n // readonly key: string; // key to encrypt the keybag\n readonly crypto: CryptoRuntime;\n readonly keyLength: number; // default: 16\n // readonly logger: Logger;\n readonly keyRuntime: KeyBagRuntime;\n}\n\nexport interface KeyBagProvider {\n get(id: string): Promise<KeyItem | undefined>;\n set(id: string, item: KeyItem): Promise<void>;\n}\nexport interface KeyBagRuntime {\n readonly url: URI;\n readonly crypto: CryptoRuntime;\n readonly logger: Logger;\n readonly sthis: SuperThis;\n readonly keyLength: number;\n // readonly key?: FPCryptoKey;\n getBag(): Promise<KeyBagProvider>;\n id(): string;\n}\n\nexport type KeyBackProviderFactory = (url: URI, sthis: SuperThis) => Promise<KeyBagProvider>;\n\nexport interface KeyBagProviderFactoryItem {\n readonly protocol: string;\n // if this is set the default protocol selection is overridden\n readonly override?: boolean;\n readonly factory: KeyBackProviderFactory;\n}\n\nconst keyBagProviderFactories = new Map<string, KeyBagProviderFactoryItem>(\n [\n {\n protocol: \"file:\",\n factory: async (url: URI, sthis: SuperThis) => {\n return new KeyBagProviderFile(url, sthis);\n },\n },\n {\n protocol: \"indexdb:\",\n factory: async (url: URI, sthis: SuperThis) => {\n const { KeyBagProviderImpl } = await import(\"@fireproof/core/web\");\n return new KeyBagProviderImpl(url, sthis);\n },\n },\n {\n protocol: \"memory:\",\n factory: async (url: URI, sthis: SuperThis) => {\n return new KeyBagProviderMemory(url, sthis);\n },\n },\n ].map((i) => [i.protocol, i]),\n);\n\nexport function registerKeyBagProviderFactory(item: KeyBagProviderFactoryItem) {\n const protocol = item.protocol.endsWith(\":\") ? item.protocol : item.protocol + \":\";\n keyBagProviderFactories.set(protocol, {\n ...item,\n protocol,\n });\n}\n\nexport function defaultKeyBagUrl(sthis: SuperThis): URI {\n let bagFnameOrUrl = sthis.env.get(\"FP_KEYBAG_URL\");\n let url: URI;\n if (runtimeFn().isBrowser) {\n url = URI.from(bagFnameOrUrl || \"indexdb://fp-keybag\");\n } else {\n if (!bagFnameOrUrl) {\n const home = sthis.env.get(\"HOME\");\n bagFnameOrUrl = `${home}/.fireproof/keybag`;\n url = URI.from(`file://${bagFnameOrUrl}`);\n } else {\n url = URI.from(bagFnameOrUrl);\n }\n }\n const logger = ensureLogger(sthis, \"defaultKeyBagUrl\");\n logger.Debug().Url(url).Msg(\"from env\");\n return url;\n}\n\nexport function defaultKeyBagOpts(sthis: SuperThis, kbo?: Partial<KeyBagOpts>): KeyBagRuntime {\n kbo = kbo || {};\n if (kbo.keyRuntime) {\n return kbo.keyRuntime;\n }\n const logger = ensureLogger(sthis, \"KeyBag\");\n let url: URI;\n if (kbo.url) {\n url = URI.from(kbo.url);\n logger.Debug().Url(url).Msg(\"from opts\");\n } else {\n let bagFnameOrUrl = sthis.env.get(\"FP_KEYBAG_URL\");\n if (runtimeFn().isBrowser) {\n url = URI.from(bagFnameOrUrl || \"indexdb://fp-keybag\");\n } else {\n if (!bagFnameOrUrl) {\n const home = sthis.env.get(\"HOME\");\n bagFnameOrUrl = `${home}/.fireproof/keybag`;\n url = URI.from(`file://${bagFnameOrUrl}`);\n } else {\n url = URI.from(bagFnameOrUrl);\n }\n }\n logger.Debug().Url(url).Msg(\"from env\");\n }\n const kitem = keyBagProviderFactories.get(url.protocol);\n if (!kitem) {\n throw logger.Error().Url(url).Msg(\"unsupported protocol\").AsError();\n }\n\n if (url.hasParam(\"masterkey\")) {\n throw logger.Error().Url(url).Msg(\"masterkey is not supported\").AsError();\n }\n\n return {\n url,\n crypto: kbo.crypto || toCryptoRuntime({}),\n sthis,\n logger,\n keyLength: kbo.keyLength || 16,\n getBag: () => kitem.factory(url, sthis),\n id: () => {\n return url.toString();\n },\n };\n}\n\nconst _keyBags = new KeyedResolvOnce<KeyBag>();\nexport async function getKeyBag(sthis: SuperThis, kbo: Partial<KeyBagOpts> = {}): Promise<KeyBag> {\n await sthis.start();\n const rt = defaultKeyBagOpts(sthis, kbo);\n return _keyBags.get(rt.id()).once(async () => new KeyBag(rt));\n}\n","import { runtimeFn, URI } from \"@adviser/cement\";\nimport { SysFileSystem } from \"../../../types.js\";\n\nexport function sysFileSystemFactory(uri: URI): Promise<SysFileSystem> {\n const rt = runtimeFn();\n switch (true) {\n case rt.isNodeIsh:\n return import(\"@fireproof/core/node\").then((m) => m.getSysFileSystem(uri));\n case rt.isDeno:\n return import(\"@fireproof/core/deno\").then((m) => m.getSysFileSystem(uri));\n default:\n throw new Error(`unsupported runtime:${rt}`);\n }\n}\n","import { Logger, URI } from \"@adviser/cement\";\nimport { SuperThis, SysFileSystem } from \"../../../types.js\";\nimport { KeyBagProvider, KeyItem } from \"../../key-bag.js\";\nimport { isNotFoundError } from \"../../../utils.js\";\nimport { sysFileSystemFactory } from \"./sys-file-system-factory.js\";\n\ninterface KeyBagCtx {\n readonly dirName: string;\n readonly sysFS: SysFileSystem;\n readonly fName: string;\n}\n\nexport class KeyBagProviderFile implements KeyBagProvider {\n async _prepare(id: string): Promise<KeyBagCtx> {\n await this.sthis.start();\n const sysFS = await sysFileSystemFactory(this.url);\n const dirName = this.url.pathname;\n await sysFS.mkdir(dirName, { recursive: true });\n return {\n dirName,\n sysFS,\n fName: this.sthis.pathOps.join(dirName, `${id.replace(/[^a-zA-Z0-9]/g, \"_\")}.json`),\n };\n }\n\n private readonly url: URI;\n readonly logger: Logger;\n readonly sthis: SuperThis;\n constructor(url: URI, sthis: SuperThis) {\n this.url = url;\n this.sthis = sthis;\n this.logger = sthis.logger;\n }\n\n async get(id: string): Promise<KeyItem | undefined> {\n const ctx = await this._prepare(id);\n try {\n const p = await ctx.sysFS.readfile(ctx.fName);\n const ki = JSON.parse(this.sthis.txt.decode(p)) as KeyItem;\n return ki;\n } catch (e) {\n if (isNotFoundError(e)) {\n return undefined;\n }\n throw this.logger.Error().Err(e).Str(\"file\", ctx.dirName).Msg(\"read bag failed\").AsError();\n }\n }\n\n async set(id: string, item: KeyItem): Promise<void> {\n const ctx = await this._prepare(id);\n const p = this.sthis.txt.encode(JSON.stringify(item, null, 2));\n await ctx.sysFS.writefile(ctx.fName, p);\n }\n}\n","import { URI } from \"@adviser/cement\";\nimport { KeyBagProvider, KeyItem } from \"./key-bag.js\";\nimport { SuperThis } from \"../types.js\";\n\nconst memoryKeyBag = new Map<string, Uint8Array>();\n\nexport class KeyBagProviderMemory implements KeyBagProvider {\n private readonly url: URI;\n readonly sthis: SuperThis;\n constructor(url: URI, sthis: SuperThis) {\n this.url = url;\n this.sthis = sthis;\n }\n key(id: string): string {\n return `${this.url.pathname}/${id}`;\n }\n\n async get(id: string): Promise<KeyItem | undefined> {\n const binKeyItem = memoryKeyBag.get(this.key(id));\n if (binKeyItem) {\n const ki = JSON.parse(this.sthis.txt.decode(binKeyItem)) as KeyItem;\n return ki;\n }\n return undefined;\n }\n\n async set(id: string, item: KeyItem): Promise<void> {\n const p = this.sthis.txt.encode(JSON.stringify(item, null, 2));\n memoryKeyBag.set(this.key(id), p);\n }\n}\n","import { FileTransactionMeta } from \"../types.js\";\nimport { CarTransaction } from \"./transaction.js\";\nimport {\n AnyBlock,\n AnyLink,\n CarGroup,\n CarHeader,\n CarLog,\n CarMakeable,\n CommitOpts,\n DataStore,\n DbMeta,\n MetaStore,\n toCIDBlock,\n TransactionMeta,\n WALStore,\n} from \"./types.js\";\nimport * as CBW from \"@fireproof/vendor/@ipld/car/buffer-writer\";\nimport { CID } from \"multiformats\";\nimport { encode } from \"../runtime/wait-pr-multiformats/block.js\";\nimport { BlockEncoder } from \"../runtime/wait-pr-multiformats/codec-interface.js\";\nimport { sha256 as hasher } from \"multiformats/hashes/sha2\";\nimport * as dagCodec from \"@fireproof/vendor/@ipld/dag-cbor\";\n\nasync function encodeCarFile(roots: AnyLink[], t: CarMakeable, codec: BlockEncoder<number, Uint8Array>): Promise<AnyBlock> {\n let size = 0;\n const headerSize = CBW.headerLength({ roots } as { roots: CID<unknown, number, number, 1>[] });\n size += headerSize;\n for (const { cid, bytes } of t.entries()) {\n size += CBW.blockLength({ cid, bytes } as CBW.Block);\n }\n const buffer = new Uint8Array(size);\n const writer = CBW.createWriter(buffer.buffer, { headerSize });\n\n for (const r of roots) {\n writer.addRoot(r as CID<unknown, number, number, 1>);\n }\n\n for (const { cid, bytes } of t.entries()) {\n writer.write({ cid, bytes } as CBW.Block);\n }\n writer.close();\n return await encode({ value: writer.bytes, hasher, codec });\n}\n\nexport async function createCarFile(\n encoder: BlockEncoder<number, Uint8Array>,\n cid: AnyLink,\n t: CarTransaction,\n): Promise<{ cid: AnyLink; bytes: Uint8Array }> {\n // try {\n return encodeCarFile([cid], t, encoder);\n // const keycr = await store.keyedCrypto()\n // return keycr.isEncrypting\n // ? await encryptedEncodeCarFile(this.logger, keycr, cid, t)\n // : await encodeCarFile([cid], t);\n // } catch (e) {\n // throw store.logger.Error().Err(e).Msg(\"error creating car file\").AsError();\n // }\n}\n\nexport async function commitFiles(\n fileStore: DataStore,\n walStore: WALStore,\n t: CarTransaction,\n done: TransactionMeta,\n // opts: CommitOpts = { noLoader: false, compact: false },\n): Promise<CarGroup> {\n const { files: roots } = makeFileCarHeader(done as FileTransactionMeta) as {\n files: AnyLink[];\n };\n const cids: AnyLink[] = [];\n // const fileStore = await this.fileStore();\n const codec = (await fileStore.keyedCrypto()).codec();\n const cars = await prepareCarFilesFiles(codec, roots, t);\n for (const car of cars) {\n const { cid, bytes } = car;\n // real deal\n await fileStore.save({ cid, bytes });\n await walStore.enqueueFile(cid /*, !!opts.public*/);\n cids.push(cid);\n }\n return cids;\n}\n\nfunction makeFileCarHeader(result: FileTransactionMeta): TransactionMeta {\n const files: AnyLink[] = [];\n for (const [, meta] of Object.entries(result.files || {})) {\n if (meta && typeof meta === \"object\" && \"cid\" in meta && meta !== null) {\n files.push(meta.cid as AnyLink);\n }\n }\n return { ...result, files };\n}\n\nasync function prepareCarFilesFiles(\n encoder: BlockEncoder<number, Uint8Array>,\n roots: AnyLink[],\n t: CarTransaction,\n // isPublic: boolean,\n): Promise<{ cid: AnyLink; bytes: Uint8Array }[]> {\n // const theKey = isPublic ? null : await this._getKey();\n // const kc = await store.keyedCrypto()\n // const car = kc.isEncrypting\n // ? await encryptedEncodeCarFile(this.logger, kc, roots[0], t)\n // : await encodeCarFile(roots, t);\n return [await encodeCarFile(roots, t, encoder)];\n}\n\n// PUR Commit\n\nfunction makeCarHeader<T>(meta: T, cars: CarLog, compact = false): CarHeader<T> {\n const coreHeader = compact ? { cars: [], compact: cars } : { cars, compact: [] };\n return { ...coreHeader, meta };\n}\n\nasync function encodeCarHeader<T>(fp: CarHeader<T>) {\n return (await encode({\n value: { fp },\n hasher,\n codec: dagCodec,\n })) as AnyBlock;\n}\n\nexport interface CommitParams {\n readonly encoder: BlockEncoder<number, Uint8Array>;\n readonly carLog: CarLog;\n readonly carStore: DataStore;\n readonly WALStore: WALStore;\n readonly metaStore: MetaStore;\n readonly threshold?: number;\n}\n\nexport async function commit<T>(\n params: CommitParams,\n t: CarTransaction,\n done: T,\n opts: CommitOpts = { noLoader: false, compact: false },\n): Promise<{ cgrp: CarGroup; header: CarHeader<T> }> {\n const fp = makeCarHeader<T>(done, params.carLog, !!opts.compact);\n const rootBlock = await encodeCarHeader(fp);\n\n const cars = await prepareCarFiles(params.encoder, params.threshold, rootBlock, t);\n const cids: AnyLink[] = [];\n for (const car of cars) {\n const { cid, bytes } = car;\n await params.carStore.save({ cid, bytes });\n cids.push(cid);\n }\n\n // await this.cacheTransaction(t);\n const newDbMeta = { cars: cids } as DbMeta;\n await params.WALStore.enqueue(newDbMeta, opts);\n await params.metaStore.save(newDbMeta);\n return { cgrp: cids, header: fp };\n}\n\nasync function prepareCarFiles(\n encoder: BlockEncoder<number, Uint8Array>,\n threshold: number | undefined,\n rootBlock: AnyBlock,\n t: CarTransaction,\n): Promise<{ cid: AnyLink; bytes: Uint8Array }[]> {\n // const theKey = isPublic ? undefined : await this._getKey();\n const carFiles: { cid: AnyLink; bytes: Uint8Array }[] = [];\n threshold = threshold || 128000 * 8; // remove the * 8 to fit partykit\n let clonedt = new CarTransaction(t.parent, { add: false, noLoader: false });\n clonedt.putSync(rootBlock.cid, rootBlock.bytes);\n let newsize = CBW.blockLength(toCIDBlock(rootBlock));\n let cidRootBlock = rootBlock;\n for (const { cid, bytes } of t.entries()) {\n newsize += CBW.blockLength(toCIDBlock({ cid: cid, bytes }));\n if (newsize >= threshold) {\n carFiles.push(await createCarFile(encoder, cidRootBlock.cid, clonedt));\n clonedt = new CarTransaction(t.parent, { add: false, noLoader: false });\n clonedt.putSync(cid, bytes);\n cidRootBlock = { cid, bytes };\n newsize = CBW.blockLength(toCIDBlock({ cid, bytes })); //+ CBW.blockLength(rootBlock)\n } else {\n clonedt.putSync(cid, bytes);\n }\n }\n // HEREMENO\n carFiles.push(await createCarFile(encoder, cidRootBlock.cid, clonedt));\n // console.log(\"split to \", carFiles.length, \"files\")\n return carFiles;\n}\n","import { Logger } from \"@adviser/cement\";\nimport type { CarClockHead, CarClockLink, DbMeta } from \"./types.js\";\nimport { ensureLogger } from \"../utils.js\";\nimport { SuperThis } from \"../types.js\";\n\ninterface TaskItem {\n readonly cid: string;\n readonly dbMeta: DbMeta;\n retries: number;\n}\n\nexport class TaskManager {\n // we need to remove the events after some time\n private readonly eventsWeHandled = new Set<string>();\n\n private queue: TaskItem[] = [];\n private isProcessing = false;\n\n readonly logger: Logger;\n readonly callback: (dbMeta: DbMeta) => Promise<void>;\n constructor(sthis: SuperThis, callback: (dbMeta: DbMeta) => Promise<void>) {\n this.logger = ensureLogger(sthis, \"TaskManager\");\n this.callback = callback;\n }\n\n async handleEvent(cid: CarClockLink, parents: CarClockHead, dbMeta: DbMeta) {\n for (const parent of parents) {\n this.eventsWeHandled.add(parent.toString());\n }\n this.queue.push({ cid: cid.toString(), dbMeta, retries: 0 });\n this.queue = this.queue.filter(({ cid }) => !this.eventsWeHandled.has(cid));\n void this.processQueue();\n }\n\n private async processQueue() {\n if (this.isProcessing) return;\n this.isProcessing = true;\n const filteredQueue = this.queue.filter(({ cid }) => !this.eventsWeHandled.has(cid));\n const first = filteredQueue[0];\n if (!first) {\n this.isProcessing = false;\n return;\n }\n try {\n await this.callback(first.dbMeta);\n this.eventsWeHandled.add(first.cid);\n this.queue = this.queue.filter(({ cid }) => !this.eventsWeHandled.has(cid));\n } catch (err) {\n if (first.retries++ > 3) {\n this.logger.Error().Str(\"cid\", first.cid).Msg(\"failed to process event block after 3 retries\");\n this.queue = this.queue.filter(({ cid }) => cid !== first.cid);\n }\n await new Promise((resolve) => setTimeout(resolve, 50));\n throw this.logger.Error().Err(err).Msg(\"failed to process event block\").AsError();\n } finally {\n this.isProcessing = false;\n if (this.queue.length > 0) {\n void this.processQueue();\n }\n }\n }\n}\n","import { CryptoRuntime, Logger, URI } from \"@adviser/cement\";\nimport { BytesWithIv, CodecOpts, IvAndBytes, IvKeyIdData, KeyedCrypto, KeyWithFingerPrint } from \"../blockstore/index.js\";\nimport { ensureLogger, UInt8ArrayEqual } from \"../utils.js\";\nimport { KeyBag } from \"./key-bag.js\";\nimport type { BlockCodec } from \"./wait-pr-multiformats/codec-interface.js\";\nimport { base58btc } from \"multiformats/bases/base58\";\nimport { sha256 as hasher } from \"multiformats/hashes/sha2\";\nimport * as CBOR from \"@fireproof/vendor/cborg\";\nimport { PARAM, SuperThis } from \"../types.js\";\n\ninterface GenerateIVFn {\n calc(ko: KeyedCrypto, crypto: CryptoRuntime, data: Uint8Array): Promise<Uint8Array>;\n verify(ko: KeyedCrypto, crypto: CryptoRuntime, iv: Uint8Array, data: Uint8Array): Promise<boolean>;\n}\n\nconst generateIV: Record<string, GenerateIVFn> = {\n random: {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n calc: async (ko: KeyedCrypto, crypto: CryptoRuntime, data: Uint8Array): Promise<Uint8Array> => {\n return crypto.randomBytes(ko.ivLength);\n },\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n verify: async (ko: KeyedCrypto, crypto: CryptoRuntime, iv: Uint8Array, data: Uint8Array): Promise<boolean> => {\n return true;\n },\n },\n hash: {\n calc: async (ko: KeyedCrypto, crypto: CryptoRuntime, data: Uint8Array): Promise<Uint8Array> => {\n const hash = await hasher.digest(data);\n const hashBytes = new Uint8Array(hash.bytes);\n const hashArray = new Uint8Array(ko.ivLength);\n for (let i = 0; i < hashBytes.length; i++) {\n hashArray[i % ko.ivLength] ^= hashBytes[i];\n }\n return hashArray;\n },\n verify: async function (ko: KeyedCrypto, crypto: CryptoRuntime, iv: Uint8Array, data: Uint8Array): Promise<boolean> {\n return ko.url.getParam(PARAM.IV_VERIFY) !== \"disable\" && UInt8ArrayEqual(iv, await this.calc(ko, crypto, data));\n },\n },\n};\n\nfunction getGenerateIVFn(url: URI, opts: Partial<CodecOpts>): GenerateIVFn {\n const ivhash = opts.ivCalc || url.getParam(PARAM.IV_HASH) || \"hash\";\n return generateIV[ivhash] || generateIV[\"hash\"];\n}\n\nexport class BlockIvKeyIdCodec implements BlockCodec<0x300539, Uint8Array> {\n readonly code = 0x300539;\n readonly name = \"Fireproof@encrypted-block:aes-gcm\";\n\n readonly ko: KeyedCrypto;\n readonly iv?: Uint8Array;\n readonly opts: Partial<CodecOpts>;\n constructor(ko: KeyedCrypto, iv?: Uint8Array, opts?: CodecOpts) {\n this.ko = ko;\n this.iv = iv;\n this.opts = opts || {};\n }\n\n async encode(data: Uint8Array): Promise<Uint8Array> {\n const calcIv = this.iv || (await getGenerateIVFn(this.ko.url, this.opts).calc(this.ko, this.ko.crypto, data));\n const { iv } = this.ko.algo(calcIv);\n const fprt = await this.ko.fingerPrint();\n const keyId = base58btc.decode(fprt);\n this.ko.logger.Debug().Str(\"fp\", fprt).Msg(\"encode\");\n return CBOR.encode({\n iv: iv,\n keyId: keyId,\n data: await this.ko._encrypt({ iv, bytes: data }),\n } as IvKeyIdData);\n }\n\n async decode(abytes: Uint8Array | ArrayBuffer): Promise<Uint8Array> {\n let bytes: Uint8Array;\n if (abytes instanceof Uint8Array) {\n bytes = abytes;\n } else {\n bytes = new Uint8Array(abytes);\n }\n const { iv, keyId, data } = CBOR.decode(bytes) as IvKeyIdData;\n const fprt = await this.ko.fingerPrint();\n this.ko.logger.Debug().Str(\"fp\", base58btc.encode(keyId)).Msg(\"decode\");\n if (base58btc.encode(keyId) !== fprt) {\n throw this.ko.logger.Error().Str(\"fp\", fprt).Str(\"keyId\", base58btc.encode(keyId)).Msg(\"keyId mismatch\").AsError();\n }\n const result = await this.ko._decrypt({ iv: iv, bytes: data });\n if (!this.opts?.noIVVerify && !(await getGenerateIVFn(this.ko.url, this.opts).verify(this.ko, this.ko.crypto, iv, result))) {\n throw this.ko.logger.Error().Msg(\"iv missmatch\").AsError();\n }\n return result;\n }\n}\n\nclass keyedCrypto implements KeyedCrypto {\n readonly ivLength = 12;\n readonly logger: Logger;\n readonly crypto: CryptoRuntime;\n readonly key: KeyWithFingerPrint;\n readonly isEncrypting = true;\n readonly url: URI;\n constructor(url: URI, key: KeyWithFingerPrint, cyopt: CryptoRuntime, sthis: SuperThis) {\n this.logger = ensureLogger(sthis, \"keyedCrypto\");\n this.crypto = cyopt;\n this.key = key;\n this.url = url;\n }\n fingerPrint(): Promise<string> {\n return Promise.resolve(this.key.fingerPrint);\n }\n codec(iv?: Uint8Array, opts?: CodecOpts): BlockCodec<number, Uint8Array> {\n return new BlockIvKeyIdCodec(this, iv, opts);\n }\n algo(iv?: Uint8Array) {\n return {\n name: \"AES-GCM\",\n iv: iv || this.crypto.randomBytes(this.ivLength),\n tagLength: 128,\n };\n }\n async _decrypt(data: IvAndBytes): Promise<Uint8Array> {\n this.logger.Debug().Len(data.bytes, \"bytes\").Len(data.iv, \"iv\").Str(\"fp\", this.key.fingerPrint).Msg(\"decrypting\");\n return new Uint8Array(await this.crypto.decrypt(this.algo(data.iv), this.key.key, data.bytes));\n }\n async _encrypt(data: BytesWithIv): Promise<Uint8Array> {\n this.logger.Debug().Len(data.bytes).Str(\"fp\", this.key.fingerPrint).Msg(\"encrypting\");\n const a = this.algo(data.iv);\n return new Uint8Array(await this.crypto.encrypt(a, this.key.key, data.bytes));\n }\n}\n\nclass nullCodec implements BlockCodec<0x0, Uint8Array> {\n readonly code = 0x0;\n readonly name = \"Fireproof@unencrypted-block\";\n\n encode(data: Uint8Array): Uint8Array {\n return data;\n }\n decode(data: Uint8Array): Uint8Array {\n return data;\n }\n}\n\nclass noCrypto implements KeyedCrypto {\n readonly ivLength = 0;\n readonly code = 0x0;\n readonly name = \"Fireproof@unencrypted-block\";\n readonly logger: Logger;\n readonly crypto: CryptoRuntime;\n readonly isEncrypting = false;\n readonly _fingerPrint = \"noCrypto:\" + Math.random();\n readonly url: URI;\n constructor(url: URI, cyrt: CryptoRuntime, sthis: SuperThis) {\n this.logger = ensureLogger(sthis, \"noCrypto\");\n this.crypto = cyrt;\n this.url = url;\n }\n\n fingerPrint(): Promise<string> {\n return Promise.resolve(this._fingerPrint);\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n codec(iv?: Uint8Array): BlockCodec<number, Uint8Array> {\n return new nullCodec();\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n algo(iv?: Uint8Array): { name: string; iv: Uint8Array; tagLength: number } {\n return {\n name: \"noCrypto\",\n iv: new Uint8Array(),\n tagLength: 0,\n };\n }\n _decrypt(): Promise<Uint8Array> {\n throw this.logger.Error().Msg(\"noCrypto.decrypt not implemented\").AsError();\n }\n _encrypt(): Promise<Uint8Array> {\n throw this.logger.Error().Msg(\"noCrypto.decrypt not implemented\").AsError();\n }\n}\n\nexport async function keyedCryptoFactory(url: URI, kb: KeyBag, sthis: SuperThis): Promise<KeyedCrypto> {\n const storekey = url.getParam(PARAM.STORE_KEY);\n if (storekey && storekey !== \"insecure\") {\n let rkey = await kb.getNamedKey(storekey, true);\n if (rkey.isErr()) {\n try {\n rkey = await kb.toKeyWithFingerPrint(storekey);\n } catch (e) {\n throw (\n sthis.logger\n .Error()\n .Err(e)\n .Str(\"keybag\", kb.rt.id())\n // .Result(\"key\", rkey)\n .Str(\"name\", storekey)\n .Msg(\"getNamedKey failed\")\n .AsError()\n );\n }\n }\n return new keyedCrypto(url, rkey.Ok(), kb.rt.crypto, sthis);\n }\n return new noCrypto(url, kb.rt.crypto, sthis);\n}\n","import { CID } from \"multiformats\";\nimport { DbMetaEvent, WALState } from \"./types.js\";\nimport { Result } from \"@adviser/cement\";\n\nexport enum FPEnvelopeType {\n CAR = \"car\",\n FILE = \"file\",\n META = \"meta\",\n WAL = \"wal\",\n}\n\nexport interface FPEnvelope<T> {\n readonly type: FPEnvelopeType;\n readonly payload: T;\n}\n\nexport interface FPEnvelopeCar extends FPEnvelope<Uint8Array> {\n readonly type: FPEnvelopeType.CAR;\n}\n\nexport interface FPEnvelopeFile extends FPEnvelope<Uint8Array> {\n readonly type: FPEnvelopeType.FILE;\n}\n\nexport interface FPEnvelopeMeta extends FPEnvelope<DbMetaEvent[]> {\n readonly type: FPEnvelopeType.META;\n}\n\nexport interface FPWALCarsOps {\n readonly cars: CID[];\n}\n// export interface FPWAL {\n// // fileOperations: any[]; will be added with connector-fixes\n// // noLoaderOps: any[]; will be added with connector-fixes\n// readonly operations: FPWALCarsOps[];\n// }\nexport interface FPEnvelopeWAL extends FPEnvelope<WALState> {\n readonly type: FPEnvelopeType.WAL;\n}\n\n// export function WAL2FPMsg(sthis: SuperThis, ws: WALState): Result<FPEnvelopeWAL> {\n// return Result.Ok({\n// type: \"wal\",\n// payload: ws\n// })\n// }\n\n// export function FPMsg2WAL(fpmsg: FPEnvelopeWAL): Result<WALState> {\n// // const renv = FPMsgMatch2Envelope(fpmsg, \"wal\");\n// // if (renv.isErr()) {\n// // return Result.Err(renv.Err());\n// // }\n// if (fpmsg.type !== \"wal\") {\n// return Result.Err(`expected type to be wal`);\n// }\n// const convertCids = fpmsg.payload as WALState;\n// for (const op of convertCids.operations) {\n// const cars = []\n// for (const strCid of op.cars) {\n// for (const cidVal of Object.values(strCid)) {\n// cars.push(CID.parse(cidVal));\n// }\n// }\n// (op as {cars: CID[]}).cars = cars;\n// }\n// return Result.Ok(convertCids);\n// }\n\n// export function Meta2FPMsg(fpmetas: DbMetaEvent[]): Uint8Array {\n// /*\n// [\n// {\n// \"cid\":\"bafyreibc2rbsszqw5z7xiojra2vgskl3mi7iegf3ynpofm6w6lcxx4r7ha\",\n// \"data\":\"MomRkYXRhoWZkYk1ldGFYU3siY2FycyI6W3siLyI6ImJhZzR5dnFhYmNpcW9peXdlb2Vjd214Z3VmdDV4YmJsMnFxd2c3Z2tmYTV6cG91d2huYWVoN3E1b3o2eTNoMnkifV19Z3BhcmVudHOB2CpYJQABcRIgTXAXVfzn7tghZBnaOrXq0+bmY3kK9f1CCNrGfeA73hk=\",\n// \"parents\":[\"bafyreicnoalvl7hh53mcczaz3i5ll2wt43tgg6ik6x6uecg2yz66ao66de\"]\n// }\n// ]\n// */\n// return encode({ type: \"meta\", payload: fpmetas } as FPEnvelopeMeta);\n// }\n\n// export function FPMsg2Meta(fpmsg: Uint8Array): Result<DbMeta> {\n// const renv = FPMsgMatch2Envelope(fpmsg, \"meta\");\n// if (renv.isErr()) {\n// return Result.Err(renv.Err());\n// }\n// return Result.Ok(renv.Ok().payload as DbMeta);\n// }\n\nexport function Car2FPMsg(fpcar: Uint8Array): Result<FPEnvelopeCar> {\n return Result.Ok({ type: FPEnvelopeType.CAR, payload: fpcar });\n}\n\n// export function FPMsg2Car(fpmsg: Uint8Array): Result<Uint8Array> {\n// const renv = FPMsgMatch2Envelope(fpmsg, \"car\");\n// if (renv.isErr()) {\n// return Result.Err(renv.Err());\n// }\n// return Result.Ok(renv.Ok().payload as Uint8Array);\n// }\n\nexport function File2FPMsg(fpfile: Uint8Array): Result<FPEnvelopeFile> {\n return Result.Ok({ type: FPEnvelopeType.FILE, payload: fpfile });\n}\n\n// export function FPMsg2File(fpmsg: Uint8Array): Result<Uint8Array> {\n// const renv = FPMsgMatch2Envelope(fpmsg, \"file\");\n// if (renv.isErr()) {\n// return Result.Err(renv.Err());\n// }\n// return Result.Ok(renv.Ok().payload as Uint8Array);\n// }\n\n// export function FPMsgMatch2Envelope(fpmsg: Uint8Array, ...types: string[]): Result<FPEnvelope<unknown>> {\n// let env: FPEnvelope<unknown>;\n// try {\n// env = decode(fpmsg);\n// } catch (e) {\n// return Result.Err(`failed to decode envelope: ${e}`);\n// }\n// if (typeof env !== \"object\") {\n// return Result.Err(`expected envelope to be an object`);\n// }\n// if (typeof env.type !== \"string\") {\n// return Result.Err(`expected type to be a string`);\n// }\n// if (types.length > 0 && !types.includes(env.type)) {\n// return Result.Err(`expected type to be ${types}`);\n// }\n// // need to check if the payload is a valid WAL\n// return Result.Ok(env);\n// }\n","import { Result, URI } from \"@adviser/cement\";\nimport {\n SerdeGateway,\n SerdeGatewayBuildUrlReturn,\n SerdeGatewayCloseReturn,\n SerdeGatewayDeleteReturn,\n SerdeGatewayDestroyReturn,\n SerdeGatewayGetReturn,\n SerdeGatewayInterceptor,\n SerdeGatewayPutReturn,\n SerdeGatewayStartReturn,\n SerdeGatewaySubscribeReturn,\n SerdeGetResult,\n UnsubscribeResult,\n VoidResult,\n} from \"./serde-gateway.js\";\nimport { SuperThis } from \"../types.js\";\nimport { FPEnvelope, FPEnvelopeMeta } from \"./fp-envelope.js\";\nimport { Loadable } from \"./types.js\";\n\nexport class PassThroughGateway implements SerdeGatewayInterceptor {\n async buildUrl(sthis: SuperThis, url: URI, key: string): Promise<Result<SerdeGatewayBuildUrlReturn>> {\n const op = { url, key };\n return Result.Ok({ op });\n }\n async start(sthis: SuperThis, url: URI): Promise<Result<SerdeGatewayStartReturn>> {\n const op = { url };\n return Result.Ok({ op });\n }\n async close(sthis: SuperThis, url: URI): Promise<Result<SerdeGatewayCloseReturn>> {\n const op = { url };\n return Result.Ok({ op });\n }\n async delete(sthis: SuperThis, url: URI): Promise<Result<SerdeGatewayDeleteReturn>> {\n const op = { url };\n return Result.Ok({ op });\n }\n async destroy(sthis: SuperThis, url: URI): Promise<Result<SerdeGatewayDestroyReturn>> {\n const op = { url };\n return Result.Ok({ op });\n }\n async put<T>(sthis: SuperThis, url: URI, body: FPEnvelope<T>): Promise<Result<SerdeGatewayPutReturn<T>>> {\n const op = { url, body };\n return Result.Ok({ op });\n }\n async get<S>(sthis: SuperThis, url: URI): Promise<Result<SerdeGatewayGetReturn<S>>> {\n const op = { url };\n return Result.Ok({ op });\n }\n async subscribe(\n sthis: SuperThis,\n url: URI,\n callback: (meta: FPEnvelopeMeta) => Promise<void>,\n ): Promise<Result<SerdeGatewaySubscribeReturn>> {\n const op = { url, callback };\n return Result.Ok({ op });\n }\n}\n\nconst passThrougthGateway = new PassThroughGateway();\n\nexport class InterceptorGateway implements SerdeGateway {\n readonly innerGW: SerdeGateway;\n readonly interceptor: SerdeGatewayInterceptor;\n\n constructor(sthis: SuperThis, innerGW: SerdeGateway, interceptor: SerdeGatewayInterceptor | undefined) {\n this.innerGW = innerGW;\n this.interceptor = interceptor || passThrougthGateway;\n }\n\n async buildUrl(sthis: SuperThis, baseUrl: URI, key: string, loader: Loadable): Promise<Result<URI>> {\n const rret = await this.interceptor.buildUrl(sthis, baseUrl, key, loader);\n if (rret.isErr()) {\n return Result.Err(rret.Err());\n }\n const ret = rret.unwrap();\n if (ret.stop && ret.value) {\n return ret.value;\n }\n return this.innerGW.buildUrl(sthis, ret.op.url, ret.op.key, loader);\n }\n\n async destroy(sthis: SuperThis, iurl: URI, loader: Loadable): Promise<Result<void>> {\n const rret = await this.interceptor.destroy(sthis, iurl, loader);\n if (rret.isErr()) {\n return Result.Err(rret.Err());\n }\n const ret = rret.unwrap();\n if (ret.stop && ret.value) {\n return ret.value;\n }\n return this.innerGW.destroy(sthis, ret.op.url, loader);\n }\n\n async start(sthis: SuperThis, url: URI, loader: Loadable): Promise<Result<URI>> {\n const rret = await this.interceptor.start(sthis, url, loader);\n if (rret.isErr()) {\n return Result.Err(rret.Err());\n }\n const ret = rret.unwrap();\n if (ret.stop && ret.value) {\n return ret.value;\n }\n return await this.innerGW.start(sthis, ret.op.url, loader);\n }\n\n async close(sthis: SuperThis, url: URI, loader: Loadable): Promise<VoidResult> {\n const rret = await this.interceptor.close(sthis, url, loader);\n if (rret.isErr()) {\n return Result.Err(rret.Err());\n }\n const ret = rret.unwrap();\n if (ret.stop && ret.value) {\n return ret.value;\n }\n return await this.innerGW.close(sthis, ret.op.url, loader);\n }\n\n async put<T>(sthis: SuperThis, url: URI, fpEnv: FPEnvelope<T>, loader: Loadable): Promise<VoidResult> {\n const rret = await this.interceptor.put(sthis, url, fpEnv, loader);\n if (rret.isErr()) {\n return Result.Err(rret.Err());\n }\n const ret = rret.unwrap();\n if (ret.stop && ret.value) {\n return ret.value;\n }\n return this.innerGW.put(sthis, ret.op.url, ret.op.body, loader);\n }\n\n async get<S>(sthis: SuperThis, url: URI, loader: Loadable): Promise<SerdeGetResult<S>> {\n const rret = await this.interceptor.get<S>(sthis, url, loader);\n if (rret.isErr()) {\n return Result.Err(rret.Err());\n }\n const ret = rret.unwrap();\n if (ret.stop && ret.value) {\n return ret.value;\n }\n return this.innerGW.get(sthis, ret.op.url, loader);\n }\n\n async subscribe(\n sthis: SuperThis,\n url: URI,\n callback: (msg: FPEnvelopeMeta) => Promise<void>,\n loader: Loadable,\n ): Promise<UnsubscribeResult> {\n if (!this.innerGW.subscribe) {\n return Result.Err(sthis.logger.Error().Url(url).Msg(\"subscribe not supported\").AsError());\n }\n const rret = await this.interceptor.subscribe(sthis, url, callback, loader);\n if (rret.isErr()) {\n return Result.Err(rret.Err());\n }\n const ret = rret.unwrap();\n if (ret.stop && ret.value) {\n return ret.value;\n }\n return this.innerGW.subscribe(sthis, ret.op.url, ret.op.callback, loader);\n }\n\n async delete(sthis: SuperThis, url: URI, loader: Loadable): Promise<VoidResult> {\n const rret = await this.interceptor.delete(sthis, url, loader);\n if (rret.isErr()) {\n return Result.Err(rret.Err());\n }\n const ret = rret.unwrap();\n if (ret.stop && ret.value) {\n return ret.value;\n }\n return this.innerGW.delete(sthis, url, loader);\n }\n\n async getPlain(sthis: SuperThis, url: URI, key: string, loader?: Loadable): Promise<Result<Uint8Array>> {\n return this.innerGW.getPlain(sthis, url, key, loader);\n }\n}\n","import { BuildURI, runtimeFn, URI } from \"@adviser/cement\";\nimport { PARAM, SuperThis } from \"../types.js\";\nimport { SerdeGateway } from \"./serde-gateway.js\";\nimport { FILESTORE_VERSION } from \"../runtime/gateways/file/version.js\";\nimport { MemoryGateway } from \"../runtime/gateways/memory/gateway.js\";\nimport { INDEXDB_VERSION } from \"../runtime/index.js\";\nimport { FileGateway } from \"../runtime/gateways/file/gateway-impl.js\";\nimport { sysFileSystemFactory } from \"../runtime/gateways/file/sys-file-system-factory.js\";\nimport { DefSerdeGateway } from \"../runtime/gateways/def-serde-gateway.js\";\nimport { Gateway } from \"./gateway.js\";\n\nexport interface SerdeGatewayFactoryItem {\n readonly protocol: string;\n // readonly overrideBaseURL?: string; // if this set it overrides the defaultURL\n // readonly overrideRegistration?: boolean; // if this is set, it will override the registration\n readonly isDefault?: boolean;\n\n defaultURI(sthis: SuperThis): URI;\n\n serdegateway(sthis: SuperThis): Promise<SerdeGateway>;\n\n // readonly gateway?: (sthis: SuperThis) => Promise<SerdeGateway>;\n // readonly test: (sthis: SuperThis, gfi: GatewayFactoryItem) => Promise<TestGateway>;\n // which switches between file and indexdb\n // readonly data: (logger: Logger) => Promise<Gateway>;\n // readonly meta: (logger: Logger) => Promise<Gateway>;\n // readonly wal: (logger: Logger) => Promise<Gateway>;\n // readonly test: (logger: Logger) => Promise<TestStore>;\n}\n\nconst storeFactory = new Map<string, SerdeGatewayFactoryItem>();\n\nexport function getDefaultURI(sthis: SuperThis, protocol?: string): URI {\n if (protocol) {\n if (!protocol.endsWith(\":\")) {\n protocol += \":\";\n }\n const gfi = storeFactory.get(protocol);\n if (gfi) {\n return gfi.defaultURI(sthis);\n }\n }\n const found = Array.from(storeFactory.values()).find((item) => item.isDefault);\n if (!found) {\n throw sthis.logger.Error().Msg(\"no default found\").AsError();\n }\n return found.defaultURI(sthis);\n}\n\nexport interface SerdeOrGatewayFactoryItem {\n readonly protocol: string;\n readonly isDefault?: boolean;\n\n readonly defaultURI: (sthis: SuperThis) => URI;\n\n readonly serdegateway?: (sthis: SuperThis) => Promise<SerdeGateway>;\n readonly gateway?: (sthis: SuperThis) => Promise<Gateway>;\n}\n\nexport function registerStoreProtocol(item: SerdeOrGatewayFactoryItem): () => void {\n let protocol = item.protocol;\n if (!protocol.endsWith(\":\")) {\n protocol += \":\";\n }\n if (!item.serdegateway && !item.gateway) {\n throw new Error(`registerStoreProtocol needs a gateway or serdegateway`);\n }\n let serdegateway: (sthis: SuperThis) => Promise<SerdeGateway>;\n if (item.gateway) {\n serdegateway = async (sthis) => {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const m = await item.gateway!(sthis);\n // console.log(\"Gateway Plug in DefSerdeGateway\", m);\n return new DefSerdeGateway(m);\n };\n } else {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n serdegateway = item.serdegateway!;\n }\n if (item.isDefault) {\n Array.from(storeFactory.values()).forEach((items) => {\n (items as { isDefault: boolean }).isDefault = false;\n });\n }\n storeFactory.set(protocol, {\n ...item,\n serdegateway,\n });\n return () => {\n storeFactory.delete(protocol);\n };\n}\n\nexport function getGatewayFactoryItem(protocol: string): SerdeGatewayFactoryItem | undefined {\n return storeFactory.get(protocol);\n}\n\nexport function defaultGatewayFactoryItem(): SerdeGatewayFactoryItem {\n const found = Array.from(storeFactory.values()).find((item) => item.isDefault);\n if (!found) {\n throw new Error(\"no default found\");\n }\n return found;\n}\n\nfunction defaultURI(sthis: SuperThis) {\n const rt = runtimeFn();\n return (\n BuildURI.from(\"file://\")\n // .pathname(`${sthis.env.get(\"HOME\")}/.fireproof/${FILESTORE_VERSION.replace(/-.*$/, \"\")}`)\n .pathname(`${sthis.env.get(\"HOME\")}/.fireproof/${FILESTORE_VERSION.replace(/-.*$/, \"\")}`)\n .setParam(PARAM.VERSION, FILESTORE_VERSION)\n .setParam(PARAM.URL_GEN, \"default\")\n .setParam(PARAM.RUNTIME, rt.isNodeIsh ? \"node\" : rt.isDeno ? \"deno\" : \"unknown\")\n .URI()\n );\n}\n\nif (runtimeFn().isNodeIsh || runtimeFn().isDeno) {\n registerStoreProtocol({\n protocol: \"file:\",\n isDefault: true,\n defaultURI,\n gateway: async (sthis) => {\n return new FileGateway(sthis, await sysFileSystemFactory(defaultURI(sthis)));\n },\n });\n}\n\nif (runtimeFn().isBrowser) {\n registerStoreProtocol({\n protocol: \"indexdb:\",\n isDefault: true,\n defaultURI: () => {\n return BuildURI.from(\"indexdb://\")\n .pathname(\"fp\")\n .setParam(PARAM.VERSION, INDEXDB_VERSION)\n .setParam(PARAM.RUNTIME, \"browser\")\n .URI();\n },\n gateway: async () => {\n const { GatewayImpl } = await import(\"@fireproof/core/web\");\n return new GatewayImpl();\n },\n });\n}\n\nconst memory = new Map<string, Uint8Array>();\nregisterStoreProtocol({\n protocol: \"memory:\",\n isDefault: false,\n defaultURI: () => {\n return BuildURI.from(\"memory://\").pathname(\"ram\").URI();\n },\n gateway: async (sthis) => {\n return new MemoryGateway(sthis, memory);\n },\n});\n","export const FILESTORE_VERSION = \"v0.19-file\";\n","import { Result, URI } from \"@adviser/cement\";\nimport { Gateway, GetResult } from \"../../../blockstore/gateway.js\";\nimport { PARAM, SuperThis } from \"../../../types.js\";\nimport { MEMORY_VERSION } from \"./version.js\";\nimport { NotFoundError } from \"../../../utils.js\";\nimport { VoidResult } from \"../../../blockstore/serde-gateway.js\";\n\nexport class MemoryGateway implements Gateway {\n readonly memorys: Map<string, Uint8Array>;\n readonly sthis: SuperThis;\n constructor(sthis: SuperThis, memorys: Map<string, Uint8Array>) {\n this.memorys = memorys;\n this.sthis = sthis;\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 start(baseUrl: URI): Promise<Result<URI>> {\n return Promise.resolve(Result.Ok(baseUrl.build().setParam(PARAM.VERSION, MEMORY_VERSION).URI()));\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n close(baseUrl: URI): Promise<VoidResult> {\n return Promise.resolve(Result.Ok(undefined));\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n destroy(baseUrl: URI): Promise<VoidResult> {\n this.memorys.clear();\n return Promise.resolve(Result.Ok(undefined));\n }\n async put(url: URI, bytes: Uint8Array): Promise<VoidResult> {\n this.memorys.set(url.toString(), bytes);\n return Result.Ok(undefined);\n }\n // get could return a NotFoundError if the key is not found\n get(url: URI): Promise<GetResult> {\n const x = this.memorys.get(url.toString());\n if (!x) {\n return Promise.resolve(Result.Err(new NotFoundError(\"not found\")));\n }\n return Promise.resolve(Result.Ok(x));\n }\n delete(url: URI): Promise<VoidResult> {\n this.memorys.delete(url.toString());\n return Promise.resolve(Result.Ok(undefined));\n }\n\n async getPlain(url: URI, key: string): Promise<Result<Uint8Array>> {\n const x = this.memorys.get(url.build().setParam(PARAM.KEY, key).toString());\n if (!x) {\n return Result.Err(new NotFoundError(\"not found\"));\n }\n return Result.Ok(x);\n }\n}\n","export const MEMORY_VERSION = \"v0.19-memory\";\n","// export * from \"./sys-container.js\";\nexport * from \"./gateways/file/utils.js\";\n\n// export * as sql from \"./store-sql/index.js\";\nexport * as files from \"./files.js\";\n\nexport * as kb from \"./key-bag.js\";\nexport * as kc from \"./keyed-crypto.js\";\n\nexport * as mf from \"./wait-pr-multiformats/index.js\";\n\nexport { runtimeFn } from \"@adviser/cement\";\n\nexport * as gw from \"./gateways/index.js\";\n\nexport * from \"./key-bag.js\";\n\nexport { FILESTORE_VERSION } from \"./gateways/file/version.js\";\nexport { INDEXDB_VERSION } from \"./gateways/indexdb/version.js\";\n// export { V0_19SQL_VERSION } from \"./store-sql/v0.19/version.js\";\n","import type { URI } from \"@adviser/cement\";\nimport { getStore } from \"@fireproof/core\";\nimport type { SuperThis } from \"@fireproof/core\";\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 urlGen = url.getParam(PARAM.URL_GEN);\n // switch (urlGen) {\n // case \"default\":\n // case \"fromEnv\":\n // default:\n // break;\n // }\n\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, 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","export * as block from \"./block.js\";\nexport * as codec from \"./codec-interface.js\";\n","import type { ArrayBufferView, ByteView } from \"multiformats\";\n\n/**\n * IPLD encoder part of the codec.\n */\nexport interface BlockEncoder<Code extends number, T> {\n name: string;\n code: Code;\n encode(data: T): ByteView<T> | PromiseLike<ByteView<T>>;\n}\n\n/**\n * IPLD decoder part of the codec.\n */\nexport interface BlockDecoder<Code extends number, T> {\n code: Code;\n decode(bytes: ByteView<T> | ArrayBufferView<T>): T | PromiseLike<T>;\n}\n\n/**\n * An IPLD codec is a combination of both encoder and decoder.\n */\nexport interface BlockCodec<Code extends number, T> extends BlockEncoder<Code, T>, BlockDecoder<Code, T> {}\n\nexport type { ArrayBufferView, ByteView };\n","export * from \"./fp-envelope-serialize.js\";\nexport * as file from \"./file/index.js\";\n","import { exception2Result, Result, URI } from \"@adviser/cement\";\nimport {\n CarClockLink,\n DbMeta,\n DbMetaBinary,\n DbMetaEvent,\n FPEnvelope,\n FPEnvelopeCar,\n FPEnvelopeFile,\n FPEnvelopeMeta,\n FPEnvelopeType,\n FPEnvelopeWAL,\n WALState,\n} from \"../../blockstore/index.js\";\nimport { PARAM, PromiseToUInt8, SuperThis } from \"../../types.js\";\nimport { decodeEventBlock, EventBlock } from \"@fireproof/vendor/@web3-storage/pail/clock\";\nimport { base64pad } from \"multiformats/bases/base64\";\nimport { CID, Link } from \"multiformats\";\nimport { fromJSON } from \"multiformats/link\";\nimport { format, parse } from \"@fireproof/vendor/@ipld/dag-json\";\nimport { EventView } from \"@fireproof/vendor/@web3-storage/pail/clock/api\";\nimport { coercePromiseIntoUint8 } from \"../../utils.js\";\n\nexport interface SerializedMeta {\n readonly data: string; // base64pad encoded\n readonly parents: string[];\n readonly cid: string;\n}\n\nasync function dbMetaEvent2Serialized(sthis: SuperThis, dbEvents: Omit<DbMetaEvent, \"eventCid\">[]): Promise<SerializedMeta[]> {\n return await Promise.all(\n dbEvents.map(async (dbEvent) => {\n const event = await EventBlock.create<DbMetaBinary>(\n {\n dbMeta: sthis.txt.encode(format(dbEvent.dbMeta)),\n },\n dbEvent.parents as unknown as Link<EventView<DbMetaBinary>, number, number, 1>[],\n );\n return {\n cid: event.cid.toString(),\n parents: dbEvent.parents.map((i) => i.toString()),\n data: base64pad.encode(event.bytes),\n } as SerializedMeta;\n }),\n );\n}\n\nfunction WALState2Serialized(sthis: SuperThis, wal: WALState): SerializedWAL {\n const serializedWAL: SerializedWAL = {\n fileOperations: wal.fileOperations.map((fop) => ({\n cid: fop.cid.toString(),\n public: fop.public,\n })),\n noLoaderOps: wal.noLoaderOps.map((nop) => ({\n cars: nop.cars.map((i) => i.toString()),\n })),\n operations: wal.operations.map((op) => ({\n cars: op.cars.map((i) => i.toString()),\n })),\n };\n return serializedWAL;\n}\n\nexport type CAREncodeEnvelope = (sthis: SuperThis, payload: Uint8Array) => Promise<Result<Uint8Array>>;\nexport type FILEEncodeEnvelope = (sthis: SuperThis, payload: Uint8Array) => Promise<Result<Uint8Array>>;\nexport type METAEncodeEnvelope = (sthis: SuperThis, payload: SerializedMeta[]) => Promise<Result<Uint8Array>>;\nexport type WALEncodeEnvelope = (sthis: SuperThis, payload: SerializedWAL) => Promise<Result<Uint8Array>>;\n\n// export type CAREncodeEnvelope = (sthis: SuperThis, payload: Uint8Array, base: CAREncodeEnvelopeBase) => Promise<Uint8Array>;\n// export type FILEEncodeEnvelope = (sthis: SuperThis, payload: Uint8Array, base: CAREncodeEnvelopeBase) => Promise<Uint8Array>;\n// export type METAEncodeEnvelope = (sthis: SuperThis, payload: SerializedMeta[], base: METAEncodeEnvelopeBase) => Promise<Uint8Array>;\n// export type WALEncodeEnvelope = (sthis: SuperThis, payload: SerializedWAL, base: WALEncodeEnvelopeBase) => Promise<Uint8Array>;\nexport interface Encoder {\n readonly car: CAREncodeEnvelope;\n readonly file: FILEEncodeEnvelope;\n readonly meta: METAEncodeEnvelope;\n readonly wal: WALEncodeEnvelope;\n}\n\nconst defaultEncoder: Encoder = {\n car: async (sthis: SuperThis, payload: Uint8Array) => Result.Ok(payload),\n file: async (sthis: SuperThis, payload: Uint8Array) => Result.Ok(payload),\n meta: async (sthis: SuperThis, payload: SerializedMeta[]) => Result.Ok(sthis.txt.encode(JSON.stringify(payload))),\n wal: async (sthis: SuperThis, payload: SerializedWAL) => Result.Ok(sthis.txt.encode(JSON.stringify(payload))),\n};\n\nexport async function fpSerialize<T>(\n sthis: SuperThis,\n env: FPEnvelope<T>,\n pencoder?: Partial<Encoder>,\n): Promise<Result<Uint8Array>> {\n const encoder = {\n ...defaultEncoder,\n ...pencoder,\n };\n switch (env.type) {\n case FPEnvelopeType.FILE:\n return encoder.file(sthis, (env as FPEnvelopeFile).payload);\n case FPEnvelopeType.CAR:\n return encoder.car(sthis, (env as FPEnvelopeCar).payload);\n case FPEnvelopeType.WAL:\n return encoder.wal(sthis, WALState2Serialized(sthis, (env as FPEnvelopeWAL).payload));\n case FPEnvelopeType.META:\n return encoder.meta(sthis, await dbMetaEvent2Serialized(sthis, (env as FPEnvelopeMeta).payload));\n default:\n throw sthis.logger.Error().Str(\"type\", env.type).Msg(\"unsupported store\").AsError();\n }\n}\n\nasync function decode2DbMetaEvents(sthis: SuperThis, rserializedMeta: Result<SerializedMeta[]>): Promise<Result<DbMetaEvent[]>> {\n if (rserializedMeta.isErr()) {\n return Result.Err(rserializedMeta.Err());\n }\n const serializedMeta = rserializedMeta.unwrap();\n if (!Array.isArray(serializedMeta)) {\n return sthis.logger.Debug().Any(\"metaEntries\", serializedMeta).Msg(\"No data in MetaEntries\").ResultError();\n }\n if (!serializedMeta.length) {\n return sthis.logger.Debug().Msg(\"No MetaEntries found\").ResultError();\n }\n return Result.Ok(\n await Promise.all(\n serializedMeta.map(async (metaEntry) => {\n const eventBlock = await decodeEventBlock<DbMetaBinary>(base64pad.decode(metaEntry.data));\n const dbMeta = parse<DbMeta>(sthis.txt.decode(eventBlock.value.data.dbMeta));\n return {\n eventCid: eventBlock.cid as CarClockLink,\n parents: metaEntry.parents.map((i: string) => CID.parse(i)),\n dbMeta,\n } satisfies DbMetaEvent;\n }),\n ),\n );\n}\n\ntype linkOrCid = { \"/\": string } | string;\n\nexport interface SerializedWAL {\n readonly fileOperations?: { cid: linkOrCid; public: boolean }[];\n readonly noLoaderOps?: { cars: linkOrCid[] }[];\n readonly operations?: { cars: linkOrCid[] }[];\n}\n\nfunction toCid(sthis: SuperThis, link: linkOrCid): CID {\n if (typeof link === \"string\") {\n return CID.parse(link);\n }\n return fromJSON(link);\n}\n\nasync function decode2WalState(sthis: SuperThis, rserializedWAL: Result<SerializedWAL>): Promise<Result<WALState>> {\n if (rserializedWAL.isErr()) {\n return Result.Err(rserializedWAL.Err());\n }\n const serializedWAL = rserializedWAL.unwrap();\n return Result.Ok({\n fileOperations: (serializedWAL.fileOperations || []).map((fop) => ({\n cid: toCid(sthis, fop.cid),\n public: !!fop.public,\n })),\n noLoaderOps: (serializedWAL.noLoaderOps || []).map((nop) => ({\n cars: (nop.cars || []).map((i) => toCid(sthis, i)),\n })),\n operations: (serializedWAL.operations || []).map((op) => ({\n cars: (op.cars || []).map((i) => toCid(sthis, i)),\n })),\n });\n}\n// export type CARDecodeEnvelopeBase = (sthis: SuperThis, payload: Uint8Array) => Promise<Result<Uint8Array>>;\n// export type FILEDecodeEnvelopeBase = (sthis: SuperThis, payload: Uint8Array) => Promise<Result<Uint8Array>>;\n// export type WALDecodeEnvelopeBase = (sthis: SuperThis, payload: SerializedWAL) => Promise<Result<SerializedWAL>>;\n// export type METADecodeEnvelopeBase = (sthis: SuperThis, payload: SerializedMeta[]) => Promise<Result<SerializedMeta[]>>;\n\nexport type CARDecodeEnvelope = (sthis: SuperThis, payload: Uint8Array) => Promise<Result<Uint8Array>>;\nexport type FILEDecodeEnvelope = (sthis: SuperThis, payload: Uint8Array) => Promise<Result<Uint8Array>>;\nexport type METADecodeEnvelope = (sthis: SuperThis, payload: Uint8Array) => Promise<Result<SerializedMeta[]>>;\nexport type WALDecodeEnvelope = (sthis: SuperThis, payload: Uint8Array) => Promise<Result<SerializedWAL>>;\nexport interface Decoder {\n readonly car: CARDecodeEnvelope;\n readonly file: FILEDecodeEnvelope;\n readonly meta: METADecodeEnvelope;\n readonly wal: WALDecodeEnvelope;\n}\n\nconst defaultDecoder = {\n car: async (sthis: SuperThis, payload: Uint8Array) => Result.Ok(payload),\n file: async (sthis: SuperThis, payload: Uint8Array) => Result.Ok(payload),\n meta: async (sthis: SuperThis, payload: Uint8Array) =>\n exception2Result(() => JSON.parse(sthis.txt.decode(payload)) as SerializedMeta[]),\n wal: async (sthis: SuperThis, payload: Uint8Array) =>\n exception2Result(() => JSON.parse(sthis.txt.decode(payload)) as SerializedWAL),\n};\n\nfunction makeFPEnvelope<S>(type: FPEnvelopeType, payload: Result<S>): Result<FPEnvelope<S>> {\n if (payload.isErr()) {\n return Result.Err(payload.Err());\n }\n return Result.Ok({\n type,\n payload: payload.unwrap(),\n });\n}\n\nexport async function fpDeserialize<S>(\n sthis: SuperThis,\n url: URI,\n intoRaw: PromiseToUInt8,\n pdecoder?: Partial<Decoder>,\n): Promise<Result<FPEnvelope<S>>> {\n const rraw = await coercePromiseIntoUint8(intoRaw);\n if (rraw.isErr()) {\n return Result.Err(rraw.Err());\n }\n const raw = rraw.unwrap();\n const decoder = {\n ...defaultDecoder,\n ...pdecoder,\n };\n switch (url.getParam(PARAM.STORE)) {\n case \"data\":\n if (url.getParam(PARAM.SUFFIX) === \".car\") {\n return makeFPEnvelope(FPEnvelopeType.CAR, await decoder.car(sthis, raw)) as Result<FPEnvelope<S>>;\n }\n return makeFPEnvelope(FPEnvelopeType.FILE, await decoder.file(sthis, raw)) as Result<FPEnvelope<S>>;\n case \"wal\":\n return makeFPEnvelope(FPEnvelopeType.WAL, await decode2WalState(sthis, await decoder.wal(sthis, raw))) as Result<\n FPEnvelope<S>\n >;\n case \"meta\":\n return makeFPEnvelope(FPEnvelopeType.META, await decode2DbMetaEvents(sthis, await decoder.meta(sthis, raw))) as Result<\n FPEnvelope<S>\n >;\n default:\n return sthis.logger.Error().Str(\"store\", url.getParam(PARAM.STORE)).Msg(\"unsupported store\").ResultError();\n }\n}\n","export * from \"./key-bag-file.js\";\nexport * from \"./sys-file-system-factory.js\";\n","export const INDEXDB_VERSION = \"v0.19-indexdb\";\n","import { FILESTORE_VERSION } from \"./version.js\";\nimport { exception2Result, KeyedResolvOnce, Result, URI } from \"@adviser/cement\";\nimport { getFileName, getPath } from \"./utils.js\";\nimport { PARAM, SuperThis, SysFileSystem } from \"../../../types.js\";\nimport { exceptionWrapper, isNotFoundError, NotFoundError } from \"../../../utils.js\";\nimport { Gateway, GetResult } from \"../../../blockstore/gateway.js\";\n\nconst versionFiles = new KeyedResolvOnce<string>();\n\nexport class FileGateway implements Gateway {\n // abstract readonly storeType: StoreType;\n readonly fs: SysFileSystem;\n\n constructor(sthis: SuperThis, fs: SysFileSystem) {\n this.fs = fs;\n }\n\n async getVersionFromFile(path: string, sthis: SuperThis): Promise<string> {\n return versionFiles.get(path).once(async () => {\n await this.fs.mkdir(path, { recursive: true });\n const vFile = sthis.pathOps.join(path, \"version\");\n const vFileStat = await this.fs.stat(vFile).catch(() => undefined);\n if (!vFileStat) {\n await this.fs.writefile(sthis.pathOps.join(path, \"version\"), FILESTORE_VERSION);\n return FILESTORE_VERSION;\n } else if (!vFileStat.isFile()) {\n throw sthis.logger.Error().Str(\"file\", vFile).Msg(`version file is a directory`).AsError();\n }\n const v = await this.fs.readfile(vFile);\n const vStr = sthis.txt.decode(v);\n if (vStr !== FILESTORE_VERSION) {\n sthis.logger.Warn().Str(\"file\", vFile).Str(\"from\", vStr).Str(\"expected\", FILESTORE_VERSION).Msg(`version mismatch`);\n }\n return vStr;\n });\n }\n\n start(baseURL: URI, sthis: SuperThis): Promise<Result<URI>> {\n return exception2Result(async () => {\n await this.fs.start();\n const url = baseURL.build();\n url.defParam(PARAM.VERSION, FILESTORE_VERSION);\n // url.defParam(\"store\", this.storeType);\n const dbUrl = await this.buildUrl(url.URI(), \"dummy\");\n const dbdirFile = this.getFilePath(dbUrl.Ok(), sthis);\n await this.fs.mkdir(sthis.pathOps.dirname(dbdirFile), { recursive: true });\n const dbroot = sthis.pathOps.dirname(dbdirFile);\n sthis.logger.Debug().Url(url.URI()).Str(\"dbroot\", dbroot).Msg(\"start\");\n url.setParam(PARAM.VERSION, await this.getVersionFromFile(dbroot, sthis));\n return url.URI();\n });\n }\n\n async buildUrl(baseUrl: URI, key: string): Promise<Result<URI>> {\n return Result.Ok(baseUrl.build().setParam(PARAM.KEY, key).URI());\n }\n\n async close(): Promise<Result<void>> {\n return Result.Ok(undefined);\n }\n\n getFilePath(url: URI, sthis: SuperThis): string {\n const key = url.getParam(PARAM.KEY);\n if (!key) throw sthis.logger.Error().Url(url).Msg(`key not found`).AsError();\n // const urlGen = url.getParam(PARAM.URL_GEN);\n // switch (urlGen) {\n // case \"default\":\n // return sthis.pathOps.join(getPath(url, sthis), getFileName(url, sthis));\n // case \"fromEnv\":\n // return sthis.pathOps.join(getPath(url, sthis), getFileName(url, sthis));\n // default:\n // break;\n // }\n return sthis.pathOps.join(getPath(url, sthis), getFileName(url, sthis));\n }\n\n async put(url: URI, bytes: Uint8Array, sthis: SuperThis): Promise<Result<void>> {\n return exception2Result(async () => {\n const file = await this.getFilePath(url, sthis);\n sthis.logger.Debug().Str(\"url\", url.toString()).Str(\"file\", file).Msg(\"put\");\n await this.fs.writefile(file, bytes);\n });\n }\n\n async get(url: URI, sthis: SuperThis): Promise<GetResult> {\n return exceptionWrapper(async () => {\n const file = this.getFilePath(url, sthis);\n try {\n sthis.logger.Debug().Url(url).Str(\"file\", file).Msg(\"get\");\n const res = await this.fs.readfile(file);\n return Result.Ok(res);\n } catch (e: unknown) {\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\n async delete(url: URI, sthis: SuperThis): Promise<Result<void>> {\n return exception2Result(async () => {\n await this.fs.unlink(this.getFilePath(url, sthis));\n });\n }\n\n async destroy(baseURL: URI, sthis: SuperThis): Promise<Result<void>> {\n const url = await this.buildUrl(baseURL, \"x\");\n if (url.isErr()) return url;\n const filepath = sthis.pathOps.dirname(this.getFilePath(url.Ok(), sthis));\n let files: string[] = [];\n try {\n files = await this.fs.readdir(filepath);\n } catch (e: unknown) {\n if (!isNotFoundError(e)) {\n throw sthis.logger.Error().Err(e).Str(\"dir\", filepath).Msg(\"destroy:readdir\").AsError();\n }\n }\n for (const file of files) {\n const pathed = sthis.pathOps.join(filepath, file);\n try {\n await this.fs.unlink(pathed);\n } catch (e: unknown) {\n if (!isNotFoundError(e)) {\n throw sthis.logger.Error().Err(e).Str(\"file\", pathed).Msg(\"destroy:unlink\").AsError();\n }\n }\n }\n return Result.Ok(undefined);\n }\n\n async getPlain(iurl: URI, key: string, sthis: SuperThis) {\n const url = iurl.build().setParam(PARAM.KEY, key).URI();\n const dbFile = sthis.pathOps.join(getPath(url, sthis), getFileName(url, sthis));\n sthis.logger.Debug().Url(url).Str(\"dbFile\", dbFile).Msg(\"get\");\n const buffer = await this.fs.readfile(dbFile);\n sthis.logger.Debug().Url(url).Str(\"dbFile\", dbFile).Len(buffer).Msg(\"got\");\n return Result.Ok(buffer);\n }\n}\n","import { Result, URI } from \"@adviser/cement\";\nimport { Gateway } from \"../../blockstore/gateway.js\";\nimport { FPEnvelope } from \"../../blockstore/fp-envelope.js\";\nimport { fpDeserialize, fpSerialize } from \"./fp-envelope-serialize.js\";\nimport { SerdeGateway, SerdeGetResult } from \"../../blockstore/serde-gateway.js\";\nimport { SuperThis } from \"../../types.js\";\n\nexport class DefSerdeGateway implements SerdeGateway {\n // abstract readonly storeType: StoreType;\n readonly gw: Gateway;\n\n constructor(gw: Gateway) {\n this.gw = gw;\n }\n\n start(sthis: SuperThis, baseURL: URI): Promise<Result<URI>> {\n return this.gw.start(baseURL, sthis);\n }\n\n async buildUrl(sthis: SuperThis, baseUrl: URI, key: string): Promise<Result<URI>> {\n return this.gw.buildUrl(baseUrl, key, sthis);\n }\n\n async close(sthis: SuperThis, uri: URI): Promise<Result<void>> {\n return this.gw.close(uri, sthis);\n }\n\n async put<T>(sthis: SuperThis, url: URI, env: FPEnvelope<T>): Promise<Result<void>> {\n const rUint8 = await fpSerialize(sthis, env);\n if (rUint8.isErr()) return rUint8;\n return this.gw.put(url, rUint8.Ok(), sthis);\n }\n\n async get<S>(sthis: SuperThis, url: URI): Promise<SerdeGetResult<S>> {\n const res = await this.gw.get(url, sthis);\n if (res.isErr()) return Result.Err(res.Err());\n return fpDeserialize(sthis, url, res) as Promise<SerdeGetResult<S>>;\n }\n\n async delete(sthis: SuperThis, url: URI): Promise<Result<void>> {\n return this.gw.delete(url, sthis);\n }\n\n async destroy(sthis: SuperThis, baseURL: URI): Promise<Result<void>> {\n return this.gw.destroy(baseURL, sthis);\n }\n\n async getPlain(sthis: SuperThis, iurl: URI, key: string) {\n return this.gw.getPlain(iurl, key, sthis);\n }\n}\n","import { URI } from \"@adviser/cement\";\nimport { DataStoreImpl, MetaStoreImpl, StoreOpts } from \"./store.js\";\nimport { SuperThis } from \"../types.js\";\n\n// export type LoadHandler = (dbMetas: DbMeta[]) => Promise<void>;\n// export function validateDataParams(params: DownloadDataFnParams | UploadDataFnParams, logger: Logger) {\n// const { type, name, car } = params;\n// if (!name) throw logger.Error().Msg(\"name is required\").AsError();\n// if (!car) {\n// throw logger.Error().Msg(\"car is required\").AsError();\n// }\n// if (type !== \"file\" && type !== \"data\") {\n// throw logger.Error().Msg(\"type must be file or data\").AsError();\n// }\n// }\n\n// export function validateMetaParams(params: DownloadMetaFnParams | UploadMetaFnParams, logger: Logger) {\n// const { name, branch } = params;\n// if (!name) throw logger.Error().Msg(\"name is required\").AsError();\n// if (!branch) {\n// throw logger.Error().Msg(\"branch is required\").AsError();\n// }\n// }\n\n// export class RemoteDataStore extends DataStoreImpl {\n// // just for explaining the concept\n// }\n\n// export class RemoteMetaStore extends MetaStoreImpl {\n// // just for explaining the concept\n// }\n\nexport async function RemoteDataStore(sthis: SuperThis, url: URI, opts: StoreOpts) {\n const ds = new DataStoreImpl(sthis, url, opts);\n await ds.start();\n return ds;\n}\nexport async function RemoteMetaStore(sthis: SuperThis, url: URI, opts: StoreOpts) {\n const ms = new MetaStoreImpl(sthis, url, opts);\n await ms.start();\n return ms;\n}\n\n// export class RemoteWALStore extends WALStoreImpl {\n// // basicly do nothing write the WAL into memory\n// constructor(loader: Loadable) {\n\n// //import { FileWALGateway } from \"../runtime/gateways/file/gateway.js\";\n// // super(loader, new URL(\"file:///dummy?fs=mem\"), loader.logger, new FileWALGateway(loader.logger));\n// }\n\n// }\n","import { Logger, URI } from \"@adviser/cement\";\n\nimport { PARAM, throwFalsy } from \"../types.js\";\nimport { TaskManager } from \"./task-manager.js\";\nimport type { Connection, Loadable, RefBlockstore, RefLoadable } from \"./types.js\";\nimport { RemoteDataStore, RemoteMetaStore } from \"./store-remote.js\";\nimport { getStartedGateway } from \"./store-factory.js\";\n\n// export interface Connectable {\n// // readonly blockstore: {\n// // readonly loader?: Loader;\n// // readonly ebOpts: BlockstoreRuntime;\n// // };\n// readonly name?: string;\n// // readonly sthis: SuperThis;\n// }\n\nfunction coerceLoader(ref: RefLoadable | RefBlockstore): Loadable | undefined {\n const refl = ref as RefLoadable;\n if (refl.loader) {\n return refl.loader;\n }\n const refb = ref as RefBlockstore;\n if (refb.blockstore) {\n return coerceLoader(refb.blockstore);\n }\n return undefined;\n}\n\nexport abstract class ConnectionBase implements Connection {\n // readonly ready: Promise<unknown>;\n // todo move to LRU blockstore https://github.com/web3-storage/w3clock/blob/main/src/worker/block.js\n // readonly eventBlocks = new MemoryBlockstore();\n private loader?: Loadable;\n taskManager?: TaskManager;\n loaded: Promise<void> = Promise.resolve();\n\n readonly url: URI;\n\n // abstract metaUpload(bytes: Uint8Array, params: UploadMetaFnParams): Promise<Uint8Array[] | Falsy>;\n // abstract dataUpload(bytes: Uint8Array, params: UploadDataFnParams, opts?: { public?: boolean }): Promise<void>;\n // abstract metaDownload(params: DownloadMetaFnParams): Promise<Uint8Array[] | Falsy>;\n // abstract dataDownload(params: DownloadDataFnParams): Promise<Uint8Array | Falsy>;\n\n readonly logger: Logger;\n constructor(url: URI, logger: Logger) {\n this.logger = logger;\n this.url = url;\n }\n\n async refresh() {\n await throwFalsy(throwFalsy(this.loader).remoteMetaStore).load();\n await (await throwFalsy(this.loader).WALStore()).process();\n }\n\n async connect(refl: RefLoadable | RefBlockstore) {\n await this.connectMeta(refl);\n await this.connectStorage(refl);\n }\n\n async connectMeta(refl: RefLoadable | RefBlockstore) {\n const loader = coerceLoader(refl);\n if (!loader) throw this.logger.Error().Msg(\"connectMeta: loader is required\").AsError();\n this.loader = loader;\n await this.onConnect();\n const metaUrl = this.url.build().defParam(PARAM.STORE, \"meta\").URI();\n const rgateway = await getStartedGateway(loader.sthis, metaUrl);\n if (rgateway.isErr())\n throw this.logger.Error().Result(\"err\", rgateway).Url(metaUrl).Msg(\"connectMeta: gateway is required\").AsError();\n // const name = metaUrl.toString();\n const dbName = metaUrl.getParam(PARAM.NAME);\n if (!dbName) {\n throw this.logger.Error().Url(metaUrl).Msg(\"connectMeta: dbName is required\").AsError();\n }\n const gateway = rgateway.Ok();\n const remote = await RemoteMetaStore(loader.sthis, metaUrl, {\n gateway: gateway.gateway,\n loader,\n });\n this.loader.remoteMetaStore = remote;\n this.loaded = this.loader.ready().then(async () => {\n return remote.load().then(async () => {\n return (await throwFalsy(this.loader).WALStore()).process();\n });\n });\n }\n\n abstract onConnect(): Promise<void>;\n\n async connectStorage(refl: RefLoadable | RefBlockstore) {\n const loader = coerceLoader(refl);\n if (!loader) throw this.logger.Error().Msg(\"connectStorage_X: loader is required\").AsError();\n this.loader = loader;\n const dataUrl = this.url.build().defParam(PARAM.STORE, \"data\").URI();\n const rgateway = await getStartedGateway(loader.sthis, dataUrl);\n if (rgateway.isErr())\n throw this.logger.Error().Result(\"err\", rgateway).Url(dataUrl).Msg(\"connectStorage_X: gateway is required\").AsError();\n const name = dataUrl.getParam(PARAM.NAME);\n if (!name) throw this.logger.Error().Url(dataUrl).Msg(\"connectStorage_X: name is required\").AsError;\n loader.remoteCarStore = await RemoteDataStore(loader.sthis, this.url, {\n gateway: rgateway.Ok().gateway,\n loader,\n });\n // @jchris why we have a differention between remoteCarStore and remoteFileStore? -- file store is for on-demand attachment loading\n // for now we don't have any difference but in superthis car store and\n // file store could have different urls/gateways\n loader.remoteFileStore = loader.remoteCarStore;\n }\n\n // move this stuff to connect\n // async getDashboardURL(compact = true) {\n // const baseUrl = 'https://dashboard.fireproof.storage/'\n // if (!this.loader?.remoteCarStore) return new URL('/howto', baseUrl)\n // // if (compact) {\n // // await this.compact()\n // // }\n // const currents = await this.loader?.metaStore?.load()\n // if (!currents) throw new Error(\"Can't sync empty ledger: save data first\")\n // if (currents.length > 1)\n // throw new Error(\"Can't sync ledger with split heads: make an update first\")\n // const current = currents[0]\n // const params = {\n // car: current.car.toString()\n // }\n // if (current.key) {\n // // @ts-ignore\n // params.key = current.key.toString()\n // }\n // // @ts-ignore\n // if (this.name) {\n // // @ts-ignore\n // params.name = this.name\n // }\n // const url = new URL('/import#' + new URLSearchParams(params).toString(), baseUrl)\n // console.log('Import to dashboard: ' + url.toString())\n // return url\n // }\n\n // openDashboard() {\n // void this.getDashboardURL().then(url => {\n // if (url) window.open(url.toString(), '_blank')\n // })\n // }\n}\n","import { encode, decode, Block } from \"./runtime/wait-pr-multiformats/block.js\";\nimport { parse } from \"multiformats/link\";\nimport { sha256 as hasher } from \"multiformats/hashes/sha2\";\nimport * as codec from \"@fireproof/vendor/@ipld/dag-cbor\";\nimport { put, get, entries, root } from \"@fireproof/vendor/@web3-storage/pail/crdt\";\nimport { EventBlockView, EventLink, Operation, PutOperation } from \"@fireproof/vendor/@web3-storage/pail/crdt/api\";\nimport { EventFetcher, vis } from \"@fireproof/vendor/@web3-storage/pail/clock\";\nimport * as Batch from \"@fireproof/vendor/@web3-storage/pail/crdt/batch\";\nimport {\n type EncryptedBlockstore,\n CarTransaction,\n BlockFetcher,\n TransactionMeta,\n AnyLink,\n StoreRuntime,\n BaseBlockstore,\n CompactFetcher,\n} from \"./blockstore/index.js\";\nimport {\n type IndexKeyType,\n type DocUpdate,\n type ClockHead,\n type DocValue,\n type CRDTMeta,\n type ChangesOptions,\n type DocFileMeta,\n type DocFiles,\n type DocSet,\n type DocWithId,\n type DocTypes,\n throwFalsy,\n} from \"./types.js\";\nimport { Result } from \"@fireproof/vendor/@web3-storage/pail/crdt/api\";\nimport { Logger } from \"@adviser/cement\";\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nfunction time(tag: string) {\n // console.time(tag)\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nfunction timeEnd(tag: string) {\n // console.timeEnd(tag)\n}\n\nfunction toString<K extends IndexKeyType>(key: K, logger: Logger): string {\n switch (typeof key) {\n case \"string\":\n case \"number\":\n return key.toString();\n default:\n throw logger.Error().Msg(\"Invalid key type\").AsError();\n }\n}\n\nexport async function applyBulkUpdateToCrdt<T extends DocTypes>(\n store: StoreRuntime,\n tblocks: CarTransaction,\n head: ClockHead,\n updates: DocUpdate<T>[],\n logger: Logger,\n): Promise<CRDTMeta> {\n let result: Result | null = null;\n if (updates.length > 1) {\n const batch = await Batch.create(tblocks, head);\n for (const update of updates) {\n const link = await writeDocContent(store, tblocks, update, logger);\n await batch.put(toString(update.id, logger), link);\n }\n result = await batch.commit();\n } else if (updates.length === 1) {\n const link = await writeDocContent(store, tblocks, updates[0], logger);\n result = await put(tblocks, head, toString(updates[0].id, logger), link);\n }\n if (!result) throw logger.Error().Uint64(\"updates.len\", updates.length).Msg(\"Missing result\").AsError();\n\n if (result.event) {\n for (const { cid, bytes } of [\n ...result.additions,\n // ...result.removals,\n result.event,\n ]) {\n tblocks.putSync(cid, bytes);\n }\n }\n return { head: result.head } as CRDTMeta;\n}\n\n// this whole thing can get pulled outside of the write queue\nasync function writeDocContent<T extends DocTypes>(\n store: StoreRuntime,\n blocks: CarTransaction,\n update: DocUpdate<T>,\n logger: Logger,\n): Promise<AnyLink> {\n let value: Partial<DocValue<T>>;\n if (update.del) {\n value = { del: true };\n } else {\n if (!update.value) throw logger.Error().Msg(\"Missing value\").AsError();\n await processFiles(store, blocks, update.value, logger);\n value = { doc: update.value as DocWithId<T> };\n }\n const block = await encode({ value, hasher, codec });\n blocks.putSync(block.cid, block.bytes);\n return block.cid;\n}\n\nasync function processFiles<T extends DocTypes>(store: StoreRuntime, blocks: CarTransaction, doc: DocSet<T>, logger: Logger) {\n if (doc._files) {\n await processFileset(logger, store, blocks, doc._files);\n }\n if (doc._publicFiles) {\n await processFileset(logger, store, blocks, doc._publicFiles /*, true*/);\n }\n}\n\nasync function processFileset(\n logger: Logger,\n store: StoreRuntime,\n blocks: CarTransaction,\n files: DocFiles /*, publicFiles = false */,\n) {\n const dbBlockstore = blocks.parent as EncryptedBlockstore;\n if (!dbBlockstore.loader) throw logger.Error().Msg(\"Missing loader, ledger name is required\").AsError();\n const t = new CarTransaction(dbBlockstore); // maybe this should move to encrypted-blockstore\n const didPut = [];\n // let totalSize = 0\n for (const filename in files) {\n if (File === files[filename].constructor) {\n const file = files[filename] as File;\n\n // totalSize += file.size\n const { cid, blocks: fileBlocks } = await store.encodeFile(file);\n didPut.push(filename);\n for (const block of fileBlocks) {\n t.putSync(block.cid, block.bytes);\n }\n files[filename] = { cid, type: file.type, size: file.size } as DocFileMeta;\n } else {\n const { cid, type, size, car } = files[filename] as DocFileMeta;\n if (cid && type && size && car) {\n files[filename] = { cid, type, size, car };\n }\n }\n }\n\n if (didPut.length) {\n const car = await dbBlockstore.loader.commitFiles(\n t,\n { files } as unknown as TransactionMeta /* {\n public: publicFiles,\n } */,\n );\n if (car) {\n for (const name of didPut) {\n files[name] = { car, ...files[name] } as DocFileMeta;\n }\n }\n }\n}\n\nexport async function getValueFromCrdt<T extends DocTypes>(\n blocks: BaseBlockstore,\n head: ClockHead,\n key: string,\n logger: Logger,\n): Promise<DocValue<T>> {\n if (!head.length) throw logger.Debug().Msg(\"Getting from an empty ledger\").AsError();\n const link = await get(blocks, head, key);\n if (!link) throw logger.Error().Str(\"key\", key).Msg(`Missing key`).AsError();\n return await getValueFromLink(blocks, link, logger);\n}\n\nexport function readFiles<T extends DocTypes>(blocks: BaseBlockstore, { doc }: Partial<DocValue<T>>) {\n if (!doc) return;\n if (doc._files) {\n readFileset(blocks as EncryptedBlockstore, doc._files);\n }\n if (doc._publicFiles) {\n readFileset(blocks as EncryptedBlockstore, doc._publicFiles, true);\n }\n}\n\nfunction readFileset(blocks: EncryptedBlockstore, files: DocFiles, isPublic = false) {\n for (const filename in files) {\n const fileMeta = files[filename] as DocFileMeta;\n if (fileMeta.cid) {\n if (isPublic) {\n fileMeta.url = `https://${fileMeta.cid.toString()}.ipfs.w3s.link/`;\n }\n if (fileMeta.car) {\n fileMeta.file = async () =>\n await blocks.ebOpts.storeRuntime.decodeFile(\n {\n get: async (cid: AnyLink) => {\n return await blocks.getFile(throwFalsy(fileMeta.car), cid);\n },\n },\n fileMeta.cid,\n fileMeta,\n );\n }\n }\n files[filename] = fileMeta;\n }\n}\n\nasync function getValueFromLink<T extends DocTypes>(blocks: BlockFetcher, link: AnyLink, logger: Logger): Promise<DocValue<T>> {\n const block = await blocks.get(link);\n if (!block) throw logger.Error().Str(\"link\", link.toString()).Msg(`Missing linked block`).AsError();\n const { value } = (await decode({ bytes: block.bytes, hasher, codec })) as { value: DocValue<T> };\n const cvalue = {\n ...value,\n cid: link,\n };\n readFiles(blocks as EncryptedBlockstore, cvalue);\n return cvalue;\n}\n\nclass DirtyEventFetcher<T> extends EventFetcher<T> {\n readonly logger: Logger;\n constructor(logger: Logger, blocks: BlockFetcher) {\n super(blocks);\n this.logger = logger;\n }\n async get(link: EventLink<T>): Promise<EventBlockView<T>> {\n try {\n return super.get(link);\n } catch (e) {\n this.logger.Error().Ref(\"link\", link.toString()).Err(e).Msg(\"Missing event\");\n return { value: undefined } as unknown as EventBlockView<T>;\n }\n }\n}\n\nexport async function clockChangesSince<T extends DocTypes>(\n blocks: BlockFetcher,\n head: ClockHead,\n since: ClockHead,\n opts: ChangesOptions,\n logger: Logger,\n): Promise<{ result: DocUpdate<T>[]; head: ClockHead }> {\n const eventsFetcher = (\n opts.dirty ? new DirtyEventFetcher<Operation>(logger, blocks) : new EventFetcher<Operation>(blocks)\n ) as EventFetcher<Operation>;\n const keys = new Set<string>();\n const updates = await gatherUpdates<T>(\n blocks,\n eventsFetcher,\n head,\n since,\n [],\n keys,\n new Set<string>(),\n opts.limit || Infinity,\n logger,\n );\n return { result: updates.reverse(), head };\n}\n\nasync function gatherUpdates<T extends DocTypes>(\n blocks: BlockFetcher,\n eventsFetcher: EventFetcher<Operation>,\n head: ClockHead,\n since: ClockHead,\n updates: DocUpdate<T>[] = [],\n keys: Set<string>,\n didLinks: Set<string>,\n limit: number,\n logger: Logger,\n): Promise<DocUpdate<T>[]> {\n if (limit <= 0) return updates;\n // if (Math.random() < 0.001) console.log('gatherUpdates', head.length, since.length, updates.length)\n const sHead = head.map((l) => l.toString());\n for (const link of since) {\n if (sHead.includes(link.toString())) {\n return updates;\n }\n }\n for (const link of head) {\n if (didLinks.has(link.toString())) continue;\n didLinks.add(link.toString());\n const { value: event } = await eventsFetcher.get(link);\n if (!event) continue;\n const { type } = event.data;\n let ops = [] as PutOperation[];\n if (type === \"batch\") {\n ops = event.data.ops as PutOperation[];\n } else if (type === \"put\") {\n ops = [event.data] as PutOperation[];\n }\n for (let i = ops.length - 1; i >= 0; i--) {\n const { key, value } = ops[i];\n if (!keys.has(key)) {\n // todo option to see all updates\n const docValue = await getValueFromLink<T>(blocks, value, logger);\n updates.push({ id: key, value: docValue.doc, del: docValue.del, clock: link });\n limit--;\n keys.add(key);\n }\n }\n if (event.parents) {\n updates = await gatherUpdates(blocks, eventsFetcher, event.parents, since, updates, keys, didLinks, limit, logger);\n }\n }\n return updates;\n}\n\nexport async function* getAllEntries<T extends DocTypes>(blocks: BlockFetcher, head: ClockHead, logger: Logger) {\n // return entries(blocks, head)\n for await (const [key, link] of entries(blocks, head)) {\n const docValue = await getValueFromLink(blocks, link, logger);\n yield { id: key, value: docValue.doc, del: docValue.del } as DocUpdate<T>;\n }\n}\n\nexport async function* clockVis(blocks: BlockFetcher, head: ClockHead) {\n for await (const line of vis(blocks, head)) {\n yield line;\n }\n}\n\nlet isCompacting = false;\nexport async function doCompact(blockLog: CompactFetcher, head: ClockHead, logger: Logger) {\n if (isCompacting) {\n // console.log('already compacting')\n return;\n }\n isCompacting = true;\n\n time(\"compact head\");\n for (const cid of head) {\n const bl = await blockLog.get(cid);\n if (!bl) throw logger.Error().Ref(\"cid\", cid).Msg(\"Missing head block\").AsError();\n }\n timeEnd(\"compact head\");\n\n // for await (const blk of blocks.entries()) {\n // const bl = await blockLog.get(blk.cid)\n // if (!bl) throw new Error('Missing tblock: ' + blk.cid.toString())\n // }\n\n // todo maybe remove\n // for await (const blk of blocks.loader!.entries()) {\n // const bl = await blockLog.get(blk.cid)\n // if (!bl) throw new Error('Missing db block: ' + blk.cid.toString())\n // }\n\n time(\"compact all entries\");\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n for await (const _entry of getAllEntries(blockLog, head, logger)) {\n // result.push(entry)\n // void 1;\n continue;\n }\n timeEnd(\"compact all entries\");\n\n // time(\"compact crdt entries\")\n // for await (const [, link] of entries(blockLog, head)) {\n // const bl = await blockLog.get(link)\n // if (!bl) throw new Error('Missing entry block: ' + link.toString())\n // }\n // timeEnd(\"compact crdt entries\")\n\n time(\"compact clock vis\");\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n for await (const _line of vis(blockLog, head)) {\n void 1;\n }\n timeEnd(\"compact clock vis\");\n\n time(\"compact root\");\n const result = await root(blockLog, head);\n timeEnd(\"compact root\");\n\n time(\"compact root blocks\");\n for (const { cid, bytes } of [...result.additions, ...result.removals]) {\n blockLog.loggedBlocks.putSync(cid, bytes);\n }\n timeEnd(\"compact root blocks\");\n\n time(\"compact changes\");\n await clockChangesSince(blockLog, head, [], {}, logger);\n timeEnd(\"compact changes\");\n\n isCompacting = false;\n}\n\nexport async function getBlock(blocks: BlockFetcher, cidString: string) {\n const block = await blocks.get(parse(cidString));\n if (!block) throw new Error(`Missing block ${cidString}`);\n const { cid, value } = await decode({ bytes: block.bytes, codec, hasher });\n return new Block({ cid, value, bytes: block.bytes });\n}\n","import type { Block, Link } from \"multiformats\";\nimport { create } from \"./runtime/wait-pr-multiformats/block.js\";\nimport { sha256 as hasher } from \"multiformats/hashes/sha2\";\nimport * as codec from \"@fireproof/vendor/@ipld/dag-cbor\";\n\n// @ts-expect-error \"charwise\" has no types\nimport charwise from \"charwise\";\n// @ts-expect-error \"prolly-trees\" has no types\nimport * as DbIndex from \"prolly-trees/db-index\";\n// @ts-expect-error \"prolly-trees\" has no types\nimport { bf, simpleCompare } from \"prolly-trees/utils\";\n// @ts-expect-error \"prolly-trees\" has no types\nimport { nocache as cache } from \"prolly-trees/cache\";\n// @ts-expect-error \"prolly-trees\" has no types\nimport { ProllyNode as BaseNode } from \"prolly-trees/db-index\";\n\nimport {\n DocUpdate,\n MapFn,\n DocFragment,\n IndexUpdate,\n QueryOpts,\n IndexRow,\n DocWithId,\n IndexKeyType,\n IndexKey,\n DocTypes,\n DocObject,\n IndexUpdateString,\n} from \"./types.js\";\nimport { CarTransaction, BlockFetcher, AnyLink, AnyBlock } from \"./blockstore/index.js\";\nimport { CRDT } from \"./crdt.js\";\nimport { Logger } from \"@adviser/cement\";\n\nexport class IndexTree<K extends IndexKeyType, R extends DocFragment> {\n cid?: AnyLink;\n root?: ProllyNode<K, R>;\n}\n\ntype CompareRef = string | number;\nexport type CompareKey = [string | number, CompareRef];\n\nfunction refCompare(aRef: CompareRef, bRef: CompareRef) {\n if (Number.isNaN(aRef)) return -1;\n if (Number.isNaN(bRef)) throw new Error(\"ref may not be Infinity or NaN\");\n if (aRef === Infinity) return 1;\n // if (!Number.isFinite(bRef)) throw new Error('ref may not be Infinity or NaN')\n\n return simpleCompare(aRef, bRef) as number;\n}\n\nfunction compare(a: CompareKey, b: CompareKey) {\n const [aKey, aRef] = a;\n const [bKey, bRef] = b;\n\n const comp: number = simpleCompare(aKey, bKey);\n if (comp !== 0) return comp;\n return refCompare(aRef, bRef);\n}\n\nexport const byKeyOpts: StaticProllyOptions<CompareKey> = { cache, chunker: bf(30), codec, hasher, compare };\n\nexport const byIdOpts: StaticProllyOptions<unknown> = { cache, chunker: bf(30), codec, hasher, compare: simpleCompare };\n\nexport interface IndexDoc<K extends IndexKeyType> {\n readonly key: IndexKey<K>;\n readonly value: DocFragment;\n}\n\nexport interface IndexDocString {\n readonly key: string;\n readonly value: DocFragment;\n}\n\nexport function indexEntriesForChanges<T extends DocTypes, K extends IndexKeyType>(\n changes: DocUpdate<T>[],\n mapFn: MapFn<T>,\n): IndexDoc<K>[] {\n const indexEntries: IndexDoc<K>[] = [];\n changes.forEach(({ id: key, value, del }) => {\n if (del || !value) return;\n let mapCalled = false;\n const mapReturn = mapFn({ ...(value as DocWithId<T>), _id: key }, (k: IndexKeyType, v?: DocFragment) => {\n mapCalled = true;\n if (typeof k === \"undefined\") return;\n indexEntries.push({\n key: [charwise.encode(k) as K, key],\n value: v || null,\n });\n });\n if (!mapCalled && mapReturn) {\n indexEntries.push({\n key: [charwise.encode(mapReturn) as K, key],\n value: null,\n });\n }\n });\n return indexEntries;\n}\n\nfunction makeProllyGetBlock(blocks: BlockFetcher): (address: AnyLink) => Promise<AnyBlock> {\n return async (address: AnyLink) => {\n const block = await blocks.get(address);\n if (!block) throw new Error(`Missing block ${address.toString()}`);\n const { cid, bytes } = block;\n return create({ cid, bytes, hasher, codec }) as Promise<AnyBlock>;\n };\n}\n\nexport async function bulkIndex<K extends IndexKeyType, T extends DocFragment, CT>(\n logger: Logger,\n tblocks: CarTransaction,\n inIndex: IndexTree<K, T>,\n indexEntries: (IndexUpdate<K> | IndexUpdateString)[],\n opts: StaticProllyOptions<CT>,\n): Promise<IndexTree<K, T>> {\n logger.Debug().Msg(\"enter bulkIndex\");\n if (!indexEntries.length) return inIndex;\n if (!inIndex.root) {\n if (!inIndex.cid) {\n let returnRootBlock: Block | undefined = undefined;\n let returnNode: ProllyNode<K, T> | undefined = undefined;\n\n for await (const node of (await DbIndex.create({\n get: makeProllyGetBlock(tblocks),\n list: indexEntries,\n ...opts,\n })) as ProllyNode<K, T>[]) {\n const block = await node.block;\n await tblocks.put(block.cid, block.bytes);\n returnRootBlock = block;\n returnNode = node;\n }\n if (!returnNode || !returnRootBlock) throw new Error(\"failed to create index\");\n logger.Debug().Msg(\"exit !root bulkIndex\");\n return { root: returnNode, cid: returnRootBlock.cid };\n } else {\n inIndex.root = (await DbIndex.load({ cid: inIndex.cid, get: makeProllyGetBlock(tblocks), ...opts })) as ProllyNode<K, T>;\n }\n }\n logger.Debug().Msg(\"pre bulk bulkIndex\");\n const { root, blocks: newBlocks } = await inIndex.root.bulk(indexEntries);\n if (root) {\n logger.Debug().Msg(\"pre root put bulkIndex\");\n for await (const block of newBlocks) {\n await tblocks.put(block.cid, block.bytes);\n }\n return { root, cid: (await root.block).cid };\n } else {\n logger.Debug().Msg(\"pre !root bulkIndex\");\n return { root: undefined, cid: undefined };\n }\n}\n\nexport async function loadIndex<K extends IndexKeyType, T extends DocFragment, CT>(\n tblocks: BlockFetcher,\n cid: AnyLink,\n opts: StaticProllyOptions<CT>,\n): Promise<ProllyNode<K, T>> {\n return (await DbIndex.load({ cid, get: makeProllyGetBlock(tblocks), ...opts })) as ProllyNode<K, T>;\n}\n\nexport async function applyQuery<K extends IndexKeyType, T extends DocObject, R extends DocFragment>(\n crdt: CRDT<T>,\n resp: { result: ProllyIndexRow<K, R>[] },\n query: QueryOpts<K>,\n): Promise<{\n rows: IndexRow<K, T, R>[];\n}> {\n if (query.descending) {\n resp.result = resp.result.reverse();\n }\n if (query.limit) {\n resp.result = resp.result.slice(0, query.limit);\n }\n if (query.includeDocs) {\n resp.result = await Promise.all(\n resp.result.map(async (row) => {\n const val = await crdt.get(row.id);\n const doc = val ? ({ ...val.doc, _id: row.id } as DocWithId<T>) : undefined;\n return { ...row, doc };\n }),\n );\n }\n return {\n rows: resp.result.map(({ key, ...row }) => {\n return {\n key: charwise.decode(key),\n ...row,\n };\n }),\n };\n}\n\nexport function encodeRange(range: [IndexKeyType, IndexKeyType]): [string, string] {\n return [charwise.encode(range[0]), charwise.encode(range[1])];\n}\n\nexport function encodeKey(key: DocFragment): string {\n return charwise.encode(key) as string;\n}\n\nexport interface ProllyIndexRow<K extends IndexKeyType, T extends DocFragment> {\n readonly id: string;\n readonly key: IndexKey<K>;\n readonly value: T;\n}\n\n// ProllyNode type based on the ProllyNode from 'prolly-trees/base'\ninterface ProllyNode<K extends IndexKeyType, T extends DocFragment> extends BaseNode {\n getAllEntries(): PromiseLike<{ [x: string]: unknown; result: ProllyIndexRow<K, T>[] }>;\n getMany<KI extends IndexKeyType>(removeIds: KI[]): Promise<{ /* [x: K]: unknown; */ result: IndexKey<K>[] }>;\n range(a: string, b: string): Promise<{ result: ProllyIndexRow<K, T>[] }>;\n get(key: string): Promise<{ result: ProllyIndexRow<K, T>[] }>;\n bulk(bulk: (IndexUpdate<K> | IndexUpdateString)[]): PromiseLike<{\n readonly root?: ProllyNode<K, T>;\n readonly blocks: Block[];\n }>;\n readonly address: Promise<Link>;\n readonly distance: number;\n compare: (a: unknown, b: unknown) => number;\n readonly cache: unknown;\n readonly block: Promise<Block>;\n}\n\ninterface StaticProllyOptions<T> {\n readonly cache: unknown;\n chunker: (entry: T, distance: number) => boolean;\n readonly codec: unknown;\n readonly hasher: unknown;\n compare: (a: T, b: T) => number;\n}\n","import {\n type ClockHead,\n type DocUpdate,\n type MapFn,\n type IndexUpdate,\n type QueryOpts,\n type IdxMeta,\n type DocFragment,\n type IdxMetaMap,\n type IndexKeyType,\n type IndexRows,\n type DocTypes,\n type IndexUpdateString,\n throwFalsy,\n IndexTransactionMeta,\n SuperThis,\n} from \"./types.js\";\nimport { BaseBlockstore } from \"./blockstore/index.js\";\n\nimport {\n bulkIndex,\n indexEntriesForChanges,\n byIdOpts,\n byKeyOpts,\n IndexTree,\n applyQuery,\n encodeRange,\n encodeKey,\n loadIndex,\n IndexDocString,\n CompareKey,\n} from \"./indexer-helpers.js\";\nimport { CRDT, HasCRDT } from \"./crdt.js\";\nimport { ensureLogger } from \"./utils.js\";\nimport { Logger } from \"@adviser/cement\";\n\nexport function index<K extends IndexKeyType = string, T extends DocTypes = NonNullable<unknown>, R extends DocFragment = T>(\n refDb: HasCRDT<T>,\n name: string,\n mapFn?: MapFn<T>,\n meta?: IdxMeta,\n): Index<K, T, R> {\n if (mapFn && meta) throw refDb.crdt.logger.Error().Msg(\"cannot provide both mapFn and meta\").AsError();\n if (mapFn && mapFn.constructor.name !== \"Function\") throw refDb.crdt.logger.Error().Msg(\"mapFn must be a function\").AsError();\n if (refDb.crdt.indexers.has(name)) {\n const idx = refDb.crdt.indexers.get(name) as unknown as Index<K, T>;\n idx.applyMapFn(name, mapFn, meta);\n } else {\n const idx = new Index<K, T>(refDb.crdt.sthis, refDb.crdt, name, mapFn, meta);\n refDb.crdt.indexers.set(name, idx as unknown as Index<K, NonNullable<unknown>, NonNullable<unknown>>);\n }\n return refDb.crdt.indexers.get(name) as unknown as Index<K, T, R>;\n}\n\n// interface ByIdIndexIten<K extends IndexKeyType> {\n// readonly key: K;\n// readonly value: [K, K];\n// }\n\nexport class Index<K extends IndexKeyType, T extends DocTypes, R extends DocFragment = T> {\n readonly blockstore: BaseBlockstore;\n readonly crdt: CRDT<T>;\n readonly name: string;\n mapFn?: MapFn<T>;\n mapFnString = \"\";\n byKey: IndexTree<K, R> = new IndexTree<K, R>();\n byId: IndexTree<K, R> = new IndexTree<K, R>();\n indexHead?: ClockHead;\n includeDocsDefault = false;\n initError?: Error;\n\n ready(): Promise<void> {\n return Promise.all([this.blockstore.ready(), this.crdt.ready()]).then(() => {\n /* noop */\n });\n }\n\n // close(): Promise<void> {\n // return Promise.all([this.blockstore.close(), this.crdt.close()]).then(() => {\n // /* noop */\n // });\n // }\n // destroy(): Promise<void> {\n // return Promise.all([this.blockstore.destroy(), this.crdt.destroy()]).then(() => {\n // /* noop */\n // });\n // }\n\n readonly logger: Logger;\n\n constructor(sthis: SuperThis, crdt: CRDT<T> | CRDT<NonNullable<unknown>>, name: string, mapFn?: MapFn<T>, meta?: IdxMeta) {\n this.logger = ensureLogger(sthis, \"Index\");\n this.blockstore = crdt.indexBlockstore;\n this.crdt = crdt as CRDT<T>;\n this.applyMapFn(name, mapFn, meta);\n this.name = name;\n if (!(this.mapFnString || this.initError)) throw this.logger.Error().Msg(\"missing mapFnString\").AsError();\n // this.ready = this.blockstore.ready.then(() => {\n // return;\n // });\n // .then((header: IdxCarHeader) => {\n // // @ts-ignore\n // if (header.head) throw new Error('cannot have head in idx header')\n // if (header.indexes === undefined) throw new Error('missing indexes in idx header')\n // // for (const [name, idx] of Object.entries(header.indexes)) {\n // // index({ _crdt: crdt }, name, undefined, idx as IdxMeta)\n // // }\n // })\n }\n\n applyMapFn(name: string, mapFn?: MapFn<T>, meta?: IdxMeta) {\n if (mapFn && meta) throw this.logger.Error().Msg(\"cannot provide both mapFn and meta\").AsError();\n if (this.name && this.name !== name) throw this.logger.Error().Msg(\"cannot change name\").AsError();\n // this.name = name;\n try {\n if (meta) {\n // hydrating from header\n if (this.indexHead && this.indexHead.map((c) => c.toString()).join() !== meta.head.map((c) => c.toString()).join()) {\n throw this.logger.Error().Msg(\"cannot apply different head meta\").AsError();\n }\n\n if (this.mapFnString) {\n // we already initialized from application code\n if (this.mapFnString !== meta.map) {\n this.logger\n .Warn()\n .Msg(`cannot apply different mapFn meta: old mapFnString ${this.mapFnString} new mapFnString ${meta.map}`);\n // throw new Error('cannot apply different mapFn meta')\n } else {\n this.byId.cid = meta.byId;\n this.byKey.cid = meta.byKey;\n this.indexHead = meta.head;\n }\n } else {\n // we are first\n this.mapFnString = meta.map;\n this.byId.cid = meta.byId;\n this.byKey.cid = meta.byKey;\n this.indexHead = meta.head;\n }\n } else {\n if (this.mapFn) {\n // we already initialized from application code\n if (mapFn) {\n if (this.mapFn.toString() !== mapFn.toString()) {\n throw this.logger.Error().Msg(\"cannot apply different mapFn app2\").AsError();\n }\n }\n } else {\n // application code is creating an index\n if (!mapFn) {\n mapFn = ((doc) => (doc as unknown as Record<string, unknown>)[name] ?? undefined) as MapFn<T>;\n }\n if (this.mapFnString) {\n // we already loaded from a header\n if (this.mapFnString !== mapFn.toString()) {\n throw this.logger\n .Error()\n .Str(\"mapFnString\", this.mapFnString)\n .Str(\"mapFn\", mapFn.toString())\n .Msg(\"cannot apply different mapFn app\")\n .AsError();\n }\n } else {\n // we are first\n this.mapFnString = mapFn.toString();\n }\n this.mapFn = mapFn;\n }\n }\n const matches = /=>\\s*(.*)/.test(this.mapFnString);\n this.includeDocsDefault = matches;\n } catch (e) {\n this.initError = e as Error;\n }\n }\n\n async query(opts: QueryOpts<K> = {}): Promise<IndexRows<K, T, R>> {\n this.logger.Debug().Msg(\"enter query\");\n await this.ready();\n // this._resetIndex();\n this.logger.Debug().Msg(\"post ready query\");\n await this._updateIndex();\n this.logger.Debug().Msg(\"post _updateIndex query\");\n await this._hydrateIndex();\n this.logger.Debug().Msg(\"post _hydrateIndex query\");\n if (!this.byKey.root) {\n return await applyQuery<K, T, R>(this.crdt, { result: [] }, opts);\n }\n if (this.includeDocsDefault && opts.includeDocs === undefined) opts.includeDocs = true;\n if (opts.range) {\n const eRange = encodeRange(opts.range);\n return await applyQuery<K, T, R>(this.crdt, await throwFalsy(this.byKey.root).range(eRange[0], eRange[1]), opts);\n }\n if (opts.key) {\n const encodedKey = encodeKey(opts.key);\n return await applyQuery<K, T, R>(this.crdt, await throwFalsy(this.byKey.root).get(encodedKey), opts);\n }\n if (Array.isArray(opts.keys)) {\n const results = await Promise.all(\n opts.keys.map(async (key: DocFragment) => {\n const encodedKey = encodeKey(key);\n return (await applyQuery<K, T, R>(this.crdt, await throwFalsy(this.byKey.root).get(encodedKey), opts)).rows;\n }),\n );\n return { rows: results.flat() };\n }\n if (opts.prefix) {\n if (!Array.isArray(opts.prefix)) opts.prefix = [opts.prefix];\n // prefix should be always an array\n const start = [...opts.prefix, NaN];\n const end = [...opts.prefix, Infinity];\n const encodedR = encodeRange([start, end]);\n return await applyQuery<K, T, R>(this.crdt, await this.byKey.root.range(...encodedR), opts);\n }\n const all = await this.byKey.root.getAllEntries(); // funky return type\n return await applyQuery<K, T, R>(\n this.crdt,\n {\n // @ts-expect-error getAllEntries returns a different type than range\n result: all.result.map(({ key: [k, id], value }) => ({\n key: k,\n id,\n value,\n })),\n },\n opts,\n );\n }\n\n _resetIndex() {\n this.byId = new IndexTree();\n this.byKey = new IndexTree();\n this.indexHead = undefined;\n }\n\n async _hydrateIndex() {\n if (this.byId.root && this.byKey.root) return;\n if (!this.byId.cid || !this.byKey.cid) return;\n this.byId.root = await loadIndex<K, R, K>(this.blockstore, this.byId.cid, byIdOpts);\n this.byKey.root = await loadIndex<K, R, CompareKey>(this.blockstore, this.byKey.cid, byKeyOpts);\n }\n\n async _updateIndex(): Promise<IndexTransactionMeta> {\n await this.ready();\n this.logger.Debug().Msg(\"enter _updateIndex\");\n if (this.initError) throw this.initError;\n if (!this.mapFn) throw this.logger.Error().Msg(\"No map function defined\").AsError();\n let result: DocUpdate<T>[], head: ClockHead;\n if (!this.indexHead || this.indexHead.length === 0) {\n ({ result, head } = await this.crdt.allDocs());\n this.logger.Debug().Msg(\"enter crdt.allDocs\");\n } else {\n ({ result, head } = await this.crdt.changes(this.indexHead));\n this.logger.Debug().Msg(\"enter crdt.changes\");\n }\n if (result.length === 0) {\n this.indexHead = head;\n // return { byId: this.byId, byKey: this.byKey } as IndexTransactionMeta;\n }\n let staleKeyIndexEntries: IndexUpdate<K>[] = [];\n let removeIdIndexEntries: IndexUpdateString[] = [];\n if (this.byId.root) {\n const removeIds = result.map(({ id: key }) => key);\n const { result: oldChangeEntries } = await this.byId.root.getMany(removeIds);\n staleKeyIndexEntries = oldChangeEntries.map((key) => ({ key, del: true }));\n removeIdIndexEntries = oldChangeEntries.map((key) => ({ key: key[1], del: true }));\n }\n const indexEntries = indexEntriesForChanges<T, K>(result, this.mapFn); // use a getter to translate from string\n const byIdIndexEntries: IndexDocString[] = indexEntries.map(({ key }) => ({\n key: key[1],\n value: key,\n }));\n const indexerMeta: IdxMetaMap = { indexes: new Map() };\n\n for (const [name, indexer] of this.crdt.indexers) {\n if (indexer.indexHead) {\n indexerMeta.indexes?.set(name, {\n byId: indexer.byId.cid,\n byKey: indexer.byKey.cid,\n head: indexer.indexHead,\n map: indexer.mapFnString,\n name: indexer.name,\n } as IdxMeta);\n }\n }\n if (result.length === 0) {\n return indexerMeta as unknown as IndexTransactionMeta;\n }\n this.logger.Debug().Msg(\"pre this.blockstore.transaction\");\n const { meta } = await this.blockstore.transaction<IndexTransactionMeta>(async (tblocks): Promise<IndexTransactionMeta> => {\n this.byId = await bulkIndex<K, R, K>(\n this.logger,\n tblocks,\n this.byId,\n removeIdIndexEntries.concat(byIdIndexEntries),\n byIdOpts,\n );\n this.byKey = await bulkIndex<K, R, CompareKey>(\n this.logger,\n tblocks,\n this.byKey,\n staleKeyIndexEntries.concat(indexEntries),\n byKeyOpts,\n );\n this.indexHead = head;\n if (this.byId.cid && this.byKey.cid) {\n const idxMeta = {\n byId: this.byId.cid,\n byKey: this.byKey.cid,\n head,\n map: this.mapFnString,\n name: this.name,\n } as IdxMeta;\n indexerMeta.indexes?.set(this.name, idxMeta);\n }\n this.logger.Debug().Any(\"indexerMeta\", new Array(indexerMeta.indexes?.entries())).Msg(\"exit this.blockstore.transaction fn\");\n return indexerMeta as unknown as IndexTransactionMeta;\n });\n this.logger.Debug().Msg(\"post this.blockstore.transaction\");\n return meta;\n }\n}\n","import { advance } from \"@fireproof/vendor/@web3-storage/pail/clock\";\nimport { root } from \"@fireproof/vendor/@web3-storage/pail/crdt\";\nimport { Logger, ResolveOnce } from \"@adviser/cement\";\n\nimport { clockChangesSince } from \"./crdt-helpers.js\";\nimport type { BaseBlockstore, CarTransaction } from \"./blockstore/index.js\";\nimport { type DocUpdate, type ClockHead, type DocTypes, throwFalsy } from \"./types.js\";\nimport { applyHeadQueue, ApplyHeadQueue } from \"./apply-head-queue.js\";\nimport { ensureLogger } from \"./utils.js\";\n\nexport class CRDTClock<T extends DocTypes> {\n // todo: track local and remote clocks independently, merge on read\n // that way we can drop the whole remote if we need to\n // should go with making sure the local clock only references locally available blockstore on write\n head: ClockHead = [];\n\n readonly zoomers: Set<() => void> = new Set<() => void>();\n readonly watchers: Set<(updates: DocUpdate<T>[]) => void> = new Set<(updates: DocUpdate<T>[]) => void>();\n readonly emptyWatchers: Set<() => void> = new Set<() => void>();\n\n readonly blockstore: BaseBlockstore;\n\n readonly applyHeadQueue: ApplyHeadQueue<T>;\n transaction?: CarTransaction;\n\n readonly _ready: ResolveOnce<void> = new ResolveOnce<void>();\n async ready(): Promise<void> {\n return this._ready.once(async () => {\n await this.blockstore.ready();\n });\n }\n\n async close() {\n await this.blockstore.close();\n }\n\n readonly logger: Logger;\n constructor(blockstore: BaseBlockstore) {\n this.blockstore = blockstore;\n this.logger = ensureLogger(blockstore.sthis, \"CRDTClock\");\n this.applyHeadQueue = applyHeadQueue(this.int_applyHead.bind(this), this.logger);\n }\n\n setHead(head: ClockHead) {\n this.head = head;\n }\n\n async applyHead(newHead: ClockHead, prevHead: ClockHead, updates?: DocUpdate<T>[]): Promise<void> {\n for await (const { updates: updatesAcc, all } of this.applyHeadQueue.push({\n newHead,\n prevHead,\n updates,\n })) {\n return this.processUpdates(updatesAcc, all, prevHead);\n }\n }\n\n async processUpdates(updatesAcc: DocUpdate<T>[], all: boolean, prevHead: ClockHead) {\n let internalUpdates = updatesAcc;\n if (this.watchers.size && !all) {\n const changes = await clockChangesSince<T>(throwFalsy(this.blockstore), this.head, prevHead, {}, this.logger);\n internalUpdates = changes.result;\n }\n this.zoomers.forEach((fn) => fn());\n this.notifyWatchers(internalUpdates || []);\n }\n\n notifyWatchers(updates: DocUpdate<T>[]) {\n this.emptyWatchers.forEach((fn) => fn());\n this.watchers.forEach((fn) => fn(updates || []));\n }\n\n onTick(fn: (updates: DocUpdate<T>[]) => void) {\n this.watchers.add(fn);\n }\n\n onTock(fn: () => void) {\n this.emptyWatchers.add(fn);\n }\n\n onZoom(fn: () => void) {\n this.zoomers.add(fn);\n }\n\n async int_applyHead(newHead: ClockHead, prevHead: ClockHead, localUpdates: boolean) {\n // if (!(this.head && prevHead && newHead)) {\n // throw new Error(\"missing head\");\n // }\n const noLoader = !localUpdates;\n\n // console.log(\"int_applyHead\", this.applyHeadQueue.size(), this.head, newHead, prevHead, localUpdates);\n const ogHead = sortClockHead(this.head);\n newHead = sortClockHead(newHead);\n if (compareClockHeads(ogHead, newHead)) {\n return;\n }\n const ogPrev = sortClockHead(prevHead);\n if (compareClockHeads(ogHead, ogPrev)) {\n this.setHead(newHead);\n return;\n }\n\n // const noLoader = this.head.length === 1 && !updates?.length\n if (!this.blockstore) {\n throw this.logger.Error().Msg(\"missing blockstore\").AsError();\n }\n await validateBlocks(this.logger, newHead, this.blockstore);\n if (!this.transaction) {\n this.transaction = this.blockstore.openTransaction({ noLoader, add: false });\n }\n const tblocks = this.transaction;\n\n const advancedHead = await advanceBlocks(this.logger, newHead, tblocks, this.head);\n const result = await root(tblocks, advancedHead);\n for (const { cid, bytes } of [\n ...result.additions,\n // ...result.removals\n ]) {\n tblocks.putSync(cid, bytes);\n }\n if (!noLoader) {\n await this.blockstore.commitTransaction(tblocks, { head: advancedHead }, { add: false, noLoader });\n this.transaction = undefined;\n }\n this.setHead(advancedHead);\n }\n}\n\n// Helper functions\nfunction sortClockHead(clockHead: ClockHead) {\n return clockHead.sort((a, b) => a.toString().localeCompare(b.toString()));\n}\n\nasync function validateBlocks(logger: Logger, newHead: ClockHead, blockstore?: BaseBlockstore) {\n if (!blockstore) throw logger.Error().Msg(\"missing blockstore\");\n newHead.map(async (cid) => {\n const got = await blockstore.get(cid);\n if (!got) {\n throw logger.Error().Str(\"cid\", cid.toString()).Msg(\"int_applyHead missing block\").AsError();\n }\n });\n}\n\nfunction compareClockHeads(head1: ClockHead, head2: ClockHead) {\n return head1.toString() === head2.toString();\n}\n\nasync function advanceBlocks(logger: Logger, newHead: ClockHead, tblocks: CarTransaction, head: ClockHead) {\n for (const cid of newHead) {\n try {\n head = await advance(tblocks, head, cid);\n } catch (e) {\n logger.Debug().Err(e).Msg(\"failed to advance head\");\n // console.log('failed to advance head:', cid.toString(), e)\n continue;\n }\n }\n return head;\n}\n","import { Logger } from \"@adviser/cement\";\nimport { ClockHead, DocTypes, DocUpdate } from \"./types.js\";\n\ntype ApplyHeadWorkerFunction = (newHead: ClockHead, prevHead: ClockHead, localUpdates: boolean) => Promise<void>;\n\ninterface ApplyHeadTask<T extends DocTypes> {\n readonly newHead: ClockHead;\n readonly prevHead: ClockHead;\n readonly updates?: DocUpdate<T>[];\n}\n\nexport interface ApplyHeadQueue<T extends DocTypes> {\n push(task: ApplyHeadTask<T>): AsyncGenerator<\n {\n readonly updates: DocUpdate<T>[];\n readonly all: boolean;\n },\n void,\n unknown\n >;\n size(): number;\n}\n\nexport function applyHeadQueue<T extends DocTypes>(worker: ApplyHeadWorkerFunction, logger: Logger): ApplyHeadQueue<T> {\n const queue: ApplyHeadTask<T>[] = [];\n let isProcessing = false;\n\n async function* process() {\n if (isProcessing || queue.length === 0) return;\n isProcessing = true;\n const allUpdates: DocUpdate<T>[] = [];\n try {\n while (queue.length > 0) {\n queue.sort((a, b) => (b.updates ? 1 : -1));\n const task = queue.shift();\n if (!task) continue;\n\n await worker(task.newHead, task.prevHead, task.updates !== undefined).catch((e) => {\n throw logger.Error().Err(e).Msg(\"int_applyHead worker error\").AsError();\n });\n // console.timeEnd('int_applyHead worker')\n\n if (task.updates) {\n allUpdates.push(...task.updates);\n }\n // Yield the updates if there are no tasks with updates left in the queue or the current task has updates\n if (!queue.some((t) => t.updates) || task.updates) {\n const allTasksHaveUpdates = queue.every((task) => task.updates !== null);\n yield { updates: allUpdates, all: allTasksHaveUpdates };\n allUpdates.length = 0;\n }\n }\n } finally {\n isProcessing = false;\n const generator = process();\n let result = await generator.next();\n while (!result.done) {\n result = await generator.next();\n }\n }\n }\n\n return {\n push(task: ApplyHeadTask<T>): AsyncGenerator<{ updates: DocUpdate<T>[]; all: boolean }, void, unknown> {\n queue.push(task);\n return process();\n },\n size() {\n return queue.length;\n },\n };\n}\n","export const PACKAGE_VERSION = Object.keys({\n \"0.20.0-dev-preview-05\": \"xxxx\",\n})[0] as string;\n"],"mappings":"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","names":["BuildURI","KeyedResolvOnce","ResolveOnce","URI","PARAM","raw","index","ResolveOnce","KeyedResolvOnce","Result","ResolveOnce","Result","ResolveOnce","codec","hasher","toCryptoRuntime","toCryptoRuntime","Future","ResolveOnce","Result","runtimeFn","toCryptoRuntime","URI","base58btc","ResolveOnce","base58btc","Result","runtimeFn","URI","toCryptoRuntime","hasher","dagCodec","codec","hasher","cid","ResolveOnce","cid","cache","got","batchSize","hasher","base58btc","hasher","hasher","base58btc","Result","FPEnvelopeType","Result","Result","ResolveOnce","runtimeFn","Result","Result","runtimeFn","getStore","runtimeFn","exception2Result","Result","EventBlock","CID","format","EventBlock","format","Result","CID","exception2Result","raw","exception2Result","KeyedResolvOnce","Result","KeyedResolvOnce","exception2Result","Result","Result","Result","runtimeFn","KeyedResolvOnce","Result","parse","hasher","hasher","parse","hasher","codec","root","root","ResolveOnce","task","ResolveOnce","root","ResolveOnce","KeyedResolvOnce","ResolveOnce","updates","defaultURI","URI","BuildURI"]}
1
+ {"version":3,"sources":["../../src/ledger.ts","../../src/utils.ts","../../src/types.ts","../../src/write-queue.ts","../../src/runtime/files.ts","../../src/runtime/key-bag.ts","../../src/runtime/gateways/file/sys-file-system-factory.ts","../../src/runtime/gateways/file/key-bag-file.ts","../../src/runtime/key-bag-memory.ts","../../src/blockstore/register-store-protocol.ts","../../src/runtime/gateways/file/version.ts","../../src/runtime/gateways/indexdb/version.ts","../../src/runtime/gateways/file/gateway-impl.ts","../../src/runtime/gateways/file/utils.ts","../../src/runtime/gateways/memory/gateway.ts","../../src/runtime/gateways/memory/version.ts","../../src/runtime/gateways/def-serde-gateway.ts","../../src/runtime/gateways/fp-envelope-serialize.ts","../../src/blockstore/fp-envelope.ts","../../src/runtime/wait-pr-multiformats/block.ts","../../src/indexer-helpers.ts","../../src/indexer.ts","../../src/database.ts","../../src/crdt.ts","../../src/blockstore/index.ts","../../src/blockstore/types.ts","../../src/blockstore/store-factory.ts","../../src/blockstore/store.ts","../../src/blockstore/loader.ts","../../src/blockstore/loader-helpers.ts","../../src/blockstore/transaction.ts","../../src/blockstore/commit-queue.ts","../../src/blockstore/commitor.ts","../../src/blockstore/task-manager.ts","../../src/runtime/keyed-crypto.ts","../../src/blockstore/interceptor-gateway.ts","../../src/blockstore/store-remote.ts","../../src/blockstore/connection-base.ts","../../src/crdt-helpers.ts","../../src/crdt-clock.ts","../../src/apply-head-queue.ts","../../src/runtime/index.ts","../../src/runtime/wait-pr-multiformats/index.ts","../../src/runtime/wait-pr-multiformats/codec-interface.ts","../../src/runtime/gateways/index.ts","../../src/runtime/gateways/file/index.ts","../../src/version.ts"],"sourcesContent":["import { BuildURI, CoerceURI, KeyedResolvOnce, Logger, ResolveOnce, URI } from \"@adviser/cement\";\n\nimport { defaultWriteQueueOpts, writeQueue, WriteQueueParams } from \"./write-queue.js\";\nimport type {\n DocUpdate,\n ConfigOpts,\n DocWithId,\n ListenerFn,\n DocTypes,\n SuperThis,\n Database,\n Ledger,\n WriteQueue,\n CRDT,\n} from \"./types.js\";\nimport { PARAM } from \"./types.js\";\nimport { DbMeta, SerdeGatewayInterceptor, StoreEnDeFile, StoreURIRuntime, StoreUrlsOpts } from \"./blockstore/index.js\";\nimport { ensureLogger, ensureSuperThis, toSortedArray } from \"./utils.js\";\n\nimport { decodeFile, encodeFile } from \"./runtime/files.js\";\nimport { defaultKeyBagOpts, KeyBagRuntime } from \"./runtime/key-bag.js\";\nimport { getDefaultURI } from \"./blockstore/register-store-protocol.js\";\nimport { DatabaseImpl } from \"./database.js\";\nimport { CRDTImpl } from \"./crdt.js\";\n\nconst ledgers = new KeyedResolvOnce<Ledger>();\n\nexport function keyConfigOpts(sthis: SuperThis, name?: string, opts?: ConfigOpts): string {\n return JSON.stringify(\n toSortedArray({\n name,\n stores: toSortedArray(JSON.parse(JSON.stringify(toStoreURIRuntime(sthis, name, opts?.storeUrls)))),\n }),\n );\n}\n\nexport interface LedgerOpts {\n readonly name?: string;\n // readonly public?: boolean;\n readonly meta?: DbMeta;\n readonly gatewayInterceptor?: SerdeGatewayInterceptor;\n\n readonly writeQueue: WriteQueueParams;\n // readonly factoryUnreg?: () => void;\n // readonly persistIndexes?: boolean;\n // readonly autoCompact?: number;\n readonly storeUrls: StoreURIRuntime;\n readonly storeEnDe: StoreEnDeFile;\n readonly keyBag: KeyBagRuntime;\n // readonly threshold?: number;\n}\n\nexport function isLedger(db: unknown): db is Ledger {\n return db instanceof LedgerImpl || db instanceof LedgerShell;\n}\n\nexport function LedgerFactory(name: string | undefined, opts?: ConfigOpts): Ledger {\n const sthis = ensureSuperThis(opts);\n return new LedgerShell(\n ledgers.get(keyConfigOpts(sthis, name, opts)).once((key) => {\n const db = new LedgerImpl(sthis, {\n name,\n meta: opts?.meta,\n keyBag: defaultKeyBagOpts(sthis, opts?.keyBag),\n storeUrls: toStoreURIRuntime(sthis, name, opts?.storeUrls),\n gatewayInterceptor: opts?.gatewayInterceptor,\n writeQueue: defaultWriteQueueOpts(opts?.writeQueue),\n storeEnDe: {\n encodeFile,\n decodeFile,\n ...opts?.storeEnDe,\n },\n });\n db.onClosed(() => {\n ledgers.unget(key);\n });\n return db;\n }),\n );\n}\n\nexport class LedgerShell implements Ledger {\n readonly ref: LedgerImpl;\n readonly writeQueue: WriteQueue<DocUpdate<DocTypes>>;\n readonly name: string;\n constructor(ref: LedgerImpl) {\n this.ref = ref;\n this.writeQueue = ref.writeQueue;\n this.name = ref.name;\n ref.addShell(this);\n }\n\n get id(): string {\n return this.ref.id;\n }\n get logger(): Logger {\n return this.ref.logger;\n }\n get sthis(): SuperThis {\n return this.ref.sthis;\n }\n get crdt(): CRDT {\n return this.ref.crdt;\n }\n\n onClosed(fn: () => void): () => void {\n return this.ref.onClosed(fn);\n }\n close(): Promise<void> {\n return this.ref.shellClose(this);\n }\n destroy(): Promise<void> {\n return this.ref.destroy();\n }\n ready(): Promise<void> {\n return this.ref.ready();\n }\n\n // asDB(): Database {\n // return this.ref.asDB();\n // }\n\n subscribe<T extends DocTypes>(listener: ListenerFn<T>, updates?: boolean): () => void {\n return this.ref.subscribe(listener, updates);\n }\n}\n\nclass LedgerImpl implements Ledger {\n // readonly name: string;\n readonly opts: LedgerOpts;\n\n _listening = false;\n readonly _listeners = new Set<ListenerFn<DocTypes>>();\n readonly _noupdate_listeners = new Set<ListenerFn<DocTypes>>();\n readonly crdt: CRDT;\n readonly writeQueue: WriteQueue<DocUpdate<DocTypes>>;\n // readonly blockstore: BaseBlockstore;\n\n readonly shells: Set<LedgerShell> = new Set<LedgerShell>();\n\n get name(): string {\n return this.opts.storeUrls.data.data.getParam(PARAM.NAME) || \"default\";\n }\n\n addShell(shell: LedgerShell) {\n this.shells.add(shell);\n }\n\n readonly _onClosedFns = new Map<string, () => void>();\n onClosed(fn: () => void): () => void {\n const id = this.sthis.nextId().str;\n this._onClosedFns.set(id, fn);\n return () => {\n this._onClosedFns.delete(id);\n };\n }\n async close() {\n throw this.logger.Error().Str(\"db\", this.name).Msg(`use shellClose`).AsError();\n }\n async shellClose(db: LedgerShell) {\n if (!this.shells.has(db)) {\n throw this.logger.Error().Str(\"db\", this.name).Msg(`LedgerShell mismatch`).AsError();\n }\n this.shells.delete(db);\n if (this.shells.size === 0) {\n await this.ready();\n await this.crdt.close();\n await this.writeQueue.close();\n this._onClosedFns.forEach((fn) => fn());\n }\n // await this.blockstore.close();\n }\n\n async destroy() {\n await this.ready();\n await this.crdt.destroy();\n // await this.blockstore.destroy();\n }\n\n readonly _ready: ResolveOnce<void> = new ResolveOnce<void>();\n async ready(): Promise<void> {\n const ret = await this._ready.once(async () => {\n await this.sthis.start();\n await this.crdt.ready();\n // await this.blockstore.ready();\n });\n return ret;\n }\n\n readonly logger: Logger;\n readonly sthis: SuperThis;\n readonly id: string;\n\n constructor(sthis: SuperThis, opts: LedgerOpts) {\n this.opts = opts; // || this.opts;\n // this.name = opts.storeUrls.data.data.getParam(PARAM.NAME) || \"default\";\n this.sthis = sthis;\n this.id = sthis.timeOrderedNextId().str;\n this.logger = ensureLogger(this.sthis, \"Ledger\");\n this.crdt = new CRDTImpl(this.sthis, this.opts);\n this.writeQueue = writeQueue(\n this.sthis,\n async (updates: DocUpdate<DocTypes>[]) => this.crdt.bulk(updates),\n this.opts.writeQueue,\n );\n this.crdt.clock.onTock(() => this._no_update_notify());\n }\n\n // readonly _asDb = new ResolveOnce<Database>();\n // asDB(): Database {\n // return this._asDb.once(() => new DatabaseImpl(this));\n // }\n\n subscribe<T extends DocTypes>(listener: ListenerFn<T>, updates?: boolean): () => void {\n this.logger.Debug().Bool(\"updates\", updates).Msg(\"subscribe\");\n if (updates) {\n if (!this._listening) {\n this._listening = true;\n this.crdt.clock.onTick((updates: DocUpdate<NonNullable<unknown>>[]) => {\n void this._notify(updates);\n });\n }\n this._listeners.add(listener as ListenerFn<NonNullable<unknown>>);\n return () => {\n this._listeners.delete(listener as ListenerFn<NonNullable<unknown>>);\n };\n } else {\n this._noupdate_listeners.add(listener as ListenerFn<NonNullable<unknown>>);\n return () => {\n this._noupdate_listeners.delete(listener as ListenerFn<NonNullable<unknown>>);\n };\n }\n }\n\n private async _notify(updates: DocUpdate<DocTypes>[]) {\n await this.ready();\n if (this._listeners.size) {\n const docs: DocWithId<DocTypes>[] = updates.map(({ id, value }) => ({ ...value, _id: id }));\n for (const listener of this._listeners) {\n await (async () => await listener(docs as DocWithId<DocTypes>[]))().catch((e: Error) => {\n this.logger.Error().Err(e).Msg(\"subscriber error\");\n });\n }\n }\n }\n\n private async _no_update_notify() {\n await this.ready();\n if (this._noupdate_listeners.size) {\n for (const listener of this._noupdate_listeners) {\n await (async () => await listener([]))().catch((e: Error) => {\n this.logger.Error().Err(e).Msg(\"subscriber error\");\n });\n }\n }\n }\n}\n\nfunction defaultURI(\n sthis: SuperThis,\n curi: CoerceURI | undefined,\n uri: URI,\n store: \"data\" | \"meta\" | \"wal\",\n ctx?: Partial<{\n readonly idx: boolean;\n readonly file: boolean;\n }>,\n): URI {\n ctx = ctx || {};\n const ret = (curi ? URI.from(curi) : uri).build().setParam(PARAM.STORE, store);\n if (!ret.hasParam(PARAM.NAME)) {\n const name = sthis.pathOps.basename(ret.URI().pathname);\n if (!name) {\n throw sthis.logger.Error().Url(ret).Any(\"ctx\", ctx).Msg(\"Ledger name is required\").AsError();\n }\n ret.setParam(PARAM.NAME, name);\n }\n if (ctx.idx) {\n ret.defParam(PARAM.INDEX, \"idx\");\n ret.defParam(PARAM.STORE_KEY, `@${ret.getParam(PARAM.NAME)}-${store}-idx@`);\n } else {\n ret.defParam(PARAM.STORE_KEY, `@${ret.getParam(PARAM.NAME)}-${store}@`);\n }\n if (store === \"data\") {\n if (ctx.file) {\n // ret.defParam(PARAM.SUFFIX, \"\");\n } else {\n ret.defParam(PARAM.SUFFIX, \".car\");\n }\n }\n return ret.URI();\n}\n\nexport function toStoreURIRuntime(sthis: SuperThis, name?: string, sopts?: StoreUrlsOpts): StoreURIRuntime {\n sopts = sopts || {};\n if (!sopts.base) {\n const fp_env = sthis.env.get(\"FP_STORAGE_URL\");\n if (fp_env) {\n sopts = { ...sopts, base: BuildURI.from(fp_env).setParam(PARAM.URL_GEN, \"fromEnv\") };\n } else {\n sopts = { ...sopts, base: getDefaultURI(sthis).build().setParam(PARAM.URL_GEN, \"default\") };\n }\n }\n const bbase = BuildURI.from(sopts.base);\n if (name) {\n bbase.setParam(PARAM.NAME, name);\n }\n const base = bbase.URI();\n // readonly public?: boolean;\n // readonly meta?: DbMeta;\n // readonly persistIndexes?: boolean;\n // readonly autoCompact?: number;\n // readonly threshold?: number;\n return {\n idx: {\n data: defaultURI(sthis, sopts.idx?.data, base, \"data\", { idx: true }),\n file: defaultURI(sthis, sopts.idx?.data, base, \"data\", { file: true, idx: true }),\n meta: defaultURI(sthis, sopts.idx?.meta, base, \"meta\", { idx: true }),\n wal: defaultURI(sthis, sopts.idx?.wal, base, \"wal\", { idx: true }),\n },\n data: {\n data: defaultURI(sthis, sopts.data?.data, base, \"data\"),\n file: defaultURI(sthis, sopts.data?.data, base, \"data\", { file: true }),\n meta: defaultURI(sthis, sopts.data?.meta, base, \"meta\"),\n wal: defaultURI(sthis, sopts.data?.wal, base, \"wal\"),\n },\n };\n}\n\nclass Fireproof {\n Ledger(name: string, opts?: ConfigOpts): Ledger {\n return LedgerFactory(name, opts);\n }\n DB(name: string, opts?: ConfigOpts): Database {\n return new DatabaseImpl(this.Ledger(name, opts));\n }\n}\n\nexport const fireproof = new Fireproof();\n","import {\n Logger,\n LoggerImpl,\n IsLogger,\n Result,\n ResolveOnce,\n isURL,\n URI,\n envFactory,\n Env,\n toCryptoRuntime,\n CryptoRuntime,\n JSONFormatter,\n YAMLFormatter,\n} from \"@adviser/cement\";\nimport { PARAM, PathOps, StoreType, SuperThis, SuperThisOpts, TextEndeCoder, PromiseToUInt8, ToUInt8 } from \"./types.js\";\nimport { base58btc } from \"multiformats/bases/base58\";\n\n//export type { Logger };\n//export { Result };\n\nconst _globalLogger = new ResolveOnce();\nfunction globalLogger(): Logger {\n return _globalLogger.once(() => new LoggerImpl());\n}\n\nconst registerFP_DEBUG = new ResolveOnce();\n\ninterface superThisOpts {\n readonly logger: Logger;\n readonly env: Env;\n readonly pathOps: PathOps;\n readonly crypto: CryptoRuntime;\n readonly ctx: Record<string, unknown>;\n readonly txt: TextEndeCoder;\n}\n\nclass SuperThisImpl implements SuperThis {\n readonly logger: Logger;\n readonly env: Env;\n readonly pathOps: PathOps;\n readonly ctx: Record<string, unknown>;\n readonly txt: TextEndeCoder;\n readonly crypto: CryptoRuntime;\n\n constructor(opts: superThisOpts) {\n this.logger = opts.logger;\n this.env = opts.env;\n this.crypto = opts.crypto;\n this.pathOps = opts.pathOps;\n this.txt = opts.txt;\n this.ctx = { ...opts.ctx };\n // console.log(\"superThis\", this);\n }\n\n nextId(bytes = 6): { str: string; bin: Uint8Array } {\n const bin = this.crypto.randomBytes(bytes);\n return {\n str: base58btc.encode(bin),\n bin,\n };\n }\n\n timeOrderedNextId(now?: number): { str: string } {\n now = typeof now === \"number\" ? now : new Date().getTime();\n // 49th bit\n const t = (0x1000000000000 + now).toString(16).replace(/^1/, \"\");\n const bin = this.crypto.randomBytes(10);\n bin[1] = (bin[1] & 0xf0) | (bin[1] | 0x08 && 0x0b);\n const hex = Array.from(bin)\n .map((i) => i.toString(16).padStart(2, \"0\"))\n .join(\"\");\n return {\n str: `${t.slice(0, 8)}-${t.slice(8)}-7${hex.slice(0, 3)}-${hex.slice(3, 7)}-${hex.slice(7, 19)}`,\n };\n }\n\n start(): Promise<void> {\n return Promise.resolve();\n }\n\n clone(override: Partial<SuperThisOpts>): SuperThis {\n return new SuperThisImpl({\n logger: override.logger || this.logger,\n env: envFactory(override.env) || this.env,\n crypto: override.crypto || this.crypto,\n pathOps: override.pathOps || this.pathOps,\n txt: override.txt || this.txt,\n ctx: { ...this.ctx, ...override.ctx },\n });\n }\n}\n\n// const pathOps =\nfunction presetEnv() {\n const penv = new Map([\n // [\"FP_DEBUG\", \"xxx\"],\n // [\"FP_ENV\", \"development\"],\n ...Array.from(\n Object.entries(\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ((globalThis as any)[Symbol.for(\"FP_PRESET_ENV\")] || {}) as Record<string, string>,\n ),\n ), // .map(([k, v]) => [k, v as string])\n ]);\n // console.log(\">>>>>>\", penv)\n return penv;\n}\n// const envImpl = envFactory({\n// symbol: \"FP_ENV\",\n// presetEnv: presetEnv(),\n// });\nclass pathOpsImpl implements PathOps {\n join(...paths: string[]): string {\n return paths.map((i) => i.replace(/\\/+$/, \"\")).join(\"/\");\n }\n dirname(path: string) {\n return path.split(\"/\").slice(0, -1).join(\"/\");\n }\n basename(path: string): string {\n return path.split(\"/\").pop() || \"\";\n }\n // homedir() {\n // throw new Error(\"SysContainer:homedir is not available in seeded state\");\n // }\n}\nconst pathOps = new pathOpsImpl();\nconst txtOps = ((txtEncoder, txtDecoder) => ({\n encode: (input: string) => txtEncoder.encode(input),\n decode: (input: ToUInt8) => txtDecoder.decode(coerceIntoUint8(input).Ok()),\n // eslint-disable-next-line no-restricted-globals\n}))(new TextEncoder(), new TextDecoder());\n\nconst _onSuperThis = new Map<string, (sthis: SuperThis) => void>();\nexport function onSuperThis(fn: (sthis: SuperThis) => void): () => void {\n const key = `onSuperThis-${Math.random().toString(36).slice(2)}`;\n _onSuperThis.set(key, fn);\n return () => {\n _onSuperThis.delete(key);\n };\n}\n\nexport function ensureSuperThis(osthis?: Partial<SuperThisOpts>): SuperThis {\n const env = envFactory({\n symbol: osthis?.env?.symbol || \"FP_ENV\",\n presetEnv: osthis?.env?.presetEnv || presetEnv(),\n });\n const ret = new SuperThisImpl({\n logger: osthis?.logger || globalLogger(),\n env,\n crypto: osthis?.crypto || toCryptoRuntime(),\n ctx: osthis?.ctx || {},\n pathOps,\n txt: osthis?.txt || txtOps,\n });\n _onSuperThis.forEach((fn) => fn(ret));\n return ret;\n}\n\n// // eslint-disable-next-line @typescript-eslint/no-unused-vars\nexport function ensureSuperLog(sthis: SuperThis, componentName: string, ctx?: Record<string, unknown>): SuperThis {\n return sthis.clone({\n logger: ensureLogger(sthis, componentName, ctx),\n });\n}\n\nexport function ensureLogger(\n sthis: SuperThis /* Partial<LoggerOpts> | Logger */,\n componentName: string,\n ctx?: Record<string, unknown>,\n): Logger {\n // if (!opts?.logger) {\n // throw new Error(\"logger is required\");\n // }\n let logger: Logger;\n if (sthis && IsLogger(sthis.logger)) {\n logger = sthis.logger;\n } else {\n logger = globalLogger();\n }\n const cLogger = logger.With().Module(componentName); //.Str(\"this\", uuidv7());\n const debug: string[] = [];\n let exposeStack = false;\n if (ctx) {\n if (\"debug\" in ctx) {\n if (typeof ctx.debug === \"string\" && ctx.debug.length > 0) {\n debug.push(ctx.debug);\n } else {\n debug.push(componentName);\n }\n delete ctx.debug;\n }\n if (\"exposeStack\" in ctx) {\n exposeStack = true;\n delete ctx.exposeStack;\n }\n if (\"exposeStack\" in ctx) {\n exposeStack = true;\n delete ctx.exposeStack;\n }\n if (\"this\" in ctx) {\n cLogger.Str(\"this\", sthis.nextId(4).str);\n delete ctx.this;\n }\n for (const [key, value] of Object.entries(ctx)) {\n switch (typeof value) {\n case \"string\":\n cLogger.Str(key, value);\n break;\n case \"number\":\n cLogger.Uint64(key, value);\n break;\n default:\n if (value instanceof Date) {\n cLogger.Str(key, value.toISOString());\n } else if (isURL(value)) {\n cLogger.Str(key, value.toString());\n } else if (typeof value === \"function\") {\n cLogger.Ref(key, value);\n } else {\n cLogger.Any(key, value);\n }\n break;\n }\n }\n }\n registerFP_DEBUG\n .once(async () => {\n // console.log(\"registerFP_DEBUG\", SysContainer.env)\n sthis.env.onSet(\n (key, value) => {\n // console.log(\"FP_DEBUG\", key, value, debug)\n switch (key) {\n case \"FP_FORMAT\": {\n switch (value) {\n case \"jsonice\":\n logger.SetFormatter(new JSONFormatter(logger.TxtEnDe(), 2));\n break;\n case \"yaml\":\n logger.SetFormatter(new YAMLFormatter(logger.TxtEnDe(), 2));\n break;\n case \"json\":\n default:\n logger.SetFormatter(new JSONFormatter(logger.TxtEnDe()));\n break;\n }\n break;\n }\n case \"FP_DEBUG\":\n logger.SetDebug(value || []);\n break;\n case \"FP_STACK\":\n logger.SetExposeStack(!!value);\n break;\n }\n },\n \"FP_FORMAT\",\n \"FP_DEBUG\",\n \"FP_STACK\",\n );\n })\n .finally(() => {\n /* do nothing */\n });\n\n if (debug.length > 0) {\n logger.SetDebug(debug);\n }\n if (exposeStack) {\n logger.SetExposeStack(true);\n }\n const out = cLogger.Logger();\n if (sthis.env.get(\"FP_CONSTRUCTOR_DEBUG\")) {\n out.Debug().Msg(\"constructor\");\n }\n return out;\n}\n\nexport type Joiner = (...toJoin: string[]) => string;\n\nexport interface Store {\n readonly store: StoreType;\n readonly name: string;\n}\n\nexport function getStore(url: URI, sthis: SuperThis, joiner: Joiner): Store {\n const store = url.getParam(PARAM.STORE);\n switch (store) {\n case \"data\":\n case \"wal\":\n case \"meta\":\n break;\n default:\n throw sthis.logger.Error().Url(url).Msg(`store not found`).AsError();\n throw sthis.logger.Error().Url(url).Msg(`store not found`).AsError();\n }\n let name: string = store;\n if (url.hasParam(\"index\")) {\n name = joiner(url.getParam(PARAM.INDEX) || \"idx\", name);\n }\n return { store, name };\n}\n\nexport function getKey(url: URI, logger: Logger): string {\n const result = url.getParam(PARAM.KEY);\n if (!result) throw logger.Error().Str(\"url\", url.toString()).Msg(`key not found`).AsError();\n return result;\n}\n\nexport function getName(sthis: SuperThis, url: URI): string {\n let result = url.getParam(PARAM.NAME);\n if (!result) {\n result = sthis.pathOps.dirname(url.pathname);\n if (result.length === 0) {\n throw sthis.logger.Error().Str(\"url\", url.toString()).Msg(`name not found`).AsError();\n }\n }\n return result;\n}\n\n// export function exception2Result<T = void>(fn: () => Promise<T>): Promise<Result<T>> {\n// return fn()\n// .then((value) => Result.Ok(value))\n// .catch((e) => Result.Err(e));\n// }\n\nexport async function exceptionWrapper<T, E extends Error>(fn: () => Promise<Result<T, E>>): Promise<Result<T, E>> {\n return fn().catch((e) => Result.Err(e));\n}\n\n// // the big side effect party --- hate it\n// export function sanitizeURL(url: URL) {\n// url.searchParams.sort();\n// // const searchParams = Object.entries(url.searchParams).sort(([a], [b]) => a.localeCompare(b));\n// // console.log(\"searchParams\", searchParams);\n// // for (const [key] of searchParams) {\n// // url.searchParams.delete(key);\n// // }\n// // for (const [key, value] of searchParams) {\n// // url.searchParams.set(key, value);\n// // }\n// }\n\nexport class NotFoundError extends Error {\n readonly code = \"ENOENT\";\n}\n\nexport function isNotFoundError(e: Error | Result<unknown> | unknown): e is NotFoundError {\n if (Result.Is(e)) {\n if (e.isOk()) return false;\n e = e.Err();\n }\n if ((e as NotFoundError).code === \"ENOENT\") return true;\n return false;\n}\n\nexport function UInt8ArrayEqual(a: Uint8Array, b: Uint8Array): boolean {\n if (a.length !== b.length) {\n return false;\n }\n for (let i = 0; i < a.length; i++) {\n if (a[i] !== b[i]) {\n return false;\n }\n }\n return true;\n}\n\nexport function inplaceFilter<T>(i: T[], pred: (i: T, idx: number) => boolean): T[] {\n const founds: number[] = [];\n for (let j = 0; j < i.length; j++) {\n if (!pred(i[j], j)) {\n founds.push(j);\n }\n }\n for (let j = founds.length - 1; j >= 0; j--) {\n i.splice(founds[j], 1);\n }\n return i;\n}\n\nexport function toSortedArray(set?: Record<string, unknown>): Record<string, unknown>[] {\n if (!set) return [];\n return Object.entries(set)\n .sort(([a], [b]) => a.localeCompare(b))\n .map(([k, v]) => ({ [k]: v }));\n}\n\nexport function coerceIntoUint8(raw: ToUInt8): Result<Uint8Array> {\n if (raw instanceof Uint8Array) {\n return Result.Ok(raw);\n }\n if (Result.Is(raw)) {\n return raw;\n }\n return Result.Err(\"Not a Uint8Array\");\n}\n\nexport async function coercePromiseIntoUint8(raw: PromiseToUInt8): Promise<Result<Uint8Array>> {\n if (raw instanceof Uint8Array) {\n return Result.Ok(raw);\n }\n if (Result.Is(raw)) {\n return raw;\n }\n if (typeof raw.then === \"function\") {\n try {\n return coercePromiseIntoUint8(await raw);\n } catch (e) {\n return Result.Err(e as Error);\n }\n }\n return Result.Err(\"Not a Uint8Array\");\n}\n\nexport function makeName(fnString: string) {\n const regex = /\\(([^,()]+,\\s*[^,()]+|\\[[^\\]]+\\],\\s*[^,()]+)\\)/g;\n let found: RegExpExecArray | null = null;\n const matches = Array.from(fnString.matchAll(regex), (match) => match[1].trim());\n if (matches.length === 0) {\n found = /=>\\s*{?\\s*([^{}]+)\\s*}?/.exec(fnString);\n if (found && found[1].includes(\"return\")) {\n found = null;\n }\n }\n if (!found) {\n return fnString;\n } else {\n // it's a consise arrow function, match everything after the arrow\n return found[1];\n }\n}\n","import type { EventLink } from \"@fireproof/vendor/@web3-storage/pail/clock/api\";\nimport type { Operation } from \"@fireproof/vendor/@web3-storage/pail/crdt/api\";\nimport type { Block, UnknownLink, Version } from \"multiformats\";\n\nimport type {\n CarTransactionOpts,\n DbMeta,\n AnyLink,\n StoreUrlsOpts,\n StoreEnDeFile,\n SerdeGatewayInterceptor,\n Loadable,\n AnyBlock,\n TransactionMeta,\n TransactionWrapper,\n BlockstoreRuntime,\n} from \"./blockstore/index.js\";\nimport { EnvFactoryOpts, Env, Logger, CryptoRuntime, Result } from \"@adviser/cement\";\n\n// import type { MakeDirectoryOptions, PathLike, Stats } from \"fs\";\nimport { KeyBagOpts } from \"./runtime/key-bag.js\";\nimport { WriteQueueParams } from \"./write-queue.js\";\nimport { Index } from \"./indexer.js\";\n\nexport type { DbMeta };\n\nexport type Falsy = false | null | undefined;\n\nexport function isFalsy(value: unknown): value is Falsy {\n return value === false && value === null && value === undefined;\n}\n\nexport enum PARAM {\n SUFFIX = \"suffix\",\n URL_GEN = \"urlGen\", // \"urlGen\" | \"default\"\n STORE_KEY = \"storekey\",\n STORE = \"store\",\n KEY = \"key\",\n INDEX = \"index\",\n NAME = \"name\",\n VERSION = \"version\",\n RUNTIME = \"runtime\", // \"node\" | \"deno\" | \"browser\"\n FRAG_SIZE = \"fragSize\",\n IV_VERIFY = \"ivVerify\",\n IV_HASH = \"ivHash\",\n FRAG_FID = \"fid\",\n FRAG_OFS = \"ofs\",\n FRAG_LEN = \"len\",\n FRAG_HEAD = \"headerSize\",\n EXTRACTKEY = \"extractKey\",\n // FS = \"fs\",\n}\n\nexport function throwFalsy<T>(value: T | Falsy): T {\n if (isFalsy(value)) {\n throw new Error(\"value is Falsy\");\n }\n return value;\n}\n\nexport function falsyToUndef<T>(value: T | Falsy): T | undefined {\n if (isFalsy(value)) {\n return undefined;\n }\n return value;\n}\n\nexport type StoreType = \"data\" | \"wal\" | \"meta\";\nexport interface FPStats {\n isFile(): boolean;\n isDirectory(): boolean;\n isBlockDevice(): boolean;\n isCharacterDevice(): boolean;\n isSymbolicLink(): boolean;\n isFIFO(): boolean;\n isSocket(): boolean;\n uid: number | Falsy;\n gid: number | Falsy;\n size: number | Falsy;\n atime: Date | Falsy;\n mtime: Date | Falsy;\n ctime: Date | Falsy;\n birthtime: Date | Falsy;\n}\n\nexport interface SysFileSystem {\n start(): Promise<SysFileSystem>;\n mkdir(path: string, options?: { recursive: boolean }): Promise<string | undefined>;\n readdir(path: string /*, options?: unknown*/): Promise<string[]>;\n rm(path: string, options?: { recursive: boolean }): Promise<void>;\n copyFile(source: string, destination: string): Promise<void>;\n readfile(path: string /*, options?: { encoding: BufferEncoding; flag?: string }*/): Promise<Uint8Array>;\n stat(path: string): Promise<FPStats>;\n unlink(path: string): Promise<void>;\n writefile(path: string, data: Uint8Array | string): Promise<void>;\n}\n\nexport interface PathOps {\n join(...args: string[]): string;\n dirname(path: string): string;\n basename(path: string): string;\n}\n\nexport type ToUInt8 = Uint8Array | Result<Uint8Array>;\nexport type PromiseToUInt8 = ToUInt8 | Promise<Uint8Array> | Promise<Result<Uint8Array>>;\n\nexport interface TextEndeCoder {\n encode(input: string): Uint8Array;\n decode(input: ToUInt8): string;\n}\nexport interface SuperThisOpts {\n // readonly crypto?: CryptoRuntime;\n readonly logger: Logger;\n readonly pathOps: PathOps;\n readonly crypto: CryptoRuntime;\n readonly env: EnvFactoryOpts;\n readonly txt: TextEndeCoder;\n readonly ctx: Record<string, unknown>;\n}\n\nexport interface SuperThis {\n readonly logger: Logger;\n readonly loggerCollector?: Logger;\n readonly env: Env;\n readonly pathOps: PathOps;\n readonly ctx: Record<string, unknown>;\n readonly txt: TextEndeCoder;\n timeOrderedNextId(time?: number): { str: string; toString: () => string };\n nextId(bytes?: number): { str: string; bin: Uint8Array; toString: () => string };\n start(): Promise<void>;\n clone(override: Partial<SuperThisOpts>): SuperThis;\n}\n\nexport interface ConfigOpts extends Partial<SuperThisOpts> {\n readonly public?: boolean;\n readonly meta?: DbMeta;\n // readonly persistIndexes?: boolean;\n readonly writeQueue?: Partial<WriteQueueParams>;\n readonly gatewayInterceptor?: SerdeGatewayInterceptor;\n readonly autoCompact?: number;\n readonly storeUrls?: StoreUrlsOpts;\n readonly storeEnDe?: StoreEnDeFile;\n readonly threshold?: number;\n readonly keyBag?: Partial<KeyBagOpts>;\n}\n\nexport type ClockLink = EventLink<Operation>;\n\nexport type ClockHead = ClockLink[];\n\nexport type DocFragment = Uint8Array | string | number | boolean | null | AnyLink | DocFragment[] | object;\n// | { [key: string]: DocFragment };\n\nexport type DocLiteral = string | number | boolean | Uint8Array | unknown;\n\nexport type DocObject = NonNullable<unknown>;\nexport type DocTypes = DocObject;\n\nexport type DocRecord<T extends DocObject> = T;\n\nexport type UnknownDoc = DocRecord<never>;\n\nexport type DocFiles = Record<string, DocFileMeta | File>;\n\nexport interface DocBase {\n readonly _id: string;\n readonly _files?: DocFiles;\n readonly _publicFiles?: DocFiles;\n readonly _deleted?: boolean;\n}\n\nexport type DocWithId<T extends DocTypes> = DocBase & T;\n\nexport type DocSet<T extends DocTypes> = Partial<DocBase> & T;\n\nexport interface DocFileMeta {\n readonly type: string;\n readonly size: number;\n readonly cid: AnyLink;\n readonly car?: AnyLink;\n url?: string;\n file?: () => Promise<File>;\n}\n\nexport interface DocUpdate<T extends DocTypes> {\n readonly id: string;\n readonly value?: DocSet<T>;\n readonly del?: boolean;\n readonly clock?: ClockLink; // would be useful to give ClockLinks a type\n}\n\n// todo merge into above\nexport interface DocValue<T extends DocTypes> {\n readonly doc: DocWithId<T>;\n readonly del: boolean;\n readonly cid: AnyLink;\n}\n\nexport type KeyLiteral = string | number | boolean;\nexport type IndexKeyType = KeyLiteral | KeyLiteral[];\nexport type IndexKey<K extends IndexKeyType> = [K, string];\n\nexport interface IndexUpdate<K extends IndexKeyType> {\n readonly key: IndexKey<K>;\n readonly value?: DocFragment;\n readonly del?: boolean;\n}\n\nexport interface IndexUpdateString {\n readonly key: string;\n readonly value?: DocFragment;\n readonly del?: boolean;\n}\n\n// export interface IndexRowObject<K extends IndexKeyType, T extends DocObject> {\n// readonly id: string;\n// readonly key: K;\n// readonly value: T\n// // readonly row: T // DocFragment;\n// // readonly doc?: DocWithId<T>;\n// // value?: T;\n// // readonly del?: boolean;\n// }\n\n// export interface IndexRowLiteral<K extends IndexKeyType, T extends DocLiteral> {\n// readonly id: string;\n// readonly key: IndexKey<K>;\n// readonly value: T\n// }\n\n// export type IndexRow<K extends IndexKeyType, T extends DocTypes> =\n// T extends DocLiteral ? IndexRowLiteral<K, T> : IndexRowObject<K, T>\n\nexport interface IndexRow<K extends IndexKeyType, T extends DocObject, R extends DocFragment> {\n readonly id: string;\n readonly key: K; // IndexKey<K>;\n readonly value: R;\n readonly doc?: DocWithId<T>;\n}\n\nexport interface IndexRows<K extends IndexKeyType, T extends DocObject, R extends DocFragment = T> {\n readonly rows: IndexRow<K, T, R>[];\n}\nexport interface CRDTMeta {\n readonly head: ClockHead;\n}\n\nexport interface IndexTransactionMeta {\n readonly indexes: Record<string, IdxMeta>;\n}\n\nexport interface FileTransactionMeta {\n readonly files?: AnyLink[];\n}\n\nexport type MetaType = CRDTMeta | IndexTransactionMeta | FileTransactionMeta;\n\nexport interface IdxMeta {\n readonly byId: AnyLink;\n readonly byKey: AnyLink;\n readonly map: string;\n readonly name: string;\n readonly head: ClockHead;\n}\n\nexport interface IdxMetaMap {\n readonly indexes?: Map<string, IdxMeta>;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nexport interface QueryOpts<K extends IndexKeyType> {\n readonly descending?: boolean;\n readonly limit?: number;\n includeDocs?: boolean;\n readonly range?: [IndexKeyType, IndexKeyType];\n readonly key?: DocFragment;\n readonly keys?: DocFragment[];\n prefix?: IndexKeyType;\n}\n\nexport interface AllDocsQueryOpts extends QueryOpts<string> {\n readonly key?: string;\n readonly keys?: string[];\n prefix?: string;\n}\n\nexport interface AllDocsResponse<T extends DocTypes> {\n readonly rows: {\n readonly key: string;\n readonly value: DocWithId<T>;\n }[];\n readonly clock: ClockHead;\n readonly name?: string;\n}\n\ntype EmitFn = (k: IndexKeyType, v?: DocFragment) => void;\nexport type MapFn<T extends DocTypes> = (doc: DocWithId<T>, emit: EmitFn) => DocFragment | unknown;\n\nexport interface ChangesOptions {\n readonly dirty?: boolean;\n readonly limit?: number;\n}\n\nexport interface ChangesResponseRow<T extends DocTypes> {\n readonly key: string;\n readonly value: DocWithId<T>;\n readonly clock?: ClockLink;\n}\n\nexport interface ChangesResponse<T extends DocTypes> {\n readonly clock: ClockHead;\n readonly rows: ChangesResponseRow<T>[];\n readonly name?: string;\n}\n\nexport interface DocResponse {\n readonly id: string;\n readonly clock: ClockHead;\n readonly name?: string;\n}\n\nexport interface BulkResponse {\n readonly ids: string[];\n readonly clock: ClockHead;\n readonly name?: string;\n}\n\nexport type UpdateListenerFn<T extends DocTypes> = (docs: DocWithId<T>[]) => Promise<void> | void;\nexport type NoUpdateListenerFn = () => Promise<void> | void;\nexport type ListenerFn<T extends DocTypes> = UpdateListenerFn<T> | NoUpdateListenerFn;\n\nexport interface CRDTEntry {\n readonly data: string;\n readonly parents: string[];\n readonly cid: string;\n}\n\nexport type VoidFn = () => void;\nexport type UnReg = () => void;\nexport interface CRDTClock {\n readonly head: ClockHead;\n onTock(fn: VoidFn): UnReg;\n onTick(fn: (updates: DocUpdate<DocTypes>[]) => void): UnReg;\n applyHead(newHead: ClockHead, prevHead: ClockHead, updates?: DocUpdate<DocTypes>[]): Promise<void>;\n onZoom(fn: VoidFn): UnReg;\n close(): Promise<void>;\n ready(): Promise<void>;\n}\n\nexport interface CarTransaction {\n readonly parent: BaseBlockstore;\n get<T, C extends number, A extends number, V extends Version>(cid: AnyLink): Promise<Block<T, C, A, V> | undefined>;\n\n superGet(cid: AnyLink): Promise<AnyBlock | undefined>;\n\n putSync(cid: UnknownLink, bytes: Uint8Array<ArrayBufferLike>): void;\n\n put(cid: UnknownLink, bytes: Uint8Array<ArrayBufferLike>): Promise<void>;\n\n entries(): AsyncIterableIterator<AnyBlock>;\n}\n\nexport interface BaseBlockstore {\n readonly transactions: Set<CarTransaction>;\n readonly sthis: SuperThis;\n readonly loader: Loadable;\n readonly ebOpts: BlockstoreRuntime;\n ready(): Promise<void>;\n close(): Promise<void>;\n destroy(): Promise<void>;\n compact(): Promise<void>;\n readonly logger: Logger;\n\n get<T, C extends number, A extends number, V extends Version>(cid: AnyLink): Promise<Block<T, C, A, V> | undefined>;\n put(cid: UnknownLink, bytes: Uint8Array<ArrayBufferLike>): Promise<void>;\n\n transaction<M extends TransactionMeta>(\n fn: (t: CarTransaction) => Promise<M>,\n _opts?: CarTransactionOpts,\n ): Promise<TransactionWrapper<M>>;\n\n // get<T, C extends number, A extends number, V extends Version>(cid: AnyAnyLink): Promise<Block<T, C, A, V> | undefined>\n // transaction<M extends TransactionMeta>(\n // fn: (t: CarTransaction) => Promise<M>,\n // _opts?: CarTransactionOpts,\n // ): Promise<TransactionWrapper<M>>\n\n openTransaction(opts: CarTransactionOpts /* = { add: true, noLoader: false }*/): CarTransaction;\n\n commitTransaction<M extends TransactionMeta>(\n t: CarTransaction,\n done: M,\n opts: CarTransactionOpts,\n ): Promise<TransactionWrapper<M>>;\n entries(): AsyncIterableIterator<AnyBlock>;\n}\n\nexport interface CRDT extends ReadyCloseDestroy, HasLogger, HasSuperThis, HasCRDT {\n readonly logger: Logger;\n readonly sthis: SuperThis;\n // self reference to fullfill HasCRDT\n readonly crdt: CRDT;\n readonly clock: CRDTClock;\n\n readonly blockstore: BaseBlockstore;\n readonly indexBlockstore: BaseBlockstore;\n readonly indexers: Map<string, Index<IndexKeyType, DocTypes>>;\n\n bulk<T extends DocTypes>(updates: DocUpdate<T>[]): Promise<CRDTMeta>;\n ready(): Promise<void>;\n close(): Promise<void>;\n destroy(): Promise<void>;\n allDocs<T extends DocTypes>(): Promise<{ result: DocUpdate<T>[]; head: ClockHead }>;\n vis(): Promise<string>;\n getBlock(cidString: string): Promise<Block>;\n get(key: string): Promise<DocValue<DocTypes> | Falsy>;\n // defaults by impl\n changes<T extends DocTypes>(\n since?: ClockHead,\n opts?: ChangesOptions,\n ): Promise<{\n result: DocUpdate<T>[];\n head: ClockHead;\n }>;\n compact(): Promise<void>;\n}\n\nexport interface HasCRDT {\n readonly crdt: CRDT;\n}\n\nexport interface RefLedger {\n readonly ledger: Ledger;\n}\n\nexport interface HasLogger {\n readonly logger: Logger;\n}\n\nexport interface HasSuperThis {\n readonly sthis: SuperThis;\n}\n\nexport interface ReadyCloseDestroy {\n close(): Promise<void>;\n destroy(): Promise<void>;\n ready(): Promise<void>;\n}\n\nexport interface Database extends ReadyCloseDestroy, HasLogger, HasSuperThis {\n // readonly name: string;\n readonly ledger: Ledger;\n readonly logger: Logger;\n readonly sthis: SuperThis;\n readonly id: string;\n readonly name: string;\n\n onClosed(fn: () => void): void;\n\n get<T extends DocTypes>(id: string): Promise<DocWithId<T>>;\n put<T extends DocTypes>(doc: DocSet<T>): Promise<DocResponse>;\n bulk<T extends DocTypes>(docs: DocSet<T>[]): Promise<BulkResponse>;\n del(id: string): Promise<DocResponse>;\n changes<T extends DocTypes>(since?: ClockHead, opts?: ChangesOptions): Promise<ChangesResponse<T>>;\n allDocs<T extends DocTypes>(opts?: AllDocsQueryOpts): Promise<AllDocsResponse<T>>;\n allDocuments<T extends DocTypes>(): Promise<{\n rows: {\n key: string;\n value: DocWithId<T>;\n }[];\n clock: ClockHead;\n }>;\n subscribe<T extends DocTypes>(listener: ListenerFn<T>, updates?: boolean): () => void;\n\n query<K extends IndexKeyType, T extends DocTypes, R extends DocFragment = T>(\n field: string | MapFn<T>,\n opts?: QueryOpts<K>,\n ): Promise<IndexRows<K, T, R>>;\n compact(): Promise<void>;\n}\n\nexport interface WriteQueue<T extends DocUpdate<S>, S extends DocTypes = DocTypes> {\n push(task: T): Promise<MetaType>;\n bulk(tasks: T[]): Promise<MetaType>;\n close(): Promise<void>;\n}\n\nexport interface Ledger extends HasCRDT {\n // readonly name: string;\n readonly writeQueue: WriteQueue<DocUpdate<DocTypes>>;\n\n readonly logger: Logger;\n readonly sthis: SuperThis;\n readonly id: string;\n\n readonly name: string;\n\n onClosed(fn: () => void): () => void;\n\n close(): Promise<void>;\n destroy(): Promise<void>;\n ready(): Promise<void>;\n\n subscribe<T extends DocTypes>(listener: ListenerFn<T>, updates?: boolean): () => void;\n\n // asDB(): Database;\n\n // get<T extends DocTypes>(id: string): Promise<DocWithId<T>>;\n // put<T extends DocTypes>(doc: DocSet<T>): Promise<DocResponse>;\n // bulk<T extends DocTypes>(docs: DocSet<T>[]): Promise<BulkResponse>;\n // del(id: string): Promise<DocResponse>;\n // changes<T extends DocTypes>(since?: ClockHead, opts?: ChangesOptions): Promise<ChangesResponse<T>>;\n // allDocs<T extends DocTypes>(opts?: AllDocsQueryOpts): Promise<AllDocsResponse<T>>;\n // allDocuments<T extends DocTypes>(): Promise<{\n // rows: {\n // key: string;\n // value: DocWithId<T>;\n // }[];\n // clock: ClockHead;\n // }>;\n // subscribe<T extends DocTypes>(listener: ListenerFn<T>, updates?: boolean): () => void;\n\n // query<K extends IndexKeyType, T extends DocTypes, R extends DocFragment = T>(\n // field: string | MapFn<T>,\n // opts?: QueryOpts<K>,\n // ): Promise<IndexRows<K, T, R>>;\n // compact(): Promise<void>;\n}\n","import { ensureLogger } from \"./utils.js\";\nimport { DocTypes, MetaType, DocUpdate, SuperThis, WriteQueue } from \"./types.js\";\nimport { Future, Logger } from \"@adviser/cement\";\n\ntype WorkerFunction<T extends DocTypes> = (tasks: DocUpdate<T>[]) => Promise<MetaType>;\n\ninterface WriteQueueItem<T extends DocTypes> {\n // readonly task?: DocUpdate<T>;\n readonly tasks?: DocUpdate<T>[];\n resolve(result: MetaType): void;\n reject(error: Error): void;\n}\n\nexport interface WriteQueueParams {\n // default 32\n // if chunkSize is 1 the result will be ordered in time\n readonly chunkSize: number;\n}\n\nexport function defaultWriteQueueOpts(opts: Partial<WriteQueueParams> = {}): WriteQueueParams {\n return {\n ...opts,\n chunkSize: opts.chunkSize && opts.chunkSize > 0 ? opts.chunkSize : 32,\n };\n}\n\nclass WriteQueueImpl<T extends DocUpdate<T>> implements WriteQueue<T> {\n private readonly opts: WriteQueueParams;\n\n private readonly queue: WriteQueueItem<T>[] = [];\n private readonly worker: WorkerFunction<T>;\n private isProcessing = false;\n private readonly logger: Logger;\n\n constructor(sthis: SuperThis, worker: WorkerFunction<T>, opts: WriteQueueParams) {\n this.logger = ensureLogger(sthis, \"WriteQueueImpl\");\n this.worker = worker;\n this.opts = defaultWriteQueueOpts(opts);\n }\n\n private waitForEmptyQueue?: Future<void>;\n private testEmptyQueue() {\n if (this.waitForEmptyQueue && this.queue.length === 0) {\n this.waitForEmptyQueue.resolve();\n }\n }\n\n private async process() {\n if (this.isProcessing || this.queue.length === 0) {\n this.testEmptyQueue();\n return;\n }\n this.isProcessing = true;\n try {\n this.logger.Debug().Any(\"opts\", this.opts).Len(this.queue).Msg(\"Processing tasks\");\n const tasksToProcess = this.queue.splice(0, this.opts.chunkSize);\n const updates = tasksToProcess.map((item) => item.tasks).filter((item) => item) as DocUpdate<T>[][];\n const promises = updates.map(async (update, index) => {\n try {\n const result = await this.worker(update);\n tasksToProcess[index].resolve(result);\n } catch (error) {\n tasksToProcess[index].reject(this.logger.Error().Err(error).Msg(\"Error processing task\").AsError());\n }\n });\n await Promise.allSettled(promises);\n this.logger.Debug().Any(\"opts\", this.opts).Len(this.queue).Msg(\"Processed tasks\");\n } catch (error) {\n this.logger.Error().Err(error).Msg(\"Error processing tasks\");\n } finally {\n this.isProcessing = false;\n setTimeout(() => this.process(), 0);\n }\n }\n\n bulk(tasks: DocUpdate<T>[]): Promise<MetaType> {\n return new Promise<MetaType>((resolve, reject) => {\n this.queue.push({ tasks, resolve, reject });\n this.process();\n });\n }\n push(task: DocUpdate<T>): Promise<MetaType> {\n return this.bulk([task]);\n }\n close(): Promise<void> {\n this.waitForEmptyQueue = new Future();\n this.testEmptyQueue();\n return this.waitForEmptyQueue.asPromise();\n }\n}\n\nexport function writeQueue<T extends DocUpdate<T>>(\n sthis: SuperThis,\n worker: WorkerFunction<T>,\n opts: WriteQueueParams,\n): WriteQueue<T> {\n return new WriteQueueImpl<T>(sthis, worker, opts);\n}\n","import * as UnixFS from \"@ipld/unixfs\";\nimport * as raw from \"multiformats/codecs/raw\";\nimport { withMaxChunkSize } from \"@ipld/unixfs/file/chunker/fixed\";\nimport { withWidth } from \"@ipld/unixfs/file/layout/balanced\";\n\nimport type { View } from \"@ipld/unixfs\";\nimport { DocFileMeta } from \"../types.js\";\n\nimport { exporter, ReadableStorage } from \"@fireproof/vendor/ipfs-unixfs-exporter\";\nimport { BlobLike, AnyLink, AnyBlock } from \"../blockstore/index.js\";\n\nconst queuingStrategy = UnixFS.withCapacity();\n\nconst settings = UnixFS.configure({\n fileChunkEncoder: raw,\n smallFileEncoder: raw,\n chunker: withMaxChunkSize(1024 * 1024),\n fileLayout: withWidth(1024),\n});\n\nasync function collect<T>(collectable: ReadableStream<T>): Promise<T[]> {\n const chunks: T[] = [];\n await collectable.pipeTo(\n new WritableStream({\n write(chunk) {\n chunks.push(chunk);\n },\n }),\n );\n return chunks;\n}\n\nexport async function encodeFile(blob: BlobLike): Promise<{ cid: AnyLink; blocks: AnyBlock[] }> {\n const readable = createFileEncoderStream(blob);\n const blocks = await collect(readable);\n return { cid: blocks.at(-1).cid, blocks };\n}\n\nexport async function decodeFile(blocks: unknown, cid: AnyLink, meta: DocFileMeta): Promise<File> {\n const entry = await exporter(cid.toString(), blocks as ReadableStorage, { length: meta.size });\n const chunks = [];\n for await (const chunk of entry.content()) {\n chunks.push(chunk);\n }\n return new File(chunks, entry.name, { type: meta.type, lastModified: 0 });\n}\n\nfunction createFileEncoderStream(blob: BlobLike) {\n const { readable, writable } = new TransformStream({}, queuingStrategy);\n const unixfsWriter = UnixFS.createWriter({ writable, settings });\n const fileBuilder = new UnixFSFileBuilder(\"\", blob);\n void (async () => {\n await fileBuilder.finalize(unixfsWriter);\n await unixfsWriter.close();\n })();\n return readable;\n}\n\nclass UnixFSFileBuilder {\n #file;\n readonly name: string;\n constructor(name: string, file: BlobLike) {\n this.name = name;\n this.#file = file;\n }\n\n async finalize(writer: View) {\n const unixfsFileWriter = UnixFS.createFileWriter(writer);\n await this.#file.stream().pipeTo(\n new WritableStream({\n async write(chunk) {\n await unixfsFileWriter.write(chunk as Uint8Array);\n },\n }),\n );\n return await unixfsFileWriter.close();\n }\n}\n","import {\n CoerceURI,\n CryptoRuntime,\n KeyedResolvOnce,\n Logger,\n ResolveOnce,\n ResolveSeq,\n Result,\n runtimeFn,\n toCryptoRuntime,\n URI,\n} from \"@adviser/cement\";\nimport { KeyWithFingerExtract, KeyWithFingerPrint } from \"../blockstore/types.js\";\nimport { ensureLogger } from \"../utils.js\";\nimport { base58btc } from \"multiformats/bases/base58\";\nimport { PARAM, SuperThis } from \"../types.js\";\nimport { KeyBagProviderFile } from \"./gateways/file/key-bag-file.js\";\nimport { KeyBagProviderMemory } from \"./key-bag-memory.js\";\n\nexport class KeyBag {\n readonly logger: Logger;\n constructor(readonly rt: KeyBagRuntime) {\n this.logger = ensureLogger(rt.sthis, \"KeyBag\", {\n // id: rt.id(),\n });\n this.logger.Debug().Msg(\"KeyBag created\");\n }\n\n readonly _warnOnce: ResolveOnce<void> = new ResolveOnce<void>();\n async subtleKey(key: string): Promise<CryptoKey> {\n const extractable = this.rt.url.getParam(PARAM.EXTRACTKEY) === \"_deprecated_internal_api\";\n if (extractable) {\n this._warnOnce.once(() =>\n this.logger.Warn().Msg(\"extractKey is enabled via _deprecated_internal_api --- handle keys safely!!!\"),\n );\n }\n return await this.rt.crypto.importKey(\n \"raw\", // raw or jwk\n base58btc.decode(key),\n // hexStringToUint8Array(key), // raw data\n \"AES-GCM\",\n extractable,\n [\"encrypt\", \"decrypt\"],\n );\n }\n\n async ensureKeyFromUrl(url: URI, keyFactory: () => string): Promise<Result<URI>> {\n // add storekey to url\n const storeKey = url.getParam(PARAM.STORE_KEY);\n if (storeKey === \"insecure\") {\n return Result.Ok(url);\n }\n if (!storeKey) {\n const keyName = `@${keyFactory()}@`;\n const ret = await this.getNamedKey(keyName);\n if (ret.isErr()) {\n return ret as unknown as Result<URI>;\n }\n const urb = url.build().setParam(PARAM.STORE_KEY, keyName);\n return Result.Ok(urb.URI());\n }\n if (storeKey.startsWith(\"@\") && storeKey.endsWith(\"@\")) {\n const ret = await this.getNamedKey(storeKey);\n if (ret.isErr()) {\n return ret as unknown as Result<URI>;\n }\n }\n return Result.Ok(url);\n }\n\n async toKeyWithFingerPrint(keyStr: string): Promise<Result<KeyWithFingerPrint>> {\n const material = base58btc.decode(keyStr); //\n const key = await this.subtleKey(keyStr);\n const fpr = await this.rt.crypto.digestSHA256(material);\n return Result.Ok({\n key,\n fingerPrint: base58btc.encode(new Uint8Array(fpr)),\n });\n }\n\n readonly _seq: ResolveSeq<Result<KeyWithFingerPrint>> = new ResolveSeq<Result<KeyWithFingerPrint>>();\n async setNamedKey(name: string, key: string): Promise<Result<KeyWithFingerPrint>> {\n return this._seq.add(() => this._setNamedKey(name, key));\n }\n\n // avoid deadlock\n async _setNamedKey(name: string, key: string): Promise<Result<KeyWithFingerPrint>> {\n const item = {\n name,\n key: key,\n };\n const bag = await this.rt.getBag();\n this.logger.Debug().Str(\"name\", name).Msg(\"setNamedKey\");\n // there should be a version that throws if key exists\n await bag.set(name, item);\n return await this.toKeyWithFingerPrint(item.key);\n }\n\n async getNamedExtractableKey(name: string, failIfNotFound = false): Promise<Result<KeyWithFingerExtract>> {\n const ret = await this.getNamedKey(name, failIfNotFound);\n if (ret.isErr()) {\n return ret as unknown as Result<KeyWithFingerExtract>;\n }\n const named = ret.Ok();\n return Result.Ok({\n ...named,\n extract: async () => {\n const ext = new Uint8Array((await this.rt.crypto.exportKey(\"raw\", named.key)) as ArrayBuffer);\n return {\n key: ext,\n keyStr: base58btc.encode(ext),\n };\n },\n });\n }\n\n async getNamedKey(name: string, failIfNotFound = false): Promise<Result<KeyWithFingerPrint>> {\n const id = this.rt.sthis.nextId(4).str;\n return this._seq.add(async () => {\n const bag = await this.rt.getBag();\n const named = await bag.get(name);\n if (named) {\n const fpr = await this.toKeyWithFingerPrint(named.key);\n this.logger.Debug().Str(\"id\", id).Str(\"name\", name).Result(\"fpr\", fpr).Msg(\"fingerPrint getNamedKey\");\n return fpr;\n }\n if (failIfNotFound) {\n this.logger.Debug().Str(\"id\", id).Str(\"name\", name).Msg(\"failIfNotFound getNamedKey\");\n return Result.Err(new Error(`Key not found: ${name}`));\n }\n // this.logger.Debug().Str(\"id\", id).Str(\"name\", name).Msg(\"createKey getNamedKey-pre\");\n const ret = await this._setNamedKey(name, base58btc.encode(this.rt.crypto.randomBytes(this.rt.keyLength)));\n this.logger.Debug().Str(\"id\", id).Str(\"name\", name).Result(\"fpr\", ret).Msg(\"createKey getNamedKey-post\");\n return ret;\n });\n }\n}\n\nexport interface KeyItem {\n readonly name: string;\n readonly key: string;\n}\nexport type KeyBagFile = Record<string, KeyItem>;\n\nexport interface KeyBagOpts {\n // in future you can encrypt the keybag with ?masterkey=xxxxx\n readonly url: CoerceURI;\n // readonly key: string; // key to encrypt the keybag\n readonly crypto: CryptoRuntime;\n readonly keyLength: number; // default: 16\n // readonly logger: Logger;\n readonly keyRuntime: KeyBagRuntime;\n}\n\nexport interface KeyBagProvider {\n get(id: string): Promise<KeyItem | undefined>;\n set(id: string, item: KeyItem): Promise<void>;\n}\nexport interface KeyBagRuntime {\n readonly url: URI;\n readonly crypto: CryptoRuntime;\n readonly logger: Logger;\n readonly sthis: SuperThis;\n readonly keyLength: number;\n // readonly key?: FPCryptoKey;\n getBag(): Promise<KeyBagProvider>;\n id(): string;\n}\n\nexport type KeyBackProviderFactory = (url: URI, sthis: SuperThis) => Promise<KeyBagProvider>;\n\nexport interface KeyBagProviderFactoryItem {\n readonly protocol: string;\n // if this is set the default protocol selection is overridden\n readonly override?: boolean;\n readonly factory: KeyBackProviderFactory;\n}\n\nconst keyBagProviderFactories = new Map<string, KeyBagProviderFactoryItem>(\n [\n {\n protocol: \"file:\",\n factory: async (url: URI, sthis: SuperThis) => {\n return new KeyBagProviderFile(url, sthis);\n },\n },\n {\n protocol: \"indexdb:\",\n factory: async (url: URI, sthis: SuperThis) => {\n const { KeyBagProviderImpl } = await import(\"@fireproof/core/web\");\n return new KeyBagProviderImpl(url, sthis);\n },\n },\n {\n protocol: \"memory:\",\n factory: async (url: URI, sthis: SuperThis) => {\n return new KeyBagProviderMemory(url, sthis);\n },\n },\n ].map((i) => [i.protocol, i]),\n);\n\nexport function registerKeyBagProviderFactory(item: KeyBagProviderFactoryItem) {\n const protocol = item.protocol.endsWith(\":\") ? item.protocol : item.protocol + \":\";\n keyBagProviderFactories.set(protocol, {\n ...item,\n protocol,\n });\n}\n\nexport function defaultKeyBagUrl(sthis: SuperThis): URI {\n let bagFnameOrUrl = sthis.env.get(\"FP_KEYBAG_URL\");\n let url: URI;\n if (runtimeFn().isBrowser) {\n url = URI.from(bagFnameOrUrl || \"indexdb://fp-keybag\");\n } else {\n if (!bagFnameOrUrl) {\n const home = sthis.env.get(\"HOME\");\n bagFnameOrUrl = `${home}/.fireproof/keybag`;\n url = URI.from(`file://${bagFnameOrUrl}`);\n } else {\n url = URI.from(bagFnameOrUrl);\n }\n }\n const logger = ensureLogger(sthis, \"defaultKeyBagUrl\");\n logger.Debug().Url(url).Msg(\"from env\");\n return url;\n}\n\nexport function defaultKeyBagOpts(sthis: SuperThis, kbo?: Partial<KeyBagOpts>): KeyBagRuntime {\n kbo = kbo || {};\n if (kbo.keyRuntime) {\n return kbo.keyRuntime;\n }\n const logger = ensureLogger(sthis, \"KeyBag\");\n let url: URI;\n if (kbo.url) {\n url = URI.from(kbo.url);\n logger.Debug().Url(url).Msg(\"from opts\");\n } else {\n let bagFnameOrUrl = sthis.env.get(\"FP_KEYBAG_URL\");\n if (runtimeFn().isBrowser) {\n url = URI.from(bagFnameOrUrl || \"indexdb://fp-keybag\");\n } else {\n if (!bagFnameOrUrl) {\n const home = sthis.env.get(\"HOME\");\n bagFnameOrUrl = `${home}/.fireproof/keybag`;\n url = URI.from(`file://${bagFnameOrUrl}`);\n } else {\n url = URI.from(bagFnameOrUrl);\n }\n }\n logger.Debug().Url(url).Msg(\"from env\");\n }\n const kitem = keyBagProviderFactories.get(url.protocol);\n if (!kitem) {\n throw logger.Error().Url(url).Msg(\"unsupported protocol\").AsError();\n }\n\n if (url.hasParam(\"masterkey\")) {\n throw logger.Error().Url(url).Msg(\"masterkey is not supported\").AsError();\n }\n\n return {\n url,\n crypto: kbo.crypto || toCryptoRuntime({}),\n sthis,\n logger,\n keyLength: kbo.keyLength || 16,\n getBag: () => kitem.factory(url, sthis),\n id: () => {\n return url.toString();\n },\n };\n}\n\nconst _keyBags = new KeyedResolvOnce<KeyBag>();\nexport async function getKeyBag(sthis: SuperThis, kbo: Partial<KeyBagOpts> = {}): Promise<KeyBag> {\n await sthis.start();\n const rt = defaultKeyBagOpts(sthis, kbo);\n return _keyBags.get(rt.id()).once(async () => new KeyBag(rt));\n}\n","import { runtimeFn, URI } from \"@adviser/cement\";\nimport type { SysFileSystem } from \"../../../types.js\";\n\nexport function sysFileSystemFactory(uri: URI): Promise<SysFileSystem> {\n const rt = runtimeFn();\n switch (true) {\n case rt.isNodeIsh:\n return import(\"@fireproof/core/node\").then((m) => m.getSysFileSystem(uri));\n case rt.isDeno:\n return import(\"@fireproof/core/deno\").then((m) => m.getSysFileSystem(uri));\n default:\n throw new Error(`unsupported runtime:${rt}`);\n }\n}\n","import { Logger, URI } from \"@adviser/cement\";\nimport { SuperThis, SysFileSystem } from \"../../../types.js\";\nimport { KeyBagProvider, KeyItem } from \"../../key-bag.js\";\nimport { isNotFoundError } from \"../../../utils.js\";\nimport { sysFileSystemFactory } from \"./sys-file-system-factory.js\";\n\ninterface KeyBagCtx {\n readonly dirName: string;\n readonly sysFS: SysFileSystem;\n readonly fName: string;\n}\n\nexport class KeyBagProviderFile implements KeyBagProvider {\n async _prepare(id: string): Promise<KeyBagCtx> {\n await this.sthis.start();\n const sysFS = await sysFileSystemFactory(this.url);\n const dirName = this.url.pathname;\n await sysFS.mkdir(dirName, { recursive: true });\n return {\n dirName,\n sysFS,\n fName: this.sthis.pathOps.join(dirName, `${id.replace(/[^a-zA-Z0-9]/g, \"_\")}.json`),\n };\n }\n\n private readonly url: URI;\n readonly logger: Logger;\n readonly sthis: SuperThis;\n constructor(url: URI, sthis: SuperThis) {\n this.url = url;\n this.sthis = sthis;\n this.logger = sthis.logger;\n }\n\n async get(id: string): Promise<KeyItem | undefined> {\n const ctx = await this._prepare(id);\n try {\n const p = await ctx.sysFS.readfile(ctx.fName);\n const ki = JSON.parse(this.sthis.txt.decode(p)) as KeyItem;\n return ki;\n } catch (e) {\n if (isNotFoundError(e)) {\n return undefined;\n }\n throw this.logger.Error().Err(e).Str(\"file\", ctx.dirName).Msg(\"read bag failed\").AsError();\n }\n }\n\n async set(id: string, item: KeyItem): Promise<void> {\n const ctx = await this._prepare(id);\n const p = this.sthis.txt.encode(JSON.stringify(item, null, 2));\n await ctx.sysFS.writefile(ctx.fName, p);\n }\n}\n","import { URI } from \"@adviser/cement\";\nimport { KeyBagProvider, KeyItem } from \"./key-bag.js\";\nimport { SuperThis } from \"../types.js\";\n\nconst memoryKeyBag = new Map<string, Uint8Array>();\n\nexport class KeyBagProviderMemory implements KeyBagProvider {\n private readonly url: URI;\n readonly sthis: SuperThis;\n constructor(url: URI, sthis: SuperThis) {\n this.url = url;\n this.sthis = sthis;\n }\n key(id: string): string {\n return `${this.url.pathname}/${id}`;\n }\n\n async get(id: string): Promise<KeyItem | undefined> {\n const binKeyItem = memoryKeyBag.get(this.key(id));\n if (binKeyItem) {\n const ki = JSON.parse(this.sthis.txt.decode(binKeyItem)) as KeyItem;\n return ki;\n }\n return undefined;\n }\n\n async set(id: string, item: KeyItem): Promise<void> {\n const p = this.sthis.txt.encode(JSON.stringify(item, null, 2));\n memoryKeyBag.set(this.key(id), p);\n }\n}\n","import { BuildURI, runtimeFn, URI } from \"@adviser/cement\";\nimport { PARAM, SuperThis } from \"../types.js\";\nimport type { SerdeGateway } from \"./serde-gateway.js\";\nimport { FILESTORE_VERSION } from \"../runtime/gateways/file/version.js\";\nimport { INDEXDB_VERSION } from \"../runtime/gateways/indexdb/version.js\";\nimport type { Gateway } from \"./gateway.js\";\n\nimport { FileGateway } from \"../runtime/gateways/file/gateway-impl.js\";\nimport { MemoryGateway } from \"../runtime/gateways/memory/gateway.js\";\nimport { sysFileSystemFactory } from \"../runtime/gateways/file/sys-file-system-factory.js\";\nimport { DefSerdeGateway } from \"../runtime/gateways/def-serde-gateway.js\";\n\nexport interface SerdeGatewayFactoryItem {\n readonly protocol: string;\n // readonly overrideBaseURL?: string; // if this set it overrides the defaultURL\n // readonly overrideRegistration?: boolean; // if this is set, it will override the registration\n readonly isDefault?: boolean;\n\n defaultURI(sthis: SuperThis): URI;\n\n serdegateway(sthis: SuperThis): Promise<SerdeGateway>;\n\n // readonly gateway?: (sthis: SuperThis) => Promise<SerdeGateway>;\n // readonly test: (sthis: SuperThis, gfi: GatewayFactoryItem) => Promise<TestGateway>;\n // which switches between file and indexdb\n // readonly data: (logger: Logger) => Promise<Gateway>;\n // readonly meta: (logger: Logger) => Promise<Gateway>;\n // readonly wal: (logger: Logger) => Promise<Gateway>;\n // readonly test: (logger: Logger) => Promise<TestStore>;\n}\n\nconst storeFactory = new Map<string, SerdeGatewayFactoryItem>();\n\nexport function getDefaultURI(sthis: SuperThis, protocol?: string): URI {\n if (protocol) {\n if (!protocol.endsWith(\":\")) {\n protocol += \":\";\n }\n const gfi = storeFactory.get(protocol);\n if (gfi) {\n return gfi.defaultURI(sthis);\n }\n }\n const found = Array.from(storeFactory.values()).find((item) => item.isDefault);\n if (!found) {\n throw sthis.logger.Error().Msg(\"no default found\").AsError();\n }\n return found.defaultURI(sthis);\n}\n\nexport interface SerdeOrGatewayFactoryItem {\n readonly protocol: string;\n readonly isDefault?: boolean;\n\n readonly defaultURI: (sthis: SuperThis) => URI;\n\n readonly serdegateway?: (sthis: SuperThis) => Promise<SerdeGateway>;\n readonly gateway?: (sthis: SuperThis) => Promise<Gateway>;\n}\n\nexport function registerStoreProtocol(item: SerdeOrGatewayFactoryItem): () => void {\n let protocol = item.protocol;\n if (!protocol.endsWith(\":\")) {\n protocol += \":\";\n }\n if (!item.serdegateway && !item.gateway) {\n throw new Error(`registerStoreProtocol needs a gateway or serdegateway`);\n }\n let serdegateway: (sthis: SuperThis) => Promise<SerdeGateway>;\n if (item.gateway) {\n serdegateway = async (sthis) => {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const m = await item.gateway!(sthis);\n // console.log(\"Gateway Plug in DefSerdeGateway\", m);\n return new DefSerdeGateway(m);\n };\n } else {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n serdegateway = item.serdegateway!;\n }\n if (item.isDefault) {\n Array.from(storeFactory.values()).forEach((items) => {\n (items as { isDefault: boolean }).isDefault = false;\n });\n }\n storeFactory.set(protocol, {\n ...item,\n serdegateway,\n });\n return () => {\n storeFactory.delete(protocol);\n };\n}\n\nexport function getGatewayFactoryItem(protocol: string): SerdeGatewayFactoryItem | undefined {\n return storeFactory.get(protocol);\n}\n\nexport function defaultGatewayFactoryItem(): SerdeGatewayFactoryItem {\n const found = Array.from(storeFactory.values()).find((item) => item.isDefault);\n if (!found) {\n throw new Error(\"no default found\");\n }\n return found;\n}\n\nfunction defaultURI(sthis: SuperThis) {\n const rt = runtimeFn();\n return (\n BuildURI.from(\"file://\")\n // .pathname(`${sthis.env.get(\"HOME\")}/.fireproof/${FILESTORE_VERSION.replace(/-.*$/, \"\")}`)\n .pathname(`${sthis.env.get(\"HOME\")}/.fireproof/${FILESTORE_VERSION.replace(/-.*$/, \"\")}`)\n .setParam(PARAM.VERSION, FILESTORE_VERSION)\n .setParam(PARAM.URL_GEN, \"default\")\n .setParam(PARAM.RUNTIME, rt.isNodeIsh ? \"node\" : rt.isDeno ? \"deno\" : \"unknown\")\n .URI()\n );\n}\n\nif (runtimeFn().isNodeIsh || runtimeFn().isDeno) {\n registerStoreProtocol({\n protocol: \"file:\",\n isDefault: true,\n defaultURI,\n gateway: async (sthis) => {\n return new FileGateway(sthis, await sysFileSystemFactory(defaultURI(sthis)));\n },\n });\n}\n\nif (runtimeFn().isBrowser) {\n registerStoreProtocol({\n protocol: \"indexdb:\",\n isDefault: true,\n defaultURI: () => {\n return BuildURI.from(\"indexdb://\")\n .pathname(\"fp\")\n .setParam(PARAM.VERSION, INDEXDB_VERSION)\n .setParam(PARAM.RUNTIME, \"browser\")\n .URI();\n },\n gateway: async () => {\n const { GatewayImpl } = await import(\"@fireproof/core/web\");\n return new GatewayImpl();\n },\n });\n}\n\nconst memory = new Map<string, Uint8Array>();\nregisterStoreProtocol({\n protocol: \"memory:\",\n isDefault: false,\n defaultURI: () => {\n return BuildURI.from(\"memory://\").pathname(\"ram\").URI();\n },\n gateway: async (sthis) => {\n return new MemoryGateway(sthis, memory);\n },\n});\n","export const FILESTORE_VERSION = \"v0.19-file\";\n","export const INDEXDB_VERSION = \"v0.19-indexdb\";\n","import { FILESTORE_VERSION } from \"./version.js\";\nimport { exception2Result, KeyedResolvOnce, Result, URI } from \"@adviser/cement\";\nimport { getFileName, getPath } from \"./utils.js\";\nimport { PARAM, SuperThis, SysFileSystem } from \"../../../types.js\";\nimport { exceptionWrapper, isNotFoundError, NotFoundError } from \"../../../utils.js\";\nimport type { Gateway, GetResult } from \"../../../blockstore/gateway.js\";\n\nconst versionFiles = new KeyedResolvOnce<string>();\n\nexport class FileGateway implements Gateway {\n // abstract readonly storeType: StoreType;\n readonly fs: SysFileSystem;\n\n constructor(sthis: SuperThis, fs: SysFileSystem) {\n this.fs = fs;\n }\n\n async getVersionFromFile(path: string, sthis: SuperThis): Promise<string> {\n return versionFiles.get(path).once(async () => {\n await this.fs.mkdir(path, { recursive: true });\n const vFile = sthis.pathOps.join(path, \"version\");\n const vFileStat = await this.fs.stat(vFile).catch(() => undefined);\n if (!vFileStat) {\n await this.fs.writefile(sthis.pathOps.join(path, \"version\"), FILESTORE_VERSION);\n return FILESTORE_VERSION;\n } else if (!vFileStat.isFile()) {\n throw sthis.logger.Error().Str(\"file\", vFile).Msg(`version file is a directory`).AsError();\n }\n const v = await this.fs.readfile(vFile);\n const vStr = sthis.txt.decode(v);\n if (vStr !== FILESTORE_VERSION) {\n sthis.logger.Warn().Str(\"file\", vFile).Str(\"from\", vStr).Str(\"expected\", FILESTORE_VERSION).Msg(`version mismatch`);\n }\n return vStr;\n });\n }\n\n start(baseURL: URI, sthis: SuperThis): Promise<Result<URI>> {\n return exception2Result(async () => {\n await this.fs.start();\n const url = baseURL.build();\n url.defParam(PARAM.VERSION, FILESTORE_VERSION);\n // url.defParam(\"store\", this.storeType);\n const dbUrl = await this.buildUrl(url.URI(), \"dummy\");\n const dbdirFile = this.getFilePath(dbUrl.Ok(), sthis);\n await this.fs.mkdir(sthis.pathOps.dirname(dbdirFile), { recursive: true });\n const dbroot = sthis.pathOps.dirname(dbdirFile);\n sthis.logger.Debug().Url(url.URI()).Str(\"dbroot\", dbroot).Msg(\"start\");\n url.setParam(PARAM.VERSION, await this.getVersionFromFile(dbroot, sthis));\n return url.URI();\n });\n }\n\n async buildUrl(baseUrl: URI, key: string): Promise<Result<URI>> {\n return Result.Ok(baseUrl.build().setParam(PARAM.KEY, key).URI());\n }\n\n async close(): Promise<Result<void>> {\n return Result.Ok(undefined);\n }\n\n getFilePath(url: URI, sthis: SuperThis): string {\n const key = url.getParam(PARAM.KEY);\n if (!key) throw sthis.logger.Error().Url(url).Msg(`key not found`).AsError();\n // const urlGen = url.getParam(PARAM.URL_GEN);\n // switch (urlGen) {\n // case \"default\":\n // return sthis.pathOps.join(getPath(url, sthis), getFileName(url, sthis));\n // case \"fromEnv\":\n // return sthis.pathOps.join(getPath(url, sthis), getFileName(url, sthis));\n // default:\n // break;\n // }\n return sthis.pathOps.join(getPath(url, sthis), getFileName(url, sthis));\n }\n\n async put(url: URI, bytes: Uint8Array, sthis: SuperThis): Promise<Result<void>> {\n return exception2Result(async () => {\n const file = await this.getFilePath(url, sthis);\n sthis.logger.Debug().Str(\"url\", url.toString()).Str(\"file\", file).Msg(\"put\");\n await this.fs.writefile(file, bytes);\n });\n }\n\n async get(url: URI, sthis: SuperThis): Promise<GetResult> {\n return exceptionWrapper(async () => {\n const file = this.getFilePath(url, sthis);\n try {\n sthis.logger.Debug().Url(url).Str(\"file\", file).Msg(\"get\");\n const res = await this.fs.readfile(file);\n return Result.Ok(res);\n } catch (e: unknown) {\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\n async delete(url: URI, sthis: SuperThis): Promise<Result<void>> {\n return exception2Result(async () => {\n await this.fs.unlink(this.getFilePath(url, sthis));\n });\n }\n\n async destroy(baseURL: URI, sthis: SuperThis): Promise<Result<void>> {\n const url = await this.buildUrl(baseURL, \"x\");\n if (url.isErr()) return url;\n const filepath = sthis.pathOps.dirname(this.getFilePath(url.Ok(), sthis));\n let files: string[] = [];\n try {\n files = await this.fs.readdir(filepath);\n } catch (e: unknown) {\n if (!isNotFoundError(e)) {\n throw sthis.logger.Error().Err(e).Str(\"dir\", filepath).Msg(\"destroy:readdir\").AsError();\n }\n }\n for (const file of files) {\n const pathed = sthis.pathOps.join(filepath, file);\n try {\n await this.fs.unlink(pathed);\n } catch (e: unknown) {\n if (!isNotFoundError(e)) {\n throw sthis.logger.Error().Err(e).Str(\"file\", pathed).Msg(\"destroy:unlink\").AsError();\n }\n }\n }\n return Result.Ok(undefined);\n }\n\n async getPlain(iurl: URI, key: string, sthis: SuperThis) {\n const url = iurl.build().setParam(PARAM.KEY, key).URI();\n const dbFile = sthis.pathOps.join(getPath(url, sthis), getFileName(url, sthis));\n sthis.logger.Debug().Url(url).Str(\"dbFile\", dbFile).Msg(\"get\");\n const buffer = await this.fs.readfile(dbFile);\n sthis.logger.Debug().Url(url).Str(\"dbFile\", dbFile).Len(buffer).Msg(\"got\");\n return Result.Ok(buffer);\n }\n}\n","import type { URI } from \"@adviser/cement\";\nimport { getStore } from \"@fireproof/core\";\nimport type { SuperThis } from \"@fireproof/core\";\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 urlGen = url.getParam(PARAM.URL_GEN);\n // switch (urlGen) {\n // case \"default\":\n // case \"fromEnv\":\n // default:\n // break;\n // }\n\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, 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","import { Result, URI } from \"@adviser/cement\";\nimport { Gateway, GetResult } from \"../../../blockstore/gateway.js\";\nimport { PARAM, SuperThis } from \"../../../types.js\";\nimport { MEMORY_VERSION } from \"./version.js\";\nimport { NotFoundError } from \"../../../utils.js\";\nimport { VoidResult } from \"../../../blockstore/serde-gateway.js\";\n\nexport class MemoryGateway implements Gateway {\n readonly memorys: Map<string, Uint8Array>;\n readonly sthis: SuperThis;\n constructor(sthis: SuperThis, memorys: Map<string, Uint8Array>) {\n this.memorys = memorys;\n this.sthis = sthis;\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 start(baseUrl: URI): Promise<Result<URI>> {\n return Promise.resolve(Result.Ok(baseUrl.build().setParam(PARAM.VERSION, MEMORY_VERSION).URI()));\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n close(baseUrl: URI): Promise<VoidResult> {\n return Promise.resolve(Result.Ok(undefined));\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n destroy(baseUrl: URI): Promise<VoidResult> {\n this.memorys.clear();\n return Promise.resolve(Result.Ok(undefined));\n }\n async put(url: URI, bytes: Uint8Array): Promise<VoidResult> {\n this.memorys.set(url.toString(), bytes);\n return Result.Ok(undefined);\n }\n // get could return a NotFoundError if the key is not found\n get(url: URI): Promise<GetResult> {\n const x = this.memorys.get(url.toString());\n if (!x) {\n return Promise.resolve(Result.Err(new NotFoundError(\"not found\")));\n }\n return Promise.resolve(Result.Ok(x));\n }\n delete(url: URI): Promise<VoidResult> {\n this.memorys.delete(url.toString());\n return Promise.resolve(Result.Ok(undefined));\n }\n\n async getPlain(url: URI, key: string): Promise<Result<Uint8Array>> {\n const x = this.memorys.get(url.build().setParam(PARAM.KEY, key).toString());\n if (!x) {\n return Result.Err(new NotFoundError(\"not found\"));\n }\n return Result.Ok(x);\n }\n}\n","export const MEMORY_VERSION = \"v0.19-memory\";\n","import { Result, URI } from \"@adviser/cement\";\nimport type { Gateway } from \"../../blockstore/gateway.js\";\nimport type { FPEnvelope } from \"../../blockstore/fp-envelope.js\";\nimport { fpDeserialize, fpSerialize } from \"./fp-envelope-serialize.js\";\nimport type { SerdeGateway, SerdeGetResult } from \"../../blockstore/serde-gateway.js\";\nimport type { SuperThis } from \"../../types.js\";\n\nexport class DefSerdeGateway implements SerdeGateway {\n // abstract readonly storeType: StoreType;\n readonly gw: Gateway;\n\n constructor(gw: Gateway) {\n this.gw = gw;\n }\n\n start(sthis: SuperThis, baseURL: URI): Promise<Result<URI>> {\n return this.gw.start(baseURL, sthis);\n }\n\n async buildUrl(sthis: SuperThis, baseUrl: URI, key: string): Promise<Result<URI>> {\n return this.gw.buildUrl(baseUrl, key, sthis);\n }\n\n async close(sthis: SuperThis, uri: URI): Promise<Result<void>> {\n return this.gw.close(uri, sthis);\n }\n\n async put<T>(sthis: SuperThis, url: URI, env: FPEnvelope<T>): Promise<Result<void>> {\n const rUint8 = await fpSerialize(sthis, env);\n if (rUint8.isErr()) return rUint8;\n return this.gw.put(url, rUint8.Ok(), sthis);\n }\n\n async get<S>(sthis: SuperThis, url: URI): Promise<SerdeGetResult<S>> {\n const res = await this.gw.get(url, sthis);\n if (res.isErr()) return Result.Err(res.Err());\n return fpDeserialize(sthis, url, res) as Promise<SerdeGetResult<S>>;\n }\n\n async delete(sthis: SuperThis, url: URI): Promise<Result<void>> {\n return this.gw.delete(url, sthis);\n }\n\n async destroy(sthis: SuperThis, baseURL: URI): Promise<Result<void>> {\n return this.gw.destroy(baseURL, sthis);\n }\n\n async getPlain(sthis: SuperThis, iurl: URI, key: string) {\n return this.gw.getPlain(iurl, key, sthis);\n }\n}\n","import { exception2Result, Result, URI } from \"@adviser/cement\";\nimport type { CarClockLink, DbMeta, DbMetaBinary, DbMetaEvent, WALState } from \"../../blockstore/index.js\";\nimport {\n FPEnvelope,\n FPEnvelopeCar,\n FPEnvelopeFile,\n FPEnvelopeMeta,\n FPEnvelopeType,\n FPEnvelopeWAL,\n} from \"../../blockstore/fp-envelope.js\";\nimport { PARAM, PromiseToUInt8, SuperThis } from \"../../types.js\";\nimport { decodeEventBlock, EventBlock } from \"@fireproof/vendor/@web3-storage/pail/clock\";\nimport { base64pad } from \"multiformats/bases/base64\";\nimport { CID, Link } from \"multiformats\";\nimport { fromJSON } from \"multiformats/link\";\nimport { format, parse } from \"@fireproof/vendor/@ipld/dag-json\";\nimport { EventView } from \"@fireproof/vendor/@web3-storage/pail/clock/api\";\nimport { coercePromiseIntoUint8 } from \"../../utils.js\";\n\nexport interface SerializedMeta {\n readonly data: string; // base64pad encoded\n readonly parents: string[];\n readonly cid: string;\n}\n\nasync function dbMetaEvent2Serialized(sthis: SuperThis, dbEvents: Omit<DbMetaEvent, \"eventCid\">[]): Promise<SerializedMeta[]> {\n return await Promise.all(\n dbEvents.map(async (dbEvent) => {\n const event = await EventBlock.create<DbMetaBinary>(\n {\n dbMeta: sthis.txt.encode(format(dbEvent.dbMeta)),\n },\n dbEvent.parents as unknown as Link<EventView<DbMetaBinary>, number, number, 1>[],\n );\n return {\n cid: event.cid.toString(),\n parents: dbEvent.parents.map((i) => i.toString()),\n data: base64pad.encode(event.bytes),\n } as SerializedMeta;\n }),\n );\n}\n\nfunction WALState2Serialized(sthis: SuperThis, wal: WALState): SerializedWAL {\n const serializedWAL: SerializedWAL = {\n fileOperations: wal.fileOperations.map((fop) => ({\n cid: fop.cid.toString(),\n public: fop.public,\n })),\n noLoaderOps: wal.noLoaderOps.map((nop) => ({\n cars: nop.cars.map((i) => i.toString()),\n })),\n operations: wal.operations.map((op) => ({\n cars: op.cars.map((i) => i.toString()),\n })),\n };\n return serializedWAL;\n}\n\nexport type CAREncodeEnvelope = (sthis: SuperThis, payload: Uint8Array) => Promise<Result<Uint8Array>>;\nexport type FILEEncodeEnvelope = (sthis: SuperThis, payload: Uint8Array) => Promise<Result<Uint8Array>>;\nexport type METAEncodeEnvelope = (sthis: SuperThis, payload: SerializedMeta[]) => Promise<Result<Uint8Array>>;\nexport type WALEncodeEnvelope = (sthis: SuperThis, payload: SerializedWAL) => Promise<Result<Uint8Array>>;\n\n// export type CAREncodeEnvelope = (sthis: SuperThis, payload: Uint8Array, base: CAREncodeEnvelopeBase) => Promise<Uint8Array>;\n// export type FILEEncodeEnvelope = (sthis: SuperThis, payload: Uint8Array, base: CAREncodeEnvelopeBase) => Promise<Uint8Array>;\n// export type METAEncodeEnvelope = (sthis: SuperThis, payload: SerializedMeta[], base: METAEncodeEnvelopeBase) => Promise<Uint8Array>;\n// export type WALEncodeEnvelope = (sthis: SuperThis, payload: SerializedWAL, base: WALEncodeEnvelopeBase) => Promise<Uint8Array>;\nexport interface Encoder {\n readonly car: CAREncodeEnvelope;\n readonly file: FILEEncodeEnvelope;\n readonly meta: METAEncodeEnvelope;\n readonly wal: WALEncodeEnvelope;\n}\n\nconst defaultEncoder: Encoder = {\n car: async (sthis: SuperThis, payload: Uint8Array) => Result.Ok(payload),\n file: async (sthis: SuperThis, payload: Uint8Array) => Result.Ok(payload),\n meta: async (sthis: SuperThis, payload: SerializedMeta[]) => Result.Ok(sthis.txt.encode(JSON.stringify(payload))),\n wal: async (sthis: SuperThis, payload: SerializedWAL) => Result.Ok(sthis.txt.encode(JSON.stringify(payload))),\n};\n\nexport async function fpSerialize<T>(\n sthis: SuperThis,\n env: FPEnvelope<T>,\n pencoder?: Partial<Encoder>,\n): Promise<Result<Uint8Array>> {\n const encoder = {\n ...defaultEncoder,\n ...pencoder,\n };\n switch (env.type) {\n case FPEnvelopeType.FILE:\n return encoder.file(sthis, (env as FPEnvelopeFile).payload);\n case FPEnvelopeType.CAR:\n return encoder.car(sthis, (env as FPEnvelopeCar).payload);\n case FPEnvelopeType.WAL:\n return encoder.wal(sthis, WALState2Serialized(sthis, (env as FPEnvelopeWAL).payload));\n case FPEnvelopeType.META:\n return encoder.meta(sthis, await dbMetaEvent2Serialized(sthis, (env as FPEnvelopeMeta).payload));\n default:\n throw sthis.logger.Error().Str(\"type\", env.type).Msg(\"unsupported store\").AsError();\n }\n}\n\nasync function decode2DbMetaEvents(sthis: SuperThis, rserializedMeta: Result<SerializedMeta[]>): Promise<Result<DbMetaEvent[]>> {\n if (rserializedMeta.isErr()) {\n return Result.Err(rserializedMeta.Err());\n }\n const serializedMeta = rserializedMeta.unwrap();\n if (!Array.isArray(serializedMeta)) {\n return sthis.logger.Debug().Any(\"metaEntries\", serializedMeta).Msg(\"No data in MetaEntries\").ResultError();\n }\n if (!serializedMeta.length) {\n return sthis.logger.Debug().Msg(\"No MetaEntries found\").ResultError();\n }\n return Result.Ok(\n await Promise.all(\n serializedMeta.map(async (metaEntry) => {\n const eventBlock = await decodeEventBlock<DbMetaBinary>(base64pad.decode(metaEntry.data));\n const dbMeta = parse<DbMeta>(sthis.txt.decode(eventBlock.value.data.dbMeta));\n return {\n eventCid: eventBlock.cid as CarClockLink,\n parents: metaEntry.parents.map((i: string) => CID.parse(i)),\n dbMeta,\n } satisfies DbMetaEvent;\n }),\n ),\n );\n}\n\ntype linkOrCid = { \"/\": string } | string;\n\nexport interface SerializedWAL {\n readonly fileOperations?: { cid: linkOrCid; public: boolean }[];\n readonly noLoaderOps?: { cars: linkOrCid[] }[];\n readonly operations?: { cars: linkOrCid[] }[];\n}\n\nfunction toCid(sthis: SuperThis, link: linkOrCid): CID {\n if (typeof link === \"string\") {\n return CID.parse(link);\n }\n return fromJSON(link);\n}\n\nasync function decode2WalState(sthis: SuperThis, rserializedWAL: Result<SerializedWAL>): Promise<Result<WALState>> {\n if (rserializedWAL.isErr()) {\n return Result.Err(rserializedWAL.Err());\n }\n const serializedWAL = rserializedWAL.unwrap();\n return Result.Ok({\n fileOperations: (serializedWAL.fileOperations || []).map((fop) => ({\n cid: toCid(sthis, fop.cid),\n public: !!fop.public,\n })),\n noLoaderOps: (serializedWAL.noLoaderOps || []).map((nop) => ({\n cars: (nop.cars || []).map((i) => toCid(sthis, i)),\n })),\n operations: (serializedWAL.operations || []).map((op) => ({\n cars: (op.cars || []).map((i) => toCid(sthis, i)),\n })),\n });\n}\n// export type CARDecodeEnvelopeBase = (sthis: SuperThis, payload: Uint8Array) => Promise<Result<Uint8Array>>;\n// export type FILEDecodeEnvelopeBase = (sthis: SuperThis, payload: Uint8Array) => Promise<Result<Uint8Array>>;\n// export type WALDecodeEnvelopeBase = (sthis: SuperThis, payload: SerializedWAL) => Promise<Result<SerializedWAL>>;\n// export type METADecodeEnvelopeBase = (sthis: SuperThis, payload: SerializedMeta[]) => Promise<Result<SerializedMeta[]>>;\n\nexport type CARDecodeEnvelope = (sthis: SuperThis, payload: Uint8Array) => Promise<Result<Uint8Array>>;\nexport type FILEDecodeEnvelope = (sthis: SuperThis, payload: Uint8Array) => Promise<Result<Uint8Array>>;\nexport type METADecodeEnvelope = (sthis: SuperThis, payload: Uint8Array) => Promise<Result<SerializedMeta[]>>;\nexport type WALDecodeEnvelope = (sthis: SuperThis, payload: Uint8Array) => Promise<Result<SerializedWAL>>;\nexport interface Decoder {\n readonly car: CARDecodeEnvelope;\n readonly file: FILEDecodeEnvelope;\n readonly meta: METADecodeEnvelope;\n readonly wal: WALDecodeEnvelope;\n}\n\nconst defaultDecoder = {\n car: async (sthis: SuperThis, payload: Uint8Array) => Result.Ok(payload),\n file: async (sthis: SuperThis, payload: Uint8Array) => Result.Ok(payload),\n meta: async (sthis: SuperThis, payload: Uint8Array) =>\n exception2Result(() => JSON.parse(sthis.txt.decode(payload)) as SerializedMeta[]),\n wal: async (sthis: SuperThis, payload: Uint8Array) =>\n exception2Result(() => JSON.parse(sthis.txt.decode(payload)) as SerializedWAL),\n};\n\nfunction makeFPEnvelope<S>(type: FPEnvelopeType, payload: Result<S>): Result<FPEnvelope<S>> {\n if (payload.isErr()) {\n return Result.Err(payload.Err());\n }\n return Result.Ok({\n type,\n payload: payload.unwrap(),\n });\n}\n\nexport async function fpDeserialize<S>(\n sthis: SuperThis,\n url: URI,\n intoRaw: PromiseToUInt8,\n pdecoder?: Partial<Decoder>,\n): Promise<Result<FPEnvelope<S>>> {\n const rraw = await coercePromiseIntoUint8(intoRaw);\n if (rraw.isErr()) {\n return Result.Err(rraw.Err());\n }\n const raw = rraw.unwrap();\n const decoder = {\n ...defaultDecoder,\n ...pdecoder,\n };\n switch (url.getParam(PARAM.STORE)) {\n case \"data\":\n if (url.getParam(PARAM.SUFFIX) === \".car\") {\n return makeFPEnvelope(FPEnvelopeType.CAR, await decoder.car(sthis, raw)) as Result<FPEnvelope<S>>;\n }\n return makeFPEnvelope(FPEnvelopeType.FILE, await decoder.file(sthis, raw)) as Result<FPEnvelope<S>>;\n case \"wal\":\n return makeFPEnvelope(FPEnvelopeType.WAL, await decode2WalState(sthis, await decoder.wal(sthis, raw))) as Result<\n FPEnvelope<S>\n >;\n case \"meta\":\n return makeFPEnvelope(FPEnvelopeType.META, await decode2DbMetaEvents(sthis, await decoder.meta(sthis, raw))) as Result<\n FPEnvelope<S>\n >;\n default:\n return sthis.logger.Error().Str(\"store\", url.getParam(PARAM.STORE)).Msg(\"unsupported store\").ResultError();\n }\n}\n","import { CID } from \"multiformats\";\nimport { DbMetaEvent, WALState } from \"./types.js\";\nimport { Result } from \"@adviser/cement\";\n\nexport enum FPEnvelopeType {\n CAR = \"car\",\n FILE = \"file\",\n META = \"meta\",\n WAL = \"wal\",\n}\n\nexport interface FPEnvelope<T> {\n readonly type: FPEnvelopeType;\n readonly payload: T;\n}\n\nexport interface FPEnvelopeCar extends FPEnvelope<Uint8Array> {\n readonly type: FPEnvelopeType.CAR;\n}\n\nexport interface FPEnvelopeFile extends FPEnvelope<Uint8Array> {\n readonly type: FPEnvelopeType.FILE;\n}\n\nexport interface FPEnvelopeMeta extends FPEnvelope<DbMetaEvent[]> {\n readonly type: FPEnvelopeType.META;\n}\n\nexport interface FPWALCarsOps {\n readonly cars: CID[];\n}\n// export interface FPWAL {\n// // fileOperations: any[]; will be added with connector-fixes\n// // noLoaderOps: any[]; will be added with connector-fixes\n// readonly operations: FPWALCarsOps[];\n// }\nexport interface FPEnvelopeWAL extends FPEnvelope<WALState> {\n readonly type: FPEnvelopeType.WAL;\n}\n\n// export function WAL2FPMsg(sthis: SuperThis, ws: WALState): Result<FPEnvelopeWAL> {\n// return Result.Ok({\n// type: \"wal\",\n// payload: ws\n// })\n// }\n\n// export function FPMsg2WAL(fpmsg: FPEnvelopeWAL): Result<WALState> {\n// // const renv = FPMsgMatch2Envelope(fpmsg, \"wal\");\n// // if (renv.isErr()) {\n// // return Result.Err(renv.Err());\n// // }\n// if (fpmsg.type !== \"wal\") {\n// return Result.Err(`expected type to be wal`);\n// }\n// const convertCids = fpmsg.payload as WALState;\n// for (const op of convertCids.operations) {\n// const cars = []\n// for (const strCid of op.cars) {\n// for (const cidVal of Object.values(strCid)) {\n// cars.push(CID.parse(cidVal));\n// }\n// }\n// (op as {cars: CID[]}).cars = cars;\n// }\n// return Result.Ok(convertCids);\n// }\n\n// export function Meta2FPMsg(fpmetas: DbMetaEvent[]): Uint8Array {\n// /*\n// [\n// {\n// \"cid\":\"bafyreibc2rbsszqw5z7xiojra2vgskl3mi7iegf3ynpofm6w6lcxx4r7ha\",\n// \"data\":\"MomRkYXRhoWZkYk1ldGFYU3siY2FycyI6W3siLyI6ImJhZzR5dnFhYmNpcW9peXdlb2Vjd214Z3VmdDV4YmJsMnFxd2c3Z2tmYTV6cG91d2huYWVoN3E1b3o2eTNoMnkifV19Z3BhcmVudHOB2CpYJQABcRIgTXAXVfzn7tghZBnaOrXq0+bmY3kK9f1CCNrGfeA73hk=\",\n// \"parents\":[\"bafyreicnoalvl7hh53mcczaz3i5ll2wt43tgg6ik6x6uecg2yz66ao66de\"]\n// }\n// ]\n// */\n// return encode({ type: \"meta\", payload: fpmetas } as FPEnvelopeMeta);\n// }\n\n// export function FPMsg2Meta(fpmsg: Uint8Array): Result<DbMeta> {\n// const renv = FPMsgMatch2Envelope(fpmsg, \"meta\");\n// if (renv.isErr()) {\n// return Result.Err(renv.Err());\n// }\n// return Result.Ok(renv.Ok().payload as DbMeta);\n// }\n\nexport function Car2FPMsg(fpcar: Uint8Array): Result<FPEnvelopeCar> {\n return Result.Ok({ type: FPEnvelopeType.CAR, payload: fpcar });\n}\n\n// export function FPMsg2Car(fpmsg: Uint8Array): Result<Uint8Array> {\n// const renv = FPMsgMatch2Envelope(fpmsg, \"car\");\n// if (renv.isErr()) {\n// return Result.Err(renv.Err());\n// }\n// return Result.Ok(renv.Ok().payload as Uint8Array);\n// }\n\nexport function File2FPMsg(fpfile: Uint8Array): Result<FPEnvelopeFile> {\n return Result.Ok({ type: FPEnvelopeType.FILE, payload: fpfile });\n}\n\n// export function FPMsg2File(fpmsg: Uint8Array): Result<Uint8Array> {\n// const renv = FPMsgMatch2Envelope(fpmsg, \"file\");\n// if (renv.isErr()) {\n// return Result.Err(renv.Err());\n// }\n// return Result.Ok(renv.Ok().payload as Uint8Array);\n// }\n\n// export function FPMsgMatch2Envelope(fpmsg: Uint8Array, ...types: string[]): Result<FPEnvelope<unknown>> {\n// let env: FPEnvelope<unknown>;\n// try {\n// env = decode(fpmsg);\n// } catch (e) {\n// return Result.Err(`failed to decode envelope: ${e}`);\n// }\n// if (typeof env !== \"object\") {\n// return Result.Err(`expected envelope to be an object`);\n// }\n// if (typeof env.type !== \"string\") {\n// return Result.Err(`expected type to be a string`);\n// }\n// if (types.length > 0 && !types.includes(env.type)) {\n// return Result.Err(`expected type to be ${types}`);\n// }\n// // need to check if the payload is a valid WAL\n// return Result.Ok(env);\n// }\n","// this enable async codec\n// it should be gone if this in multiformats is merged:\n// https://github.com/multiformats/js-multiformats/pull/305\nimport { bytes as binary, CID, MultihashHasher, BlockView, ByteView, Version, Link } from \"multiformats\";\nimport { Block as mfBlock } from \"multiformats/block\";\nimport { BlockDecoder, BlockEncoder } from \"./codec-interface.js\";\n\n// export type Block<T, C extends number, A extends number, V extends Version> = mfBlock<T, C, A, V>\n\nexport const Block = mfBlock;\n\ninterface DecodeInput<T, Code extends number, Alg extends number> {\n bytes: ByteView<T>;\n codec: BlockDecoder<Code, T>;\n hasher: MultihashHasher<Alg>;\n}\n\nexport async function decode<T, Code extends number, Alg extends number>({\n bytes,\n codec,\n hasher,\n}: DecodeInput<T, Code, Alg>): Promise<BlockView<T, Code, Alg>> {\n if (bytes == null) throw new Error('Missing required argument \"bytes\"');\n if (codec == null || hasher == null) throw new Error(\"Missing required argument: codec or hasher\");\n\n const value = await Promise.resolve(codec.decode(bytes));\n const hash = await hasher.digest(bytes);\n const cid = CID.create(1, codec.code, hash) as CID<T, Code, Alg, 1>;\n\n return new mfBlock({ value, bytes, cid });\n}\n\ninterface EncodeInput<T, Code extends number, Alg extends number> {\n value: T;\n codec: BlockEncoder<Code, T>;\n hasher: MultihashHasher<Alg>;\n}\n\nexport async function encode<T, Code extends number, Alg extends number>({\n value,\n codec,\n hasher,\n}: EncodeInput<T, Code, Alg>): Promise<BlockView<T, Code, Alg>> {\n if (typeof value === \"undefined\") throw new Error('Missing required argument \"value\"');\n if (codec == null || hasher == null) throw new Error(\"Missing required argument: codec or hasher\");\n\n const bytes = await Promise.resolve(codec.encode(value));\n const hash = await hasher.digest(bytes);\n const cid = CID.create(1, codec.code, hash) as CID<T, Code, Alg, 1>;\n\n return new mfBlock({ value, bytes, cid });\n}\n\ninterface CreateInput<T, Code extends number, Alg extends number, V extends Version> {\n bytes: ByteView<T>;\n cid: Link<T, Code, Alg, V>;\n hasher: MultihashHasher<Alg>;\n codec: BlockDecoder<Code, T>;\n}\n\nexport async function create<T, Code extends number, Alg extends number, V extends Version>({\n bytes,\n cid,\n hasher,\n codec,\n}: CreateInput<T, Code, Alg, V>): Promise<BlockView<T, Code, Alg, V>> {\n if (bytes == null) throw new Error('Missing required argument \"bytes\"');\n if (hasher == null) throw new Error('Missing required argument \"hasher\"');\n const value = await Promise.resolve(codec.decode(bytes));\n const hash = await hasher.digest(bytes);\n if (!binary.equals(cid.multihash.bytes, hash.bytes)) {\n throw new Error(\"CID hash does not match bytes\");\n }\n\n return createUnsafe({\n bytes,\n cid,\n value,\n codec,\n });\n}\n\ntype CreateUnsafeInput<T, Code extends number, Alg extends number, V extends Version> =\n | {\n cid: Link<T, Code, Alg, V>;\n value: T;\n codec?: BlockDecoder<Code, T>;\n bytes: ByteView<T>;\n }\n | {\n cid: Link<T, Code, Alg, V>;\n value?: undefined;\n codec: BlockDecoder<Code, T>;\n bytes: ByteView<T>;\n };\n\n/**\n * @template T - Logical type of the data encoded in the block\n * @template Code - multicodec code corresponding to codec used to encode the block\n * @template Alg - multicodec code corresponding to the hashing algorithm used in CID creation.\n * @template V - CID version\n */\nexport async function createUnsafe<T, Code extends number, Alg extends number, V extends Version>({\n bytes,\n cid,\n value: maybeValue,\n codec,\n}: CreateUnsafeInput<T, Code, Alg, V>): Promise<BlockView<T, Code, Alg, V>> {\n const value = await Promise.resolve(maybeValue !== undefined ? maybeValue : codec?.decode(bytes));\n\n if (value === undefined) throw new Error('Missing required argument, must either provide \"value\" or \"codec\"');\n\n return new Block({\n cid: cid as CID<T, Code, Alg, V>,\n bytes,\n value,\n });\n}\n","import type { Block, Link } from \"multiformats\";\nimport { create } from \"./runtime/wait-pr-multiformats/block.js\";\nimport { sha256 as hasher } from \"multiformats/hashes/sha2\";\nimport * as codec from \"@fireproof/vendor/@ipld/dag-cbor\";\n\n// @ts-expect-error \"charwise\" has no types\nimport charwise from \"charwise\";\n// @ts-expect-error \"prolly-trees\" has no types\nimport * as DbIndex from \"prolly-trees/db-index\";\n// @ts-expect-error \"prolly-trees\" has no types\nimport { bf, simpleCompare } from \"prolly-trees/utils\";\n// @ts-expect-error \"prolly-trees\" has no types\nimport { nocache as cache } from \"prolly-trees/cache\";\n// @ts-expect-error \"prolly-trees\" has no types\nimport { ProllyNode as BaseNode } from \"prolly-trees/db-index\";\n\nimport {\n DocUpdate,\n MapFn,\n DocFragment,\n IndexUpdate,\n QueryOpts,\n IndexRow,\n DocWithId,\n IndexKeyType,\n IndexKey,\n DocTypes,\n DocObject,\n IndexUpdateString,\n CarTransaction,\n CRDT,\n} from \"./types.js\";\nimport { BlockFetcher, AnyLink, AnyBlock } from \"./blockstore/index.js\";\nimport { Logger } from \"@adviser/cement\";\n\nexport class IndexTree<K extends IndexKeyType, R extends DocFragment> {\n cid?: AnyLink;\n root?: ProllyNode<K, R>;\n}\n\ntype CompareRef = string | number;\nexport type CompareKey = [string | number, CompareRef];\n\nfunction refCompare(aRef: CompareRef, bRef: CompareRef) {\n if (Number.isNaN(aRef)) return -1;\n if (Number.isNaN(bRef)) throw new Error(\"ref may not be Infinity or NaN\");\n if (aRef === Infinity) return 1;\n // if (!Number.isFinite(bRef)) throw new Error('ref may not be Infinity or NaN')\n\n return simpleCompare(aRef, bRef) as number;\n}\n\nfunction compare(a: CompareKey, b: CompareKey) {\n const [aKey, aRef] = a;\n const [bKey, bRef] = b;\n\n const comp: number = simpleCompare(aKey, bKey);\n if (comp !== 0) return comp;\n return refCompare(aRef, bRef);\n}\n\nexport const byKeyOpts: StaticProllyOptions<CompareKey> = { cache, chunker: bf(30), codec, hasher, compare };\n\nexport const byIdOpts: StaticProllyOptions<unknown> = { cache, chunker: bf(30), codec, hasher, compare: simpleCompare };\n\nexport interface IndexDoc<K extends IndexKeyType> {\n readonly key: IndexKey<K>;\n readonly value: DocFragment;\n}\n\nexport interface IndexDocString {\n readonly key: string;\n readonly value: DocFragment;\n}\n\nexport function indexEntriesForChanges<T extends DocTypes, K extends IndexKeyType>(\n changes: DocUpdate<T>[],\n mapFn: MapFn<T>,\n): IndexDoc<K>[] {\n const indexEntries: IndexDoc<K>[] = [];\n changes.forEach(({ id: key, value, del }) => {\n if (del || !value) return;\n let mapCalled = false;\n const mapReturn = mapFn({ ...(value as DocWithId<T>), _id: key }, (k: IndexKeyType, v?: DocFragment) => {\n mapCalled = true;\n if (typeof k === \"undefined\") return;\n indexEntries.push({\n key: [charwise.encode(k) as K, key],\n value: v || null,\n });\n });\n if (!mapCalled && mapReturn) {\n indexEntries.push({\n key: [charwise.encode(mapReturn) as K, key],\n value: null,\n });\n }\n });\n return indexEntries;\n}\n\nfunction makeProllyGetBlock(blocks: BlockFetcher): (address: AnyLink) => Promise<AnyBlock> {\n return async (address: AnyLink) => {\n const block = await blocks.get(address);\n if (!block) throw new Error(`Missing block ${address.toString()}`);\n const { cid, bytes } = block;\n return create({ cid, bytes, hasher, codec }) as Promise<AnyBlock>;\n };\n}\n\nexport async function bulkIndex<K extends IndexKeyType, T extends DocFragment, CT>(\n logger: Logger,\n tblocks: CarTransaction,\n inIndex: IndexTree<K, T>,\n indexEntries: (IndexUpdate<K> | IndexUpdateString)[],\n opts: StaticProllyOptions<CT>,\n): Promise<IndexTree<K, T>> {\n logger.Debug().Msg(\"enter bulkIndex\");\n if (!indexEntries.length) return inIndex;\n if (!inIndex.root) {\n if (!inIndex.cid) {\n let returnRootBlock: Block | undefined = undefined;\n let returnNode: ProllyNode<K, T> | undefined = undefined;\n\n for await (const node of (await DbIndex.create({\n get: makeProllyGetBlock(tblocks),\n list: indexEntries,\n ...opts,\n })) as ProllyNode<K, T>[]) {\n const block = await node.block;\n await tblocks.put(block.cid, block.bytes);\n returnRootBlock = block;\n returnNode = node;\n }\n if (!returnNode || !returnRootBlock) throw new Error(\"failed to create index\");\n logger.Debug().Msg(\"exit !root bulkIndex\");\n return { root: returnNode, cid: returnRootBlock.cid };\n } else {\n inIndex.root = (await DbIndex.load({ cid: inIndex.cid, get: makeProllyGetBlock(tblocks), ...opts })) as ProllyNode<K, T>;\n }\n }\n logger.Debug().Msg(\"pre bulk bulkIndex\");\n const { root, blocks: newBlocks } = await inIndex.root.bulk(indexEntries);\n if (root) {\n logger.Debug().Msg(\"pre root put bulkIndex\");\n for await (const block of newBlocks) {\n await tblocks.put(block.cid, block.bytes);\n }\n return { root, cid: (await root.block).cid };\n } else {\n logger.Debug().Msg(\"pre !root bulkIndex\");\n return { root: undefined, cid: undefined };\n }\n}\n\nexport async function loadIndex<K extends IndexKeyType, T extends DocFragment, CT>(\n tblocks: BlockFetcher,\n cid: AnyLink,\n opts: StaticProllyOptions<CT>,\n): Promise<ProllyNode<K, T>> {\n return (await DbIndex.load({ cid, get: makeProllyGetBlock(tblocks), ...opts })) as ProllyNode<K, T>;\n}\n\nexport async function applyQuery<K extends IndexKeyType, T extends DocObject, R extends DocFragment>(\n crdt: CRDT,\n resp: { result: ProllyIndexRow<K, R>[] },\n query: QueryOpts<K>,\n): Promise<{\n rows: IndexRow<K, T, R>[];\n}> {\n if (query.descending) {\n resp.result = resp.result.reverse();\n }\n if (query.limit) {\n resp.result = resp.result.slice(0, query.limit);\n }\n if (query.includeDocs) {\n resp.result = await Promise.all(\n resp.result.map(async (row) => {\n const val = await crdt.get(row.id);\n const doc = val ? ({ ...val.doc, _id: row.id } as DocWithId<T>) : undefined;\n return { ...row, doc };\n }),\n );\n }\n return {\n rows: resp.result.map(({ key, ...row }) => {\n return {\n key: charwise.decode(key),\n ...row,\n };\n }),\n };\n}\n\nexport function encodeRange(range: [IndexKeyType, IndexKeyType]): [string, string] {\n return [charwise.encode(range[0]), charwise.encode(range[1])];\n}\n\nexport function encodeKey(key: DocFragment): string {\n return charwise.encode(key) as string;\n}\n\nexport interface ProllyIndexRow<K extends IndexKeyType, T extends DocFragment> {\n readonly id: string;\n readonly key: IndexKey<K>;\n readonly value: T;\n}\n\n// ProllyNode type based on the ProllyNode from 'prolly-trees/base'\ninterface ProllyNode<K extends IndexKeyType, T extends DocFragment> extends BaseNode {\n getAllEntries(): PromiseLike<{ [x: string]: unknown; result: ProllyIndexRow<K, T>[] }>;\n getMany<KI extends IndexKeyType>(removeIds: KI[]): Promise<{ /* [x: K]: unknown; */ result: IndexKey<K>[] }>;\n range(a: string, b: string): Promise<{ result: ProllyIndexRow<K, T>[] }>;\n get(key: string): Promise<{ result: ProllyIndexRow<K, T>[] }>;\n bulk(bulk: (IndexUpdate<K> | IndexUpdateString)[]): PromiseLike<{\n readonly root?: ProllyNode<K, T>;\n readonly blocks: Block[];\n }>;\n readonly address: Promise<Link>;\n readonly distance: number;\n compare: (a: unknown, b: unknown) => number;\n readonly cache: unknown;\n readonly block: Promise<Block>;\n}\n\ninterface StaticProllyOptions<T> {\n readonly cache: unknown;\n chunker: (entry: T, distance: number) => boolean;\n readonly codec: unknown;\n readonly hasher: unknown;\n compare: (a: T, b: T) => number;\n}\n","import {\n type ClockHead,\n type DocUpdate,\n type MapFn,\n type IndexUpdate,\n type QueryOpts,\n type IdxMeta,\n type DocFragment,\n type IdxMetaMap,\n type IndexKeyType,\n type IndexRows,\n type DocTypes,\n type IndexUpdateString,\n throwFalsy,\n type IndexTransactionMeta,\n type SuperThis,\n type BaseBlockstore,\n type CRDT,\n type HasCRDT,\n type HasLogger,\n type HasSuperThis,\n type RefLedger,\n} from \"./types.js\";\n// import { BaseBlockstore } from \"./blockstore/index.js\";\n\nimport {\n bulkIndex,\n indexEntriesForChanges,\n byIdOpts,\n byKeyOpts,\n IndexTree,\n applyQuery,\n encodeRange,\n encodeKey,\n loadIndex,\n IndexDocString,\n CompareKey,\n} from \"./indexer-helpers.js\";\nimport { ensureLogger } from \"./utils.js\";\nimport { Logger } from \"@adviser/cement\";\n\nfunction refLedger(u: HasCRDT | RefLedger): u is RefLedger {\n return !!(u as RefLedger).ledger;\n}\n\nexport function index<K extends IndexKeyType = string, T extends DocTypes = NonNullable<unknown>, R extends DocFragment = T>(\n refDb: HasLogger & HasSuperThis & (HasCRDT | RefLedger),\n name: string,\n mapFn?: MapFn<T>,\n meta?: IdxMeta,\n): Index<K, T, R> {\n const crdt = refLedger(refDb) ? refDb.ledger.crdt : refDb.crdt;\n\n if (mapFn && meta) throw refDb.logger.Error().Msg(\"cannot provide both mapFn and meta\").AsError();\n if (mapFn && mapFn.constructor.name !== \"Function\") throw refDb.logger.Error().Msg(\"mapFn must be a function\").AsError();\n if (crdt.indexers.has(name)) {\n const idx = crdt.indexers.get(name) as unknown as Index<K, T>;\n idx.applyMapFn(name, mapFn, meta);\n } else {\n const idx = new Index<K, T>(refDb.sthis, crdt, name, mapFn, meta);\n crdt.indexers.set(name, idx as unknown as Index<K, NonNullable<unknown>, NonNullable<unknown>>);\n }\n return crdt.indexers.get(name) as unknown as Index<K, T, R>;\n}\n\n// interface ByIdIndexIten<K extends IndexKeyType> {\n// readonly key: K;\n// readonly value: [K, K];\n// }\n\nexport class Index<K extends IndexKeyType, T extends DocTypes, R extends DocFragment = T> {\n readonly blockstore: BaseBlockstore;\n readonly crdt: CRDT;\n readonly name: string;\n mapFn?: MapFn<T>;\n mapFnString = \"\";\n byKey: IndexTree<K, R> = new IndexTree<K, R>();\n byId: IndexTree<K, R> = new IndexTree<K, R>();\n indexHead?: ClockHead;\n includeDocsDefault = false;\n initError?: Error;\n\n ready(): Promise<void> {\n return Promise.all([this.blockstore.ready(), this.crdt.ready()]).then(() => {\n /* noop */\n });\n }\n\n // close(): Promise<void> {\n // return Promise.all([this.blockstore.close(), this.crdt.close()]).then(() => {\n // /* noop */\n // });\n // }\n // destroy(): Promise<void> {\n // return Promise.all([this.blockstore.destroy(), this.crdt.destroy()]).then(() => {\n // /* noop */\n // });\n // }\n\n readonly logger: Logger;\n\n constructor(sthis: SuperThis, crdt: CRDT, name: string, mapFn?: MapFn<T>, meta?: IdxMeta) {\n this.logger = ensureLogger(sthis, \"Index\");\n this.blockstore = crdt.indexBlockstore;\n this.crdt = crdt as CRDT;\n this.applyMapFn(name, mapFn, meta);\n this.name = name;\n if (!(this.mapFnString || this.initError)) throw this.logger.Error().Msg(\"missing mapFnString\").AsError();\n // this.ready = this.blockstore.ready.then(() => {\n // return;\n // });\n // .then((header: IdxCarHeader) => {\n // // @ts-ignore\n // if (header.head) throw new Error('cannot have head in idx header')\n // if (header.indexes === undefined) throw new Error('missing indexes in idx header')\n // // for (const [name, idx] of Object.entries(header.indexes)) {\n // // index({ _crdt: crdt }, name, undefined, idx as IdxMeta)\n // // }\n // })\n }\n\n applyMapFn(name: string, mapFn?: MapFn<T>, meta?: IdxMeta) {\n if (mapFn && meta) throw this.logger.Error().Msg(\"cannot provide both mapFn and meta\").AsError();\n if (this.name && this.name !== name) throw this.logger.Error().Msg(\"cannot change name\").AsError();\n // this.name = name;\n try {\n if (meta) {\n // hydrating from header\n if (this.indexHead && this.indexHead.map((c) => c.toString()).join() !== meta.head.map((c) => c.toString()).join()) {\n throw this.logger.Error().Msg(\"cannot apply different head meta\").AsError();\n }\n\n if (this.mapFnString) {\n // we already initialized from application code\n if (this.mapFnString !== meta.map) {\n this.logger\n .Warn()\n .Msg(`cannot apply different mapFn meta: old mapFnString ${this.mapFnString} new mapFnString ${meta.map}`);\n // throw new Error('cannot apply different mapFn meta')\n } else {\n this.byId.cid = meta.byId;\n this.byKey.cid = meta.byKey;\n this.indexHead = meta.head;\n }\n } else {\n // we are first\n this.mapFnString = meta.map;\n this.byId.cid = meta.byId;\n this.byKey.cid = meta.byKey;\n this.indexHead = meta.head;\n }\n } else {\n if (this.mapFn) {\n // we already initialized from application code\n if (mapFn) {\n if (this.mapFn.toString() !== mapFn.toString()) {\n throw this.logger.Error().Msg(\"cannot apply different mapFn app2\").AsError();\n }\n }\n } else {\n // application code is creating an index\n if (!mapFn) {\n mapFn = ((doc) => (doc as unknown as Record<string, unknown>)[name] ?? undefined) as MapFn<T>;\n }\n if (this.mapFnString) {\n // we already loaded from a header\n if (this.mapFnString !== mapFn.toString()) {\n throw this.logger\n .Error()\n .Str(\"mapFnString\", this.mapFnString)\n .Str(\"mapFn\", mapFn.toString())\n .Msg(\"cannot apply different mapFn app\")\n .AsError();\n }\n } else {\n // we are first\n this.mapFnString = mapFn.toString();\n }\n this.mapFn = mapFn;\n }\n }\n const matches = /=>\\s*(.*)/.test(this.mapFnString);\n this.includeDocsDefault = matches;\n } catch (e) {\n this.initError = e as Error;\n }\n }\n\n async query(opts: QueryOpts<K> = {}): Promise<IndexRows<K, T, R>> {\n this.logger.Debug().Msg(\"enter query\");\n await this.ready();\n // this._resetIndex();\n this.logger.Debug().Msg(\"post ready query\");\n await this._updateIndex();\n this.logger.Debug().Msg(\"post _updateIndex query\");\n await this._hydrateIndex();\n this.logger.Debug().Msg(\"post _hydrateIndex query\");\n if (!this.byKey.root) {\n return await applyQuery<K, T, R>(this.crdt, { result: [] }, opts);\n }\n if (this.includeDocsDefault && opts.includeDocs === undefined) opts.includeDocs = true;\n if (opts.range) {\n const eRange = encodeRange(opts.range);\n return await applyQuery<K, T, R>(this.crdt, await throwFalsy(this.byKey.root).range(eRange[0], eRange[1]), opts);\n }\n if (opts.key) {\n const encodedKey = encodeKey(opts.key);\n return await applyQuery<K, T, R>(this.crdt, await throwFalsy(this.byKey.root).get(encodedKey), opts);\n }\n if (Array.isArray(opts.keys)) {\n const results = await Promise.all(\n opts.keys.map(async (key: DocFragment) => {\n const encodedKey = encodeKey(key);\n return (await applyQuery<K, T, R>(this.crdt, await throwFalsy(this.byKey.root).get(encodedKey), opts)).rows;\n }),\n );\n return { rows: results.flat() };\n }\n if (opts.prefix) {\n if (!Array.isArray(opts.prefix)) opts.prefix = [opts.prefix];\n // prefix should be always an array\n const start = [...opts.prefix, NaN];\n const end = [...opts.prefix, Infinity];\n const encodedR = encodeRange([start, end]);\n return await applyQuery<K, T, R>(this.crdt, await this.byKey.root.range(...encodedR), opts);\n }\n const all = await this.byKey.root.getAllEntries(); // funky return type\n return await applyQuery<K, T, R>(\n this.crdt,\n {\n // @ts-expect-error getAllEntries returns a different type than range\n result: all.result.map(({ key: [k, id], value }) => ({\n key: k,\n id,\n value,\n })),\n },\n opts,\n );\n }\n\n _resetIndex() {\n this.byId = new IndexTree();\n this.byKey = new IndexTree();\n this.indexHead = undefined;\n }\n\n async _hydrateIndex() {\n if (this.byId.root && this.byKey.root) return;\n if (!this.byId.cid || !this.byKey.cid) return;\n this.byId.root = await loadIndex<K, R, K>(this.blockstore, this.byId.cid, byIdOpts);\n this.byKey.root = await loadIndex<K, R, CompareKey>(this.blockstore, this.byKey.cid, byKeyOpts);\n }\n\n async _updateIndex(): Promise<IndexTransactionMeta> {\n await this.ready();\n this.logger.Debug().Msg(\"enter _updateIndex\");\n if (this.initError) throw this.initError;\n if (!this.mapFn) throw this.logger.Error().Msg(\"No map function defined\").AsError();\n let result: DocUpdate<T>[], head: ClockHead;\n if (!this.indexHead || this.indexHead.length === 0) {\n ({ result, head } = await this.crdt.allDocs<T>());\n this.logger.Debug().Msg(\"enter crdt.allDocs\");\n } else {\n ({ result, head } = await this.crdt.changes<T>(this.indexHead));\n this.logger.Debug().Msg(\"enter crdt.changes\");\n }\n if (result.length === 0) {\n this.indexHead = head;\n // return { byId: this.byId, byKey: this.byKey } as IndexTransactionMeta;\n }\n let staleKeyIndexEntries: IndexUpdate<K>[] = [];\n let removeIdIndexEntries: IndexUpdateString[] = [];\n if (this.byId.root) {\n const removeIds = result.map(({ id: key }) => key);\n const { result: oldChangeEntries } = await this.byId.root.getMany(removeIds);\n staleKeyIndexEntries = oldChangeEntries.map((key) => ({ key, del: true }));\n removeIdIndexEntries = oldChangeEntries.map((key) => ({ key: key[1], del: true }));\n }\n const indexEntries = indexEntriesForChanges<T, K>(result, this.mapFn); // use a getter to translate from string\n const byIdIndexEntries: IndexDocString[] = indexEntries.map(({ key }) => ({\n key: key[1],\n value: key,\n }));\n const indexerMeta: IdxMetaMap = { indexes: new Map() };\n\n for (const [name, indexer] of this.crdt.indexers) {\n if (indexer.indexHead) {\n indexerMeta.indexes?.set(name, {\n byId: indexer.byId.cid,\n byKey: indexer.byKey.cid,\n head: indexer.indexHead,\n map: indexer.mapFnString,\n name: indexer.name,\n } as IdxMeta);\n }\n }\n if (result.length === 0) {\n return indexerMeta as unknown as IndexTransactionMeta;\n }\n this.logger.Debug().Msg(\"pre this.blockstore.transaction\");\n const { meta } = await this.blockstore.transaction<IndexTransactionMeta>(async (tblocks): Promise<IndexTransactionMeta> => {\n this.byId = await bulkIndex<K, R, K>(\n this.logger,\n tblocks,\n this.byId,\n removeIdIndexEntries.concat(byIdIndexEntries),\n byIdOpts,\n );\n this.byKey = await bulkIndex<K, R, CompareKey>(\n this.logger,\n tblocks,\n this.byKey,\n staleKeyIndexEntries.concat(indexEntries),\n byKeyOpts,\n );\n this.indexHead = head;\n if (this.byId.cid && this.byKey.cid) {\n const idxMeta = {\n byId: this.byId.cid,\n byKey: this.byKey.cid,\n head,\n map: this.mapFnString,\n name: this.name,\n } as IdxMeta;\n indexerMeta.indexes?.set(this.name, idxMeta);\n }\n this.logger.Debug().Any(\"indexerMeta\", new Array(indexerMeta.indexes?.entries())).Msg(\"exit this.blockstore.transaction fn\");\n return indexerMeta as unknown as IndexTransactionMeta;\n });\n this.logger.Debug().Msg(\"post this.blockstore.transaction\");\n return meta;\n }\n}\n","import { Logger } from \"@adviser/cement\";\nimport { index } from \"./indexer.js\";\nimport type {\n ClockHead,\n MapFn,\n QueryOpts,\n ChangesOptions,\n DocSet,\n DocWithId,\n IndexKeyType,\n ListenerFn,\n DocResponse,\n BulkResponse,\n ChangesResponse,\n DocTypes,\n IndexRows,\n DocFragment,\n ChangesResponseRow,\n CRDTMeta,\n AllDocsQueryOpts,\n AllDocsResponse,\n SuperThis,\n Database,\n Ledger,\n} from \"./types.js\";\nimport { ensureLogger, NotFoundError } from \"./utils.js\";\n\nimport { makeName } from \"./utils.js\";\n\nexport function isDatabase(db: unknown): db is Database {\n return db instanceof DatabaseImpl;\n}\n\nexport class DatabaseImpl implements Database {\n onClosed(fn: () => void) {\n this.ledger.onClosed(fn);\n }\n close() {\n return this.ledger.close();\n }\n\n destroy() {\n return this.ledger.destroy();\n }\n\n ready(): Promise<void> {\n return this.ledger.ready();\n }\n\n readonly ledger: Ledger;\n readonly logger: Logger;\n readonly sthis: SuperThis;\n readonly id: string;\n\n constructor(ledger: Ledger) {\n this.sthis = ledger.sthis;\n this.ledger = ledger;\n this.id = ledger.id;\n this.logger = ensureLogger(this.sthis, \"Database\");\n }\n\n get name() {\n return this.ledger.name;\n }\n\n async get<T extends DocTypes>(id: string): Promise<DocWithId<T>> {\n if (!id) throw this.logger.Error().Str(\"db\", this.name).Msg(`Doc id is required`).AsError();\n\n await this.ready();\n this.logger.Debug().Str(\"id\", id).Msg(\"get\");\n const got = await this.ledger.crdt.get(id).catch((e) => {\n throw new NotFoundError(`Not found: ${id} - ${e.message}`);\n });\n if (!got) throw new NotFoundError(`Not found: ${id}`);\n const { doc } = got;\n return { ...(doc as unknown as DocWithId<T>), _id: id };\n }\n\n async put<T extends DocTypes>(doc: DocSet<T>): Promise<DocResponse> {\n await this.ready();\n this.logger.Debug().Str(\"id\", doc._id).Msg(\"put\");\n const { _id, ...value } = doc;\n const docId = _id || this.sthis.timeOrderedNextId().str;\n const result = (await this.ledger.writeQueue.push({\n id: docId,\n value: {\n ...(value as unknown as DocSet<T>),\n _id: docId,\n },\n })) as CRDTMeta;\n return { id: docId, clock: result?.head, name: this.name } as DocResponse;\n }\n\n async bulk<T extends DocTypes>(docs: DocSet<T>[]): Promise<BulkResponse> {\n await this.ready();\n\n const updates = docs.map((doc) => {\n const id = doc._id || this.sthis.timeOrderedNextId().str;\n return {\n id,\n value: {\n ...(doc as unknown as DocSet<T>),\n _id: id,\n },\n };\n });\n const result = (await this.ledger.writeQueue.bulk(updates)) as CRDTMeta;\n return { ids: updates.map((u) => u.id), clock: result.head, name: this.name } as BulkResponse;\n }\n\n async del(id: string): Promise<DocResponse> {\n await this.ready();\n this.logger.Debug().Str(\"id\", id).Msg(\"del\");\n const result = (await this.ledger.writeQueue.push({ id: id, del: true })) as CRDTMeta;\n return { id, clock: result?.head, name: this.name } as DocResponse;\n }\n\n async changes<T extends DocTypes>(since: ClockHead = [], opts: ChangesOptions = {}): Promise<ChangesResponse<T>> {\n await this.ready();\n this.logger.Debug().Any(\"since\", since).Any(\"opts\", opts).Msg(\"changes\");\n const { result, head } = await this.ledger.crdt.changes(since, opts);\n const rows: ChangesResponseRow<T>[] = result.map(({ id: key, value, del, clock }) => ({\n key,\n value: (del ? { _id: key, _deleted: true } : { _id: key, ...value }) as DocWithId<T>,\n clock,\n }));\n return { rows, clock: head, name: this.name };\n }\n\n async allDocs<T extends DocTypes>(opts: AllDocsQueryOpts = {}): Promise<AllDocsResponse<T>> {\n await this.ready();\n void opts;\n this.logger.Debug().Msg(\"allDocs\");\n const { result, head } = await this.ledger.crdt.allDocs();\n const rows = result.map(({ id: key, value, del }) => ({\n key,\n value: (del ? { _id: key, _deleted: true } : { _id: key, ...value }) as DocWithId<T>,\n }));\n return { rows, clock: head, name: this.name };\n }\n\n async allDocuments<T extends DocTypes>(): Promise<{\n rows: {\n key: string;\n value: DocWithId<T>;\n }[];\n clock: ClockHead;\n }> {\n return this.allDocs<T>();\n }\n\n subscribe<T extends DocTypes>(listener: ListenerFn<T>, updates?: boolean): () => void {\n return this.ledger.subscribe(listener, updates);\n }\n\n // todo if we add this onto dbs in fireproof.ts then we can make index.ts a separate package\n async query<K extends IndexKeyType, T extends DocTypes, R extends DocFragment = T>(\n field: string | MapFn<T>,\n opts: QueryOpts<K> = {},\n ): Promise<IndexRows<K, T, R>> {\n await this.ready();\n this.logger.Debug().Any(\"field\", field).Any(\"opts\", opts).Msg(\"query\");\n // const _crdt = this.ledger.crdt as unknown as CRDT<T>;\n const idx = typeof field === \"string\" ? index<K, T, R>(this, field) : index<K, T, R>(this, makeName(field.toString()), field);\n return await idx.query(opts);\n }\n\n async compact() {\n await this.ready();\n await this.ledger.crdt.compact();\n }\n}\n","import type { Block } from \"multiformats\";\nimport { Logger, ResolveOnce } from \"@adviser/cement\";\nimport { EncryptedBlockstore, type TransactionMeta, CompactFetcher, toStoreRuntime } from \"./blockstore/index.js\";\nimport {\n clockChangesSince,\n applyBulkUpdateToCrdt,\n getValueFromCrdt,\n readFiles,\n getAllEntries,\n clockVis,\n getBlock,\n doCompact,\n} from \"./crdt-helpers.js\";\nimport type {\n DocUpdate,\n CRDTMeta,\n ClockHead,\n ChangesOptions,\n DocValue,\n IndexKeyType,\n DocWithId,\n Falsy,\n SuperThis,\n IndexTransactionMeta,\n DocTypes,\n CRDT,\n CRDTClock,\n BaseBlockstore,\n CarTransaction,\n} from \"./types.js\";\nimport { index, type Index } from \"./indexer.js\";\n// import { blockstoreFactory } from \"./blockstore/transaction.js\";\nimport { ensureLogger } from \"./utils.js\";\nimport type { LedgerOpts } from \"./ledger.js\";\nimport { CRDTClockImpl } from \"./crdt-clock.js\";\n\nexport class CRDTImpl implements CRDT {\n readonly opts: LedgerOpts;\n\n readonly blockstore: BaseBlockstore;\n readonly indexBlockstore: BaseBlockstore;\n readonly indexers = new Map<string, Index<IndexKeyType, NonNullable<unknown>>>();\n readonly clock: CRDTClock;\n\n readonly logger: Logger;\n readonly sthis: SuperThis;\n // self reference to fullfill HasCRDT\n readonly crdt: CRDT;\n\n constructor(sthis: SuperThis, opts: LedgerOpts) {\n this.sthis = sthis;\n this.crdt = this;\n this.logger = ensureLogger(sthis, \"CRDT\");\n this.opts = opts;\n this.blockstore = new EncryptedBlockstore(sthis, {\n applyMeta: async (meta: TransactionMeta) => {\n const crdtMeta = meta as CRDTMeta;\n if (!crdtMeta.head) throw this.logger.Error().Msg(\"missing head\").AsError();\n await this.clock.applyHead(crdtMeta.head, []);\n },\n compact: async (blocks: CompactFetcher) => {\n await doCompact(blocks, this.clock.head, this.logger);\n return { head: this.clock.head } as TransactionMeta;\n },\n gatewayInterceptor: opts.gatewayInterceptor,\n // autoCompact: this.opts.autoCompact || 100,\n storeRuntime: toStoreRuntime(this.sthis, this.opts.storeEnDe),\n storeUrls: this.opts.storeUrls.data,\n keyBag: this.opts.keyBag,\n // public: this.opts.public,\n meta: this.opts.meta,\n // threshold: this.opts.threshold,\n });\n this.indexBlockstore = new EncryptedBlockstore(sthis, {\n // name: opts.name,\n applyMeta: async (meta: TransactionMeta) => {\n const idxCarMeta = meta as IndexTransactionMeta;\n if (!idxCarMeta.indexes) throw this.logger.Error().Msg(\"missing indexes\").AsError();\n for (const [name, idx] of Object.entries(idxCarMeta.indexes)) {\n index(this, name, undefined, idx);\n }\n },\n gatewayInterceptor: opts.gatewayInterceptor,\n storeRuntime: toStoreRuntime(this.sthis, this.opts.storeEnDe),\n storeUrls: this.opts.storeUrls.idx,\n keyBag: this.opts.keyBag,\n // public: this.opts.public,\n });\n this.clock = new CRDTClockImpl(this.blockstore);\n this.clock.onZoom(() => {\n for (const idx of this.indexers.values()) {\n idx._resetIndex();\n }\n });\n }\n\n async bulk<T extends DocTypes>(updates: DocUpdate<T>[]): Promise<CRDTMeta> {\n await this.ready();\n const prevHead = [...this.clock.head];\n\n const done = await this.blockstore.transaction<CRDTMeta>(async (blocks: CarTransaction): Promise<CRDTMeta> => {\n const { head } = await applyBulkUpdateToCrdt<DocTypes>(\n this.blockstore.ebOpts.storeRuntime,\n blocks,\n this.clock.head,\n updates,\n this.logger,\n );\n updates = updates.map((dupdate: DocUpdate<T>) => {\n // if (!dupdate.value) throw new Error(\"missing value\");\n readFiles(this.blockstore, { doc: dupdate.value as DocWithId<DocTypes> });\n return dupdate;\n });\n return { head };\n });\n await this.clock.applyHead(done.meta.head, prevHead, updates);\n return done.meta;\n }\n\n readonly onceReady: ResolveOnce<void> = new ResolveOnce<void>();\n async ready(): Promise<void> {\n return this.onceReady.once(async () => {\n try {\n // await this.blockstore.ready();\n // await this.indexBlockstore.ready();\n // await this.clock.ready();\n await Promise.all([this.blockstore.ready(), this.indexBlockstore.ready(), this.clock.ready()]);\n } catch (e) {\n throw this.logger.Error().Err(e).Msg(`CRDT is not ready`).AsError();\n }\n });\n }\n\n async close(): Promise<void> {\n // await this.blockstore.close();\n // await this.indexBlockstore.close();\n // await this.clock.close();\n await Promise.all([this.blockstore.close(), this.indexBlockstore.close(), this.clock.close()]);\n }\n\n async destroy(): Promise<void> {\n await Promise.all([this.blockstore.destroy(), this.indexBlockstore.destroy()]);\n }\n\n // if (snap) await this.clock.applyHead(crdtMeta.head, this.clock.head)\n\n async allDocs<T extends DocTypes>(): Promise<{ result: DocUpdate<T>[]; head: ClockHead }> {\n await this.ready();\n const result: DocUpdate<T>[] = [];\n for await (const entry of getAllEntries<DocTypes>(this.blockstore, this.clock.head, this.logger)) {\n result.push(entry as DocUpdate<T>);\n }\n return { result, head: this.clock.head };\n }\n\n async vis(): Promise<string> {\n await this.ready();\n const txt: string[] = [];\n for await (const line of clockVis(this.blockstore, this.clock.head)) {\n txt.push(line);\n }\n return txt.join(\"\\n\");\n }\n\n async getBlock(cidString: string): Promise<Block> {\n await this.ready();\n return await getBlock(this.blockstore, cidString);\n }\n\n async get(key: string): Promise<DocValue<DocTypes> | Falsy> {\n await this.ready();\n const result = await getValueFromCrdt<DocTypes>(this.blockstore, this.clock.head, key, this.logger);\n if (result.del) return undefined;\n return result;\n }\n\n async changes<T extends DocTypes>(\n since: ClockHead = [],\n opts: ChangesOptions = {},\n ): Promise<{\n result: DocUpdate<T>[];\n head: ClockHead;\n }> {\n await this.ready();\n return await clockChangesSince<T>(this.blockstore, this.clock.head, since, opts, this.logger);\n }\n\n async compact(): Promise<void> {\n const blocks = this.blockstore as EncryptedBlockstore;\n return await blocks.compact();\n }\n}\n","export * from \"./types.js\";\n\nexport * from \"./store-factory.js\";\nexport * from \"./serde-gateway.js\";\nexport * from \"./gateway.js\";\n\nexport * from \"./fp-envelope.js\";\n\nexport * from \"./store-factory.js\";\nexport * from \"./interceptor-gateway.js\";\n\nexport { createDbMetaEvent } from \"./store.js\";\n\nexport * from \"./register-store-protocol.js\";\n\nexport {\n EncryptedBlockstore,\n BaseBlockstoreImpl,\n CompactionFetcher,\n type BlockFetcher,\n CarTransactionImpl,\n type CarTransactionOpts,\n} from \"./transaction.js\";\nexport { Loader } from \"./loader.js\";\nexport { parseCarFile } from \"./loader-helpers.js\";\nexport { ConnectionBase } from \"./connection-base.js\";\n// export { setCryptoKeyFromGatewayMetaPayload, addCryptoKeyToGatewayMetaPayload } from \"./meta-key-helper.js\";\n","import type { CID, Link, Version } from \"multiformats\";\nimport type { BlockCodec } from \"../runtime/wait-pr-multiformats/codec-interface.js\";\nimport { CarTransaction, DocFileMeta, Falsy, StoreType, SuperThis } from \"../types.js\";\nimport { BlockFetcher } from \"./transaction.js\";\nimport { CommitQueue } from \"./commit-queue.js\";\nimport { KeyBag, KeyBagRuntime } from \"../runtime/key-bag.js\";\nimport { CoerceURI, CryptoRuntime, CTCryptoKey, Logger, Result, URI } from \"@adviser/cement\";\nimport { EventBlock } from \"@fireproof/vendor/@web3-storage/pail/clock\";\nimport { TaskManager } from \"./task-manager.js\";\nimport { SerdeGateway, SerdeGatewayInterceptor } from \"./serde-gateway.js\";\nimport { CarReader } from \"@fireproof/vendor/@ipld/car\";\n\nexport type AnyLink = Link<unknown, number, number, Version>;\nexport type CarGroup = AnyLink[];\nexport type CarLog = CarGroup[];\nexport type AnyAnyLink = Link<unknown, number, number, Version>;\n\nexport type AnyLinkFn = (cid: AnyLink) => Promise<AnyBlock | undefined>;\n\nexport interface AnyBlock {\n readonly cid: Link<unknown, number, number, Version>;\n readonly bytes: Uint8Array;\n}\n\nexport interface CIDBlock {\n readonly cid: CID<unknown, number, number, Version>;\n readonly bytes: Uint8Array;\n}\n\nexport function toCIDBlock(block: AnyBlock): CIDBlock {\n return block as CIDBlock;\n}\nexport interface AnyAnyBlock {\n readonly cid: AnyAnyLink;\n readonly bytes: Uint8Array;\n}\n\n// export interface EncryptOpts {\n// readonly key: ArrayBuffer;\n// readonly cid: AnyLink;\n// readonly bytes: Uint8Array;\n// }\n\nexport interface IvKeyIdData {\n readonly iv: Uint8Array;\n readonly keyId: Uint8Array;\n readonly data: Uint8Array;\n}\n\nexport interface IvAndBytes {\n readonly bytes: Uint8Array;\n readonly iv: Uint8Array;\n}\n\nexport interface BytesWithIv {\n readonly bytes: Uint8Array;\n readonly iv?: Uint8Array;\n}\n\n// export interface DecryptOpts {\n// readonly key: ArrayBuffer;\n// readonly value: IvAndBytes;\n// }\n\nexport interface AnyDecodedBlock {\n readonly cid: AnyLink;\n readonly bytes: Uint8Array;\n readonly value: Uint8Array;\n}\n\nexport interface CarMakeable {\n entries(): AsyncIterable<AnyBlock>;\n get(cid: AnyLink): Promise<AnyBlock | undefined>;\n}\n\nexport interface CarHeader<T> {\n readonly cars: CarLog;\n readonly compact: CarLog;\n readonly meta: T;\n}\n\n// type NestedData =\n// | Uint8Array\n// | string\n// | number\n// | boolean\n// | undefined\n// | null\n// | AnyLink\n// | NestedData[]\n// | { [key: string]: NestedData };\n\nexport interface TransactionWrapper<M extends TransactionMeta> {\n meta: M;\n cars?: CarGroup;\n t: CarTransaction;\n}\n\nexport type TransactionMeta = unknown;\n//CRDTMeta | IndexTransactionMeta | FileTransactionMeta;\n\n// export interface MakeCodecCrypto {\n// subtle: {\n// decrypt: (algo: { name: string; iv: Uint8Array; tagLength: number }, key: CryptoKey, data: Uint8Array) => Promise<ArrayBuffer>;\n// encrypt: (algo: { name: string; iv: Uint8Array; tagLength: number }, key: CryptoKey, data: Uint8Array) => Promise<ArrayBuffer>;\n// };\n// }\n\n// an implementation of this Interface contains the keymaterial\n// so that the fp-core can use the decrypt and encrypt without knowing the key\nexport interface EncryptedBlock {\n readonly value: IvAndBytes;\n}\n\nexport interface KeyMaterial {\n readonly key: Uint8Array;\n readonly keyStr: string;\n}\n\nexport interface KeyWithFingerPrint {\n readonly fingerPrint: string;\n readonly key: CTCryptoKey;\n}\n\nexport interface KeyWithFingerExtract extends KeyWithFingerPrint {\n extract(): Promise<KeyMaterial>;\n}\n\nexport interface CodecOpts {\n readonly ivCalc: \"random\" | \"hash\";\n readonly noIVVerify: boolean;\n}\nexport interface KeyedCrypto {\n readonly ivLength: number; // in bytes only 12 and 16 are allowed\n readonly logger: Logger;\n readonly crypto: CryptoRuntime;\n readonly url: URI;\n // readonly codec: BlockCodec<number, IvAndBytes>;\n // readonly isEncrypting: boolean;\n fingerPrint(): Promise<string>;\n algo(iv?: Uint8Array): { name: string; iv: Uint8Array; tagLength: number };\n codec(iv?: Uint8Array, codecOpts?: Partial<CodecOpts>): BlockCodec<number, Uint8Array>;\n _decrypt(data: IvAndBytes): Promise<Uint8Array>;\n _encrypt(data: BytesWithIv): Promise<Uint8Array>;\n // encode(data: Uint8Array): Promise<Uint8Array>;\n // decode(bytes: Uint8Array | ArrayBuffer): Promise<Uint8Array>;\n}\n\nexport interface BlobLike {\n /**\n * Returns a ReadableStream which yields the Blob data.\n */\n stream: () => ReadableStream;\n}\n\nexport interface StoreFactory {\n makeMetaStore?: (loader: Loadable) => Promise<MetaStore>;\n makeDataStore?: (loader: Loadable) => Promise<DataStore>;\n makeWALStore?: (loader: Loadable) => Promise<WALStore>;\n\n encodeFile?: (blob: BlobLike) => Promise<{ cid: AnyLink; blocks: AnyBlock[] }>;\n decodeFile?: (blocks: unknown, cid: AnyLink, meta: DocFileMeta) => Promise<File>;\n}\n\nexport interface StoreUrls {\n // string means local storage\n // URL means schema selects the storeType\n // readonly base: CoerceURI;\n readonly meta: CoerceURI;\n readonly data: CoerceURI;\n // readonly index: CoerceURI;\n readonly wal: CoerceURI;\n}\n\n// export interface StoreUrlBaseOpts {\n// readonly base?: CoerceURI;\n// readonly data?: Partial<StoreUrls>\n// readonly idx?: Partial<StoreUrls>\n// }\n\nexport interface StoreEnDeFile {\n readonly encodeFile: (blob: BlobLike) => Promise<{ cid: AnyLink; blocks: AnyBlock[] }>;\n readonly decodeFile: (blocks: unknown, cid: AnyLink, meta: DocFileMeta) => Promise<File>;\n}\n\nexport interface StoreUrlsOpts {\n // readonly urls?: StoreUrlBaseOpts;\n // readonly func?: StoreFactory;\n readonly base?: CoerceURI;\n readonly data?: Partial<StoreUrls>;\n readonly idx?: Partial<StoreUrls>;\n}\n\nexport interface StoreURIs {\n readonly meta: URI;\n readonly data: URI;\n readonly file: URI;\n readonly wal: URI;\n}\n\nexport interface StoreURIRuntime {\n readonly data: StoreURIs;\n readonly idx: StoreURIs;\n}\n\nexport interface StoreFactoryItem {\n readonly sthis: SuperThis;\n readonly url: URI;\n readonly gatewayInterceptor?: SerdeGatewayInterceptor;\n // readonly keybag: KeyBag;\n readonly loader: Loadable;\n}\n\nexport interface StoreRuntime {\n // readonly isIndex?: string; // index prefix\n //xx readonly stores: Partial<Stores>;\n // the factories should produce ready-to-use stores\n // which means they have to call start() on the store\n // to fullfill lifecycle requirements\n // to release resources, like one ledger connection\n // for all stores a refcount on close() should be used\n makeMetaStore(sfi: StoreFactoryItem): Promise<MetaStore>;\n makeDataStore(sfi: StoreFactoryItem): Promise<DataStore>;\n makeWALStore(sfi: StoreFactoryItem): Promise<WALStore>;\n encodeFile(blob: BlobLike): Promise<{ cid: AnyLink; blocks: AnyBlock[] }>;\n decodeFile(blocks: unknown, cid: AnyLink, meta: DocFileMeta): Promise<File>;\n}\n\nexport interface CommitOpts {\n readonly noLoader?: boolean;\n readonly compact?: boolean;\n // readonly public?: boolean;\n}\n\nexport interface DbMeta {\n readonly cars: CarGroup;\n // key?: string;\n}\n\n// export interface UploadMetaFnParams {\n// readonly name: string;\n// readonly branch: string;\n// }\n\n// export type FnParamTypes = \"data\" | \"file\";\n\n// export interface UploadDataFnParams {\n// readonly type: FnParamTypes;\n// readonly name: string;\n// readonly car: string;\n// readonly size: string;\n// }\n\n// export interface DownloadDataFnParams {\n// readonly type: FnParamTypes;\n// readonly name: string;\n// readonly car: string;\n// }\n\n// export interface DownloadMetaFnParams {\n// readonly name: string;\n// readonly branch: string;\n// }\n\nexport type LoadHandler = (dbMetas: DbMeta[]) => Promise<void>;\n\nexport interface RefLoadable {\n readonly loader: Loadable;\n}\nexport interface RefBlockstore {\n readonly blockstore: RefLoadable;\n}\n\nexport interface Connection {\n // readonly loader?: Loadable;\n readonly loaded: Promise<void>;\n // connectMeta(ref: RefLoadable | RefBlockstore): void;\n connectStorage(ref: RefLoadable | RefBlockstore): void;\n\n // metaUpload(bytes: Uint8Array, params: UploadMetaFnParams): Promise<Uint8Array[] | Falsy>;\n // dataUpload(bytes: Uint8Array, params: UploadDataFnParams, opts?: { public?: boolean }): Promise<void>;\n // metaDownload(params: DownloadMetaFnParams): Promise<Uint8Array[] | Falsy>;\n // dataDownload(params: DownloadDataFnParams): Promise<Uint8Array | Falsy>;\n}\n\nexport interface BaseStore {\n readonly storeType: StoreType;\n readonly realGateway: SerdeGateway;\n // readonly url: URI\n url(): URI;\n // readonly name: string;\n onStarted(fn: () => void): void;\n onClosed(fn: () => void): void;\n\n keyedCrypto(): Promise<KeyedCrypto>;\n\n close(): Promise<Result<void>>;\n destroy(): Promise<Result<void>>;\n readonly ready?: () => Promise<void>;\n start(): Promise<Result<URI>>;\n}\n\nexport interface DbMetaEvent {\n readonly eventCid: CarClockLink;\n readonly parents: CarClockHead;\n readonly dbMeta: DbMeta;\n}\n\nexport function DbMetaEventEqual(a: DbMetaEvent, b: DbMetaEvent): boolean {\n return (\n a.eventCid.equals(b.eventCid) &&\n a.parents.length === b.parents.length &&\n a.parents.every((p, i) => p.equals(b.parents[i])) &&\n a.dbMeta.cars.length === b.dbMeta.cars.length &&\n a.dbMeta.cars.every((c, i) => c.equals(b.dbMeta.cars[i]))\n );\n}\n\nexport function DbMetaEventsEqual(a: DbMetaEvent[], b: DbMetaEvent[]): boolean {\n return a.length === b.length && a.every((e, i) => DbMetaEventEqual(e, b[i]));\n}\n\nexport interface MetaStore extends BaseStore {\n readonly storeType: \"meta\";\n load(branch?: string): Promise<DbMeta[] | Falsy>;\n // branch is defaulted to \"main\"\n save(meta: DbMeta, branch?: string): Promise<Result<void>>;\n // onLoad(branch: string, loadHandler: LoadHandler): () => void;\n // handleByteHeads(byteHeads: Uint8Array, branch?: string): Promise<DbMetaEvent[]>;\n}\n\n// export interface RemoteMetaStore extends MetaStore {\n// }\n\nexport interface DataSaveOpts {\n readonly public: boolean;\n}\n\nexport interface DataStore extends BaseStore {\n readonly storeType: \"data\";\n load(cid: AnyLink): Promise<AnyBlock>;\n save(car: AnyBlock, opts?: DataSaveOpts): Promise</*AnyLink | */ void>;\n remove(cid: AnyLink): Promise<Result<void>>;\n}\n\nexport interface WALState {\n readonly operations: DbMeta[];\n readonly noLoaderOps: DbMeta[];\n readonly fileOperations: {\n readonly cid: AnyLink;\n readonly public: boolean;\n }[];\n}\n\nexport interface WALStore extends BaseStore {\n readonly storeType: \"wal\";\n ready(): Promise<void>;\n readonly processing?: Promise<void> | undefined;\n readonly processQueue: CommitQueue<void>;\n\n process(): Promise<void>;\n enqueue(dbMeta: DbMeta, opts: CommitOpts): Promise<void>;\n enqueueFile(fileCid: AnyLink /*, publicFile?: boolean*/): Promise<void>;\n load(): Promise<WALState | Falsy>;\n save(state: WALState): Promise<void>;\n}\n\nexport type CompactFetcher = BlockFetcher & {\n readonly loggedBlocks: CarTransaction;\n};\nexport type CompactFn = (blocks: CompactFetcher) => Promise<TransactionMeta>;\n\nexport interface StoreRuntimeUrls {\n readonly meta: URI;\n readonly data: URI;\n readonly wal: URI;\n}\n\nexport interface BlockstoreParams {\n readonly logger: Logger;\n readonly applyMeta: (meta: TransactionMeta, snap?: boolean) => Promise<void>;\n readonly compact: CompactFn;\n readonly autoCompact: number;\n readonly crypto: CryptoRuntime;\n readonly public: boolean;\n readonly meta: DbMeta;\n readonly threshold: number;\n readonly gatewayInterceptor?: SerdeGatewayInterceptor;\n readonly storeEnDeFile: Partial<StoreEnDeFile>;\n readonly keyBag: KeyBagRuntime;\n readonly storeUrls: StoreURIs;\n readonly storeRuntime: StoreRuntime;\n}\n\nexport type BlockstoreOpts = Partial<BlockstoreParams> & {\n readonly keyBag: KeyBagRuntime;\n readonly storeUrls: StoreURIs;\n readonly storeRuntime: StoreRuntime;\n};\n\nexport interface BlockstoreRuntime {\n readonly logger: Logger;\n readonly applyMeta: (meta: TransactionMeta, snap?: boolean) => Promise<void>;\n readonly compact: CompactFn;\n readonly autoCompact: number;\n readonly crypto: CryptoRuntime;\n readonly storeRuntime: StoreRuntime;\n readonly keyBag: KeyBagRuntime;\n readonly storeUrls: StoreURIs;\n readonly gatewayInterceptor?: SerdeGatewayInterceptor;\n // readonly storeEnDeFile: StoreEnDeFile;\n // readonly public: boolean;\n readonly meta?: DbMeta;\n // readonly name?: string;\n readonly threshold: number;\n}\n\nexport interface Loadable {\n // readonly name: string; // = \"\";\n readonly sthis: SuperThis;\n readonly ebOpts: BlockstoreRuntime;\n carLog: CarLog;\n remoteMetaStore?: MetaStore;\n remoteFileStore?: DataStore;\n remoteCarStore?: DataStore;\n readonly taskManager: TaskManager;\n\n ready(): Promise<void>;\n close(): Promise<void>;\n\n keyBag(): Promise<KeyBag>;\n metaStore(): Promise<MetaStore>;\n fileStore(): Promise<DataStore>;\n WALStore(): Promise<WALStore>;\n carStore(): Promise<DataStore>;\n\n handleDbMetasFromStore(metas: DbMeta[]): Promise<void>;\n\n commit<T = TransactionMeta>(t: CarTransaction, done: T, opts: CommitOpts): Promise<CarGroup>;\n destroy(): Promise<void>;\n getBlock(cid: AnyLink): Promise<AnyBlock | Falsy>;\n loadFileCar(cid: AnyLink /*, isPublic = false*/): Promise<CarReader>;\n loadCar(cid: AnyLink): Promise<CarReader>;\n commitFiles(\n t: CarTransaction,\n done: TransactionMeta /* opts: CommitOpts = { noLoader: false, compact: false } */,\n ): Promise<CarGroup>;\n entries(cache?: boolean): AsyncIterableIterator<AnyBlock>;\n}\n\nexport interface DbMetaBinary {\n readonly dbMeta: Uint8Array;\n}\nexport type DbMetaEventBlock = EventBlock<DbMetaBinary>;\nexport type CarClockLink = Link<DbMetaEventBlock, number, number, Version>;\nexport type CarClockHead = CarClockLink[];\n","import { Logger, KeyedResolvOnce, URI, Result } from \"@adviser/cement\";\n\nimport { decodeFile, encodeFile } from \"../runtime/files.js\";\nimport { DataStoreImpl, MetaStoreImpl, WALStoreImpl } from \"./store.js\";\nimport { StoreEnDeFile, StoreFactoryItem, StoreRuntime } from \"./types.js\";\nimport { PARAM, SuperThis } from \"../types.js\";\nimport { getGatewayFactoryItem } from \"./register-store-protocol.js\";\nimport { SerdeGateway } from \"./serde-gateway.js\";\n\ninterface SerdeGatewayInstances {\n readonly gateway: SerdeGateway;\n}\ninterface GatewayReady extends SerdeGatewayInstances {\n readonly url: URI;\n}\n\nconst onceGateway = new KeyedResolvOnce<GatewayReady>();\nconst gatewayInstances = new KeyedResolvOnce<SerdeGatewayInstances>();\nexport async function getStartedGateway(sthis: SuperThis, url: URI): Promise<Result<GatewayReady>> {\n return onceGateway.get(url.toString()).once(async () => {\n const item = getGatewayFactoryItem(url.protocol);\n if (item) {\n const ret = {\n url,\n ...(await gatewayInstances.get(url.protocol).once(async () => ({}))),\n gateway: await item.serdegateway(sthis),\n };\n const res = await ret.gateway.start(sthis, url);\n if (res.isErr()) {\n return Result.Err(sthis.logger.Error().Result(\"start\", res).Msg(\"start failed\").AsError());\n }\n ret.url = res.Ok();\n return Result.Ok(ret);\n }\n return Result.Err(sthis.logger.Warn().Url(url).Msg(\"unsupported protocol\").AsError());\n });\n}\n\nasync function dataStoreFactory(sfi: StoreFactoryItem): Promise<DataStoreImpl> {\n const storeUrl = sfi.url.build().setParam(PARAM.STORE, \"data\").URI();\n const rgateway = await getStartedGateway(sfi.sthis, storeUrl);\n if (rgateway.isErr()) {\n throw sfi.sthis.logger.Error().Result(\"err\", rgateway).Url(sfi.url).Msg(\"notfound\").AsError();\n }\n const gateway = rgateway.Ok();\n const store = new DataStoreImpl(sfi.sthis, gateway.url, {\n gateway: gateway.gateway,\n gatewayInterceptor: sfi.gatewayInterceptor,\n loader: sfi.loader,\n });\n return store;\n}\n\n// const onceLoadMetaGateway = new KeyedResolvOnce<Gateway>();\n// function loadMetaGateway(url: URI, logger: Logger) {\n// return onceLoadMetaGateway.get(url.protocol).once(async () => {\n// return await getGatewayFromURL(url, logger).then((item) => {\n// if (!item) {\n// throw logger.Error().Url(url).Msg(\"unsupported protocol or store\").AsError();\n// }\n// return item;\n// });\n// });\n// }\n\n// const onceMetaStoreFactory = new KeyedResolvOnce<MetaStoreImpl>();\nasync function metaStoreFactory(sfi: StoreFactoryItem): Promise<MetaStoreImpl> {\n const storeUrl = sfi.url.build().setParam(PARAM.STORE, \"meta\").URI();\n const rgateway = await getStartedGateway(sfi.sthis, storeUrl);\n if (rgateway.isErr()) {\n throw sfi.sthis.logger.Error().Result(\"err\", rgateway).Url(sfi.url).Msg(\"notfound\").AsError();\n }\n const gateway = rgateway.Ok();\n const store = new MetaStoreImpl(sfi.sthis, gateway.url, {\n gateway: gateway.gateway,\n gatewayInterceptor: sfi.gatewayInterceptor,\n loader: sfi.loader,\n });\n return store;\n}\n\n// const onceWalGateway = new KeyedResolvOnce<Gateway>();\n// function loadWalGateway(url: URI, logger: Logger) {\n// return onceWalGateway.get(url.protocol).once(async () => {\n// return await getGatewayFromURL(url, logger).then((item) => {\n// if (!item) {\n// throw logger.Error().Url(url).Msg(\"unsupported protocol or store\").AsError();\n// }\n// return item;\n// });\n// });\n// }\n\n// const onceRemoteWalFactory = new KeyedResolvOnce<WALStoreImpl>();\nasync function WALStoreFactory(sfi: StoreFactoryItem): Promise<WALStoreImpl> {\n const storeUrl = sfi.url.build().setParam(PARAM.STORE, \"wal\").URI();\n const rgateway = await getStartedGateway(sfi.sthis, storeUrl);\n if (rgateway.isErr()) {\n throw sfi.sthis.logger.Error().Result(\"err\", rgateway).Url(sfi.url).Msg(\"notfound\").AsError();\n }\n const gateway = rgateway.Ok();\n const store = new WALStoreImpl(sfi.sthis, gateway.url, {\n gateway: gateway.gateway,\n gatewayInterceptor: sfi.gatewayInterceptor,\n loader: sfi.loader,\n });\n return store;\n}\n\nasync function ensureStart<T>(store: T & { start: () => Promise<Result<URI>>; logger: Logger }): Promise<T> {\n const ret = await store.start();\n if (ret.isErr()) {\n throw store.logger.Error().Result(\"start\", ret).Msg(\"start failed\").AsError();\n }\n store.logger.Debug().Url(ret.Ok(), \"prepared\").Msg(\"produced\");\n return store;\n}\n\nexport function ensureStoreEnDeFile(ende?: Partial<StoreEnDeFile>): StoreEnDeFile {\n ende = ende || {};\n return {\n encodeFile: ende.encodeFile || encodeFile,\n decodeFile: ende.decodeFile || decodeFile,\n };\n}\n\nexport function toStoreRuntime(sthis: SuperThis, endeOpts: Partial<StoreEnDeFile> = {}): StoreRuntime {\n // const logger = ensureLogger(sthis, \"toStoreRuntime\", {});\n return {\n makeMetaStore: async (sfi: StoreFactoryItem) => ensureStart(await metaStoreFactory(sfi)),\n // async (loader: Loadable) => {\n // logger\n // .Debug()\n // .Str(\"fromOpts\", \"\" + !!endeOpts.func?.makeMetaStore)\n // .Msg(\"makeMetaStore\");\n // return ensureStart(await (endeOpts.func?.makeMetaStore || metaStoreFactory)(loader), logger);\n // },\n makeDataStore: async (sfi: StoreFactoryItem) => ensureStart(await dataStoreFactory(sfi)),\n // async (loader: Loadable) => {\n // logger\n // .Debug()\n // .Str(\"fromOpts\", \"\" + !!endeOpts.func?.makeDataStore)\n // .Msg(\"makeDataStore\");\n // return ensureStart(await (endeOpts.func?.makeDataStore || dataStoreFactory)(loader), logger);\n // },\n makeWALStore: async (sfi: StoreFactoryItem) => ensureStart(await WALStoreFactory(sfi)),\n // async (loader: Loadable) => {\n // logger\n // .Debug()\n // .Str(\"fromOpts\", \"\" + !!endeOpts.func?.makeWALStore)\n // .Msg(\"makeRemoteWAL\");\n // return ensureStart(await (endeOpts.func?.makeWALStore || remoteWalFactory)(loader), logger);\n // },\n\n ...ensureStoreEnDeFile(endeOpts),\n };\n}\n","import { exception2Result, Logger, ResolveOnce, Result, URI } from \"@adviser/cement\";\nimport type {\n AnyBlock,\n AnyLink,\n CommitOpts,\n DataSaveOpts,\n DataStore,\n DbMeta,\n WALStore as WALStore,\n WALState,\n LoadHandler,\n KeyedCrypto,\n Loadable,\n CarClockHead,\n DbMetaBinary,\n CarClockLink,\n DbMetaEvent,\n MetaStore,\n} from \"./types.js\";\nimport { Falsy, PARAM, StoreType, SuperThis, throwFalsy } from \"../types.js\";\nimport { SerdeGateway, SerdeGatewayInterceptor } from \"./serde-gateway.js\";\nimport { ensureLogger, inplaceFilter, isNotFoundError } from \"../utils.js\";\nimport { carLogIncludesGroup } from \"./loader.js\";\nimport { CommitQueue } from \"./commit-queue.js\";\nimport { keyedCryptoFactory } from \"../runtime/keyed-crypto.js\";\nimport { Car2FPMsg, File2FPMsg, FPEnvelopeCar, FPEnvelopeFile, FPEnvelopeMeta, FPEnvelopeWAL } from \"./fp-envelope.js\";\nimport { EventView } from \"@fireproof/vendor/@web3-storage/pail/clock/api\";\nimport { EventBlock } from \"@fireproof/vendor/@web3-storage/pail/clock\";\nimport { format } from \"@fireproof/vendor/@ipld/dag-json\";\n// import { createDbMetaEventBlock } from \"./meta-key-helper.js\";\nimport pRetry from \"p-retry\";\nimport pMap from \"p-map\";\nimport { Link } from \"multiformats\";\nimport { InterceptorGateway } from \"./interceptor-gateway.js\";\n\nfunction guardVersion(url: URI): Result<URI> {\n if (!url.hasParam(\"version\")) {\n return Result.Err(`missing version: ${url.toString()}`);\n }\n return Result.Ok(url);\n}\n\nexport interface StoreOpts {\n readonly gateway: SerdeGateway;\n // readonly keybag: KeyBag;\n readonly gatewayInterceptor?: SerdeGatewayInterceptor;\n readonly loader: Loadable;\n}\n\nexport abstract class BaseStoreImpl {\n // should be injectable\n\n abstract readonly storeType: StoreType;\n // readonly name: string;\n\n private _url: URI;\n readonly logger: Logger;\n readonly sthis: SuperThis;\n readonly gateway: SerdeGateway;\n readonly realGateway: SerdeGateway;\n // readonly keybag: KeyBag;\n readonly opts: StoreOpts;\n readonly loader: Loadable;\n // readonly loader: Loadable;\n constructor(sthis: SuperThis, url: URI, opts: StoreOpts, logger: Logger) {\n // this.name = name;\n this._url = url;\n this.opts = opts;\n // this.keybag = opts.keybag;\n this.loader = opts.loader;\n this.sthis = sthis;\n const name = this._url.getParam(PARAM.NAME);\n if (!name) {\n throw logger.Error().Url(this._url).Msg(\"missing name\").AsError();\n }\n this.logger = logger\n .With()\n .Str(\"this\", this.sthis.nextId().str)\n .Ref(\"url\", () => this._url.toString())\n // .Str(\"name\", name)\n .Logger();\n this.realGateway = opts.gateway;\n this.gateway = new InterceptorGateway(this.sthis, opts.gateway, opts.gatewayInterceptor);\n }\n\n url(): URI {\n return this._url;\n }\n\n readonly _onStarted: (() => void)[] = [];\n onStarted(fn: () => void) {\n this._onStarted.push(fn);\n }\n readonly _onClosed: (() => void)[] = [];\n onClosed(fn: () => void) {\n this._onClosed.push(fn);\n }\n abstract close(): Promise<Result<void>>;\n\n async ready() {\n return;\n }\n\n async keyedCrypto(): Promise<KeyedCrypto> {\n return keyedCryptoFactory(this._url, await this.loader.keyBag(), this.sthis);\n }\n\n async start(): Promise<Result<URI>> {\n this.logger.Debug().Str(\"storeType\", this.storeType).Msg(\"starting-gateway-pre\");\n this._url = this._url.build().setParam(PARAM.STORE, this.storeType).URI();\n const res = await this.gateway.start(this.sthis, this._url, this.loader);\n if (res.isErr()) {\n this.logger.Error().Result(\"gw-start\", res).Msg(\"started-gateway\");\n return res as Result<URI>;\n }\n this._url = res.Ok();\n // add storekey to url\n const kb = await this.loader.keyBag();\n const skRes = await kb.ensureKeyFromUrl(this._url, () => {\n const idx = this._url.getParam(PARAM.INDEX);\n const storeKeyName = [this.url().getParam(PARAM.NAME)];\n if (idx) {\n storeKeyName.push(idx);\n }\n storeKeyName.push(this.storeType);\n return storeKeyName.join(\":\");\n });\n if (skRes.isErr()) {\n return skRes as Result<URI>;\n }\n this._url = skRes.Ok();\n const version = guardVersion(this._url);\n if (version.isErr()) {\n this.logger.Error().Result(\"version\", version).Msg(\"guardVersion\");\n await this.close();\n return version;\n }\n if (this.ready) {\n const fn = this.ready.bind(this);\n const ready = await exception2Result(fn);\n if (ready.isErr()) {\n await this.close();\n return ready as Result<URI>;\n }\n }\n this._onStarted.forEach((fn) => fn());\n this.logger.Debug().Msg(\"started\");\n return version;\n }\n}\n\nexport async function createDbMetaEvent(sthis: SuperThis, dbMeta: DbMeta, parents: CarClockHead): Promise<DbMetaEvent> {\n const event = await EventBlock.create<DbMetaBinary>(\n {\n dbMeta: sthis.txt.encode(format(dbMeta)),\n },\n parents as unknown as Link<EventView<DbMetaBinary>, number, number, 1>[],\n );\n return {\n eventCid: event.cid as CarClockLink,\n dbMeta,\n parents,\n };\n}\n\nexport class MetaStoreImpl extends BaseStoreImpl implements MetaStore {\n readonly storeType = \"meta\";\n readonly subscribers = new Map<string, LoadHandler[]>();\n parents: CarClockHead = [];\n // remote: boolean;\n\n constructor(sthis: SuperThis, url: URI, opts: StoreOpts) {\n // const my = new URL(url.toString());\n // my.searchParams.set(\"storekey\", 'insecure');\n super(sthis, url, { ...opts }, ensureLogger(sthis, \"MetaStoreImpl\"));\n // this.remote = !!remote;\n if (/*this.remote && */ opts.gateway.subscribe) {\n this.onStarted(async () => {\n this.logger.Debug().Str(\"url\", this.url().toString()).Msg(\"Subscribing to the gateway\");\n opts.gateway.subscribe?.(\n this.sthis,\n this.url(),\n async ({ payload: dbMetas }: FPEnvelopeMeta) => {\n this.logger.Debug().Msg(\"Received message from gateway\");\n await Promise.all(\n dbMetas.map((dbMeta) => this.loader.taskManager?.handleEvent(dbMeta.eventCid, dbMeta.parents, dbMeta.dbMeta)),\n );\n this.updateParentsFromDbMetas(dbMetas);\n },\n this.loader,\n );\n });\n }\n }\n\n private updateParentsFromDbMetas(dbMetas: DbMetaEvent[]) {\n const cids = dbMetas.map((m) => m.eventCid);\n const dbMetaParents = dbMetas.flatMap((m) => m.parents);\n const uniqueParentsMap = new Map([...this.parents, ...cids].map((p) => [p.toString(), p]));\n const dbMetaParentsSet = new Set(dbMetaParents.map((p) => p.toString()));\n this.parents = Array.from(uniqueParentsMap.values()).filter((p) => !dbMetaParentsSet.has(p.toString()));\n }\n\n // async handleByteHeads(byteHeads: Uint8Array) {\n // // return await decodeGatewayMetaBytesToDbMeta(this.sthis, byteHeads);\n // const rDbMeta = await fpDeserialize(this.sthis, byteHeads, this.url());\n // if (rDbMeta.isErr()) {\n // throw this.logger.Error().Err(rDbMeta).Msg(\"error deserializing\").AsError();\n // }\n // return (rDbMeta.Ok() as FPEnvelopeMeta).payload;\n // }\n\n async load(): Promise<DbMeta[] | Falsy> {\n const branch = \"main\";\n const url = await this.gateway.buildUrl(this.sthis, this.url(), branch, this.loader);\n if (url.isErr()) {\n throw this.logger.Error().Result(\"buildUrl\", url).Str(\"branch\", branch).Msg(\"got error from gateway.buildUrl\").AsError();\n }\n const rfpEnv = await this.gateway.get(this.sthis, url.Ok(), this.loader);\n if (rfpEnv.isErr()) {\n if (isNotFoundError(rfpEnv)) {\n return undefined;\n }\n throw this.logger.Error().Url(url.Ok()).Err(rfpEnv).Msg(\"gateway get\").AsError();\n }\n const dbMetas = (rfpEnv.Ok() as FPEnvelopeMeta).payload;\n // const dbMetas = await this.handleByteHeads(fpMeta.payload);\n await this.loader.handleDbMetasFromStore(dbMetas.map((m) => m.dbMeta)); // the old one didn't await\n this.updateParentsFromDbMetas(dbMetas);\n return dbMetas.map((m) => m.dbMeta);\n }\n\n async save(meta: DbMeta, branch?: string): Promise<Result<void>> {\n branch = branch || \"main\";\n this.logger.Debug().Str(\"branch\", branch).Any(\"meta\", meta).Msg(\"saving meta\");\n\n // const fpMetas = await encodeEventsWithParents(this.sthis, [event], this.parents);\n const url = await this.gateway.buildUrl(this.sthis, this.url(), branch, this.loader);\n if (url.isErr()) {\n throw this.logger.Error().Err(url.Err()).Str(\"branch\", branch).Msg(\"got error from gateway.buildUrl\").AsError();\n }\n const dbMetaEvent = await createDbMetaEvent(this.sthis, meta, this.parents);\n const res = await this.gateway.put(\n this.sthis,\n url.Ok(),\n {\n type: \"meta\",\n payload: [dbMetaEvent],\n } as FPEnvelopeMeta,\n this.loader,\n );\n if (res.isErr()) {\n throw this.logger.Error().Err(res.Err()).Msg(\"got error from gateway.put\").AsError();\n }\n // await this.loader.handleDbMetasFromStore([meta]);\n // this.loader.taskManager?.eventsWeHandled.add(event.cid.toString());\n return res;\n }\n\n async close(): Promise<Result<void>> {\n await this.gateway.close(this.sthis, this.url(), this.loader);\n this._onClosed.forEach((fn) => fn());\n return Result.Ok(undefined);\n }\n async destroy(): Promise<Result<void>> {\n this.logger.Debug().Msg(\"destroy\");\n return this.gateway.destroy(this.sthis, this.url(), this.loader);\n }\n}\n\nexport class DataStoreImpl extends BaseStoreImpl implements DataStore {\n readonly storeType = \"data\";\n\n constructor(sthis: SuperThis, url: URI, opts: StoreOpts) {\n super(sthis, url, { ...opts }, ensureLogger(sthis, \"DataStoreImpl\"));\n }\n\n async load(cid: AnyLink): Promise<AnyBlock> {\n this.logger.Debug().Any(\"cid\", cid).Msg(\"loading\");\n const url = await this.gateway.buildUrl(this.sthis, this.url(), cid.toString(), this.loader);\n if (url.isErr()) {\n throw this.logger.Error().Err(url.Err()).Str(\"cid\", cid.toString()).Msg(\"got error from gateway.buildUrl\").AsError();\n }\n const res = await this.gateway.get(this.sthis, url.Ok(), this.loader);\n if (res.isErr()) {\n throw res.Err();\n }\n const fpenv = res.Ok() as FPEnvelopeFile | FPEnvelopeCar;\n switch (fpenv.type) {\n case \"car\":\n return { cid, bytes: fpenv.payload };\n case \"file\":\n return { cid, bytes: fpenv.payload };\n default:\n throw this.logger.Error().Msg(\"unexpected type\").AsError();\n }\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n async save(car: AnyBlock, opts?: DataSaveOpts): Promise</*AnyLink | */ void> {\n this.logger.Debug().Any(\"cid\", car.cid.toString()).Msg(\"saving\");\n const url = await this.gateway.buildUrl(this.sthis, this.url(), car.cid.toString(), this.loader);\n if (url.isErr()) {\n throw this.logger.Error().Err(url.Err()).Ref(\"cid\", car.cid).Msg(\"got error from gateway.buildUrl\").AsError();\n }\n // without URL changes in super-this branch we\n // can distinguish between car and file\n let fpMsg: Result<FPEnvelopeCar | FPEnvelopeFile>;\n switch (url.Ok().getParam(PARAM.STORE)) {\n case \"data\":\n if (url.Ok().getParam(PARAM.SUFFIX)) {\n fpMsg = Car2FPMsg(car.bytes);\n } else {\n fpMsg = File2FPMsg(car.bytes);\n }\n break;\n default:\n throw this.logger.Error().Str(\"store\", url.Ok().getParam(PARAM.STORE)).Msg(\"unexpected store\").AsError();\n }\n if (fpMsg.isErr()) {\n throw this.logger.Error().Err(fpMsg).Msg(\"got error from FPMsg2Car\").AsError();\n }\n const res = await this.gateway.put(this.sthis, url.Ok(), fpMsg.Ok(), this.loader);\n if (res.isErr()) {\n throw this.logger.Error().Err(res.Err()).Msg(\"got error from gateway.put\").AsError();\n }\n return res.Ok();\n }\n async remove(cid: AnyLink): Promise<Result<void>> {\n const url = await this.gateway.buildUrl(this.sthis, this.url(), cid.toString(), this.loader);\n if (url.isErr()) {\n return url;\n }\n return this.gateway.delete(this.sthis, url.Ok(), this.loader);\n }\n async close(): Promise<Result<void>> {\n await this.gateway.close(this.sthis, this.url(), this.loader);\n this._onClosed.forEach((fn) => fn());\n return Result.Ok(undefined);\n }\n destroy(): Promise<Result<void>> {\n this.logger.Debug().Msg(\"destroy\");\n return this.gateway.destroy(this.sthis, this.url(), this.loader);\n }\n}\n\nexport class WALStoreImpl extends BaseStoreImpl implements WALStore {\n readonly storeType = \"wal\";\n // readonly tag: string = \"rwal-base\";\n\n // readonly loader: Loadable;\n\n readonly _ready = new ResolveOnce<void>();\n\n readonly walState: WALState = { operations: [], noLoaderOps: [], fileOperations: [] };\n readonly processing: Promise<void> | undefined = undefined;\n readonly processQueue: CommitQueue<void> = new CommitQueue<void>();\n\n constructor(sthis: SuperThis, url: URI, opts: StoreOpts) {\n // const my = new URL(url.toString());\n // my.searchParams.set(\"storekey\", 'insecure');\n super(sthis, url, { ...opts }, ensureLogger(sthis, \"WALStoreImpl\"));\n // this.loader = loader;\n }\n\n async ready(): Promise<void> {\n return this._ready.once(async () => {\n const walState = await this.load().catch((e) => {\n this.logger.Error().Err(e).Msg(\"error loading wal\");\n return undefined;\n });\n this.walState.operations.splice(0, this.walState.operations.length);\n this.walState.fileOperations.splice(0, this.walState.fileOperations.length);\n if (walState) {\n this.walState.operations.push(...walState.operations);\n this.walState.fileOperations.push(...walState.fileOperations);\n }\n });\n }\n\n async enqueue(dbMeta: DbMeta, opts: CommitOpts) {\n await this.ready();\n if (opts.compact) {\n this.walState.operations.splice(0, this.walState.operations.length);\n this.walState.noLoaderOps.splice(0, this.walState.noLoaderOps.length);\n this.walState.noLoaderOps.push(dbMeta);\n } else if (opts.noLoader) {\n this.walState.noLoaderOps.push(dbMeta);\n } else {\n this.walState.operations.push(dbMeta);\n }\n await this.save(this.walState);\n if (!opts.noLoader) {\n void this.process();\n }\n }\n\n async enqueueFile(fileCid: AnyLink, publicFile = false) {\n await this.ready();\n this.walState.fileOperations.push({ cid: fileCid, public: publicFile });\n // await this.save(this.walState)\n }\n\n async process() {\n await this.ready();\n if (!this.loader.remoteCarStore) return;\n await this.processQueue.enqueue(async () => {\n try {\n await this._doProcess();\n } catch (e) {\n this.logger.Error().Any(\"error\", e).Msg(\"error processing wal\");\n }\n if (this.walState.operations.length || this.walState.fileOperations.length || this.walState.noLoaderOps.length) {\n setTimeout(() => void this.process(), 0);\n }\n });\n }\n\n async _doProcess() {\n if (!this.loader) return;\n if (!this.loader.remoteCarStore) return;\n\n const operations = [...this.walState.operations];\n const noLoaderOps = [...this.walState.noLoaderOps];\n const fileOperations = [...this.walState.fileOperations];\n\n if (operations.length + noLoaderOps.length + fileOperations.length === 0) return;\n\n const concurrencyLimit = 3;\n\n // Helper function to retry uploads\n const retryableUpload = <T>(fn: () => Promise<T>, description: string) =>\n pRetry(fn, {\n retries: 5,\n onFailedAttempt: (error) => {\n this.logger\n .Warn()\n .Msg(`Attempt ${error.attemptNumber} failed for ${description}. There are ${error.retriesLeft} retries left.`);\n },\n });\n\n try {\n // Process noLoaderOps\n await pMap(\n noLoaderOps,\n async (dbMeta) => {\n await retryableUpload(async () => {\n if (!this.loader) {\n return;\n }\n for (const cid of dbMeta.cars) {\n const car = await (await this.loader.carStore()).load(cid);\n if (!car) {\n if (carLogIncludesGroup(this.loader.carLog, dbMeta.cars)) {\n throw this.logger.Error().Ref(\"cid\", cid).Msg(\"missing local car\").AsError();\n }\n } else {\n await throwFalsy(this.loader.remoteCarStore).save(car);\n }\n }\n // Remove from walState after successful upload\n inplaceFilter(this.walState.noLoaderOps, (op) => op !== dbMeta);\n }, `noLoaderOp with dbMeta.cars=${dbMeta.cars.toString()}`);\n },\n { concurrency: concurrencyLimit },\n );\n\n // Process operations\n await pMap(\n operations,\n async (dbMeta) => {\n await retryableUpload(async () => {\n if (!this.loader) {\n return;\n }\n for (const cid of dbMeta.cars) {\n const car = await (await this.loader.carStore()).load(cid);\n if (!car) {\n if (carLogIncludesGroup(this.loader.carLog, dbMeta.cars)) {\n throw this.logger.Error().Ref(\"cid\", cid).Msg(`missing local car`).AsError();\n }\n } else {\n await throwFalsy(this.loader.remoteCarStore).save(car);\n }\n }\n // Remove from walState after successful upload\n inplaceFilter(this.walState.operations, (op) => op !== dbMeta);\n }, `operation with dbMeta.cars=${dbMeta.cars.toString()}`);\n },\n { concurrency: concurrencyLimit },\n );\n\n // Process fileOperations\n await pMap(\n fileOperations,\n async ({ cid: fileCid, public: publicFile }) => {\n await retryableUpload(async () => {\n if (!this.loader) {\n return;\n }\n const fileBlock = await (await this.loader.fileStore()).load(fileCid);\n if (!fileBlock) {\n throw this.logger.Error().Ref(\"cid\", fileCid).Msg(\"missing file block\").AsError();\n }\n await this.loader.remoteFileStore?.save(fileBlock, { public: publicFile });\n // Remove from walState after successful upload\n inplaceFilter(this.walState.fileOperations, (op) => op.cid !== fileCid);\n }, `fileOperation with cid=${fileCid.toString()}`);\n },\n { concurrency: concurrencyLimit },\n );\n\n // If all uploads succeeded, send the last dbMeta to remoteMetaStore\n if (operations.length) {\n const lastOp = operations[operations.length - 1];\n await retryableUpload(async () => {\n if (!this.loader) {\n return;\n }\n await this.loader.remoteMetaStore?.save(lastOp);\n }, `remoteMetaStore save with dbMeta.cars=${lastOp.cars.toString()}`);\n }\n } catch (error) {\n // Log the error\n this.logger.Error().Any(\"error\", error).Msg(\"Processing failed\");\n // Do not proceed to send metadata if any uploads failed\n return;\n } finally {\n // Always save the WAL state\n await this.save(this.walState);\n }\n }\n\n async load(): Promise<WALState | Falsy> {\n this.logger.Debug().Msg(\"loading\");\n const filepath = await this.gateway.buildUrl(this.sthis, this.url(), \"main\", this.loader);\n if (filepath.isErr()) {\n throw this.logger.Error().Err(filepath.Err()).Url(this.url()).Msg(\"error building url\").AsError();\n }\n const bytes = (await this.gateway.get(this.sthis, filepath.Ok(), this.loader)) as Result<FPEnvelopeWAL>;\n if (bytes.isErr()) {\n if (isNotFoundError(bytes)) {\n return undefined;\n }\n throw this.logger.Error().Err(bytes.Err()).Msg(\"error get\").AsError();\n }\n if (bytes.Ok().type !== \"wal\") {\n throw this.logger.Error().Str(\"type\", bytes.Ok().type).Msg(\"unexpected type\").AsError();\n }\n return bytes.Ok().payload;\n }\n\n async save(state: WALState) {\n const filepath = await this.gateway.buildUrl(this.sthis, this.url(), \"main\", this.loader);\n if (filepath.isErr()) {\n throw this.logger.Error().Err(filepath.Err()).Url(this.url()).Msg(\"error building url\").AsError();\n }\n // let encoded: ToString<WALState>;\n // try {\n // encoded = format(state);\n // } catch (e) {\n // throw this.logger.Error().Err(e).Any(\"state\", state).Msg(\"error format\").AsError();\n // }\n const res = await this.gateway.put(\n this.sthis,\n filepath.Ok(),\n {\n type: \"wal\",\n payload: state,\n } as FPEnvelopeWAL,\n this.loader,\n );\n if (res.isErr()) {\n throw this.logger.Error().Err(res.Err()).Str(\"filePath\", filepath.Ok().toString()).Msg(\"error saving\").AsError();\n }\n }\n\n async close() {\n await this.gateway.close(this.sthis, this.url(), this.loader);\n this._onClosed.forEach((fn) => fn());\n return Result.Ok(undefined);\n }\n\n destroy() {\n this.logger.Debug().Msg(\"destroy\");\n return this.gateway.destroy(this.sthis, this.url(), this.loader);\n }\n}\n","import pLimit from \"p-limit\";\nimport { CarReader } from \"@fireproof/vendor/@ipld/car/reader\";\nimport { Logger, ResolveOnce } from \"@adviser/cement\";\n// import { uuidv4 } from \"uuidv7\";\n\nimport {\n type AnyBlock,\n type AnyLink,\n type CarHeader,\n type CommitOpts,\n type DbMeta,\n type TransactionMeta,\n type CarGroup,\n type CarLog,\n DataStore,\n WALStore,\n // RemoteMetaStore,\n // RemoteMetaStore,\n MetaStore,\n BaseStore,\n type Loadable,\n BlockstoreRuntime,\n BlockstoreOpts,\n} from \"./types.js\";\n\nimport { parseCarFile } from \"./loader-helpers.js\";\n\nimport { defaultedBlockstoreRuntime } from \"./transaction.js\";\nimport { CommitQueue } from \"./commit-queue.js\";\nimport type { CarTransaction, Falsy, SuperThis } from \"../types.js\";\nimport { getKeyBag, KeyBag } from \"../runtime/key-bag.js\";\nimport { commit, commitFiles, CommitParams } from \"./commitor.js\";\nimport { decode } from \"../runtime/wait-pr-multiformats/block.js\";\nimport { sha256 as hasher } from \"multiformats/hashes/sha2\";\nimport { TaskManager } from \"./task-manager.js\";\n\nexport function carLogIncludesGroup(list: CarLog, cids: CarGroup) {\n return list.some((arr: CarGroup) => {\n return arr.toString() === cids.toString();\n });\n}\n\n// this works for car groups because toString looks like bafy,bafy\nfunction uniqueCids(list: CarLog, remove = new Set<string>()): CarLog {\n const byString = new Map<string, CarGroup>();\n for (const cid of list) {\n if (remove.has(cid.toString())) continue;\n byString.set(cid.toString(), cid);\n }\n return [...byString.values()];\n}\n\n// export interface DecoderAndCarReader extends CarReader {\n// readonly decoder: BlockDecoder<number, Uint8Array>;\n// }\n\nexport class Loader implements Loadable {\n // readonly name: string;\n readonly ebOpts: BlockstoreRuntime;\n readonly commitQueue: CommitQueue<CarGroup> = new CommitQueue<CarGroup>();\n readonly isCompacting = false;\n readonly carReaders: Map<string, Promise<CarReader>> = new Map<string, Promise<CarReader>>();\n readonly seenCompacted: Set<string> = new Set<string>();\n readonly processedCars: Set<string> = new Set<string>();\n readonly sthis: SuperThis;\n readonly taskManager: TaskManager;\n\n carLog: CarLog = [];\n // key?: string;\n // keyId?: string;\n remoteMetaStore?: MetaStore;\n remoteCarStore?: DataStore;\n remoteFileStore?: DataStore;\n\n private getBlockCache = new Map<string, AnyBlock>();\n private seenMeta = new Set<string>();\n private writeLimit = pLimit(1);\n\n private readonly _carStore = new ResolveOnce<DataStore>();\n async carStore(): Promise<DataStore> {\n return this._carStore.once(async () =>\n this.ebOpts.storeRuntime.makeDataStore({\n sthis: this.sthis,\n gatewayInterceptor: this.ebOpts.gatewayInterceptor,\n url: this.ebOpts.storeUrls.data,\n // keybag: await this.keyBag(),\n loader: this,\n }),\n );\n }\n\n private readonly _fileStore = new ResolveOnce<DataStore>();\n async fileStore(): Promise<DataStore> {\n return this._fileStore.once(async () =>\n this.ebOpts.storeRuntime.makeDataStore({\n sthis: this.sthis,\n gatewayInterceptor: this.ebOpts.gatewayInterceptor,\n url: this.ebOpts.storeUrls.file,\n // keybag: await this.keyBag(),\n loader: this,\n }),\n );\n }\n private readonly _WALStore = new ResolveOnce<WALStore>();\n async WALStore(): Promise<WALStore> {\n return this._WALStore.once(async () =>\n this.ebOpts.storeRuntime.makeWALStore({\n sthis: this.sthis,\n gatewayInterceptor: this.ebOpts.gatewayInterceptor,\n url: this.ebOpts.storeUrls.wal,\n // keybag: await this.keyBag(),\n loader: this,\n }),\n );\n }\n\n private readonly _metaStore = new ResolveOnce<MetaStore>();\n async metaStore(): Promise<MetaStore> {\n return this._metaStore.once(async () =>\n this.ebOpts.storeRuntime.makeMetaStore({\n sthis: this.sthis,\n gatewayInterceptor: this.ebOpts.gatewayInterceptor,\n url: this.ebOpts.storeUrls.meta,\n // keybag: await this.keyBag(),\n loader: this,\n }),\n );\n }\n\n keyBag(): Promise<KeyBag> {\n return getKeyBag(this.sthis, this.ebOpts.keyBag);\n }\n\n private readonly onceReady: ResolveOnce<void> = new ResolveOnce<void>();\n async ready(): Promise<void> {\n return this.onceReady.once(async () => {\n const metas = await (await this.metaStore()).load();\n if (this.ebOpts.meta) {\n await this.handleDbMetasFromStore([this.ebOpts.meta]);\n } else if (metas) {\n await this.handleDbMetasFromStore(metas);\n }\n });\n }\n\n async close() {\n await this.commitQueue.waitIdle();\n const toClose = await Promise.all([this.carStore(), this.metaStore(), this.fileStore(), this.WALStore()]);\n await Promise.all(toClose.map((store) => store.close()));\n }\n\n async destroy() {\n const toDestroy = await Promise.all([this.carStore(), this.metaStore(), this.fileStore(), this.WALStore()]);\n await Promise.all(toDestroy.map((store) => store.destroy()));\n }\n\n readonly logger: Logger;\n constructor(sthis: SuperThis, ebOpts: BlockstoreOpts) {\n // this.name = name;\n // console.log(\"Loader\", name, ebOpts)\n this.sthis = sthis;\n this.ebOpts = defaultedBlockstoreRuntime(\n sthis,\n {\n ...ebOpts,\n // name,\n },\n \"Loader\",\n );\n this.logger = this.ebOpts.logger;\n this.taskManager = new TaskManager(sthis, async (dbMeta: DbMeta) => {\n await this.handleDbMetasFromStore([dbMeta]);\n });\n }\n\n // async snapToCar(carCid: AnyLink | string) {\n // await this.ready\n // if (typeof carCid === 'string') {\n // carCid = CID.parse(carCid)\n // }\n // const carHeader = await this.loadCarHeaderFromMeta({ car: carCid, key: this.key || null })\n // this.carLog = [carCid, ...carHeader.cars]\n // await this.getMoreReaders(carHeader.cars)\n // await this._applyCarHeader(carHeader, true)\n // }\n\n async handleDbMetasFromStore(metas: DbMeta[]): Promise<void> {\n this.logger.Debug().Any(\"metas\", metas).Msg(\"handleDbMetasFromStore\");\n for (const meta of metas) {\n await this.writeLimit(async () => {\n await this.mergeDbMetaIntoClock(meta);\n });\n }\n }\n\n async mergeDbMetaIntoClock(meta: DbMeta): Promise<void> {\n if (this.isCompacting) {\n throw this.logger.Error().Msg(\"cannot merge while compacting\").AsError();\n }\n\n if (this.seenMeta.has(meta.cars.toString())) return;\n this.seenMeta.add(meta.cars.toString());\n\n // if (meta.key) {\n // await this.setKey(meta.key);\n // }\n if (carLogIncludesGroup(this.carLog, meta.cars)) {\n return;\n }\n const carHeader = await this.loadCarHeaderFromMeta<TransactionMeta>(meta);\n // fetch other cars down the compact log?\n // todo we should use a CID set for the compacted cids (how to expire?)\n // console.log('merge carHeader', carHeader.head.length, carHeader.head.toString(), meta.car.toString())\n carHeader.compact.map((c) => c.toString()).forEach(this.seenCompacted.add, this.seenCompacted);\n await this.getMoreReaders(carHeader.cars.flat());\n this.carLog = [...uniqueCids([meta.cars, ...this.carLog, ...carHeader.cars], this.seenCompacted)];\n await this.ebOpts.applyMeta?.(carHeader.meta);\n }\n\n // protected async ingestKeyFromMeta(meta: DbMeta): Promise<void> {\n // const { key } = meta;\n // if (key) {\n // await this.setKey(key);\n // }\n // }\n\n async loadCarHeaderFromMeta<T>({ cars: cids }: DbMeta): Promise<CarHeader<T>> {\n //Call loadCar for every cid\n const reader = await this.loadCar(cids[0]);\n return await parseCarFile(reader, this.logger);\n }\n\n // async _getKey(): Promise<string | undefined> {\n // if (this.key) return this.key;\n // // generate a random key\n // if (!this.ebOpts.public) {\n // await this.setKey(toHexString(this.ebOpts.crypto.randomBytes(32)));\n // }\n // return this.key || undefined;\n // }\n\n async commitFiles(\n t: CarTransaction,\n done: TransactionMeta,\n // opts: CommitOpts = { noLoader: false, compact: false },\n ): Promise<CarGroup> {\n await this.ready();\n const fstore = await this.fileStore();\n const wstore = await this.WALStore();\n return this.commitQueue.enqueue(() => commitFiles(fstore, wstore, t, done));\n }\n\n async loadFileCar(cid: AnyLink /*, isPublic = false*/): Promise<CarReader> {\n return await this.storesLoadCar(cid, await this.fileStore(), this.remoteFileStore);\n }\n\n async commit<T = TransactionMeta>(\n t: CarTransaction,\n done: T,\n opts: CommitOpts = { noLoader: false, compact: false },\n ): Promise<CarGroup> {\n await this.ready();\n const carStore = await this.carStore();\n const params: CommitParams = {\n encoder: (await carStore.keyedCrypto()).codec(),\n carLog: this.carLog,\n carStore: carStore,\n WALStore: await this.WALStore(),\n metaStore: await this.metaStore(),\n threshold: this.ebOpts.threshold,\n };\n return this.commitQueue.enqueue(async () => {\n await this.cacheTransaction(t);\n const ret = await commit(params, t, done, opts);\n await this.updateCarLog(ret.cgrp, ret.header, !!opts.compact);\n return ret.cgrp;\n });\n }\n\n async updateCarLog<T>(cids: CarGroup, fp: CarHeader<T>, compact: boolean): Promise<void> {\n if (compact) {\n const previousCompactCid = fp.compact[fp.compact.length - 1];\n fp.compact.map((c) => c.toString()).forEach(this.seenCompacted.add, this.seenCompacted);\n this.carLog = [...uniqueCids([...this.carLog, ...fp.cars, cids], this.seenCompacted)];\n await this.removeCidsForCompact(previousCompactCid[0]).catch((e) => e);\n } else {\n this.carLog.unshift(cids);\n }\n }\n\n async cacheTransaction(t: CarTransaction) {\n for await (const block of t.entries()) {\n const sBlock = block.cid.toString();\n if (!this.getBlockCache.has(sBlock)) {\n this.getBlockCache.set(sBlock, block);\n }\n }\n }\n\n async cacheCarReader(carCidStr: string, reader: CarReader) {\n if (this.processedCars.has(carCidStr)) return;\n this.processedCars.add(carCidStr);\n for await (const block of reader.blocks()) {\n const sBlock = block.cid.toString();\n if (!this.getBlockCache.has(sBlock)) {\n this.getBlockCache.set(sBlock, block);\n }\n }\n }\n\n async removeCidsForCompact(cid: AnyLink) {\n const carHeader = await this.loadCarHeaderFromMeta({\n cars: [cid],\n } as unknown as DbMeta);\n for (const cids of carHeader.compact) {\n for (const cid of cids) {\n await (await this.carStore()).remove(cid);\n }\n }\n }\n\n // async flushCars() {\n // await this.ready\n // // for each cid in car log, make a dbMeta\n // for (const cid of this.carLog) {\n // const dbMeta = { car: cid, key: this.key || null } as DbMeta\n // await this.remoteWAL!.enqueue(dbMeta, { public: false })\n // }\n // }\n\n async *entries(cache = true): AsyncIterableIterator<AnyBlock> {\n await this.ready();\n if (cache) {\n for (const [, block] of this.getBlockCache) {\n yield block;\n }\n } else {\n for (const [, block] of this.getBlockCache) {\n yield block;\n }\n for (const cids of this.carLog) {\n for (const cid of cids) {\n const reader = await this.loadCar(cid);\n if (!reader) throw this.logger.Error().Ref(\"cid\", cid).Msg(\"missing car reader\").AsError();\n for await (const block of reader.blocks()) {\n const sCid = block.cid.toString();\n if (!this.getBlockCache.has(sCid)) {\n yield block;\n }\n }\n }\n }\n }\n }\n\n async getBlock(cid: AnyLink): Promise<AnyBlock | Falsy> {\n await this.ready();\n const sCid = cid.toString();\n if (this.getBlockCache.has(sCid)) return this.getBlockCache.get(sCid);\n\n const getCarCid = async (carCid: AnyLink) => {\n if (this.getBlockCache.has(sCid)) return this.getBlockCache.get(sCid);\n const reader = await this.loadCar(carCid);\n if (!reader) {\n throw this.logger.Error().Ref(\"cid\", carCid).Msg(\"missing car reader\").AsError();\n }\n await this.cacheCarReader(carCid.toString(), reader).catch(() => {\n return;\n });\n if (this.getBlockCache.has(sCid)) return this.getBlockCache.get(sCid);\n throw this.logger.Error().Str(\"cid\", sCid).Msg(\"block not in reader\").AsError();\n };\n\n const getCompactCarCids = async (carCid: AnyLink) => {\n // console.log(\"getCompactCarCids\", carCid.toString())\n\n const reader = await this.loadCar(carCid);\n if (!reader) {\n throw this.logger.Error().Str(\"cid\", carCid.toString()).Msg(\"missing car reader\").AsError();\n }\n\n const header = await parseCarFile(reader, this.logger);\n\n const compacts = header.compact;\n\n let got: AnyBlock | undefined;\n const batchSize = 5;\n for (let i = 0; i < compacts.length; i += batchSize) {\n const promises: Promise<AnyBlock | undefined>[] = [];\n for (let j = i; j < Math.min(i + batchSize, compacts.length); j++) {\n for (const cid of compacts[j]) {\n promises.push(getCarCid(cid));\n }\n }\n try {\n got = await Promise.any(promises);\n } catch {\n // Ignore the error and continue with the next iteration\n }\n if (got) break;\n }\n\n if (this.getBlockCache.has(sCid)) return this.getBlockCache.get(sCid);\n throw this.logger.Error().Str(\"cid\", sCid).Msg(\"block not in compact reader\").AsError();\n };\n\n let got;\n const batchSize = 5;\n for (let i = 0; i < this.carLog.length; i += batchSize) {\n const batch = this.carLog.slice(i, i + batchSize);\n const promises: Promise<AnyBlock | undefined>[] = batch.flatMap((slice) => slice.map(getCarCid));\n try {\n got = await Promise.any(promises);\n } catch {\n // Ignore the error and continue with the next iteration\n }\n if (got) break;\n }\n\n if (!got) {\n try {\n got = await getCompactCarCids(this.carLog[this.carLog.length - 1][0]);\n } catch {\n // Ignore the error and continue with the next iteration\n }\n }\n\n return got;\n }\n\n async loadCar(cid: AnyLink): Promise<CarReader> {\n if (!this.carStore) {\n throw this.logger.Error().Msg(\"car store not initialized\").AsError();\n }\n const loaded = await this.storesLoadCar(cid, await this.carStore(), this.remoteCarStore);\n return loaded;\n }\n\n async makeDecoderAndCarReader(cid: AnyLink, local: DataStore, remote?: DataStore): Promise<CarReader> {\n const cidsString = cid.toString();\n let loadedCar: AnyBlock | undefined = undefined;\n let activeStore: BaseStore = local;\n try {\n //loadedCar now is an array of AnyBlocks\n this.logger.Debug().Str(\"cid\", cidsString).Msg(\"loading car\");\n loadedCar = await local.load(cid);\n this.logger.Debug().Bool(\"loadedCar\", loadedCar).Msg(\"loaded\");\n } catch (e) {\n if (remote) {\n const remoteCar = await remote.load(cid);\n if (remoteCar) {\n // todo test for this\n this.logger.Debug().Ref(\"cid\", remoteCar.cid).Msg(\"saving remote car locally\");\n await local.save(remoteCar);\n loadedCar = remoteCar;\n activeStore = remote;\n }\n } else {\n this.logger.Error().Str(\"cid\", cidsString).Err(e).Msg(\"loading car\");\n }\n }\n if (!loadedCar) {\n throw this.logger.Error().Url(local.url()).Str(\"cid\", cidsString).Msg(\"missing car files\").AsError();\n }\n //This needs a fix as well as the fromBytes function expects a Uint8Array\n //Either we can merge the bytes or return an array of rawReaders\n const bytes = await decode({ bytes: loadedCar.bytes, hasher, codec: (await activeStore.keyedCrypto()).codec() }); // as Uint8Array,\n const rawReader = await CarReader.fromBytes(bytes.value);\n const readerP = Promise.resolve(rawReader);\n // const kc = await activeStore.keyedCrypto()\n // const readerP = !kc.isEncrypting ? Promise.resolve(rawReader) : this.ensureDecryptedReader(activeStore, rawReader);\n\n const cachedReaderP = readerP.then(async (reader) => {\n await this.cacheCarReader(cidsString, reader).catch((e) => {\n this.logger.Error().Err(e).Str(\"cid\", cidsString).Msg(\"error caching car reader\");\n return;\n });\n return reader;\n });\n this.carReaders.set(cidsString, cachedReaderP);\n return readerP;\n }\n\n //What if instead it returns an Array of CarHeader\n protected async storesLoadCar(cid: AnyLink, local: DataStore, remote?: DataStore): Promise<CarReader> {\n const cidsString = cid.toString();\n let dacr = this.carReaders.get(cidsString);\n if (!dacr) {\n dacr = this.makeDecoderAndCarReader(cid, local, remote);\n this.carReaders.set(cidsString, dacr);\n }\n return dacr;\n }\n\n protected async getMoreReaders(cids: AnyLink[]) {\n const limit = pLimit(5);\n const missing = cids.filter((cid) => !this.carReaders.has(cid.toString()));\n await Promise.all(missing.map((cid) => limit(() => this.loadCar(cid))));\n }\n}\n","import { decode } from \"../runtime/wait-pr-multiformats/block.js\";\nimport { sha256 as hasher } from \"multiformats/hashes/sha2\";\nimport * as dagCodec from \"@fireproof/vendor/@ipld/dag-cbor\";\nimport type { Logger } from \"@adviser/cement\";\n\nimport { CarHeader } from \"./types.js\";\n// import { decodeRunLength } from \"../runtime/keyed-crypto.js\";\n// import { base58btc } from \"multiformats/bases/base58\";\nimport { CarReader } from \"@fireproof/vendor/@ipld/car/reader\";\n\n// export async function encodeCarHeader<T>(fp: CarHeader<T>) {\n// return (await encode({\n// value: { fp },\n// hasher,\n// codec: dagCodec,\n// })) as AnyBlock;\n// }\n\n// function wrapDagDecoder<T>(dec: BlockDecoder<number, Uint8Array>): BlockDecoder<number, CarDecoded<T>> {\n// return {\n// code: dec.code,\n// decode: async (block: Uint8Array) => dagCodec.decode(await dec.decode(block))\n// }\n// }\n\ninterface CarDecoded<T> {\n readonly fp: CarHeader<T>;\n}\n\nexport async function parseCarFile<T>(reader: CarReader, logger: Logger): Promise<CarHeader<T>> {\n const roots = await reader.getRoots();\n const header = await reader.get(roots[0]);\n if (!header) throw logger.Error().Msg(\"missing header block\").AsError();\n const dec = await decode({ bytes: header.bytes, hasher, codec: dagCodec });\n // console.log(\"parseCarFile-done\", roots[0].toString(), header)\n // const { value } = await decode({\n // bytes: header.bytes,\n // hasher,\n // codec: await wrapDagDecoder<T>({\n // code: dagCodec.code,\n // decode: (block) => {\n // const ui = new Uint8Array(block);\n // const iv = decodeRunLength(ui, 0, logger);\n // const key = decodeRunLength(ui, iv.next, logger);\n // // const fp = decodeRunLength(ui, key.next, logger);\n // console.log(\"parseCarFile\", { iv: iv.data.length, key: base58btc.encode(key.data) }, (new Error()).stack);\n // return ui\n // }\n // })\n // });\n const fpvalue = dec.value as CarDecoded<T>;\n // @jchris where is the fp attribute coming from?\n if (fpvalue && !fpvalue.fp) {\n throw logger.Error().Msg(\"missing fp\").AsError();\n }\n return fpvalue.fp;\n}\n","import { MemoryBlockstore } from \"@fireproof/vendor/@web3-storage/pail/block\";\nimport { BlockFetcher as BlockFetcherApi } from \"@fireproof/vendor/@web3-storage/pail/api\";\n\nimport {\n AnyAnyLink,\n AnyBlock,\n AnyLink,\n CarMakeable,\n TransactionMeta,\n TransactionWrapper,\n BlockstoreOpts,\n BlockstoreRuntime,\n Loadable,\n} from \"./types.js\";\n\nimport { Loader } from \"./loader.js\";\nimport type { CID, Block, Version, UnknownLink } from \"multiformats\";\nimport { BaseBlockstore, CarTransaction, falsyToUndef, SuperThis } from \"../types.js\";\nimport { ensureStoreEnDeFile, toStoreRuntime } from \"./store-factory.js\";\nimport { Logger, toCryptoRuntime } from \"@adviser/cement\";\nimport { ensureLogger, ensureSuperThis } from \"../utils.js\";\n\nexport type BlockFetcher = BlockFetcherApi;\nexport interface CarTransactionOpts {\n readonly add: boolean;\n readonly noLoader: boolean;\n}\n\nexport class CarTransactionImpl implements CarMakeable, CarTransaction {\n readonly parent: BaseBlockstore;\n readonly #memblock = new MemoryBlockstore();\n\n constructor(parent: BaseBlockstore, opts: CarTransactionOpts = { add: true, noLoader: false }) {\n // super();\n if (opts.add) {\n parent.transactions.add(this);\n }\n this.parent = parent;\n }\n\n async get<T, C extends number, A extends number, V extends Version>(cid: AnyLink): Promise<Block<T, C, A, V> | undefined> {\n return ((await this.superGet(cid)) || falsyToUndef(await this.parent.get(cid))) as Block<T, C, A, V>;\n }\n\n async superGet(cid: AnyLink): Promise<AnyBlock | undefined> {\n return this.#memblock.get(cid);\n }\n\n async put(cid: AnyLink, block: Uint8Array): Promise<void> {\n await this.#memblock.put(cid, block);\n }\n\n putSync(cid: UnknownLink, bytes: Uint8Array<ArrayBufferLike>): void {\n this.#memblock.putSync(cid, bytes);\n }\n\n async *entries(): AsyncIterableIterator<AnyBlock> {\n for await (const blk of this.#memblock.entries()) {\n yield blk;\n }\n }\n}\n\nexport function defaultedBlockstoreRuntime(\n sthis: SuperThis,\n opts: BlockstoreOpts,\n component: string,\n ctx?: Record<string, unknown>,\n): BlockstoreRuntime {\n const logger = ensureLogger(sthis, component, ctx);\n // const store = opts.store || {};\n return {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n applyMeta: (meta: TransactionMeta, snap?: boolean): Promise<void> => {\n return Promise.resolve();\n },\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n compact: async (blocks: BlockFetcher) => {\n return {} as unknown as TransactionMeta;\n },\n autoCompact: 100,\n public: false,\n // name: undefined,\n threshold: 1000 * 1000,\n ...opts,\n logger,\n keyBag: opts.keyBag || {},\n crypto: toCryptoRuntime(opts.crypto),\n storeUrls: opts.storeUrls,\n // storeEnDeFile: ensureStoreEnDeFile(opts.storeEnDeFile),\n // store,\n storeRuntime: toStoreRuntime(sthis, ensureStoreEnDeFile(opts.storeEnDeFile)),\n };\n}\n\n// export function blockstoreFactory(sthis: SuperThis, opts: BlockstoreOpts): BaseBlockstore | EncryptedBlockstore {\n// // if (opts.name) {\n// return new EncryptedBlockstore(sthis, opts);\n// // } else {\n// // return new BaseBlockstore(opts);\n// // }\n// }\n\nexport class BaseBlockstoreImpl implements BlockFetcher {\n readonly transactions: Set<CarTransaction> = new Set<CarTransaction>();\n readonly ebOpts: BlockstoreRuntime;\n readonly sthis: SuperThis;\n\n readonly loader: Loadable;\n // readonly name?: string;\n\n // ready: Promise<void>;\n ready(): Promise<void> {\n return Promise.resolve();\n }\n\n async close(): Promise<void> {\n // no-op\n }\n\n async destroy(): Promise<void> {\n // no-op\n }\n\n async compact(): Promise<void> {\n // no-op\n }\n\n readonly logger: Logger;\n constructor(ebOpts: BlockstoreOpts) {\n this.sthis = ensureSuperThis(ebOpts);\n this.ebOpts = defaultedBlockstoreRuntime(this.sthis, ebOpts, \"BaseBlockstore\");\n this.logger = this.ebOpts.logger;\n this.loader = new Loader(this.sthis, ebOpts);\n }\n\n async get<T, C extends number, A extends number, V extends Version>(cid: AnyAnyLink): Promise<Block<T, C, A, V> | undefined> {\n if (!cid) throw this.logger.Error().Msg(\"required cid\").AsError();\n for (const f of this.transactions) {\n // if (Math.random() < 0.001) console.log('get', cid.toString(), this.transactions.size)\n const v = await f.superGet(cid);\n if (v) return v as Block<T, C, A, V>;\n }\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n async put(cid: AnyAnyLink, block: Uint8Array): Promise<void> {\n throw this.logger.Error().Msg(\"use a transaction to put\").AsError();\n }\n\n lastTxMeta?: unknown; // TransactionMeta\n\n async transaction<M extends TransactionMeta>(\n fn: (t: CarTransaction) => Promise<M>,\n _opts?: CarTransactionOpts,\n ): Promise<TransactionWrapper<M>> {\n this.logger.Debug().Msg(\"enter transaction\");\n const t = new CarTransactionImpl(this, _opts);\n this.logger.Debug().Msg(\"post CarTransaction\");\n const done: M = await fn(t);\n this.logger.Debug().Msg(\"post fn\");\n this.lastTxMeta = done;\n return { t, meta: done };\n }\n\n openTransaction(opts: CarTransactionOpts = { add: true, noLoader: false }): CarTransaction {\n return new CarTransactionImpl(this, opts);\n }\n\n async commitTransaction<M extends TransactionMeta>(\n t: CarTransaction,\n done: M,\n opts: CarTransactionOpts,\n ): Promise<TransactionWrapper<M>> {\n if (!this.loader) throw this.logger.Error().Msg(\"loader required to commit\").AsError();\n const cars = await this.loader.commit<M>(t, done, opts);\n if (this.ebOpts.autoCompact && this.loader.carLog.length > this.ebOpts.autoCompact) {\n setTimeout(() => void this.compact(), 10);\n }\n if (cars) {\n this.transactions.delete(t);\n return { meta: done, cars, t };\n }\n throw this.logger.Error().Msg(\"failed to commit car files\").AsError();\n }\n\n async *entries(): AsyncIterableIterator<AnyBlock> {\n const seen = new Set<string>();\n for (const t of this.transactions) {\n for await (const blk of t.entries()) {\n if (seen.has(blk.cid.toString())) continue;\n seen.add(blk.cid.toString());\n yield blk;\n }\n }\n }\n}\n\nexport class EncryptedBlockstore extends BaseBlockstoreImpl {\n // readonly name: string;\n\n ready(): Promise<void> {\n return this.loader.ready();\n }\n\n close(): Promise<void> {\n return this.loader.close();\n }\n\n destroy(): Promise<void> {\n return this.loader.destroy();\n }\n\n compacting = false;\n readonly logger: Logger;\n\n constructor(sthis: SuperThis, ebOpts: BlockstoreOpts) {\n super(ebOpts);\n this.logger = ensureLogger(this.sthis, \"EncryptedBlockstore\", {\n this: 1,\n });\n }\n\n async get<T, C extends number, A extends number, V extends Version>(cid: AnyAnyLink): Promise<Block<T, C, A, V> | undefined> {\n const got = await super.get(cid);\n if (got) return got as Block<T, C, A, V>;\n if (!this.loader) {\n return;\n }\n return falsyToUndef(await this.loader.getBlock(cid)) as Block<T, C, A, V>;\n }\n\n async transaction<M extends TransactionMeta>(\n fn: (t: CarTransaction) => Promise<M>,\n opts = { noLoader: false },\n ): Promise<TransactionWrapper<M>> {\n this.logger.Debug().Msg(\"enter transaction\");\n const { t, meta: done } = await super.transaction<M>(fn);\n this.logger.Debug().Msg(\"post super.transaction\");\n const cars = await this.loader.commit<M>(t, done, opts);\n this.logger.Debug().Msg(\"post this.loader.commit\");\n if (this.ebOpts.autoCompact && this.loader.carLog.length > this.ebOpts.autoCompact) {\n setTimeout(() => void this.compact(), 10);\n }\n if (cars) {\n this.transactions.delete(t);\n return { meta: done, cars, t };\n }\n throw this.logger.Error().Msg(\"failed to commit car files\").AsError();\n }\n\n async getFile(car: AnyLink, cid: AnyLink /*, isPublic = false*/): Promise<Uint8Array> {\n await this.ready();\n if (!this.loader) throw this.logger.Error().Msg(\"loader required to get file, ledger must be named\").AsError();\n const reader = await this.loader.loadFileCar(car /*, isPublic */);\n const block = await reader.get(cid as CID);\n if (!block) throw this.logger.Error().Str(\"cid\", cid.toString()).Msg(`Missing block`).AsError();\n return block.bytes;\n }\n\n async compact() {\n await this.ready();\n if (!this.loader) throw this.logger.Error().Msg(\"loader required to compact\").AsError();\n if (this.loader.carLog.length < 2) return;\n const compactFn = this.ebOpts.compact || ((blocks: CompactionFetcher) => this.defaultCompact(blocks, this.logger));\n if (!compactFn || this.compacting) return;\n const blockLog = new CompactionFetcher(this);\n this.compacting = true;\n const meta = await compactFn(blockLog);\n await this.loader.commit(blockLog.loggedBlocks, meta, {\n compact: true,\n noLoader: true,\n });\n this.compacting = false;\n }\n\n async defaultCompact(blocks: CompactionFetcher, logger: Logger): Promise<TransactionMeta> {\n // console.log('eb compact')\n if (!this.loader) {\n throw logger.Error().Msg(\"no loader\").AsError();\n }\n if (!this.lastTxMeta) {\n throw logger.Error().Msg(\"no lastTxMeta\").AsError();\n }\n for await (const blk of this.loader.entries(false)) {\n blocks.loggedBlocks.putSync(blk.cid, blk.bytes);\n }\n for (const t of this.transactions) {\n for await (const blk of t.entries()) {\n blocks.loggedBlocks.putSync(blk.cid, blk.bytes);\n }\n }\n return this.lastTxMeta as TransactionMeta;\n }\n\n async *entries(): AsyncIterableIterator<AnyBlock> {\n // const seen = new Set<string>();\n for await (const blk of this.loader.entries()) {\n // if (seen.has(blk.cid.toString())) continue\n // seen.add(blk.cid.toString())\n yield blk;\n }\n }\n}\n\nexport class CompactionFetcher implements BlockFetcher {\n readonly blockstore: EncryptedBlockstore;\n // loader: Loader | null = null\n readonly loggedBlocks: CarTransaction;\n\n constructor(blocks: EncryptedBlockstore) {\n this.blockstore = blocks;\n // this.loader = blocks.loader\n this.loggedBlocks = new CarTransactionImpl(blocks);\n }\n\n async get<T, C extends number, A extends number, V extends Version>(cid: AnyLink): Promise<Block<T, C, A, V> | undefined> {\n const block = await this.blockstore.get(cid);\n if (block) this.loggedBlocks.putSync(cid, block.bytes);\n return falsyToUndef(block) as Block<T, C, A, V>;\n }\n}\n","import { Future } from \"@adviser/cement\";\n\ntype QueueFunction<T = void> = () => Promise<T>;\n\nexport class CommitQueue<T = void> {\n readonly queue: QueueFunction<void>[] = [];\n processing = false;\n\n readonly _waitIdleItems: Set<Future<void>> = new Set<Future<void>>();\n waitIdle(): Promise<void> {\n if (this.queue.length === 0 && !this.processing) {\n return Promise.resolve();\n }\n const fn = new Future<void>();\n this._waitIdleItems.add(fn);\n return fn.asPromise();\n }\n\n async enqueue(fn: QueueFunction<T>): Promise<T> {\n return new Promise<T>((resolve, reject) => {\n const queueFn = async () => {\n try {\n resolve(await fn());\n } catch (e) {\n reject(e);\n } finally {\n this.processing = false;\n this.processNext();\n }\n };\n this.queue.push(queueFn);\n if (!this.processing) {\n this.processNext();\n }\n });\n }\n\n processNext() {\n if (this.queue.length > 0 && !this.processing) {\n this.processing = true;\n const queueFn = this.queue.shift();\n if (queueFn) {\n queueFn().finally(() => {\n /**/\n });\n }\n }\n if (this.queue.length === 0 && !this.processing) {\n const toResolve = Array.from(this._waitIdleItems);\n this._waitIdleItems.clear();\n toResolve.map((fn) => fn.resolve());\n }\n }\n}\n","import { FileTransactionMeta, CarTransaction } from \"../types.js\";\nimport {\n AnyBlock,\n AnyLink,\n CarGroup,\n CarHeader,\n CarLog,\n CarMakeable,\n CommitOpts,\n DataStore,\n DbMeta,\n MetaStore,\n toCIDBlock,\n TransactionMeta,\n WALStore,\n} from \"./types.js\";\nimport * as CBW from \"@fireproof/vendor/@ipld/car/buffer-writer\";\nimport { CID } from \"multiformats\";\nimport { encode } from \"../runtime/wait-pr-multiformats/block.js\";\nimport { BlockEncoder } from \"../runtime/wait-pr-multiformats/codec-interface.js\";\nimport { sha256 as hasher } from \"multiformats/hashes/sha2\";\nimport * as dagCodec from \"@fireproof/vendor/@ipld/dag-cbor\";\nimport { CarTransactionImpl } from \"./transaction.js\";\n\nasync function encodeCarFile(roots: AnyLink[], t: CarMakeable, codec: BlockEncoder<number, Uint8Array>): Promise<AnyBlock> {\n let size = 0;\n const headerSize = CBW.headerLength({ roots } as { roots: CID<unknown, number, number, 1>[] });\n size += headerSize;\n for await (const { cid, bytes } of t.entries()) {\n size += CBW.blockLength({ cid, bytes } as CBW.Block);\n }\n const buffer = new Uint8Array(size);\n const writer = CBW.createWriter(buffer.buffer, { headerSize });\n\n for (const r of roots) {\n writer.addRoot(r as CID<unknown, number, number, 1>);\n }\n\n for await (const { cid, bytes } of t.entries()) {\n writer.write({ cid, bytes } as CBW.Block);\n }\n writer.close();\n return await encode({ value: writer.bytes, hasher, codec });\n}\n\nexport async function createCarFile(\n encoder: BlockEncoder<number, Uint8Array>,\n cid: AnyLink,\n t: CarTransaction,\n): Promise<{ cid: AnyLink; bytes: Uint8Array }> {\n // try {\n return encodeCarFile([cid], t, encoder);\n // const keycr = await store.keyedCrypto()\n // return keycr.isEncrypting\n // ? await encryptedEncodeCarFile(this.logger, keycr, cid, t)\n // : await encodeCarFile([cid], t);\n // } catch (e) {\n // throw store.logger.Error().Err(e).Msg(\"error creating car file\").AsError();\n // }\n}\n\nexport async function commitFiles(\n fileStore: DataStore,\n walStore: WALStore,\n t: CarTransaction,\n done: TransactionMeta,\n // opts: CommitOpts = { noLoader: false, compact: false },\n): Promise<CarGroup> {\n const { files: roots } = makeFileCarHeader(done as FileTransactionMeta) as {\n files: AnyLink[];\n };\n const cids: AnyLink[] = [];\n // const fileStore = await this.fileStore();\n const codec = (await fileStore.keyedCrypto()).codec();\n const cars = await prepareCarFilesFiles(codec, roots, t);\n for (const car of cars) {\n const { cid, bytes } = car;\n // real deal\n await fileStore.save({ cid, bytes });\n await walStore.enqueueFile(cid /*, !!opts.public*/);\n cids.push(cid);\n }\n return cids;\n}\n\nfunction makeFileCarHeader(result: FileTransactionMeta): TransactionMeta {\n const files: AnyLink[] = [];\n for (const [, meta] of Object.entries(result.files || {})) {\n if (meta && typeof meta === \"object\" && \"cid\" in meta && meta !== null) {\n files.push(meta.cid as AnyLink);\n }\n }\n return { ...result, files };\n}\n\nasync function prepareCarFilesFiles(\n encoder: BlockEncoder<number, Uint8Array>,\n roots: AnyLink[],\n t: CarTransaction,\n // isPublic: boolean,\n): Promise<{ cid: AnyLink; bytes: Uint8Array }[]> {\n // const theKey = isPublic ? null : await this._getKey();\n // const kc = await store.keyedCrypto()\n // const car = kc.isEncrypting\n // ? await encryptedEncodeCarFile(this.logger, kc, roots[0], t)\n // : await encodeCarFile(roots, t);\n return [await encodeCarFile(roots, t, encoder)];\n}\n\n// PUR Commit\n\nfunction makeCarHeader<T>(meta: T, cars: CarLog, compact = false): CarHeader<T> {\n const coreHeader = compact ? { cars: [], compact: cars } : { cars, compact: [] };\n return { ...coreHeader, meta };\n}\n\nasync function encodeCarHeader<T>(fp: CarHeader<T>) {\n return (await encode({\n value: { fp },\n hasher,\n codec: dagCodec,\n })) as AnyBlock;\n}\n\nexport interface CommitParams {\n readonly encoder: BlockEncoder<number, Uint8Array>;\n readonly carLog: CarLog;\n readonly carStore: DataStore;\n readonly WALStore: WALStore;\n readonly metaStore: MetaStore;\n readonly threshold?: number;\n}\n\nexport async function commit<T>(\n params: CommitParams,\n t: CarTransaction,\n done: T,\n opts: CommitOpts = { noLoader: false, compact: false },\n): Promise<{ cgrp: CarGroup; header: CarHeader<T> }> {\n const fp = makeCarHeader<T>(done, params.carLog, !!opts.compact);\n const rootBlock = await encodeCarHeader(fp);\n\n const cars = await prepareCarFiles(params.encoder, params.threshold, rootBlock, t);\n const cids: AnyLink[] = [];\n for (const car of cars) {\n const { cid, bytes } = car;\n await params.carStore.save({ cid, bytes });\n cids.push(cid);\n }\n\n // await this.cacheTransaction(t);\n const newDbMeta = { cars: cids } as DbMeta;\n await params.WALStore.enqueue(newDbMeta, opts);\n await params.metaStore.save(newDbMeta);\n return { cgrp: cids, header: fp };\n}\n\nasync function prepareCarFiles(\n encoder: BlockEncoder<number, Uint8Array>,\n threshold: number | undefined,\n rootBlock: AnyBlock,\n t: CarTransaction,\n): Promise<{ cid: AnyLink; bytes: Uint8Array }[]> {\n // const theKey = isPublic ? undefined : await this._getKey();\n const carFiles: { cid: AnyLink; bytes: Uint8Array }[] = [];\n threshold = threshold || 128000 * 8; // remove the * 8 to fit partykit\n let clonedt = new CarTransactionImpl(t.parent, { add: false, noLoader: false });\n clonedt.putSync(rootBlock.cid, rootBlock.bytes);\n let newsize = CBW.blockLength(toCIDBlock(rootBlock));\n let cidRootBlock = rootBlock;\n for await (const { cid, bytes } of t.entries()) {\n newsize += CBW.blockLength(toCIDBlock({ cid: cid, bytes }));\n if (newsize >= threshold) {\n carFiles.push(await createCarFile(encoder, cidRootBlock.cid, clonedt));\n clonedt = new CarTransactionImpl(t.parent, { add: false, noLoader: false });\n clonedt.putSync(cid, bytes);\n cidRootBlock = { cid, bytes };\n newsize = CBW.blockLength(toCIDBlock({ cid, bytes })); //+ CBW.blockLength(rootBlock)\n } else {\n clonedt.putSync(cid, bytes);\n }\n }\n // HEREMENO\n carFiles.push(await createCarFile(encoder, cidRootBlock.cid, clonedt));\n // console.log(\"split to \", carFiles.length, \"files\")\n return carFiles;\n}\n","import { Logger } from \"@adviser/cement\";\nimport type { CarClockHead, CarClockLink, DbMeta } from \"./types.js\";\nimport { ensureLogger } from \"../utils.js\";\nimport { SuperThis } from \"../types.js\";\n\ninterface TaskItem {\n readonly cid: string;\n readonly dbMeta: DbMeta;\n retries: number;\n}\n\nexport class TaskManager {\n // we need to remove the events after some time\n private readonly eventsWeHandled = new Set<string>();\n\n private queue: TaskItem[] = [];\n private isProcessing = false;\n\n readonly logger: Logger;\n readonly callback: (dbMeta: DbMeta) => Promise<void>;\n constructor(sthis: SuperThis, callback: (dbMeta: DbMeta) => Promise<void>) {\n this.logger = ensureLogger(sthis, \"TaskManager\");\n this.callback = callback;\n }\n\n async handleEvent(cid: CarClockLink, parents: CarClockHead, dbMeta: DbMeta) {\n for (const parent of parents) {\n this.eventsWeHandled.add(parent.toString());\n }\n this.queue.push({ cid: cid.toString(), dbMeta, retries: 0 });\n this.queue = this.queue.filter(({ cid }) => !this.eventsWeHandled.has(cid));\n void this.processQueue();\n }\n\n private async processQueue() {\n if (this.isProcessing) return;\n this.isProcessing = true;\n const filteredQueue = this.queue.filter(({ cid }) => !this.eventsWeHandled.has(cid));\n const first = filteredQueue[0];\n if (!first) {\n this.isProcessing = false;\n return;\n }\n try {\n await this.callback(first.dbMeta);\n this.eventsWeHandled.add(first.cid);\n this.queue = this.queue.filter(({ cid }) => !this.eventsWeHandled.has(cid));\n } catch (err) {\n if (first.retries++ > 3) {\n this.logger.Error().Str(\"cid\", first.cid).Msg(\"failed to process event block after 3 retries\");\n this.queue = this.queue.filter(({ cid }) => cid !== first.cid);\n }\n await new Promise((resolve) => setTimeout(resolve, 50));\n throw this.logger.Error().Err(err).Msg(\"failed to process event block\").AsError();\n } finally {\n this.isProcessing = false;\n if (this.queue.length > 0) {\n void this.processQueue();\n }\n }\n }\n}\n","import { CryptoRuntime, Logger, URI } from \"@adviser/cement\";\nimport { BytesWithIv, CodecOpts, IvAndBytes, IvKeyIdData, KeyedCrypto, KeyWithFingerPrint } from \"../blockstore/index.js\";\nimport { ensureLogger, UInt8ArrayEqual } from \"../utils.js\";\nimport { KeyBag } from \"./key-bag.js\";\nimport type { BlockCodec } from \"./wait-pr-multiformats/codec-interface.js\";\nimport { base58btc } from \"multiformats/bases/base58\";\nimport { sha256 as hasher } from \"multiformats/hashes/sha2\";\nimport * as CBOR from \"@fireproof/vendor/cborg\";\nimport { PARAM, SuperThis } from \"../types.js\";\n\ninterface GenerateIVFn {\n calc(ko: KeyedCrypto, crypto: CryptoRuntime, data: Uint8Array): Promise<Uint8Array>;\n verify(ko: KeyedCrypto, crypto: CryptoRuntime, iv: Uint8Array, data: Uint8Array): Promise<boolean>;\n}\n\nconst generateIV: Record<string, GenerateIVFn> = {\n random: {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n calc: async (ko: KeyedCrypto, crypto: CryptoRuntime, data: Uint8Array): Promise<Uint8Array> => {\n return crypto.randomBytes(ko.ivLength);\n },\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n verify: async (ko: KeyedCrypto, crypto: CryptoRuntime, iv: Uint8Array, data: Uint8Array): Promise<boolean> => {\n return true;\n },\n },\n hash: {\n calc: async (ko: KeyedCrypto, crypto: CryptoRuntime, data: Uint8Array): Promise<Uint8Array> => {\n const hash = await hasher.digest(data);\n const hashBytes = new Uint8Array(hash.bytes);\n const hashArray = new Uint8Array(ko.ivLength);\n for (let i = 0; i < hashBytes.length; i++) {\n hashArray[i % ko.ivLength] ^= hashBytes[i];\n }\n return hashArray;\n },\n verify: async function (ko: KeyedCrypto, crypto: CryptoRuntime, iv: Uint8Array, data: Uint8Array): Promise<boolean> {\n return ko.url.getParam(PARAM.IV_VERIFY) !== \"disable\" && UInt8ArrayEqual(iv, await this.calc(ko, crypto, data));\n },\n },\n};\n\nfunction getGenerateIVFn(url: URI, opts: Partial<CodecOpts>): GenerateIVFn {\n const ivhash = opts.ivCalc || url.getParam(PARAM.IV_HASH) || \"hash\";\n return generateIV[ivhash] || generateIV[\"hash\"];\n}\n\nexport class BlockIvKeyIdCodec implements BlockCodec<0x300539, Uint8Array> {\n readonly code = 0x300539;\n readonly name = \"Fireproof@encrypted-block:aes-gcm\";\n\n readonly ko: KeyedCrypto;\n readonly iv?: Uint8Array;\n readonly opts: Partial<CodecOpts>;\n constructor(ko: KeyedCrypto, iv?: Uint8Array, opts?: CodecOpts) {\n this.ko = ko;\n this.iv = iv;\n this.opts = opts || {};\n }\n\n async encode(data: Uint8Array): Promise<Uint8Array> {\n const calcIv = this.iv || (await getGenerateIVFn(this.ko.url, this.opts).calc(this.ko, this.ko.crypto, data));\n const { iv } = this.ko.algo(calcIv);\n const fprt = await this.ko.fingerPrint();\n const keyId = base58btc.decode(fprt);\n this.ko.logger.Debug().Str(\"fp\", fprt).Msg(\"encode\");\n return CBOR.encode({\n iv: iv,\n keyId: keyId,\n data: await this.ko._encrypt({ iv, bytes: data }),\n } as IvKeyIdData);\n }\n\n async decode(abytes: Uint8Array | ArrayBuffer): Promise<Uint8Array> {\n let bytes: Uint8Array;\n if (abytes instanceof Uint8Array) {\n bytes = abytes;\n } else {\n bytes = new Uint8Array(abytes);\n }\n const { iv, keyId, data } = CBOR.decode(bytes) as IvKeyIdData;\n const fprt = await this.ko.fingerPrint();\n this.ko.logger.Debug().Str(\"fp\", base58btc.encode(keyId)).Msg(\"decode\");\n if (base58btc.encode(keyId) !== fprt) {\n throw this.ko.logger.Error().Str(\"fp\", fprt).Str(\"keyId\", base58btc.encode(keyId)).Msg(\"keyId mismatch\").AsError();\n }\n const result = await this.ko._decrypt({ iv: iv, bytes: data });\n if (!this.opts?.noIVVerify && !(await getGenerateIVFn(this.ko.url, this.opts).verify(this.ko, this.ko.crypto, iv, result))) {\n throw this.ko.logger.Error().Msg(\"iv missmatch\").AsError();\n }\n return result;\n }\n}\n\nclass keyedCrypto implements KeyedCrypto {\n readonly ivLength = 12;\n readonly logger: Logger;\n readonly crypto: CryptoRuntime;\n readonly key: KeyWithFingerPrint;\n readonly isEncrypting = true;\n readonly url: URI;\n constructor(url: URI, key: KeyWithFingerPrint, cyopt: CryptoRuntime, sthis: SuperThis) {\n this.logger = ensureLogger(sthis, \"keyedCrypto\");\n this.crypto = cyopt;\n this.key = key;\n this.url = url;\n }\n fingerPrint(): Promise<string> {\n return Promise.resolve(this.key.fingerPrint);\n }\n codec(iv?: Uint8Array, opts?: CodecOpts): BlockCodec<number, Uint8Array> {\n return new BlockIvKeyIdCodec(this, iv, opts);\n }\n algo(iv?: Uint8Array) {\n return {\n name: \"AES-GCM\",\n iv: iv || this.crypto.randomBytes(this.ivLength),\n tagLength: 128,\n };\n }\n async _decrypt(data: IvAndBytes): Promise<Uint8Array> {\n this.logger.Debug().Len(data.bytes, \"bytes\").Len(data.iv, \"iv\").Str(\"fp\", this.key.fingerPrint).Msg(\"decrypting\");\n return new Uint8Array(await this.crypto.decrypt(this.algo(data.iv), this.key.key, data.bytes));\n }\n async _encrypt(data: BytesWithIv): Promise<Uint8Array> {\n this.logger.Debug().Len(data.bytes).Str(\"fp\", this.key.fingerPrint).Msg(\"encrypting\");\n const a = this.algo(data.iv);\n return new Uint8Array(await this.crypto.encrypt(a, this.key.key, data.bytes));\n }\n}\n\nclass nullCodec implements BlockCodec<0x0, Uint8Array> {\n readonly code = 0x0;\n readonly name = \"Fireproof@unencrypted-block\";\n\n encode(data: Uint8Array): Uint8Array {\n return data;\n }\n decode(data: Uint8Array): Uint8Array {\n return data;\n }\n}\n\nclass noCrypto implements KeyedCrypto {\n readonly ivLength = 0;\n readonly code = 0x0;\n readonly name = \"Fireproof@unencrypted-block\";\n readonly logger: Logger;\n readonly crypto: CryptoRuntime;\n readonly isEncrypting = false;\n readonly _fingerPrint = \"noCrypto:\" + Math.random();\n readonly url: URI;\n constructor(url: URI, cyrt: CryptoRuntime, sthis: SuperThis) {\n this.logger = ensureLogger(sthis, \"noCrypto\");\n this.crypto = cyrt;\n this.url = url;\n }\n\n fingerPrint(): Promise<string> {\n return Promise.resolve(this._fingerPrint);\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n codec(iv?: Uint8Array): BlockCodec<number, Uint8Array> {\n return new nullCodec();\n }\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n algo(iv?: Uint8Array): { name: string; iv: Uint8Array; tagLength: number } {\n return {\n name: \"noCrypto\",\n iv: new Uint8Array(),\n tagLength: 0,\n };\n }\n _decrypt(): Promise<Uint8Array> {\n throw this.logger.Error().Msg(\"noCrypto.decrypt not implemented\").AsError();\n }\n _encrypt(): Promise<Uint8Array> {\n throw this.logger.Error().Msg(\"noCrypto.decrypt not implemented\").AsError();\n }\n}\n\nexport async function keyedCryptoFactory(url: URI, kb: KeyBag, sthis: SuperThis): Promise<KeyedCrypto> {\n const storekey = url.getParam(PARAM.STORE_KEY);\n if (storekey && storekey !== \"insecure\") {\n let rkey = await kb.getNamedKey(storekey, true);\n if (rkey.isErr()) {\n try {\n rkey = await kb.toKeyWithFingerPrint(storekey);\n } catch (e) {\n throw (\n sthis.logger\n .Error()\n .Err(e)\n .Str(\"keybag\", kb.rt.id())\n // .Result(\"key\", rkey)\n .Str(\"name\", storekey)\n .Msg(\"getNamedKey failed\")\n .AsError()\n );\n }\n }\n return new keyedCrypto(url, rkey.Ok(), kb.rt.crypto, sthis);\n }\n return new noCrypto(url, kb.rt.crypto, sthis);\n}\n","import { Result, URI } from \"@adviser/cement\";\nimport {\n SerdeGateway,\n SerdeGatewayBuildUrlReturn,\n SerdeGatewayCloseReturn,\n SerdeGatewayDeleteReturn,\n SerdeGatewayDestroyReturn,\n SerdeGatewayGetReturn,\n SerdeGatewayInterceptor,\n SerdeGatewayPutReturn,\n SerdeGatewayStartReturn,\n SerdeGatewaySubscribeReturn,\n SerdeGetResult,\n UnsubscribeResult,\n VoidResult,\n} from \"./serde-gateway.js\";\nimport { SuperThis } from \"../types.js\";\nimport { FPEnvelope, FPEnvelopeMeta } from \"./fp-envelope.js\";\nimport { Loadable } from \"./types.js\";\n\nexport class PassThroughGateway implements SerdeGatewayInterceptor {\n async buildUrl(sthis: SuperThis, url: URI, key: string): Promise<Result<SerdeGatewayBuildUrlReturn>> {\n const op = { url, key };\n return Result.Ok({ op });\n }\n async start(sthis: SuperThis, url: URI): Promise<Result<SerdeGatewayStartReturn>> {\n const op = { url };\n return Result.Ok({ op });\n }\n async close(sthis: SuperThis, url: URI): Promise<Result<SerdeGatewayCloseReturn>> {\n const op = { url };\n return Result.Ok({ op });\n }\n async delete(sthis: SuperThis, url: URI): Promise<Result<SerdeGatewayDeleteReturn>> {\n const op = { url };\n return Result.Ok({ op });\n }\n async destroy(sthis: SuperThis, url: URI): Promise<Result<SerdeGatewayDestroyReturn>> {\n const op = { url };\n return Result.Ok({ op });\n }\n async put<T>(sthis: SuperThis, url: URI, body: FPEnvelope<T>): Promise<Result<SerdeGatewayPutReturn<T>>> {\n const op = { url, body };\n return Result.Ok({ op });\n }\n async get<S>(sthis: SuperThis, url: URI): Promise<Result<SerdeGatewayGetReturn<S>>> {\n const op = { url };\n return Result.Ok({ op });\n }\n async subscribe(\n sthis: SuperThis,\n url: URI,\n callback: (meta: FPEnvelopeMeta) => Promise<void>,\n ): Promise<Result<SerdeGatewaySubscribeReturn>> {\n const op = { url, callback };\n return Result.Ok({ op });\n }\n}\n\nconst passThrougthGateway = new PassThroughGateway();\n\nexport class InterceptorGateway implements SerdeGateway {\n readonly innerGW: SerdeGateway;\n readonly interceptor: SerdeGatewayInterceptor;\n\n constructor(sthis: SuperThis, innerGW: SerdeGateway, interceptor: SerdeGatewayInterceptor | undefined) {\n this.innerGW = innerGW;\n this.interceptor = interceptor || passThrougthGateway;\n }\n\n async buildUrl(sthis: SuperThis, baseUrl: URI, key: string, loader: Loadable): Promise<Result<URI>> {\n const rret = await this.interceptor.buildUrl(sthis, baseUrl, key, loader);\n if (rret.isErr()) {\n return Result.Err(rret.Err());\n }\n const ret = rret.unwrap();\n if (ret.stop && ret.value) {\n return ret.value;\n }\n return this.innerGW.buildUrl(sthis, ret.op.url, ret.op.key, loader);\n }\n\n async destroy(sthis: SuperThis, iurl: URI, loader: Loadable): Promise<Result<void>> {\n const rret = await this.interceptor.destroy(sthis, iurl, loader);\n if (rret.isErr()) {\n return Result.Err(rret.Err());\n }\n const ret = rret.unwrap();\n if (ret.stop && ret.value) {\n return ret.value;\n }\n return this.innerGW.destroy(sthis, ret.op.url, loader);\n }\n\n async start(sthis: SuperThis, url: URI, loader: Loadable): Promise<Result<URI>> {\n const rret = await this.interceptor.start(sthis, url, loader);\n if (rret.isErr()) {\n return Result.Err(rret.Err());\n }\n const ret = rret.unwrap();\n if (ret.stop && ret.value) {\n return ret.value;\n }\n return await this.innerGW.start(sthis, ret.op.url, loader);\n }\n\n async close(sthis: SuperThis, url: URI, loader: Loadable): Promise<VoidResult> {\n const rret = await this.interceptor.close(sthis, url, loader);\n if (rret.isErr()) {\n return Result.Err(rret.Err());\n }\n const ret = rret.unwrap();\n if (ret.stop && ret.value) {\n return ret.value;\n }\n return await this.innerGW.close(sthis, ret.op.url, loader);\n }\n\n async put<T>(sthis: SuperThis, url: URI, fpEnv: FPEnvelope<T>, loader: Loadable): Promise<VoidResult> {\n const rret = await this.interceptor.put(sthis, url, fpEnv, loader);\n if (rret.isErr()) {\n return Result.Err(rret.Err());\n }\n const ret = rret.unwrap();\n if (ret.stop && ret.value) {\n return ret.value;\n }\n return this.innerGW.put(sthis, ret.op.url, ret.op.body, loader);\n }\n\n async get<S>(sthis: SuperThis, url: URI, loader: Loadable): Promise<SerdeGetResult<S>> {\n const rret = await this.interceptor.get<S>(sthis, url, loader);\n if (rret.isErr()) {\n return Result.Err(rret.Err());\n }\n const ret = rret.unwrap();\n if (ret.stop && ret.value) {\n return ret.value;\n }\n return this.innerGW.get(sthis, ret.op.url, loader);\n }\n\n async subscribe(\n sthis: SuperThis,\n url: URI,\n callback: (msg: FPEnvelopeMeta) => Promise<void>,\n loader: Loadable,\n ): Promise<UnsubscribeResult> {\n if (!this.innerGW.subscribe) {\n return Result.Err(sthis.logger.Error().Url(url).Msg(\"subscribe not supported\").AsError());\n }\n const rret = await this.interceptor.subscribe(sthis, url, callback, loader);\n if (rret.isErr()) {\n return Result.Err(rret.Err());\n }\n const ret = rret.unwrap();\n if (ret.stop && ret.value) {\n return ret.value;\n }\n return this.innerGW.subscribe(sthis, ret.op.url, ret.op.callback, loader);\n }\n\n async delete(sthis: SuperThis, url: URI, loader: Loadable): Promise<VoidResult> {\n const rret = await this.interceptor.delete(sthis, url, loader);\n if (rret.isErr()) {\n return Result.Err(rret.Err());\n }\n const ret = rret.unwrap();\n if (ret.stop && ret.value) {\n return ret.value;\n }\n return this.innerGW.delete(sthis, url, loader);\n }\n\n async getPlain(sthis: SuperThis, url: URI, key: string, loader?: Loadable): Promise<Result<Uint8Array>> {\n return this.innerGW.getPlain(sthis, url, key, loader);\n }\n}\n","import { URI } from \"@adviser/cement\";\nimport { DataStoreImpl, MetaStoreImpl, StoreOpts } from \"./store.js\";\nimport { SuperThis } from \"../types.js\";\n\n// export type LoadHandler = (dbMetas: DbMeta[]) => Promise<void>;\n// export function validateDataParams(params: DownloadDataFnParams | UploadDataFnParams, logger: Logger) {\n// const { type, name, car } = params;\n// if (!name) throw logger.Error().Msg(\"name is required\").AsError();\n// if (!car) {\n// throw logger.Error().Msg(\"car is required\").AsError();\n// }\n// if (type !== \"file\" && type !== \"data\") {\n// throw logger.Error().Msg(\"type must be file or data\").AsError();\n// }\n// }\n\n// export function validateMetaParams(params: DownloadMetaFnParams | UploadMetaFnParams, logger: Logger) {\n// const { name, branch } = params;\n// if (!name) throw logger.Error().Msg(\"name is required\").AsError();\n// if (!branch) {\n// throw logger.Error().Msg(\"branch is required\").AsError();\n// }\n// }\n\n// export class RemoteDataStore extends DataStoreImpl {\n// // just for explaining the concept\n// }\n\n// export class RemoteMetaStore extends MetaStoreImpl {\n// // just for explaining the concept\n// }\n\nexport async function RemoteDataStore(sthis: SuperThis, url: URI, opts: StoreOpts) {\n const ds = new DataStoreImpl(sthis, url, opts);\n await ds.start();\n return ds;\n}\nexport async function RemoteMetaStore(sthis: SuperThis, url: URI, opts: StoreOpts) {\n const ms = new MetaStoreImpl(sthis, url, opts);\n await ms.start();\n return ms;\n}\n\n// export class RemoteWALStore extends WALStoreImpl {\n// // basicly do nothing write the WAL into memory\n// constructor(loader: Loadable) {\n\n// //import { FileWALGateway } from \"../runtime/gateways/file/gateway.js\";\n// // super(loader, new URL(\"file:///dummy?fs=mem\"), loader.logger, new FileWALGateway(loader.logger));\n// }\n\n// }\n","import { Logger, URI } from \"@adviser/cement\";\n\nimport { PARAM, throwFalsy } from \"../types.js\";\nimport { TaskManager } from \"./task-manager.js\";\nimport type { Connection, Loadable, RefBlockstore, RefLoadable } from \"./types.js\";\nimport { RemoteDataStore, RemoteMetaStore } from \"./store-remote.js\";\nimport { getStartedGateway } from \"./store-factory.js\";\n\n// export interface Connectable {\n// // readonly blockstore: {\n// // readonly loader?: Loader;\n// // readonly ebOpts: BlockstoreRuntime;\n// // };\n// readonly name?: string;\n// // readonly sthis: SuperThis;\n// }\n\nfunction coerceLoader(ref: RefLoadable | RefBlockstore): Loadable | undefined {\n const refl = ref as RefLoadable;\n if (refl.loader) {\n return refl.loader;\n }\n const refb = ref as RefBlockstore;\n if (refb.blockstore) {\n return coerceLoader(refb.blockstore);\n }\n return undefined;\n}\n\nexport abstract class ConnectionBase implements Connection {\n // readonly ready: Promise<unknown>;\n // todo move to LRU blockstore https://github.com/web3-storage/w3clock/blob/main/src/worker/block.js\n // readonly eventBlocks = new MemoryBlockstore();\n private loader?: Loadable;\n taskManager?: TaskManager;\n loaded: Promise<void> = Promise.resolve();\n\n readonly url: URI;\n\n // abstract metaUpload(bytes: Uint8Array, params: UploadMetaFnParams): Promise<Uint8Array[] | Falsy>;\n // abstract dataUpload(bytes: Uint8Array, params: UploadDataFnParams, opts?: { public?: boolean }): Promise<void>;\n // abstract metaDownload(params: DownloadMetaFnParams): Promise<Uint8Array[] | Falsy>;\n // abstract dataDownload(params: DownloadDataFnParams): Promise<Uint8Array | Falsy>;\n\n readonly logger: Logger;\n constructor(url: URI, logger: Logger) {\n this.logger = logger;\n this.url = url;\n }\n\n async refresh() {\n await throwFalsy(throwFalsy(this.loader).remoteMetaStore).load();\n await (await throwFalsy(this.loader).WALStore()).process();\n }\n\n async connect(refl: RefLoadable | RefBlockstore) {\n await this.connectMeta(refl);\n await this.connectStorage(refl);\n }\n\n async connectMeta(refl: RefLoadable | RefBlockstore) {\n const loader = coerceLoader(refl);\n if (!loader) throw this.logger.Error().Msg(\"connectMeta: loader is required\").AsError();\n this.loader = loader;\n await this.onConnect();\n const metaUrl = this.url.build().defParam(PARAM.STORE, \"meta\").URI();\n const rgateway = await getStartedGateway(loader.sthis, metaUrl);\n if (rgateway.isErr())\n throw this.logger.Error().Result(\"err\", rgateway).Url(metaUrl).Msg(\"connectMeta: gateway is required\").AsError();\n // const name = metaUrl.toString();\n const dbName = metaUrl.getParam(PARAM.NAME);\n if (!dbName) {\n throw this.logger.Error().Url(metaUrl).Msg(\"connectMeta: dbName is required\").AsError();\n }\n const gateway = rgateway.Ok();\n const remote = await RemoteMetaStore(loader.sthis, metaUrl, {\n gateway: gateway.gateway,\n loader,\n });\n this.loader.remoteMetaStore = remote;\n this.loaded = this.loader.ready().then(async () => {\n return remote.load().then(async () => {\n return (await throwFalsy(this.loader).WALStore()).process();\n });\n });\n }\n\n abstract onConnect(): Promise<void>;\n\n async connectStorage(refl: RefLoadable | RefBlockstore) {\n const loader = coerceLoader(refl);\n if (!loader) throw this.logger.Error().Msg(\"connectStorage_X: loader is required\").AsError();\n this.loader = loader;\n const dataUrl = this.url.build().defParam(PARAM.STORE, \"data\").URI();\n const rgateway = await getStartedGateway(loader.sthis, dataUrl);\n if (rgateway.isErr())\n throw this.logger.Error().Result(\"err\", rgateway).Url(dataUrl).Msg(\"connectStorage_X: gateway is required\").AsError();\n const name = dataUrl.getParam(PARAM.NAME);\n if (!name) throw this.logger.Error().Url(dataUrl).Msg(\"connectStorage_X: name is required\").AsError;\n loader.remoteCarStore = await RemoteDataStore(loader.sthis, this.url, {\n gateway: rgateway.Ok().gateway,\n loader,\n });\n // @jchris why we have a differention between remoteCarStore and remoteFileStore? -- file store is for on-demand attachment loading\n // for now we don't have any difference but in superthis car store and\n // file store could have different urls/gateways\n loader.remoteFileStore = loader.remoteCarStore;\n }\n\n // move this stuff to connect\n // async getDashboardURL(compact = true) {\n // const baseUrl = 'https://dashboard.fireproof.storage/'\n // if (!this.loader?.remoteCarStore) return new URL('/howto', baseUrl)\n // // if (compact) {\n // // await this.compact()\n // // }\n // const currents = await this.loader?.metaStore?.load()\n // if (!currents) throw new Error(\"Can't sync empty ledger: save data first\")\n // if (currents.length > 1)\n // throw new Error(\"Can't sync ledger with split heads: make an update first\")\n // const current = currents[0]\n // const params = {\n // car: current.car.toString()\n // }\n // if (current.key) {\n // // @ts-ignore\n // params.key = current.key.toString()\n // }\n // // @ts-ignore\n // if (this.name) {\n // // @ts-ignore\n // params.name = this.name\n // }\n // const url = new URL('/import#' + new URLSearchParams(params).toString(), baseUrl)\n // console.log('Import to dashboard: ' + url.toString())\n // return url\n // }\n\n // openDashboard() {\n // void this.getDashboardURL().then(url => {\n // if (url) window.open(url.toString(), '_blank')\n // })\n // }\n}\n","import { encode, decode, Block } from \"./runtime/wait-pr-multiformats/block.js\";\nimport { parse } from \"multiformats/link\";\nimport { sha256 as hasher } from \"multiformats/hashes/sha2\";\nimport * as codec from \"@fireproof/vendor/@ipld/dag-cbor\";\nimport { put, get, entries, root } from \"@fireproof/vendor/@web3-storage/pail/crdt\";\nimport { EventBlockView, EventLink, Operation, PutOperation } from \"@fireproof/vendor/@web3-storage/pail/crdt/api\";\nimport { EventFetcher, vis } from \"@fireproof/vendor/@web3-storage/pail/clock\";\nimport * as Batch from \"@fireproof/vendor/@web3-storage/pail/crdt/batch\";\nimport {\n type EncryptedBlockstore,\n BlockFetcher,\n TransactionMeta,\n AnyLink,\n StoreRuntime,\n CompactFetcher,\n} from \"./blockstore/index.js\";\nimport {\n type IndexKeyType,\n type DocUpdate,\n type ClockHead,\n type DocValue,\n type CRDTMeta,\n type ChangesOptions,\n type DocFileMeta,\n type DocFiles,\n type DocSet,\n type DocWithId,\n type DocTypes,\n throwFalsy,\n CarTransaction,\n BaseBlockstore,\n} from \"./types.js\";\nimport { Result } from \"@fireproof/vendor/@web3-storage/pail/crdt/api\";\nimport { Logger } from \"@adviser/cement\";\nimport { CarTransactionImpl } from \"./blockstore/transaction.js\";\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nfunction time(tag: string) {\n // console.time(tag)\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nfunction timeEnd(tag: string) {\n // console.timeEnd(tag)\n}\n\nfunction toString<K extends IndexKeyType>(key: K, logger: Logger): string {\n switch (typeof key) {\n case \"string\":\n case \"number\":\n return key.toString();\n default:\n throw logger.Error().Msg(\"Invalid key type\").AsError();\n }\n}\n\nexport async function applyBulkUpdateToCrdt<T extends DocTypes>(\n store: StoreRuntime,\n tblocks: CarTransaction,\n head: ClockHead,\n updates: DocUpdate<T>[],\n logger: Logger,\n): Promise<CRDTMeta> {\n let result: Result | null = null;\n if (updates.length > 1) {\n const batch = await Batch.create(tblocks, head);\n for (const update of updates) {\n const link = await writeDocContent(store, tblocks, update, logger);\n await batch.put(toString(update.id, logger), link);\n }\n result = await batch.commit();\n } else if (updates.length === 1) {\n const link = await writeDocContent(store, tblocks, updates[0], logger);\n result = await put(tblocks, head, toString(updates[0].id, logger), link);\n }\n if (!result) throw logger.Error().Uint64(\"updates.len\", updates.length).Msg(\"Missing result\").AsError();\n\n if (result.event) {\n for (const { cid, bytes } of [\n ...result.additions,\n // ...result.removals,\n result.event,\n ]) {\n tblocks.putSync(cid, bytes);\n }\n }\n return { head: result.head } as CRDTMeta;\n}\n\n// this whole thing can get pulled outside of the write queue\nasync function writeDocContent<T extends DocTypes>(\n store: StoreRuntime,\n blocks: CarTransaction,\n update: DocUpdate<T>,\n logger: Logger,\n): Promise<AnyLink> {\n let value: Partial<DocValue<T>>;\n if (update.del) {\n value = { del: true };\n } else {\n if (!update.value) throw logger.Error().Msg(\"Missing value\").AsError();\n await processFiles(store, blocks, update.value, logger);\n value = { doc: update.value as DocWithId<T> };\n }\n const block = await encode({ value, hasher, codec });\n blocks.putSync(block.cid, block.bytes);\n return block.cid;\n}\n\nasync function processFiles<T extends DocTypes>(store: StoreRuntime, blocks: CarTransaction, doc: DocSet<T>, logger: Logger) {\n if (doc._files) {\n await processFileset(logger, store, blocks, doc._files);\n }\n if (doc._publicFiles) {\n await processFileset(logger, store, blocks, doc._publicFiles /*, true*/);\n }\n}\n\nasync function processFileset(\n logger: Logger,\n store: StoreRuntime,\n blocks: CarTransaction,\n files: DocFiles /*, publicFiles = false */,\n) {\n const dbBlockstore = blocks.parent as unknown as EncryptedBlockstore;\n if (!dbBlockstore.loader) throw logger.Error().Msg(\"Missing loader, ledger name is required\").AsError();\n const t = new CarTransactionImpl(dbBlockstore); // maybe this should move to encrypted-blockstore\n const didPut = [];\n // let totalSize = 0\n for (const filename in files) {\n if (File === files[filename].constructor) {\n const file = files[filename] as File;\n\n // totalSize += file.size\n const { cid, blocks: fileBlocks } = await store.encodeFile(file);\n didPut.push(filename);\n for (const block of fileBlocks) {\n t.putSync(block.cid, block.bytes);\n }\n files[filename] = { cid, type: file.type, size: file.size } as DocFileMeta;\n } else {\n const { cid, type, size, car } = files[filename] as DocFileMeta;\n if (cid && type && size && car) {\n files[filename] = { cid, type, size, car };\n }\n }\n }\n\n if (didPut.length) {\n const car = await dbBlockstore.loader.commitFiles(\n t,\n { files } as unknown as TransactionMeta /* {\n public: publicFiles,\n } */,\n );\n if (car) {\n for (const name of didPut) {\n files[name] = { car, ...files[name] } as DocFileMeta;\n }\n }\n }\n}\n\nexport async function getValueFromCrdt<T extends DocTypes>(\n blocks: BaseBlockstore,\n head: ClockHead,\n key: string,\n logger: Logger,\n): Promise<DocValue<T>> {\n if (!head.length) throw logger.Debug().Msg(\"Getting from an empty ledger\").AsError();\n const link = await get(blocks, head, key);\n if (!link) throw logger.Error().Str(\"key\", key).Msg(`Missing key`).AsError();\n return await getValueFromLink(blocks, link, logger);\n}\n\nexport function readFiles<T extends DocTypes>(blocks: BaseBlockstore, { doc }: Partial<DocValue<T>>) {\n if (!doc) return;\n if (doc._files) {\n readFileset(blocks as EncryptedBlockstore, doc._files);\n }\n if (doc._publicFiles) {\n readFileset(blocks as EncryptedBlockstore, doc._publicFiles, true);\n }\n}\n\nfunction readFileset(blocks: EncryptedBlockstore, files: DocFiles, isPublic = false) {\n for (const filename in files) {\n const fileMeta = files[filename] as DocFileMeta;\n if (fileMeta.cid) {\n if (isPublic) {\n fileMeta.url = `https://${fileMeta.cid.toString()}.ipfs.w3s.link/`;\n }\n if (fileMeta.car) {\n fileMeta.file = async () =>\n await blocks.ebOpts.storeRuntime.decodeFile(\n {\n get: async (cid: AnyLink) => {\n return await blocks.getFile(throwFalsy(fileMeta.car), cid);\n },\n },\n fileMeta.cid,\n fileMeta,\n );\n }\n }\n files[filename] = fileMeta;\n }\n}\n\nasync function getValueFromLink<T extends DocTypes>(blocks: BlockFetcher, link: AnyLink, logger: Logger): Promise<DocValue<T>> {\n const block = await blocks.get(link);\n if (!block) throw logger.Error().Str(\"link\", link.toString()).Msg(`Missing linked block`).AsError();\n const { value } = (await decode({ bytes: block.bytes, hasher, codec })) as { value: DocValue<T> };\n const cvalue = {\n ...value,\n cid: link,\n };\n readFiles(blocks as EncryptedBlockstore, cvalue);\n return cvalue;\n}\n\nclass DirtyEventFetcher<T> extends EventFetcher<T> {\n readonly logger: Logger;\n constructor(logger: Logger, blocks: BlockFetcher) {\n super(blocks);\n this.logger = logger;\n }\n async get(link: EventLink<T>): Promise<EventBlockView<T>> {\n try {\n return super.get(link);\n } catch (e) {\n this.logger.Error().Ref(\"link\", link.toString()).Err(e).Msg(\"Missing event\");\n return { value: undefined } as unknown as EventBlockView<T>;\n }\n }\n}\n\nexport async function clockChangesSince<T extends DocTypes>(\n blocks: BlockFetcher,\n head: ClockHead,\n since: ClockHead,\n opts: ChangesOptions,\n logger: Logger,\n): Promise<{ result: DocUpdate<T>[]; head: ClockHead }> {\n const eventsFetcher = (\n opts.dirty ? new DirtyEventFetcher<Operation>(logger, blocks) : new EventFetcher<Operation>(blocks)\n ) as EventFetcher<Operation>;\n const keys = new Set<string>();\n const updates = await gatherUpdates<T>(\n blocks,\n eventsFetcher,\n head,\n since,\n [],\n keys,\n new Set<string>(),\n opts.limit || Infinity,\n logger,\n );\n return { result: updates.reverse(), head };\n}\n\nasync function gatherUpdates<T extends DocTypes>(\n blocks: BlockFetcher,\n eventsFetcher: EventFetcher<Operation>,\n head: ClockHead,\n since: ClockHead,\n updates: DocUpdate<T>[] = [],\n keys: Set<string>,\n didLinks: Set<string>,\n limit: number,\n logger: Logger,\n): Promise<DocUpdate<T>[]> {\n if (limit <= 0) return updates;\n // if (Math.random() < 0.001) console.log('gatherUpdates', head.length, since.length, updates.length)\n const sHead = head.map((l) => l.toString());\n for (const link of since) {\n if (sHead.includes(link.toString())) {\n return updates;\n }\n }\n for (const link of head) {\n if (didLinks.has(link.toString())) continue;\n didLinks.add(link.toString());\n const { value: event } = await eventsFetcher.get(link);\n if (!event) continue;\n const { type } = event.data;\n let ops = [] as PutOperation[];\n if (type === \"batch\") {\n ops = event.data.ops as PutOperation[];\n } else if (type === \"put\") {\n ops = [event.data] as PutOperation[];\n }\n for (let i = ops.length - 1; i >= 0; i--) {\n const { key, value } = ops[i];\n if (!keys.has(key)) {\n // todo option to see all updates\n const docValue = await getValueFromLink<T>(blocks, value, logger);\n updates.push({ id: key, value: docValue.doc, del: docValue.del, clock: link });\n limit--;\n keys.add(key);\n }\n }\n if (event.parents) {\n updates = await gatherUpdates(blocks, eventsFetcher, event.parents, since, updates, keys, didLinks, limit, logger);\n }\n }\n return updates;\n}\n\nexport async function* getAllEntries<T extends DocTypes>(blocks: BlockFetcher, head: ClockHead, logger: Logger) {\n // return entries(blocks, head)\n for await (const [key, link] of entries(blocks, head)) {\n const docValue = await getValueFromLink(blocks, link, logger);\n yield { id: key, value: docValue.doc, del: docValue.del } as DocUpdate<T>;\n }\n}\n\nexport async function* clockVis(blocks: BlockFetcher, head: ClockHead) {\n for await (const line of vis(blocks, head)) {\n yield line;\n }\n}\n\nlet isCompacting = false;\nexport async function doCompact(blockLog: CompactFetcher, head: ClockHead, logger: Logger) {\n if (isCompacting) {\n // console.log('already compacting')\n return;\n }\n isCompacting = true;\n\n time(\"compact head\");\n for (const cid of head) {\n const bl = await blockLog.get(cid);\n if (!bl) throw logger.Error().Ref(\"cid\", cid).Msg(\"Missing head block\").AsError();\n }\n timeEnd(\"compact head\");\n\n // for await (const blk of blocks.entries()) {\n // const bl = await blockLog.get(blk.cid)\n // if (!bl) throw new Error('Missing tblock: ' + blk.cid.toString())\n // }\n\n // todo maybe remove\n // for await (const blk of blocks.loader!.entries()) {\n // const bl = await blockLog.get(blk.cid)\n // if (!bl) throw new Error('Missing db block: ' + blk.cid.toString())\n // }\n\n time(\"compact all entries\");\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n for await (const _entry of getAllEntries(blockLog, head, logger)) {\n // result.push(entry)\n // void 1;\n continue;\n }\n timeEnd(\"compact all entries\");\n\n // time(\"compact crdt entries\")\n // for await (const [, link] of entries(blockLog, head)) {\n // const bl = await blockLog.get(link)\n // if (!bl) throw new Error('Missing entry block: ' + link.toString())\n // }\n // timeEnd(\"compact crdt entries\")\n\n time(\"compact clock vis\");\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n for await (const _line of vis(blockLog, head)) {\n void 1;\n }\n timeEnd(\"compact clock vis\");\n\n time(\"compact root\");\n const result = await root(blockLog, head);\n timeEnd(\"compact root\");\n\n time(\"compact root blocks\");\n for (const { cid, bytes } of [...result.additions, ...result.removals]) {\n blockLog.loggedBlocks.putSync(cid, bytes);\n }\n timeEnd(\"compact root blocks\");\n\n time(\"compact changes\");\n await clockChangesSince(blockLog, head, [], {}, logger);\n timeEnd(\"compact changes\");\n\n isCompacting = false;\n}\n\nexport async function getBlock(blocks: BlockFetcher, cidString: string) {\n const block = await blocks.get(parse(cidString));\n if (!block) throw new Error(`Missing block ${cidString}`);\n const { cid, value } = await decode({ bytes: block.bytes, codec, hasher });\n return new Block({ cid, value, bytes: block.bytes });\n}\n","import { advance } from \"@fireproof/vendor/@web3-storage/pail/clock\";\nimport { root } from \"@fireproof/vendor/@web3-storage/pail/crdt\";\nimport { Logger, ResolveOnce } from \"@adviser/cement\";\n\nimport { clockChangesSince } from \"./crdt-helpers.js\";\nimport type { DocUpdate, ClockHead, DocTypes, VoidFn, UnReg, SuperThis, BaseBlockstore, CarTransaction } from \"./types.js\";\nimport { applyHeadQueue, ApplyHeadQueue } from \"./apply-head-queue.js\";\nimport { ensureLogger } from \"./utils.js\";\n\nexport class CRDTClockImpl {\n // todo: track local and remote clocks independently, merge on read\n // that way we can drop the whole remote if we need to\n // should go with making sure the local clock only references locally available blockstore on write\n readonly head: ClockHead = [];\n\n readonly zoomers = new Map<string, VoidFn>();\n readonly watchers = new Map<string, (updates: DocUpdate<DocTypes>[]) => void>();\n readonly emptyWatchers = new Map<string, VoidFn>();\n\n readonly blockstore: BaseBlockstore;\n\n readonly applyHeadQueue: ApplyHeadQueue<DocTypes>;\n transaction?: CarTransaction;\n\n readonly _ready: ResolveOnce<void> = new ResolveOnce<void>();\n async ready(): Promise<void> {\n return this._ready.once(async () => {\n await this.blockstore.ready();\n });\n }\n\n async close() {\n await this.blockstore.close();\n }\n\n readonly logger: Logger;\n readonly sthis: SuperThis;\n constructor(blockstore: BaseBlockstore) {\n this.sthis = blockstore.sthis;\n this.blockstore = blockstore;\n this.logger = ensureLogger(blockstore.sthis, \"CRDTClock\");\n this.applyHeadQueue = applyHeadQueue(this.int_applyHead.bind(this), this.logger);\n }\n\n setHead(head: ClockHead) {\n // this.head = head;\n this.head.splice(0, this.head.length, ...head);\n }\n\n async applyHead(newHead: ClockHead, prevHead: ClockHead, updates?: DocUpdate<DocTypes>[]): Promise<void> {\n for await (const { updates: updatesAcc, all } of this.applyHeadQueue.push({\n newHead,\n prevHead,\n updates,\n })) {\n return this.processUpdates(updatesAcc, all, prevHead);\n }\n }\n\n async processUpdates(updatesAcc: DocUpdate<DocTypes>[], all: boolean, prevHead: ClockHead) {\n let internalUpdates = updatesAcc;\n if (this.watchers.size && !all) {\n const changes = await clockChangesSince<DocTypes>(this.blockstore, this.head, prevHead, {}, this.logger);\n internalUpdates = changes.result;\n }\n this.zoomers.forEach((fn) => fn());\n this.notifyWatchers(internalUpdates || []);\n }\n\n notifyWatchers(updates: DocUpdate<DocTypes>[]) {\n this.emptyWatchers.forEach((fn) => fn());\n this.watchers.forEach((fn) => fn(updates || []));\n }\n\n onTick(fn: (updates: DocUpdate<DocTypes>[]) => void): UnReg {\n const key = this.sthis.timeOrderedNextId().str;\n this.watchers.set(key, fn);\n return () => {\n this.watchers.delete(key);\n };\n }\n\n onTock(fn: VoidFn): UnReg {\n const key = this.sthis.timeOrderedNextId().str;\n this.emptyWatchers.set(key, fn);\n return () => {\n this.emptyWatchers.delete(key);\n };\n }\n\n onZoom(fn: VoidFn): UnReg {\n const key = this.sthis.timeOrderedNextId().str;\n this.zoomers.set(key, fn);\n return () => {\n this.zoomers.delete(key);\n };\n }\n\n async int_applyHead(newHead: ClockHead, prevHead: ClockHead, localUpdates: boolean) {\n // if (!(this.head && prevHead && newHead)) {\n // throw new Error(\"missing head\");\n // }\n const noLoader = !localUpdates;\n\n // console.log(\"int_applyHead\", this.applyHeadQueue.size(), this.head, newHead, prevHead, localUpdates);\n const ogHead = sortClockHead(this.head);\n newHead = sortClockHead(newHead);\n if (compareClockHeads(ogHead, newHead)) {\n return;\n }\n const ogPrev = sortClockHead(prevHead);\n if (compareClockHeads(ogHead, ogPrev)) {\n this.setHead(newHead);\n return;\n }\n\n // const noLoader = this.head.length === 1 && !updates?.length\n if (!this.blockstore) {\n throw this.logger.Error().Msg(\"missing blockstore\").AsError();\n }\n await validateBlocks(this.logger, newHead, this.blockstore);\n if (!this.transaction) {\n this.transaction = this.blockstore.openTransaction({ noLoader, add: false });\n }\n const tblocks = this.transaction;\n\n const advancedHead = await advanceBlocks(this.logger, newHead, tblocks, this.head);\n const result = await root(tblocks, advancedHead);\n for (const { cid, bytes } of [\n ...result.additions,\n // ...result.removals\n ]) {\n tblocks.putSync(cid, bytes);\n }\n if (!noLoader) {\n await this.blockstore.commitTransaction(tblocks, { head: advancedHead }, { add: false, noLoader });\n this.transaction = undefined;\n }\n this.setHead(advancedHead);\n }\n}\n\n// Helper functions\nfunction sortClockHead(clockHead: ClockHead) {\n return clockHead.sort((a, b) => a.toString().localeCompare(b.toString()));\n}\n\nasync function validateBlocks(logger: Logger, newHead: ClockHead, blockstore?: BaseBlockstore) {\n if (!blockstore) throw logger.Error().Msg(\"missing blockstore\");\n newHead.map(async (cid) => {\n const got = await blockstore.get(cid);\n if (!got) {\n throw logger.Error().Str(\"cid\", cid.toString()).Msg(\"int_applyHead missing block\").AsError();\n }\n });\n}\n\nfunction compareClockHeads(head1: ClockHead, head2: ClockHead) {\n return head1.toString() === head2.toString();\n}\n\nasync function advanceBlocks(logger: Logger, newHead: ClockHead, tblocks: CarTransaction, head: ClockHead) {\n for (const cid of newHead) {\n try {\n head = await advance(tblocks, head, cid);\n } catch (e) {\n logger.Debug().Err(e).Msg(\"failed to advance head\");\n // console.log('failed to advance head:', cid.toString(), e)\n continue;\n }\n }\n return head;\n}\n","import { Logger } from \"@adviser/cement\";\nimport { ClockHead, DocTypes, DocUpdate } from \"./types.js\";\n\ntype ApplyHeadWorkerFunction = (newHead: ClockHead, prevHead: ClockHead, localUpdates: boolean) => Promise<void>;\n\ninterface ApplyHeadTask<T extends DocTypes> {\n readonly newHead: ClockHead;\n readonly prevHead: ClockHead;\n readonly updates?: DocUpdate<T>[];\n}\n\nexport interface ApplyHeadQueue<T extends DocTypes> {\n push(task: ApplyHeadTask<T>): AsyncGenerator<\n {\n readonly updates: DocUpdate<T>[];\n readonly all: boolean;\n },\n void,\n unknown\n >;\n size(): number;\n}\n\nexport function applyHeadQueue<T extends DocTypes>(worker: ApplyHeadWorkerFunction, logger: Logger): ApplyHeadQueue<T> {\n const queue: ApplyHeadTask<T>[] = [];\n let isProcessing = false;\n\n async function* process() {\n if (isProcessing || queue.length === 0) return;\n isProcessing = true;\n const allUpdates: DocUpdate<T>[] = [];\n try {\n while (queue.length > 0) {\n queue.sort((a, b) => (b.updates ? 1 : -1));\n const task = queue.shift();\n if (!task) continue;\n\n await worker(task.newHead, task.prevHead, task.updates !== undefined).catch((e) => {\n throw logger.Error().Err(e).Msg(\"int_applyHead worker error\").AsError();\n });\n // console.timeEnd('int_applyHead worker')\n\n if (task.updates) {\n allUpdates.push(...task.updates);\n }\n // Yield the updates if there are no tasks with updates left in the queue or the current task has updates\n if (!queue.some((t) => t.updates) || task.updates) {\n const allTasksHaveUpdates = queue.every((task) => task.updates !== null);\n yield { updates: allUpdates, all: allTasksHaveUpdates };\n allUpdates.length = 0;\n }\n }\n } finally {\n isProcessing = false;\n const generator = process();\n let result = await generator.next();\n while (!result.done) {\n result = await generator.next();\n }\n }\n }\n\n return {\n push(task: ApplyHeadTask<T>): AsyncGenerator<{ updates: DocUpdate<T>[]; all: boolean }, void, unknown> {\n queue.push(task);\n return process();\n },\n size() {\n return queue.length;\n },\n };\n}\n","// export * from \"./sys-container.js\";\nexport * from \"./gateways/file/utils.js\";\n\n// export * as sql from \"./store-sql/index.js\";\nexport * as files from \"./files.js\";\n\nexport * as kb from \"./key-bag.js\";\nexport * as kc from \"./keyed-crypto.js\";\n\nexport * as mf from \"./wait-pr-multiformats/index.js\";\n\nexport { runtimeFn } from \"@adviser/cement\";\n\nexport * as gw from \"./gateways/index.js\";\n\nexport * from \"./key-bag.js\";\n\nexport { FILESTORE_VERSION } from \"./gateways/file/version.js\";\nexport { INDEXDB_VERSION } from \"./gateways/indexdb/version.js\";\n// export { V0_19SQL_VERSION } from \"./store-sql/v0.19/version.js\";\n","export * as block from \"./block.js\";\nexport * as codec from \"./codec-interface.js\";\n","import type { ArrayBufferView, ByteView } from \"multiformats\";\n\n/**\n * IPLD encoder part of the codec.\n */\nexport interface BlockEncoder<Code extends number, T> {\n name: string;\n code: Code;\n encode(data: T): ByteView<T> | PromiseLike<ByteView<T>>;\n}\n\n/**\n * IPLD decoder part of the codec.\n */\nexport interface BlockDecoder<Code extends number, T> {\n code: Code;\n decode(bytes: ByteView<T> | ArrayBufferView<T>): T | PromiseLike<T>;\n}\n\n/**\n * An IPLD codec is a combination of both encoder and decoder.\n */\nexport interface BlockCodec<Code extends number, T> extends BlockEncoder<Code, T>, BlockDecoder<Code, T> {}\n\nexport type { ArrayBufferView, ByteView };\n","export * from \"./fp-envelope-serialize.js\";\nexport * as file from \"./file/index.js\";\n","export * from \"./key-bag-file.js\";\nexport * from \"./sys-file-system-factory.js\";\n","export const PACKAGE_VERSION = Object.keys({\n \"0.20.0-dev-preview-10\": \"xxxx\",\n})[0] as string;\n"],"mappings":"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","names":["BuildURI","KeyedResolvOnce","ResolveOnce","URI","PARAM","raw","index","ResolveOnce","Result","runtimeFn","toCryptoRuntime","URI","base58btc","ResolveOnce","base58btc","Result","runtimeFn","URI","toCryptoRuntime","runtimeFn","KeyedResolvOnce","Result","getStore","KeyedResolvOnce","Result","Result","Result","Result","exception2Result","Result","Result","FPEnvelopeType","Result","exception2Result","raw","Result","runtimeFn","CID","codec","hasher","root","ResolveOnce","KeyedResolvOnce","Result","exception2Result","ResolveOnce","Result","ResolveOnce","hasher","toCryptoRuntime","toCryptoRuntime","Future","hasher","dagCodec","codec","hasher","dagCodec","hasher","cid","ResolveOnce","cid","cache","got","batchSize","hasher","base58btc","hasher","hasher","base58btc","EventBlock","format","Result","Result","exception2Result","EventBlock","format","ResolveOnce","KeyedResolvOnce","Result","parse","hasher","codec","hasher","codec","parse","root","ResolveOnce","task","ResolveOnce","root","ResolveOnce","KeyedResolvOnce","ResolveOnce","updates","defaultURI","URI","BuildURI","runtimeFn","runtimeFn"]}