@xyo-network/module-abstract 2.88.3 → 2.89.0-rc.2

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 (37) hide show
  1. package/dist/browser/AbstractModule.d.cts +3 -3
  2. package/dist/browser/AbstractModule.d.cts.map +1 -1
  3. package/dist/browser/AbstractModule.d.mts +3 -3
  4. package/dist/browser/AbstractModule.d.mts.map +1 -1
  5. package/dist/browser/AbstractModule.d.ts +3 -3
  6. package/dist/browser/AbstractModule.d.ts.map +1 -1
  7. package/dist/browser/Error.d.cts +2 -2
  8. package/dist/browser/Error.d.cts.map +1 -1
  9. package/dist/browser/Error.d.mts +2 -2
  10. package/dist/browser/Error.d.mts.map +1 -1
  11. package/dist/browser/Error.d.ts +2 -2
  12. package/dist/browser/Error.d.ts.map +1 -1
  13. package/dist/browser/index.cjs +17 -17
  14. package/dist/browser/index.cjs.map +1 -1
  15. package/dist/browser/index.js +17 -17
  16. package/dist/browser/index.js.map +1 -1
  17. package/dist/node/AbstractModule.d.cts +3 -3
  18. package/dist/node/AbstractModule.d.cts.map +1 -1
  19. package/dist/node/AbstractModule.d.mts +3 -3
  20. package/dist/node/AbstractModule.d.mts.map +1 -1
  21. package/dist/node/AbstractModule.d.ts +3 -3
  22. package/dist/node/AbstractModule.d.ts.map +1 -1
  23. package/dist/node/Error.d.cts +2 -2
  24. package/dist/node/Error.d.cts.map +1 -1
  25. package/dist/node/Error.d.mts +2 -2
  26. package/dist/node/Error.d.mts.map +1 -1
  27. package/dist/node/Error.d.ts +2 -2
  28. package/dist/node/Error.d.ts.map +1 -1
  29. package/dist/node/index.cjs +17 -17
  30. package/dist/node/index.cjs.map +1 -1
  31. package/dist/node/index.js +17 -17
  32. package/dist/node/index.js.map +1 -1
  33. package/package.json +18 -18
  34. package/src/AbstractModule.ts +17 -17
  35. package/src/Error.ts +4 -3
  36. package/src/QueryValidator/ModuleConfigQueryValidator.ts +1 -1
  37. package/src/QueryValidator/SupportedQueryValidator.ts +1 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/AbstractModule.ts","../../src/BaseEmitter.ts","../../src/determineAccount.ts","../../src/Error.ts","../../src/QueryValidator/ModuleConfigQueryValidator.ts","../../src/QueryValidator/SupportedQueryValidator.ts","../../src/AbstractModuleInstance.ts"],"sourcesContent":["/* eslint-disable max-lines */\nimport { assertEx } from '@xylabs/assert'\nimport { handleError, handleErrorAsync } from '@xylabs/error'\nimport { exists } from '@xylabs/exists'\nimport { compact } from '@xylabs/lodash'\nimport { IdLogger } from '@xylabs/logger'\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, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { ConfigPayload, ConfigSchema } from '@xyo-network/config-payload-plugin'\nimport { PayloadHasher } from '@xyo-network/hash'\nimport { ModuleManifestPayload, ModuleManifestPayloadSchema } from '@xyo-network/manifest-model'\nimport {\n AddressPreviousHashPayload,\n AddressPreviousHashSchema,\n CreatableModule,\n CreatableModuleFactory,\n duplicateModules,\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 ModuleInstance,\n ModuleManifestQuerySchema,\n ModuleParams,\n ModuleQueriedEventArgs,\n ModuleQuery,\n ModuleQueryBase,\n ModuleQueryHandlerResult,\n ModuleQueryResult,\n ModuleSubscribeQuerySchema,\n SchemaString,\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 } 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 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<ModuleQueryBase['schema'], string> = {\n [ModuleAddressQuerySchema]: '1',\n [ModuleDescribeQuerySchema]: '4',\n [ModuleDiscoverQuerySchema]: '2',\n [ModuleManifestQuerySchema]: '5',\n [ModuleSubscribeQuerySchema]: '3',\n }\n protected readonly _queryAccounts: Record<ModuleQueryBase['schema'], AccountInstance | undefined> = {\n [ModuleAddressQuerySchema]: undefined,\n [ModuleDescribeQuerySchema]: undefined,\n [ModuleDiscoverQuerySchema]: undefined,\n [ModuleManifestQuerySchema]: 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\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 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 [ModuleDiscoverQuerySchema, ModuleAddressQuerySchema, ModuleSubscribeQuerySchema, ModuleDescribeQuerySchema, ModuleManifestQuerySchema]\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 timestamp() {\n return this.config.timestamp ?? false\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 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 _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 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 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._noOverride('query')\n const sourceQuery = await PayloadHasher.hashAsync(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(assertEx(QueryBoundWitnessWrapper.unwrap(query)), payloads, queryConfig)))\n } catch (ex) {\n await handleErrorAsync(ex, async (error) => {\n errorPayloads.push(\n await new ModuleErrorBuilder()\n .sources([await PayloadHasher.hashAsync(query)])\n .name(this.config.name ?? '<Unknown>')\n .query(query.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(query, resultPayloads, sourceQuery, queryAccount ? [queryAccount] : [], errorPayloads)\n const args: ModuleQueriedEventArgs = { module: this, payloads, query, result }\n await this.emit('moduleQueried', args)\n return result\n })\n }\n\n queryable<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): boolean {\n if (!this.started('warn')) return false\n const configValidator = queryConfig\n ? new ModuleConfigQueryValidator(Object.assign({}, this.config, queryConfig)).queryable\n : 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>(nameOrAddress: string, options?: ModuleFilterOptions<T>): Promise<T | undefined>\n async resolve<T extends ModuleInstance = ModuleInstance>(\n nameOrAddressOrFilter?: ModuleFilter<T> | string,\n options?: ModuleFilterOptions<T>,\n ): Promise<T | T[] | undefined> {\n const direction = options?.direction ?? 'all'\n const up = direction === 'up' || direction === 'all'\n const down = direction === 'down' || direction === 'all'\n switch (typeof nameOrAddressOrFilter) {\n case 'string': {\n return (\n (down ? await (this.downResolver as CompositeModuleResolver).resolve<T>(nameOrAddressOrFilter, options) : undefined) ??\n (up ? await (this.upResolver as CompositeModuleResolver).resolve<T>(nameOrAddressOrFilter, options) : undefined)\n )\n }\n default: {\n const filter: ModuleFilter<T> | undefined = nameOrAddressOrFilter\n return [\n ...(down ? await (this.downResolver as CompositeModuleResolver).resolve<T>(filter, options) : []),\n ...(up ? await (this.upResolver as CompositeModuleResolver).resolve<T>(filter, options) : []),\n ].filter(duplicateModules)\n }\n }\n }\n\n start(_timeout?: number): Promisable<boolean> {\n //using promise as mutex\n this._startPromise = this._startPromise ?? this.startHandler()\n return this._startPromise\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 return result\n })\n }\n\n protected bindHashes(hashes: string[], schema: SchemaString[], account?: AccountInstance) {\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: string[], schema: SchemaString[], 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<[QueryBoundWitness, Payload[], Payload[]], AccountInstance> {\n const promise = new PromiseEx<[QueryBoundWitness, Payload[], 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<[QueryBoundWitness, Payload[], Payload[]]> {\n const builder = 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: T,\n payloads: Payload[],\n sourceQuery?: string,\n additionalWitnesses: AccountInstance[] = [],\n errors?: ModuleError[],\n ): Promise<ModuleQueryResult> {\n const builder = new BoundWitnessBuilder().payloads(payloads).errors(errors).sourceQuery(sourceQuery)\n const queryWitnessAccount = this.queryAccounts[query.schema as ModuleQueryBase['schema']]\n const witnesses = [this.account, queryWitnessAccount, ...additionalWitnesses].filter(exists)\n builder.witnesses(witnesses)\n const result: ModuleQueryResult = [(await builder.build())[0], payloads, errors ?? []]\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 ModuleQueryBase['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 = previousHash\n ? { address, previousHash, schema: AddressPreviousHashSchema }\n : { 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 = QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(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 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 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 { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { ModuleError, ModuleErrorSchema } from '@xyo-network/payload-model'\n\nexport class ModuleErrorBuilder extends PayloadBuilder<ModuleError> {\n _message?: string\n _name?: string\n _query?: string\n _sources?: string[]\n constructor() {\n super({ schema: ModuleErrorSchema })\n }\n\n override build(): Promise<ModuleError> {\n return Promise.resolve({\n message: this._message,\n name: this._name,\n query: this._query,\n schema: ModuleErrorSchema,\n sources: this._sources,\n })\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: string) {\n this._query = query\n return this\n }\n\n sources(sources: string[]) {\n this._sources = sources\n return this\n }\n}\n","import { Address } from '@xylabs/hex'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { AnyConfigSchema, CosigningAddressSet, ModuleConfig, ModuleQuery, SchemaString } from '@xyo-network/module-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<SchemaString, SortedPipedAddressesString[]> = {}\n protected disallowed: Record<SchemaString, Address[]> = {}\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 = QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(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: SchemaString, addresses: string[]): 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: SchemaString, 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 { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { Module, ModuleQuery } 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 = QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(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 return this.busy(async () => {\n return await this.describeHandler()\n })\n }\n\n discover(): Promise<Payload[]> {\n return this.busy(async () => {\n return await this.discoverHandler()\n })\n }\n\n manifest(maxDepth?: number, ignoreAddresses?: string[]): Promise<ModuleManifestPayload> {\n return this.busy(async () => {\n return await this.manifestHandler(maxDepth, ignoreAddresses)\n })\n }\n\n moduleAddress(): Promise<AddressPreviousHashPayload[]> {\n return this.busy(async () => {\n return await this.moduleAddressHandler()\n })\n }\n\n subscribe(_queryAccount?: AccountInstance) {\n return this.subscribeHandler()\n }\n}\n"],"mappings":"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","names":["assertEx","handleError","handleErrorAsync","exists","compact","IdLogger","PromiseEx","Account","AddressSchema","asArchivistInstance","BoundWitnessBuilder","QueryBoundWitnessBuilder","QueryBoundWitnessWrapper","ConfigSchema","PayloadHasher","ModuleManifestPayloadSchema","AddressPreviousHashSchema","duplicateModules","ModuleAddressQuerySchema","ModuleDescribeQuerySchema","ModuleDescriptionSchema","ModuleDiscoverQuerySchema","ModuleFactory","ModuleManifestQuerySchema","ModuleSubscribeQuerySchema","serializableField","CompositeModuleResolver","PayloadBuilder","QuerySchema","Base","Events","BaseEmitter","Base","eventData","events","constructor","params","Events","clearListeners","eventNames","emit","eventName","eventArgs","emitSerial","listenerCount","off","listener","offAny","on","onAny","once","assertEx","Account","isDetermineAccountFromAccountParams","params","assertEx","accountPath","account","isDetermineAccountFromWalletParams","wallet","determineAccount","allowRandomAccount","Account","randomSync","derivePath","console","warn","PayloadBuilder","ModuleErrorSchema","ModuleErrorBuilder","PayloadBuilder","_message","_name","_query","_sources","constructor","schema","ModuleErrorSchema","build","Promise","resolve","message","name","query","sources","QueryBoundWitnessWrapper","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","QueryBoundWitnessWrapper","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","ModuleSubscribeQuerySchema","_queryAccounts","_startPromise","_started","moduleConfigQueryValidator","supportedQueryValidator","_busyCount","constructor","privateConstructorKey","params","account","assertEx","mutatedParams","SupportedQueryValidator","queryable","ModuleConfigQueryValidator","config","configSchema","configSchemas","address","allowAnonymous","security","ephemeralQueryAccountEnabled","id","name","queries","queryAccountPaths","_queryAccountPaths","queryAccounts","timestamp","_getRootFunction","funcName","anyThis","__proto__","_noOverride","functionName","thisFunc","rootFunc","create","length","Error","schema","allowedSchemas","includes","JSON","stringify","mutatedConfig","logger","debug","activeLogger","defaultLogger","generatedAccount","determineAccount","IdLogger","newModule","enableLazyLoad","start","allowRandomAccount","factory","ModuleFactory","withParams","busy","closure","args","module","emit","eventName","eventArgs","previousHash","query","payloads","queryConfig","sourceQuery","PayloadHasher","hashAsync","resultPayloads","errorPayloads","queryAccount","Account","randomSync","started","addresses","push","queryHandler","QueryBoundWitnessWrapper","unwrap","ex","handleErrorAsync","error","ModuleErrorBuilder","sources","message","build","Date","now","result","bindQueryResult","configValidator","Object","assign","validators","every","validator","resolve","nameOrAddressOrFilter","options","direction","up","down","filter","duplicateModules","_timeout","startHandler","notStartedAction","tryStart","handleError","_a","warn","log","stop","stopHandler","bindHashes","hashes","promise","PromiseEx","bindHashesInternal","builder","BoundWitnessBuilder","witness","bindQuery","bindQueryInternal","QueryBoundWitnessBuilder","additionalWitnesses","errors","queryWitnessAccount","witnesses","exists","archiving","storeToArchivists","flat","describeHandler","description","ModuleDescriptionSchema","discover","discoverHandler","children","compact","map","payload","AddressSchema","_maxDepth","PayloadBuilder","fields","Promise","all","QuerySchema","ConfigSchema","getArchivist","archivist","resolved","asArchivistInstance","initializeQueryAccounts","paths","values","distinctPaths","Set","size","wallet","derivePath","key","prototype","hasOwnProperty","call","queryAccountPath","manifestHandler","_depth","_ignoreAddresses","ModuleManifestPayloadSchema","status","moduleAddressHandler","entries","value","AddressPreviousHashSchema","moduleAccount","moduleAccountPreviousHash","wrapper","parseQuery","queryPayload","getQuery","maxDepth","subscribeHandler","resolveArchivingArchivists","archivists","mod","validateConfig","insert","bw","parents","reduce","valid","join","Array","isArray","serializableField","toString","assertEx","AbstractModuleInstance","AbstractModule","constructor","privateConstructorKey","params","account","assertEx","mutatedParams","upResolver","add","downResolver","describe","busy","describeHandler","discover","discoverHandler","manifest","maxDepth","ignoreAddresses","manifestHandler","moduleAddress","moduleAddressHandler","subscribe","_queryAccount","subscribeHandler"]}
1
+ {"version":3,"sources":["../../src/AbstractModule.ts","../../src/BaseEmitter.ts","../../src/determineAccount.ts","../../src/Error.ts","../../src/QueryValidator/ModuleConfigQueryValidator.ts","../../src/QueryValidator/SupportedQueryValidator.ts","../../src/AbstractModuleInstance.ts"],"sourcesContent":["/* eslint-disable max-lines */\nimport { assertEx } from '@xylabs/assert'\nimport { handleError, handleErrorAsync } from '@xylabs/error'\nimport { exists } from '@xylabs/exists'\nimport { compact } from '@xylabs/lodash'\nimport { IdLogger } from '@xylabs/logger'\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, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, QueryBoundWitness } from '@xyo-network/boundwitness-model'\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 duplicateModules,\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 ModuleInstance,\n ModuleManifestQuerySchema,\n ModuleParams,\n ModuleQueriedEventArgs,\n ModuleQuery,\n ModuleQueryBase,\n ModuleQueryHandlerResult,\n ModuleQueryResult,\n ModuleSubscribeQuerySchema,\n SchemaString,\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, 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 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<ModuleQueryBase['schema'], string> = {\n [ModuleAddressQuerySchema]: '1',\n [ModuleDescribeQuerySchema]: '4',\n [ModuleDiscoverQuerySchema]: '2',\n [ModuleManifestQuerySchema]: '5',\n [ModuleSubscribeQuerySchema]: '3',\n }\n protected readonly _queryAccounts: Record<ModuleQueryBase['schema'], AccountInstance | undefined> = {\n [ModuleAddressQuerySchema]: undefined,\n [ModuleDescribeQuerySchema]: undefined,\n [ModuleDiscoverQuerySchema]: undefined,\n [ModuleManifestQuerySchema]: 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\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 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 [ModuleDiscoverQuerySchema, ModuleAddressQuerySchema, ModuleSubscribeQuerySchema, ModuleDescribeQuerySchema, ModuleManifestQuerySchema]\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 timestamp() {\n return this.config.timestamp ?? false\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 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 _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 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 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._noOverride('query')\n const sourceQuery = await PayloadBuilder.build(assertEx(await 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 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 (!(await this.started('warn'))) return false\n const configValidator = queryConfig\n ? new ModuleConfigQueryValidator(Object.assign({}, this.config, queryConfig)).queryable\n : 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>(nameOrAddress: string, options?: ModuleFilterOptions<T>): Promise<T | undefined>\n async resolve<T extends ModuleInstance = ModuleInstance>(\n nameOrAddressOrFilter?: ModuleFilter<T> | string,\n options?: ModuleFilterOptions<T>,\n ): Promise<T | T[] | undefined> {\n const direction = options?.direction ?? 'all'\n const up = direction === 'up' || direction === 'all'\n const down = direction === 'down' || direction === 'all'\n switch (typeof nameOrAddressOrFilter) {\n case 'string': {\n return (\n (down ? await (this.downResolver as CompositeModuleResolver).resolve<T>(nameOrAddressOrFilter, options) : undefined) ??\n (up ? await (this.upResolver as CompositeModuleResolver).resolve<T>(nameOrAddressOrFilter, options) : undefined)\n )\n }\n default: {\n const filter: ModuleFilter<T> | undefined = nameOrAddressOrFilter\n return [\n ...(down ? await (this.downResolver as CompositeModuleResolver).resolve<T>(filter, options) : []),\n ...(up ? await (this.upResolver as CompositeModuleResolver).resolve<T>(filter, options) : []),\n ].filter(duplicateModules)\n }\n }\n }\n\n start(_timeout?: number): Promisable<boolean> {\n //using promise as mutex\n this._startPromise = this._startPromise ?? this.startHandler()\n return this._startPromise\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 return result\n })\n }\n\n protected bindHashes(hashes: string[], schema: SchemaString[], 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: string[], schema: SchemaString[], 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<[QueryBoundWitness, Payload[], Payload[]], AccountInstance> {\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n const promise = new PromiseEx<[QueryBoundWitness, Payload[], 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<[QueryBoundWitness, Payload[], 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 ModuleQueryBase['schema']]\n const witnesses = [this.account, queryWitnessAccount, ...additionalWitnesses].filter(exists)\n builder.witnesses(witnesses)\n const result: ModuleQueryResult = [(await builder.build())[0], payloads, errors ?? []]\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 ModuleQueryBase['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 = previousHash\n ? { address, previousHash, schema: AddressPreviousHashSchema }\n : { 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<ModuleQuery>(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 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 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 { 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?: string\n _sources?: string[]\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: string) {\n this._query = query\n return this\n }\n\n sources(sources: string[]) {\n this._sources = sources\n return this\n }\n}\n","import { Address } from '@xylabs/hex'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { AnyConfigSchema, CosigningAddressSet, ModuleConfig, ModuleQuery, SchemaString } from '@xyo-network/module-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<SchemaString, SortedPipedAddressesString[]> = {}\n protected disallowed: Record<SchemaString, Address[]> = {}\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<ModuleQuery>(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: SchemaString, addresses: string[]): 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: SchemaString, 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 { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { Module, ModuleQuery } 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<ModuleQuery>(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 return this.busy(async () => {\n return await this.describeHandler()\n })\n }\n\n discover(): Promise<Payload[]> {\n return this.busy(async () => {\n return await this.discoverHandler()\n })\n }\n\n manifest(maxDepth?: number, ignoreAddresses?: string[]): Promise<ModuleManifestPayload> {\n return this.busy(async () => {\n return await this.manifestHandler(maxDepth, ignoreAddresses)\n })\n }\n\n moduleAddress(): Promise<AddressPreviousHashPayload[]> {\n return this.busy(async () => {\n return await this.moduleAddressHandler()\n })\n }\n\n subscribe(_queryAccount?: AccountInstance) {\n return this.subscribeHandler()\n }\n}\n"],"mappings":"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","names":["assertEx","handleError","handleErrorAsync","exists","compact","IdLogger","PromiseEx","Account","AddressSchema","asArchivistInstance","BoundWitnessBuilder","QueryBoundWitnessBuilder","QueryBoundWitnessWrapper","ConfigSchema","ModuleManifestPayloadSchema","AddressPreviousHashSchema","duplicateModules","ModuleAddressQuerySchema","ModuleDescribeQuerySchema","ModuleDescriptionSchema","ModuleDiscoverQuerySchema","ModuleFactory","ModuleManifestQuerySchema","ModuleSubscribeQuerySchema","serializableField","CompositeModuleResolver","PayloadBuilder","QuerySchema","Base","Events","BaseEmitter","Base","eventData","events","constructor","params","Events","clearListeners","eventNames","emit","eventName","eventArgs","emitSerial","listenerCount","off","listener","offAny","on","onAny","once","assertEx","Account","isDetermineAccountFromAccountParams","params","assertEx","accountPath","account","isDetermineAccountFromWalletParams","wallet","determineAccount","allowRandomAccount","Account","randomSync","derivePath","console","warn","PayloadBuilder","ModuleErrorSchema","ModuleErrorBuilder","PayloadBuilder","_message","_name","_query","_sources","constructor","schema","ModuleErrorSchema","build","fields","message","name","query","sources","QueryBoundWitnessWrapper","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","QueryBoundWitnessWrapper","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","ModuleSubscribeQuerySchema","_queryAccounts","_startPromise","_started","moduleConfigQueryValidator","supportedQueryValidator","_busyCount","constructor","privateConstructorKey","params","account","assertEx","mutatedParams","SupportedQueryValidator","queryable","ModuleConfigQueryValidator","config","configSchema","configSchemas","address","allowAnonymous","security","ephemeralQueryAccountEnabled","id","name","queries","queryAccountPaths","_queryAccountPaths","queryAccounts","timestamp","_getRootFunction","funcName","anyThis","__proto__","_noOverride","functionName","thisFunc","rootFunc","create","length","Error","schema","allowedSchemas","includes","JSON","stringify","mutatedConfig","logger","debug","activeLogger","defaultLogger","generatedAccount","determineAccount","IdLogger","newModule","enableLazyLoad","start","allowRandomAccount","factory","ModuleFactory","withParams","busy","closure","args","module","emit","eventName","eventArgs","previousHash","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","nameOrAddressOrFilter","options","direction","up","down","filter","duplicateModules","_timeout","startHandler","notStartedAction","tryStart","handleError","_a","warn","log","stop","stopHandler","bindHashes","hashes","promise","PromiseEx","bindHashesInternal","builder","BoundWitnessBuilder","witness","bindQuery","bindQueryInternal","QueryBoundWitnessBuilder","additionalWitnesses","errors","queryWitnessAccount","witnesses","exists","archiving","storeToArchivists","flat","describeHandler","description","ModuleDescriptionSchema","discover","discoverHandler","children","compact","map","payload","AddressSchema","_maxDepth","fields","Promise","all","QuerySchema","ConfigSchema","getArchivist","archivist","resolved","asArchivistInstance","initializeQueryAccounts","paths","values","distinctPaths","Set","size","wallet","derivePath","key","prototype","hasOwnProperty","call","queryAccountPath","manifestHandler","_depth","_ignoreAddresses","ModuleManifestPayloadSchema","status","moduleAddressHandler","entries","value","AddressPreviousHashSchema","moduleAccount","moduleAccountPreviousHash","wrapper","parseQuery","queryPayload","getQuery","maxDepth","subscribeHandler","resolveArchivingArchivists","archivists","mod","validateConfig","insert","bw","parents","reduce","valid","join","Array","isArray","serializableField","toString","assertEx","AbstractModuleInstance","AbstractModule","constructor","privateConstructorKey","params","account","assertEx","mutatedParams","upResolver","add","downResolver","describe","busy","describeHandler","discover","discoverHandler","manifest","maxDepth","ignoreAddresses","manifestHandler","moduleAddress","moduleAddressHandler","subscribe","_queryAccount","subscribeHandler"]}
package/package.json CHANGED
@@ -18,22 +18,21 @@
18
18
  "@xylabs/logger": "^2.13.29",
19
19
  "@xylabs/object": "^2.88.5",
20
20
  "@xylabs/promise": "^2.13.29",
21
- "@xyo-network/account": "~2.88.3",
22
- "@xyo-network/account-model": "~2.88.3",
23
- "@xyo-network/address-payload-plugin": "~2.88.3",
24
- "@xyo-network/archivist-model": "~2.88.3",
25
- "@xyo-network/boundwitness-builder": "~2.88.3",
26
- "@xyo-network/boundwitness-model": "~2.88.3",
27
- "@xyo-network/config-payload-plugin": "~2.88.3",
28
- "@xyo-network/hash": "~2.88.3",
29
- "@xyo-network/manifest-model": "~2.88.3",
30
- "@xyo-network/module-events": "~2.88.3",
31
- "@xyo-network/module-model": "~2.88.3",
32
- "@xyo-network/module-resolver": "~2.88.3",
33
- "@xyo-network/payload-builder": "~2.88.3",
34
- "@xyo-network/payload-model": "~2.88.3",
35
- "@xyo-network/query-payload-plugin": "~2.88.3",
36
- "@xyo-network/wallet-model": "~2.88.3"
21
+ "@xyo-network/account": "~2.89.0-rc.2",
22
+ "@xyo-network/account-model": "~2.89.0-rc.2",
23
+ "@xyo-network/address-payload-plugin": "~2.89.0-rc.2",
24
+ "@xyo-network/archivist-model": "~2.89.0-rc.2",
25
+ "@xyo-network/boundwitness-builder": "~2.89.0-rc.2",
26
+ "@xyo-network/boundwitness-model": "~2.89.0-rc.2",
27
+ "@xyo-network/config-payload-plugin": "~2.89.0-rc.2",
28
+ "@xyo-network/manifest-model": "~2.89.0-rc.2",
29
+ "@xyo-network/module-events": "~2.89.0-rc.2",
30
+ "@xyo-network/module-model": "~2.89.0-rc.2",
31
+ "@xyo-network/module-resolver": "~2.89.0-rc.2",
32
+ "@xyo-network/payload-builder": "~2.89.0-rc.2",
33
+ "@xyo-network/payload-model": "~2.89.0-rc.2",
34
+ "@xyo-network/query-payload-plugin": "~2.89.0-rc.2",
35
+ "@xyo-network/wallet-model": "~2.89.0-rc.2"
37
36
  },
38
37
  "devDependencies": {
39
38
  "@xylabs/ts-scripts-yarn3": "^3.2.42",
@@ -79,6 +78,7 @@
79
78
  "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
80
79
  },
81
80
  "sideEffects": false,
82
- "version": "2.88.3",
83
- "type": "module"
81
+ "version": "2.89.0-rc.2",
82
+ "type": "module",
83
+ "stableVersion": "2.88.3"
84
84
  }
@@ -12,7 +12,6 @@ import { ArchivistInstance, asArchivistInstance } from '@xyo-network/archivist-m
12
12
  import { BoundWitnessBuilder, QueryBoundWitnessBuilder, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'
13
13
  import { BoundWitness, QueryBoundWitness } from '@xyo-network/boundwitness-model'
14
14
  import { ConfigPayload, ConfigSchema } from '@xyo-network/config-payload-plugin'
15
- import { PayloadHasher } from '@xyo-network/hash'
16
15
  import { ModuleManifestPayload, ModuleManifestPayloadSchema } from '@xyo-network/manifest-model'
17
16
  import {
18
17
  AddressPreviousHashPayload,
@@ -46,7 +45,7 @@ import {
46
45
  } from '@xyo-network/module-model'
47
46
  import { CompositeModuleResolver } from '@xyo-network/module-resolver'
48
47
  import { PayloadBuilder } from '@xyo-network/payload-builder'
49
- import { ModuleError, Payload, Query } from '@xyo-network/payload-model'
48
+ import { ModuleError, Payload, Query, WithMeta } from '@xyo-network/payload-model'
50
49
  import { QueryPayload, QuerySchema } from '@xyo-network/query-payload-plugin'
51
50
  import { WalletInstance } from '@xyo-network/wallet-model'
52
51
 
@@ -265,7 +264,7 @@ export abstract class AbstractModule<TParams extends ModuleParams = ModuleParams
265
264
  queryConfig?: TConfig,
266
265
  ): Promise<ModuleQueryResult> {
267
266
  this._noOverride('query')
268
- const sourceQuery = await PayloadHasher.hashAsync(query)
267
+ const sourceQuery = await PayloadBuilder.build(assertEx(await QueryBoundWitnessWrapper.unwrap(query), 'Invalid query'))
269
268
  return await this.busy(async () => {
270
269
  const resultPayloads: Payload[] = []
271
270
  const errorPayloads: ModuleError[] = []
@@ -275,14 +274,14 @@ export abstract class AbstractModule<TParams extends ModuleParams = ModuleParams
275
274
  if (!this.allowAnonymous && query.addresses.length === 0) {
276
275
  throw new Error(`Anonymous Queries not allowed, but running anyway [${this.config.name}], [${this.address}]`)
277
276
  }
278
- resultPayloads.push(...(await this.queryHandler(assertEx(QueryBoundWitnessWrapper.unwrap(query)), payloads, queryConfig)))
277
+ resultPayloads.push(...(await this.queryHandler(sourceQuery, payloads, queryConfig)))
279
278
  } catch (ex) {
280
279
  await handleErrorAsync(ex, async (error) => {
281
280
  errorPayloads.push(
282
281
  await new ModuleErrorBuilder()
283
- .sources([await PayloadHasher.hashAsync(query)])
282
+ .sources([sourceQuery.$hash])
284
283
  .name(this.config.name ?? '<Unknown>')
285
- .query(query.schema)
284
+ .query(sourceQuery.schema)
286
285
  .message(error.message)
287
286
  .build(),
288
287
  )
@@ -292,19 +291,19 @@ export abstract class AbstractModule<TParams extends ModuleParams = ModuleParams
292
291
  const timestamp = { schema: 'network.xyo.timestamp', timestamp: Date.now() }
293
292
  resultPayloads.push(timestamp)
294
293
  }
295
- const result = await this.bindQueryResult(query, resultPayloads, sourceQuery, queryAccount ? [queryAccount] : [], errorPayloads)
296
- const args: ModuleQueriedEventArgs = { module: this, payloads, query, result }
294
+ const result = await this.bindQueryResult(sourceQuery, resultPayloads, queryAccount ? [queryAccount] : [], errorPayloads)
295
+ const args: ModuleQueriedEventArgs = { module: this, payloads, query: sourceQuery, result }
297
296
  await this.emit('moduleQueried', args)
298
297
  return result
299
298
  })
300
299
  }
301
300
 
302
- queryable<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(
301
+ async queryable<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(
303
302
  query: T,
304
303
  payloads?: Payload[],
305
304
  queryConfig?: TConfig,
306
- ): boolean {
307
- if (!this.started('warn')) return false
305
+ ): Promise<boolean> {
306
+ if (!(await this.started('warn'))) return false
308
307
  const configValidator = queryConfig
309
308
  ? new ModuleConfigQueryValidator(Object.assign({}, this.config, queryConfig)).queryable
310
309
  : this.moduleConfigQueryValidator
@@ -403,6 +402,7 @@ export abstract class AbstractModule<TParams extends ModuleParams = ModuleParams
403
402
  }
404
403
 
405
404
  protected bindHashes(hashes: string[], schema: SchemaString[], account?: AccountInstance) {
405
+ // eslint-disable-next-line @typescript-eslint/no-misused-promises
406
406
  const promise = new PromiseEx((resolve) => {
407
407
  const result = this.bindHashesInternal(hashes, schema, account)
408
408
  resolve?.(result)
@@ -423,6 +423,7 @@ export abstract class AbstractModule<TParams extends ModuleParams = ModuleParams
423
423
  payloads?: Payload[],
424
424
  account?: AccountInstance,
425
425
  ): PromiseEx<[QueryBoundWitness, Payload[], Payload[]], AccountInstance> {
426
+ // eslint-disable-next-line @typescript-eslint/no-misused-promises
426
427
  const promise = new PromiseEx<[QueryBoundWitness, Payload[], Payload[]], AccountInstance>(async (resolve) => {
427
428
  const result = await this.bindQueryInternal(query, payloads, account)
428
429
  resolve?.(result)
@@ -436,19 +437,18 @@ export abstract class AbstractModule<TParams extends ModuleParams = ModuleParams
436
437
  payloads?: Payload[],
437
438
  account?: AccountInstance,
438
439
  ): Promise<[QueryBoundWitness, Payload[], Payload[]]> {
439
- const builder = new QueryBoundWitnessBuilder().payloads(payloads).witness(this.account).query(query)
440
+ const builder = await (await new QueryBoundWitnessBuilder().payloads(payloads)).witness(this.account).query(query)
440
441
  const result = await (account ? builder.witness(account) : builder).build()
441
442
  return result
442
443
  }
443
444
 
444
445
  protected async bindQueryResult<T extends Query>(
445
- query: T,
446
+ query: WithMeta<T>,
446
447
  payloads: Payload[],
447
- sourceQuery?: string,
448
448
  additionalWitnesses: AccountInstance[] = [],
449
449
  errors?: ModuleError[],
450
450
  ): Promise<ModuleQueryResult> {
451
- const builder = new BoundWitnessBuilder().payloads(payloads).errors(errors).sourceQuery(sourceQuery)
451
+ const builder = (await (await new BoundWitnessBuilder().payloads(payloads)).errors(errors)).sourceQuery(query.$hash)
452
452
  const queryWitnessAccount = this.queryAccounts[query.schema as ModuleQueryBase['schema']]
453
453
  const witnesses = [this.account, queryWitnessAccount, ...additionalWitnesses].filter(exists)
454
454
  builder.witnesses(witnesses)
@@ -559,9 +559,9 @@ export abstract class AbstractModule<TParams extends ModuleParams = ModuleParams
559
559
  queryConfig?: TConfig,
560
560
  ): Promise<ModuleQueryHandlerResult> {
561
561
  await this.started('throw')
562
- const wrapper = QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)
562
+ const wrapper = await QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)
563
563
  const queryPayload = await wrapper.getQuery()
564
- assertEx(this.queryable(query, payloads, queryConfig))
564
+ assertEx(await this.queryable(query, payloads, queryConfig))
565
565
  const resultPayloads: Payload[] = []
566
566
  switch (queryPayload.schema) {
567
567
  case ModuleManifestQuerySchema: {
package/src/Error.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  import { PayloadBuilder } from '@xyo-network/payload-builder'
2
- import { ModuleError, ModuleErrorSchema } from '@xyo-network/payload-model'
2
+ import { ModuleError, ModuleErrorSchema, WithMeta } from '@xyo-network/payload-model'
3
3
 
4
4
  export class ModuleErrorBuilder extends PayloadBuilder<ModuleError> {
5
5
  _message?: string
@@ -10,14 +10,15 @@ export class ModuleErrorBuilder extends PayloadBuilder<ModuleError> {
10
10
  super({ schema: ModuleErrorSchema })
11
11
  }
12
12
 
13
- override build(): Promise<ModuleError> {
14
- return Promise.resolve({
13
+ override build(): Promise<WithMeta<ModuleError>> {
14
+ this.fields({
15
15
  message: this._message,
16
16
  name: this._name,
17
17
  query: this._query,
18
18
  schema: ModuleErrorSchema,
19
19
  sources: this._sources,
20
20
  })
21
+ return super.build()
21
22
  }
22
23
 
23
24
  message(message: string) {
@@ -35,7 +35,7 @@ export class ModuleConfigQueryValidator<TConfig extends AnyConfigSchema<ModuleCo
35
35
  if (!this.hasRules) return true
36
36
  const addresses = query.addresses
37
37
  if (addresses.length === 0) return false
38
- const wrapper = QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)
38
+ const wrapper = await QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)
39
39
  const schema = (await wrapper.getQuery()).schema
40
40
  return this.queryAllowed(schema, addresses) && !this.queryDisallowed(schema, addresses)
41
41
  }
@@ -10,7 +10,7 @@ export const isQuerySupportedByModule = async <T extends QueryBoundWitness = Que
10
10
  query: T,
11
11
  payloads?: Payload[],
12
12
  ): Promise<boolean> => {
13
- const wrapper = QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)
13
+ const wrapper = await QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)
14
14
  const schema = (await wrapper.getQuery()).schema
15
15
  return mod.queries.includes(schema)
16
16
  }