@xyo-network/module-abstract 2.92.7 → 2.92.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (42) hide show
  1. package/dist/browser/AbstractModule.d.cts +11 -5
  2. package/dist/browser/AbstractModule.d.cts.map +1 -1
  3. package/dist/browser/AbstractModule.d.mts +11 -5
  4. package/dist/browser/AbstractModule.d.mts.map +1 -1
  5. package/dist/browser/AbstractModule.d.ts +11 -5
  6. package/dist/browser/AbstractModule.d.ts.map +1 -1
  7. package/dist/browser/AbstractModuleInstance.d.cts +2 -1
  8. package/dist/browser/AbstractModuleInstance.d.cts.map +1 -1
  9. package/dist/browser/AbstractModuleInstance.d.mts +2 -1
  10. package/dist/browser/AbstractModuleInstance.d.mts.map +1 -1
  11. package/dist/browser/AbstractModuleInstance.d.ts +2 -1
  12. package/dist/browser/AbstractModuleInstance.d.ts.map +1 -1
  13. package/dist/browser/determineAccount.d.cts.map +1 -1
  14. package/dist/browser/determineAccount.d.mts.map +1 -1
  15. package/dist/browser/determineAccount.d.ts.map +1 -1
  16. package/dist/browser/index.cjs +54 -38
  17. package/dist/browser/index.cjs.map +1 -1
  18. package/dist/browser/index.js +54 -38
  19. package/dist/browser/index.js.map +1 -1
  20. package/dist/node/AbstractModule.d.cts +11 -5
  21. package/dist/node/AbstractModule.d.cts.map +1 -1
  22. package/dist/node/AbstractModule.d.mts +11 -5
  23. package/dist/node/AbstractModule.d.mts.map +1 -1
  24. package/dist/node/AbstractModule.d.ts +11 -5
  25. package/dist/node/AbstractModule.d.ts.map +1 -1
  26. package/dist/node/AbstractModuleInstance.d.cts +2 -1
  27. package/dist/node/AbstractModuleInstance.d.cts.map +1 -1
  28. package/dist/node/AbstractModuleInstance.d.mts +2 -1
  29. package/dist/node/AbstractModuleInstance.d.mts.map +1 -1
  30. package/dist/node/AbstractModuleInstance.d.ts +2 -1
  31. package/dist/node/AbstractModuleInstance.d.ts.map +1 -1
  32. package/dist/node/determineAccount.d.cts.map +1 -1
  33. package/dist/node/determineAccount.d.mts.map +1 -1
  34. package/dist/node/determineAccount.d.ts.map +1 -1
  35. package/dist/node/index.cjs +61 -42
  36. package/dist/node/index.cjs.map +1 -1
  37. package/dist/node/index.js +61 -42
  38. package/dist/node/index.js.map +1 -1
  39. package/package.json +25 -25
  40. package/src/AbstractModule.ts +68 -41
  41. package/src/AbstractModuleInstance.ts +3 -2
  42. package/src/determineAccount.ts +6 -3
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/AbstractModule.ts","../../src/BaseEmitter.ts","../../src/determineAccount.ts","../../src/Error.ts","../../src/QueryValidator/ModuleConfigQueryValidator.ts","../../src/QueryValidator/SupportedQueryValidator.ts","../../src/AbstractModuleInstance.ts"],"sourcesContent":["export * from './AbstractModule'\nexport * from './AbstractModuleInstance'\nexport * from './BaseEmitter'\nexport * from './Error'\nexport * from './QueryValidator'\n","/* eslint-disable max-lines */\nimport { assertEx } from '@xylabs/assert'\nimport { handleError, handleErrorAsync } from '@xylabs/error'\nimport { exists } from '@xylabs/exists'\nimport { Hash } from '@xylabs/hex'\nimport { compact } from '@xylabs/lodash'\nimport { ConsoleLogger, IdLogger, Logger, LogLevel } from '@xylabs/logger'\nimport { Base } from '@xylabs/object'\nimport { Promisable, PromiseEx } from '@xylabs/promise'\nimport { Account, HDWallet } from '@xyo-network/account'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { AddressPayload, AddressSchema } from '@xyo-network/address-payload-plugin'\nimport { ArchivistInstance, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitnessBuilder, QueryBoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { ConfigPayload, ConfigSchema } from '@xyo-network/config-payload-plugin'\nimport { ModuleManifestPayload, ModuleManifestPayloadSchema } from '@xyo-network/manifest-model'\nimport {\n AddressPreviousHashPayload,\n AddressPreviousHashSchema,\n CreatableModule,\n CreatableModuleFactory,\n DeadModuleError,\n duplicateModules,\n isModuleName,\n Module,\n ModuleAddressQuerySchema,\n ModuleBusyEventArgs,\n ModuleConfig,\n ModuleDescribeQuerySchema,\n ModuleDescriptionPayload,\n ModuleDescriptionSchema,\n ModuleDiscoverQuerySchema,\n ModuleEventData,\n ModuleFactory,\n ModuleFilter,\n ModuleFilterOptions,\n ModuleIdentifier,\n ModuleInstance,\n ModuleManifestQuerySchema,\n ModuleParams,\n ModuleQueriedEventArgs,\n ModuleQueries,\n ModuleQueryHandlerResult,\n ModuleQueryResult,\n ModuleStateQuerySchema,\n ModuleStatus,\n ModuleSubscribeQuerySchema,\n serializableField,\n} from '@xyo-network/module-model'\nimport { CompositeModuleResolver } from '@xyo-network/module-resolver'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { ModuleError, Payload, Query, Schema, WithMeta } from '@xyo-network/payload-model'\nimport { QueryPayload, QuerySchema } from '@xyo-network/query-payload-plugin'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nimport { BaseEmitter } from './BaseEmitter'\nimport { determineAccount } from './determineAccount'\nimport { ModuleErrorBuilder } from './Error'\nimport { ModuleConfigQueryValidator, Queryable, SupportedQueryValidator } from './QueryValidator'\n\nexport abstract class AbstractModule<TParams extends ModuleParams = ModuleParams, TEventData extends ModuleEventData = ModuleEventData>\n extends BaseEmitter<TParams, TEventData>\n implements Module<TParams, TEventData>\n{\n static readonly allowRandomAccount: boolean = true\n static configSchemas: string[]\n static override defaultLogger: Logger = new ConsoleLogger(LogLevel.log)\n static enableLazyLoad = false\n\n protected static privateConstructorKey = Date.now().toString()\n\n readonly downResolver: Omit<CompositeModuleResolver, 'resolve'> = new CompositeModuleResolver()\n readonly upResolver: Omit<CompositeModuleResolver, 'resolve>'> = new CompositeModuleResolver()\n\n protected _account: AccountInstance | undefined = undefined\n protected readonly _baseModuleQueryAccountPaths: Record<ModuleQueries['schema'], string> = {\n [ModuleAddressQuerySchema]: '1',\n [ModuleDescribeQuerySchema]: '4',\n [ModuleDiscoverQuerySchema]: '2',\n [ModuleManifestQuerySchema]: '5',\n [ModuleStateQuerySchema]: '6',\n [ModuleSubscribeQuerySchema]: '3',\n }\n protected _lastError?: Error\n protected readonly _queryAccounts: Record<ModuleQueries['schema'], AccountInstance | undefined> = {\n [ModuleAddressQuerySchema]: undefined,\n [ModuleDescribeQuerySchema]: undefined,\n [ModuleDiscoverQuerySchema]: undefined,\n [ModuleManifestQuerySchema]: undefined,\n [ModuleStateQuerySchema]: undefined,\n [ModuleSubscribeQuerySchema]: undefined,\n }\n protected _startPromise: Promisable<boolean> | undefined = undefined\n protected _started: Promisable<boolean> | undefined = undefined\n protected readonly moduleConfigQueryValidator: Queryable\n protected readonly supportedQueryValidator: Queryable\n\n private _busyCount = 0\n private _status: ModuleStatus = 'stopped'\n\n constructor(privateConstructorKey: string, params: TParams, account: AccountInstance) {\n assertEx(AbstractModule.privateConstructorKey === privateConstructorKey, 'Use create function instead of constructor')\n // Clone params to prevent mutation of the incoming object\n const mutatedParams = { ...params } as TParams\n super(mutatedParams)\n\n this._account = account\n\n this.supportedQueryValidator = new SupportedQueryValidator(this as Module).queryable\n this.moduleConfigQueryValidator = new ModuleConfigQueryValidator(mutatedParams?.config).queryable\n }\n\n static get configSchema(): string {\n return this.configSchemas[0]\n }\n\n get account() {\n return assertEx(this._account, 'Missing account')\n }\n\n get address() {\n return this.account.address\n }\n\n get allowAnonymous() {\n return !!this.config.security?.allowAnonymous\n }\n\n get config(): TParams['config'] {\n return this.params.config\n }\n\n get dead() {\n return this.status === 'dead'\n }\n\n get ephemeralQueryAccountEnabled(): boolean {\n return !!this.params.ephemeralQueryAccountEnabled\n }\n\n get id() {\n return this.config.name ?? this.address\n }\n\n get queries(): string[] {\n return [\n ModuleDiscoverQuerySchema,\n ModuleAddressQuerySchema,\n ModuleSubscribeQuerySchema,\n ModuleDescribeQuerySchema,\n ModuleManifestQuerySchema,\n ModuleStateQuerySchema,\n ]\n }\n\n get queryAccountPaths(): Readonly<Record<Query['schema'], string | undefined>> {\n return { ...this._baseModuleQueryAccountPaths, ...this._queryAccountPaths }\n }\n\n get queryAccounts(): Readonly<Record<Query['schema'], AccountInstance | undefined>> {\n return this._queryAccounts\n }\n\n get status() {\n return this._status\n }\n\n get timestamp() {\n return this.config.timestamp ?? false\n }\n\n protected get baseModuleQueryAccountPaths(): Record<ModuleQueries['schema'], string> {\n return this._baseModuleQueryAccountPaths\n }\n\n protected override get logger() {\n return this.params?.logger ?? AbstractModule.defaultLogger ?? Base.defaultLogger\n }\n\n protected set status(value: ModuleStatus) {\n if (this._status !== 'dead') {\n this._status = value\n }\n }\n\n protected abstract get _queryAccountPaths(): Record<Query['schema'], string>\n\n static _getRootFunction(funcName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let anyThis = this as any\n while (anyThis.__proto__[funcName]) {\n anyThis = anyThis.__proto__\n }\n return anyThis[funcName]\n }\n\n static _noOverride(functionName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const thisFunc = (this as any)[functionName]\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const rootFunc = this._getRootFunction(functionName)\n assertEx(thisFunc === rootFunc, `Override not allowed for [${functionName}] - override ${functionName}Handler instead`)\n }\n\n static async create<TModule extends ModuleInstance>(\n this: CreatableModule<TModule>,\n params?: Omit<TModule['params'], 'config'> & { config?: TModule['params']['config'] },\n ) {\n this._noOverride('create')\n if (!this.configSchemas || this.configSchemas.length === 0) {\n throw new Error(`Missing configSchema [${params?.config?.schema}][${this.name}]`)\n }\n\n assertEx(params?.config?.name === undefined || isModuleName(params.config.name), `Invalid module name: ${params?.config?.name}`)\n\n const { account } = params ?? {}\n\n const schema: string = params?.config?.schema ?? this.configSchema\n const allowedSchemas: string[] = this.configSchemas\n\n assertEx(allowedSchemas.includes(schema), () => `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`)\n const mutatedConfig: TModule['params']['config'] = { ...params?.config, schema } as TModule['params']['config']\n params?.logger?.debug(`config: ${JSON.stringify(mutatedConfig, null, 2)}`)\n const mutatedParams: TModule['params'] = { ...params, config: mutatedConfig } as TModule['params']\n\n const activeLogger = params?.logger ?? AbstractModule.defaultLogger\n const generatedAccount = await AbstractModule.determineAccount({ account })\n const address = generatedAccount.address\n mutatedParams.logger = activeLogger ? new IdLogger(activeLogger, () => `0x${address}`) : undefined\n\n const newModule = new this(AbstractModule.privateConstructorKey, mutatedParams, generatedAccount)\n\n if (!AbstractModule.enableLazyLoad) {\n await newModule.start?.()\n }\n return newModule\n }\n\n static async determineAccount(params: {\n account?: AccountInstance | 'random'\n accountPath?: string\n wallet?: WalletInstance\n }): Promise<AccountInstance> {\n return await determineAccount(params, this.allowRandomAccount)\n }\n\n static factory<TModule extends ModuleInstance>(\n this: CreatableModule<TModule>,\n params?: Omit<TModule['params'], 'config'> & { config?: TModule['params']['config'] },\n ): CreatableModuleFactory<TModule> {\n return ModuleFactory.withParams(this, params)\n }\n\n _getRootFunction(funcName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let anyThis = this as any\n while (anyThis.__proto__[funcName]) {\n anyThis = anyThis.__proto__\n }\n return anyThis[funcName]\n }\n\n async busy<R>(closure: () => Promise<R>) {\n if (this._busyCount <= 0) {\n this._busyCount = 0\n const args: ModuleBusyEventArgs = { busy: true, module: this }\n await this.emit('moduleBusy', args)\n }\n this._busyCount++\n try {\n return await closure()\n } finally {\n this._busyCount--\n if (this._busyCount <= 0) {\n this._busyCount = 0\n const args: ModuleBusyEventArgs = { busy: false, module: this }\n await this.emit('moduleBusy', args)\n }\n }\n }\n\n override emit<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return super.emit(eventName, eventArgs)\n }\n\n previousHash(): Promisable<string | undefined> {\n this._checkDead()\n return this.account.previousHash\n }\n\n async query<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryResult> {\n this._checkDead()\n this._noOverride('query')\n const sourceQuery = await PayloadBuilder.build(assertEx(QueryBoundWitnessWrapper.unwrap(query), 'Invalid query'))\n return await this.busy(async () => {\n const resultPayloads: Payload[] = []\n const errorPayloads: ModuleError[] = []\n const queryAccount = this.ephemeralQueryAccountEnabled ? Account.randomSync() : undefined\n try {\n await this.started('throw')\n if (!this.allowAnonymous && query.addresses.length === 0) {\n throw new Error(`Anonymous Queries not allowed, but running anyway [${this.config.name}], [${this.address}]`)\n }\n resultPayloads.push(...(await this.queryHandler(sourceQuery, payloads, queryConfig)))\n } catch (ex) {\n await handleErrorAsync(ex, async (error) => {\n this._lastError = error\n this.status = 'dead'\n errorPayloads.push(\n await new ModuleErrorBuilder()\n .sources([sourceQuery.$hash])\n .name(this.config.name ?? '<Unknown>')\n .query(sourceQuery.schema)\n .message(error.message)\n .build(),\n )\n })\n }\n if (this.timestamp) {\n const timestamp = { schema: 'network.xyo.timestamp', timestamp: Date.now() }\n resultPayloads.push(timestamp)\n }\n const result = await this.bindQueryResult(sourceQuery, resultPayloads, queryAccount ? [queryAccount] : [], errorPayloads)\n const args: ModuleQueriedEventArgs = { module: this, payloads, query: sourceQuery, result }\n await this.emit('moduleQueried', args)\n return result\n })\n }\n\n async queryable<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<boolean> {\n if (this.dead) {\n return false\n }\n if (!(await this.started('warn'))) return false\n const configValidator =\n queryConfig ? new ModuleConfigQueryValidator(Object.assign({}, this.config, queryConfig)).queryable : this.moduleConfigQueryValidator\n const validators = [this.supportedQueryValidator, configValidator]\n\n return validators.every((validator) => validator(query, payloads))\n }\n\n async resolve<T extends ModuleInstance = ModuleInstance>(filter?: ModuleFilter, options?: ModuleFilterOptions<T>): Promise<T[]>\n async resolve<T extends ModuleInstance = ModuleInstance>(id: ModuleIdentifier, options?: ModuleFilterOptions<T>): Promise<T | undefined>\n async resolve<T extends ModuleInstance = ModuleInstance>(\n idOrFilter?: ModuleFilter<T> | ModuleIdentifier,\n { required = 'log', ...options }: ModuleFilterOptions<T> = {},\n ): Promise<T | T[] | undefined> {\n const childOptions = { ...options, required: false }\n const direction = options?.direction ?? 'all'\n const up = direction === 'up' || direction === 'all'\n const down = direction === 'down' || direction === 'all'\n let result: T | T[] | undefined\n switch (typeof idOrFilter) {\n case 'string': {\n if (this.dead) {\n return undefined\n }\n result =\n (down ? await (this.downResolver as CompositeModuleResolver).resolve<T>(idOrFilter, childOptions) : undefined) ??\n (up ? await (this.upResolver as CompositeModuleResolver).resolve<T>(idOrFilter, childOptions) : undefined)\n break\n }\n default: {\n if (this.dead) {\n return []\n }\n const filter: ModuleFilter<T> | undefined = idOrFilter\n result = [\n ...(down ? await (this.downResolver as CompositeModuleResolver).resolve<T>(filter, childOptions) : []),\n ...(up ? await (this.upResolver as CompositeModuleResolver).resolve<T>(filter, childOptions) : []),\n ].filter(duplicateModules)\n break\n }\n }\n if (required && (result === undefined || (Array.isArray(result) && result.length > 0))) {\n switch (required) {\n case 'warn': {\n this.logger.warn('resolve failed', idOrFilter)\n break\n }\n case 'log': {\n this.logger.log('resolve failed', idOrFilter)\n break\n }\n default: {\n this.logger.error('resolve failed', idOrFilter)\n break\n }\n }\n }\n return result\n }\n\n start(_timeout?: number): Promisable<boolean> {\n //using promise as mutex\n this._startPromise = this._startPromise ?? this.startHandler()\n const result = this._startPromise\n this.status = result ? 'started' : 'dead'\n return result\n }\n\n async started(notStartedAction: 'error' | 'throw' | 'warn' | 'log' | 'none' = 'log', tryStart = true): Promise<boolean> {\n const started = await this._started\n if (started === true) {\n return true\n }\n if (!started) {\n //using promise as mutex\n this._started = (async () => {\n if (tryStart) {\n try {\n await this.start()\n return true\n } catch (ex) {\n handleError(ex, (error) => {\n this.logger?.warn(`Autostart of Module Failed: ${error.message})`)\n this._started = undefined\n })\n }\n }\n switch (notStartedAction) {\n case 'throw': {\n throw new Error(`Module not Started [${this.address}]`)\n }\n case 'warn': {\n this.logger?.warn('Module not started')\n break\n }\n case 'error': {\n this.logger?.error('Module not started')\n break\n }\n case 'none': {\n break\n }\n default: {\n this.logger?.log('Module not started')\n break\n }\n }\n return false\n })()\n }\n if (!this._started) {\n throw 'Failed to create start promise'\n }\n return await this._started\n }\n\n async stop(_timeout?: number): Promise<boolean> {\n return await this.busy(async () => {\n const result = await this.stopHandler()\n this._started = undefined\n this._startPromise = undefined\n this.status = result ? 'stopped' : 'dead'\n return result\n })\n }\n\n protected _checkDead() {\n if (this.dead) {\n throw new DeadModuleError(this.id, this._lastError)\n }\n }\n\n protected _noOverride(functionName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const thisFunc = (this as any)[functionName]\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const rootFunc = this._getRootFunction(functionName)\n assertEx(thisFunc === rootFunc, () => `Override not allowed for [${functionName}] - override ${functionName}Handler instead`)\n }\n\n protected bindHashes(hashes: Hash[], schema: Schema[], account?: AccountInstance) {\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n const promise = new PromiseEx((resolve) => {\n const result = this.bindHashesInternal(hashes, schema, account)\n resolve?.(result)\n return result\n }, account)\n return promise\n }\n\n protected async bindHashesInternal(hashes: Hash[], schema: Schema[], account?: AccountInstance): Promise<BoundWitness> {\n const builder = new BoundWitnessBuilder().hashes(hashes, schema).witness(this.account)\n const result = (await (account ? builder.witness(account) : builder).build())[0]\n this.logger?.debug(`result: ${JSON.stringify(result, null, 2)}`)\n return result\n }\n\n protected bindQuery<T extends Query>(\n query: T,\n payloads?: Payload[],\n account?: AccountInstance,\n ): PromiseEx<[WithMeta<QueryBoundWitness>, WithMeta<Payload>[], WithMeta<Payload>[]], AccountInstance> {\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n const promise = new PromiseEx<[WithMeta<QueryBoundWitness>, WithMeta<Payload>[], WithMeta<Payload>[]], AccountInstance>(async (resolve) => {\n const result = await this.bindQueryInternal(query, payloads, account)\n resolve?.(result)\n return result\n }, account)\n return promise\n }\n\n protected async bindQueryInternal<T extends Query>(\n query: T,\n payloads?: Payload[],\n account?: AccountInstance,\n ): Promise<[WithMeta<QueryBoundWitness>, WithMeta<Payload>[], WithMeta<Payload>[]]> {\n const builder = await (await new QueryBoundWitnessBuilder().payloads(payloads)).witness(this.account).query(query)\n const result = await (account ? builder.witness(account) : builder).build()\n return result\n }\n\n protected async bindQueryResult<T extends Query>(\n query: WithMeta<T>,\n payloads: Payload[],\n additionalWitnesses: AccountInstance[] = [],\n errors?: ModuleError[],\n ): Promise<ModuleQueryResult> {\n const builder = (await (await new BoundWitnessBuilder().payloads(payloads)).errors(errors)).sourceQuery(query.$hash)\n const queryWitnessAccount = this.queryAccounts[query.schema as ModuleQueries['schema']]\n const witnesses = [this.account, queryWitnessAccount, ...additionalWitnesses].filter(exists)\n builder.witnesses(witnesses)\n const result: ModuleQueryResult = [\n (await builder.build())[0],\n await Promise.all(payloads.map((payload) => PayloadBuilder.build(payload))),\n await Promise.all((errors ?? [])?.map((error) => PayloadBuilder.build(error))),\n ]\n if (this.config.archiving) {\n await this.storeToArchivists(result.flat())\n }\n return result\n }\n\n protected async describeHandler(): Promise<ModuleDescriptionPayload> {\n const description: ModuleDescriptionPayload = {\n address: this.address,\n queries: this.queries,\n schema: ModuleDescriptionSchema,\n }\n if (this.config?.name) {\n description.name = this.config.name\n }\n\n const discover = await this.discoverHandler()\n\n description.children = compact(\n discover?.map((payload) => {\n const address = payload.schema === AddressSchema ? (payload as AddressPayload).address : undefined\n return address == this.address ? undefined : address\n }) ?? [],\n )\n\n return description\n }\n\n protected async discoverHandler(_maxDepth?: number): Promise<Payload[]> {\n const config = this.config\n const address = await new PayloadBuilder<AddressPayload>({ schema: AddressSchema })\n .fields({ address: this.address, name: this.config?.name })\n .build()\n const queries = await Promise.all(\n this.queries.map(async (query) => {\n return await new PayloadBuilder<QueryPayload>({ schema: QuerySchema }).fields({ query }).build()\n }),\n )\n const configSchema: ConfigPayload = {\n config: config.schema,\n schema: ConfigSchema,\n }\n return compact([config, configSchema, address, ...queries])\n }\n\n protected async getArchivist(): Promise<ArchivistInstance | undefined> {\n if (!this.config.archivist) return undefined\n const resolved = await this.upResolver.resolve(this.config.archivist)\n return asArchivistInstance(resolved)\n }\n\n protected async initializeQueryAccounts() {\n // Ensure distinct/unique wallet paths\n const paths = Object.values(this.queryAccountPaths).filter(exists)\n const distinctPaths = new Set<string>(paths)\n assertEx(distinctPaths.size === paths.length, () => `${this.config?.name ? this.config.name + ': ' : ''}Duplicate query account paths`)\n // Create an account for query this module supports\n const wallet = this.account as unknown as HDWallet\n if (wallet?.derivePath) {\n for (const key in this.queryAccountPaths) {\n if (Object.prototype.hasOwnProperty.call(this.queryAccountPaths, key)) {\n const query = key as ModuleQueries['schema']\n const queryAccountPath = this.queryAccountPaths[query]\n if (queryAccountPath) {\n this._queryAccounts[query] = await wallet.derivePath?.(queryAccountPath)\n }\n }\n }\n }\n }\n\n protected manifestHandler(_depth?: number, _ignoreAddresses?: string[]): Promisable<ModuleManifestPayload> {\n const name = this.config.name ?? 'Anonymous'\n return { config: { name, ...this.config }, schema: ModuleManifestPayloadSchema, status: { address: this.address } }\n }\n\n protected moduleAddressHandler(): Promisable<AddressPreviousHashPayload[]> {\n // Return array of all addresses and their previous hash\n const queryAccounts = Object.entries(this.queryAccounts)\n .filter((value): value is [string, AccountInstance] => {\n return exists(value[1])\n })\n .map(([name, account]) => {\n const address = account.address\n const previousHash = account.previousHash\n return [\n { address, name, schema: AddressSchema },\n { address, previousHash, schema: AddressPreviousHashSchema },\n ]\n })\n const address = this.address\n const name = this.config.name\n const previousHash = this.address\n const moduleAccount = name ? { address, name, schema: AddressSchema } : { address, schema: AddressSchema }\n const moduleAccountPreviousHash =\n previousHash ? { address, previousHash, schema: AddressPreviousHashSchema } : { address, schema: AddressPreviousHashSchema }\n return [moduleAccount, moduleAccountPreviousHash, ...queryAccounts].flat()\n }\n\n protected async queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryHandlerResult> {\n await this.started('throw')\n const wrapper = await QueryBoundWitnessWrapper.parseQuery<ModuleQueries>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(await this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n switch (queryPayload.schema) {\n case ModuleManifestQuerySchema: {\n resultPayloads.push(await this.manifestHandler(queryPayload.maxDepth))\n break\n }\n case ModuleDiscoverQuerySchema: {\n const { maxDepth } = queryPayload\n resultPayloads.push(...(await this.discoverHandler(maxDepth)))\n break\n }\n case ModuleDescribeQuerySchema: {\n resultPayloads.push(await this.describeHandler())\n break\n }\n case ModuleAddressQuerySchema: {\n resultPayloads.push(...(await this.moduleAddressHandler()))\n break\n }\n case ModuleStateQuerySchema: {\n resultPayloads.push(...(await this.stateHandler()))\n break\n }\n case ModuleSubscribeQuerySchema: {\n this.subscribeHandler()\n break\n }\n default: {\n throw new Error(`Unsupported Query [${(queryPayload as Payload).schema}]`)\n }\n }\n return resultPayloads\n }\n\n protected async resolveArchivingArchivists(): Promise<ArchivistInstance[]> {\n const archivists = this.config.archiving?.archivists\n if (!archivists) return []\n const resolved = await Promise.all(archivists.map((archivist) => this.resolve(archivist)))\n return compact(resolved.map((mod) => asArchivistInstance(mod)))\n }\n\n protected async startHandler(): Promise<boolean> {\n this.validateConfig()\n await this.initializeQueryAccounts()\n this._started = true\n return true\n }\n\n protected async stateHandler(): Promise<Payload[]> {\n return [await this.manifestHandler(), ...(await this.discoverHandler()), await this.describeHandler()]\n }\n\n protected stopHandler(_timeout?: number): Promisable<boolean> {\n this._started = undefined\n return true\n }\n\n protected async storeToArchivists(payloads: Payload[]): Promise<Payload[]> {\n const archivists = await this.resolveArchivingArchivists()\n return (\n await Promise.all(\n archivists.map((archivist) => {\n return archivist.insert?.(payloads)\n }),\n )\n ).map(([bw]) => bw)\n }\n\n protected subscribeHandler() {\n return\n }\n\n protected validateConfig(config?: unknown, parents: string[] = []): boolean {\n // eslint-disable-next-line unicorn/no-array-reduce\n return Object.entries(config ?? this.config ?? {}).reduce((valid, [key, value]) => {\n switch (typeof value) {\n case 'function': {\n this.logger?.warn(`Fields of type function not allowed in config [${parents?.join('.')}.${key}]`)\n return false\n }\n case 'object': {\n if (Array.isArray(value)) {\n return (\n // eslint-disable-next-line unicorn/no-array-reduce\n value.reduce((valid, value) => {\n return this.validateConfig(value, [...parents, key]) && valid\n }, true) && valid\n )\n }\n\n if (!serializableField(value)) {\n this.logger?.warn(`Fields that are not serializable to JSON are not allowed in config [${parents?.join('.')}.${key}]`)\n return false\n }\n return value ? this.validateConfig(value, [...parents, key]) && valid : true\n }\n default: {\n return valid\n }\n }\n }, true)\n }\n}\n","import { Base, BaseParams } from '@xylabs/object'\nimport { EventAnyListener, EventData, EventFunctions, EventListener, Events } from '@xyo-network/module-events'\n\nexport class BaseEmitter<TParams extends BaseParams = BaseParams, TEventData extends EventData = EventData>\n extends Base<TParams>\n implements EventFunctions<TEventData>\n{\n //just here to query types\n eventData = {} as TEventData\n\n private events: Events<TEventData>\n\n constructor(params: TParams) {\n super(params)\n this.events = new Events<TEventData>()\n }\n\n clearListeners(eventNames: keyof TEventData | (keyof TEventData)[]) {\n return this.events.clearListeners(eventNames)\n }\n\n emit<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return this.events.emit(eventName, eventArgs)\n }\n\n emitSerial<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return this.events.emitSerial(eventName, eventArgs)\n }\n\n listenerCount(eventNames: keyof TEventData | (keyof TEventData)[]) {\n return this.events.listenerCount(eventNames)\n }\n\n off<TEventName extends keyof TEventData>(eventNames: TEventName | TEventName[], listener: EventListener<TEventData[TEventName]>) {\n return this.events.off(eventNames, listener)\n }\n\n offAny(listener: EventAnyListener) {\n return this.events.offAny(listener)\n }\n\n on<TEventName extends keyof TEventData>(eventNames: TEventName | TEventName[], listener: EventListener<TEventData[TEventName]>) {\n return this.events.on(eventNames, listener)\n }\n\n onAny(listener: EventAnyListener) {\n return this.events.onAny(listener)\n }\n\n once<TEventName extends keyof TEventData>(eventName: TEventName, listener: EventListener<TEventData[TEventName]>) {\n return this.events.once(eventName, listener)\n }\n}\n","/* eslint-disable max-lines */\nimport { assertEx } from '@xylabs/assert'\nimport { Account } from '@xyo-network/account'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nexport interface DetermineAccountFromAccountParams {\n account: AccountInstance | 'random'\n}\n\nexport interface DetermineAccountFromWalletParams {\n accountPath?: string\n wallet: WalletInstance\n}\n\nexport interface DetermineRandomParams {}\n\nexport type DetermineAccountParams = DetermineAccountFromAccountParams | DetermineAccountFromWalletParams | DetermineRandomParams\n\nconst isDetermineAccountFromAccountParams = (params: DetermineAccountParams): params is DetermineAccountFromAccountParams => {\n assertEx(!(params as DetermineAccountFromWalletParams).accountPath, 'accountPath may not be provided when account is provided')\n return !!(params as DetermineAccountFromAccountParams).account\n}\n\nconst isDetermineAccountFromWalletParams = (params: DetermineAccountParams): params is DetermineAccountFromWalletParams => {\n return !!(params as DetermineAccountFromWalletParams).wallet\n}\n\nexport async function determineAccount(params: DetermineAccountParams, allowRandomAccount = true): Promise<AccountInstance> {\n if (isDetermineAccountFromAccountParams(params)) {\n if (params.account === 'random') {\n assertEx(allowRandomAccount, 'Random address not allowed')\n return Account.randomSync()\n }\n return params.account\n }\n\n if (isDetermineAccountFromWalletParams(params)) {\n return assertEx(params.accountPath ? await params.wallet.derivePath(params.accountPath) : params.wallet, 'Failed to derive account from path')\n }\n\n //this should eventually be removed/thrown\n console.warn('AbstractModule.determineAccount: No account or wallet provided - Creating Random account')\n return Account.randomSync()\n}\n","import { Hash } from '@xylabs/hex'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { ModuleError, ModuleErrorSchema, WithMeta } from '@xyo-network/payload-model'\n\nexport class ModuleErrorBuilder extends PayloadBuilder<ModuleError> {\n _message?: string\n _name?: string\n _query?: Hash\n _sources?: Hash[]\n constructor() {\n super({ schema: ModuleErrorSchema })\n }\n\n override build(): Promise<WithMeta<ModuleError>> {\n this.fields({\n message: this._message,\n name: this._name,\n query: this._query,\n schema: ModuleErrorSchema,\n sources: this._sources,\n })\n return super.build()\n }\n\n message(message: string) {\n this._message = message\n return this\n }\n\n name(name: string) {\n this._name = name\n return this\n }\n\n query(query: Hash) {\n this._query = query\n return this\n }\n\n sources(sources: Hash[]) {\n this._sources = sources\n return this\n }\n}\n","import { Address } from '@xylabs/hex'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { AnyConfigSchema, CosigningAddressSet, ModuleConfig, ModuleQueries } from '@xyo-network/module-model'\nimport { Schema } from '@xyo-network/payload-model'\n\nimport { Queryable, QueryValidator } from './QueryValidator'\n\nexport type SortedPipedAddressesString = string\n\nconst delimiter = ''\n\nexport class ModuleConfigQueryValidator<TConfig extends AnyConfigSchema<ModuleConfig>> implements QueryValidator {\n protected allowed: Record<Schema, SortedPipedAddressesString[]> = {}\n protected disallowed: Record<Schema, SortedPipedAddressesString[]> = {}\n protected readonly hasAllowedRules: boolean\n protected readonly hasDisallowedRules: boolean\n protected readonly hasRules: boolean\n\n constructor(config?: TConfig) {\n if (config?.security?.allowed) {\n for (const [schema, addresses] of Object.entries(config.security?.allowed)) {\n this.allowed[schema] = addresses.map(toAddressesString)\n }\n }\n if (config?.security?.disallowed) {\n for (const [schema, addresses] of Object.entries(config.security?.disallowed)) {\n this.disallowed[schema] = addresses.map(toAddressesString)\n }\n }\n this.hasAllowedRules = Object.keys(this.allowed).length > 0\n this.hasDisallowedRules = Object.keys(this.disallowed).length > 0\n this.hasRules = this.hasAllowedRules || this.hasDisallowedRules\n }\n\n queryable: Queryable = async (query, payloads) => {\n if (!this.hasRules) return true\n const addresses = query.addresses\n if (addresses.length === 0) return false\n const wrapper = await QueryBoundWitnessWrapper.parseQuery<ModuleQueries>(query, payloads)\n const schema = (await wrapper.getQuery()).schema\n return this.queryAllowed(schema, addresses) && !this.queryDisallowed(schema, addresses)\n }\n\n protected queryAllowed = (schema: Schema, addresses: Address[]): boolean => {\n if (!this.hasAllowedRules) return true\n // All cosigners must sign\n if (addresses.length > 1) {\n const signatories = toAddressesString(addresses)\n const validCosigners = this.allowed?.[schema]?.includes(signatories)\n if (validCosigners) return true\n }\n // OR all signers have to be allowed individually\n return addresses.every((address) => this.allowed?.[schema]?.includes(address) || false)\n }\n protected queryDisallowed = (schema: Schema, addresses: string[]): boolean => {\n if (!this.hasDisallowedRules) return false\n return addresses.some((address) => this.disallowed?.[schema]?.includes(address))\n }\n}\n\n// TODO: Handle 0x prefix\nconst toAddressesString = (addresses: string | CosigningAddressSet): SortedPipedAddressesString => {\n return Array.isArray(addresses) ?\n addresses\n .sort()\n .map((address) => address.toLowerCase())\n .join(delimiter)\n : addresses.toLowerCase()\n}\n","import { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { Module, ModuleQueries } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nimport { Queryable, QueryValidator } from './QueryValidator'\n\nexport const isQuerySupportedByModule = async <T extends QueryBoundWitness = QueryBoundWitness>(\n mod: Module,\n query: T,\n payloads?: Payload[],\n): Promise<boolean> => {\n const wrapper = await QueryBoundWitnessWrapper.parseQuery<ModuleQueries>(query, payloads)\n const schema = (await wrapper.getQuery()).schema\n return mod.queries.includes(schema)\n}\n\nexport class SupportedQueryValidator implements QueryValidator {\n constructor(protected readonly mod: Module) {}\n queryable: Queryable = (query, payloads) => {\n return isQuerySupportedByModule(this.mod, query, payloads)\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { ModuleManifestPayload } from '@xyo-network/manifest-model'\nimport { AddressPreviousHashPayload, Module, ModuleDescriptionPayload, ModuleEventData, ModuleParams } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nimport { AbstractModule } from './AbstractModule'\n\nexport abstract class AbstractModuleInstance<TParams extends ModuleParams = ModuleParams, TEventData extends ModuleEventData = ModuleEventData>\n extends AbstractModule<TParams, TEventData>\n implements Module<TParams, TEventData>\n{\n constructor(privateConstructorKey: string, params: TParams, account: AccountInstance) {\n assertEx(AbstractModule.privateConstructorKey === privateConstructorKey, 'Use create function instead of constructor')\n // Clone params to prevent mutation of the incoming object\n const mutatedParams = { ...params } as TParams\n super(privateConstructorKey, mutatedParams, account)\n this.upResolver.add(this)\n this.downResolver.add(this)\n }\n\n describe(): Promise<ModuleDescriptionPayload> {\n this._checkDead()\n return this.busy(async () => {\n return await this.describeHandler()\n })\n }\n\n discover(): Promise<Payload[]> {\n this._checkDead()\n return this.busy(async () => {\n return await this.discoverHandler()\n })\n }\n\n manifest(maxDepth?: number, ignoreAddresses?: string[]): Promise<ModuleManifestPayload> {\n this._checkDead()\n return this.busy(async () => {\n return await this.manifestHandler(maxDepth, ignoreAddresses)\n })\n }\n\n moduleAddress(): Promise<AddressPreviousHashPayload[]> {\n this._checkDead()\n return this.busy(async () => {\n return await this.moduleAddressHandler()\n })\n }\n\n state() {\n this._checkDead()\n return this.busy(async () => {\n return await this.stateHandler()\n })\n }\n\n subscribe(_queryAccount?: AccountInstance) {\n this._checkDead()\n return this.subscribeHandler()\n }\n}\n"],"mappings":"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","names":["import_assert","import_object","import_account","import_boundwitness_wrapper","import_payload_builder","BaseEmitter","Base","eventData","events","constructor","params","Events","clearListeners","eventNames","emit","eventName","eventArgs","emitSerial","listenerCount","off","listener","offAny","on","onAny","once","isDetermineAccountFromAccountParams","params","assertEx","accountPath","account","isDetermineAccountFromWalletParams","wallet","determineAccount","allowRandomAccount","Account","randomSync","derivePath","console","warn","ModuleErrorBuilder","PayloadBuilder","_message","_name","_query","_sources","constructor","schema","ModuleErrorSchema","build","fields","message","name","query","sources","delimiter","ModuleConfigQueryValidator","allowed","disallowed","hasAllowedRules","hasDisallowedRules","hasRules","constructor","config","security","schema","addresses","Object","entries","map","toAddressesString","keys","length","queryable","query","payloads","wrapper","QueryBoundWitnessWrapper","parseQuery","getQuery","queryAllowed","queryDisallowed","signatories","validCosigners","includes","every","address","_a","_b","some","Array","isArray","sort","toLowerCase","join","import_boundwitness_wrapper","isQuerySupportedByModule","mod","query","payloads","wrapper","QueryBoundWitnessWrapper","parseQuery","schema","getQuery","queries","includes","SupportedQueryValidator","constructor","queryable","AbstractModule","BaseEmitter","downResolver","CompositeModuleResolver","upResolver","_account","undefined","_baseModuleQueryAccountPaths","ModuleAddressQuerySchema","ModuleDescribeQuerySchema","ModuleDiscoverQuerySchema","ModuleManifestQuerySchema","ModuleStateQuerySchema","ModuleSubscribeQuerySchema","_lastError","_queryAccounts","_startPromise","_started","moduleConfigQueryValidator","supportedQueryValidator","_busyCount","_status","constructor","privateConstructorKey","params","account","assertEx","mutatedParams","SupportedQueryValidator","queryable","ModuleConfigQueryValidator","config","configSchema","configSchemas","address","allowAnonymous","security","dead","status","ephemeralQueryAccountEnabled","id","name","queries","queryAccountPaths","_queryAccountPaths","queryAccounts","timestamp","baseModuleQueryAccountPaths","logger","defaultLogger","Base","value","_getRootFunction","funcName","anyThis","__proto__","_noOverride","functionName","thisFunc","rootFunc","create","length","Error","schema","isModuleName","allowedSchemas","includes","JSON","stringify","mutatedConfig","debug","activeLogger","generatedAccount","determineAccount","IdLogger","newModule","enableLazyLoad","start","allowRandomAccount","factory","ModuleFactory","withParams","busy","closure","args","module","emit","eventName","eventArgs","previousHash","_checkDead","query","payloads","queryConfig","sourceQuery","PayloadBuilder","build","QueryBoundWitnessWrapper","unwrap","resultPayloads","errorPayloads","queryAccount","Account","randomSync","started","addresses","push","queryHandler","ex","handleErrorAsync","error","ModuleErrorBuilder","sources","$hash","message","Date","now","result","bindQueryResult","configValidator","Object","assign","validators","every","validator","resolve","idOrFilter","required","options","childOptions","direction","up","down","filter","duplicateModules","Array","isArray","warn","log","_timeout","startHandler","notStartedAction","tryStart","handleError","_a","stop","stopHandler","DeadModuleError","bindHashes","hashes","promise","PromiseEx","bindHashesInternal","builder","BoundWitnessBuilder","witness","bindQuery","bindQueryInternal","QueryBoundWitnessBuilder","additionalWitnesses","errors","queryWitnessAccount","witnesses","exists","Promise","all","map","payload","archiving","storeToArchivists","flat","describeHandler","description","ModuleDescriptionSchema","discover","discoverHandler","children","compact","AddressSchema","_maxDepth","fields","QuerySchema","ConfigSchema","getArchivist","archivist","resolved","asArchivistInstance","initializeQueryAccounts","paths","values","distinctPaths","Set","size","wallet","derivePath","key","prototype","hasOwnProperty","call","queryAccountPath","manifestHandler","_depth","_ignoreAddresses","ModuleManifestPayloadSchema","moduleAddressHandler","entries","AddressPreviousHashSchema","moduleAccount","moduleAccountPreviousHash","wrapper","parseQuery","queryPayload","getQuery","maxDepth","stateHandler","subscribeHandler","resolveArchivingArchivists","archivists","mod","validateConfig","insert","bw","parents","reduce","valid","join","serializableField","ConsoleLogger","LogLevel","toString","import_assert","AbstractModuleInstance","AbstractModule","constructor","privateConstructorKey","params","account","assertEx","mutatedParams","upResolver","add","downResolver","describe","_checkDead","busy","describeHandler","discover","discoverHandler","manifest","maxDepth","ignoreAddresses","manifestHandler","moduleAddress","moduleAddressHandler","state","stateHandler","subscribe","_queryAccount","subscribeHandler"]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/AbstractModule.ts","../../src/BaseEmitter.ts","../../src/determineAccount.ts","../../src/Error.ts","../../src/QueryValidator/ModuleConfigQueryValidator.ts","../../src/QueryValidator/SupportedQueryValidator.ts","../../src/AbstractModuleInstance.ts"],"sourcesContent":["export * from './AbstractModule'\nexport * from './AbstractModuleInstance'\nexport * from './BaseEmitter'\nexport * from './Error'\nexport * from './QueryValidator'\n","/* eslint-disable complexity */\n/* eslint-disable max-lines */\nimport { assertEx } from '@xylabs/assert'\nimport { handleError, handleErrorAsync } from '@xylabs/error'\nimport { exists } from '@xylabs/exists'\nimport { Address, Hash } from '@xylabs/hex'\nimport { compact } from '@xylabs/lodash'\nimport { ConsoleLogger, IdLogger, Logger, LogLevel } from '@xylabs/logger'\nimport { Base } from '@xylabs/object'\nimport { Promisable, PromiseEx } from '@xylabs/promise'\nimport { Account, HDWallet } from '@xyo-network/account'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { AddressPayload, AddressSchema } from '@xyo-network/address-payload-plugin'\nimport { ArchivistInstance, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitnessBuilder, QueryBoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { ConfigPayload, ConfigSchema } from '@xyo-network/config-payload-plugin'\nimport { ModuleManifestPayload, ModuleManifestPayloadSchema } from '@xyo-network/manifest-model'\nimport {\n AddressPreviousHashPayload,\n AddressPreviousHashSchema,\n CreatableModule,\n CreatableModuleFactory,\n DeadModuleError,\n duplicateModules,\n isModuleName,\n Module,\n ModuleAddressQuerySchema,\n ModuleBusyEventArgs,\n ModuleConfig,\n ModuleDescribeQuerySchema,\n ModuleDescriptionPayload,\n ModuleDescriptionSchema,\n ModuleDiscoverQuerySchema,\n ModuleEventData,\n ModuleFactory,\n ModuleFilter,\n ModuleFilterOptions,\n ModuleIdentifier,\n ModuleInstance,\n ModuleManifestQuerySchema,\n ModuleParams,\n ModuleQueriedEventArgs,\n ModuleQueries,\n ModuleQueryHandlerResult,\n ModuleQueryResult,\n ModuleStateQuerySchema,\n ModuleStatus,\n ModuleSubscribeQuerySchema,\n serializableField,\n} from '@xyo-network/module-model'\nimport { CompositeModuleResolver } from '@xyo-network/module-resolver'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { ModuleError, Payload, Query, Schema, WithMeta } from '@xyo-network/payload-model'\nimport { QueryPayload, QuerySchema } from '@xyo-network/query-payload-plugin'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nimport { BaseEmitter } from './BaseEmitter'\nimport { determineAccount } from './determineAccount'\nimport { ModuleErrorBuilder } from './Error'\nimport { ModuleConfigQueryValidator, Queryable, SupportedQueryValidator } from './QueryValidator'\n\nexport abstract class AbstractModule<TParams extends ModuleParams = ModuleParams, TEventData extends ModuleEventData = ModuleEventData>\n extends BaseEmitter<TParams, TEventData>\n implements Module<TParams, TEventData>\n{\n static readonly allowRandomAccount: boolean = true\n static configSchemas: string[]\n static override defaultLogger: Logger = new ConsoleLogger(LogLevel.log)\n static enableLazyLoad = false\n\n protected static privateConstructorKey = Date.now().toString()\n\n readonly downResolver = new CompositeModuleResolver()\n readonly upResolver = new CompositeModuleResolver()\n\n protected _account: AccountInstance | undefined = undefined\n protected readonly _baseModuleQueryAccountPaths: Record<ModuleQueries['schema'], string> = {\n [ModuleAddressQuerySchema]: '1',\n [ModuleDescribeQuerySchema]: '4',\n [ModuleDiscoverQuerySchema]: '2',\n [ModuleManifestQuerySchema]: '5',\n [ModuleStateQuerySchema]: '6',\n [ModuleSubscribeQuerySchema]: '3',\n }\n protected _lastError?: Error\n protected readonly _queryAccounts: Record<ModuleQueries['schema'], AccountInstance | undefined> = {\n [ModuleAddressQuerySchema]: undefined,\n [ModuleDescribeQuerySchema]: undefined,\n [ModuleDiscoverQuerySchema]: undefined,\n [ModuleManifestQuerySchema]: undefined,\n [ModuleStateQuerySchema]: undefined,\n [ModuleSubscribeQuerySchema]: undefined,\n }\n protected _startPromise: Promisable<boolean> | undefined = undefined\n protected _started: Promisable<boolean> | undefined = undefined\n protected readonly moduleConfigQueryValidator: Queryable\n protected readonly supportedQueryValidator: Queryable\n\n private _busyCount = 0\n private _status: ModuleStatus = 'stopped'\n\n constructor(privateConstructorKey: string, params: TParams, account: AccountInstance) {\n assertEx(AbstractModule.privateConstructorKey === privateConstructorKey, () => 'Use create function instead of constructor')\n // Clone params to prevent mutation of the incoming object\n const mutatedParams = { ...params } as TParams\n super(mutatedParams)\n\n this._account = account\n\n this.supportedQueryValidator = new SupportedQueryValidator(this as Module).queryable\n this.moduleConfigQueryValidator = new ModuleConfigQueryValidator(mutatedParams?.config).queryable\n }\n\n static get configSchema(): string {\n return this.configSchemas[0]\n }\n\n get account() {\n return assertEx(this._account, () => 'Missing account')\n }\n\n get address() {\n return this.account.address\n }\n\n get allowAnonymous() {\n return !!this.config.security?.allowAnonymous\n }\n\n get config(): TParams['config'] {\n return this.params.config\n }\n\n get dead() {\n return this.status === 'dead'\n }\n\n get ephemeralQueryAccountEnabled(): boolean {\n return !!this.params.ephemeralQueryAccountEnabled\n }\n\n get id() {\n return this.config.name ?? this.address\n }\n\n get queries(): string[] {\n return [\n ModuleDiscoverQuerySchema,\n ModuleAddressQuerySchema,\n ModuleSubscribeQuerySchema,\n ModuleDescribeQuerySchema,\n ModuleManifestQuerySchema,\n ModuleStateQuerySchema,\n ]\n }\n\n get queryAccountPaths(): Readonly<Record<Query['schema'], string | undefined>> {\n return { ...this._baseModuleQueryAccountPaths, ...this._queryAccountPaths }\n }\n\n get queryAccounts(): Readonly<Record<Query['schema'], AccountInstance | undefined>> {\n return this._queryAccounts\n }\n\n get status() {\n return this._status\n }\n\n get timestamp() {\n return this.config.timestamp ?? false\n }\n\n protected get baseModuleQueryAccountPaths(): Record<ModuleQueries['schema'], string> {\n return this._baseModuleQueryAccountPaths\n }\n\n protected override get logger() {\n return this.params?.logger ?? AbstractModule.defaultLogger ?? Base.defaultLogger\n }\n\n protected set status(value: ModuleStatus) {\n if (this._status !== 'dead') {\n this._status = value\n }\n }\n\n protected abstract get _queryAccountPaths(): Record<Query['schema'], string>\n\n static _getRootFunction(funcName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let anyThis = this as any\n while (anyThis.__proto__[funcName]) {\n anyThis = anyThis.__proto__\n }\n return anyThis[funcName]\n }\n\n static _noOverride(functionName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const thisFunc = (this as any)[functionName]\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const rootFunc = this._getRootFunction(functionName)\n assertEx(thisFunc === rootFunc, () => `Override not allowed for [${functionName}] - override ${functionName}Handler instead`)\n }\n\n static async create<TModule extends ModuleInstance>(\n this: CreatableModule<TModule>,\n params?: Omit<TModule['params'], 'config'> & { config?: TModule['params']['config'] },\n ) {\n this._noOverride('create')\n if (!this.configSchemas || this.configSchemas.length === 0) {\n throw new Error(`Missing configSchema [${params?.config?.schema}][${this.name}]`)\n }\n\n assertEx(params?.config?.name === undefined || isModuleName(params.config.name), () => `Invalid module name: ${params?.config?.name}`)\n\n const { account } = params ?? {}\n\n const schema: string = params?.config?.schema ?? this.configSchema\n const allowedSchemas: string[] = this.configSchemas\n\n assertEx(allowedSchemas.includes(schema), () => `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`)\n const mutatedConfig: TModule['params']['config'] = { ...params?.config, schema } as TModule['params']['config']\n params?.logger?.debug(`config: ${JSON.stringify(mutatedConfig, null, 2)}`)\n const mutatedParams: TModule['params'] = { ...params, config: mutatedConfig } as TModule['params']\n\n const activeLogger = params?.logger ?? AbstractModule.defaultLogger\n const generatedAccount = await AbstractModule.determineAccount({ account })\n const address = generatedAccount.address\n mutatedParams.logger = activeLogger ? new IdLogger(activeLogger, () => `0x${address}`) : undefined\n\n const newModule = new this(AbstractModule.privateConstructorKey, mutatedParams, generatedAccount)\n\n if (!AbstractModule.enableLazyLoad) {\n await newModule.start?.()\n }\n return newModule\n }\n\n static async determineAccount(params: {\n account?: AccountInstance | 'random'\n accountPath?: string\n wallet?: WalletInstance\n }): Promise<AccountInstance> {\n return await determineAccount(params, this.allowRandomAccount)\n }\n\n static factory<TModule extends ModuleInstance>(\n this: CreatableModule<TModule>,\n params?: Omit<TModule['params'], 'config'> & { config?: TModule['params']['config'] },\n ): CreatableModuleFactory<TModule> {\n return ModuleFactory.withParams(this, params)\n }\n\n _getRootFunction(funcName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let anyThis = this as any\n while (anyThis.__proto__[funcName]) {\n anyThis = anyThis.__proto__\n }\n return anyThis[funcName]\n }\n\n async busy<R>(closure: () => Promise<R>) {\n if (this._busyCount <= 0) {\n this._busyCount = 0\n const args: ModuleBusyEventArgs = { busy: true, module: this }\n await this.emit('moduleBusy', args)\n }\n this._busyCount++\n try {\n return await closure()\n } finally {\n this._busyCount--\n if (this._busyCount <= 0) {\n this._busyCount = 0\n const args: ModuleBusyEventArgs = { busy: false, module: this }\n await this.emit('moduleBusy', args)\n }\n }\n }\n\n override emit<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return super.emit(eventName, eventArgs)\n }\n\n previousHash(): Promisable<string | undefined> {\n this._checkDead()\n return this.account.previousHash\n }\n\n async query<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryResult> {\n this._checkDead()\n this._noOverride('query')\n const sourceQuery = await PayloadBuilder.build(assertEx(QueryBoundWitnessWrapper.unwrap(query), () => 'Invalid query'))\n return await this.busy(async () => {\n const resultPayloads: Payload[] = []\n const errorPayloads: ModuleError[] = []\n const queryAccount = this.ephemeralQueryAccountEnabled ? Account.randomSync() : undefined\n try {\n await this.started('throw')\n if (!this.allowAnonymous && query.addresses.length === 0) {\n throw new Error(`Anonymous Queries not allowed, but running anyway [${this.config.name}], [${this.address}]`)\n }\n if (queryConfig?.allowedQueries) {\n assertEx(queryConfig?.allowedQueries.includes(sourceQuery.schema), () => `Query not allowed [${sourceQuery.schema}]`)\n }\n resultPayloads.push(...(await this.queryHandler(sourceQuery, payloads, queryConfig)))\n } catch (ex) {\n await handleErrorAsync(ex, async (error) => {\n this._lastError = error\n this.status = 'dead'\n errorPayloads.push(\n await new ModuleErrorBuilder()\n .sources([sourceQuery.$hash])\n .name(this.config.name ?? '<Unknown>')\n .query(sourceQuery.schema)\n .message(error.message)\n .build(),\n )\n })\n }\n if (this.timestamp) {\n const timestamp = { schema: 'network.xyo.timestamp', timestamp: Date.now() }\n resultPayloads.push(timestamp)\n }\n const result = await this.bindQueryResult(sourceQuery, resultPayloads, queryAccount ? [queryAccount] : [], errorPayloads)\n const args: ModuleQueriedEventArgs = { module: this, payloads, query: sourceQuery, result }\n await this.emit('moduleQueried', args)\n return result\n })\n }\n\n async queryable<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<boolean> {\n if (this.dead) {\n return false\n }\n if (!(await this.started('warn'))) return false\n const configValidator =\n queryConfig ? new ModuleConfigQueryValidator(Object.assign({}, this.config, queryConfig)).queryable : this.moduleConfigQueryValidator\n const validators = [this.supportedQueryValidator, configValidator]\n\n return validators.every((validator) => validator(query, payloads))\n }\n\n /** @deprecated do not pass undefined. If trying to get all, pass '*' */\n async resolve(): Promise<ModuleInstance[]>\n async resolve<T extends ModuleInstance = ModuleInstance>(all: '*', options?: ModuleFilterOptions<T>): Promise<T[]>\n async resolve<T extends ModuleInstance = ModuleInstance>(filter: ModuleFilter, options?: ModuleFilterOptions<T>): Promise<T[]>\n async resolve<T extends ModuleInstance = ModuleInstance>(id: ModuleIdentifier, options?: ModuleFilterOptions<T>): Promise<T | undefined>\n /** @deprecated use '*' if trying to resolve all */\n async resolve<T extends ModuleInstance = ModuleInstance>(filter?: ModuleFilter, options?: ModuleFilterOptions<T>): Promise<T[]>\n async resolve<T extends ModuleInstance = ModuleInstance>(\n idOrFilter: ModuleFilter<T> | ModuleIdentifier = '*',\n { required = 'log', ...options }: ModuleFilterOptions<T> = {},\n ): Promise<T | T[] | undefined> {\n const childOptions = { ...options, required: false }\n const direction = options?.direction ?? 'all'\n const up = direction === 'up' || direction === 'all'\n const down = direction === 'down' || direction === 'all'\n let result: T | T[] | undefined\n if (idOrFilter === '*') {\n if (this.dead) {\n return []\n }\n return [\n ...(down ? await (this.downResolver as CompositeModuleResolver).resolve<T>('*', childOptions) : []),\n ...(up ? await (this.upResolver as CompositeModuleResolver).resolve<T>('*', childOptions) : []),\n ].filter(duplicateModules)\n } else {\n switch (typeof idOrFilter) {\n case 'string': {\n if (this.dead) {\n return undefined\n }\n result =\n (down ? await (this.downResolver as CompositeModuleResolver).resolve<T>(idOrFilter, childOptions) : undefined) ??\n (up ? await (this.upResolver as CompositeModuleResolver).resolve<T>(idOrFilter, childOptions) : undefined)\n break\n }\n default: {\n if (this.dead) {\n return []\n }\n const filter: ModuleFilter<T> | undefined = idOrFilter\n result = [\n ...(down ? await (this.downResolver as CompositeModuleResolver).resolve<T>(filter, childOptions) : []),\n ...(up ? await (this.upResolver as CompositeModuleResolver).resolve<T>(filter, childOptions) : []),\n ].filter(duplicateModules)\n break\n }\n }\n }\n this.validateRequiredResolve(required, result, idOrFilter)\n return result\n }\n\n start(_timeout?: number): Promisable<boolean> {\n //using promise as mutex\n this._startPromise = this._startPromise ?? this.startHandler()\n const result = this._startPromise\n this.status = result ? 'started' : 'dead'\n return result\n }\n\n async started(notStartedAction: 'error' | 'throw' | 'warn' | 'log' | 'none' = 'log', tryStart = true): Promise<boolean> {\n const started = await this._started\n if (started === true) {\n return true\n }\n if (!started) {\n //using promise as mutex\n this._started = (async () => {\n if (tryStart) {\n try {\n await this.start()\n return true\n } catch (ex) {\n handleError(ex, (error) => {\n this.logger?.warn(`Autostart of Module Failed: ${error.message})`)\n this._started = undefined\n })\n }\n }\n switch (notStartedAction) {\n case 'throw': {\n throw new Error(`Module not Started [${this.address}]`)\n }\n case 'warn': {\n this.logger?.warn('Module not started')\n break\n }\n case 'error': {\n this.logger?.error('Module not started')\n break\n }\n case 'none': {\n break\n }\n default: {\n this.logger?.log('Module not started')\n break\n }\n }\n return false\n })()\n }\n if (!this._started) {\n throw 'Failed to create start promise'\n }\n return await this._started\n }\n\n async stop(_timeout?: number): Promise<boolean> {\n return await this.busy(async () => {\n const result = await this.stopHandler()\n this._started = undefined\n this._startPromise = undefined\n this.status = result ? 'stopped' : 'dead'\n return result\n })\n }\n\n protected _checkDead() {\n if (this.dead) {\n throw new DeadModuleError(this.id, this._lastError)\n }\n }\n\n protected _noOverride(functionName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const thisFunc = (this as any)[functionName]\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const rootFunc = this._getRootFunction(functionName)\n assertEx(thisFunc === rootFunc, () => `Override not allowed for [${functionName}] - override ${functionName}Handler instead`)\n }\n\n protected bindHashes(hashes: Hash[], schema: Schema[], account?: AccountInstance) {\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n const promise = new PromiseEx((resolve) => {\n const result = this.bindHashesInternal(hashes, schema, account)\n resolve?.(result)\n return result\n }, account)\n return promise\n }\n\n protected async bindHashesInternal(hashes: Hash[], schema: Schema[], account?: AccountInstance): Promise<BoundWitness> {\n const builder = new BoundWitnessBuilder().hashes(hashes, schema).witness(this.account)\n const result = (await (account ? builder.witness(account) : builder).build())[0]\n this.logger?.debug(`result: ${JSON.stringify(result, null, 2)}`)\n return result\n }\n\n protected bindQuery<T extends Query>(\n query: T,\n payloads?: Payload[],\n account?: AccountInstance,\n ): PromiseEx<[WithMeta<QueryBoundWitness>, WithMeta<Payload>[], WithMeta<Payload>[]], AccountInstance> {\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n const promise = new PromiseEx<[WithMeta<QueryBoundWitness>, WithMeta<Payload>[], WithMeta<Payload>[]], AccountInstance>(async (resolve) => {\n const result = await this.bindQueryInternal(query, payloads, account)\n resolve?.(result)\n return result\n }, account)\n return promise\n }\n\n protected async bindQueryInternal<T extends Query>(\n query: T,\n payloads?: Payload[],\n account?: AccountInstance,\n ): Promise<[WithMeta<QueryBoundWitness>, WithMeta<Payload>[], WithMeta<Payload>[]]> {\n const builder = await (await new QueryBoundWitnessBuilder().payloads(payloads)).witness(this.account).query(query)\n const result = await (account ? builder.witness(account) : builder).build()\n return result\n }\n\n protected async bindQueryResult<T extends Query>(\n query: WithMeta<T>,\n payloads: Payload[],\n additionalWitnesses: AccountInstance[] = [],\n errors?: ModuleError[],\n ): Promise<ModuleQueryResult> {\n const builder = (await (await new BoundWitnessBuilder().payloads(payloads)).errors(errors)).sourceQuery(query.$hash)\n const queryWitnessAccount = this.queryAccounts[query.schema as ModuleQueries['schema']]\n const witnesses = [this.account, queryWitnessAccount, ...additionalWitnesses].filter(exists)\n builder.witnesses(witnesses)\n const result: ModuleQueryResult = [\n (await builder.build())[0],\n await Promise.all(payloads.map((payload) => PayloadBuilder.build(payload))),\n await Promise.all((errors ?? [])?.map((error) => PayloadBuilder.build(error))),\n ]\n if (this.config.archiving) {\n await this.storeToArchivists(result.flat())\n }\n return result\n }\n\n protected async describeHandler(): Promise<ModuleDescriptionPayload> {\n const description: ModuleDescriptionPayload = {\n address: this.address,\n queries: this.queries,\n schema: ModuleDescriptionSchema,\n }\n if (this.config?.name) {\n description.name = this.config.name\n }\n\n const discover = await this.discoverHandler()\n\n description.children = compact(\n discover?.map((payload) => {\n const address = payload.schema === AddressSchema ? (payload as AddressPayload).address : undefined\n return address == this.address ? undefined : address\n }) ?? [],\n )\n\n return description\n }\n\n protected async discoverHandler(_maxDepth?: number): Promise<Payload[]> {\n const config = this.config\n const address = await new PayloadBuilder<AddressPayload>({ schema: AddressSchema })\n .fields({ address: this.address, name: this.config?.name })\n .build()\n const queries = await Promise.all(\n this.queries.map(async (query) => {\n return await new PayloadBuilder<QueryPayload>({ schema: QuerySchema }).fields({ query }).build()\n }),\n )\n const configSchema: ConfigPayload = {\n config: config.schema,\n schema: ConfigSchema,\n }\n return compact([config, configSchema, address, ...queries])\n }\n\n protected async getArchivist(): Promise<ArchivistInstance | undefined> {\n if (!this.config.archivist) return undefined\n const resolved = await this.upResolver.resolve(this.config.archivist)\n return asArchivistInstance(resolved)\n }\n\n protected async initializeQueryAccounts() {\n // Ensure distinct/unique wallet paths\n const paths = Object.values(this.queryAccountPaths).filter(exists)\n const distinctPaths = new Set<string>(paths)\n assertEx(distinctPaths.size === paths.length, () => `${this.config?.name ? this.config.name + ': ' : ''}Duplicate query account paths`)\n // Create an account for query this module supports\n const wallet = this.account as unknown as HDWallet\n if (wallet?.derivePath) {\n for (const key in this.queryAccountPaths) {\n if (Object.prototype.hasOwnProperty.call(this.queryAccountPaths, key)) {\n const query = key as ModuleQueries['schema']\n const queryAccountPath = this.queryAccountPaths[query]\n if (queryAccountPath) {\n this._queryAccounts[query] = await wallet.derivePath?.(queryAccountPath)\n }\n }\n }\n }\n }\n\n protected manifestHandler(_depth?: number, _ignoreAddresses?: Address[]): Promisable<ModuleManifestPayload> {\n const name = this.config.name ?? 'Anonymous'\n return { config: { name, ...this.config }, schema: ModuleManifestPayloadSchema, status: { address: this.address } }\n }\n\n protected moduleAddressHandler(): Promisable<AddressPreviousHashPayload[]> {\n // Return array of all addresses and their previous hash\n const queryAccounts = Object.entries(this.queryAccounts)\n .filter((value): value is [string, AccountInstance] => {\n return exists(value[1])\n })\n .map(([name, account]) => {\n const address = account.address\n const previousHash = account.previousHash\n return [\n { address, name, schema: AddressSchema },\n { address, previousHash, schema: AddressPreviousHashSchema },\n ]\n })\n const address = this.address\n const name = this.config.name\n const previousHash = this.address\n const moduleAccount = name ? { address, name, schema: AddressSchema } : { address, schema: AddressSchema }\n const moduleAccountPreviousHash =\n previousHash ? { address, previousHash, schema: AddressPreviousHashSchema } : { address, schema: AddressPreviousHashSchema }\n return [moduleAccount, moduleAccountPreviousHash, ...queryAccounts].flat()\n }\n\n protected async queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryHandlerResult> {\n await this.started('throw')\n const wrapper = await QueryBoundWitnessWrapper.parseQuery<ModuleQueries>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(await this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n switch (queryPayload.schema) {\n case ModuleManifestQuerySchema: {\n resultPayloads.push(await this.manifestHandler(queryPayload.maxDepth))\n break\n }\n case ModuleDiscoverQuerySchema: {\n const { maxDepth } = queryPayload\n resultPayloads.push(...(await this.discoverHandler(maxDepth)))\n break\n }\n case ModuleDescribeQuerySchema: {\n resultPayloads.push(await this.describeHandler())\n break\n }\n case ModuleAddressQuerySchema: {\n resultPayloads.push(...(await this.moduleAddressHandler()))\n break\n }\n case ModuleStateQuerySchema: {\n resultPayloads.push(...(await this.stateHandler()))\n break\n }\n case ModuleSubscribeQuerySchema: {\n this.subscribeHandler()\n break\n }\n default: {\n throw new Error(`Unsupported Query [${(queryPayload as Payload).schema}]`)\n }\n }\n return resultPayloads\n }\n\n protected async resolveArchivingArchivists(): Promise<ArchivistInstance[]> {\n const archivists = this.config.archiving?.archivists\n if (!archivists) return []\n const resolved = await Promise.all(archivists.map((archivist) => this.resolve(archivist)))\n return compact(resolved.map((mod) => asArchivistInstance(mod)))\n }\n\n protected async startHandler(): Promise<boolean> {\n this.validateConfig()\n await this.initializeQueryAccounts()\n this._started = true\n return true\n }\n\n protected async stateHandler(): Promise<Payload[]> {\n return [await this.manifestHandler(), ...(await this.discoverHandler()), await this.describeHandler()]\n }\n\n protected stopHandler(_timeout?: number): Promisable<boolean> {\n this._started = undefined\n return true\n }\n\n protected async storeToArchivists(payloads: Payload[]): Promise<Payload[]> {\n const archivists = await this.resolveArchivingArchivists()\n return (\n await Promise.all(\n archivists.map((archivist) => {\n return archivist.insert?.(payloads)\n }),\n )\n ).map(([bw]) => bw)\n }\n\n protected subscribeHandler() {\n return\n }\n\n protected validateConfig(config?: unknown, parents: string[] = []): boolean {\n // eslint-disable-next-line unicorn/no-array-reduce\n return Object.entries(config ?? this.config ?? {}).reduce((valid, [key, value]) => {\n switch (typeof value) {\n case 'function': {\n this.logger?.warn(`Fields of type function not allowed in config [${parents?.join('.')}.${key}]`)\n return false\n }\n case 'object': {\n if (Array.isArray(value)) {\n return (\n // eslint-disable-next-line unicorn/no-array-reduce\n value.reduce((valid, value) => {\n return this.validateConfig(value, [...parents, key]) && valid\n }, true) && valid\n )\n }\n\n if (!serializableField(value)) {\n this.logger?.warn(`Fields that are not serializable to JSON are not allowed in config [${parents?.join('.')}.${key}]`)\n return false\n }\n return value ? this.validateConfig(value, [...parents, key]) && valid : true\n }\n default: {\n return valid\n }\n }\n }, true)\n }\n\n private validateRequiredResolve(\n required: boolean | 'warn' | 'log',\n result: ModuleInstance[] | ModuleInstance | undefined,\n idOrFilter: ModuleIdentifier | ModuleFilter,\n ) {\n if (required && (result === undefined || (Array.isArray(result) && result.length > 0))) {\n switch (required) {\n case 'warn': {\n this.logger.warn('resolve failed', idOrFilter)\n break\n }\n case 'log': {\n this.logger.log('resolve failed', idOrFilter)\n break\n }\n default: {\n this.logger.error('resolve failed', idOrFilter)\n break\n }\n }\n }\n }\n}\n","import { Base, BaseParams } from '@xylabs/object'\nimport { EventAnyListener, EventData, EventFunctions, EventListener, Events } from '@xyo-network/module-events'\n\nexport class BaseEmitter<TParams extends BaseParams = BaseParams, TEventData extends EventData = EventData>\n extends Base<TParams>\n implements EventFunctions<TEventData>\n{\n //just here to query types\n eventData = {} as TEventData\n\n private events: Events<TEventData>\n\n constructor(params: TParams) {\n super(params)\n this.events = new Events<TEventData>()\n }\n\n clearListeners(eventNames: keyof TEventData | (keyof TEventData)[]) {\n return this.events.clearListeners(eventNames)\n }\n\n emit<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return this.events.emit(eventName, eventArgs)\n }\n\n emitSerial<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return this.events.emitSerial(eventName, eventArgs)\n }\n\n listenerCount(eventNames: keyof TEventData | (keyof TEventData)[]) {\n return this.events.listenerCount(eventNames)\n }\n\n off<TEventName extends keyof TEventData>(eventNames: TEventName | TEventName[], listener: EventListener<TEventData[TEventName]>) {\n return this.events.off(eventNames, listener)\n }\n\n offAny(listener: EventAnyListener) {\n return this.events.offAny(listener)\n }\n\n on<TEventName extends keyof TEventData>(eventNames: TEventName | TEventName[], listener: EventListener<TEventData[TEventName]>) {\n return this.events.on(eventNames, listener)\n }\n\n onAny(listener: EventAnyListener) {\n return this.events.onAny(listener)\n }\n\n once<TEventName extends keyof TEventData>(eventName: TEventName, listener: EventListener<TEventData[TEventName]>) {\n return this.events.once(eventName, listener)\n }\n}\n","/* eslint-disable max-lines */\nimport { assertEx } from '@xylabs/assert'\nimport { Account } from '@xyo-network/account'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nexport interface DetermineAccountFromAccountParams {\n account: AccountInstance | 'random'\n}\n\nexport interface DetermineAccountFromWalletParams {\n accountPath?: string\n wallet: WalletInstance\n}\n\nexport interface DetermineRandomParams {}\n\nexport type DetermineAccountParams = DetermineAccountFromAccountParams | DetermineAccountFromWalletParams | DetermineRandomParams\n\nconst isDetermineAccountFromAccountParams = (params: DetermineAccountParams): params is DetermineAccountFromAccountParams => {\n assertEx(!(params as DetermineAccountFromWalletParams).accountPath, () => 'accountPath may not be provided when account is provided')\n return !!(params as DetermineAccountFromAccountParams).account\n}\n\nconst isDetermineAccountFromWalletParams = (params: DetermineAccountParams): params is DetermineAccountFromWalletParams => {\n return !!(params as DetermineAccountFromWalletParams).wallet\n}\n\nexport async function determineAccount(params: DetermineAccountParams, allowRandomAccount = true): Promise<AccountInstance> {\n if (isDetermineAccountFromAccountParams(params)) {\n if (params.account === 'random') {\n assertEx(allowRandomAccount, () => 'Random address not allowed')\n return Account.randomSync()\n }\n return params.account\n }\n\n if (isDetermineAccountFromWalletParams(params)) {\n return assertEx(\n params.accountPath ? await params.wallet.derivePath(params.accountPath) : params.wallet,\n () => 'Failed to derive account from path',\n )\n }\n\n //this should eventually be removed/thrown\n console.warn('AbstractModule.determineAccount: No account or wallet provided - Creating Random account')\n return Account.randomSync()\n}\n","import { Hash } from '@xylabs/hex'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { ModuleError, ModuleErrorSchema, WithMeta } from '@xyo-network/payload-model'\n\nexport class ModuleErrorBuilder extends PayloadBuilder<ModuleError> {\n _message?: string\n _name?: string\n _query?: Hash\n _sources?: Hash[]\n constructor() {\n super({ schema: ModuleErrorSchema })\n }\n\n override build(): Promise<WithMeta<ModuleError>> {\n this.fields({\n message: this._message,\n name: this._name,\n query: this._query,\n schema: ModuleErrorSchema,\n sources: this._sources,\n })\n return super.build()\n }\n\n message(message: string) {\n this._message = message\n return this\n }\n\n name(name: string) {\n this._name = name\n return this\n }\n\n query(query: Hash) {\n this._query = query\n return this\n }\n\n sources(sources: Hash[]) {\n this._sources = sources\n return this\n }\n}\n","import { Address } from '@xylabs/hex'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { AnyConfigSchema, CosigningAddressSet, ModuleConfig, ModuleQueries } from '@xyo-network/module-model'\nimport { Schema } from '@xyo-network/payload-model'\n\nimport { Queryable, QueryValidator } from './QueryValidator'\n\nexport type SortedPipedAddressesString = string\n\nconst delimiter = ''\n\nexport class ModuleConfigQueryValidator<TConfig extends AnyConfigSchema<ModuleConfig>> implements QueryValidator {\n protected allowed: Record<Schema, SortedPipedAddressesString[]> = {}\n protected disallowed: Record<Schema, SortedPipedAddressesString[]> = {}\n protected readonly hasAllowedRules: boolean\n protected readonly hasDisallowedRules: boolean\n protected readonly hasRules: boolean\n\n constructor(config?: TConfig) {\n if (config?.security?.allowed) {\n for (const [schema, addresses] of Object.entries(config.security?.allowed)) {\n this.allowed[schema] = addresses.map(toAddressesString)\n }\n }\n if (config?.security?.disallowed) {\n for (const [schema, addresses] of Object.entries(config.security?.disallowed)) {\n this.disallowed[schema] = addresses.map(toAddressesString)\n }\n }\n this.hasAllowedRules = Object.keys(this.allowed).length > 0\n this.hasDisallowedRules = Object.keys(this.disallowed).length > 0\n this.hasRules = this.hasAllowedRules || this.hasDisallowedRules\n }\n\n queryable: Queryable = async (query, payloads) => {\n if (!this.hasRules) return true\n const addresses = query.addresses\n if (addresses.length === 0) return false\n const wrapper = await QueryBoundWitnessWrapper.parseQuery<ModuleQueries>(query, payloads)\n const schema = (await wrapper.getQuery()).schema\n return this.queryAllowed(schema, addresses) && !this.queryDisallowed(schema, addresses)\n }\n\n protected queryAllowed = (schema: Schema, addresses: Address[]): boolean => {\n if (!this.hasAllowedRules) return true\n // All cosigners must sign\n if (addresses.length > 1) {\n const signatories = toAddressesString(addresses)\n const validCosigners = this.allowed?.[schema]?.includes(signatories)\n if (validCosigners) return true\n }\n // OR all signers have to be allowed individually\n return addresses.every((address) => this.allowed?.[schema]?.includes(address) || false)\n }\n protected queryDisallowed = (schema: Schema, addresses: string[]): boolean => {\n if (!this.hasDisallowedRules) return false\n return addresses.some((address) => this.disallowed?.[schema]?.includes(address))\n }\n}\n\n// TODO: Handle 0x prefix\nconst toAddressesString = (addresses: string | CosigningAddressSet): SortedPipedAddressesString => {\n return Array.isArray(addresses) ?\n addresses\n .sort()\n .map((address) => address.toLowerCase())\n .join(delimiter)\n : addresses.toLowerCase()\n}\n","import { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { Module, ModuleQueries } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nimport { Queryable, QueryValidator } from './QueryValidator'\n\nexport const isQuerySupportedByModule = async <T extends QueryBoundWitness = QueryBoundWitness>(\n mod: Module,\n query: T,\n payloads?: Payload[],\n): Promise<boolean> => {\n const wrapper = await QueryBoundWitnessWrapper.parseQuery<ModuleQueries>(query, payloads)\n const schema = (await wrapper.getQuery()).schema\n return mod.queries.includes(schema)\n}\n\nexport class SupportedQueryValidator implements QueryValidator {\n constructor(protected readonly mod: Module) {}\n queryable: Queryable = (query, payloads) => {\n return isQuerySupportedByModule(this.mod, query, payloads)\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { Address } from '@xylabs/hex'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { ModuleManifestPayload } from '@xyo-network/manifest-model'\nimport { AddressPreviousHashPayload, Module, ModuleDescriptionPayload, ModuleEventData, ModuleParams } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nimport { AbstractModule } from './AbstractModule'\n\nexport abstract class AbstractModuleInstance<TParams extends ModuleParams = ModuleParams, TEventData extends ModuleEventData = ModuleEventData>\n extends AbstractModule<TParams, TEventData>\n implements Module<TParams, TEventData>\n{\n constructor(privateConstructorKey: string, params: TParams, account: AccountInstance) {\n assertEx(AbstractModule.privateConstructorKey === privateConstructorKey, () => 'Use create function instead of constructor')\n // Clone params to prevent mutation of the incoming object\n const mutatedParams = { ...params } as TParams\n super(privateConstructorKey, mutatedParams, account)\n this.upResolver.add(this)\n this.downResolver.add(this)\n }\n\n describe(): Promise<ModuleDescriptionPayload> {\n this._checkDead()\n return this.busy(async () => {\n return await this.describeHandler()\n })\n }\n\n discover(): Promise<Payload[]> {\n this._checkDead()\n return this.busy(async () => {\n return await this.discoverHandler()\n })\n }\n\n manifest(maxDepth?: number, ignoreAddresses?: Address[]): Promise<ModuleManifestPayload> {\n this._checkDead()\n return this.busy(async () => {\n return await this.manifestHandler(maxDepth, ignoreAddresses)\n })\n }\n\n moduleAddress(): Promise<AddressPreviousHashPayload[]> {\n this._checkDead()\n return this.busy(async () => {\n return await this.moduleAddressHandler()\n })\n }\n\n state() {\n this._checkDead()\n return this.busy(async () => {\n return await this.stateHandler()\n })\n }\n\n subscribe(_queryAccount?: AccountInstance) {\n this._checkDead()\n return this.subscribeHandler()\n }\n}\n"],"mappings":"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","names":["import_assert","import_object","import_account","import_boundwitness_wrapper","import_payload_builder","BaseEmitter","Base","eventData","events","constructor","params","Events","clearListeners","eventNames","emit","eventName","eventArgs","emitSerial","listenerCount","off","listener","offAny","on","onAny","once","isDetermineAccountFromAccountParams","params","assertEx","accountPath","account","isDetermineAccountFromWalletParams","wallet","determineAccount","allowRandomAccount","Account","randomSync","derivePath","console","warn","ModuleErrorBuilder","PayloadBuilder","_message","_name","_query","_sources","constructor","schema","ModuleErrorSchema","build","fields","message","name","query","sources","delimiter","ModuleConfigQueryValidator","allowed","disallowed","hasAllowedRules","hasDisallowedRules","hasRules","constructor","config","security","schema","addresses","Object","entries","map","toAddressesString","keys","length","queryable","query","payloads","wrapper","QueryBoundWitnessWrapper","parseQuery","getQuery","queryAllowed","queryDisallowed","signatories","validCosigners","includes","every","address","_a","_b","some","Array","isArray","sort","toLowerCase","join","import_boundwitness_wrapper","isQuerySupportedByModule","mod","query","payloads","wrapper","QueryBoundWitnessWrapper","parseQuery","schema","getQuery","queries","includes","SupportedQueryValidator","constructor","queryable","AbstractModule","BaseEmitter","downResolver","CompositeModuleResolver","upResolver","_account","undefined","_baseModuleQueryAccountPaths","ModuleAddressQuerySchema","ModuleDescribeQuerySchema","ModuleDiscoverQuerySchema","ModuleManifestQuerySchema","ModuleStateQuerySchema","ModuleSubscribeQuerySchema","_lastError","_queryAccounts","_startPromise","_started","moduleConfigQueryValidator","supportedQueryValidator","_busyCount","_status","constructor","privateConstructorKey","params","account","assertEx","mutatedParams","SupportedQueryValidator","queryable","ModuleConfigQueryValidator","config","configSchema","configSchemas","address","allowAnonymous","security","dead","status","ephemeralQueryAccountEnabled","id","name","queries","queryAccountPaths","_queryAccountPaths","queryAccounts","timestamp","baseModuleQueryAccountPaths","logger","defaultLogger","Base","value","_getRootFunction","funcName","anyThis","__proto__","_noOverride","functionName","thisFunc","rootFunc","create","length","Error","schema","isModuleName","_a","allowedSchemas","includes","JSON","stringify","mutatedConfig","debug","activeLogger","generatedAccount","determineAccount","IdLogger","newModule","enableLazyLoad","start","allowRandomAccount","factory","ModuleFactory","withParams","busy","closure","args","module","emit","eventName","eventArgs","previousHash","_checkDead","query","payloads","queryConfig","sourceQuery","PayloadBuilder","build","QueryBoundWitnessWrapper","unwrap","resultPayloads","errorPayloads","queryAccount","Account","randomSync","started","addresses","allowedQueries","push","queryHandler","ex","handleErrorAsync","error","ModuleErrorBuilder","sources","$hash","message","Date","now","result","bindQueryResult","configValidator","Object","assign","validators","every","validator","resolve","idOrFilter","required","options","childOptions","direction","up","down","filter","duplicateModules","validateRequiredResolve","_timeout","startHandler","notStartedAction","tryStart","handleError","warn","log","stop","stopHandler","DeadModuleError","bindHashes","hashes","promise","PromiseEx","bindHashesInternal","builder","BoundWitnessBuilder","witness","bindQuery","bindQueryInternal","QueryBoundWitnessBuilder","additionalWitnesses","errors","queryWitnessAccount","witnesses","exists","Promise","all","map","payload","archiving","storeToArchivists","flat","describeHandler","description","ModuleDescriptionSchema","discover","discoverHandler","children","compact","AddressSchema","_maxDepth","fields","QuerySchema","ConfigSchema","getArchivist","archivist","resolved","asArchivistInstance","initializeQueryAccounts","paths","values","distinctPaths","Set","size","wallet","derivePath","key","prototype","hasOwnProperty","call","queryAccountPath","manifestHandler","_depth","_ignoreAddresses","ModuleManifestPayloadSchema","moduleAddressHandler","entries","AddressPreviousHashSchema","moduleAccount","moduleAccountPreviousHash","wrapper","parseQuery","queryPayload","getQuery","maxDepth","stateHandler","subscribeHandler","resolveArchivingArchivists","archivists","mod","validateConfig","insert","bw","parents","reduce","valid","join","Array","isArray","serializableField","ConsoleLogger","LogLevel","toString","import_assert","AbstractModuleInstance","AbstractModule","constructor","privateConstructorKey","params","account","assertEx","mutatedParams","upResolver","add","downResolver","describe","_checkDead","busy","describeHandler","discover","discoverHandler","manifest","maxDepth","ignoreAddresses","manifestHandler","moduleAddress","moduleAddressHandler","state","stateHandler","subscribe","_queryAccount","subscribeHandler"]}
@@ -72,7 +72,7 @@ var BaseEmitter = _BaseEmitter;
72
72
  import { assertEx } from "@xylabs/assert";
73
73
  import { Account } from "@xyo-network/account";
74
74
  var isDetermineAccountFromAccountParams = /* @__PURE__ */ __name((params) => {
75
- assertEx(!params.accountPath, "accountPath may not be provided when account is provided");
75
+ assertEx(!params.accountPath, () => "accountPath may not be provided when account is provided");
76
76
  return !!params.account;
77
77
  }, "isDetermineAccountFromAccountParams");
78
78
  var isDetermineAccountFromWalletParams = /* @__PURE__ */ __name((params) => {
@@ -81,13 +81,13 @@ var isDetermineAccountFromWalletParams = /* @__PURE__ */ __name((params) => {
81
81
  async function determineAccount(params, allowRandomAccount = true) {
82
82
  if (isDetermineAccountFromAccountParams(params)) {
83
83
  if (params.account === "random") {
84
- assertEx(allowRandomAccount, "Random address not allowed");
84
+ assertEx(allowRandomAccount, () => "Random address not allowed");
85
85
  return Account.randomSync();
86
86
  }
87
87
  return params.account;
88
88
  }
89
89
  if (isDetermineAccountFromWalletParams(params)) {
90
- return assertEx(params.accountPath ? await params.wallet.derivePath(params.accountPath) : params.wallet, "Failed to derive account from path");
90
+ return assertEx(params.accountPath ? await params.wallet.derivePath(params.accountPath) : params.wallet, () => "Failed to derive account from path");
91
91
  }
92
92
  console.warn("AbstractModule.determineAccount: No account or wallet provided - Creating Random account");
93
93
  return Account.randomSync();
@@ -251,7 +251,7 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
251
251
  _busyCount = 0;
252
252
  _status = "stopped";
253
253
  constructor(privateConstructorKey, params, account) {
254
- assertEx2(_AbstractModule.privateConstructorKey === privateConstructorKey, "Use create function instead of constructor");
254
+ assertEx2(_AbstractModule.privateConstructorKey === privateConstructorKey, () => "Use create function instead of constructor");
255
255
  const mutatedParams = {
256
256
  ...params
257
257
  };
@@ -264,7 +264,7 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
264
264
  return this.configSchemas[0];
265
265
  }
266
266
  get account() {
267
- return assertEx2(this._account, "Missing account");
267
+ return assertEx2(this._account, () => "Missing account");
268
268
  }
269
269
  get address() {
270
270
  return this.account.address;
@@ -332,24 +332,27 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
332
332
  static _noOverride(functionName) {
333
333
  const thisFunc = this[functionName];
334
334
  const rootFunc = this._getRootFunction(functionName);
335
- assertEx2(thisFunc === rootFunc, `Override not allowed for [${functionName}] - override ${functionName}Handler instead`);
335
+ assertEx2(thisFunc === rootFunc, () => `Override not allowed for [${functionName}] - override ${functionName}Handler instead`);
336
336
  }
337
337
  static async create(params) {
338
- var _a, _b, _c, _d, _e, _f;
338
+ var _a, _b, _c, _d, _e;
339
339
  this._noOverride("create");
340
340
  if (!this.configSchemas || this.configSchemas.length === 0) {
341
341
  throw new Error(`Missing configSchema [${(_a = params == null ? void 0 : params.config) == null ? void 0 : _a.schema}][${this.name}]`);
342
342
  }
343
- assertEx2(((_b = params == null ? void 0 : params.config) == null ? void 0 : _b.name) === void 0 || isModuleName(params.config.name), `Invalid module name: ${(_c = params == null ? void 0 : params.config) == null ? void 0 : _c.name}`);
343
+ assertEx2(((_b = params == null ? void 0 : params.config) == null ? void 0 : _b.name) === void 0 || isModuleName(params.config.name), () => {
344
+ var _a2;
345
+ return `Invalid module name: ${(_a2 = params == null ? void 0 : params.config) == null ? void 0 : _a2.name}`;
346
+ });
344
347
  const { account } = params ?? {};
345
- const schema = ((_d = params == null ? void 0 : params.config) == null ? void 0 : _d.schema) ?? this.configSchema;
348
+ const schema = ((_c = params == null ? void 0 : params.config) == null ? void 0 : _c.schema) ?? this.configSchema;
346
349
  const allowedSchemas = this.configSchemas;
347
350
  assertEx2(allowedSchemas.includes(schema), () => `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`);
348
351
  const mutatedConfig = {
349
352
  ...params == null ? void 0 : params.config,
350
353
  schema
351
354
  };
352
- (_e = params == null ? void 0 : params.logger) == null ? void 0 : _e.debug(`config: ${JSON.stringify(mutatedConfig, null, 2)}`);
355
+ (_d = params == null ? void 0 : params.logger) == null ? void 0 : _d.debug(`config: ${JSON.stringify(mutatedConfig, null, 2)}`);
353
356
  const mutatedParams = {
354
357
  ...params,
355
358
  config: mutatedConfig
@@ -362,7 +365,7 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
362
365
  mutatedParams.logger = activeLogger ? new IdLogger(activeLogger, () => `0x${address}`) : void 0;
363
366
  const newModule = new this(_AbstractModule.privateConstructorKey, mutatedParams, generatedAccount);
364
367
  if (!_AbstractModule.enableLazyLoad) {
365
- await ((_f = newModule.start) == null ? void 0 : _f.call(newModule));
368
+ await ((_e = newModule.start) == null ? void 0 : _e.call(newModule));
366
369
  }
367
370
  return newModule;
368
371
  }
@@ -413,7 +416,7 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
413
416
  async query(query, payloads, queryConfig) {
414
417
  this._checkDead();
415
418
  this._noOverride("query");
416
- const sourceQuery = await PayloadBuilder2.build(assertEx2(QueryBoundWitnessWrapper3.unwrap(query), "Invalid query"));
419
+ const sourceQuery = await PayloadBuilder2.build(assertEx2(QueryBoundWitnessWrapper3.unwrap(query), () => "Invalid query"));
417
420
  return await this.busy(async () => {
418
421
  const resultPayloads = [];
419
422
  const errorPayloads = [];
@@ -423,6 +426,9 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
423
426
  if (!this.allowAnonymous && query.addresses.length === 0) {
424
427
  throw new Error(`Anonymous Queries not allowed, but running anyway [${this.config.name}], [${this.address}]`);
425
428
  }
429
+ if (queryConfig == null ? void 0 : queryConfig.allowedQueries) {
430
+ assertEx2(queryConfig == null ? void 0 : queryConfig.allowedQueries.includes(sourceQuery.schema), () => `Query not allowed [${sourceQuery.schema}]`);
431
+ }
426
432
  resultPayloads.push(...await this.queryHandler(sourceQuery, payloads, queryConfig));
427
433
  } catch (ex) {
428
434
  await handleErrorAsync(ex, async (error) => {
@@ -466,7 +472,7 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
466
472
  ];
467
473
  return validators.every((validator) => validator(query, payloads));
468
474
  }
469
- async resolve(idOrFilter, { required = "log", ...options } = {}) {
475
+ async resolve(idOrFilter = "*", { required = "log", ...options } = {}) {
470
476
  const childOptions = {
471
477
  ...options,
472
478
  required: false
@@ -475,42 +481,37 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
475
481
  const up = direction === "up" || direction === "all";
476
482
  const down = direction === "down" || direction === "all";
477
483
  let result;
478
- switch (typeof idOrFilter) {
479
- case "string": {
480
- if (this.dead) {
481
- return void 0;
482
- }
483
- result = (down ? await this.downResolver.resolve(idOrFilter, childOptions) : void 0) ?? (up ? await this.upResolver.resolve(idOrFilter, childOptions) : void 0);
484
- break;
485
- }
486
- default: {
487
- if (this.dead) {
488
- return [];
489
- }
490
- const filter = idOrFilter;
491
- result = [
492
- ...down ? await this.downResolver.resolve(filter, childOptions) : [],
493
- ...up ? await this.upResolver.resolve(filter, childOptions) : []
494
- ].filter(duplicateModules);
495
- break;
484
+ if (idOrFilter === "*") {
485
+ if (this.dead) {
486
+ return [];
496
487
  }
497
- }
498
- if (required && (result === void 0 || Array.isArray(result) && result.length > 0)) {
499
- switch (required) {
500
- case "warn": {
501
- this.logger.warn("resolve failed", idOrFilter);
502
- break;
503
- }
504
- case "log": {
505
- this.logger.log("resolve failed", idOrFilter);
488
+ return [
489
+ ...down ? await this.downResolver.resolve("*", childOptions) : [],
490
+ ...up ? await this.upResolver.resolve("*", childOptions) : []
491
+ ].filter(duplicateModules);
492
+ } else {
493
+ switch (typeof idOrFilter) {
494
+ case "string": {
495
+ if (this.dead) {
496
+ return void 0;
497
+ }
498
+ result = (down ? await this.downResolver.resolve(idOrFilter, childOptions) : void 0) ?? (up ? await this.upResolver.resolve(idOrFilter, childOptions) : void 0);
506
499
  break;
507
500
  }
508
501
  default: {
509
- this.logger.error("resolve failed", idOrFilter);
502
+ if (this.dead) {
503
+ return [];
504
+ }
505
+ const filter = idOrFilter;
506
+ result = [
507
+ ...down ? await this.downResolver.resolve(filter, childOptions) : [],
508
+ ...up ? await this.upResolver.resolve(filter, childOptions) : []
509
+ ].filter(duplicateModules);
510
510
  break;
511
511
  }
512
512
  }
513
513
  }
514
+ this.validateRequiredResolve(required, result, idOrFilter);
514
515
  return result;
515
516
  }
516
517
  start(_timeout) {
@@ -870,6 +871,24 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
870
871
  }
871
872
  }, true);
872
873
  }
874
+ validateRequiredResolve(required, result, idOrFilter) {
875
+ if (required && (result === void 0 || Array.isArray(result) && result.length > 0)) {
876
+ switch (required) {
877
+ case "warn": {
878
+ this.logger.warn("resolve failed", idOrFilter);
879
+ break;
880
+ }
881
+ case "log": {
882
+ this.logger.log("resolve failed", idOrFilter);
883
+ break;
884
+ }
885
+ default: {
886
+ this.logger.error("resolve failed", idOrFilter);
887
+ break;
888
+ }
889
+ }
890
+ }
891
+ }
873
892
  };
874
893
  __name(_AbstractModule, "AbstractModule");
875
894
  __publicField(_AbstractModule, "allowRandomAccount", true);
@@ -883,7 +902,7 @@ var AbstractModule = _AbstractModule;
883
902
  import { assertEx as assertEx3 } from "@xylabs/assert";
884
903
  var _AbstractModuleInstance = class _AbstractModuleInstance extends AbstractModule {
885
904
  constructor(privateConstructorKey, params, account) {
886
- assertEx3(AbstractModule.privateConstructorKey === privateConstructorKey, "Use create function instead of constructor");
905
+ assertEx3(AbstractModule.privateConstructorKey === privateConstructorKey, () => "Use create function instead of constructor");
887
906
  const mutatedParams = {
888
907
  ...params
889
908
  };