@xyo-network/module-abstract 2.75.17 → 2.76.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/AbstractModule.d.cts +3 -4
- package/dist/browser/AbstractModule.d.cts.map +1 -1
- package/dist/browser/AbstractModule.d.mts +3 -4
- package/dist/browser/AbstractModule.d.mts.map +1 -1
- package/dist/browser/AbstractModule.d.ts +3 -4
- package/dist/browser/AbstractModule.d.ts.map +1 -1
- package/dist/browser/QueryValidator/QueryValidator.d.cts +1 -1
- package/dist/browser/QueryValidator/QueryValidator.d.cts.map +1 -1
- package/dist/browser/QueryValidator/QueryValidator.d.mts +1 -1
- package/dist/browser/QueryValidator/QueryValidator.d.mts.map +1 -1
- package/dist/browser/QueryValidator/QueryValidator.d.ts +1 -1
- package/dist/browser/QueryValidator/QueryValidator.d.ts.map +1 -1
- package/dist/browser/QueryValidator/SupportedQueryValidator.d.cts +2 -2
- package/dist/browser/QueryValidator/SupportedQueryValidator.d.cts.map +1 -1
- package/dist/browser/QueryValidator/SupportedQueryValidator.d.mts +2 -2
- package/dist/browser/QueryValidator/SupportedQueryValidator.d.mts.map +1 -1
- package/dist/browser/QueryValidator/SupportedQueryValidator.d.ts +2 -2
- package/dist/browser/QueryValidator/SupportedQueryValidator.d.ts.map +1 -1
- package/dist/browser/determineAccount.d.cts +8 -0
- package/dist/browser/determineAccount.d.cts.map +1 -0
- package/dist/browser/determineAccount.d.mts +8 -0
- package/dist/browser/determineAccount.d.mts.map +1 -0
- package/dist/browser/determineAccount.d.ts +8 -0
- package/dist/browser/determineAccount.d.ts.map +1 -0
- package/dist/browser/index.cjs +36 -28
- package/dist/browser/index.cjs.map +1 -1
- package/dist/browser/index.js +36 -28
- package/dist/browser/index.js.map +1 -1
- package/dist/node/AbstractModule.d.cts +3 -4
- package/dist/node/AbstractModule.d.cts.map +1 -1
- package/dist/node/AbstractModule.d.mts +3 -4
- package/dist/node/AbstractModule.d.mts.map +1 -1
- package/dist/node/AbstractModule.d.ts +3 -4
- package/dist/node/AbstractModule.d.ts.map +1 -1
- package/dist/node/QueryValidator/QueryValidator.d.cts +1 -1
- package/dist/node/QueryValidator/QueryValidator.d.cts.map +1 -1
- package/dist/node/QueryValidator/QueryValidator.d.mts +1 -1
- package/dist/node/QueryValidator/QueryValidator.d.mts.map +1 -1
- package/dist/node/QueryValidator/QueryValidator.d.ts +1 -1
- package/dist/node/QueryValidator/QueryValidator.d.ts.map +1 -1
- package/dist/node/QueryValidator/SupportedQueryValidator.d.cts +2 -2
- package/dist/node/QueryValidator/SupportedQueryValidator.d.cts.map +1 -1
- package/dist/node/QueryValidator/SupportedQueryValidator.d.mts +2 -2
- package/dist/node/QueryValidator/SupportedQueryValidator.d.mts.map +1 -1
- package/dist/node/QueryValidator/SupportedQueryValidator.d.ts +2 -2
- package/dist/node/QueryValidator/SupportedQueryValidator.d.ts.map +1 -1
- package/dist/node/determineAccount.d.cts +8 -0
- package/dist/node/determineAccount.d.cts.map +1 -0
- package/dist/node/determineAccount.d.mts +8 -0
- package/dist/node/determineAccount.d.mts.map +1 -0
- package/dist/node/determineAccount.d.ts +8 -0
- package/dist/node/determineAccount.d.ts.map +1 -0
- package/dist/node/index.js +36 -28
- package/dist/node/index.js.map +1 -1
- package/dist/node/index.mjs +36 -28
- package/dist/node/index.mjs.map +1 -1
- package/package.json +20 -20
- package/src/AbstractModule.ts +9 -20
- package/src/QueryValidator/QueryValidator.ts +1 -1
- package/src/QueryValidator/SupportedQueryValidator.ts +2 -1
- package/src/determineAccount.ts +27 -0
- package/dist/docs.json +0 -43516
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/AbstractModule.ts","../../src/BaseEmitter.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 { exists } from '@xylabs/exists'\nimport { compact } from '@xylabs/lodash'\nimport { 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, QueryBoundWitness, QueryBoundWitnessBuilder, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { ConfigPayload, ConfigSchema } from '@xyo-network/config-payload-plugin'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { handleError, handleErrorAsync } from '@xyo-network/error'\nimport { ModuleManifestPayload, ModuleManifestPayloadSchema } from '@xyo-network/manifest-model'\nimport {\n AddressPreviousHashPayload,\n AddressPreviousHashSchema,\n CreatableModule,\n CreatableModuleFactory,\n duplicateModules,\n IndividualArchivistConfig,\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 { Promisable, PromiseEx } from '@xyo-network/promise'\nimport { QueryPayload, QuerySchema } from '@xyo-network/query-payload-plugin'\nimport { IdLogger } from '@xyo-network/shared'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nimport { BaseEmitter } from './BaseEmitter'\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 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 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 Error(`Missing configSchema [${params?.config?.schema}][${this.name}]`)\n }\n\n const { account, config, wallet } = params ?? {}\n const { accountDerivationPath } = config ?? {}\n\n assertEx(\n !(!!account && !!wallet),\n `Specifying both {account} and {wallet} are not allowed [${config?.schema}] [${\n account === 'random' ? 'random' : account?.address\n }, ${wallet?.address}]`,\n )\n\n const schema: string = params?.config?.schema ?? this.configSchema\n const allowedSchemas: string[] = this.configSchemas\n\n assertEx(\n allowedSchemas.filter((allowedSchema) => allowedSchema === schema).length > 0,\n `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`,\n )\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, accountDerivationPath, wallet })\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({\n account,\n accountDerivationPath,\n wallet,\n }: {\n account?: AccountInstance | 'random'\n accountDerivationPath?: string\n wallet?: WalletInstance\n }): Promise<AccountInstance> {\n if (wallet) {\n return assertEx(accountDerivationPath ? await wallet.derivePath(accountDerivationPath) : wallet, 'Failed to derive account from path')\n } else if (account === 'random') {\n return await HDWallet.random()\n } else if (account) {\n return account\n } else {\n //this should eventually be removed/thrown\n console.warn('AbstractModule.determineAccount: No account provided - Creating Random account')\n return await HDWallet.random()\n }\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 return await this.busy(async () => {\n const resultPayloads: Payload[] = []\n const errorPayloads: ModuleError[] = []\n const queryAccount = this.ephemeralQueryAccountEnabled ? await HDWallet.random() : undefined\n try {\n await this.started('throw')\n if (!this.allowAnonymous) {\n if (query.addresses.length === 0) {\n throw Error(`Anonymous Queries not allowed, but running anyway [${this.config.name}], [${this.address}]`)\n }\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 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, 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 Error(`Module not Started [${this.address}]`)\n case 'warn':\n this.logger?.warn('Module not started')\n break\n case 'error':\n this.logger?.error('Module not started')\n break\n case 'none':\n break\n case 'log':\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 additionalWitnesses: AccountInstance[] = [],\n errors?: ModuleError[],\n ): Promise<ModuleQueryResult> {\n const builder = new BoundWitnessBuilder().payloads(payloads).errors(errors)\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 commitArchivist = () => this.getArchivist('commit')\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 ? address : undefined\n }) ?? [],\n )\n\n return description\n }\n\n protected discoverHandler(): Promisable<Payload[]> {\n const config = this.config\n const address = new PayloadBuilder<AddressPayload>({ schema: AddressSchema }).fields({ address: this.address, name: this.config?.name }).build()\n const queries = this.queries.map((query) => {\n return new PayloadBuilder<QueryPayload>({ schema: QuerySchema }).fields({ query }).build()\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(kind: keyof IndividualArchivistConfig): Promise<ArchivistInstance | undefined> {\n if (!this.config.archivist) return undefined\n const filter =\n typeof this.config.archivist === 'string' || this.config.archivist instanceof String\n ? (this.config.archivist as string)\n : (this.config?.archivist?.[kind] as string)\n const resolved = await this.upResolver.resolve(filter)\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 resultPayloads.push(...(await this.discoverHandler()))\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 Error(`Unsupported Query [${(queryPayload as Payload).schema}]`)\n }\n return resultPayloads\n }\n\n protected readArchivist = () => this.getArchivist('read')\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 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 case 'object': {\n if (Array.isArray(value)) {\n return (\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 }, true)\n }\n\n protected writeArchivist = () => this.getArchivist('write')\n}\n","import { Base, BaseParams } from '@xyo-network/core'\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","import { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { ModuleError, ModuleErrorSchema } from '@xyo-network/payload-model'\n\nexport class ModuleErrorBuilder extends PayloadBuilder {\n _message?: string\n _name?: string\n _query?: string\n _sources?: string[]\n constructor() {\n super({ schema: ModuleErrorSchema })\n }\n\n override build(): ModuleError {\n return {\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 { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { Address } from '@xyo-network/core'\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 Object.entries(config.security?.allowed).forEach(([schema, addresses]) => {\n this.allowed[schema] = addresses.map(toAddressesString)\n })\n }\n if (config?.security?.disallowed) {\n Object.entries(config.security?.disallowed).forEach(([schema, addresses]) => {\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) 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 { QueryBoundWitness, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\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":["import_boundwitness_builder","import_core","import_payload_builder","BaseEmitter","Base","eventData","events","constructor","params","Events","clearListeners","eventNames","emit","eventName","eventArgs","emitSerial","listenerCount","off","listener","offAny","on","onAny","once","ModuleErrorBuilder","PayloadBuilder","_message","_name","_query","_sources","constructor","schema","ModuleErrorSchema","build","message","name","query","sources","delimiter","ModuleConfigQueryValidator","allowed","disallowed","hasAllowedRules","hasDisallowedRules","hasRules","constructor","config","security","Object","entries","forEach","schema","addresses","map","toAddressesString","keys","length","queryable","query","payloads","wrapper","QueryBoundWitnessWrapper","parseQuery","getQuery","queryAllowed","queryDisallowed","signatories","validCosigners","includes","every","address","some","Array","isArray","sort","toLowerCase","join","import_boundwitness_builder","isQuerySupportedByModule","mod","query","payloads","wrapper","QueryBoundWitnessWrapper","parseQuery","schema","getQuery","queries","includes","SupportedQueryValidator","constructor","queryable","AbstractModule","BaseEmitter","configSchemas","enableLazyLoad","privateConstructorKey","Date","now","toString","downResolver","CompositeModuleResolver","upResolver","_account","undefined","_baseModuleQueryAccountPaths","ModuleAddressQuerySchema","ModuleDescribeQuerySchema","ModuleDiscoverQuerySchema","ModuleManifestQuerySchema","ModuleSubscribeQuerySchema","_queryAccounts","_startPromise","_started","moduleConfigQueryValidator","supportedQueryValidator","_busyCount","constructor","params","account","assertEx","mutatedParams","SupportedQueryValidator","queryable","ModuleConfigQueryValidator","config","configSchema","address","allowAnonymous","security","ephemeralQueryAccountEnabled","queries","queryAccountPaths","_queryAccountPaths","queryAccounts","timestamp","_getRootFunction","funcName","anyThis","__proto__","_noOverride","functionName","thisFunc","rootFunc","create","length","Error","schema","name","wallet","accountDerivationPath","allowedSchemas","filter","allowedSchema","JSON","stringify","mutatedConfig","logger","debug","activeLogger","defaultLogger","generatedAccount","determineAccount","IdLogger","newModule","start","derivePath","HDWallet","random","console","warn","factory","ModuleFactory","withParams","busy","closure","args","module","emit","eventName","eventArgs","previousHash","query","payloads","queryConfig","resultPayloads","errorPayloads","queryAccount","started","addresses","push","queryHandler","QueryBoundWitnessWrapper","unwrap","ex","handleErrorAsync","error","ModuleErrorBuilder","sources","PayloadHasher","hashAsync","message","build","result","bindQueryResult","configValidator","Object","assign","validators","every","validator","resolve","nameOrAddressOrFilter","options","direction","up","down","duplicateModules","_timeout","startHandler","notStartedAction","tryStart","handleError","log","stop","stopHandler","bindHashes","hashes","promise","PromiseEx","bindHashesInternal","builder","BoundWitnessBuilder","witness","bindQuery","bindQueryInternal","QueryBoundWitnessBuilder","additionalWitnesses","errors","queryWitnessAccount","witnesses","exists","archiving","storeToArchivists","flat","commitArchivist","getArchivist","describeHandler","description","ModuleDescriptionSchema","discover","discoverHandler","children","compact","map","payload","AddressSchema","PayloadBuilder","fields","QuerySchema","ConfigSchema","kind","archivist","String","resolved","asArchivistInstance","initializeQueryAccounts","paths","values","distinctPaths","Set","size","key","prototype","hasOwnProperty","call","queryAccountPath","manifestHandler","_depth","_ignoreAddresses","ModuleManifestPayloadSchema","status","moduleAddressHandler","entries","value","AddressPreviousHashSchema","moduleAccount","moduleAccountPreviousHash","wrapper","parseQuery","queryPayload","getQuery","maxDepth","subscribeHandler","readArchivist","resolveArchivingArchivists","archivists","Promise","all","mod","validateConfig","insert","bw","parents","reduce","valid","join","Array","isArray","serializableField","writeArchivist","import_assert","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/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 { exists } from '@xylabs/exists'\nimport { compact } from '@xylabs/lodash'\nimport { 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/core'\nimport { handleError, handleErrorAsync } from '@xyo-network/error'\nimport { ModuleManifestPayload, ModuleManifestPayloadSchema } from '@xyo-network/manifest-model'\nimport {\n AddressPreviousHashPayload,\n AddressPreviousHashSchema,\n CreatableModule,\n CreatableModuleFactory,\n duplicateModules,\n IndividualArchivistConfig,\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 { Promisable, PromiseEx } from '@xyo-network/promise'\nimport { QueryPayload, QuerySchema } from '@xyo-network/query-payload-plugin'\nimport { IdLogger } from '@xyo-network/shared'\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 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 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 Error(`Missing configSchema [${params?.config?.schema}][${this.name}]`)\n }\n\n const { account, config, wallet } = params ?? {}\n const { accountDerivationPath } = config ?? {}\n\n assertEx(\n !(!!account && !!wallet),\n `Specifying both {account} and {wallet} are not allowed [${config?.schema}] [${\n account === 'random' ? 'random' : account?.address\n }, ${wallet?.address}]`,\n )\n\n const schema: string = params?.config?.schema ?? this.configSchema\n const allowedSchemas: string[] = this.configSchemas\n\n assertEx(\n allowedSchemas.filter((allowedSchema) => allowedSchema === schema).length > 0,\n `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`,\n )\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, accountDerivationPath, wallet })\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 accountDerivationPath?: string\n wallet?: WalletInstance\n }): Promise<AccountInstance> {\n return await determineAccount(params)\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 ? await HDWallet.random() : undefined\n try {\n await this.started('throw')\n if (!this.allowAnonymous) {\n if (query.addresses.length === 0) {\n throw Error(`Anonymous Queries not allowed, but running anyway [${this.config.name}], [${this.address}]`)\n }\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 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 Error(`Module not Started [${this.address}]`)\n case 'warn':\n this.logger?.warn('Module not started')\n break\n case 'error':\n this.logger?.error('Module not started')\n break\n case 'none':\n break\n case 'log':\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 commitArchivist = () => this.getArchivist('commit')\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 ? address : undefined\n }) ?? [],\n )\n\n return description\n }\n\n protected discoverHandler(): Promisable<Payload[]> {\n const config = this.config\n const address = new PayloadBuilder<AddressPayload>({ schema: AddressSchema }).fields({ address: this.address, name: this.config?.name }).build()\n const queries = this.queries.map((query) => {\n return new PayloadBuilder<QueryPayload>({ schema: QuerySchema }).fields({ query }).build()\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(kind: keyof IndividualArchivistConfig): Promise<ArchivistInstance | undefined> {\n if (!this.config.archivist) return undefined\n const filter =\n typeof this.config.archivist === 'string' || this.config.archivist instanceof String\n ? (this.config.archivist as string)\n : (this.config?.archivist?.[kind] as string)\n const resolved = await this.upResolver.resolve(filter)\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 resultPayloads.push(...(await this.discoverHandler()))\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 Error(`Unsupported Query [${(queryPayload as Payload).schema}]`)\n }\n return resultPayloads\n }\n\n protected readArchivist = () => this.getArchivist('read')\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 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 case 'object': {\n if (Array.isArray(value)) {\n return (\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 }, true)\n }\n\n protected writeArchivist = () => this.getArchivist('write')\n}\n","import { Base, BaseParams } from '@xyo-network/core'\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 { HDWallet } from '@xyo-network/account'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nexport const determineAccount = async ({\n account,\n accountDerivationPath,\n wallet,\n}: {\n account?: AccountInstance | 'random'\n accountDerivationPath?: string\n wallet?: WalletInstance\n}): Promise<AccountInstance> => {\n if (wallet) {\n return assertEx(accountDerivationPath ? await wallet.derivePath(accountDerivationPath) : wallet, 'Failed to derive account from path')\n } else if (account === 'random') {\n return await HDWallet.random()\n } else if (account) {\n return account\n } else {\n //this should eventually be removed/thrown\n console.warn('AbstractModule.determineAccount: No account provided - Creating Random account')\n return await HDWallet.random()\n }\n}\n","import { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { ModuleError, ModuleErrorSchema } from '@xyo-network/payload-model'\n\nexport class ModuleErrorBuilder extends PayloadBuilder {\n _message?: string\n _name?: string\n _query?: string\n _sources?: string[]\n constructor() {\n super({ schema: ModuleErrorSchema })\n }\n\n override build(): ModuleError {\n return {\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 { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { Address } from '@xyo-network/core'\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 Object.entries(config.security?.allowed).forEach(([schema, addresses]) => {\n this.allowed[schema] = addresses.map(toAddressesString)\n })\n }\n if (config?.security?.disallowed) {\n Object.entries(config.security?.disallowed).forEach(([schema, addresses]) => {\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) 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":";;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;;;;;;;ACCA,IAAAA,iBAAyB;AACzB,oBAAuB;AACvB,oBAAwB;AACxB,IAAAC,kBAAyB;AAEzB,oCAA8C;AAC9C,6BAAuD;AACvD,IAAAC,+BAAwF;AAExF,mCAA4C;AAC5C,IAAAC,eAA8B;AAC9B,mBAA8C;AAC9C,4BAAmE;AACnE,0BA8BO;AACP,6BAAwC;AACxC,IAAAC,0BAA+B;AAE/B,qBAAsC;AACtC,kCAA0C;AAC1C,oBAAyB;;;AClDzB,kBAAiC;AACjC,2BAAmF;AAE5E,IAAMC,cAAN,cACGC,iBAAAA;EAJV,OAIUA;;;;EAIRC,YAAY,CAAC;EAELC;EAERC,YAAYC,QAAiB;AAC3B,UAAMA,MAAAA;AACN,SAAKF,SAAS,IAAIG,4BAAAA;EACpB;EAEAC,eAAeC,YAAqD;AAClE,WAAO,KAAKL,OAAOI,eAAeC,UAAAA;EACpC;EAEAC,KACEC,WACAC,WACA;AACA,WAAO,KAAKR,OAAOM,KAAKC,WAAWC,SAAAA;EACrC;EAEAC,WACEF,WACAC,WACA;AACA,WAAO,KAAKR,OAAOS,WAAWF,WAAWC,SAAAA;EAC3C;EAEAE,cAAcL,YAAqD;AACjE,WAAO,KAAKL,OAAOU,cAAcL,UAAAA;EACnC;EAEAM,IAAyCN,YAAuCO,UAAiD;AAC/H,WAAO,KAAKZ,OAAOW,IAAIN,YAAYO,QAAAA;EACrC;EAEAC,OAAOD,UAA4B;AACjC,WAAO,KAAKZ,OAAOa,OAAOD,QAAAA;EAC5B;EAEAE,GAAwCT,YAAuCO,UAAiD;AAC9H,WAAO,KAAKZ,OAAOc,GAAGT,YAAYO,QAAAA;EACpC;EAEAG,MAAMH,UAA4B;AAChC,WAAO,KAAKZ,OAAOe,MAAMH,QAAAA;EAC3B;EAEAI,KAA0CT,WAAuBK,UAAiD;AAChH,WAAO,KAAKZ,OAAOgB,KAAKT,WAAWK,QAAAA;EACrC;AACF;;;ACzDA,oBAAyB;AACzB,qBAAyB;AAIlB,IAAMK,mBAAmB,8BAAO,EACrCC,SACAC,uBACAC,OAAM,MAKP;AACC,MAAIA,QAAQ;AACV,eAAOC,wBAASF,wBAAwB,MAAMC,OAAOE,WAAWH,qBAAAA,IAAyBC,QAAQ,oCAAA;EACnG,WAAWF,YAAY,UAAU;AAC/B,WAAO,MAAMK,wBAASC,OAAM;EAC9B,WAAWN,SAAS;AAClB,WAAOA;EACT,OAAO;AAELO,YAAQC,KAAK,gFAAA;AACb,WAAO,MAAMH,wBAASC,OAAM;EAC9B;AACF,GApBgC;;;ACNhC,6BAA+B;AAC/B,2BAA+C;AAExC,IAAMG,qBAAN,cAAiCC,sCAAAA;EAHxC,OAGwCA;;;EACtCC;EACAC;EACAC;EACAC;EACAC,cAAc;AACZ,UAAM;MAAEC,QAAQC;IAAkB,CAAA;EACpC;EAESC,QAAqB;AAC5B,WAAO;MACLC,SAAS,KAAKR;MACdS,MAAM,KAAKR;MACXS,OAAO,KAAKR;MACZG,QAAQC;MACRK,SAAS,KAAKR;IAChB;EACF;EAEAK,QAAQA,SAAiB;AACvB,SAAKR,WAAWQ;AAChB,WAAO;EACT;EAEAC,KAAKA,MAAc;AACjB,SAAKR,QAAQQ;AACb,WAAO;EACT;EAEAC,MAAMA,OAAe;AACnB,SAAKR,SAASQ;AACd,WAAO;EACT;EAEAC,QAAQA,SAAmB;AACzB,SAAKR,WAAWQ;AAChB,WAAO;EACT;AACF;;;ACzCA,kCAAyC;AAQzC,IAAMC,YAAY;AAEX,IAAMC,6BAAN,MAAMA;EAVb,OAUaA;;;EACDC,UAA8D,CAAC;EAC/DC,aAA8C,CAAC;EACtCC;EACAC;EACAC;EAEnBC,YAAYC,QAAkB;AAC5B,QAAIA,QAAQC,UAAUP,SAAS;AAC7BQ,aAAOC,QAAQH,OAAOC,UAAUP,OAAAA,EAASU,QAAQ,CAAC,CAACC,QAAQC,SAAAA,MAAU;AACnE,aAAKZ,QAAQW,MAAAA,IAAUC,UAAUC,IAAIC,iBAAAA;MACvC,CAAA;IACF;AACA,QAAIR,QAAQC,UAAUN,YAAY;AAChCO,aAAOC,QAAQH,OAAOC,UAAUN,UAAAA,EAAYS,QAAQ,CAAC,CAACC,QAAQC,SAAAA,MAAU;AACtE,aAAKX,WAAWU,MAAAA,IAAUC,UAAUC,IAAIC,iBAAAA;MAC1C,CAAA;IACF;AACA,SAAKZ,kBAAkBM,OAAOO,KAAK,KAAKf,OAAO,EAAEgB,SAAS;AAC1D,SAAKb,qBAAqBK,OAAOO,KAAK,KAAKd,UAAU,EAAEe,SAAS;AAChE,SAAKZ,WAAW,KAAKF,mBAAmB,KAAKC;EAC/C;EAEAc,YAAuB,OAAOC,OAAOC,aAAAA;AACnC,QAAI,CAAC,KAAKf;AAAU,aAAO;AAC3B,UAAMQ,YAAYM,MAAMN;AACxB,QAAI,CAACA,UAAUI;AAAQ,aAAO;AAC9B,UAAMI,UAAUC,qDAAyBC,WAAwBJ,OAAOC,QAAAA;AACxE,UAAMR,UAAU,MAAMS,QAAQG,SAAQ,GAAIZ;AAC1C,WAAO,KAAKa,aAAab,QAAQC,SAAAA,KAAc,CAAC,KAAKa,gBAAgBd,QAAQC,SAAAA;EAC/E;EAEUY,eAAe,CAACb,QAAsBC,cAAAA;AAC9C,QAAI,CAAC,KAAKV;AAAiB,aAAO;AAElC,QAAIU,UAAUI,SAAS,GAAG;AACxB,YAAMU,cAAcZ,kBAAkBF,SAAAA;AACtC,YAAMe,iBAAiB,KAAK3B,UAAUW,MAAAA,GAASiB,SAASF,WAAAA;AACxD,UAAIC;AAAgB,eAAO;IAC7B;AAEA,WAAOf,UAAUiB,MAAM,CAACC,YAAY,KAAK9B,UAAUW,MAAAA,GAASiB,SAASE,OAAAA,KAAY,KAAA;EACnF;EACUL,kBAAkB,CAACd,QAAsBC,cAAAA;AACjD,QAAI,CAAC,KAAKT;AAAoB,aAAO;AACrC,WAAOS,UAAUmB,KAAK,CAACD,YAAY,KAAK7B,aAAaU,MAAAA,GAASiB,SAASE,OAAAA,CAAAA;EACzE;AACF;AAGA,IAAMhB,oBAAoB,wBAACF,cAAAA;AACzB,SAAOoB,MAAMC,QAAQrB,SAAAA,IACjBA,UACGsB,KAAI,EACJrB,IAAI,CAACiB,YAAYA,QAAQK,YAAW,CAAA,EACpCC,KAAKtC,SAAAA,IACRc,UAAUuB,YAAW;AAC3B,GAP0B;;;AC5D1B,IAAAE,+BAAyC;AAOlC,IAAMC,2BAA2B,8BACtCC,KACAC,OACAC,aAAAA;AAEA,QAAMC,UAAUC,sDAAyBC,WAAwBJ,OAAOC,QAAAA;AACxE,QAAMI,UAAU,MAAMH,QAAQI,SAAQ,GAAID;AAC1C,SAAON,IAAIQ,QAAQC,SAASH,MAAAA;AAC9B,GARwC;AAUjC,IAAMI,0BAAN,MAAMA;EAjBb,OAiBaA;;;;EACXC,YAA+BX,KAAa;SAAbA,MAAAA;SAC/BY,YAAuB,CAACX,OAAOC,aAAAA;AAC7B,aAAOH,yBAAyB,KAAKC,KAAKC,OAAOC,QAAAA;IACnD;EAH6C;EAC7CU;AAGF;;;ALoCO,IAAeC,iBAAf,MAAeA,wBACZC,YAAAA;EA3DV,OA2DUA;;;EAGR,OAAOC;EACP,OAAOC,iBAAiB;EAExB,OAAiBC,wBAAwBC,KAAKC,IAAG,EAAGC,SAAQ;EAEnDC,eAAyD,IAAIC,+CAAAA;EAC7DC,aAAwD,IAAID,+CAAAA;EAE3DE,WAAwCC;EAC/BC,+BAA0E;IAC3F,CAACC,4CAAAA,GAA2B;IAC5B,CAACC,6CAAAA,GAA4B;IAC7B,CAACC,6CAAAA,GAA4B;IAC7B,CAACC,6CAAAA,GAA4B;IAC7B,CAACC,8CAAAA,GAA6B;EAChC;EACmBC,iBAAiF;IAClG,CAACL,4CAAAA,GAA2BF;IAC5B,CAACG,6CAAAA,GAA4BH;IAC7B,CAACI,6CAAAA,GAA4BJ;IAC7B,CAACK,6CAAAA,GAA4BL;IAC7B,CAACM,8CAAAA,GAA6BN;EAChC;EACUQ,gBAAiDR;EACjDS,WAA4CT;EACnCU;EACAC;EAEXC,aAAa;EAErBC,YAAYrB,uBAA+BsB,QAAiBC,SAA0B;AACpFC,iCAAS5B,gBAAeI,0BAA0BA,uBAAuB,4CAAA;AAEzE,UAAMyB,gBAAgB;MAAE,GAAGH;IAAO;AAClC,UAAMG,aAAAA;AAEN,SAAKlB,WAAWgB;AAEhB,SAAKJ,0BAA0B,IAAIO,wBAAwB,IAAI,EAAYC;AAC3E,SAAKT,6BAA6B,IAAIU,2BAA2BH,eAAeI,MAAAA,EAAQF;EAC1F;EAEA,WAAWG,eAAuB;AAChC,WAAO,KAAKhC,cAAc,CAAA;EAC5B;EAEA,IAAIyB,UAAU;AACZ,eAAOC,yBAAS,KAAKjB,UAAU,iBAAA;EACjC;EAEA,IAAIwB,UAAU;AACZ,WAAO,KAAKR,QAAQQ;EACtB;EAEA,IAAIC,iBAAiB;AACnB,WAAO,CAAC,CAAC,KAAKH,OAAOI,UAAUD;EACjC;EAEA,IAAIH,SAA4B;AAC9B,WAAO,KAAKP,OAAOO;EACrB;EAEA,IAAIK,+BAAwC;AAC1C,WAAO,CAAC,CAAC,KAAKZ,OAAOY;EACvB;EAEA,IAAIC,UAAoB;AACtB,WAAO;MAACvB;MAA2BF;MAA0BI;MAA4BH;MAA2BE;;EACtH;EAEA,IAAIuB,oBAA2E;AAC7E,WAAO;MAAE,GAAG,KAAK3B;MAA8B,GAAG,KAAK4B;IAAmB;EAC5E;EAEA,IAAIC,gBAAgF;AAClF,WAAO,KAAKvB;EACd;EAEA,IAAIwB,YAAY;AACd,WAAO,KAAKV,OAAOU,aAAa;EAClC;EAIA,OAAOC,iBAAiBC,UAAkB;AAExC,QAAIC,UAAU;AACd,WAAOA,QAAQC,UAAUF,QAAAA,GAAW;AAClCC,gBAAUA,QAAQC;IACpB;AACA,WAAOD,QAAQD,QAAAA;EACjB;EAEA,OAAOG,YAAYC,cAAsB;AAEvC,UAAMC,WAAY,KAAaD,YAAAA;AAE/B,UAAME,WAAW,KAAKP,iBAAiBK,YAAAA;AACvCrB,iCAASsB,aAAaC,UAAU,6BAA6BF,YAAAA,gBAA4BA,YAAAA,iBAA6B;EACxH;EAEA,aAAaG,OAEX1B,QACA;AACA,SAAKsB,YAAY,QAAA;AACjB,QAAI,CAAC,KAAK9C,iBAAiB,KAAKA,cAAcmD,WAAW,GAAG;AAC1D,YAAMC,MAAM,yBAAyB5B,QAAQO,QAAQsB,MAAAA,KAAW,KAAKC,IAAI,GAAG;IAC9E;AAEA,UAAM,EAAE7B,SAASM,QAAQwB,OAAM,IAAK/B,UAAU,CAAC;AAC/C,UAAM,EAAEgC,sBAAqB,IAAKzB,UAAU,CAAC;AAE7CL,iCACE,EAAE,CAAC,CAACD,WAAW,CAAC,CAAC8B,SACjB,2DAA2DxB,QAAQsB,MAAAA,MACjE5B,YAAY,WAAW,WAAWA,SAASQ,OAAAA,KACxCsB,QAAQtB,OAAAA,GAAU;AAGzB,UAAMoB,SAAiB7B,QAAQO,QAAQsB,UAAU,KAAKrB;AACtD,UAAMyB,iBAA2B,KAAKzD;AAEtC0B,iCACE+B,eAAeC,OAAO,CAACC,kBAAkBA,kBAAkBN,MAAAA,EAAQF,SAAS,GAC5E,+BAA+BE,MAAAA,eAAqBO,KAAKC,UAAUJ,cAAAA,CAAAA,GAAkB;AAEvF,UAAMK,gBAA6C;MAAE,GAAGtC,QAAQO;MAAQsB;IAAO;AAC/E7B,YAAQuC,QAAQC,MAAM,WAAWJ,KAAKC,UAAUC,eAAe,MAAM,CAAA,CAAA,EAAI;AACzE,UAAMnC,gBAAmC;MAAE,GAAGH;MAAQO,QAAQ+B;IAAc;AAE5E,UAAMG,eAAezC,QAAQuC,UAAUjE,gBAAeoE;AACtD,UAAMC,mBAAmB,MAAMrE,gBAAesE,iBAAiB;MAAE3C;MAAS+B;MAAuBD;IAAO,CAAA;AACxG,UAAMtB,UAAUkC,iBAAiBlC;AACjCN,kBAAcoC,SAASE,eAAe,IAAII,uBAASJ,cAAc,MAAM,KAAKhC,OAAAA,EAAS,IAAIvB;AAEzF,UAAM4D,YAAY,IAAI,KAAKxE,gBAAeI,uBAAuByB,eAAewC,gBAAAA;AAEhF,QAAI,CAACrE,gBAAeG,gBAAgB;AAClC,YAAMqE,UAAUC,QAAK;IACvB;AACA,WAAOD;EACT;EAEA,aAAaF,iBAAiB5C,QAID;AAC3B,WAAO,MAAM4C,iBAAiB5C,MAAAA;EAChC;EAEA,OAAOgD,QAELhD,QACiC;AACjC,WAAOiD,kCAAcC,WAAW,MAAMlD,MAAAA;EACxC;EAEAkB,iBAAiBC,UAAkB;AAEjC,QAAIC,UAAU;AACd,WAAOA,QAAQC,UAAUF,QAAAA,GAAW;AAClCC,gBAAUA,QAAQC;IACpB;AACA,WAAOD,QAAQD,QAAAA;EACjB;EAEAG,YAAYC,cAAsB;AAEhC,UAAMC,WAAY,KAAaD,YAAAA;AAE/B,UAAME,WAAW,KAAKP,iBAAiBK,YAAAA;AACvCrB,iCAASsB,aAAaC,UAAU,6BAA6BF,YAAAA,gBAA4BA,YAAAA,iBAA6B;EACxH;EAEA,MAAM4B,KAAQC,SAA2B;AACvC,QAAI,KAAKtD,cAAc,GAAG;AACxB,WAAKA,aAAa;AAClB,YAAMuD,OAA4B;QAAEF,MAAM;QAAMG,QAAQ;MAAK;AAC7D,YAAM,KAAKC,KAAK,cAAcF,IAAAA;IAChC;AACA,SAAKvD;AACL,QAAI;AACF,aAAO,MAAMsD,QAAAA;IACf,UAAA;AACE,WAAKtD;AACL,UAAI,KAAKA,cAAc,GAAG;AACxB,aAAKA,aAAa;AAClB,cAAMuD,OAA4B;UAAEF,MAAM;UAAOG,QAAQ;QAAK;AAC9D,cAAM,KAAKC,KAAK,cAAcF,IAAAA;MAChC;IACF;EACF;EAESE,KACPC,WACAC,WACA;AACA,WAAO,MAAMF,KAAKC,WAAWC,SAAAA;EAC/B;EAEAC,eAA+C;AAC7C,WAAO,KAAKzD,QAAQyD;EACtB;EAEA,MAAMC,MACJA,OACAC,UACAC,aAC4B;AAC5B,SAAKvC,YAAY,OAAA;AACjB,UAAMwC,cAAc,MAAMC,2BAAcC,UAAUL,KAAAA;AAClD,WAAO,MAAM,KAAKR,KAAK,YAAA;AACrB,YAAMc,iBAA4B,CAAA;AAClC,YAAMC,gBAA+B,CAAA;AACrC,YAAMC,eAAe,KAAKvD,+BAA+B,MAAMwD,yBAASC,OAAM,IAAKnF;AACnF,UAAI;AACF,cAAM,KAAKoF,QAAQ,OAAA;AACnB,YAAI,CAAC,KAAK5D,gBAAgB;AACxB,cAAIiD,MAAMY,UAAU5C,WAAW,GAAG;AAChC,kBAAMC,MAAM,sDAAsD,KAAKrB,OAAOuB,IAAI,OAAO,KAAKrB,OAAO,GAAG;UAC1G;QACF;AACAwD,uBAAeO,KAAI,GAAK,MAAM,KAAKC,iBAAavE,yBAASwE,sDAAyBC,OAAOhB,KAAAA,CAAAA,GAASC,UAAUC,WAAAA,CAAAA;MAC9G,SAASe,IAAI;AACX,kBAAMC,+BAAiBD,IAAI,OAAOE,UAAAA;AAChCZ,wBAAcM,KACZ,IAAIO,mBAAAA,EACDC,QAAQ;YAAC,MAAMjB,2BAAcC,UAAUL,KAAAA;WAAO,EAC9C7B,KAAK,KAAKvB,OAAOuB,QAAQ,WAAA,EACzB6B,MAAMA,MAAM9B,MAAM,EAClBoD,QAAQH,MAAMG,OAAO,EACrBC,MAAK,CAAA;QAEZ,CAAA;MACF;AACA,UAAI,KAAKjE,WAAW;AAClB,cAAMA,YAAY;UAAEY,QAAQ;UAAyBZ,WAAWtC,KAAKC,IAAG;QAAG;AAC3EqF,uBAAeO,KAAKvD,SAAAA;MACtB;AACA,YAAMkE,SAAS,MAAM,KAAKC,gBAAgBzB,OAAOM,gBAAgBH,aAAaK,eAAe;QAACA;UAAgB,CAAA,GAAID,aAAAA;AAClH,YAAMb,OAA+B;QAAEC,QAAQ;QAAMM;QAAUD;QAAOwB;MAAO;AAC7E,YAAM,KAAK5B,KAAK,iBAAiBF,IAAAA;AACjC,aAAO8B;IACT,CAAA;EACF;EAEA9E,UACEsD,OACAC,UACAC,aACS;AACT,QAAI,CAAC,KAAKS,QAAQ,MAAA;AAAS,aAAO;AAClC,UAAMe,kBAAkBxB,cACpB,IAAIvD,2BAA2BgF,OAAOC,OAAO,CAAC,GAAG,KAAKhF,QAAQsD,WAAAA,CAAAA,EAAcxD,YAC5E,KAAKT;AACT,UAAM4F,aAAa;MAAC,KAAK3F;MAAyBwF;;AAElD,WAAOG,WAAWC,MAAM,CAACC,cAAcA,UAAU/B,OAAOC,QAAAA,CAAAA;EAC1D;EAIA,MAAM+B,QACJC,uBACAC,SAC8B;AAC9B,UAAMC,YAAYD,SAASC,aAAa;AACxC,UAAMC,KAAKD,cAAc,QAAQA,cAAc;AAC/C,UAAME,OAAOF,cAAc,UAAUA,cAAc;AACnD,YAAQ,OAAOF,uBAAAA;MACb,KAAK,UAAU;AACb,gBACGI,OAAO,MAAO,KAAKlH,aAAyC6G,QAAWC,uBAAuBC,OAAAA,IAAW3G,YACzG6G,KAAK,MAAO,KAAK/G,WAAuC2G,QAAWC,uBAAuBC,OAAAA,IAAW3G;MAE1G;MACA,SAAS;AACP,cAAMgD,SAAsC0D;AAC5C,eAAO;aACDI,OAAO,MAAO,KAAKlH,aAAyC6G,QAAWzD,QAAQ2D,OAAAA,IAAW,CAAA;aAC1FE,KAAK,MAAO,KAAK/G,WAAuC2G,QAAWzD,QAAQ2D,OAAAA,IAAW,CAAA;UAC1F3D,OAAO+D,oCAAAA;MACX;IACF;EACF;EAEAlD,MAAMmD,UAAwC;AAE5C,SAAKxG,gBAAgB,KAAKA,iBAAiB,KAAKyG,aAAY;AAC5D,WAAO,KAAKzG;EACd;EAEA,MAAM4E,QAAQ8B,mBAAgE,OAAOC,WAAW,MAAwB;AACtH,UAAM/B,UAAU,MAAM,KAAK3E;AAC3B,QAAI2E,YAAY,MAAM;AACpB,aAAO;IACT;AACA,QAAI,CAACA,SAAS;AAEZ,WAAK3E,YAAY,YAAA;AACf,YAAI0G,UAAU;AACZ,cAAI;AACF,kBAAM,KAAKtD,MAAK;AAChB,mBAAO;UACT,SAAS6B,IAAI;AACX0B,0CAAY1B,IAAI,CAACE,UAAAA;AACf,mBAAKvC,QAAQgE,KAAK,+BAA+BzB,MAAMG,OAAO,GAAG;AACjE,mBAAKtF,WAAWT;YAClB,CAAA;UACF;QACF;AACA,gBAAQkH,kBAAAA;UACN,KAAK;AACH,kBAAMxE,MAAM,uBAAuB,KAAKnB,OAAO,GAAG;UACpD,KAAK;AACH,iBAAK8B,QAAQgE,KAAK,oBAAA;AAClB;UACF,KAAK;AACH,iBAAKhE,QAAQuC,MAAM,oBAAA;AACnB;UACF,KAAK;AACH;UACF,KAAK;UACL,SAAS;AACP,iBAAKvC,QAAQiE,IAAI,oBAAA;AACjB;UACF;QACF;AACA,eAAO;MACT,GAAA;IACF;AACA,QAAI,CAAC,KAAK7G,UAAU;AAClB,YAAM;IACR;AACA,WAAO,MAAM,KAAKA;EACpB;EAEA,MAAM8G,KAAKP,UAAqC;AAC9C,WAAO,MAAM,KAAK/C,KAAK,YAAA;AACrB,YAAMgC,SAAS,MAAM,KAAKuB,YAAW;AACrC,WAAK/G,WAAWT;AAChB,WAAKQ,gBAAgBR;AACrB,aAAOiG;IACT,CAAA;EACF;EAEUwB,WAAWC,QAAkB/E,QAAwB5B,SAA2B;AACxF,UAAM4G,UAAU,IAAIC,yBAAU,CAACnB,YAAAA;AAC7B,YAAMR,SAAS,KAAK4B,mBAAmBH,QAAQ/E,QAAQ5B,OAAAA;AACvD0F,gBAAUR,MAAAA;AACV,aAAOA;IACT,GAAGlF,OAAAA;AACH,WAAO4G;EACT;EAEA,MAAgBE,mBAAmBH,QAAkB/E,QAAwB5B,SAAkD;AAC7H,UAAM+G,UAAU,IAAIC,iDAAAA,EAAsBL,OAAOA,QAAQ/E,MAAAA,EAAQqF,QAAQ,KAAKjH,OAAO;AACrF,UAAMkF,UAAU,OAAOlF,UAAU+G,QAAQE,QAAQjH,OAAAA,IAAW+G,SAAS9B,MAAK,GAAI,CAAA;AAC9E,SAAK3C,QAAQC,MAAM,WAAWJ,KAAKC,UAAU8C,QAAQ,MAAM,CAAA,CAAA,EAAI;AAC/D,WAAOA;EACT;EAEUgC,UACRxD,OACAC,UACA3D,SACuE;AACvE,UAAM4G,UAAU,IAAIC,yBAAsE,OAAOnB,YAAAA;AAC/F,YAAMR,SAAS,MAAM,KAAKiC,kBAAkBzD,OAAOC,UAAU3D,OAAAA;AAC7D0F,gBAAUR,MAAAA;AACV,aAAOA;IACT,GAAGlF,OAAAA;AACH,WAAO4G;EACT;EAEA,MAAgBO,kBACdzD,OACAC,UACA3D,SACoD;AACpD,UAAM+G,UAAU,IAAIK,sDAAAA,EAA2BzD,SAASA,QAAAA,EAAUsD,QAAQ,KAAKjH,OAAO,EAAE0D,MAAMA,KAAAA;AAC9F,UAAMwB,SAAS,OAAOlF,UAAU+G,QAAQE,QAAQjH,OAAAA,IAAW+G,SAAS9B,MAAK;AACzE,WAAOC;EACT;EAEA,MAAgBC,gBACdzB,OACAC,UACAE,aACAwD,sBAAyC,CAAA,GACzCC,QAC4B;AAC5B,UAAMP,UAAU,IAAIC,iDAAAA,EAAsBrD,SAASA,QAAAA,EAAU2D,OAAOA,MAAAA,EAAQzD,YAAYA,WAAAA;AACxF,UAAM0D,sBAAsB,KAAKxG,cAAc2C,MAAM9B,MAAM;AAC3D,UAAM4F,YAAY;MAAC,KAAKxH;MAASuH;SAAwBF;MAAqBpF,OAAOwF,oBAAAA;AACrFV,YAAQS,UAAUA,SAAAA;AAClB,UAAMtC,SAA4B;OAAE,MAAM6B,QAAQ9B,MAAK,GAAI,CAAA;MAAItB;MAAU2D,UAAU,CAAA;;AACnF,QAAI,KAAKhH,OAAOoH,WAAW;AACzB,YAAM,KAAKC,kBAAkBzC,OAAO0C,KAAI,CAAA;IAC1C;AACA,WAAO1C;EACT;EAEU2C,kBAAkB,MAAM,KAAKC,aAAa,QAAA;EAEpD,MAAgBC,kBAAqD;AACnE,UAAMC,cAAwC;MAC5CxH,SAAS,KAAKA;MACdI,SAAS,KAAKA;MACdgB,QAAQqG;IACV;AACA,QAAI,KAAK3H,QAAQuB,MAAM;AACrBmG,kBAAYnG,OAAO,KAAKvB,OAAOuB;IACjC;AAEA,UAAMqG,WAAW,MAAM,KAAKC,gBAAe;AAE3CH,gBAAYI,eAAWC,uBACrBH,UAAUI,IAAI,CAACC,YAAAA;AACb,YAAM/H,UAAU+H,QAAQ3G,WAAW4G,8CAAiBD,QAA2B/H,UAAUvB;AACzF,aAAOuB,WAAW,KAAKA,UAAUA,UAAUvB;IAC7C,CAAA,KAAM,CAAA,CAAE;AAGV,WAAO+I;EACT;EAEUG,kBAAyC;AACjD,UAAM7H,SAAS,KAAKA;AACpB,UAAME,UAAU,IAAIiI,uCAA+B;MAAE7G,QAAQ4G;IAAc,CAAA,EAAGE,OAAO;MAAElI,SAAS,KAAKA;MAASqB,MAAM,KAAKvB,QAAQuB;IAAK,CAAA,EAAGoD,MAAK;AAC9I,UAAMrE,UAAU,KAAKA,QAAQ0H,IAAI,CAAC5E,UAAAA;AAChC,aAAO,IAAI+E,uCAA6B;QAAE7G,QAAQ+G;MAAY,CAAA,EAAGD,OAAO;QAAEhF;MAAM,CAAA,EAAGuB,MAAK;IAC1F,CAAA;AACA,UAAM1E,eAA8B;MAClCD,QAAQA,OAAOsB;MACfA,QAAQgH;IACV;AACA,eAAOP,uBAAQ;MAAC/H;MAAQC;MAAcC;SAAYI;KAAQ;EAC5D;EAEA,MAAgBkH,aAAae,MAA+E;AAC1G,QAAI,CAAC,KAAKvI,OAAOwI;AAAW,aAAO7J;AACnC,UAAMgD,SACJ,OAAO,KAAK3B,OAAOwI,cAAc,YAAY,KAAKxI,OAAOwI,qBAAqBC,SACzE,KAAKzI,OAAOwI,YACZ,KAAKxI,QAAQwI,YAAYD,IAAAA;AAChC,UAAMG,WAAW,MAAM,KAAKjK,WAAW2G,QAAQzD,MAAAA;AAC/C,eAAOgH,4CAAoBD,QAAAA;EAC7B;EAEA,MAAgBE,0BAA0B;AAExC,UAAMC,QAAQ9D,OAAO+D,OAAO,KAAKvI,iBAAiB,EAAEoB,OAAOwF,oBAAAA;AAC3D,UAAM4B,gBAAgB,IAAIC,IAAYH,KAAAA;AACtClJ,iCAASoJ,cAAcE,SAASJ,MAAMzH,QAAQ,GAAG,KAAKpB,QAAQuB,OAAO,KAAKvB,OAAOuB,OAAO,OAAO,EAAA,+BAAiC;AAEhI,UAAMC,SAAS,KAAK9B;AACpB,QAAI8B,QAAQ0H,YAAY;AACtB,iBAAWC,OAAO,KAAK5I,mBAAmB;AACxC,YAAIwE,OAAOqE,UAAUC,eAAeC,KAAK,KAAK/I,mBAAmB4I,GAAAA,GAAM;AACrE,gBAAM/F,QAAQ+F;AACd,gBAAMI,mBAAmB,KAAKhJ,kBAAkB6C,KAAAA;AAChD,cAAImG,kBAAkB;AACpB,iBAAKrK,eAAekE,KAAAA,IAAS,MAAM5B,OAAO0H,aAAaK,gBAAAA;UACzD;QACF;MACF;IACF;EACF;EAEUC,gBAAgBC,QAAiBC,kBAAgE;AACzG,UAAMnI,OAAO,KAAKvB,OAAOuB,QAAQ;AACjC,WAAO;MAAEvB,QAAQ;QAAEuB;QAAM,GAAG,KAAKvB;MAAO;MAAGsB,QAAQqI;MAA6BC,QAAQ;QAAE1J,SAAS,KAAKA;MAAQ;IAAE;EACpH;EAEU2J,uBAAiE;AAEzE,UAAMpJ,gBAAgBsE,OAAO+E,QAAQ,KAAKrJ,aAAa,EACpDkB,OAAO,CAACoI,UAAAA;AACP,iBAAO5C,sBAAO4C,MAAM,CAAA,CAAE;IACxB,CAAA,EACC/B,IAAI,CAAC,CAACzG,OAAM7B,OAAAA,MAAQ;AACnB,YAAMQ,WAAUR,QAAQQ;AACxB,YAAMiD,gBAAezD,QAAQyD;AAC7B,aAAO;QACL;UAAEjD,SAAAA;UAASqB,MAAAA;UAAMD,QAAQ4G;QAAc;QACvC;UAAEhI,SAAAA;UAASiD,cAAAA;UAAc7B,QAAQ0I;QAA0B;;IAE/D,CAAA;AACF,UAAM9J,UAAU,KAAKA;AACrB,UAAMqB,OAAO,KAAKvB,OAAOuB;AACzB,UAAM4B,eAAe,KAAKjD;AAC1B,UAAM+J,gBAAgB1I,OAAO;MAAErB;MAASqB;MAAMD,QAAQ4G;IAAc,IAAI;MAAEhI;MAASoB,QAAQ4G;IAAc;AACzG,UAAMgC,4BAA4B/G,eAC9B;MAAEjD;MAASiD;MAAc7B,QAAQ0I;IAA0B,IAC3D;MAAE9J;MAASoB,QAAQ0I;IAA0B;AACjD,WAAO;MAACC;MAAeC;SAA8BzJ;MAAe6G,KAAI;EAC1E;EAEA,MAAgBpD,aACdd,OACAC,UACAC,aACmC;AACnC,UAAM,KAAKS,QAAQ,OAAA;AACnB,UAAMoG,UAAUhG,sDAAyBiG,WAAwBhH,OAAOC,QAAAA;AACxE,UAAMgH,eAAe,MAAMF,QAAQG,SAAQ;AAC3C3K,iCAAS,KAAKG,UAAUsD,OAAOC,UAAUC,WAAAA,CAAAA;AACzC,UAAMI,iBAA4B,CAAA;AAClC,YAAQ2G,aAAa/I,QAAM;MACzB,KAAKtC,+CAA2B;AAC9B0E,uBAAeO,KAAK,MAAM,KAAKuF,gBAAgBa,aAAaE,QAAQ,CAAA;AACpE;MACF;MACA,KAAKxL,+CAA2B;AAC9B2E,uBAAeO,KAAI,GAAK,MAAM,KAAK4D,gBAAe,CAAA;AAClD;MACF;MACA,KAAK/I,+CAA2B;AAC9B4E,uBAAeO,KAAK,MAAM,KAAKwD,gBAAe,CAAA;AAC9C;MACF;MACA,KAAK5I,8CAA0B;AAC7B6E,uBAAeO,KAAI,GAAK,MAAM,KAAK4F,qBAAoB,CAAA;AACvD;MACF;MACA,KAAK5K,gDAA4B;AAC/B,aAAKuL,iBAAgB;AACrB;MACF;MACA;AACE,cAAMnJ,MAAM,sBAAuBgJ,aAAyB/I,MAAM,GAAG;IACzE;AACA,WAAOoC;EACT;EAEU+G,gBAAgB,MAAM,KAAKjD,aAAa,MAAA;EAElD,MAAgBkD,6BAA2D;AACzE,UAAMC,aAAa,KAAK3K,OAAOoH,WAAWuD;AAC1C,QAAI,CAACA;AAAY,aAAO,CAAA;AACxB,UAAMjC,WAAW,MAAMkC,QAAQC,IAAIF,WAAW3C,IAAI,CAACQ,cAAc,KAAKpD,QAAQoD,SAAAA,CAAAA,CAAAA;AAC9E,eAAOT,uBAAQW,SAASV,IAAI,CAAC8C,YAAQnC,4CAAoBmC,GAAAA,CAAAA,CAAAA;EAC3D;EAEA,MAAgBlF,eAAiC;AAC/C,SAAKmF,eAAc;AACnB,UAAM,KAAKnC,wBAAuB;AAClC,SAAKxJ,WAAW;AAChB,WAAO;EACT;EAEU+G,YAAYR,UAAwC;AAC5D,SAAKvG,WAAWT;AAChB,WAAO;EACT;EAEA,MAAgB0I,kBAAkBhE,UAAyC;AACzE,UAAMsH,aAAa,MAAM,KAAKD,2BAA0B;AACxD,YACE,MAAME,QAAQC,IACZF,WAAW3C,IAAI,CAACQ,cAAAA;AACd,aAAOA,UAAUwC,SAAS3H,QAAAA;IAC5B,CAAA,CAAA,GAEF2E,IAAI,CAAC,CAACiD,EAAAA,MAAQA,EAAAA;EAClB;EAEUT,mBAAmB;AAC3B;EACF;EAEUO,eAAe/K,QAAkBkL,UAAoB,CAAA,GAAa;AAC1E,WAAOnG,OAAO+E,QAAQ9J,UAAU,KAAKA,UAAU,CAAC,CAAA,EAAGmL,OAAO,CAACC,OAAO,CAACjC,KAAKY,KAAAA,MAAM;AAC5E,cAAQ,OAAOA,OAAAA;QACb,KAAK;AACH,eAAK/H,QAAQgE,KAAK,kDAAkDkF,SAASG,KAAK,GAAA,CAAA,IAAQlC,GAAAA,GAAM;AAChG,iBAAO;QACT,KAAK,UAAU;AACb,cAAImC,MAAMC,QAAQxB,KAAAA,GAAQ;AACxB,mBACEA,MAAMoB,OAAO,CAACC,QAAOrB,WAAAA;AACnB,qBAAO,KAAKgB,eAAehB,QAAO;mBAAImB;gBAAS/B;eAAI,KAAKiC;YAC1D,GAAG,IAAA,KAASA;UAEhB;AAEA,cAAI,KAACI,uCAAkBzB,KAAAA,GAAQ;AAC7B,iBAAK/H,QAAQgE,KAAK,uEAAuEkF,SAASG,KAAK,GAAA,CAAA,IAAQlC,GAAAA,GAAM;AACrH,mBAAO;UACT;AACA,iBAAOY,QAAQ,KAAKgB,eAAehB,OAAO;eAAImB;YAAS/B;WAAI,KAAKiC,QAAQ;QAC1E;QACA;AACE,iBAAOA;MACX;IACF,GAAG,IAAA;EACL;EAEUK,iBAAiB,MAAM,KAAKjE,aAAa,OAAA;AACrD;;;AMxpBA,IAAAkE,iBAAyB;AAQlB,IAAeC,yBAAf,cACGC,eAAAA;EATV,OASUA;;;EAGRC,YAAYC,uBAA+BC,QAAiBC,SAA0B;AACpFC,iCAASL,eAAeE,0BAA0BA,uBAAuB,4CAAA;AAEzE,UAAMI,gBAAgB;MAAE,GAAGH;IAAO;AAClC,UAAMD,uBAAuBI,eAAeF,OAAAA;AAC5C,SAAKG,WAAWC,IAAI,IAAI;AACxB,SAAKC,aAAaD,IAAI,IAAI;EAC5B;EAEAE,WAA8C;AAC5C,WAAO,KAAKC,KAAK,YAAA;AACf,aAAO,MAAM,KAAKC,gBAAe;IACnC,CAAA;EACF;EAEAC,WAA+B;AAC7B,WAAO,KAAKF,KAAK,YAAA;AACf,aAAO,MAAM,KAAKG,gBAAe;IACnC,CAAA;EACF;EAEAC,SAASC,UAAmBC,iBAA4D;AACtF,WAAO,KAAKN,KAAK,YAAA;AACf,aAAO,MAAM,KAAKO,gBAAgBF,UAAUC,eAAAA;IAC9C,CAAA;EACF;EAEAE,gBAAuD;AACrD,WAAO,KAAKR,KAAK,YAAA;AACf,aAAO,MAAM,KAAKS,qBAAoB;IACxC,CAAA;EACF;EAEAC,UAAUC,eAAiC;AACzC,WAAO,KAAKC,iBAAgB;EAC9B;AACF;","names":["import_assert","import_account","import_boundwitness_builder","import_core","import_payload_builder","BaseEmitter","Base","eventData","events","constructor","params","Events","clearListeners","eventNames","emit","eventName","eventArgs","emitSerial","listenerCount","off","listener","offAny","on","onAny","once","determineAccount","account","accountDerivationPath","wallet","assertEx","derivePath","HDWallet","random","console","warn","ModuleErrorBuilder","PayloadBuilder","_message","_name","_query","_sources","constructor","schema","ModuleErrorSchema","build","message","name","query","sources","delimiter","ModuleConfigQueryValidator","allowed","disallowed","hasAllowedRules","hasDisallowedRules","hasRules","constructor","config","security","Object","entries","forEach","schema","addresses","map","toAddressesString","keys","length","queryable","query","payloads","wrapper","QueryBoundWitnessWrapper","parseQuery","getQuery","queryAllowed","queryDisallowed","signatories","validCosigners","includes","every","address","some","Array","isArray","sort","toLowerCase","join","import_boundwitness_builder","isQuerySupportedByModule","mod","query","payloads","wrapper","QueryBoundWitnessWrapper","parseQuery","schema","getQuery","queries","includes","SupportedQueryValidator","constructor","queryable","AbstractModule","BaseEmitter","configSchemas","enableLazyLoad","privateConstructorKey","Date","now","toString","downResolver","CompositeModuleResolver","upResolver","_account","undefined","_baseModuleQueryAccountPaths","ModuleAddressQuerySchema","ModuleDescribeQuerySchema","ModuleDiscoverQuerySchema","ModuleManifestQuerySchema","ModuleSubscribeQuerySchema","_queryAccounts","_startPromise","_started","moduleConfigQueryValidator","supportedQueryValidator","_busyCount","constructor","params","account","assertEx","mutatedParams","SupportedQueryValidator","queryable","ModuleConfigQueryValidator","config","configSchema","address","allowAnonymous","security","ephemeralQueryAccountEnabled","queries","queryAccountPaths","_queryAccountPaths","queryAccounts","timestamp","_getRootFunction","funcName","anyThis","__proto__","_noOverride","functionName","thisFunc","rootFunc","create","length","Error","schema","name","wallet","accountDerivationPath","allowedSchemas","filter","allowedSchema","JSON","stringify","mutatedConfig","logger","debug","activeLogger","defaultLogger","generatedAccount","determineAccount","IdLogger","newModule","start","factory","ModuleFactory","withParams","busy","closure","args","module","emit","eventName","eventArgs","previousHash","query","payloads","queryConfig","sourceQuery","PayloadHasher","hashAsync","resultPayloads","errorPayloads","queryAccount","HDWallet","random","started","addresses","push","queryHandler","QueryBoundWitnessWrapper","unwrap","ex","handleErrorAsync","error","ModuleErrorBuilder","sources","message","build","result","bindQueryResult","configValidator","Object","assign","validators","every","validator","resolve","nameOrAddressOrFilter","options","direction","up","down","duplicateModules","_timeout","startHandler","notStartedAction","tryStart","handleError","warn","log","stop","stopHandler","bindHashes","hashes","promise","PromiseEx","bindHashesInternal","builder","BoundWitnessBuilder","witness","bindQuery","bindQueryInternal","QueryBoundWitnessBuilder","additionalWitnesses","errors","queryWitnessAccount","witnesses","exists","archiving","storeToArchivists","flat","commitArchivist","getArchivist","describeHandler","description","ModuleDescriptionSchema","discover","discoverHandler","children","compact","map","payload","AddressSchema","PayloadBuilder","fields","QuerySchema","ConfigSchema","kind","archivist","String","resolved","asArchivistInstance","initializeQueryAccounts","paths","values","distinctPaths","Set","size","derivePath","key","prototype","hasOwnProperty","call","queryAccountPath","manifestHandler","_depth","_ignoreAddresses","ModuleManifestPayloadSchema","status","moduleAddressHandler","entries","value","AddressPreviousHashSchema","moduleAccount","moduleAccountPreviousHash","wrapper","parseQuery","queryPayload","getQuery","maxDepth","subscribeHandler","readArchivist","resolveArchivingArchivists","archivists","Promise","all","mod","validateConfig","insert","bw","parents","reduce","valid","join","Array","isArray","serializableField","writeArchivist","import_assert","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/dist/browser/index.js
CHANGED
|
@@ -2,10 +2,10 @@ var __defProp = Object.defineProperty;
|
|
|
2
2
|
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
3
3
|
|
|
4
4
|
// src/AbstractModule.ts
|
|
5
|
-
import { assertEx } from "@xylabs/assert";
|
|
5
|
+
import { assertEx as assertEx2 } from "@xylabs/assert";
|
|
6
6
|
import { exists } from "@xylabs/exists";
|
|
7
7
|
import { compact } from "@xylabs/lodash";
|
|
8
|
-
import { HDWallet } from "@xyo-network/account";
|
|
8
|
+
import { HDWallet as HDWallet2 } from "@xyo-network/account";
|
|
9
9
|
import { AddressSchema } from "@xyo-network/address-payload-plugin";
|
|
10
10
|
import { asArchivistInstance } from "@xyo-network/archivist-model";
|
|
11
11
|
import { BoundWitnessBuilder, QueryBoundWitnessBuilder, QueryBoundWitnessWrapper as QueryBoundWitnessWrapper3 } from "@xyo-network/boundwitness-builder";
|
|
@@ -63,6 +63,22 @@ var BaseEmitter = class extends Base {
|
|
|
63
63
|
}
|
|
64
64
|
};
|
|
65
65
|
|
|
66
|
+
// src/determineAccount.ts
|
|
67
|
+
import { assertEx } from "@xylabs/assert";
|
|
68
|
+
import { HDWallet } from "@xyo-network/account";
|
|
69
|
+
var determineAccount = /* @__PURE__ */ __name(async ({ account, accountDerivationPath, wallet }) => {
|
|
70
|
+
if (wallet) {
|
|
71
|
+
return assertEx(accountDerivationPath ? await wallet.derivePath(accountDerivationPath) : wallet, "Failed to derive account from path");
|
|
72
|
+
} else if (account === "random") {
|
|
73
|
+
return await HDWallet.random();
|
|
74
|
+
} else if (account) {
|
|
75
|
+
return account;
|
|
76
|
+
} else {
|
|
77
|
+
console.warn("AbstractModule.determineAccount: No account provided - Creating Random account");
|
|
78
|
+
return await HDWallet.random();
|
|
79
|
+
}
|
|
80
|
+
}, "determineAccount");
|
|
81
|
+
|
|
66
82
|
// src/Error.ts
|
|
67
83
|
import { PayloadBuilder } from "@xyo-network/payload-builder";
|
|
68
84
|
import { ModuleErrorSchema } from "@xyo-network/payload-model";
|
|
@@ -216,7 +232,7 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
216
232
|
supportedQueryValidator;
|
|
217
233
|
_busyCount = 0;
|
|
218
234
|
constructor(privateConstructorKey, params, account) {
|
|
219
|
-
|
|
235
|
+
assertEx2(_AbstractModule.privateConstructorKey === privateConstructorKey, "Use create function instead of constructor");
|
|
220
236
|
const mutatedParams = {
|
|
221
237
|
...params
|
|
222
238
|
};
|
|
@@ -229,7 +245,7 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
229
245
|
return this.configSchemas[0];
|
|
230
246
|
}
|
|
231
247
|
get account() {
|
|
232
|
-
return
|
|
248
|
+
return assertEx2(this._account, "Missing account");
|
|
233
249
|
}
|
|
234
250
|
get address() {
|
|
235
251
|
return this.account.address;
|
|
@@ -274,7 +290,7 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
274
290
|
static _noOverride(functionName) {
|
|
275
291
|
const thisFunc = this[functionName];
|
|
276
292
|
const rootFunc = this._getRootFunction(functionName);
|
|
277
|
-
|
|
293
|
+
assertEx2(thisFunc === rootFunc, `Override not allowed for [${functionName}] - override ${functionName}Handler instead`);
|
|
278
294
|
}
|
|
279
295
|
static async create(params) {
|
|
280
296
|
this._noOverride("create");
|
|
@@ -283,10 +299,10 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
283
299
|
}
|
|
284
300
|
const { account, config, wallet } = params ?? {};
|
|
285
301
|
const { accountDerivationPath } = config ?? {};
|
|
286
|
-
|
|
302
|
+
assertEx2(!(!!account && !!wallet), `Specifying both {account} and {wallet} are not allowed [${config?.schema}] [${account === "random" ? "random" : account?.address}, ${wallet?.address}]`);
|
|
287
303
|
const schema = params?.config?.schema ?? this.configSchema;
|
|
288
304
|
const allowedSchemas = this.configSchemas;
|
|
289
|
-
|
|
305
|
+
assertEx2(allowedSchemas.filter((allowedSchema) => allowedSchema === schema).length > 0, `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`);
|
|
290
306
|
const mutatedConfig = {
|
|
291
307
|
...params?.config,
|
|
292
308
|
schema
|
|
@@ -310,17 +326,8 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
310
326
|
}
|
|
311
327
|
return newModule;
|
|
312
328
|
}
|
|
313
|
-
static async determineAccount(
|
|
314
|
-
|
|
315
|
-
return assertEx(accountDerivationPath ? await wallet.derivePath(accountDerivationPath) : wallet, "Failed to derive account from path");
|
|
316
|
-
} else if (account === "random") {
|
|
317
|
-
return await HDWallet.random();
|
|
318
|
-
} else if (account) {
|
|
319
|
-
return account;
|
|
320
|
-
} else {
|
|
321
|
-
console.warn("AbstractModule.determineAccount: No account provided - Creating Random account");
|
|
322
|
-
return await HDWallet.random();
|
|
323
|
-
}
|
|
329
|
+
static async determineAccount(params) {
|
|
330
|
+
return await determineAccount(params);
|
|
324
331
|
}
|
|
325
332
|
static factory(params) {
|
|
326
333
|
return ModuleFactory.withParams(this, params);
|
|
@@ -335,7 +342,7 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
335
342
|
_noOverride(functionName) {
|
|
336
343
|
const thisFunc = this[functionName];
|
|
337
344
|
const rootFunc = this._getRootFunction(functionName);
|
|
338
|
-
|
|
345
|
+
assertEx2(thisFunc === rootFunc, `Override not allowed for [${functionName}] - override ${functionName}Handler instead`);
|
|
339
346
|
}
|
|
340
347
|
async busy(closure) {
|
|
341
348
|
if (this._busyCount <= 0) {
|
|
@@ -369,10 +376,11 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
369
376
|
}
|
|
370
377
|
async query(query, payloads, queryConfig) {
|
|
371
378
|
this._noOverride("query");
|
|
379
|
+
const sourceQuery = await PayloadHasher.hashAsync(query);
|
|
372
380
|
return await this.busy(async () => {
|
|
373
381
|
const resultPayloads = [];
|
|
374
382
|
const errorPayloads = [];
|
|
375
|
-
const queryAccount = this.ephemeralQueryAccountEnabled ? await
|
|
383
|
+
const queryAccount = this.ephemeralQueryAccountEnabled ? await HDWallet2.random() : void 0;
|
|
376
384
|
try {
|
|
377
385
|
await this.started("throw");
|
|
378
386
|
if (!this.allowAnonymous) {
|
|
@@ -380,7 +388,7 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
380
388
|
throw Error(`Anonymous Queries not allowed, but running anyway [${this.config.name}], [${this.address}]`);
|
|
381
389
|
}
|
|
382
390
|
}
|
|
383
|
-
resultPayloads.push(...await this.queryHandler(
|
|
391
|
+
resultPayloads.push(...await this.queryHandler(assertEx2(QueryBoundWitnessWrapper3.unwrap(query)), payloads, queryConfig));
|
|
384
392
|
} catch (ex) {
|
|
385
393
|
await handleErrorAsync(ex, async (error) => {
|
|
386
394
|
errorPayloads.push(new ModuleErrorBuilder().sources([
|
|
@@ -395,7 +403,7 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
395
403
|
};
|
|
396
404
|
resultPayloads.push(timestamp);
|
|
397
405
|
}
|
|
398
|
-
const result = await this.bindQueryResult(query, resultPayloads, queryAccount ? [
|
|
406
|
+
const result = await this.bindQueryResult(query, resultPayloads, sourceQuery, queryAccount ? [
|
|
399
407
|
queryAccount
|
|
400
408
|
] : [], errorPayloads);
|
|
401
409
|
const args = {
|
|
@@ -517,8 +525,8 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
517
525
|
const result = await (account ? builder.witness(account) : builder).build();
|
|
518
526
|
return result;
|
|
519
527
|
}
|
|
520
|
-
async bindQueryResult(query, payloads, additionalWitnesses = [], errors) {
|
|
521
|
-
const builder = new BoundWitnessBuilder().payloads(payloads).errors(errors);
|
|
528
|
+
async bindQueryResult(query, payloads, sourceQuery, additionalWitnesses = [], errors) {
|
|
529
|
+
const builder = new BoundWitnessBuilder().payloads(payloads).errors(errors).sourceQuery(sourceQuery);
|
|
522
530
|
const queryWitnessAccount = this.queryAccounts[query.schema];
|
|
523
531
|
const witnesses = [
|
|
524
532
|
this.account,
|
|
@@ -589,7 +597,7 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
589
597
|
async initializeQueryAccounts() {
|
|
590
598
|
const paths = Object.values(this.queryAccountPaths).filter(exists);
|
|
591
599
|
const distinctPaths = new Set(paths);
|
|
592
|
-
|
|
600
|
+
assertEx2(distinctPaths.size === paths.length, `${this.config?.name ? this.config.name + ": " : ""}Duplicate query account paths`);
|
|
593
601
|
const wallet = this.account;
|
|
594
602
|
if (wallet?.derivePath) {
|
|
595
603
|
for (const key in this.queryAccountPaths) {
|
|
@@ -664,7 +672,7 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
664
672
|
await this.started("throw");
|
|
665
673
|
const wrapper = QueryBoundWitnessWrapper3.parseQuery(query, payloads);
|
|
666
674
|
const queryPayload = await wrapper.getQuery();
|
|
667
|
-
|
|
675
|
+
assertEx2(this.queryable(query, payloads, queryConfig));
|
|
668
676
|
const resultPayloads = [];
|
|
669
677
|
switch (queryPayload.schema) {
|
|
670
678
|
case ModuleManifestQuerySchema: {
|
|
@@ -752,13 +760,13 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
752
760
|
};
|
|
753
761
|
|
|
754
762
|
// src/AbstractModuleInstance.ts
|
|
755
|
-
import { assertEx as
|
|
763
|
+
import { assertEx as assertEx3 } from "@xylabs/assert";
|
|
756
764
|
var AbstractModuleInstance = class extends AbstractModule {
|
|
757
765
|
static {
|
|
758
766
|
__name(this, "AbstractModuleInstance");
|
|
759
767
|
}
|
|
760
768
|
constructor(privateConstructorKey, params, account) {
|
|
761
|
-
|
|
769
|
+
assertEx3(AbstractModule.privateConstructorKey === privateConstructorKey, "Use create function instead of constructor");
|
|
762
770
|
const mutatedParams = {
|
|
763
771
|
...params
|
|
764
772
|
};
|