@xyo-network/bridge-pub-sub 2.94.16 → 2.94.17
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/AsyncQueryBus/AsyncQueryBusBase.d.cts +7 -72
- package/dist/browser/AsyncQueryBus/AsyncQueryBusBase.d.cts.map +1 -1
- package/dist/browser/AsyncQueryBus/AsyncQueryBusBase.d.mts +7 -72
- package/dist/browser/AsyncQueryBus/AsyncQueryBusBase.d.mts.map +1 -1
- package/dist/browser/AsyncQueryBus/AsyncQueryBusBase.d.ts +7 -72
- package/dist/browser/AsyncQueryBus/AsyncQueryBusBase.d.ts.map +1 -1
- package/dist/browser/index.cjs +59 -114
- package/dist/browser/index.cjs.map +1 -1
- package/dist/browser/index.js +54 -109
- package/dist/browser/index.js.map +1 -1
- package/dist/node/AsyncQueryBus/AsyncQueryBusBase.d.cts +7 -72
- package/dist/node/AsyncQueryBus/AsyncQueryBusBase.d.cts.map +1 -1
- package/dist/node/AsyncQueryBus/AsyncQueryBusBase.d.mts +7 -72
- package/dist/node/AsyncQueryBus/AsyncQueryBusBase.d.mts.map +1 -1
- package/dist/node/AsyncQueryBus/AsyncQueryBusBase.d.ts +7 -72
- package/dist/node/AsyncQueryBus/AsyncQueryBusBase.d.ts.map +1 -1
- package/dist/node/index.cjs +64 -118
- package/dist/node/index.cjs.map +1 -1
- package/dist/node/index.js +59 -113
- package/dist/node/index.js.map +1 -1
- package/package.json +18 -18
- package/src/AsyncQueryBus/AsyncQueryBusBase.ts +58 -101
package/dist/node/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/AbstractModuleHost/AbstractModuleHost.ts","../../src/AsyncQueryBus/AsyncQueryBusClient.ts","../../src/AsyncQueryBus/AsyncQueryBusBase.ts","../../src/AsyncQueryBus/model/QueryStatus.ts","../../src/AsyncQueryBus/AsyncQueryBusHost.ts","../../src/AsyncQueryBus/ModuleHost/ModuleHost.ts","../../src/AsyncQueryBus/ModuleProxy/ModuleProxy.ts","../../src/Schema.ts","../../src/Config.ts","../../src/PubSubBridge.ts","../../src/PubSubBridgeModuleResolver.ts"],"sourcesContent":["export * from './AbstractModuleHost'\nexport * from './AsyncQueryBus'\nexport * from './Config'\nexport * from './Params'\nexport * from './PubSubBridge'\nexport * from './PubSubBridgeModuleResolver'\nexport * from './Schema'\n","import { Base, BaseParams } from '@xylabs/object'\nimport { Promisable } from '@xylabs/promise'\nimport { ModuleInstance } from '@xyo-network/module-model'\n\nexport type ModuleHostParams<THostedInstance extends ModuleInstance = ModuleInstance> = BaseParams<{\n module: THostedInstance\n}>\n\nexport abstract class AbstractModuleHost<TParams extends ModuleHostParams = ModuleHostParams> extends Base<TParams> {\n abstract start(): Promisable<void>\n abstract stop(): Promisable<void>\n}\n","import { assertEx } from '@xylabs/assert'\nimport { delay } from '@xylabs/delay'\nimport { forget } from '@xylabs/forget'\nimport { Address } from '@xylabs/hex'\nimport { clearTimeoutEx, setTimeoutEx } from '@xylabs/timer'\nimport { isBoundWitnessWithMeta, QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { BoundWitnessDivinerQueryPayload, BoundWitnessDivinerQuerySchema } from '@xyo-network/diviner-boundwitness-model'\nimport { CacheConfig, ModuleQueryResult } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { ModuleError, Payload, PayloadWithMeta, WithMeta } from '@xyo-network/payload-model'\nimport { LRUCache } from 'lru-cache'\n\nimport { AsyncQueryBusBase } from './AsyncQueryBusBase'\nimport { AsyncQueryBusClientParams, Pending } from './model'\n\nexport class AsyncQueryBusClient<TParams extends AsyncQueryBusClientParams = AsyncQueryBusClientParams> extends AsyncQueryBusBase<TParams> {\n protected _queryCache?: LRUCache<Address, Pending | ModuleQueryResult>\n private _pollCount = 0\n private _pollId?: string\n\n constructor(params: TParams) {\n super(params)\n }\n\n get queryCacheConfig(): LRUCache.Options<Address, Pending | ModuleQueryResult, unknown> {\n const queryCacheConfig: CacheConfig | undefined = this.config?.queryCache === true ? {} : this.config?.queryCache\n return { max: 100, ttl: 1000 * 60, ...queryCacheConfig }\n }\n\n get started() {\n return !!this._pollId\n }\n\n /**\n * A cache of queries that have been issued\n */\n protected get queryCache(): LRUCache<Address, Pending | ModuleQueryResult> {\n const config = this.queryCacheConfig\n const requiredConfig = { noUpdateTTL: false, ttlAutopurge: true }\n this._queryCache = this._queryCache ?? new LRUCache<Address, Pending | ModuleQueryResult>({ ...config, ...requiredConfig })\n return this._queryCache\n }\n\n listeningAddresses() {\n return this._queryCache?.keys()\n }\n\n async send(address: Address, query: QueryBoundWitness, payloads?: Payload[] | undefined): Promise<ModuleQueryResult> {\n //console.log('send')\n this.logger?.debug(`Begin issuing query to: ${address}`)\n const $meta = { ...query?.$meta, destination: [address] }\n const routedQuery = await PayloadBuilder.build({ ...query, $meta })\n //console.log('queryArchivist - calling')\n const queryArchivist = assertEx(\n await this.queriesArchivist(),\n () => `Unable to contact queriesArchivist [${this.config?.intersect?.queries?.archivist}]`,\n )\n //console.log('queryArchivist')\n\n // TODO: Should we always re-hash to true up timestamps? We can't\n // re-sign correctly so we would lose that information if we did and\n // would also be replying to consumers with a different query hash than\n // they sent us (which might be OK since it reflect the chain of custody)\n // Revisit this once we have proxy module support as they are another\n // intermediary to consider.\n const routedQueryHash =\n // Trust the signed hash if it's there\n (routedQuery as WithMeta<QueryBoundWitness>)?.$hash ??\n // TODO: What is the right way to find the dataHash\n Object.keys(await PayloadBuilder.toDataHashMap([routedQuery]))[0]\n this.logger?.debug(`Issuing query: ${routedQueryHash} to: ${address}`)\n // If there was data associated with the query, add it to the insert\n const data = payloads ? [routedQuery, ...payloads] : [routedQuery]\n const insertResult = await queryArchivist.insert?.(data)\n this.logger?.debug(`Issued query: ${routedQueryHash} to: ${address}`)\n this.queryCache.set(routedQueryHash, Pending)\n if (!insertResult) throw new Error('Unable to issue query to queryArchivist')\n const context = new Promise<ModuleQueryResult>((resolve, reject) => {\n this.logger?.debug(`Polling for response to query: ${routedQueryHash}`)\n const pollForResponse = async () => {\n try {\n this.start()\n let response = this.queryCache.get(routedQueryHash)\n // Poll for response until cache key expires (response timed out)\n while (response !== undefined) {\n //console.log('polling...')\n // Wait a bit\n await delay(100)\n // Check the status of the response\n response = this.queryCache.get(routedQueryHash)\n // If status is no longer pending that means we received a response\n if (response && response !== Pending) {\n this.logger?.debug(`Returning response to query: ${routedQueryHash}`)\n resolve(response)\n return\n }\n }\n // If we got here waiting for a response timed out\n this.logger?.error('Timeout waiting for query response')\n // Resolve with error to match what a local module would do if it were to error\n // TODO: BW Builder/Sign result as this module?\n const error: ModuleError = {\n message: 'Timeout waiting for query response',\n query: 'network.xyo.boundwitness',\n schema: 'network.xyo.error.module',\n sources: [routedQueryHash],\n }\n reject(error)\n return\n } finally {\n this.stop()\n }\n }\n forget(pollForResponse())\n })\n return context\n }\n\n /**\n * Runs the background divine process on a loop with a delay\n * specified by the `config.pollFrequency`\n */\n private poll() {\n this._pollId = setTimeoutEx(async () => {\n try {\n await this.processIncomingResponses()\n } catch (e) {\n this.logger?.error?.(`Error in main loop: ${e}`)\n } finally {\n if (this._pollId) clearTimeoutEx(this._pollId)\n this._pollId = undefined\n this.poll()\n }\n }, this.pollFrequencyConfig)\n }\n\n /**\n * Background process for processing incoming responses to previously issued queries\n */\n private processIncomingResponses = async () => {\n const responseArchivist = await this.responsesArchivist()\n if (responseArchivist) {\n const responseBoundWitnessDiviner = await this.responsesDiviner()\n if (responseBoundWitnessDiviner) {\n const pendingCommands = [...this.queryCache.entries()].filter(([_, status]) => status === Pending)\n // TODO: Do in throttled batches\n await Promise.allSettled(\n pendingCommands.map(async ([sourceQuery, status]) => {\n if (status === Pending) {\n const divinerQuery: BoundWitnessDivinerQueryPayload = { schema: BoundWitnessDivinerQuerySchema, sourceQuery }\n const result = await responseBoundWitnessDiviner.divine([divinerQuery])\n if (result && result.length > 0) {\n const response = result.find(isBoundWitnessWithMeta)\n if (response && (response?.$meta as unknown as { sourceQuery: string })?.sourceQuery === sourceQuery) {\n this.logger?.debug(`Found response to query: ${sourceQuery}`)\n // Get any payloads associated with the response\n const payloads: PayloadWithMeta[] = response.payload_hashes?.length > 0 ? await responseArchivist.get(response.payload_hashes) : []\n this.queryCache.set(sourceQuery, [response, payloads, []])\n }\n }\n }\n }),\n )\n }\n }\n }\n\n private start() {\n if (this._pollCount === 0) {\n this.poll()\n }\n this._pollCount++\n }\n\n private stop() {\n this._pollCount--\n if (this._pollCount <= 0) {\n if (this._pollId) clearTimeoutEx(this._pollId)\n this._pollId = undefined\n this._pollCount = 0\n }\n }\n}\n","import { Address } from '@xylabs/hex'\nimport { Base, toJsonString } from '@xylabs/object'\nimport { ArchivistInstance, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitness, QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { BoundWitnessDivinerParams, BoundWitnessDivinerQueryPayload } from '@xyo-network/diviner-boundwitness-model'\nimport { asDivinerInstance, DivinerInstance } from '@xyo-network/diviner-model'\nimport { ModuleConfig } from '@xyo-network/module-model'\nimport { Mutex } from 'async-mutex'\nimport { LRUCache } from 'lru-cache'\n\nimport { AsyncQueryBusParams } from './model'\n\nexport class AsyncQueryBusBase<TParams extends AsyncQueryBusParams = AsyncQueryBusParams> extends Base<TParams> {\n protected _lastState?: LRUCache<Address, number>\n protected _targetConfigs: Record<Address, ModuleConfig> = {}\n protected _targetQueries: Record<Address, string[]> = {}\n\n private _lastQueriesArchivistAttempt?: number\n private _lastQueriesDivinerAttempt?: number\n private _lastResponsesArchivistAttempt?: number\n private _lastResponsesDivinerAttempt?: number\n private _queriesArchivist?: ArchivistInstance\n private _queriesArchivistMutex = new Mutex()\n private _queriesDiviner?: DivinerInstance<BoundWitnessDivinerParams, BoundWitnessDivinerQueryPayload, QueryBoundWitness>\n private _queriesDivinerMutex = new Mutex()\n private _reResolveDelay = 50_000\n private _responsesArchivist?: ArchivistInstance\n private _responsesArchivistMutex = new Mutex()\n private _responsesDiviner?: DivinerInstance<BoundWitnessDivinerParams, BoundWitnessDivinerQueryPayload, BoundWitness>\n private _responsesDivinerMutex = new Mutex()\n\n constructor(params: TParams) {\n super(params)\n }\n\n get config(): TParams['config'] {\n return this.params.config\n }\n\n get pollFrequencyConfig(): number {\n return this.config?.pollFrequency ?? 1000\n }\n\n get resolver() {\n return this.params.resolver\n }\n\n /**\n * A cache of the last offset of the Diviner process per address\n */\n protected get lastState(): LRUCache<Address, number> {\n const requiredConfig = { max: 1000, ttl: 0 }\n this._lastState = this._lastState ?? new LRUCache<Address, number>(requiredConfig)\n return this._lastState\n }\n\n async queriesArchivist() {\n return await this._queriesArchivistMutex.runExclusive(async () => {\n if (this._queriesArchivist) {\n return this._queriesArchivist\n }\n if (Date.now() - (this._lastQueriesArchivistAttempt ?? 0) < this._reResolveDelay) {\n return\n }\n this._lastQueriesArchivistAttempt = Date.now()\n const resolved = await this.resolver.resolve(this.config?.intersect?.queries?.archivist)\n if (resolved) {\n const typedResolve = asArchivistInstance(resolved)\n if (typedResolve) {\n return typedResolve\n } else {\n this.logger?.warn(\n `Unable to resolve queriesArchivist as correct type [${this.config?.intersect?.queries?.archivist}][${resolved?.constructor?.name}]: ${toJsonString(resolved)}`,\n )\n }\n } else {\n this.logger?.log(`Unable to resolve queriesArchivist [${this.config?.intersect?.queries?.archivist}]`)\n }\n })\n }\n\n async queriesDiviner() {\n return await this._queriesDivinerMutex.runExclusive(async () => {\n if (this._queriesDiviner) {\n return this._queriesDiviner\n }\n if (Date.now() - (this._lastQueriesDivinerAttempt ?? 0) < this._reResolveDelay) {\n return\n }\n this._lastQueriesDivinerAttempt = Date.now()\n const resolved = await this.resolver.resolve(this.config?.intersect?.queries?.boundWitnessDiviner)\n if (resolved) {\n const typedResolve = asDivinerInstance(resolved)\n if (typedResolve) {\n return typedResolve\n } else {\n this.logger?.warn(\n `Unable to resolve queriesDiviner as correct type [${this.config?.intersect?.queries?.boundWitnessDiviner}][${resolved?.constructor?.name}]: ${toJsonString(resolved)}`,\n )\n }\n } else {\n this.logger?.log(`Unable to resolve queriesDiviner [${this.config?.intersect?.queries?.boundWitnessDiviner}]`)\n }\n })\n }\n\n async responsesArchivist() {\n return await this._responsesArchivistMutex.runExclusive(async () => {\n if (this._responsesArchivist) {\n return this._responsesArchivist\n }\n if (Date.now() - (this._lastResponsesArchivistAttempt ?? 0) < this._reResolveDelay) {\n return\n }\n this._lastResponsesArchivistAttempt = Date.now()\n const resolved = await this.resolver.resolve(this.config?.intersect?.responses?.archivist)\n if (resolved) {\n const typedResolve = asArchivistInstance(resolved)\n if (typedResolve) {\n return typedResolve\n } else {\n this.logger?.warn(\n `Unable to resolve responseArchivist as correct type [${this.config?.intersect?.responses?.archivist}][${resolved?.constructor?.name}]: ${toJsonString(resolved)}`,\n )\n }\n } else {\n this.logger?.log(`Unable to resolve responseArchivist [${this.config?.intersect?.responses?.archivist}]`)\n }\n })\n }\n\n async responsesDiviner() {\n return await this._responsesDivinerMutex.runExclusive(async () => {\n if (this._responsesDiviner) {\n return this._responsesDiviner\n }\n if (Date.now() - (this._lastResponsesDivinerAttempt ?? 0) < this._reResolveDelay) {\n return\n }\n this._lastResponsesDivinerAttempt = Date.now()\n const resolved = await this.resolver.resolve(this.config?.intersect?.responses?.boundWitnessDiviner)\n if (resolved) {\n const typedResolve = asDivinerInstance(resolved)\n if (typedResolve) {\n return typedResolve\n } else {\n this.logger?.warn(\n `Unable to resolve responsesDiviner as correct type [${this.config?.intersect?.responses?.boundWitnessDiviner}][${resolved?.constructor?.name}]: ${toJsonString(resolved)}`,\n )\n }\n } else {\n this.logger?.log(`Unable to resolve responsesDiviner [${this.config?.intersect?.responses?.boundWitnessDiviner}]`)\n }\n })\n }\n\n /**\n * Commit the internal state of the process. This is similar\n * to a transaction completion in a database and should only be called\n * when results have been successfully persisted to the appropriate\n * external stores.\n * @param address The module address to commit the state for\n * @param nextState The state to commit\n */\n protected async commitState(address: Address, nextState: number) {\n await Promise.resolve()\n // TODO: Offload to Archivist/Diviner instead of in-memory\n const lastState = this.lastState.get(address)\n if (lastState && lastState >= nextState) return\n this.lastState.set(address, nextState)\n }\n\n /**\n * Retrieves the last state of the process. Used to recover state after\n * preemptions, reboots, etc.\n */\n protected async retrieveState(address: Address): Promise<number> {\n await Promise.resolve()\n const state = this.lastState.get(address)\n if (state === undefined) {\n // If this is a boot we can go back a bit in time\n // and begin processing recent commands\n const newState = Date.now() - 1000\n this.lastState.set(address, newState)\n return newState\n } else {\n return state\n }\n }\n}\n","export const Pending = 'pending' as const\nexport type Pending = typeof Pending\n","import { containsAll } from '@xylabs/array'\nimport { assertEx } from '@xylabs/assert'\nimport { Address } from '@xylabs/hex'\nimport { clearTimeoutEx, setTimeoutEx } from '@xylabs/timer'\nimport { isQueryBoundWitnessWithMeta, QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { BoundWitnessDivinerQuerySchema } from '@xyo-network/diviner-boundwitness-model'\nimport { asModuleInstance, ModuleConfigSchema, ModuleIdentifier, ModuleInstance } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Schema, WithMeta } from '@xyo-network/payload-model'\n\nimport { AsyncQueryBusBase } from './AsyncQueryBusBase'\nimport { AsyncQueryBusHostParams } from './model'\n\nexport interface ExposeOptions {\n allowedQueries?: Schema[]\n failOnAlreadyExposed?: boolean\n required?: boolean\n}\n\nexport class AsyncQueryBusHost<TParams extends AsyncQueryBusHostParams = AsyncQueryBusHostParams> extends AsyncQueryBusBase<TParams> {\n protected _exposedAddresses = new Set<Address>()\n private _exposeOptions: Record<Address, ExposeOptions> = {}\n private _pollId?: string\n\n constructor(params: TParams) {\n super(params)\n }\n\n get exposedAddresses() {\n return this._exposedAddresses\n }\n\n get perAddressBatchQueryLimit(): number {\n return this.config?.perAddressBatchQueryLimit ?? 10\n }\n\n get started() {\n return !!this._pollId\n }\n\n async expose(id: ModuleIdentifier, options?: ExposeOptions) {\n const { failOnAlreadyExposed, required = true } = options ?? {}\n const module = asModuleInstance(await this.resolver.resolve(id, { maxDepth: 10 }))\n if (!module && required) {\n throw new Error(`Unable to resolve module to expose [${id}]`)\n }\n if (module) {\n assertEx(!failOnAlreadyExposed || !this._exposedAddresses.has(module.address), () => `Address already exposed: ${id} [${module.address}]`)\n this._exposedAddresses.add(module.address)\n this._exposeOptions[module.address] = { ...options }\n this.logger?.debug(`${id} exposed [${module.address}]`)\n return module\n }\n }\n\n async listeningModules(): Promise<ModuleInstance[]> {\n const exposedModules = [...(this.config?.listeningModules ?? []), ...this.exposedAddresses.values()]\n const mods = await Promise.all(\n exposedModules.map(async (exposedModule) =>\n assertEx(\n asModuleInstance(await this.resolver.resolve(exposedModule, { maxDepth: 10 })),\n () => `Unable to resolve listeningModule [${exposedModule}]`,\n ),\n ),\n )\n return mods\n }\n\n start() {\n if (this.started) {\n console.warn('AsyncQueryBus starting when already started')\n }\n this.poll()\n }\n\n stop() {\n if (!this.started) {\n console.warn('AsyncQueryBus stopping when already stopped')\n }\n if (this._pollId) clearTimeoutEx(this._pollId)\n this._pollId = undefined\n }\n\n async unexpose(id: ModuleIdentifier, validate = true) {\n const module = asModuleInstance(await this.resolver.resolve(id, { maxDepth: 10 }))\n if (module) {\n assertEx(!validate || this._exposedAddresses.has(module.address), () => `Address not exposed [${module.address}][${module.id}]`)\n this._exposedAddresses.delete(module.address)\n delete this._exposeOptions[module.address]\n this.logger?.debug(`${module.address} [${module.id}] unexposed`)\n }\n return module\n }\n\n protected callLocalModule = async (localModule: ModuleInstance, query: WithMeta<QueryBoundWitness>) => {\n const localModuleName = localModule.config.name ?? localModule.address\n const queryArchivist = assertEx(\n await this.queriesArchivist(),\n () => `Unable to contact queriesArchivist [${this.config?.intersect?.queries?.archivist}]`,\n )\n const responsesArchivist = assertEx(\n await this.responsesArchivist(),\n () => `Unable to contact responsesArchivist [${this.config?.intersect?.queries?.archivist}]`,\n )\n const queryDestination = (query.$meta as { destination?: string[] })?.destination\n if (queryDestination && queryDestination?.includes(localModule.address)) {\n // Find the query\n const queryIndex = query.payload_hashes.indexOf(query.query)\n if (queryIndex !== -1) {\n const querySchema = query.payload_schemas[queryIndex]\n // If the destination can process this type of query\n if (localModule.queries.includes(querySchema)) {\n // Get the associated payloads\n const queryPayloads = await queryArchivist.get(query.payload_hashes)\n const queryPayloadsDict = await PayloadBuilder.toAllHashMap(queryPayloads)\n const queryHash = (await PayloadBuilder.build(query)).$hash\n // Check that we have all the arguments for the command\n if (!containsAll(Object.keys(queryPayloadsDict), query.payload_hashes)) {\n this.logger?.error(`Error processing command ${queryHash} for module ${localModuleName}, missing payloads`)\n return\n }\n try {\n // Issue the query against module\n const querySchema = queryPayloadsDict[query.query].schema\n this.logger?.debug(`Issuing query ${querySchema} (${queryHash}) addressed to module: ${localModuleName}`)\n const response = await localModule.query(query, queryPayloads, {\n allowedQueries: this._exposeOptions[localModule.address]?.allowedQueries,\n schema: ModuleConfigSchema,\n })\n const [bw, payloads, errors] = response\n this.logger?.debug(`Replying to query ${queryHash} addressed to module: ${localModuleName}`)\n const insertResult = await responsesArchivist.insert([bw, ...payloads, ...errors])\n // NOTE: If all archivists support the contract that numPayloads inserted === numPayloads returned we can\n // do some deeper assertions here like lenIn === lenOut, but for now this should be good enough since BWs\n // should always be unique causing at least one insertion\n if (insertResult.length === 0) {\n this.logger?.error(`Error replying to query ${queryHash} addressed to module: ${localModuleName}`)\n }\n if (query?.timestamp) {\n // TODO: This needs to be thought through as we can't use a distributed timestamp\n // because of collisions. We need to ensure we are using the timestamp of the store\n // so there's no chance of multiple commands at the same time\n await this.commitState(localModule.address, query.timestamp)\n }\n } catch (error) {\n this.logger?.error(`Error processing query ${queryHash} for module ${localModuleName}: ${error}`)\n console.error(`Error processing query ${queryHash} for module ${localModuleName}: ${error}`)\n }\n }\n }\n }\n }\n\n /**\n * Finds unprocessed commands addressed to the supplied address\n * @param address The address to find commands for\n */\n protected findQueriesToAddress = async (address: Address) => {\n const queryBoundWitnessDiviner = await this.queriesDiviner()\n if (queryBoundWitnessDiviner) {\n // Retrieve last offset from state store\n const timestamp = await this.retrieveState(address)\n const destination = [address]\n const limit = this.perAddressBatchQueryLimit\n // Filter for commands to us by destination address\n const divinerQuery = { destination, limit, schema: BoundWitnessDivinerQuerySchema, sort: 'asc', timestamp }\n const result = await queryBoundWitnessDiviner.divine([divinerQuery])\n const queries = result.filter(isQueryBoundWitnessWithMeta)\n const nextState = queries.length > 0 ? Math.max(...queries.map((c) => c.timestamp ?? 0)) + 1 : timestamp\n // TODO: This needs to be thought through as we can't use a distributed timestamp\n // because of collisions. We need to use the timestamp of the store so there's no\n // chance of multiple commands at the same time\n await this.commitState(address, nextState)\n return queries\n } else {\n this.logger?.warn(`Unable to resolve queryBoundWitnessDiviner [${this.config?.intersect?.queries?.boundWitnessDiviner}]`)\n }\n }\n\n /**\n * Runs the background divine process on a loop with a delay\n * specified by the `config.pollFrequency`\n */\n private poll() {\n this._pollId = setTimeoutEx(async () => {\n try {\n await this.processIncomingQueries()\n } catch (e) {\n this.logger?.error?.(`Error in main loop: ${e}`)\n } finally {\n if (this._pollId) clearTimeoutEx(this._pollId)\n this._pollId = undefined\n this.poll()\n }\n }, this.pollFrequencyConfig)\n }\n\n /**\n * Background process for checking for inbound queries\n */\n private processIncomingQueries = async () => {\n this.logger?.debug('Checking for inbound queries')\n // Check for any queries that have been issued and have not been responded to\n const localModules = await this.listeningModules()\n\n // TODO: Do in throttled batches\n await Promise.allSettled(\n localModules.map(async (localModule) => {\n try {\n const localModuleName = localModule.config.name ?? localModule.address\n this.logger?.debug(`Checking for inbound queries to ${localModuleName} [${localModule.address}]`)\n const queries = (await this.findQueriesToAddress(localModule.address)) ?? []\n if (queries.length === 0) return\n this.logger?.debug(`Found queries addressed to local module: ${localModuleName}`)\n for (const query of queries) {\n await this.callLocalModule(localModule, query)\n }\n } catch (error) {\n this.logger?.error(`Error processing queries for address ${localModule.address}: ${error}`)\n }\n }),\n )\n }\n}\n","import { AbstractModuleHost, ModuleHostParams } from '../../AbstractModuleHost'\nimport { AsyncQueryBusHost } from '../AsyncQueryBusHost'\nimport { AsyncQueryBusHostConfig } from '../model'\n\nexport type AsyncQueryBusModuleHostParams = ModuleHostParams & {\n config: AsyncQueryBusHostConfig\n}\n\nexport class AsyncQueryBusModuleHost extends AbstractModuleHost<AsyncQueryBusModuleHostParams> {\n private _busHost?: AsyncQueryBusHost\n\n constructor(params: AsyncQueryBusModuleHostParams) {\n super(params)\n }\n\n override async start(): Promise<void> {\n const listeningModules =\n this.params.config.listeningModules ?? (await this.params.module.resolve('*', { direction: 'down' })).map((m) => m.address)\n this._busHost = new AsyncQueryBusHost({\n config: { ...this.params.config, listeningModules },\n logger: this.params.logger,\n resolver: this.params.module,\n })\n this._busHost?.start()\n }\n override stop() {\n this._busHost?.stop()\n }\n}\n","import { AbstractModuleProxy, ModuleProxyParams } from '@xyo-network/abstract-bridge'\nimport { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { ModuleInstance, ModuleQueryResult } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nimport { AsyncQueryBusClient } from '../AsyncQueryBusClient'\n\nexport type AsyncQueryBusModuleProxyParams = ModuleProxyParams & {\n busClient: AsyncQueryBusClient\n}\n\nexport class AsyncQueryBusModuleProxy<\n TWrappedModule extends ModuleInstance = ModuleInstance,\n TParams extends Omit<AsyncQueryBusModuleProxyParams, 'config'> & { config: TWrappedModule['config'] } = Omit<\n AsyncQueryBusModuleProxyParams,\n 'config'\n > & {\n config: TWrappedModule['config']\n },\n >\n extends AbstractModuleProxy<TWrappedModule, TParams>\n implements ModuleInstance<TParams, TWrappedModule['eventData']>\n{\n async proxyQueryHandler<T extends QueryBoundWitness = QueryBoundWitness>(query: T, payloads?: Payload[]): Promise<ModuleQueryResult> {\n return await this.params.busClient.send(this.address, query, payloads)\n }\n\n override async startHandler(): Promise<boolean> {\n return await super.startHandler()\n }\n}\n","export const PubSubBridgeSchema = 'network.xyo.bridge.pubsub'\nexport type PubSubBridgeSchema = typeof PubSubBridgeSchema\n","import { Address } from '@xylabs/hex'\nimport { EmptyObject } from '@xylabs/object'\nimport { BridgeConfig } from '@xyo-network/bridge-model'\n\nimport { AsyncQueryBusClientConfig, AsyncQueryBusHostConfig } from './AsyncQueryBus'\nimport { PubSubBridgeSchema } from './Schema'\n\nexport const PubSubBridgeConfigSchema = `${PubSubBridgeSchema}.config`\nexport type PubSubBridgeConfigSchema = typeof PubSubBridgeConfigSchema\n\n/**\n * Configuration for the PubSubBridge\n */\nexport type PubSubBridgeConfig<TConfig extends EmptyObject = EmptyObject, TSchema extends string | void = void> = BridgeConfig<\n {\n client?: AsyncQueryBusClientConfig\n host?: AsyncQueryBusHostConfig\n roots?: Address[]\n } & TConfig,\n TSchema extends string ? TSchema : PubSubBridgeConfigSchema\n>\n","import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Address } from '@xylabs/hex'\nimport { AbstractBridge } from '@xyo-network/abstract-bridge'\nimport { BridgeExposeOptions, BridgeModule, BridgeUnexposeOptions } from '@xyo-network/bridge-model'\nimport { creatableModule, ModuleIdentifier, ModuleInstance, ModuleResolverInstance } from '@xyo-network/module-model'\nimport { LRUCache } from 'lru-cache'\n\nimport { AsyncQueryBusClient, AsyncQueryBusHost } from './AsyncQueryBus'\nimport { PubSubBridgeConfigSchema } from './Config'\nimport { PubSubBridgeParams } from './Params'\nimport { PubSubBridgeModuleResolver } from './PubSubBridgeModuleResolver'\n\nconst moduleName = 'PubSubBridge'\n\n@creatableModule()\nexport class PubSubBridge<TParams extends PubSubBridgeParams = PubSubBridgeParams> extends AbstractBridge<TParams> implements BridgeModule<TParams> {\n static override configSchemas = [PubSubBridgeConfigSchema]\n\n protected _configRootAddress: Address = ''\n protected _configStateStoreArchivist: string = ''\n protected _configStateStoreBoundWitnessDiviner: string = ''\n protected _exposedAddresses: Address[] = []\n protected _lastState?: LRUCache<string, number>\n\n private _busClient?: AsyncQueryBusClient\n private _busHost?: AsyncQueryBusHost\n private _resolver?: PubSubBridgeModuleResolver\n\n override get resolver(): ModuleResolverInstance {\n this._resolver =\n this._resolver ??\n new PubSubBridgeModuleResolver({\n bridge: this,\n busClient: assertEx(this.busClient(), () => 'busClient not configured'),\n wrapperAccount: this.account,\n })\n return this._resolver\n }\n\n protected get moduleName() {\n return `${this.config.name ?? moduleName}`\n }\n\n protected get roots() {\n return assertEx(this.config.roots, () => 'roots not configured')\n }\n\n override async discoverRoots(): Promise<ModuleInstance[]> {\n const rootInstances = (await Promise.all(this.roots.map(async (root) => await this.resolver.resolve<ModuleInstance>(root)))).filter(exists)\n for (const instance of rootInstances) {\n this.downResolver.add(instance)\n }\n return rootInstances\n }\n\n async exposeHandler(id: ModuleIdentifier, options?: BridgeExposeOptions | undefined): Promise<ModuleInstance[]> {\n const { maxDepth = 2, direction = 'all', required = true } = options ?? {}\n const host = assertEx(this.busHost(), () => 'Not configured as a host')\n const module = await host.expose(id, { required })\n if (module) {\n const children = maxDepth > 0 ? await module.resolve('*', { direction, maxDepth, visibility: 'public' }) : []\n const exposedChildren = (\n await Promise.all(children.map((child) => this.exposeHandler(child.address, { maxDepth: maxDepth - 1, required: false })))\n )\n .flat()\n .filter(exists)\n return [module, ...exposedChildren]\n }\n return []\n }\n\n exposedHandler(): Address[] {\n const exposedSet = this.busHost()?.exposedAddresses\n return exposedSet ? [...exposedSet] : []\n }\n\n override async startHandler(): Promise<boolean> {\n this.busHost()?.start()\n return await super.startHandler()\n }\n\n async unexposeHandler(id: ModuleIdentifier, options?: BridgeUnexposeOptions | undefined): Promise<ModuleInstance[]> {\n const { maxDepth = 2, direction = 'all', required = true } = options ?? {}\n const host = assertEx(this.busHost(), () => 'Not configured as a host')\n const module = await host.unexpose(id, required)\n if (module) {\n const children = maxDepth > 0 ? await module.resolve('*', { direction, maxDepth, visibility: 'public' }) : []\n const exposedChildren = (\n await Promise.all(children.map((child) => this.unexposeHandler(child.address, { maxDepth: maxDepth - 1, required: false })))\n )\n .flat()\n .filter(exists)\n return [module, ...exposedChildren]\n }\n return []\n }\n\n protected busClient() {\n if (!this._busClient && this.config.client) {\n this._busClient = new AsyncQueryBusClient({\n config: this.config.client,\n logger: this.logger,\n resolver: this,\n })\n }\n return this._busClient\n }\n\n protected busHost() {\n if (!this._busHost && this.config.host) {\n this._busHost = new AsyncQueryBusHost({\n config: this.config.host,\n logger: this.logger,\n resolver: this,\n })\n }\n return this._busHost\n }\n\n protected override stopHandler(_timeout?: number | undefined) {\n this.busHost()?.stop()\n return true\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { Address, isAddress } from '@xylabs/hex'\nimport { AbstractBridgeModuleResolver, BridgeModuleResolverParams, wrapModuleWithType } from '@xyo-network/abstract-bridge'\nimport { Account } from '@xyo-network/account'\nimport { ConfigPayload, ConfigSchema } from '@xyo-network/config-payload-plugin'\nimport { asModuleInstance, ModuleConfig, ModuleConfigSchema, ModuleFilterOptions, ModuleIdentifier, ModuleInstance } from '@xyo-network/module-model'\n\nimport { AsyncQueryBusClient, AsyncQueryBusModuleProxy, AsyncQueryBusModuleProxyParams } from './AsyncQueryBus'\n\nexport interface PubSubBridgeModuleResolverParams extends BridgeModuleResolverParams {\n busClient: AsyncQueryBusClient\n}\n\nexport class PubSubBridgeModuleResolver extends AbstractBridgeModuleResolver<PubSubBridgeModuleResolverParams> {\n override async resolveHandler<T extends ModuleInstance = ModuleInstance>(\n id: ModuleIdentifier,\n options?: ModuleFilterOptions<T>,\n ): Promise<T | T[] | undefined> {\n const parentResult = await super.resolveHandler(id, options)\n if (parentResult) {\n return parentResult\n }\n const idParts = id.split(':')\n const firstPart = idParts.shift()\n assertEx(isAddress(firstPart), () => `Invalid module address: ${firstPart}`)\n const remainderParts = idParts.join(':')\n const account = Account.randomSync()\n const params: AsyncQueryBusModuleProxyParams = {\n account,\n busClient: this.params.busClient,\n config: { schema: ModuleConfigSchema },\n host: this.params.bridge,\n moduleAddress: firstPart as Address,\n }\n const proxy = new AsyncQueryBusModuleProxy<T, AsyncQueryBusModuleProxyParams>(params)\n if (proxy) {\n const state = await proxy.state()\n if (state) {\n const configSchema = (state.find((payload) => payload.schema === ConfigSchema) as ConfigPayload | undefined)?.config\n const config = assertEx(\n state.find((payload) => payload.schema === configSchema),\n () => 'Unable to locate config',\n ) as ModuleConfig\n proxy.setConfig(config)\n }\n }\n await proxy.start?.()\n const wrapped = wrapModuleWithType(proxy, account) as unknown as T\n const as = assertEx(asModuleInstance<T>(wrapped, {}), () => `Failed to asModuleInstance [${id}]`)\n proxy.upResolver.add(as)\n proxy.downResolver.add(as)\n this.add(as)\n return remainderParts.length > 0 ? await proxy.resolve(remainderParts, options) : as\n }\n}\n"],"mappings":"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","names":["AbstractModuleHost","Base","import_lru_cache","import_object","AsyncQueryBusBase","Base","_lastState","_targetConfigs","_targetQueries","_lastQueriesArchivistAttempt","_lastQueriesDivinerAttempt","_lastResponsesArchivistAttempt","_lastResponsesDivinerAttempt","_queriesArchivist","_queriesArchivistMutex","Mutex","_queriesDiviner","_queriesDivinerMutex","_reResolveDelay","_responsesArchivist","_responsesArchivistMutex","_responsesDiviner","_responsesDivinerMutex","constructor","params","config","pollFrequencyConfig","pollFrequency","resolver","lastState","requiredConfig","max","ttl","LRUCache","queriesArchivist","runExclusive","Date","now","resolved","resolve","intersect","queries","archivist","typedResolve","asArchivistInstance","logger","warn","name","toJsonString","log","queriesDiviner","boundWitnessDiviner","asDivinerInstance","responsesArchivist","responses","responsesDiviner","commitState","address","nextState","Promise","get","set","retrieveState","state","undefined","newState","Pending","AsyncQueryBusClient","AsyncQueryBusBase","_queryCache","_pollCount","_pollId","constructor","params","queryCacheConfig","config","queryCache","max","ttl","started","requiredConfig","noUpdateTTL","ttlAutopurge","LRUCache","listeningAddresses","keys","send","address","query","payloads","logger","debug","$meta","destination","routedQuery","PayloadBuilder","build","queryArchivist","assertEx","queriesArchivist","_a","_b","_c","intersect","queries","archivist","routedQueryHash","$hash","Object","toDataHashMap","data","insertResult","insert","set","Pending","Error","context","Promise","resolve","reject","pollForResponse","start","response","get","undefined","delay","error","message","schema","sources","stop","forget","poll","setTimeoutEx","processIncomingResponses","e","clearTimeoutEx","pollFrequencyConfig","responseArchivist","responsesArchivist","responseBoundWitnessDiviner","responsesDiviner","pendingCommands","entries","filter","_","status","allSettled","map","sourceQuery","divinerQuery","BoundWitnessDivinerQuerySchema","result","divine","length","find","isBoundWitnessWithMeta","payload_hashes","import_assert","import_timer","import_boundwitness_model","import_diviner_boundwitness_model","import_payload_builder","AsyncQueryBusHost","AsyncQueryBusBase","_exposedAddresses","Set","_exposeOptions","_pollId","constructor","params","exposedAddresses","perAddressBatchQueryLimit","config","started","expose","id","options","failOnAlreadyExposed","required","module","asModuleInstance","resolver","resolve","maxDepth","Error","assertEx","has","address","add","logger","debug","listeningModules","exposedModules","values","mods","Promise","all","map","exposedModule","start","console","warn","poll","stop","clearTimeoutEx","undefined","unexpose","validate","delete","callLocalModule","localModule","query","localModuleName","name","queryArchivist","queriesArchivist","_a","_b","_c","intersect","queries","archivist","responsesArchivist","queryDestination","$meta","destination","includes","queryIndex","payload_hashes","indexOf","querySchema","payload_schemas","queryPayloads","get","queryPayloadsDict","PayloadBuilder","toAllHashMap","queryHash","build","$hash","containsAll","Object","keys","error","schema","response","allowedQueries","ModuleConfigSchema","bw","payloads","errors","insertResult","insert","length","timestamp","commitState","findQueriesToAddress","queryBoundWitnessDiviner","queriesDiviner","retrieveState","limit","divinerQuery","BoundWitnessDivinerQuerySchema","sort","result","divine","filter","isQueryBoundWitnessWithMeta","nextState","Math","max","c","boundWitnessDiviner","setTimeoutEx","processIncomingQueries","e","pollFrequencyConfig","localModules","allSettled","AsyncQueryBusModuleHost","AbstractModuleHost","_busHost","constructor","params","start","listeningModules","config","module","resolve","direction","map","m","address","AsyncQueryBusHost","logger","resolver","stop","AsyncQueryBusModuleProxy","AbstractModuleProxy","proxyQueryHandler","query","payloads","params","busClient","send","address","startHandler","PubSubBridgeSchema","PubSubBridgeConfigSchema","PubSubBridgeSchema","import_assert","import_abstract_bridge","import_module_model","import_assert","import_abstract_bridge","import_module_model","PubSubBridgeModuleResolver","AbstractBridgeModuleResolver","resolveHandler","id","options","parentResult","idParts","split","firstPart","shift","assertEx","isAddress","remainderParts","join","account","Account","randomSync","params","busClient","config","schema","ModuleConfigSchema","host","bridge","moduleAddress","proxy","AsyncQueryBusModuleProxy","state","configSchema","find","payload","ConfigSchema","setConfig","start","wrapped","wrapModuleWithType","as","asModuleInstance","upResolver","add","downResolver","length","resolve","moduleName","PubSubBridge","AbstractBridge","_configRootAddress","_configStateStoreArchivist","_configStateStoreBoundWitnessDiviner","_exposedAddresses","_lastState","_busClient","_busHost","_resolver","resolver","PubSubBridgeModuleResolver","bridge","busClient","assertEx","wrapperAccount","account","config","name","roots","discoverRoots","rootInstances","Promise","all","map","root","resolve","filter","exists","instance","downResolver","add","exposeHandler","id","options","maxDepth","direction","required","host","busHost","module","expose","children","visibility","exposedChildren","child","address","flat","exposedHandler","exposedSet","exposedAddresses","startHandler","start","unexposeHandler","unexpose","client","AsyncQueryBusClient","logger","AsyncQueryBusHost","stopHandler","_timeout","stop","configSchemas","PubSubBridgeConfigSchema","creatableModule"]}
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/AbstractModuleHost/AbstractModuleHost.ts","../../src/AsyncQueryBus/AsyncQueryBusClient.ts","../../src/AsyncQueryBus/AsyncQueryBusBase.ts","../../src/AsyncQueryBus/model/QueryStatus.ts","../../src/AsyncQueryBus/AsyncQueryBusHost.ts","../../src/AsyncQueryBus/ModuleHost/ModuleHost.ts","../../src/AsyncQueryBus/ModuleProxy/ModuleProxy.ts","../../src/Schema.ts","../../src/Config.ts","../../src/PubSubBridge.ts","../../src/PubSubBridgeModuleResolver.ts"],"sourcesContent":["export * from './AbstractModuleHost'\nexport * from './AsyncQueryBus'\nexport * from './Config'\nexport * from './Params'\nexport * from './PubSubBridge'\nexport * from './PubSubBridgeModuleResolver'\nexport * from './Schema'\n","import { Base, BaseParams } from '@xylabs/object'\nimport { Promisable } from '@xylabs/promise'\nimport { ModuleInstance } from '@xyo-network/module-model'\n\nexport type ModuleHostParams<THostedInstance extends ModuleInstance = ModuleInstance> = BaseParams<{\n module: THostedInstance\n}>\n\nexport abstract class AbstractModuleHost<TParams extends ModuleHostParams = ModuleHostParams> extends Base<TParams> {\n abstract start(): Promisable<void>\n abstract stop(): Promisable<void>\n}\n","import { assertEx } from '@xylabs/assert'\nimport { delay } from '@xylabs/delay'\nimport { forget } from '@xylabs/forget'\nimport { Address } from '@xylabs/hex'\nimport { clearTimeoutEx, setTimeoutEx } from '@xylabs/timer'\nimport { isBoundWitnessWithMeta, QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { BoundWitnessDivinerQueryPayload, BoundWitnessDivinerQuerySchema } from '@xyo-network/diviner-boundwitness-model'\nimport { CacheConfig, ModuleQueryResult } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { ModuleError, Payload, PayloadWithMeta, WithMeta } from '@xyo-network/payload-model'\nimport { LRUCache } from 'lru-cache'\n\nimport { AsyncQueryBusBase } from './AsyncQueryBusBase'\nimport { AsyncQueryBusClientParams, Pending } from './model'\n\nexport class AsyncQueryBusClient<TParams extends AsyncQueryBusClientParams = AsyncQueryBusClientParams> extends AsyncQueryBusBase<TParams> {\n protected _queryCache?: LRUCache<Address, Pending | ModuleQueryResult>\n private _pollCount = 0\n private _pollId?: string\n\n constructor(params: TParams) {\n super(params)\n }\n\n get queryCacheConfig(): LRUCache.Options<Address, Pending | ModuleQueryResult, unknown> {\n const queryCacheConfig: CacheConfig | undefined = this.config?.queryCache === true ? {} : this.config?.queryCache\n return { max: 100, ttl: 1000 * 60, ...queryCacheConfig }\n }\n\n get started() {\n return !!this._pollId\n }\n\n /**\n * A cache of queries that have been issued\n */\n protected get queryCache(): LRUCache<Address, Pending | ModuleQueryResult> {\n const config = this.queryCacheConfig\n const requiredConfig = { noUpdateTTL: false, ttlAutopurge: true }\n this._queryCache = this._queryCache ?? new LRUCache<Address, Pending | ModuleQueryResult>({ ...config, ...requiredConfig })\n return this._queryCache\n }\n\n listeningAddresses() {\n return this._queryCache?.keys()\n }\n\n async send(address: Address, query: QueryBoundWitness, payloads?: Payload[] | undefined): Promise<ModuleQueryResult> {\n //console.log('send')\n this.logger?.debug(`Begin issuing query to: ${address}`)\n const $meta = { ...query?.$meta, destination: [address] }\n const routedQuery = await PayloadBuilder.build({ ...query, $meta })\n //console.log('queryArchivist - calling')\n const queryArchivist = assertEx(\n await this.queriesArchivist(),\n () => `Unable to contact queriesArchivist [${this.config?.intersect?.queries?.archivist}]`,\n )\n //console.log('queryArchivist')\n\n // TODO: Should we always re-hash to true up timestamps? We can't\n // re-sign correctly so we would lose that information if we did and\n // would also be replying to consumers with a different query hash than\n // they sent us (which might be OK since it reflect the chain of custody)\n // Revisit this once we have proxy module support as they are another\n // intermediary to consider.\n const routedQueryHash =\n // Trust the signed hash if it's there\n (routedQuery as WithMeta<QueryBoundWitness>)?.$hash ??\n // TODO: What is the right way to find the dataHash\n Object.keys(await PayloadBuilder.toDataHashMap([routedQuery]))[0]\n this.logger?.debug(`Issuing query: ${routedQueryHash} to: ${address}`)\n // If there was data associated with the query, add it to the insert\n const data = payloads ? [routedQuery, ...payloads] : [routedQuery]\n const insertResult = await queryArchivist.insert?.(data)\n this.logger?.debug(`Issued query: ${routedQueryHash} to: ${address}`)\n this.queryCache.set(routedQueryHash, Pending)\n if (!insertResult) throw new Error('Unable to issue query to queryArchivist')\n const context = new Promise<ModuleQueryResult>((resolve, reject) => {\n this.logger?.debug(`Polling for response to query: ${routedQueryHash}`)\n const pollForResponse = async () => {\n try {\n this.start()\n let response = this.queryCache.get(routedQueryHash)\n // Poll for response until cache key expires (response timed out)\n while (response !== undefined) {\n //console.log('polling...')\n // Wait a bit\n await delay(100)\n // Check the status of the response\n response = this.queryCache.get(routedQueryHash)\n // If status is no longer pending that means we received a response\n if (response && response !== Pending) {\n this.logger?.debug(`Returning response to query: ${routedQueryHash}`)\n resolve(response)\n return\n }\n }\n // If we got here waiting for a response timed out\n this.logger?.error('Timeout waiting for query response')\n // Resolve with error to match what a local module would do if it were to error\n // TODO: BW Builder/Sign result as this module?\n const error: ModuleError = {\n message: 'Timeout waiting for query response',\n query: 'network.xyo.boundwitness',\n schema: 'network.xyo.error.module',\n sources: [routedQueryHash],\n }\n reject(error)\n return\n } finally {\n this.stop()\n }\n }\n forget(pollForResponse())\n })\n return context\n }\n\n /**\n * Runs the background divine process on a loop with a delay\n * specified by the `config.pollFrequency`\n */\n private poll() {\n this._pollId = setTimeoutEx(async () => {\n try {\n await this.processIncomingResponses()\n } catch (e) {\n this.logger?.error?.(`Error in main loop: ${e}`)\n } finally {\n if (this._pollId) clearTimeoutEx(this._pollId)\n this._pollId = undefined\n this.poll()\n }\n }, this.pollFrequencyConfig)\n }\n\n /**\n * Background process for processing incoming responses to previously issued queries\n */\n private processIncomingResponses = async () => {\n const responseArchivist = await this.responsesArchivist()\n if (responseArchivist) {\n const responseBoundWitnessDiviner = await this.responsesDiviner()\n if (responseBoundWitnessDiviner) {\n const pendingCommands = [...this.queryCache.entries()].filter(([_, status]) => status === Pending)\n // TODO: Do in throttled batches\n await Promise.allSettled(\n pendingCommands.map(async ([sourceQuery, status]) => {\n if (status === Pending) {\n const divinerQuery: BoundWitnessDivinerQueryPayload = { schema: BoundWitnessDivinerQuerySchema, sourceQuery }\n const result = await responseBoundWitnessDiviner.divine([divinerQuery])\n if (result && result.length > 0) {\n const response = result.find(isBoundWitnessWithMeta)\n if (response && (response?.$meta as unknown as { sourceQuery: string })?.sourceQuery === sourceQuery) {\n this.logger?.debug(`Found response to query: ${sourceQuery}`)\n // Get any payloads associated with the response\n const payloads: PayloadWithMeta[] = response.payload_hashes?.length > 0 ? await responseArchivist.get(response.payload_hashes) : []\n this.queryCache.set(sourceQuery, [response, payloads, []])\n }\n }\n }\n }),\n )\n }\n }\n }\n\n private start() {\n if (this._pollCount === 0) {\n this.poll()\n }\n this._pollCount++\n }\n\n private stop() {\n this._pollCount--\n if (this._pollCount <= 0) {\n if (this._pollId) clearTimeoutEx(this._pollId)\n this._pollId = undefined\n this._pollCount = 0\n }\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { Address } from '@xylabs/hex'\nimport { Base, TypeCheck } from '@xylabs/object'\nimport { ArchivistInstance, isArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitness, QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { BoundWitnessDivinerParams, BoundWitnessDivinerQueryPayload } from '@xyo-network/diviner-boundwitness-model'\nimport { DivinerInstance, isDivinerInstance } from '@xyo-network/diviner-model'\nimport { ModuleConfig, ModuleIdentifier, ModuleInstance, traceModuleIdentifier } from '@xyo-network/module-model'\nimport { Mutex } from 'async-mutex'\nimport { LRUCache } from 'lru-cache'\n\nimport { AsyncQueryBusParams } from './model'\n\nexport class AsyncQueryBusBase<TParams extends AsyncQueryBusParams = AsyncQueryBusParams> extends Base<TParams> {\n protected _lastState?: LRUCache<Address, number>\n protected _targetConfigs: Record<Address, ModuleConfig> = {}\n protected _targetQueries: Record<Address, string[]> = {}\n\n private _lastResolveAttempt: Record<ModuleIdentifier, number> = {}\n private _queriesArchivist?: ArchivistInstance\n private _queriesDiviner?: DivinerInstance<BoundWitnessDivinerParams, BoundWitnessDivinerQueryPayload, QueryBoundWitness>\n private _reResolveDelay = 1000 * 5 //5 seconds\n private _resolveMutex = new Mutex()\n private _responsesArchivist?: ArchivistInstance\n private _responsesDiviner?: DivinerInstance<BoundWitnessDivinerParams, BoundWitnessDivinerQueryPayload, BoundWitness>\n\n constructor(params: TParams) {\n super(params)\n }\n\n get config(): TParams['config'] {\n return this.params.config\n }\n\n get pollFrequencyConfig(): number {\n return this.config?.pollFrequency ?? 1000\n }\n\n get resolver() {\n return this.params.resolver\n }\n\n /**\n * A cache of the last offset of the Diviner process per address\n */\n protected get lastState(): LRUCache<Address, number> {\n const requiredConfig = { max: 1000, ttl: 0 }\n this._lastState = this._lastState ?? new LRUCache<Address, number>(requiredConfig)\n return this._lastState\n }\n\n async queriesArchivist() {\n this._queriesArchivist =\n this._queriesArchivist ??\n (await this.resolve(\n assertEx(this.config?.intersect?.queries?.archivist, () => 'No queries Archivist defined'),\n isArchivistInstance,\n ))\n return this._queriesArchivist\n }\n\n async queriesDiviner() {\n this._queriesDiviner =\n this._queriesDiviner ??\n ((await this.resolve(\n assertEx(this.config?.intersect?.queries?.boundWitnessDiviner, () => 'No queries Diviner defined'),\n isDivinerInstance,\n )) as DivinerInstance<BoundWitnessDivinerParams, BoundWitnessDivinerQueryPayload, QueryBoundWitness>)\n return this._queriesDiviner\n }\n\n async responsesArchivist() {\n this._responsesArchivist =\n this._responsesArchivist ??\n (await this.resolve(\n assertEx(this.config?.intersect?.responses?.archivist, () => 'No responses Archivist defined'),\n isArchivistInstance,\n ))\n return this._responsesArchivist\n }\n\n async responsesDiviner() {\n this._responsesDiviner =\n this._responsesDiviner ??\n ((await this.resolve(\n assertEx(this.config?.intersect?.responses?.boundWitnessDiviner, () => 'No responses Diviner defined'),\n isDivinerInstance,\n )) as DivinerInstance<BoundWitnessDivinerParams, BoundWitnessDivinerQueryPayload, BoundWitness>)\n return this._responsesDiviner\n }\n\n /**\n * Commit the internal state of the process. This is similar\n * to a transaction completion in a database and should only be called\n * when results have been successfully persisted to the appropriate\n * external stores.\n * @param address The module address to commit the state for\n * @param nextState The state to commit\n */\n protected async commitState(address: Address, nextState: number) {\n await Promise.resolve()\n // TODO: Offload to Archivist/Diviner instead of in-memory\n const lastState = this.lastState.get(address)\n if (lastState && lastState >= nextState) return\n this.lastState.set(address, nextState)\n }\n\n /**\n * Retrieves the last state of the process. Used to recover state after\n * preemptions, reboots, etc.\n */\n protected async retrieveState(address: Address): Promise<number> {\n await Promise.resolve()\n const state = this.lastState.get(address)\n if (state === undefined) {\n // If this is a boot we can go back a bit in time\n // and begin processing recent commands\n const newState = Date.now() - 1000\n this.lastState.set(address, newState)\n return newState\n } else {\n return state\n }\n }\n\n private async resolve<T extends ModuleInstance>(id: ModuleIdentifier, typeCheck: TypeCheck<T>): Promise<T | undefined> {\n return (await this._resolveMutex.runExclusive(async () => {\n if (this._queriesArchivist) {\n return this._queriesArchivist\n }\n if (Date.now() - (this._lastResolveAttempt[id] ?? 0) < this._reResolveDelay) {\n return\n }\n this._lastResolveAttempt[id] = Date.now()\n const resolved = await this.resolver.resolve(id)\n if (resolved) {\n if (typeCheck(resolved)) {\n return resolved\n } else {\n this.logger?.warn(`Unable to resolve responsesDiviner as correct type [${id}][${resolved?.constructor?.name}]: ${resolved.id}`)\n }\n } else {\n this.logger?.log(`Unable to resolve queriesArchivist [${id}] [${await traceModuleIdentifier(this.resolver, id)}]`)\n }\n })) as T | undefined\n }\n}\n","export const Pending = 'pending' as const\nexport type Pending = typeof Pending\n","import { containsAll } from '@xylabs/array'\nimport { assertEx } from '@xylabs/assert'\nimport { Address } from '@xylabs/hex'\nimport { clearTimeoutEx, setTimeoutEx } from '@xylabs/timer'\nimport { isQueryBoundWitnessWithMeta, QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { BoundWitnessDivinerQuerySchema } from '@xyo-network/diviner-boundwitness-model'\nimport { asModuleInstance, ModuleConfigSchema, ModuleIdentifier, ModuleInstance } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { Schema, WithMeta } from '@xyo-network/payload-model'\n\nimport { AsyncQueryBusBase } from './AsyncQueryBusBase'\nimport { AsyncQueryBusHostParams } from './model'\n\nexport interface ExposeOptions {\n allowedQueries?: Schema[]\n failOnAlreadyExposed?: boolean\n required?: boolean\n}\n\nexport class AsyncQueryBusHost<TParams extends AsyncQueryBusHostParams = AsyncQueryBusHostParams> extends AsyncQueryBusBase<TParams> {\n protected _exposedAddresses = new Set<Address>()\n private _exposeOptions: Record<Address, ExposeOptions> = {}\n private _pollId?: string\n\n constructor(params: TParams) {\n super(params)\n }\n\n get exposedAddresses() {\n return this._exposedAddresses\n }\n\n get perAddressBatchQueryLimit(): number {\n return this.config?.perAddressBatchQueryLimit ?? 10\n }\n\n get started() {\n return !!this._pollId\n }\n\n async expose(id: ModuleIdentifier, options?: ExposeOptions) {\n const { failOnAlreadyExposed, required = true } = options ?? {}\n const module = asModuleInstance(await this.resolver.resolve(id, { maxDepth: 10 }))\n if (!module && required) {\n throw new Error(`Unable to resolve module to expose [${id}]`)\n }\n if (module) {\n assertEx(!failOnAlreadyExposed || !this._exposedAddresses.has(module.address), () => `Address already exposed: ${id} [${module.address}]`)\n this._exposedAddresses.add(module.address)\n this._exposeOptions[module.address] = { ...options }\n this.logger?.debug(`${id} exposed [${module.address}]`)\n return module\n }\n }\n\n async listeningModules(): Promise<ModuleInstance[]> {\n const exposedModules = [...(this.config?.listeningModules ?? []), ...this.exposedAddresses.values()]\n const mods = await Promise.all(\n exposedModules.map(async (exposedModule) =>\n assertEx(\n asModuleInstance(await this.resolver.resolve(exposedModule, { maxDepth: 10 })),\n () => `Unable to resolve listeningModule [${exposedModule}]`,\n ),\n ),\n )\n return mods\n }\n\n start() {\n if (this.started) {\n console.warn('AsyncQueryBus starting when already started')\n }\n this.poll()\n }\n\n stop() {\n if (!this.started) {\n console.warn('AsyncQueryBus stopping when already stopped')\n }\n if (this._pollId) clearTimeoutEx(this._pollId)\n this._pollId = undefined\n }\n\n async unexpose(id: ModuleIdentifier, validate = true) {\n const module = asModuleInstance(await this.resolver.resolve(id, { maxDepth: 10 }))\n if (module) {\n assertEx(!validate || this._exposedAddresses.has(module.address), () => `Address not exposed [${module.address}][${module.id}]`)\n this._exposedAddresses.delete(module.address)\n delete this._exposeOptions[module.address]\n this.logger?.debug(`${module.address} [${module.id}] unexposed`)\n }\n return module\n }\n\n protected callLocalModule = async (localModule: ModuleInstance, query: WithMeta<QueryBoundWitness>) => {\n const localModuleName = localModule.config.name ?? localModule.address\n const queryArchivist = assertEx(\n await this.queriesArchivist(),\n () => `Unable to contact queriesArchivist [${this.config?.intersect?.queries?.archivist}]`,\n )\n const responsesArchivist = assertEx(\n await this.responsesArchivist(),\n () => `Unable to contact responsesArchivist [${this.config?.intersect?.queries?.archivist}]`,\n )\n const queryDestination = (query.$meta as { destination?: string[] })?.destination\n if (queryDestination && queryDestination?.includes(localModule.address)) {\n // Find the query\n const queryIndex = query.payload_hashes.indexOf(query.query)\n if (queryIndex !== -1) {\n const querySchema = query.payload_schemas[queryIndex]\n // If the destination can process this type of query\n if (localModule.queries.includes(querySchema)) {\n // Get the associated payloads\n const queryPayloads = await queryArchivist.get(query.payload_hashes)\n const queryPayloadsDict = await PayloadBuilder.toAllHashMap(queryPayloads)\n const queryHash = (await PayloadBuilder.build(query)).$hash\n // Check that we have all the arguments for the command\n if (!containsAll(Object.keys(queryPayloadsDict), query.payload_hashes)) {\n this.logger?.error(`Error processing command ${queryHash} for module ${localModuleName}, missing payloads`)\n return\n }\n try {\n // Issue the query against module\n const querySchema = queryPayloadsDict[query.query].schema\n this.logger?.debug(`Issuing query ${querySchema} (${queryHash}) addressed to module: ${localModuleName}`)\n const response = await localModule.query(query, queryPayloads, {\n allowedQueries: this._exposeOptions[localModule.address]?.allowedQueries,\n schema: ModuleConfigSchema,\n })\n const [bw, payloads, errors] = response\n this.logger?.debug(`Replying to query ${queryHash} addressed to module: ${localModuleName}`)\n const insertResult = await responsesArchivist.insert([bw, ...payloads, ...errors])\n // NOTE: If all archivists support the contract that numPayloads inserted === numPayloads returned we can\n // do some deeper assertions here like lenIn === lenOut, but for now this should be good enough since BWs\n // should always be unique causing at least one insertion\n if (insertResult.length === 0) {\n this.logger?.error(`Error replying to query ${queryHash} addressed to module: ${localModuleName}`)\n }\n if (query?.timestamp) {\n // TODO: This needs to be thought through as we can't use a distributed timestamp\n // because of collisions. We need to ensure we are using the timestamp of the store\n // so there's no chance of multiple commands at the same time\n await this.commitState(localModule.address, query.timestamp)\n }\n } catch (error) {\n this.logger?.error(`Error processing query ${queryHash} for module ${localModuleName}: ${error}`)\n console.error(`Error processing query ${queryHash} for module ${localModuleName}: ${error}`)\n }\n }\n }\n }\n }\n\n /**\n * Finds unprocessed commands addressed to the supplied address\n * @param address The address to find commands for\n */\n protected findQueriesToAddress = async (address: Address) => {\n const queryBoundWitnessDiviner = await this.queriesDiviner()\n if (queryBoundWitnessDiviner) {\n // Retrieve last offset from state store\n const timestamp = await this.retrieveState(address)\n const destination = [address]\n const limit = this.perAddressBatchQueryLimit\n // Filter for commands to us by destination address\n const divinerQuery = { destination, limit, schema: BoundWitnessDivinerQuerySchema, sort: 'asc', timestamp }\n const result = await queryBoundWitnessDiviner.divine([divinerQuery])\n const queries = result.filter(isQueryBoundWitnessWithMeta)\n const nextState = queries.length > 0 ? Math.max(...queries.map((c) => c.timestamp ?? 0)) + 1 : timestamp\n // TODO: This needs to be thought through as we can't use a distributed timestamp\n // because of collisions. We need to use the timestamp of the store so there's no\n // chance of multiple commands at the same time\n await this.commitState(address, nextState)\n return queries\n } else {\n this.logger?.warn(`Unable to resolve queryBoundWitnessDiviner [${this.config?.intersect?.queries?.boundWitnessDiviner}]`)\n }\n }\n\n /**\n * Runs the background divine process on a loop with a delay\n * specified by the `config.pollFrequency`\n */\n private poll() {\n this._pollId = setTimeoutEx(async () => {\n try {\n await this.processIncomingQueries()\n } catch (e) {\n this.logger?.error?.(`Error in main loop: ${e}`)\n } finally {\n if (this._pollId) clearTimeoutEx(this._pollId)\n this._pollId = undefined\n this.poll()\n }\n }, this.pollFrequencyConfig)\n }\n\n /**\n * Background process for checking for inbound queries\n */\n private processIncomingQueries = async () => {\n this.logger?.debug('Checking for inbound queries')\n // Check for any queries that have been issued and have not been responded to\n const localModules = await this.listeningModules()\n\n // TODO: Do in throttled batches\n await Promise.allSettled(\n localModules.map(async (localModule) => {\n try {\n const localModuleName = localModule.config.name ?? localModule.address\n this.logger?.debug(`Checking for inbound queries to ${localModuleName} [${localModule.address}]`)\n const queries = (await this.findQueriesToAddress(localModule.address)) ?? []\n if (queries.length === 0) return\n this.logger?.debug(`Found queries addressed to local module: ${localModuleName}`)\n for (const query of queries) {\n await this.callLocalModule(localModule, query)\n }\n } catch (error) {\n this.logger?.error(`Error processing queries for address ${localModule.address}: ${error}`)\n }\n }),\n )\n }\n}\n","import { AbstractModuleHost, ModuleHostParams } from '../../AbstractModuleHost'\nimport { AsyncQueryBusHost } from '../AsyncQueryBusHost'\nimport { AsyncQueryBusHostConfig } from '../model'\n\nexport type AsyncQueryBusModuleHostParams = ModuleHostParams & {\n config: AsyncQueryBusHostConfig\n}\n\nexport class AsyncQueryBusModuleHost extends AbstractModuleHost<AsyncQueryBusModuleHostParams> {\n private _busHost?: AsyncQueryBusHost\n\n constructor(params: AsyncQueryBusModuleHostParams) {\n super(params)\n }\n\n override async start(): Promise<void> {\n const listeningModules =\n this.params.config.listeningModules ?? (await this.params.module.resolve('*', { direction: 'down' })).map((m) => m.address)\n this._busHost = new AsyncQueryBusHost({\n config: { ...this.params.config, listeningModules },\n logger: this.params.logger,\n resolver: this.params.module,\n })\n this._busHost?.start()\n }\n override stop() {\n this._busHost?.stop()\n }\n}\n","import { AbstractModuleProxy, ModuleProxyParams } from '@xyo-network/abstract-bridge'\nimport { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { ModuleInstance, ModuleQueryResult } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nimport { AsyncQueryBusClient } from '../AsyncQueryBusClient'\n\nexport type AsyncQueryBusModuleProxyParams = ModuleProxyParams & {\n busClient: AsyncQueryBusClient\n}\n\nexport class AsyncQueryBusModuleProxy<\n TWrappedModule extends ModuleInstance = ModuleInstance,\n TParams extends Omit<AsyncQueryBusModuleProxyParams, 'config'> & { config: TWrappedModule['config'] } = Omit<\n AsyncQueryBusModuleProxyParams,\n 'config'\n > & {\n config: TWrappedModule['config']\n },\n >\n extends AbstractModuleProxy<TWrappedModule, TParams>\n implements ModuleInstance<TParams, TWrappedModule['eventData']>\n{\n async proxyQueryHandler<T extends QueryBoundWitness = QueryBoundWitness>(query: T, payloads?: Payload[]): Promise<ModuleQueryResult> {\n return await this.params.busClient.send(this.address, query, payloads)\n }\n\n override async startHandler(): Promise<boolean> {\n return await super.startHandler()\n }\n}\n","export const PubSubBridgeSchema = 'network.xyo.bridge.pubsub'\nexport type PubSubBridgeSchema = typeof PubSubBridgeSchema\n","import { Address } from '@xylabs/hex'\nimport { EmptyObject } from '@xylabs/object'\nimport { BridgeConfig } from '@xyo-network/bridge-model'\n\nimport { AsyncQueryBusClientConfig, AsyncQueryBusHostConfig } from './AsyncQueryBus'\nimport { PubSubBridgeSchema } from './Schema'\n\nexport const PubSubBridgeConfigSchema = `${PubSubBridgeSchema}.config`\nexport type PubSubBridgeConfigSchema = typeof PubSubBridgeConfigSchema\n\n/**\n * Configuration for the PubSubBridge\n */\nexport type PubSubBridgeConfig<TConfig extends EmptyObject = EmptyObject, TSchema extends string | void = void> = BridgeConfig<\n {\n client?: AsyncQueryBusClientConfig\n host?: AsyncQueryBusHostConfig\n roots?: Address[]\n } & TConfig,\n TSchema extends string ? TSchema : PubSubBridgeConfigSchema\n>\n","import { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { Address } from '@xylabs/hex'\nimport { AbstractBridge } from '@xyo-network/abstract-bridge'\nimport { BridgeExposeOptions, BridgeModule, BridgeUnexposeOptions } from '@xyo-network/bridge-model'\nimport { creatableModule, ModuleIdentifier, ModuleInstance, ModuleResolverInstance } from '@xyo-network/module-model'\nimport { LRUCache } from 'lru-cache'\n\nimport { AsyncQueryBusClient, AsyncQueryBusHost } from './AsyncQueryBus'\nimport { PubSubBridgeConfigSchema } from './Config'\nimport { PubSubBridgeParams } from './Params'\nimport { PubSubBridgeModuleResolver } from './PubSubBridgeModuleResolver'\n\nconst moduleName = 'PubSubBridge'\n\n@creatableModule()\nexport class PubSubBridge<TParams extends PubSubBridgeParams = PubSubBridgeParams> extends AbstractBridge<TParams> implements BridgeModule<TParams> {\n static override configSchemas = [PubSubBridgeConfigSchema]\n\n protected _configRootAddress: Address = ''\n protected _configStateStoreArchivist: string = ''\n protected _configStateStoreBoundWitnessDiviner: string = ''\n protected _exposedAddresses: Address[] = []\n protected _lastState?: LRUCache<string, number>\n\n private _busClient?: AsyncQueryBusClient\n private _busHost?: AsyncQueryBusHost\n private _resolver?: PubSubBridgeModuleResolver\n\n override get resolver(): ModuleResolverInstance {\n this._resolver =\n this._resolver ??\n new PubSubBridgeModuleResolver({\n bridge: this,\n busClient: assertEx(this.busClient(), () => 'busClient not configured'),\n wrapperAccount: this.account,\n })\n return this._resolver\n }\n\n protected get moduleName() {\n return `${this.config.name ?? moduleName}`\n }\n\n protected get roots() {\n return assertEx(this.config.roots, () => 'roots not configured')\n }\n\n override async discoverRoots(): Promise<ModuleInstance[]> {\n const rootInstances = (await Promise.all(this.roots.map(async (root) => await this.resolver.resolve<ModuleInstance>(root)))).filter(exists)\n for (const instance of rootInstances) {\n this.downResolver.add(instance)\n }\n return rootInstances\n }\n\n async exposeHandler(id: ModuleIdentifier, options?: BridgeExposeOptions | undefined): Promise<ModuleInstance[]> {\n const { maxDepth = 2, direction = 'all', required = true } = options ?? {}\n const host = assertEx(this.busHost(), () => 'Not configured as a host')\n const module = await host.expose(id, { required })\n if (module) {\n const children = maxDepth > 0 ? await module.resolve('*', { direction, maxDepth, visibility: 'public' }) : []\n const exposedChildren = (\n await Promise.all(children.map((child) => this.exposeHandler(child.address, { maxDepth: maxDepth - 1, required: false })))\n )\n .flat()\n .filter(exists)\n return [module, ...exposedChildren]\n }\n return []\n }\n\n exposedHandler(): Address[] {\n const exposedSet = this.busHost()?.exposedAddresses\n return exposedSet ? [...exposedSet] : []\n }\n\n override async startHandler(): Promise<boolean> {\n this.busHost()?.start()\n return await super.startHandler()\n }\n\n async unexposeHandler(id: ModuleIdentifier, options?: BridgeUnexposeOptions | undefined): Promise<ModuleInstance[]> {\n const { maxDepth = 2, direction = 'all', required = true } = options ?? {}\n const host = assertEx(this.busHost(), () => 'Not configured as a host')\n const module = await host.unexpose(id, required)\n if (module) {\n const children = maxDepth > 0 ? await module.resolve('*', { direction, maxDepth, visibility: 'public' }) : []\n const exposedChildren = (\n await Promise.all(children.map((child) => this.unexposeHandler(child.address, { maxDepth: maxDepth - 1, required: false })))\n )\n .flat()\n .filter(exists)\n return [module, ...exposedChildren]\n }\n return []\n }\n\n protected busClient() {\n if (!this._busClient && this.config.client) {\n this._busClient = new AsyncQueryBusClient({\n config: this.config.client,\n logger: this.logger,\n resolver: this,\n })\n }\n return this._busClient\n }\n\n protected busHost() {\n if (!this._busHost && this.config.host) {\n this._busHost = new AsyncQueryBusHost({\n config: this.config.host,\n logger: this.logger,\n resolver: this,\n })\n }\n return this._busHost\n }\n\n protected override stopHandler(_timeout?: number | undefined) {\n this.busHost()?.stop()\n return true\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { Address, isAddress } from '@xylabs/hex'\nimport { AbstractBridgeModuleResolver, BridgeModuleResolverParams, wrapModuleWithType } from '@xyo-network/abstract-bridge'\nimport { Account } from '@xyo-network/account'\nimport { ConfigPayload, ConfigSchema } from '@xyo-network/config-payload-plugin'\nimport { asModuleInstance, ModuleConfig, ModuleConfigSchema, ModuleFilterOptions, ModuleIdentifier, ModuleInstance } from '@xyo-network/module-model'\n\nimport { AsyncQueryBusClient, AsyncQueryBusModuleProxy, AsyncQueryBusModuleProxyParams } from './AsyncQueryBus'\n\nexport interface PubSubBridgeModuleResolverParams extends BridgeModuleResolverParams {\n busClient: AsyncQueryBusClient\n}\n\nexport class PubSubBridgeModuleResolver extends AbstractBridgeModuleResolver<PubSubBridgeModuleResolverParams> {\n override async resolveHandler<T extends ModuleInstance = ModuleInstance>(\n id: ModuleIdentifier,\n options?: ModuleFilterOptions<T>,\n ): Promise<T | T[] | undefined> {\n const parentResult = await super.resolveHandler(id, options)\n if (parentResult) {\n return parentResult\n }\n const idParts = id.split(':')\n const firstPart = idParts.shift()\n assertEx(isAddress(firstPart), () => `Invalid module address: ${firstPart}`)\n const remainderParts = idParts.join(':')\n const account = Account.randomSync()\n const params: AsyncQueryBusModuleProxyParams = {\n account,\n busClient: this.params.busClient,\n config: { schema: ModuleConfigSchema },\n host: this.params.bridge,\n moduleAddress: firstPart as Address,\n }\n const proxy = new AsyncQueryBusModuleProxy<T, AsyncQueryBusModuleProxyParams>(params)\n if (proxy) {\n const state = await proxy.state()\n if (state) {\n const configSchema = (state.find((payload) => payload.schema === ConfigSchema) as ConfigPayload | undefined)?.config\n const config = assertEx(\n state.find((payload) => payload.schema === configSchema),\n () => 'Unable to locate config',\n ) as ModuleConfig\n proxy.setConfig(config)\n }\n }\n await proxy.start?.()\n const wrapped = wrapModuleWithType(proxy, account) as unknown as T\n const as = assertEx(asModuleInstance<T>(wrapped, {}), () => `Failed to asModuleInstance [${id}]`)\n proxy.upResolver.add(as)\n proxy.downResolver.add(as)\n this.add(as)\n return remainderParts.length > 0 ? await proxy.resolve(remainderParts, options) : as\n }\n}\n"],"mappings":"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","names":["AbstractModuleHost","Base","import_assert","import_lru_cache","import_object","AsyncQueryBusBase","Base","_lastState","_targetConfigs","_targetQueries","_lastResolveAttempt","_queriesArchivist","_queriesDiviner","_reResolveDelay","_resolveMutex","Mutex","_responsesArchivist","_responsesDiviner","constructor","params","config","pollFrequencyConfig","pollFrequency","resolver","lastState","requiredConfig","max","ttl","LRUCache","queriesArchivist","resolve","assertEx","intersect","queries","archivist","isArchivistInstance","queriesDiviner","boundWitnessDiviner","isDivinerInstance","responsesArchivist","responses","responsesDiviner","commitState","address","nextState","Promise","get","set","retrieveState","state","undefined","newState","Date","now","id","typeCheck","runExclusive","resolved","logger","warn","name","log","traceModuleIdentifier","Pending","AsyncQueryBusClient","AsyncQueryBusBase","_queryCache","_pollCount","_pollId","constructor","params","queryCacheConfig","config","queryCache","max","ttl","started","requiredConfig","noUpdateTTL","ttlAutopurge","LRUCache","listeningAddresses","keys","send","address","query","payloads","logger","debug","$meta","destination","routedQuery","PayloadBuilder","build","queryArchivist","assertEx","queriesArchivist","_a","_b","_c","intersect","queries","archivist","routedQueryHash","$hash","Object","toDataHashMap","data","insertResult","insert","set","Pending","Error","context","Promise","resolve","reject","pollForResponse","start","response","get","undefined","delay","error","message","schema","sources","stop","forget","poll","setTimeoutEx","processIncomingResponses","e","clearTimeoutEx","pollFrequencyConfig","responseArchivist","responsesArchivist","responseBoundWitnessDiviner","responsesDiviner","pendingCommands","entries","filter","_","status","allSettled","map","sourceQuery","divinerQuery","BoundWitnessDivinerQuerySchema","result","divine","length","find","isBoundWitnessWithMeta","payload_hashes","import_assert","import_timer","import_boundwitness_model","import_diviner_boundwitness_model","import_module_model","import_payload_builder","AsyncQueryBusHost","AsyncQueryBusBase","_exposedAddresses","Set","_exposeOptions","_pollId","constructor","params","exposedAddresses","perAddressBatchQueryLimit","config","started","expose","id","options","failOnAlreadyExposed","required","module","asModuleInstance","resolver","resolve","maxDepth","Error","assertEx","has","address","add","logger","debug","listeningModules","exposedModules","values","mods","Promise","all","map","exposedModule","start","console","warn","poll","stop","clearTimeoutEx","undefined","unexpose","validate","delete","callLocalModule","localModule","query","localModuleName","name","queryArchivist","queriesArchivist","_a","_b","_c","intersect","queries","archivist","responsesArchivist","queryDestination","$meta","destination","includes","queryIndex","payload_hashes","indexOf","querySchema","payload_schemas","queryPayloads","get","queryPayloadsDict","PayloadBuilder","toAllHashMap","queryHash","build","$hash","containsAll","Object","keys","error","schema","response","allowedQueries","ModuleConfigSchema","bw","payloads","errors","insertResult","insert","length","timestamp","commitState","findQueriesToAddress","queryBoundWitnessDiviner","queriesDiviner","retrieveState","limit","divinerQuery","BoundWitnessDivinerQuerySchema","sort","result","divine","filter","isQueryBoundWitnessWithMeta","nextState","Math","max","c","boundWitnessDiviner","setTimeoutEx","processIncomingQueries","e","pollFrequencyConfig","localModules","allSettled","AsyncQueryBusModuleHost","AbstractModuleHost","_busHost","constructor","params","start","listeningModules","config","module","resolve","direction","map","m","address","AsyncQueryBusHost","logger","resolver","stop","AsyncQueryBusModuleProxy","AbstractModuleProxy","proxyQueryHandler","query","payloads","params","busClient","send","address","startHandler","PubSubBridgeSchema","PubSubBridgeConfigSchema","PubSubBridgeSchema","import_assert","import_abstract_bridge","import_module_model","import_assert","import_abstract_bridge","import_module_model","PubSubBridgeModuleResolver","AbstractBridgeModuleResolver","resolveHandler","id","options","parentResult","idParts","split","firstPart","shift","assertEx","isAddress","remainderParts","join","account","Account","randomSync","params","busClient","config","schema","ModuleConfigSchema","host","bridge","moduleAddress","proxy","AsyncQueryBusModuleProxy","state","configSchema","find","payload","ConfigSchema","setConfig","start","wrapped","wrapModuleWithType","as","asModuleInstance","upResolver","add","downResolver","length","resolve","moduleName","PubSubBridge","AbstractBridge","_configRootAddress","_configStateStoreArchivist","_configStateStoreBoundWitnessDiviner","_exposedAddresses","_lastState","_busClient","_busHost","_resolver","resolver","PubSubBridgeModuleResolver","bridge","busClient","assertEx","wrapperAccount","account","config","name","roots","discoverRoots","rootInstances","Promise","all","map","root","resolve","filter","exists","instance","downResolver","add","exposeHandler","id","options","maxDepth","direction","required","host","busHost","module","expose","children","visibility","exposedChildren","child","address","flat","exposedHandler","exposedSet","exposedAddresses","startHandler","start","unexposeHandler","unexpose","client","AsyncQueryBusClient","logger","AsyncQueryBusHost","stopHandler","_timeout","stop","configSchemas","PubSubBridgeConfigSchema","creatableModule"]}
|
package/dist/node/index.js
CHANGED
|
@@ -14,7 +14,7 @@ __name(_AbstractModuleHost, "AbstractModuleHost");
|
|
|
14
14
|
var AbstractModuleHost = _AbstractModuleHost;
|
|
15
15
|
|
|
16
16
|
// src/AsyncQueryBus/AsyncQueryBusClient.ts
|
|
17
|
-
import { assertEx } from "@xylabs/assert";
|
|
17
|
+
import { assertEx as assertEx2 } from "@xylabs/assert";
|
|
18
18
|
import { delay } from "@xylabs/delay";
|
|
19
19
|
import { forget } from "@xylabs/forget";
|
|
20
20
|
import { clearTimeoutEx, setTimeoutEx } from "@xylabs/timer";
|
|
@@ -24,28 +24,24 @@ import { PayloadBuilder } from "@xyo-network/payload-builder";
|
|
|
24
24
|
import { LRUCache as LRUCache2 } from "lru-cache";
|
|
25
25
|
|
|
26
26
|
// src/AsyncQueryBus/AsyncQueryBusBase.ts
|
|
27
|
-
import {
|
|
28
|
-
import {
|
|
29
|
-
import {
|
|
27
|
+
import { assertEx } from "@xylabs/assert";
|
|
28
|
+
import { Base as Base2 } from "@xylabs/object";
|
|
29
|
+
import { isArchivistInstance } from "@xyo-network/archivist-model";
|
|
30
|
+
import { isDivinerInstance } from "@xyo-network/diviner-model";
|
|
31
|
+
import { traceModuleIdentifier } from "@xyo-network/module-model";
|
|
30
32
|
import { Mutex } from "async-mutex";
|
|
31
33
|
import { LRUCache } from "lru-cache";
|
|
32
34
|
var _AsyncQueryBusBase = class _AsyncQueryBusBase extends Base2 {
|
|
33
35
|
_lastState;
|
|
34
36
|
_targetConfigs = {};
|
|
35
37
|
_targetQueries = {};
|
|
36
|
-
|
|
37
|
-
_lastQueriesDivinerAttempt;
|
|
38
|
-
_lastResponsesArchivistAttempt;
|
|
39
|
-
_lastResponsesDivinerAttempt;
|
|
38
|
+
_lastResolveAttempt = {};
|
|
40
39
|
_queriesArchivist;
|
|
41
|
-
_queriesArchivistMutex = new Mutex();
|
|
42
40
|
_queriesDiviner;
|
|
43
|
-
|
|
44
|
-
|
|
41
|
+
_reResolveDelay = 1e3 * 5;
|
|
42
|
+
_resolveMutex = new Mutex();
|
|
45
43
|
_responsesArchivist;
|
|
46
|
-
_responsesArchivistMutex = new Mutex();
|
|
47
44
|
_responsesDiviner;
|
|
48
|
-
_responsesDivinerMutex = new Mutex();
|
|
49
45
|
constructor(params) {
|
|
50
46
|
super(params);
|
|
51
47
|
}
|
|
@@ -71,96 +67,24 @@ var _AsyncQueryBusBase = class _AsyncQueryBusBase extends Base2 {
|
|
|
71
67
|
return this._lastState;
|
|
72
68
|
}
|
|
73
69
|
async queriesArchivist() {
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
return this._queriesArchivist;
|
|
78
|
-
}
|
|
79
|
-
if (Date.now() - (this._lastQueriesArchivistAttempt ?? 0) < this._reResolveDelay) {
|
|
80
|
-
return;
|
|
81
|
-
}
|
|
82
|
-
this._lastQueriesArchivistAttempt = Date.now();
|
|
83
|
-
const resolved = await this.resolver.resolve((_c = (_b = (_a = this.config) == null ? void 0 : _a.intersect) == null ? void 0 : _b.queries) == null ? void 0 : _c.archivist);
|
|
84
|
-
if (resolved) {
|
|
85
|
-
const typedResolve = asArchivistInstance(resolved);
|
|
86
|
-
if (typedResolve) {
|
|
87
|
-
return typedResolve;
|
|
88
|
-
} else {
|
|
89
|
-
(_h = this.logger) == null ? void 0 : _h.warn(`Unable to resolve queriesArchivist as correct type [${(_f = (_e = (_d = this.config) == null ? void 0 : _d.intersect) == null ? void 0 : _e.queries) == null ? void 0 : _f.archivist}][${(_g = resolved == null ? void 0 : resolved.constructor) == null ? void 0 : _g.name}]: ${toJsonString(resolved)}`);
|
|
90
|
-
}
|
|
91
|
-
} else {
|
|
92
|
-
(_l = this.logger) == null ? void 0 : _l.log(`Unable to resolve queriesArchivist [${(_k = (_j = (_i = this.config) == null ? void 0 : _i.intersect) == null ? void 0 : _j.queries) == null ? void 0 : _k.archivist}]`);
|
|
93
|
-
}
|
|
94
|
-
});
|
|
70
|
+
var _a, _b, _c;
|
|
71
|
+
this._queriesArchivist = this._queriesArchivist ?? await this.resolve(assertEx((_c = (_b = (_a = this.config) == null ? void 0 : _a.intersect) == null ? void 0 : _b.queries) == null ? void 0 : _c.archivist, () => "No queries Archivist defined"), isArchivistInstance);
|
|
72
|
+
return this._queriesArchivist;
|
|
95
73
|
}
|
|
96
74
|
async queriesDiviner() {
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
return this._queriesDiviner;
|
|
101
|
-
}
|
|
102
|
-
if (Date.now() - (this._lastQueriesDivinerAttempt ?? 0) < this._reResolveDelay) {
|
|
103
|
-
return;
|
|
104
|
-
}
|
|
105
|
-
this._lastQueriesDivinerAttempt = Date.now();
|
|
106
|
-
const resolved = await this.resolver.resolve((_c = (_b = (_a = this.config) == null ? void 0 : _a.intersect) == null ? void 0 : _b.queries) == null ? void 0 : _c.boundWitnessDiviner);
|
|
107
|
-
if (resolved) {
|
|
108
|
-
const typedResolve = asDivinerInstance(resolved);
|
|
109
|
-
if (typedResolve) {
|
|
110
|
-
return typedResolve;
|
|
111
|
-
} else {
|
|
112
|
-
(_h = this.logger) == null ? void 0 : _h.warn(`Unable to resolve queriesDiviner as correct type [${(_f = (_e = (_d = this.config) == null ? void 0 : _d.intersect) == null ? void 0 : _e.queries) == null ? void 0 : _f.boundWitnessDiviner}][${(_g = resolved == null ? void 0 : resolved.constructor) == null ? void 0 : _g.name}]: ${toJsonString(resolved)}`);
|
|
113
|
-
}
|
|
114
|
-
} else {
|
|
115
|
-
(_l = this.logger) == null ? void 0 : _l.log(`Unable to resolve queriesDiviner [${(_k = (_j = (_i = this.config) == null ? void 0 : _i.intersect) == null ? void 0 : _j.queries) == null ? void 0 : _k.boundWitnessDiviner}]`);
|
|
116
|
-
}
|
|
117
|
-
});
|
|
75
|
+
var _a, _b, _c;
|
|
76
|
+
this._queriesDiviner = this._queriesDiviner ?? await this.resolve(assertEx((_c = (_b = (_a = this.config) == null ? void 0 : _a.intersect) == null ? void 0 : _b.queries) == null ? void 0 : _c.boundWitnessDiviner, () => "No queries Diviner defined"), isDivinerInstance);
|
|
77
|
+
return this._queriesDiviner;
|
|
118
78
|
}
|
|
119
79
|
async responsesArchivist() {
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
return this._responsesArchivist;
|
|
124
|
-
}
|
|
125
|
-
if (Date.now() - (this._lastResponsesArchivistAttempt ?? 0) < this._reResolveDelay) {
|
|
126
|
-
return;
|
|
127
|
-
}
|
|
128
|
-
this._lastResponsesArchivistAttempt = Date.now();
|
|
129
|
-
const resolved = await this.resolver.resolve((_c = (_b = (_a = this.config) == null ? void 0 : _a.intersect) == null ? void 0 : _b.responses) == null ? void 0 : _c.archivist);
|
|
130
|
-
if (resolved) {
|
|
131
|
-
const typedResolve = asArchivistInstance(resolved);
|
|
132
|
-
if (typedResolve) {
|
|
133
|
-
return typedResolve;
|
|
134
|
-
} else {
|
|
135
|
-
(_h = this.logger) == null ? void 0 : _h.warn(`Unable to resolve responseArchivist as correct type [${(_f = (_e = (_d = this.config) == null ? void 0 : _d.intersect) == null ? void 0 : _e.responses) == null ? void 0 : _f.archivist}][${(_g = resolved == null ? void 0 : resolved.constructor) == null ? void 0 : _g.name}]: ${toJsonString(resolved)}`);
|
|
136
|
-
}
|
|
137
|
-
} else {
|
|
138
|
-
(_l = this.logger) == null ? void 0 : _l.log(`Unable to resolve responseArchivist [${(_k = (_j = (_i = this.config) == null ? void 0 : _i.intersect) == null ? void 0 : _j.responses) == null ? void 0 : _k.archivist}]`);
|
|
139
|
-
}
|
|
140
|
-
});
|
|
80
|
+
var _a, _b, _c;
|
|
81
|
+
this._responsesArchivist = this._responsesArchivist ?? await this.resolve(assertEx((_c = (_b = (_a = this.config) == null ? void 0 : _a.intersect) == null ? void 0 : _b.responses) == null ? void 0 : _c.archivist, () => "No responses Archivist defined"), isArchivistInstance);
|
|
82
|
+
return this._responsesArchivist;
|
|
141
83
|
}
|
|
142
84
|
async responsesDiviner() {
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
return this._responsesDiviner;
|
|
147
|
-
}
|
|
148
|
-
if (Date.now() - (this._lastResponsesDivinerAttempt ?? 0) < this._reResolveDelay) {
|
|
149
|
-
return;
|
|
150
|
-
}
|
|
151
|
-
this._lastResponsesDivinerAttempt = Date.now();
|
|
152
|
-
const resolved = await this.resolver.resolve((_c = (_b = (_a = this.config) == null ? void 0 : _a.intersect) == null ? void 0 : _b.responses) == null ? void 0 : _c.boundWitnessDiviner);
|
|
153
|
-
if (resolved) {
|
|
154
|
-
const typedResolve = asDivinerInstance(resolved);
|
|
155
|
-
if (typedResolve) {
|
|
156
|
-
return typedResolve;
|
|
157
|
-
} else {
|
|
158
|
-
(_h = this.logger) == null ? void 0 : _h.warn(`Unable to resolve responsesDiviner as correct type [${(_f = (_e = (_d = this.config) == null ? void 0 : _d.intersect) == null ? void 0 : _e.responses) == null ? void 0 : _f.boundWitnessDiviner}][${(_g = resolved == null ? void 0 : resolved.constructor) == null ? void 0 : _g.name}]: ${toJsonString(resolved)}`);
|
|
159
|
-
}
|
|
160
|
-
} else {
|
|
161
|
-
(_l = this.logger) == null ? void 0 : _l.log(`Unable to resolve responsesDiviner [${(_k = (_j = (_i = this.config) == null ? void 0 : _i.intersect) == null ? void 0 : _j.responses) == null ? void 0 : _k.boundWitnessDiviner}]`);
|
|
162
|
-
}
|
|
163
|
-
});
|
|
85
|
+
var _a, _b, _c;
|
|
86
|
+
this._responsesDiviner = this._responsesDiviner ?? await this.resolve(assertEx((_c = (_b = (_a = this.config) == null ? void 0 : _a.intersect) == null ? void 0 : _b.responses) == null ? void 0 : _c.boundWitnessDiviner, () => "No responses Diviner defined"), isDivinerInstance);
|
|
87
|
+
return this._responsesDiviner;
|
|
164
88
|
}
|
|
165
89
|
/**
|
|
166
90
|
* Commit the internal state of the process. This is similar
|
|
@@ -192,6 +116,28 @@ var _AsyncQueryBusBase = class _AsyncQueryBusBase extends Base2 {
|
|
|
192
116
|
return state;
|
|
193
117
|
}
|
|
194
118
|
}
|
|
119
|
+
async resolve(id, typeCheck) {
|
|
120
|
+
return await this._resolveMutex.runExclusive(async () => {
|
|
121
|
+
var _a, _b, _c;
|
|
122
|
+
if (this._queriesArchivist) {
|
|
123
|
+
return this._queriesArchivist;
|
|
124
|
+
}
|
|
125
|
+
if (Date.now() - (this._lastResolveAttempt[id] ?? 0) < this._reResolveDelay) {
|
|
126
|
+
return;
|
|
127
|
+
}
|
|
128
|
+
this._lastResolveAttempt[id] = Date.now();
|
|
129
|
+
const resolved = await this.resolver.resolve(id);
|
|
130
|
+
if (resolved) {
|
|
131
|
+
if (typeCheck(resolved)) {
|
|
132
|
+
return resolved;
|
|
133
|
+
} else {
|
|
134
|
+
(_b = this.logger) == null ? void 0 : _b.warn(`Unable to resolve responsesDiviner as correct type [${id}][${(_a = resolved == null ? void 0 : resolved.constructor) == null ? void 0 : _a.name}]: ${resolved.id}`);
|
|
135
|
+
}
|
|
136
|
+
} else {
|
|
137
|
+
(_c = this.logger) == null ? void 0 : _c.log(`Unable to resolve queriesArchivist [${id}] [${await traceModuleIdentifier(this.resolver, id)}]`);
|
|
138
|
+
}
|
|
139
|
+
});
|
|
140
|
+
}
|
|
195
141
|
};
|
|
196
142
|
__name(_AsyncQueryBusBase, "AsyncQueryBusBase");
|
|
197
143
|
var AsyncQueryBusBase = _AsyncQueryBusBase;
|
|
@@ -251,7 +197,7 @@ var _AsyncQueryBusClient = class _AsyncQueryBusClient extends AsyncQueryBusBase
|
|
|
251
197
|
...query,
|
|
252
198
|
$meta
|
|
253
199
|
});
|
|
254
|
-
const queryArchivist =
|
|
200
|
+
const queryArchivist = assertEx2(await this.queriesArchivist(), () => {
|
|
255
201
|
var _a2, _b2, _c2;
|
|
256
202
|
return `Unable to contact queriesArchivist [${(_c2 = (_b2 = (_a2 = this.config) == null ? void 0 : _a2.intersect) == null ? void 0 : _b2.queries) == null ? void 0 : _c2.archivist}]`;
|
|
257
203
|
});
|
|
@@ -388,7 +334,7 @@ var AsyncQueryBusClient = _AsyncQueryBusClient;
|
|
|
388
334
|
|
|
389
335
|
// src/AsyncQueryBus/AsyncQueryBusHost.ts
|
|
390
336
|
import { containsAll } from "@xylabs/array";
|
|
391
|
-
import { assertEx as
|
|
337
|
+
import { assertEx as assertEx3 } from "@xylabs/assert";
|
|
392
338
|
import { clearTimeoutEx as clearTimeoutEx2, setTimeoutEx as setTimeoutEx2 } from "@xylabs/timer";
|
|
393
339
|
import { isQueryBoundWitnessWithMeta } from "@xyo-network/boundwitness-model";
|
|
394
340
|
import { BoundWitnessDivinerQuerySchema as BoundWitnessDivinerQuerySchema2 } from "@xyo-network/diviner-boundwitness-model";
|
|
@@ -421,7 +367,7 @@ var _AsyncQueryBusHost = class _AsyncQueryBusHost extends AsyncQueryBusBase {
|
|
|
421
367
|
throw new Error(`Unable to resolve module to expose [${id}]`);
|
|
422
368
|
}
|
|
423
369
|
if (module) {
|
|
424
|
-
|
|
370
|
+
assertEx3(!failOnAlreadyExposed || !this._exposedAddresses.has(module.address), () => `Address already exposed: ${id} [${module.address}]`);
|
|
425
371
|
this._exposedAddresses.add(module.address);
|
|
426
372
|
this._exposeOptions[module.address] = {
|
|
427
373
|
...options
|
|
@@ -436,7 +382,7 @@ var _AsyncQueryBusHost = class _AsyncQueryBusHost extends AsyncQueryBusBase {
|
|
|
436
382
|
...((_a = this.config) == null ? void 0 : _a.listeningModules) ?? [],
|
|
437
383
|
...this.exposedAddresses.values()
|
|
438
384
|
];
|
|
439
|
-
const mods = await Promise.all(exposedModules.map(async (exposedModule) =>
|
|
385
|
+
const mods = await Promise.all(exposedModules.map(async (exposedModule) => assertEx3(asModuleInstance(await this.resolver.resolve(exposedModule, {
|
|
440
386
|
maxDepth: 10
|
|
441
387
|
})), () => `Unable to resolve listeningModule [${exposedModule}]`)));
|
|
442
388
|
return mods;
|
|
@@ -461,7 +407,7 @@ var _AsyncQueryBusHost = class _AsyncQueryBusHost extends AsyncQueryBusBase {
|
|
|
461
407
|
maxDepth: 10
|
|
462
408
|
}));
|
|
463
409
|
if (module) {
|
|
464
|
-
|
|
410
|
+
assertEx3(!validate || this._exposedAddresses.has(module.address), () => `Address not exposed [${module.address}][${module.id}]`);
|
|
465
411
|
this._exposedAddresses.delete(module.address);
|
|
466
412
|
delete this._exposeOptions[module.address];
|
|
467
413
|
(_a = this.logger) == null ? void 0 : _a.debug(`${module.address} [${module.id}] unexposed`);
|
|
@@ -471,11 +417,11 @@ var _AsyncQueryBusHost = class _AsyncQueryBusHost extends AsyncQueryBusBase {
|
|
|
471
417
|
callLocalModule = async (localModule, query) => {
|
|
472
418
|
var _a, _b, _c, _d, _e, _f, _g;
|
|
473
419
|
const localModuleName = localModule.config.name ?? localModule.address;
|
|
474
|
-
const queryArchivist =
|
|
420
|
+
const queryArchivist = assertEx3(await this.queriesArchivist(), () => {
|
|
475
421
|
var _a2, _b2, _c2;
|
|
476
422
|
return `Unable to contact queriesArchivist [${(_c2 = (_b2 = (_a2 = this.config) == null ? void 0 : _a2.intersect) == null ? void 0 : _b2.queries) == null ? void 0 : _c2.archivist}]`;
|
|
477
423
|
});
|
|
478
|
-
const responsesArchivist =
|
|
424
|
+
const responsesArchivist = assertEx3(await this.responsesArchivist(), () => {
|
|
479
425
|
var _a2, _b2, _c2;
|
|
480
426
|
return `Unable to contact responsesArchivist [${(_c2 = (_b2 = (_a2 = this.config) == null ? void 0 : _a2.intersect) == null ? void 0 : _b2.queries) == null ? void 0 : _c2.archivist}]`;
|
|
481
427
|
});
|
|
@@ -647,13 +593,13 @@ var PubSubBridgeSchema = "network.xyo.bridge.pubsub";
|
|
|
647
593
|
var PubSubBridgeConfigSchema = `${PubSubBridgeSchema}.config`;
|
|
648
594
|
|
|
649
595
|
// src/PubSubBridge.ts
|
|
650
|
-
import { assertEx as
|
|
596
|
+
import { assertEx as assertEx5 } from "@xylabs/assert";
|
|
651
597
|
import { exists } from "@xylabs/exists";
|
|
652
598
|
import { AbstractBridge } from "@xyo-network/abstract-bridge";
|
|
653
599
|
import { creatableModule } from "@xyo-network/module-model";
|
|
654
600
|
|
|
655
601
|
// src/PubSubBridgeModuleResolver.ts
|
|
656
|
-
import { assertEx as
|
|
602
|
+
import { assertEx as assertEx4 } from "@xylabs/assert";
|
|
657
603
|
import { isAddress } from "@xylabs/hex";
|
|
658
604
|
import { AbstractBridgeModuleResolver, wrapModuleWithType } from "@xyo-network/abstract-bridge";
|
|
659
605
|
import { Account } from "@xyo-network/account";
|
|
@@ -668,7 +614,7 @@ var _PubSubBridgeModuleResolver = class _PubSubBridgeModuleResolver extends Abst
|
|
|
668
614
|
}
|
|
669
615
|
const idParts = id.split(":");
|
|
670
616
|
const firstPart = idParts.shift();
|
|
671
|
-
|
|
617
|
+
assertEx4(isAddress(firstPart), () => `Invalid module address: ${firstPart}`);
|
|
672
618
|
const remainderParts = idParts.join(":");
|
|
673
619
|
const account = Account.randomSync();
|
|
674
620
|
const params = {
|
|
@@ -685,13 +631,13 @@ var _PubSubBridgeModuleResolver = class _PubSubBridgeModuleResolver extends Abst
|
|
|
685
631
|
const state = await proxy.state();
|
|
686
632
|
if (state) {
|
|
687
633
|
const configSchema = (_a = state.find((payload) => payload.schema === ConfigSchema)) == null ? void 0 : _a.config;
|
|
688
|
-
const config =
|
|
634
|
+
const config = assertEx4(state.find((payload) => payload.schema === configSchema), () => "Unable to locate config");
|
|
689
635
|
proxy.setConfig(config);
|
|
690
636
|
}
|
|
691
637
|
}
|
|
692
638
|
await ((_b = proxy.start) == null ? void 0 : _b.call(proxy));
|
|
693
639
|
const wrapped = wrapModuleWithType(proxy, account);
|
|
694
|
-
const as =
|
|
640
|
+
const as = assertEx4(asModuleInstance2(wrapped, {}), () => `Failed to asModuleInstance [${id}]`);
|
|
695
641
|
proxy.upResolver.add(as);
|
|
696
642
|
proxy.downResolver.add(as);
|
|
697
643
|
this.add(as);
|
|
@@ -726,7 +672,7 @@ var _PubSubBridge = class _PubSubBridge extends AbstractBridge {
|
|
|
726
672
|
get resolver() {
|
|
727
673
|
this._resolver = this._resolver ?? new PubSubBridgeModuleResolver({
|
|
728
674
|
bridge: this,
|
|
729
|
-
busClient:
|
|
675
|
+
busClient: assertEx5(this.busClient(), () => "busClient not configured"),
|
|
730
676
|
wrapperAccount: this.account
|
|
731
677
|
});
|
|
732
678
|
return this._resolver;
|
|
@@ -735,7 +681,7 @@ var _PubSubBridge = class _PubSubBridge extends AbstractBridge {
|
|
|
735
681
|
return `${this.config.name ?? moduleName}`;
|
|
736
682
|
}
|
|
737
683
|
get roots() {
|
|
738
|
-
return
|
|
684
|
+
return assertEx5(this.config.roots, () => "roots not configured");
|
|
739
685
|
}
|
|
740
686
|
async discoverRoots() {
|
|
741
687
|
const rootInstances = (await Promise.all(this.roots.map(async (root) => await this.resolver.resolve(root)))).filter(exists);
|
|
@@ -746,7 +692,7 @@ var _PubSubBridge = class _PubSubBridge extends AbstractBridge {
|
|
|
746
692
|
}
|
|
747
693
|
async exposeHandler(id, options) {
|
|
748
694
|
const { maxDepth = 2, direction = "all", required = true } = options ?? {};
|
|
749
|
-
const host =
|
|
695
|
+
const host = assertEx5(this.busHost(), () => "Not configured as a host");
|
|
750
696
|
const module = await host.expose(id, {
|
|
751
697
|
required
|
|
752
698
|
});
|
|
@@ -781,7 +727,7 @@ var _PubSubBridge = class _PubSubBridge extends AbstractBridge {
|
|
|
781
727
|
}
|
|
782
728
|
async unexposeHandler(id, options) {
|
|
783
729
|
const { maxDepth = 2, direction = "all", required = true } = options ?? {};
|
|
784
|
-
const host =
|
|
730
|
+
const host = assertEx5(this.busHost(), () => "Not configured as a host");
|
|
785
731
|
const module = await host.unexpose(id, required);
|
|
786
732
|
if (module) {
|
|
787
733
|
const children = maxDepth > 0 ? await module.resolve("*", {
|