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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (37) hide show
  1. package/dist/browser/AbstractModule.d.cts +3 -3
  2. package/dist/browser/AbstractModule.d.cts.map +1 -1
  3. package/dist/browser/AbstractModule.d.mts +3 -3
  4. package/dist/browser/AbstractModule.d.mts.map +1 -1
  5. package/dist/browser/AbstractModule.d.ts +3 -3
  6. package/dist/browser/AbstractModule.d.ts.map +1 -1
  7. package/dist/browser/Error.d.cts +2 -2
  8. package/dist/browser/Error.d.cts.map +1 -1
  9. package/dist/browser/Error.d.mts +2 -2
  10. package/dist/browser/Error.d.mts.map +1 -1
  11. package/dist/browser/Error.d.ts +2 -2
  12. package/dist/browser/Error.d.ts.map +1 -1
  13. package/dist/browser/index.cjs +17 -17
  14. package/dist/browser/index.cjs.map +1 -1
  15. package/dist/browser/index.js +17 -17
  16. package/dist/browser/index.js.map +1 -1
  17. package/dist/node/AbstractModule.d.cts +3 -3
  18. package/dist/node/AbstractModule.d.cts.map +1 -1
  19. package/dist/node/AbstractModule.d.mts +3 -3
  20. package/dist/node/AbstractModule.d.mts.map +1 -1
  21. package/dist/node/AbstractModule.d.ts +3 -3
  22. package/dist/node/AbstractModule.d.ts.map +1 -1
  23. package/dist/node/Error.d.cts +2 -2
  24. package/dist/node/Error.d.cts.map +1 -1
  25. package/dist/node/Error.d.mts +2 -2
  26. package/dist/node/Error.d.mts.map +1 -1
  27. package/dist/node/Error.d.ts +2 -2
  28. package/dist/node/Error.d.ts.map +1 -1
  29. package/dist/node/index.cjs +17 -17
  30. package/dist/node/index.cjs.map +1 -1
  31. package/dist/node/index.js +17 -17
  32. package/dist/node/index.js.map +1 -1
  33. package/package.json +18 -18
  34. package/src/AbstractModule.ts +17 -17
  35. package/src/Error.ts +4 -3
  36. package/src/QueryValidator/ModuleConfigQueryValidator.ts +1 -1
  37. package/src/QueryValidator/SupportedQueryValidator.ts +1 -1
@@ -48,7 +48,6 @@ var import_address_payload_plugin = require("@xyo-network/address-payload-plugin
48
48
  var import_archivist_model = require("@xyo-network/archivist-model");
49
49
  var import_boundwitness_builder3 = require("@xyo-network/boundwitness-builder");
50
50
  var import_config_payload_plugin = require("@xyo-network/config-payload-plugin");
51
- var import_hash = require("@xyo-network/hash");
52
51
  var import_manifest_model = require("@xyo-network/manifest-model");
53
52
  var import_module_model = require("@xyo-network/module-model");
54
53
  var import_module_resolver = require("@xyo-network/module-resolver");
@@ -137,13 +136,14 @@ var _ModuleErrorBuilder = class _ModuleErrorBuilder extends import_payload_build
137
136
  });
138
137
  }
139
138
  build() {
140
- return Promise.resolve({
139
+ this.fields({
141
140
  message: this._message,
142
141
  name: this._name,
143
142
  query: this._query,
144
143
  schema: import_payload_model.ModuleErrorSchema,
145
144
  sources: this._sources
146
145
  });
146
+ return super.build();
147
147
  }
148
148
  message(message) {
149
149
  this._message = message;
@@ -196,7 +196,7 @@ var _ModuleConfigQueryValidator = class _ModuleConfigQueryValidator {
196
196
  const addresses = query.addresses;
197
197
  if (addresses.length === 0)
198
198
  return false;
199
- const wrapper = import_boundwitness_builder.QueryBoundWitnessWrapper.parseQuery(query, payloads);
199
+ const wrapper = await import_boundwitness_builder.QueryBoundWitnessWrapper.parseQuery(query, payloads);
200
200
  const schema = (await wrapper.getQuery()).schema;
201
201
  return this.queryAllowed(schema, addresses) && !this.queryDisallowed(schema, addresses);
202
202
  };
@@ -233,7 +233,7 @@ var toAddressesString = /* @__PURE__ */ __name((addresses) => {
233
233
  // src/QueryValidator/SupportedQueryValidator.ts
234
234
  var import_boundwitness_builder2 = require("@xyo-network/boundwitness-builder");
235
235
  var isQuerySupportedByModule = /* @__PURE__ */ __name(async (mod, query, payloads) => {
236
- const wrapper = import_boundwitness_builder2.QueryBoundWitnessWrapper.parseQuery(query, payloads);
236
+ const wrapper = await import_boundwitness_builder2.QueryBoundWitnessWrapper.parseQuery(query, payloads);
237
237
  const schema = (await wrapper.getQuery()).schema;
238
238
  return mod.queries.includes(schema);
239
239
  }, "isQuerySupportedByModule");
@@ -420,7 +420,7 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
420
420
  }
421
421
  async query(query, payloads, queryConfig) {
422
422
  this._noOverride("query");
423
- const sourceQuery = await import_hash.PayloadHasher.hashAsync(query);
423
+ const sourceQuery = await import_payload_builder2.PayloadBuilder.build((0, import_assert2.assertEx)(await import_boundwitness_builder3.QueryBoundWitnessWrapper.unwrap(query), "Invalid query"));
424
424
  return await this.busy(async () => {
425
425
  const resultPayloads = [];
426
426
  const errorPayloads = [];
@@ -430,12 +430,12 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
430
430
  if (!this.allowAnonymous && query.addresses.length === 0) {
431
431
  throw new Error(`Anonymous Queries not allowed, but running anyway [${this.config.name}], [${this.address}]`);
432
432
  }
433
- resultPayloads.push(...await this.queryHandler((0, import_assert2.assertEx)(import_boundwitness_builder3.QueryBoundWitnessWrapper.unwrap(query)), payloads, queryConfig));
433
+ resultPayloads.push(...await this.queryHandler(sourceQuery, payloads, queryConfig));
434
434
  } catch (ex) {
435
435
  await (0, import_error.handleErrorAsync)(ex, async (error) => {
436
436
  errorPayloads.push(await new ModuleErrorBuilder().sources([
437
- await import_hash.PayloadHasher.hashAsync(query)
438
- ]).name(this.config.name ?? "<Unknown>").query(query.schema).message(error.message).build());
437
+ sourceQuery.$hash
438
+ ]).name(this.config.name ?? "<Unknown>").query(sourceQuery.schema).message(error.message).build());
439
439
  });
440
440
  }
441
441
  if (this.timestamp) {
@@ -445,21 +445,21 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
445
445
  };
446
446
  resultPayloads.push(timestamp);
447
447
  }
448
- const result = await this.bindQueryResult(query, resultPayloads, sourceQuery, queryAccount ? [
448
+ const result = await this.bindQueryResult(sourceQuery, resultPayloads, queryAccount ? [
449
449
  queryAccount
450
450
  ] : [], errorPayloads);
451
451
  const args = {
452
452
  module: this,
453
453
  payloads,
454
- query,
454
+ query: sourceQuery,
455
455
  result
456
456
  };
457
457
  await this.emit("moduleQueried", args);
458
458
  return result;
459
459
  });
460
460
  }
461
- queryable(query, payloads, queryConfig) {
462
- if (!this.started("warn"))
461
+ async queryable(query, payloads, queryConfig) {
462
+ if (!await this.started("warn"))
463
463
  return false;
464
464
  const configValidator = queryConfig ? new ModuleConfigQueryValidator(Object.assign({}, this.config, queryConfig)).queryable : this.moduleConfigQueryValidator;
465
465
  const validators = [
@@ -569,12 +569,12 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
569
569
  return promise;
570
570
  }
571
571
  async bindQueryInternal(query, payloads, account) {
572
- const builder = new import_boundwitness_builder3.QueryBoundWitnessBuilder().payloads(payloads).witness(this.account).query(query);
572
+ const builder = await (await new import_boundwitness_builder3.QueryBoundWitnessBuilder().payloads(payloads)).witness(this.account).query(query);
573
573
  const result = await (account ? builder.witness(account) : builder).build();
574
574
  return result;
575
575
  }
576
- async bindQueryResult(query, payloads, sourceQuery, additionalWitnesses = [], errors) {
577
- const builder = new import_boundwitness_builder3.BoundWitnessBuilder().payloads(payloads).errors(errors).sourceQuery(sourceQuery);
576
+ async bindQueryResult(query, payloads, additionalWitnesses = [], errors) {
577
+ const builder = (await (await new import_boundwitness_builder3.BoundWitnessBuilder().payloads(payloads)).errors(errors)).sourceQuery(query.$hash);
578
578
  const queryWitnessAccount = this.queryAccounts[query.schema];
579
579
  const witnesses = [
580
580
  this.account,
@@ -719,9 +719,9 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
719
719
  }
720
720
  async queryHandler(query, payloads, queryConfig) {
721
721
  await this.started("throw");
722
- const wrapper = import_boundwitness_builder3.QueryBoundWitnessWrapper.parseQuery(query, payloads);
722
+ const wrapper = await import_boundwitness_builder3.QueryBoundWitnessWrapper.parseQuery(query, payloads);
723
723
  const queryPayload = await wrapper.getQuery();
724
- (0, import_assert2.assertEx)(this.queryable(query, payloads, queryConfig));
724
+ (0, import_assert2.assertEx)(await this.queryable(query, payloads, queryConfig));
725
725
  const resultPayloads = [];
726
726
  switch (queryPayload.schema) {
727
727
  case import_module_model.ModuleManifestQuerySchema: {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/AbstractModule.ts","../../src/BaseEmitter.ts","../../src/determineAccount.ts","../../src/Error.ts","../../src/QueryValidator/ModuleConfigQueryValidator.ts","../../src/QueryValidator/SupportedQueryValidator.ts","../../src/AbstractModuleInstance.ts"],"sourcesContent":["export * from './AbstractModule'\nexport * from './AbstractModuleInstance'\nexport * from './BaseEmitter'\nexport * from './Error'\nexport * from './QueryValidator'\n","/* eslint-disable max-lines */\nimport { assertEx } from '@xylabs/assert'\nimport { handleError, handleErrorAsync } from '@xylabs/error'\nimport { exists } from '@xylabs/exists'\nimport { compact } from '@xylabs/lodash'\nimport { IdLogger } from '@xylabs/logger'\nimport { Promisable, PromiseEx } from '@xylabs/promise'\nimport { Account, HDWallet } from '@xyo-network/account'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { AddressPayload, AddressSchema } from '@xyo-network/address-payload-plugin'\nimport { ArchivistInstance, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitnessBuilder, QueryBoundWitnessBuilder, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { ConfigPayload, ConfigSchema } from '@xyo-network/config-payload-plugin'\nimport { PayloadHasher } from '@xyo-network/hash'\nimport { ModuleManifestPayload, ModuleManifestPayloadSchema } from '@xyo-network/manifest-model'\nimport {\n AddressPreviousHashPayload,\n AddressPreviousHashSchema,\n CreatableModule,\n CreatableModuleFactory,\n duplicateModules,\n Module,\n ModuleAddressQuerySchema,\n ModuleBusyEventArgs,\n ModuleConfig,\n ModuleDescribeQuerySchema,\n ModuleDescriptionPayload,\n ModuleDescriptionSchema,\n ModuleDiscoverQuerySchema,\n ModuleEventData,\n ModuleFactory,\n ModuleFilter,\n ModuleFilterOptions,\n ModuleInstance,\n ModuleManifestQuerySchema,\n ModuleParams,\n ModuleQueriedEventArgs,\n ModuleQuery,\n ModuleQueryBase,\n ModuleQueryHandlerResult,\n ModuleQueryResult,\n ModuleSubscribeQuerySchema,\n SchemaString,\n serializableField,\n} from '@xyo-network/module-model'\nimport { CompositeModuleResolver } from '@xyo-network/module-resolver'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { ModuleError, Payload, Query } from '@xyo-network/payload-model'\nimport { QueryPayload, QuerySchema } from '@xyo-network/query-payload-plugin'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nimport { BaseEmitter } from './BaseEmitter'\nimport { determineAccount } from './determineAccount'\nimport { ModuleErrorBuilder } from './Error'\nimport { ModuleConfigQueryValidator, Queryable, SupportedQueryValidator } from './QueryValidator'\n\nexport abstract class AbstractModule<TParams extends ModuleParams = ModuleParams, TEventData extends ModuleEventData = ModuleEventData>\n extends BaseEmitter<TParams, TEventData>\n implements Module<TParams, TEventData>\n{\n static readonly allowRandomAccount: boolean = true\n static configSchemas: string[]\n static enableLazyLoad = false\n\n protected static privateConstructorKey = Date.now().toString()\n\n readonly downResolver: Omit<CompositeModuleResolver, 'resolve'> = new CompositeModuleResolver()\n readonly upResolver: Omit<CompositeModuleResolver, 'resolve>'> = new CompositeModuleResolver()\n\n protected _account: AccountInstance | undefined = undefined\n protected readonly _baseModuleQueryAccountPaths: Record<ModuleQueryBase['schema'], string> = {\n [ModuleAddressQuerySchema]: '1',\n [ModuleDescribeQuerySchema]: '4',\n [ModuleDiscoverQuerySchema]: '2',\n [ModuleManifestQuerySchema]: '5',\n [ModuleSubscribeQuerySchema]: '3',\n }\n protected readonly _queryAccounts: Record<ModuleQueryBase['schema'], AccountInstance | undefined> = {\n [ModuleAddressQuerySchema]: undefined,\n [ModuleDescribeQuerySchema]: undefined,\n [ModuleDiscoverQuerySchema]: undefined,\n [ModuleManifestQuerySchema]: undefined,\n [ModuleSubscribeQuerySchema]: undefined,\n }\n protected _startPromise: Promisable<boolean> | undefined = undefined\n protected _started: Promisable<boolean> | undefined = undefined\n protected readonly moduleConfigQueryValidator: Queryable\n protected readonly supportedQueryValidator: Queryable\n\n private _busyCount = 0\n\n constructor(privateConstructorKey: string, params: TParams, account: AccountInstance) {\n assertEx(AbstractModule.privateConstructorKey === privateConstructorKey, 'Use create function instead of constructor')\n // Clone params to prevent mutation of the incoming object\n const mutatedParams = { ...params } as TParams\n super(mutatedParams)\n\n this._account = account\n\n this.supportedQueryValidator = new SupportedQueryValidator(this as Module).queryable\n this.moduleConfigQueryValidator = new ModuleConfigQueryValidator(mutatedParams?.config).queryable\n }\n\n static get configSchema(): string {\n return this.configSchemas[0]\n }\n\n get account() {\n return assertEx(this._account, 'Missing account')\n }\n\n get address() {\n return this.account.address\n }\n\n get allowAnonymous() {\n return !!this.config.security?.allowAnonymous\n }\n\n get config(): TParams['config'] {\n return this.params.config\n }\n\n get ephemeralQueryAccountEnabled(): boolean {\n return !!this.params.ephemeralQueryAccountEnabled\n }\n\n get id() {\n return this.config.name ?? this.address\n }\n\n get queries(): string[] {\n return [ModuleDiscoverQuerySchema, ModuleAddressQuerySchema, ModuleSubscribeQuerySchema, ModuleDescribeQuerySchema, ModuleManifestQuerySchema]\n }\n\n get queryAccountPaths(): Readonly<Record<Query['schema'], string | undefined>> {\n return { ...this._baseModuleQueryAccountPaths, ...this._queryAccountPaths }\n }\n\n get queryAccounts(): Readonly<Record<Query['schema'], AccountInstance | undefined>> {\n return this._queryAccounts\n }\n\n get timestamp() {\n return this.config.timestamp ?? false\n }\n\n protected abstract get _queryAccountPaths(): Record<Query['schema'], string>\n\n static _getRootFunction(funcName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let anyThis = this as any\n while (anyThis.__proto__[funcName]) {\n anyThis = anyThis.__proto__\n }\n return anyThis[funcName]\n }\n\n static _noOverride(functionName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const thisFunc = (this as any)[functionName]\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const rootFunc = this._getRootFunction(functionName)\n assertEx(thisFunc === rootFunc, `Override not allowed for [${functionName}] - override ${functionName}Handler instead`)\n }\n\n static async create<TModule extends ModuleInstance>(\n this: CreatableModule<TModule>,\n params?: Omit<TModule['params'], 'config'> & { config?: TModule['params']['config'] },\n ) {\n this._noOverride('create')\n if (!this.configSchemas || this.configSchemas.length === 0) {\n throw new Error(`Missing configSchema [${params?.config?.schema}][${this.name}]`)\n }\n\n const { account } = params ?? {}\n\n const schema: string = params?.config?.schema ?? this.configSchema\n const allowedSchemas: string[] = this.configSchemas\n\n assertEx(allowedSchemas.includes(schema), `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`)\n const mutatedConfig: TModule['params']['config'] = { ...params?.config, schema } as TModule['params']['config']\n params?.logger?.debug(`config: ${JSON.stringify(mutatedConfig, null, 2)}`)\n const mutatedParams: TModule['params'] = { ...params, config: mutatedConfig } as TModule['params']\n\n const activeLogger = params?.logger ?? AbstractModule.defaultLogger\n const generatedAccount = await AbstractModule.determineAccount({ account })\n const address = generatedAccount.address\n mutatedParams.logger = activeLogger ? new IdLogger(activeLogger, () => `0x${address}`) : undefined\n\n const newModule = new this(AbstractModule.privateConstructorKey, mutatedParams, generatedAccount)\n\n if (!AbstractModule.enableLazyLoad) {\n await newModule.start?.()\n }\n return newModule\n }\n\n static async determineAccount(params: {\n account?: AccountInstance | 'random'\n accountPath?: string\n wallet?: WalletInstance\n }): Promise<AccountInstance> {\n return await determineAccount(params, this.allowRandomAccount)\n }\n\n static factory<TModule extends ModuleInstance>(\n this: CreatableModule<TModule>,\n params?: Omit<TModule['params'], 'config'> & { config?: TModule['params']['config'] },\n ): CreatableModuleFactory<TModule> {\n return ModuleFactory.withParams(this, params)\n }\n\n _getRootFunction(funcName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let anyThis = this as any\n while (anyThis.__proto__[funcName]) {\n anyThis = anyThis.__proto__\n }\n return anyThis[funcName]\n }\n\n _noOverride(functionName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const thisFunc = (this as any)[functionName]\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const rootFunc = this._getRootFunction(functionName)\n assertEx(thisFunc === rootFunc, `Override not allowed for [${functionName}] - override ${functionName}Handler instead`)\n }\n\n async busy<R>(closure: () => Promise<R>) {\n if (this._busyCount <= 0) {\n this._busyCount = 0\n const args: ModuleBusyEventArgs = { busy: true, module: this }\n await this.emit('moduleBusy', args)\n }\n this._busyCount++\n try {\n return await closure()\n } finally {\n this._busyCount--\n if (this._busyCount <= 0) {\n this._busyCount = 0\n const args: ModuleBusyEventArgs = { busy: false, module: this }\n await this.emit('moduleBusy', args)\n }\n }\n }\n\n override emit<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return super.emit(eventName, eventArgs)\n }\n\n previousHash(): Promisable<string | undefined> {\n return this.account.previousHash\n }\n\n async query<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryResult> {\n this._noOverride('query')\n const sourceQuery = await PayloadHasher.hashAsync(query)\n return await this.busy(async () => {\n const resultPayloads: Payload[] = []\n const errorPayloads: ModuleError[] = []\n const queryAccount = this.ephemeralQueryAccountEnabled ? Account.randomSync() : undefined\n try {\n await this.started('throw')\n if (!this.allowAnonymous && query.addresses.length === 0) {\n throw new Error(`Anonymous Queries not allowed, but running anyway [${this.config.name}], [${this.address}]`)\n }\n resultPayloads.push(...(await this.queryHandler(assertEx(QueryBoundWitnessWrapper.unwrap(query)), payloads, queryConfig)))\n } catch (ex) {\n await handleErrorAsync(ex, async (error) => {\n errorPayloads.push(\n await new ModuleErrorBuilder()\n .sources([await PayloadHasher.hashAsync(query)])\n .name(this.config.name ?? '<Unknown>')\n .query(query.schema)\n .message(error.message)\n .build(),\n )\n })\n }\n if (this.timestamp) {\n const timestamp = { schema: 'network.xyo.timestamp', timestamp: Date.now() }\n resultPayloads.push(timestamp)\n }\n const result = await this.bindQueryResult(query, resultPayloads, sourceQuery, queryAccount ? [queryAccount] : [], errorPayloads)\n const args: ModuleQueriedEventArgs = { module: this, payloads, query, result }\n await this.emit('moduleQueried', args)\n return result\n })\n }\n\n queryable<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): boolean {\n if (!this.started('warn')) return false\n const configValidator = queryConfig\n ? new ModuleConfigQueryValidator(Object.assign({}, this.config, queryConfig)).queryable\n : this.moduleConfigQueryValidator\n const validators = [this.supportedQueryValidator, configValidator]\n\n return validators.every((validator) => validator(query, payloads))\n }\n\n async resolve<T extends ModuleInstance = ModuleInstance>(filter?: ModuleFilter, options?: ModuleFilterOptions<T>): Promise<T[]>\n async resolve<T extends ModuleInstance = ModuleInstance>(nameOrAddress: string, options?: ModuleFilterOptions<T>): Promise<T | undefined>\n async resolve<T extends ModuleInstance = ModuleInstance>(\n nameOrAddressOrFilter?: ModuleFilter<T> | string,\n options?: ModuleFilterOptions<T>,\n ): Promise<T | T[] | undefined> {\n const direction = options?.direction ?? 'all'\n const up = direction === 'up' || direction === 'all'\n const down = direction === 'down' || direction === 'all'\n switch (typeof nameOrAddressOrFilter) {\n case 'string': {\n return (\n (down ? await (this.downResolver as CompositeModuleResolver).resolve<T>(nameOrAddressOrFilter, options) : undefined) ??\n (up ? await (this.upResolver as CompositeModuleResolver).resolve<T>(nameOrAddressOrFilter, options) : undefined)\n )\n }\n default: {\n const filter: ModuleFilter<T> | undefined = nameOrAddressOrFilter\n return [\n ...(down ? await (this.downResolver as CompositeModuleResolver).resolve<T>(filter, options) : []),\n ...(up ? await (this.upResolver as CompositeModuleResolver).resolve<T>(filter, options) : []),\n ].filter(duplicateModules)\n }\n }\n }\n\n start(_timeout?: number): Promisable<boolean> {\n //using promise as mutex\n this._startPromise = this._startPromise ?? this.startHandler()\n return this._startPromise\n }\n\n async started(notStartedAction: 'error' | 'throw' | 'warn' | 'log' | 'none' = 'log', tryStart = true): Promise<boolean> {\n const started = await this._started\n if (started === true) {\n return true\n }\n if (!started) {\n //using promise as mutex\n this._started = (async () => {\n if (tryStart) {\n try {\n await this.start()\n return true\n } catch (ex) {\n handleError(ex, (error) => {\n this.logger?.warn(`Autostart of Module Failed: ${error.message})`)\n this._started = undefined\n })\n }\n }\n switch (notStartedAction) {\n case 'throw': {\n throw new Error(`Module not Started [${this.address}]`)\n }\n case 'warn': {\n this.logger?.warn('Module not started')\n break\n }\n case 'error': {\n this.logger?.error('Module not started')\n break\n }\n case 'none': {\n break\n }\n default: {\n this.logger?.log('Module not started')\n break\n }\n }\n return false\n })()\n }\n if (!this._started) {\n throw 'Failed to create start promise'\n }\n return await this._started\n }\n\n async stop(_timeout?: number): Promise<boolean> {\n return await this.busy(async () => {\n const result = await this.stopHandler()\n this._started = undefined\n this._startPromise = undefined\n return result\n })\n }\n\n protected bindHashes(hashes: string[], schema: SchemaString[], account?: AccountInstance) {\n const promise = new PromiseEx((resolve) => {\n const result = this.bindHashesInternal(hashes, schema, account)\n resolve?.(result)\n return result\n }, account)\n return promise\n }\n\n protected async bindHashesInternal(hashes: string[], schema: SchemaString[], account?: AccountInstance): Promise<BoundWitness> {\n const builder = new BoundWitnessBuilder().hashes(hashes, schema).witness(this.account)\n const result = (await (account ? builder.witness(account) : builder).build())[0]\n this.logger?.debug(`result: ${JSON.stringify(result, null, 2)}`)\n return result\n }\n\n protected bindQuery<T extends Query>(\n query: T,\n payloads?: Payload[],\n account?: AccountInstance,\n ): PromiseEx<[QueryBoundWitness, Payload[], Payload[]], AccountInstance> {\n const promise = new PromiseEx<[QueryBoundWitness, Payload[], Payload[]], AccountInstance>(async (resolve) => {\n const result = await this.bindQueryInternal(query, payloads, account)\n resolve?.(result)\n return result\n }, account)\n return promise\n }\n\n protected async bindQueryInternal<T extends Query>(\n query: T,\n payloads?: Payload[],\n account?: AccountInstance,\n ): Promise<[QueryBoundWitness, Payload[], Payload[]]> {\n const builder = new QueryBoundWitnessBuilder().payloads(payloads).witness(this.account).query(query)\n const result = await (account ? builder.witness(account) : builder).build()\n return result\n }\n\n protected async bindQueryResult<T extends Query>(\n query: T,\n payloads: Payload[],\n sourceQuery?: string,\n additionalWitnesses: AccountInstance[] = [],\n errors?: ModuleError[],\n ): Promise<ModuleQueryResult> {\n const builder = new BoundWitnessBuilder().payloads(payloads).errors(errors).sourceQuery(sourceQuery)\n const queryWitnessAccount = this.queryAccounts[query.schema as ModuleQueryBase['schema']]\n const witnesses = [this.account, queryWitnessAccount, ...additionalWitnesses].filter(exists)\n builder.witnesses(witnesses)\n const result: ModuleQueryResult = [(await builder.build())[0], payloads, errors ?? []]\n if (this.config.archiving) {\n await this.storeToArchivists(result.flat())\n }\n return result\n }\n\n protected async describeHandler(): Promise<ModuleDescriptionPayload> {\n const description: ModuleDescriptionPayload = {\n address: this.address,\n queries: this.queries,\n schema: ModuleDescriptionSchema,\n }\n if (this.config?.name) {\n description.name = this.config.name\n }\n\n const discover = await this.discoverHandler()\n\n description.children = compact(\n discover?.map((payload) => {\n const address = payload.schema === AddressSchema ? (payload as AddressPayload).address : undefined\n return address == this.address ? undefined : address\n }) ?? [],\n )\n\n return description\n }\n\n protected async discoverHandler(_maxDepth?: number): Promise<Payload[]> {\n const config = this.config\n const address = await new PayloadBuilder<AddressPayload>({ schema: AddressSchema })\n .fields({ address: this.address, name: this.config?.name })\n .build()\n const queries = await Promise.all(\n this.queries.map(async (query) => {\n return await new PayloadBuilder<QueryPayload>({ schema: QuerySchema }).fields({ query }).build()\n }),\n )\n const configSchema: ConfigPayload = {\n config: config.schema,\n schema: ConfigSchema,\n }\n return compact([config, configSchema, address, ...queries])\n }\n\n protected async getArchivist(): Promise<ArchivistInstance | undefined> {\n if (!this.config.archivist) return undefined\n const resolved = await this.upResolver.resolve(this.config.archivist)\n return asArchivistInstance(resolved)\n }\n\n protected async initializeQueryAccounts() {\n // Ensure distinct/unique wallet paths\n const paths = Object.values(this.queryAccountPaths).filter(exists)\n const distinctPaths = new Set<string>(paths)\n assertEx(distinctPaths.size === paths.length, `${this.config?.name ? this.config.name + ': ' : ''}Duplicate query account paths`)\n // Create an account for query this module supports\n const wallet = this.account as unknown as HDWallet\n if (wallet?.derivePath) {\n for (const key in this.queryAccountPaths) {\n if (Object.prototype.hasOwnProperty.call(this.queryAccountPaths, key)) {\n const query = key as ModuleQueryBase['schema']\n const queryAccountPath = this.queryAccountPaths[query]\n if (queryAccountPath) {\n this._queryAccounts[query] = await wallet.derivePath?.(queryAccountPath)\n }\n }\n }\n }\n }\n\n protected manifestHandler(_depth?: number, _ignoreAddresses?: string[]): Promisable<ModuleManifestPayload> {\n const name = this.config.name ?? 'Anonymous'\n return { config: { name, ...this.config }, schema: ModuleManifestPayloadSchema, status: { address: this.address } }\n }\n\n protected moduleAddressHandler(): Promisable<AddressPreviousHashPayload[]> {\n // Return array of all addresses and their previous hash\n const queryAccounts = Object.entries(this.queryAccounts)\n .filter((value): value is [string, AccountInstance] => {\n return exists(value[1])\n })\n .map(([name, account]) => {\n const address = account.address\n const previousHash = account.previousHash\n return [\n { address, name, schema: AddressSchema },\n { address, previousHash, schema: AddressPreviousHashSchema },\n ]\n })\n const address = this.address\n const name = this.config.name\n const previousHash = this.address\n const moduleAccount = name ? { address, name, schema: AddressSchema } : { address, schema: AddressSchema }\n const moduleAccountPreviousHash = previousHash\n ? { address, previousHash, schema: AddressPreviousHashSchema }\n : { address, schema: AddressPreviousHashSchema }\n return [moduleAccount, moduleAccountPreviousHash, ...queryAccounts].flat()\n }\n\n protected async queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryHandlerResult> {\n await this.started('throw')\n const wrapper = QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n switch (queryPayload.schema) {\n case ModuleManifestQuerySchema: {\n resultPayloads.push(await this.manifestHandler(queryPayload.maxDepth))\n break\n }\n case ModuleDiscoverQuerySchema: {\n const { maxDepth } = queryPayload\n resultPayloads.push(...(await this.discoverHandler(maxDepth)))\n break\n }\n case ModuleDescribeQuerySchema: {\n resultPayloads.push(await this.describeHandler())\n break\n }\n case ModuleAddressQuerySchema: {\n resultPayloads.push(...(await this.moduleAddressHandler()))\n break\n }\n case ModuleSubscribeQuerySchema: {\n this.subscribeHandler()\n break\n }\n default: {\n throw new Error(`Unsupported Query [${(queryPayload as Payload).schema}]`)\n }\n }\n return resultPayloads\n }\n\n protected async resolveArchivingArchivists(): Promise<ArchivistInstance[]> {\n const archivists = this.config.archiving?.archivists\n if (!archivists) return []\n const resolved = await Promise.all(archivists.map((archivist) => this.resolve(archivist)))\n return compact(resolved.map((mod) => asArchivistInstance(mod)))\n }\n\n protected async startHandler(): Promise<boolean> {\n this.validateConfig()\n await this.initializeQueryAccounts()\n this._started = true\n return true\n }\n\n protected stopHandler(_timeout?: number): Promisable<boolean> {\n this._started = undefined\n return true\n }\n\n protected async storeToArchivists(payloads: Payload[]): Promise<Payload[]> {\n const archivists = await this.resolveArchivingArchivists()\n return (\n await Promise.all(\n archivists.map((archivist) => {\n return archivist.insert?.(payloads)\n }),\n )\n ).map(([bw]) => bw)\n }\n\n protected subscribeHandler() {\n return\n }\n\n protected validateConfig(config?: unknown, parents: string[] = []): boolean {\n // eslint-disable-next-line unicorn/no-array-reduce\n return Object.entries(config ?? this.config ?? {}).reduce((valid, [key, value]) => {\n switch (typeof value) {\n case 'function': {\n this.logger?.warn(`Fields of type function not allowed in config [${parents?.join('.')}.${key}]`)\n return false\n }\n case 'object': {\n if (Array.isArray(value)) {\n return (\n // eslint-disable-next-line unicorn/no-array-reduce\n value.reduce((valid, value) => {\n return this.validateConfig(value, [...parents, key]) && valid\n }, true) && valid\n )\n }\n\n if (!serializableField(value)) {\n this.logger?.warn(`Fields that are not serializable to JSON are not allowed in config [${parents?.join('.')}.${key}]`)\n return false\n }\n return value ? this.validateConfig(value, [...parents, key]) && valid : true\n }\n default: {\n return valid\n }\n }\n }, true)\n }\n}\n","import { Base, BaseParams } from '@xylabs/object'\nimport { EventAnyListener, EventData, EventFunctions, EventListener, Events } from '@xyo-network/module-events'\n\nexport class BaseEmitter<TParams extends BaseParams = BaseParams, TEventData extends EventData = EventData>\n extends Base<TParams>\n implements EventFunctions<TEventData>\n{\n //just here to query types\n eventData = {} as TEventData\n\n private events: Events<TEventData>\n\n constructor(params: TParams) {\n super(params)\n this.events = new Events<TEventData>()\n }\n\n clearListeners(eventNames: keyof TEventData | (keyof TEventData)[]) {\n return this.events.clearListeners(eventNames)\n }\n\n emit<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return this.events.emit(eventName, eventArgs)\n }\n\n emitSerial<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return this.events.emitSerial(eventName, eventArgs)\n }\n\n listenerCount(eventNames: keyof TEventData | (keyof TEventData)[]) {\n return this.events.listenerCount(eventNames)\n }\n\n off<TEventName extends keyof TEventData>(eventNames: TEventName | TEventName[], listener: EventListener<TEventData[TEventName]>) {\n return this.events.off(eventNames, listener)\n }\n\n offAny(listener: EventAnyListener) {\n return this.events.offAny(listener)\n }\n\n on<TEventName extends keyof TEventData>(eventNames: TEventName | TEventName[], listener: EventListener<TEventData[TEventName]>) {\n return this.events.on(eventNames, listener)\n }\n\n onAny(listener: EventAnyListener) {\n return this.events.onAny(listener)\n }\n\n once<TEventName extends keyof TEventData>(eventName: TEventName, listener: EventListener<TEventData[TEventName]>) {\n return this.events.once(eventName, listener)\n }\n}\n","/* eslint-disable max-lines */\nimport { assertEx } from '@xylabs/assert'\nimport { Account } from '@xyo-network/account'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nexport interface DetermineAccountFromAccountParams {\n account: AccountInstance | 'random'\n}\n\nexport interface DetermineAccountFromWalletParams {\n accountPath?: string\n wallet: WalletInstance\n}\n\nexport interface DetermineRandomParams {}\n\nexport type DetermineAccountParams = DetermineAccountFromAccountParams | DetermineAccountFromWalletParams | DetermineRandomParams\n\nconst isDetermineAccountFromAccountParams = (params: DetermineAccountParams): params is DetermineAccountFromAccountParams => {\n assertEx(!(params as DetermineAccountFromWalletParams).accountPath, 'accountPath may not be provided when account is provided')\n return !!(params as DetermineAccountFromAccountParams).account\n}\n\nconst isDetermineAccountFromWalletParams = (params: DetermineAccountParams): params is DetermineAccountFromWalletParams => {\n return !!(params as DetermineAccountFromWalletParams).wallet\n}\n\nexport async function determineAccount(params: DetermineAccountParams, allowRandomAccount = true): Promise<AccountInstance> {\n if (isDetermineAccountFromAccountParams(params)) {\n if (params.account === 'random') {\n assertEx(allowRandomAccount, 'Random address not allowed')\n return Account.randomSync()\n }\n return params.account\n }\n\n if (isDetermineAccountFromWalletParams(params)) {\n return assertEx(params.accountPath ? await params.wallet.derivePath(params.accountPath) : params.wallet, 'Failed to derive account from path')\n }\n\n //this should eventually be removed/thrown\n console.warn('AbstractModule.determineAccount: No account or wallet provided - Creating Random account')\n return Account.randomSync()\n}\n","import { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { ModuleError, ModuleErrorSchema } from '@xyo-network/payload-model'\n\nexport class ModuleErrorBuilder extends PayloadBuilder<ModuleError> {\n _message?: string\n _name?: string\n _query?: string\n _sources?: string[]\n constructor() {\n super({ schema: ModuleErrorSchema })\n }\n\n override build(): Promise<ModuleError> {\n return Promise.resolve({\n message: this._message,\n name: this._name,\n query: this._query,\n schema: ModuleErrorSchema,\n sources: this._sources,\n })\n }\n\n message(message: string) {\n this._message = message\n return this\n }\n\n name(name: string) {\n this._name = name\n return this\n }\n\n query(query: string) {\n this._query = query\n return this\n }\n\n sources(sources: string[]) {\n this._sources = sources\n return this\n }\n}\n","import { Address } from '@xylabs/hex'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { AnyConfigSchema, CosigningAddressSet, ModuleConfig, ModuleQuery, SchemaString } from '@xyo-network/module-model'\n\nimport { Queryable, QueryValidator } from './QueryValidator'\n\nexport type SortedPipedAddressesString = string\n\nconst delimiter = ''\n\nexport class ModuleConfigQueryValidator<TConfig extends AnyConfigSchema<ModuleConfig>> implements QueryValidator {\n protected allowed: Record<SchemaString, SortedPipedAddressesString[]> = {}\n protected disallowed: Record<SchemaString, Address[]> = {}\n protected readonly hasAllowedRules: boolean\n protected readonly hasDisallowedRules: boolean\n protected readonly hasRules: boolean\n\n constructor(config?: TConfig) {\n if (config?.security?.allowed) {\n for (const [schema, addresses] of Object.entries(config.security?.allowed)) {\n this.allowed[schema] = addresses.map(toAddressesString)\n }\n }\n if (config?.security?.disallowed) {\n for (const [schema, addresses] of Object.entries(config.security?.disallowed)) {\n this.disallowed[schema] = addresses.map(toAddressesString)\n }\n }\n this.hasAllowedRules = Object.keys(this.allowed).length > 0\n this.hasDisallowedRules = Object.keys(this.disallowed).length > 0\n this.hasRules = this.hasAllowedRules || this.hasDisallowedRules\n }\n\n queryable: Queryable = async (query, payloads) => {\n if (!this.hasRules) return true\n const addresses = query.addresses\n if (addresses.length === 0) return false\n const wrapper = QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)\n const schema = (await wrapper.getQuery()).schema\n return this.queryAllowed(schema, addresses) && !this.queryDisallowed(schema, addresses)\n }\n\n protected queryAllowed = (schema: SchemaString, addresses: string[]): boolean => {\n if (!this.hasAllowedRules) return true\n // All cosigners must sign\n if (addresses.length > 1) {\n const signatories = toAddressesString(addresses)\n const validCosigners = this.allowed?.[schema]?.includes(signatories)\n if (validCosigners) return true\n }\n // OR all signers have to be allowed individually\n return addresses.every((address) => this.allowed?.[schema]?.includes(address) || false)\n }\n protected queryDisallowed = (schema: SchemaString, addresses: string[]): boolean => {\n if (!this.hasDisallowedRules) return false\n return addresses.some((address) => this.disallowed?.[schema]?.includes(address))\n }\n}\n\n// TODO: Handle 0x prefix\nconst toAddressesString = (addresses: string | CosigningAddressSet): SortedPipedAddressesString => {\n return Array.isArray(addresses)\n ? addresses\n .sort()\n .map((address) => address.toLowerCase())\n .join(delimiter)\n : addresses.toLowerCase()\n}\n","import { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { Module, ModuleQuery } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nimport { Queryable, QueryValidator } from './QueryValidator'\n\nexport const isQuerySupportedByModule = async <T extends QueryBoundWitness = QueryBoundWitness>(\n mod: Module,\n query: T,\n payloads?: Payload[],\n): Promise<boolean> => {\n const wrapper = QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)\n const schema = (await wrapper.getQuery()).schema\n return mod.queries.includes(schema)\n}\n\nexport class SupportedQueryValidator implements QueryValidator {\n constructor(protected readonly mod: Module) {}\n queryable: Queryable = (query, payloads) => {\n return isQuerySupportedByModule(this.mod, query, payloads)\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { ModuleManifestPayload } from '@xyo-network/manifest-model'\nimport { AddressPreviousHashPayload, Module, ModuleDescriptionPayload, ModuleEventData, ModuleParams } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nimport { AbstractModule } from './AbstractModule'\n\nexport abstract class AbstractModuleInstance<TParams extends ModuleParams = ModuleParams, TEventData extends ModuleEventData = ModuleEventData>\n extends AbstractModule<TParams, TEventData>\n implements Module<TParams, TEventData>\n{\n constructor(privateConstructorKey: string, params: TParams, account: AccountInstance) {\n assertEx(AbstractModule.privateConstructorKey === privateConstructorKey, 'Use create function instead of constructor')\n // Clone params to prevent mutation of the incoming object\n const mutatedParams = { ...params } as TParams\n super(privateConstructorKey, mutatedParams, account)\n this.upResolver.add(this)\n this.downResolver.add(this)\n }\n\n describe(): Promise<ModuleDescriptionPayload> {\n return this.busy(async () => {\n return await this.describeHandler()\n })\n }\n\n discover(): Promise<Payload[]> {\n return this.busy(async () => {\n return await this.discoverHandler()\n })\n }\n\n manifest(maxDepth?: number, ignoreAddresses?: string[]): Promise<ModuleManifestPayload> {\n return this.busy(async () => {\n return await this.manifestHandler(maxDepth, ignoreAddresses)\n })\n }\n\n moduleAddress(): Promise<AddressPreviousHashPayload[]> {\n return this.busy(async () => {\n return await this.moduleAddressHandler()\n })\n }\n\n subscribe(_queryAccount?: AccountInstance) {\n return this.subscribeHandler()\n }\n}\n"],"mappings":"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","names":["import_assert","import_account","import_boundwitness_builder","import_payload_builder","BaseEmitter","Base","eventData","events","constructor","params","Events","clearListeners","eventNames","emit","eventName","eventArgs","emitSerial","listenerCount","off","listener","offAny","on","onAny","once","isDetermineAccountFromAccountParams","params","assertEx","accountPath","account","isDetermineAccountFromWalletParams","wallet","determineAccount","allowRandomAccount","Account","randomSync","derivePath","console","warn","ModuleErrorBuilder","PayloadBuilder","_message","_name","_query","_sources","constructor","schema","ModuleErrorSchema","build","Promise","resolve","message","name","query","sources","delimiter","ModuleConfigQueryValidator","allowed","disallowed","hasAllowedRules","hasDisallowedRules","hasRules","constructor","config","security","schema","addresses","Object","entries","map","toAddressesString","keys","length","queryable","query","payloads","wrapper","QueryBoundWitnessWrapper","parseQuery","getQuery","queryAllowed","queryDisallowed","signatories","validCosigners","includes","every","address","_a","_b","some","Array","isArray","sort","toLowerCase","join","import_boundwitness_builder","isQuerySupportedByModule","mod","query","payloads","wrapper","QueryBoundWitnessWrapper","parseQuery","schema","getQuery","queries","includes","SupportedQueryValidator","constructor","queryable","AbstractModule","BaseEmitter","downResolver","CompositeModuleResolver","upResolver","_account","undefined","_baseModuleQueryAccountPaths","ModuleAddressQuerySchema","ModuleDescribeQuerySchema","ModuleDiscoverQuerySchema","ModuleManifestQuerySchema","ModuleSubscribeQuerySchema","_queryAccounts","_startPromise","_started","moduleConfigQueryValidator","supportedQueryValidator","_busyCount","constructor","privateConstructorKey","params","account","assertEx","mutatedParams","SupportedQueryValidator","queryable","ModuleConfigQueryValidator","config","configSchema","configSchemas","address","allowAnonymous","security","ephemeralQueryAccountEnabled","id","name","queries","queryAccountPaths","_queryAccountPaths","queryAccounts","timestamp","_getRootFunction","funcName","anyThis","__proto__","_noOverride","functionName","thisFunc","rootFunc","create","length","Error","schema","allowedSchemas","includes","JSON","stringify","mutatedConfig","logger","debug","activeLogger","defaultLogger","generatedAccount","determineAccount","IdLogger","newModule","enableLazyLoad","start","allowRandomAccount","factory","ModuleFactory","withParams","busy","closure","args","module","emit","eventName","eventArgs","previousHash","query","payloads","queryConfig","sourceQuery","PayloadHasher","hashAsync","resultPayloads","errorPayloads","queryAccount","Account","randomSync","started","addresses","push","queryHandler","QueryBoundWitnessWrapper","unwrap","ex","handleErrorAsync","error","ModuleErrorBuilder","sources","message","build","Date","now","result","bindQueryResult","configValidator","Object","assign","validators","every","validator","resolve","nameOrAddressOrFilter","options","direction","up","down","filter","duplicateModules","_timeout","startHandler","notStartedAction","tryStart","handleError","_a","warn","log","stop","stopHandler","bindHashes","hashes","promise","PromiseEx","bindHashesInternal","builder","BoundWitnessBuilder","witness","bindQuery","bindQueryInternal","QueryBoundWitnessBuilder","additionalWitnesses","errors","queryWitnessAccount","witnesses","exists","archiving","storeToArchivists","flat","describeHandler","description","ModuleDescriptionSchema","discover","discoverHandler","children","compact","map","payload","AddressSchema","_maxDepth","PayloadBuilder","fields","Promise","all","QuerySchema","ConfigSchema","getArchivist","archivist","resolved","asArchivistInstance","initializeQueryAccounts","paths","values","distinctPaths","Set","size","wallet","derivePath","key","prototype","hasOwnProperty","call","queryAccountPath","manifestHandler","_depth","_ignoreAddresses","ModuleManifestPayloadSchema","status","moduleAddressHandler","entries","value","AddressPreviousHashSchema","moduleAccount","moduleAccountPreviousHash","wrapper","parseQuery","queryPayload","getQuery","maxDepth","subscribeHandler","resolveArchivingArchivists","archivists","mod","validateConfig","insert","bw","parents","reduce","valid","join","Array","isArray","serializableField","toString","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 { handleError, handleErrorAsync } from '@xylabs/error'\nimport { exists } from '@xylabs/exists'\nimport { compact } from '@xylabs/lodash'\nimport { IdLogger } from '@xylabs/logger'\nimport { Promisable, PromiseEx } from '@xylabs/promise'\nimport { Account, HDWallet } from '@xyo-network/account'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { AddressPayload, AddressSchema } from '@xyo-network/address-payload-plugin'\nimport { ArchivistInstance, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitnessBuilder, QueryBoundWitnessBuilder, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { ConfigPayload, ConfigSchema } from '@xyo-network/config-payload-plugin'\nimport { ModuleManifestPayload, ModuleManifestPayloadSchema } from '@xyo-network/manifest-model'\nimport {\n AddressPreviousHashPayload,\n AddressPreviousHashSchema,\n CreatableModule,\n CreatableModuleFactory,\n duplicateModules,\n Module,\n ModuleAddressQuerySchema,\n ModuleBusyEventArgs,\n ModuleConfig,\n ModuleDescribeQuerySchema,\n ModuleDescriptionPayload,\n ModuleDescriptionSchema,\n ModuleDiscoverQuerySchema,\n ModuleEventData,\n ModuleFactory,\n ModuleFilter,\n ModuleFilterOptions,\n ModuleInstance,\n ModuleManifestQuerySchema,\n ModuleParams,\n ModuleQueriedEventArgs,\n ModuleQuery,\n ModuleQueryBase,\n ModuleQueryHandlerResult,\n ModuleQueryResult,\n ModuleSubscribeQuerySchema,\n SchemaString,\n serializableField,\n} from '@xyo-network/module-model'\nimport { CompositeModuleResolver } from '@xyo-network/module-resolver'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { ModuleError, Payload, Query, WithMeta } from '@xyo-network/payload-model'\nimport { QueryPayload, QuerySchema } from '@xyo-network/query-payload-plugin'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nimport { BaseEmitter } from './BaseEmitter'\nimport { determineAccount } from './determineAccount'\nimport { ModuleErrorBuilder } from './Error'\nimport { ModuleConfigQueryValidator, Queryable, SupportedQueryValidator } from './QueryValidator'\n\nexport abstract class AbstractModule<TParams extends ModuleParams = ModuleParams, TEventData extends ModuleEventData = ModuleEventData>\n extends BaseEmitter<TParams, TEventData>\n implements Module<TParams, TEventData>\n{\n static readonly allowRandomAccount: boolean = true\n static configSchemas: string[]\n static enableLazyLoad = false\n\n protected static privateConstructorKey = Date.now().toString()\n\n readonly downResolver: Omit<CompositeModuleResolver, 'resolve'> = new CompositeModuleResolver()\n readonly upResolver: Omit<CompositeModuleResolver, 'resolve>'> = new CompositeModuleResolver()\n\n protected _account: AccountInstance | undefined = undefined\n protected readonly _baseModuleQueryAccountPaths: Record<ModuleQueryBase['schema'], string> = {\n [ModuleAddressQuerySchema]: '1',\n [ModuleDescribeQuerySchema]: '4',\n [ModuleDiscoverQuerySchema]: '2',\n [ModuleManifestQuerySchema]: '5',\n [ModuleSubscribeQuerySchema]: '3',\n }\n protected readonly _queryAccounts: Record<ModuleQueryBase['schema'], AccountInstance | undefined> = {\n [ModuleAddressQuerySchema]: undefined,\n [ModuleDescribeQuerySchema]: undefined,\n [ModuleDiscoverQuerySchema]: undefined,\n [ModuleManifestQuerySchema]: undefined,\n [ModuleSubscribeQuerySchema]: undefined,\n }\n protected _startPromise: Promisable<boolean> | undefined = undefined\n protected _started: Promisable<boolean> | undefined = undefined\n protected readonly moduleConfigQueryValidator: Queryable\n protected readonly supportedQueryValidator: Queryable\n\n private _busyCount = 0\n\n constructor(privateConstructorKey: string, params: TParams, account: AccountInstance) {\n assertEx(AbstractModule.privateConstructorKey === privateConstructorKey, 'Use create function instead of constructor')\n // Clone params to prevent mutation of the incoming object\n const mutatedParams = { ...params } as TParams\n super(mutatedParams)\n\n this._account = account\n\n this.supportedQueryValidator = new SupportedQueryValidator(this as Module).queryable\n this.moduleConfigQueryValidator = new ModuleConfigQueryValidator(mutatedParams?.config).queryable\n }\n\n static get configSchema(): string {\n return this.configSchemas[0]\n }\n\n get account() {\n return assertEx(this._account, 'Missing account')\n }\n\n get address() {\n return this.account.address\n }\n\n get allowAnonymous() {\n return !!this.config.security?.allowAnonymous\n }\n\n get config(): TParams['config'] {\n return this.params.config\n }\n\n get ephemeralQueryAccountEnabled(): boolean {\n return !!this.params.ephemeralQueryAccountEnabled\n }\n\n get id() {\n return this.config.name ?? this.address\n }\n\n get queries(): string[] {\n return [ModuleDiscoverQuerySchema, ModuleAddressQuerySchema, ModuleSubscribeQuerySchema, ModuleDescribeQuerySchema, ModuleManifestQuerySchema]\n }\n\n get queryAccountPaths(): Readonly<Record<Query['schema'], string | undefined>> {\n return { ...this._baseModuleQueryAccountPaths, ...this._queryAccountPaths }\n }\n\n get queryAccounts(): Readonly<Record<Query['schema'], AccountInstance | undefined>> {\n return this._queryAccounts\n }\n\n get timestamp() {\n return this.config.timestamp ?? false\n }\n\n protected abstract get _queryAccountPaths(): Record<Query['schema'], string>\n\n static _getRootFunction(funcName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let anyThis = this as any\n while (anyThis.__proto__[funcName]) {\n anyThis = anyThis.__proto__\n }\n return anyThis[funcName]\n }\n\n static _noOverride(functionName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const thisFunc = (this as any)[functionName]\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const rootFunc = this._getRootFunction(functionName)\n assertEx(thisFunc === rootFunc, `Override not allowed for [${functionName}] - override ${functionName}Handler instead`)\n }\n\n static async create<TModule extends ModuleInstance>(\n this: CreatableModule<TModule>,\n params?: Omit<TModule['params'], 'config'> & { config?: TModule['params']['config'] },\n ) {\n this._noOverride('create')\n if (!this.configSchemas || this.configSchemas.length === 0) {\n throw new Error(`Missing configSchema [${params?.config?.schema}][${this.name}]`)\n }\n\n const { account } = params ?? {}\n\n const schema: string = params?.config?.schema ?? this.configSchema\n const allowedSchemas: string[] = this.configSchemas\n\n assertEx(allowedSchemas.includes(schema), `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`)\n const mutatedConfig: TModule['params']['config'] = { ...params?.config, schema } as TModule['params']['config']\n params?.logger?.debug(`config: ${JSON.stringify(mutatedConfig, null, 2)}`)\n const mutatedParams: TModule['params'] = { ...params, config: mutatedConfig } as TModule['params']\n\n const activeLogger = params?.logger ?? AbstractModule.defaultLogger\n const generatedAccount = await AbstractModule.determineAccount({ account })\n const address = generatedAccount.address\n mutatedParams.logger = activeLogger ? new IdLogger(activeLogger, () => `0x${address}`) : undefined\n\n const newModule = new this(AbstractModule.privateConstructorKey, mutatedParams, generatedAccount)\n\n if (!AbstractModule.enableLazyLoad) {\n await newModule.start?.()\n }\n return newModule\n }\n\n static async determineAccount(params: {\n account?: AccountInstance | 'random'\n accountPath?: string\n wallet?: WalletInstance\n }): Promise<AccountInstance> {\n return await determineAccount(params, this.allowRandomAccount)\n }\n\n static factory<TModule extends ModuleInstance>(\n this: CreatableModule<TModule>,\n params?: Omit<TModule['params'], 'config'> & { config?: TModule['params']['config'] },\n ): CreatableModuleFactory<TModule> {\n return ModuleFactory.withParams(this, params)\n }\n\n _getRootFunction(funcName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let anyThis = this as any\n while (anyThis.__proto__[funcName]) {\n anyThis = anyThis.__proto__\n }\n return anyThis[funcName]\n }\n\n _noOverride(functionName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const thisFunc = (this as any)[functionName]\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const rootFunc = this._getRootFunction(functionName)\n assertEx(thisFunc === rootFunc, `Override not allowed for [${functionName}] - override ${functionName}Handler instead`)\n }\n\n async busy<R>(closure: () => Promise<R>) {\n if (this._busyCount <= 0) {\n this._busyCount = 0\n const args: ModuleBusyEventArgs = { busy: true, module: this }\n await this.emit('moduleBusy', args)\n }\n this._busyCount++\n try {\n return await closure()\n } finally {\n this._busyCount--\n if (this._busyCount <= 0) {\n this._busyCount = 0\n const args: ModuleBusyEventArgs = { busy: false, module: this }\n await this.emit('moduleBusy', args)\n }\n }\n }\n\n override emit<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return super.emit(eventName, eventArgs)\n }\n\n previousHash(): Promisable<string | undefined> {\n return this.account.previousHash\n }\n\n async query<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryResult> {\n this._noOverride('query')\n const sourceQuery = await PayloadBuilder.build(assertEx(await QueryBoundWitnessWrapper.unwrap(query), 'Invalid query'))\n return await this.busy(async () => {\n const resultPayloads: Payload[] = []\n const errorPayloads: ModuleError[] = []\n const queryAccount = this.ephemeralQueryAccountEnabled ? Account.randomSync() : undefined\n try {\n await this.started('throw')\n if (!this.allowAnonymous && query.addresses.length === 0) {\n throw new Error(`Anonymous Queries not allowed, but running anyway [${this.config.name}], [${this.address}]`)\n }\n resultPayloads.push(...(await this.queryHandler(sourceQuery, payloads, queryConfig)))\n } catch (ex) {\n await handleErrorAsync(ex, async (error) => {\n errorPayloads.push(\n await new ModuleErrorBuilder()\n .sources([sourceQuery.$hash])\n .name(this.config.name ?? '<Unknown>')\n .query(sourceQuery.schema)\n .message(error.message)\n .build(),\n )\n })\n }\n if (this.timestamp) {\n const timestamp = { schema: 'network.xyo.timestamp', timestamp: Date.now() }\n resultPayloads.push(timestamp)\n }\n const result = await this.bindQueryResult(sourceQuery, resultPayloads, queryAccount ? [queryAccount] : [], errorPayloads)\n const args: ModuleQueriedEventArgs = { module: this, payloads, query: sourceQuery, result }\n await this.emit('moduleQueried', args)\n return result\n })\n }\n\n async queryable<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<boolean> {\n if (!(await this.started('warn'))) return false\n const configValidator = queryConfig\n ? new ModuleConfigQueryValidator(Object.assign({}, this.config, queryConfig)).queryable\n : this.moduleConfigQueryValidator\n const validators = [this.supportedQueryValidator, configValidator]\n\n return validators.every((validator) => validator(query, payloads))\n }\n\n async resolve<T extends ModuleInstance = ModuleInstance>(filter?: ModuleFilter, options?: ModuleFilterOptions<T>): Promise<T[]>\n async resolve<T extends ModuleInstance = ModuleInstance>(nameOrAddress: string, options?: ModuleFilterOptions<T>): Promise<T | undefined>\n async resolve<T extends ModuleInstance = ModuleInstance>(\n nameOrAddressOrFilter?: ModuleFilter<T> | string,\n options?: ModuleFilterOptions<T>,\n ): Promise<T | T[] | undefined> {\n const direction = options?.direction ?? 'all'\n const up = direction === 'up' || direction === 'all'\n const down = direction === 'down' || direction === 'all'\n switch (typeof nameOrAddressOrFilter) {\n case 'string': {\n return (\n (down ? await (this.downResolver as CompositeModuleResolver).resolve<T>(nameOrAddressOrFilter, options) : undefined) ??\n (up ? await (this.upResolver as CompositeModuleResolver).resolve<T>(nameOrAddressOrFilter, options) : undefined)\n )\n }\n default: {\n const filter: ModuleFilter<T> | undefined = nameOrAddressOrFilter\n return [\n ...(down ? await (this.downResolver as CompositeModuleResolver).resolve<T>(filter, options) : []),\n ...(up ? await (this.upResolver as CompositeModuleResolver).resolve<T>(filter, options) : []),\n ].filter(duplicateModules)\n }\n }\n }\n\n start(_timeout?: number): Promisable<boolean> {\n //using promise as mutex\n this._startPromise = this._startPromise ?? this.startHandler()\n return this._startPromise\n }\n\n async started(notStartedAction: 'error' | 'throw' | 'warn' | 'log' | 'none' = 'log', tryStart = true): Promise<boolean> {\n const started = await this._started\n if (started === true) {\n return true\n }\n if (!started) {\n //using promise as mutex\n this._started = (async () => {\n if (tryStart) {\n try {\n await this.start()\n return true\n } catch (ex) {\n handleError(ex, (error) => {\n this.logger?.warn(`Autostart of Module Failed: ${error.message})`)\n this._started = undefined\n })\n }\n }\n switch (notStartedAction) {\n case 'throw': {\n throw new Error(`Module not Started [${this.address}]`)\n }\n case 'warn': {\n this.logger?.warn('Module not started')\n break\n }\n case 'error': {\n this.logger?.error('Module not started')\n break\n }\n case 'none': {\n break\n }\n default: {\n this.logger?.log('Module not started')\n break\n }\n }\n return false\n })()\n }\n if (!this._started) {\n throw 'Failed to create start promise'\n }\n return await this._started\n }\n\n async stop(_timeout?: number): Promise<boolean> {\n return await this.busy(async () => {\n const result = await this.stopHandler()\n this._started = undefined\n this._startPromise = undefined\n return result\n })\n }\n\n protected bindHashes(hashes: string[], schema: SchemaString[], account?: AccountInstance) {\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n const promise = new PromiseEx((resolve) => {\n const result = this.bindHashesInternal(hashes, schema, account)\n resolve?.(result)\n return result\n }, account)\n return promise\n }\n\n protected async bindHashesInternal(hashes: string[], schema: SchemaString[], account?: AccountInstance): Promise<BoundWitness> {\n const builder = new BoundWitnessBuilder().hashes(hashes, schema).witness(this.account)\n const result = (await (account ? builder.witness(account) : builder).build())[0]\n this.logger?.debug(`result: ${JSON.stringify(result, null, 2)}`)\n return result\n }\n\n protected bindQuery<T extends Query>(\n query: T,\n payloads?: Payload[],\n account?: AccountInstance,\n ): PromiseEx<[QueryBoundWitness, Payload[], Payload[]], AccountInstance> {\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n const promise = new PromiseEx<[QueryBoundWitness, Payload[], Payload[]], AccountInstance>(async (resolve) => {\n const result = await this.bindQueryInternal(query, payloads, account)\n resolve?.(result)\n return result\n }, account)\n return promise\n }\n\n protected async bindQueryInternal<T extends Query>(\n query: T,\n payloads?: Payload[],\n account?: AccountInstance,\n ): Promise<[QueryBoundWitness, Payload[], Payload[]]> {\n const builder = await (await new QueryBoundWitnessBuilder().payloads(payloads)).witness(this.account).query(query)\n const result = await (account ? builder.witness(account) : builder).build()\n return result\n }\n\n protected async bindQueryResult<T extends Query>(\n query: WithMeta<T>,\n payloads: Payload[],\n additionalWitnesses: AccountInstance[] = [],\n errors?: ModuleError[],\n ): Promise<ModuleQueryResult> {\n const builder = (await (await new BoundWitnessBuilder().payloads(payloads)).errors(errors)).sourceQuery(query.$hash)\n const queryWitnessAccount = this.queryAccounts[query.schema as ModuleQueryBase['schema']]\n const witnesses = [this.account, queryWitnessAccount, ...additionalWitnesses].filter(exists)\n builder.witnesses(witnesses)\n const result: ModuleQueryResult = [(await builder.build())[0], payloads, errors ?? []]\n if (this.config.archiving) {\n await this.storeToArchivists(result.flat())\n }\n return result\n }\n\n protected async describeHandler(): Promise<ModuleDescriptionPayload> {\n const description: ModuleDescriptionPayload = {\n address: this.address,\n queries: this.queries,\n schema: ModuleDescriptionSchema,\n }\n if (this.config?.name) {\n description.name = this.config.name\n }\n\n const discover = await this.discoverHandler()\n\n description.children = compact(\n discover?.map((payload) => {\n const address = payload.schema === AddressSchema ? (payload as AddressPayload).address : undefined\n return address == this.address ? undefined : address\n }) ?? [],\n )\n\n return description\n }\n\n protected async discoverHandler(_maxDepth?: number): Promise<Payload[]> {\n const config = this.config\n const address = await new PayloadBuilder<AddressPayload>({ schema: AddressSchema })\n .fields({ address: this.address, name: this.config?.name })\n .build()\n const queries = await Promise.all(\n this.queries.map(async (query) => {\n return await new PayloadBuilder<QueryPayload>({ schema: QuerySchema }).fields({ query }).build()\n }),\n )\n const configSchema: ConfigPayload = {\n config: config.schema,\n schema: ConfigSchema,\n }\n return compact([config, configSchema, address, ...queries])\n }\n\n protected async getArchivist(): Promise<ArchivistInstance | undefined> {\n if (!this.config.archivist) return undefined\n const resolved = await this.upResolver.resolve(this.config.archivist)\n return asArchivistInstance(resolved)\n }\n\n protected async initializeQueryAccounts() {\n // Ensure distinct/unique wallet paths\n const paths = Object.values(this.queryAccountPaths).filter(exists)\n const distinctPaths = new Set<string>(paths)\n assertEx(distinctPaths.size === paths.length, `${this.config?.name ? this.config.name + ': ' : ''}Duplicate query account paths`)\n // Create an account for query this module supports\n const wallet = this.account as unknown as HDWallet\n if (wallet?.derivePath) {\n for (const key in this.queryAccountPaths) {\n if (Object.prototype.hasOwnProperty.call(this.queryAccountPaths, key)) {\n const query = key as ModuleQueryBase['schema']\n const queryAccountPath = this.queryAccountPaths[query]\n if (queryAccountPath) {\n this._queryAccounts[query] = await wallet.derivePath?.(queryAccountPath)\n }\n }\n }\n }\n }\n\n protected manifestHandler(_depth?: number, _ignoreAddresses?: string[]): Promisable<ModuleManifestPayload> {\n const name = this.config.name ?? 'Anonymous'\n return { config: { name, ...this.config }, schema: ModuleManifestPayloadSchema, status: { address: this.address } }\n }\n\n protected moduleAddressHandler(): Promisable<AddressPreviousHashPayload[]> {\n // Return array of all addresses and their previous hash\n const queryAccounts = Object.entries(this.queryAccounts)\n .filter((value): value is [string, AccountInstance] => {\n return exists(value[1])\n })\n .map(([name, account]) => {\n const address = account.address\n const previousHash = account.previousHash\n return [\n { address, name, schema: AddressSchema },\n { address, previousHash, schema: AddressPreviousHashSchema },\n ]\n })\n const address = this.address\n const name = this.config.name\n const previousHash = this.address\n const moduleAccount = name ? { address, name, schema: AddressSchema } : { address, schema: AddressSchema }\n const moduleAccountPreviousHash = previousHash\n ? { address, previousHash, schema: AddressPreviousHashSchema }\n : { address, schema: AddressPreviousHashSchema }\n return [moduleAccount, moduleAccountPreviousHash, ...queryAccounts].flat()\n }\n\n protected async queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryHandlerResult> {\n await this.started('throw')\n const wrapper = await QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(await this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n switch (queryPayload.schema) {\n case ModuleManifestQuerySchema: {\n resultPayloads.push(await this.manifestHandler(queryPayload.maxDepth))\n break\n }\n case ModuleDiscoverQuerySchema: {\n const { maxDepth } = queryPayload\n resultPayloads.push(...(await this.discoverHandler(maxDepth)))\n break\n }\n case ModuleDescribeQuerySchema: {\n resultPayloads.push(await this.describeHandler())\n break\n }\n case ModuleAddressQuerySchema: {\n resultPayloads.push(...(await this.moduleAddressHandler()))\n break\n }\n case ModuleSubscribeQuerySchema: {\n this.subscribeHandler()\n break\n }\n default: {\n throw new Error(`Unsupported Query [${(queryPayload as Payload).schema}]`)\n }\n }\n return resultPayloads\n }\n\n protected async resolveArchivingArchivists(): Promise<ArchivistInstance[]> {\n const archivists = this.config.archiving?.archivists\n if (!archivists) return []\n const resolved = await Promise.all(archivists.map((archivist) => this.resolve(archivist)))\n return compact(resolved.map((mod) => asArchivistInstance(mod)))\n }\n\n protected async startHandler(): Promise<boolean> {\n this.validateConfig()\n await this.initializeQueryAccounts()\n this._started = true\n return true\n }\n\n protected stopHandler(_timeout?: number): Promisable<boolean> {\n this._started = undefined\n return true\n }\n\n protected async storeToArchivists(payloads: Payload[]): Promise<Payload[]> {\n const archivists = await this.resolveArchivingArchivists()\n return (\n await Promise.all(\n archivists.map((archivist) => {\n return archivist.insert?.(payloads)\n }),\n )\n ).map(([bw]) => bw)\n }\n\n protected subscribeHandler() {\n return\n }\n\n protected validateConfig(config?: unknown, parents: string[] = []): boolean {\n // eslint-disable-next-line unicorn/no-array-reduce\n return Object.entries(config ?? this.config ?? {}).reduce((valid, [key, value]) => {\n switch (typeof value) {\n case 'function': {\n this.logger?.warn(`Fields of type function not allowed in config [${parents?.join('.')}.${key}]`)\n return false\n }\n case 'object': {\n if (Array.isArray(value)) {\n return (\n // eslint-disable-next-line unicorn/no-array-reduce\n value.reduce((valid, value) => {\n return this.validateConfig(value, [...parents, key]) && valid\n }, true) && valid\n )\n }\n\n if (!serializableField(value)) {\n this.logger?.warn(`Fields that are not serializable to JSON are not allowed in config [${parents?.join('.')}.${key}]`)\n return false\n }\n return value ? this.validateConfig(value, [...parents, key]) && valid : true\n }\n default: {\n return valid\n }\n }\n }, true)\n }\n}\n","import { Base, BaseParams } from '@xylabs/object'\nimport { EventAnyListener, EventData, EventFunctions, EventListener, Events } from '@xyo-network/module-events'\n\nexport class BaseEmitter<TParams extends BaseParams = BaseParams, TEventData extends EventData = EventData>\n extends Base<TParams>\n implements EventFunctions<TEventData>\n{\n //just here to query types\n eventData = {} as TEventData\n\n private events: Events<TEventData>\n\n constructor(params: TParams) {\n super(params)\n this.events = new Events<TEventData>()\n }\n\n clearListeners(eventNames: keyof TEventData | (keyof TEventData)[]) {\n return this.events.clearListeners(eventNames)\n }\n\n emit<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return this.events.emit(eventName, eventArgs)\n }\n\n emitSerial<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return this.events.emitSerial(eventName, eventArgs)\n }\n\n listenerCount(eventNames: keyof TEventData | (keyof TEventData)[]) {\n return this.events.listenerCount(eventNames)\n }\n\n off<TEventName extends keyof TEventData>(eventNames: TEventName | TEventName[], listener: EventListener<TEventData[TEventName]>) {\n return this.events.off(eventNames, listener)\n }\n\n offAny(listener: EventAnyListener) {\n return this.events.offAny(listener)\n }\n\n on<TEventName extends keyof TEventData>(eventNames: TEventName | TEventName[], listener: EventListener<TEventData[TEventName]>) {\n return this.events.on(eventNames, listener)\n }\n\n onAny(listener: EventAnyListener) {\n return this.events.onAny(listener)\n }\n\n once<TEventName extends keyof TEventData>(eventName: TEventName, listener: EventListener<TEventData[TEventName]>) {\n return this.events.once(eventName, listener)\n }\n}\n","/* eslint-disable max-lines */\nimport { assertEx } from '@xylabs/assert'\nimport { Account } from '@xyo-network/account'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nexport interface DetermineAccountFromAccountParams {\n account: AccountInstance | 'random'\n}\n\nexport interface DetermineAccountFromWalletParams {\n accountPath?: string\n wallet: WalletInstance\n}\n\nexport interface DetermineRandomParams {}\n\nexport type DetermineAccountParams = DetermineAccountFromAccountParams | DetermineAccountFromWalletParams | DetermineRandomParams\n\nconst isDetermineAccountFromAccountParams = (params: DetermineAccountParams): params is DetermineAccountFromAccountParams => {\n assertEx(!(params as DetermineAccountFromWalletParams).accountPath, 'accountPath may not be provided when account is provided')\n return !!(params as DetermineAccountFromAccountParams).account\n}\n\nconst isDetermineAccountFromWalletParams = (params: DetermineAccountParams): params is DetermineAccountFromWalletParams => {\n return !!(params as DetermineAccountFromWalletParams).wallet\n}\n\nexport async function determineAccount(params: DetermineAccountParams, allowRandomAccount = true): Promise<AccountInstance> {\n if (isDetermineAccountFromAccountParams(params)) {\n if (params.account === 'random') {\n assertEx(allowRandomAccount, 'Random address not allowed')\n return Account.randomSync()\n }\n return params.account\n }\n\n if (isDetermineAccountFromWalletParams(params)) {\n return assertEx(params.accountPath ? await params.wallet.derivePath(params.accountPath) : params.wallet, 'Failed to derive account from path')\n }\n\n //this should eventually be removed/thrown\n console.warn('AbstractModule.determineAccount: No account or wallet provided - Creating Random account')\n return Account.randomSync()\n}\n","import { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { ModuleError, ModuleErrorSchema, WithMeta } from '@xyo-network/payload-model'\n\nexport class ModuleErrorBuilder extends PayloadBuilder<ModuleError> {\n _message?: string\n _name?: string\n _query?: string\n _sources?: string[]\n constructor() {\n super({ schema: ModuleErrorSchema })\n }\n\n override build(): Promise<WithMeta<ModuleError>> {\n this.fields({\n message: this._message,\n name: this._name,\n query: this._query,\n schema: ModuleErrorSchema,\n sources: this._sources,\n })\n return super.build()\n }\n\n message(message: string) {\n this._message = message\n return this\n }\n\n name(name: string) {\n this._name = name\n return this\n }\n\n query(query: string) {\n this._query = query\n return this\n }\n\n sources(sources: string[]) {\n this._sources = sources\n return this\n }\n}\n","import { Address } from '@xylabs/hex'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { AnyConfigSchema, CosigningAddressSet, ModuleConfig, ModuleQuery, SchemaString } from '@xyo-network/module-model'\n\nimport { Queryable, QueryValidator } from './QueryValidator'\n\nexport type SortedPipedAddressesString = string\n\nconst delimiter = ''\n\nexport class ModuleConfigQueryValidator<TConfig extends AnyConfigSchema<ModuleConfig>> implements QueryValidator {\n protected allowed: Record<SchemaString, SortedPipedAddressesString[]> = {}\n protected disallowed: Record<SchemaString, Address[]> = {}\n protected readonly hasAllowedRules: boolean\n protected readonly hasDisallowedRules: boolean\n protected readonly hasRules: boolean\n\n constructor(config?: TConfig) {\n if (config?.security?.allowed) {\n for (const [schema, addresses] of Object.entries(config.security?.allowed)) {\n this.allowed[schema] = addresses.map(toAddressesString)\n }\n }\n if (config?.security?.disallowed) {\n for (const [schema, addresses] of Object.entries(config.security?.disallowed)) {\n this.disallowed[schema] = addresses.map(toAddressesString)\n }\n }\n this.hasAllowedRules = Object.keys(this.allowed).length > 0\n this.hasDisallowedRules = Object.keys(this.disallowed).length > 0\n this.hasRules = this.hasAllowedRules || this.hasDisallowedRules\n }\n\n queryable: Queryable = async (query, payloads) => {\n if (!this.hasRules) return true\n const addresses = query.addresses\n if (addresses.length === 0) return false\n const wrapper = await QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)\n const schema = (await wrapper.getQuery()).schema\n return this.queryAllowed(schema, addresses) && !this.queryDisallowed(schema, addresses)\n }\n\n protected queryAllowed = (schema: SchemaString, addresses: string[]): boolean => {\n if (!this.hasAllowedRules) return true\n // All cosigners must sign\n if (addresses.length > 1) {\n const signatories = toAddressesString(addresses)\n const validCosigners = this.allowed?.[schema]?.includes(signatories)\n if (validCosigners) return true\n }\n // OR all signers have to be allowed individually\n return addresses.every((address) => this.allowed?.[schema]?.includes(address) || false)\n }\n protected queryDisallowed = (schema: SchemaString, addresses: string[]): boolean => {\n if (!this.hasDisallowedRules) return false\n return addresses.some((address) => this.disallowed?.[schema]?.includes(address))\n }\n}\n\n// TODO: Handle 0x prefix\nconst toAddressesString = (addresses: string | CosigningAddressSet): SortedPipedAddressesString => {\n return Array.isArray(addresses)\n ? addresses\n .sort()\n .map((address) => address.toLowerCase())\n .join(delimiter)\n : addresses.toLowerCase()\n}\n","import { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { Module, ModuleQuery } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nimport { Queryable, QueryValidator } from './QueryValidator'\n\nexport const isQuerySupportedByModule = async <T extends QueryBoundWitness = QueryBoundWitness>(\n mod: Module,\n query: T,\n payloads?: Payload[],\n): Promise<boolean> => {\n const wrapper = await QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)\n const schema = (await wrapper.getQuery()).schema\n return mod.queries.includes(schema)\n}\n\nexport class SupportedQueryValidator implements QueryValidator {\n constructor(protected readonly mod: Module) {}\n queryable: Queryable = (query, payloads) => {\n return isQuerySupportedByModule(this.mod, query, payloads)\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { ModuleManifestPayload } from '@xyo-network/manifest-model'\nimport { AddressPreviousHashPayload, Module, ModuleDescriptionPayload, ModuleEventData, ModuleParams } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nimport { AbstractModule } from './AbstractModule'\n\nexport abstract class AbstractModuleInstance<TParams extends ModuleParams = ModuleParams, TEventData extends ModuleEventData = ModuleEventData>\n extends AbstractModule<TParams, TEventData>\n implements Module<TParams, TEventData>\n{\n constructor(privateConstructorKey: string, params: TParams, account: AccountInstance) {\n assertEx(AbstractModule.privateConstructorKey === privateConstructorKey, 'Use create function instead of constructor')\n // Clone params to prevent mutation of the incoming object\n const mutatedParams = { ...params } as TParams\n super(privateConstructorKey, mutatedParams, account)\n this.upResolver.add(this)\n this.downResolver.add(this)\n }\n\n describe(): Promise<ModuleDescriptionPayload> {\n return this.busy(async () => {\n return await this.describeHandler()\n })\n }\n\n discover(): Promise<Payload[]> {\n return this.busy(async () => {\n return await this.discoverHandler()\n })\n }\n\n manifest(maxDepth?: number, ignoreAddresses?: string[]): Promise<ModuleManifestPayload> {\n return this.busy(async () => {\n return await this.manifestHandler(maxDepth, ignoreAddresses)\n })\n }\n\n moduleAddress(): Promise<AddressPreviousHashPayload[]> {\n return this.busy(async () => {\n return await this.moduleAddressHandler()\n })\n }\n\n subscribe(_queryAccount?: AccountInstance) {\n return this.subscribeHandler()\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;;;;;;;ACCA,IAAAA,iBAAyB;AACzB,mBAA8C;AAC9C,oBAAuB;AACvB,oBAAwB;AACxB,oBAAyB;AACzB,qBAAsC;AACtC,IAAAC,kBAAkC;AAElC,oCAA8C;AAC9C,6BAAuD;AACvD,IAAAC,+BAAwF;AAExF,mCAA4C;AAC5C,4BAAmE;AACnE,0BA6BO;AACP,6BAAwC;AACxC,IAAAC,0BAA+B;AAE/B,kCAA0C;;;AChD1C,oBAAiC;AACjC,2BAAmF;AAE5E,IAAMC,eAAN,MAAMA,qBACHC,mBAAAA;;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;AAtDUd;AADH,IAAMD,cAAN;;;ACFP,oBAAyB;AACzB,qBAAwB;AAiBxB,IAAMoB,sCAAsC,wBAACC,WAAAA;AAC3CC,8BAAS,CAAED,OAA4CE,aAAa,0DAAA;AACpE,SAAO,CAAC,CAAEF,OAA6CG;AACzD,GAH4C;AAK5C,IAAMC,qCAAqC,wBAACJ,WAAAA;AAC1C,SAAO,CAAC,CAAEA,OAA4CK;AACxD,GAF2C;AAI3C,eAAsBC,iBAAiBN,QAAgCO,qBAAqB,MAAI;AAC9F,MAAIR,oCAAoCC,MAAAA,GAAS;AAC/C,QAAIA,OAAOG,YAAY,UAAU;AAC/BF,kCAASM,oBAAoB,4BAAA;AAC7B,aAAOC,uBAAQC,WAAU;IAC3B;AACA,WAAOT,OAAOG;EAChB;AAEA,MAAIC,mCAAmCJ,MAAAA,GAAS;AAC9C,eAAOC,wBAASD,OAAOE,cAAc,MAAMF,OAAOK,OAAOK,WAAWV,OAAOE,WAAW,IAAIF,OAAOK,QAAQ,oCAAA;EAC3G;AAGAM,UAAQC,KAAK,0FAAA;AACb,SAAOJ,uBAAQC,WAAU;AAC3B;AAhBsBH;;;AC5BtB,6BAA+B;AAC/B,2BAAyD;AAElD,IAAMO,sBAAN,MAAMA,4BAA2BC,sCAAAA;EACtCC;EACAC;EACAC;EACAC;EACAC,cAAc;AACZ,UAAM;MAAEC,QAAQC;IAAkB,CAAA;EACpC;EAESC,QAAwC;AAC/C,SAAKC,OAAO;MACVC,SAAS,KAAKT;MACdU,MAAM,KAAKT;MACXU,OAAO,KAAKT;MACZG,QAAQC;MACRM,SAAS,KAAKT;IAChB,CAAA;AACA,WAAO,MAAMI,MAAAA;EACf;EAEAE,QAAQA,SAAiB;AACvB,SAAKT,WAAWS;AAChB,WAAO;EACT;EAEAC,KAAKA,MAAc;AACjB,SAAKT,QAAQS;AACb,WAAO;EACT;EAEAC,MAAMA,OAAe;AACnB,SAAKT,SAASS;AACd,WAAO;EACT;EAEAC,QAAQA,SAAmB;AACzB,SAAKT,WAAWS;AAChB,WAAO;EACT;AACF;AAvCwCb;AAAjC,IAAMD,qBAAN;;;ACFP,kCAAyC;AAOzC,IAAMe,YAAY;AAEX,IAAMC,8BAAN,MAAMA,4BAAAA;EACDC,UAA8D,CAAC;EAC/DC,aAA8C,CAAC;EACtCC;EACAC;EACAC;EAEnBC,YAAYC,QAAkB;AAhBhC;AAiBI,SAAIA,sCAAQC,aAARD,mBAAkBN,SAAS;AAC7B,iBAAW,CAACQ,QAAQC,SAAAA,KAAcC,OAAOC,SAAQL,YAAOC,aAAPD,mBAAiBN,OAAAA,GAAU;AAC1E,aAAKA,QAAQQ,MAAAA,IAAUC,UAAUG,IAAIC,iBAAAA;MACvC;IACF;AACA,SAAIP,sCAAQC,aAARD,mBAAkBL,YAAY;AAChC,iBAAW,CAACO,QAAQC,SAAAA,KAAcC,OAAOC,SAAQL,YAAOC,aAAPD,mBAAiBL,UAAAA,GAAa;AAC7E,aAAKA,WAAWO,MAAAA,IAAUC,UAAUG,IAAIC,iBAAAA;MAC1C;IACF;AACA,SAAKX,kBAAkBQ,OAAOI,KAAK,KAAKd,OAAO,EAAEe,SAAS;AAC1D,SAAKZ,qBAAqBO,OAAOI,KAAK,KAAKb,UAAU,EAAEc,SAAS;AAChE,SAAKX,WAAW,KAAKF,mBAAmB,KAAKC;EAC/C;EAEAa,YAAuB,OAAOC,OAAOC,aAAAA;AACnC,QAAI,CAAC,KAAKd;AAAU,aAAO;AAC3B,UAAMK,YAAYQ,MAAMR;AACxB,QAAIA,UAAUM,WAAW;AAAG,aAAO;AACnC,UAAMI,UAAU,MAAMC,qDAAyBC,WAAwBJ,OAAOC,QAAAA;AAC9E,UAAMV,UAAU,MAAMW,QAAQG,SAAQ,GAAId;AAC1C,WAAO,KAAKe,aAAaf,QAAQC,SAAAA,KAAc,CAAC,KAAKe,gBAAgBhB,QAAQC,SAAAA;EAC/E;EAEUc,eAAe,CAACf,QAAsBC,cAAAA;AAzClD;AA0CI,QAAI,CAAC,KAAKP;AAAiB,aAAO;AAElC,QAAIO,UAAUM,SAAS,GAAG;AACxB,YAAMU,cAAcZ,kBAAkBJ,SAAAA;AACtC,YAAMiB,kBAAiB,gBAAK1B,YAAL,mBAAeQ,YAAf,mBAAwBmB,SAASF;AACxD,UAAIC;AAAgB,eAAO;IAC7B;AAEA,WAAOjB,UAAUmB,MAAM,CAACC,YAAAA;AAlD5B,UAAAC,KAAAC;AAkDwC,eAAAA,OAAAD,MAAA,KAAK9B,YAAL,gBAAA8B,IAAetB,YAAf,gBAAAuB,IAAwBJ,SAASE,aAAY;KAAA;EACnF;EACUL,kBAAkB,CAAChB,QAAsBC,cAAAA;AACjD,QAAI,CAAC,KAAKN;AAAoB,aAAO;AACrC,WAAOM,UAAUuB,KAAK,CAACH,YAAAA;AAtD3B;AAsDuC,8BAAK5B,eAAL,mBAAkBO,YAAlB,mBAA2BmB,SAASE;KAAAA;EACzE;AACF;AA/Ca9B;AAAN,IAAMA,6BAAN;AAkDP,IAAMc,oBAAoB,wBAACJ,cAAAA;AACzB,SAAOwB,MAAMC,QAAQzB,SAAAA,IACjBA,UACG0B,KAAI,EACJvB,IAAI,CAACiB,YAAYA,QAAQO,YAAW,CAAA,EACpCC,KAAKvC,SAAAA,IACRW,UAAU2B,YAAW;AAC3B,GAP0B;;;AC5D1B,IAAAE,+BAAyC;AAOlC,IAAMC,2BAA2B,8BACtCC,KACAC,OACAC,aAAAA;AAEA,QAAMC,UAAU,MAAMC,sDAAyBC,WAAwBJ,OAAOC,QAAAA;AAC9E,QAAMI,UAAU,MAAMH,QAAQI,SAAQ,GAAID;AAC1C,SAAON,IAAIQ,QAAQC,SAASH,MAAAA;AAC9B,GARwC;AAUjC,IAAMI,2BAAN,MAAMA,yBAAAA;;EACXC,YAA+BX,KAAa;SAAbA,MAAAA;SAC/BY,YAAuB,CAACX,OAAOC,aAAAA;AAC7B,aAAOH,yBAAyB,KAAKC,KAAKC,OAAOC,QAAAA;IACnD;EAH6C;EAC7CU;AAGF;AALaF;AAAN,IAAMA,0BAAN;;;ALuCA,IAAeG,kBAAf,MAAeA,wBACZC,YAAAA;EASCC,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,YAAYC,uBAA+BC,QAAiBC,SAA0B;AACpFC,iCAASvB,gBAAeoB,0BAA0BA,uBAAuB,4CAAA;AAEzE,UAAMI,gBAAgB;MAAE,GAAGH;IAAO;AAClC,UAAMG,aAAAA;AAEN,SAAKnB,WAAWiB;AAEhB,SAAKL,0BAA0B,IAAIQ,wBAAwB,IAAI,EAAYC;AAC3E,SAAKV,6BAA6B,IAAIW,2BAA2BH,+CAAeI,MAAAA,EAAQF;EAC1F;EAEA,WAAWG,eAAuB;AAChC,WAAO,KAAKC,cAAc,CAAA;EAC5B;EAEA,IAAIR,UAAU;AACZ,eAAOC,yBAAS,KAAKlB,UAAU,iBAAA;EACjC;EAEA,IAAI0B,UAAU;AACZ,WAAO,KAAKT,QAAQS;EACtB;EAEA,IAAIC,iBAAiB;AAnHvB;AAoHI,WAAO,CAAC,GAAC,UAAKJ,OAAOK,aAAZ,mBAAsBD;EACjC;EAEA,IAAIJ,SAA4B;AAC9B,WAAO,KAAKP,OAAOO;EACrB;EAEA,IAAIM,+BAAwC;AAC1C,WAAO,CAAC,CAAC,KAAKb,OAAOa;EACvB;EAEA,IAAIC,KAAK;AACP,WAAO,KAAKP,OAAOQ,QAAQ,KAAKL;EAClC;EAEA,IAAIM,UAAoB;AACtB,WAAO;MAAC3B;MAA2BF;MAA0BI;MAA4BH;MAA2BE;;EACtH;EAEA,IAAI2B,oBAA2E;AAC7E,WAAO;MAAE,GAAG,KAAK/B;MAA8B,GAAG,KAAKgC;IAAmB;EAC5E;EAEA,IAAIC,gBAAgF;AAClF,WAAO,KAAK3B;EACd;EAEA,IAAI4B,YAAY;AACd,WAAO,KAAKb,OAAOa,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;AACvCxB,iCAASyB,aAAaC,UAAU,6BAA6BF,YAAAA,gBAA4BA,YAAAA,iBAA6B;EACxH;EAEA,aAAaG,OAEX7B,QACA;AAzKJ;AA0KI,SAAKyB,YAAY,QAAA;AACjB,QAAI,CAAC,KAAKhB,iBAAiB,KAAKA,cAAcqB,WAAW,GAAG;AAC1D,YAAM,IAAIC,MAAM,0BAAyB/B,sCAAQO,WAARP,mBAAgBgC,MAAAA,KAAW,KAAKjB,IAAI,GAAG;IAClF;AAEA,UAAM,EAAEd,QAAO,IAAKD,UAAU,CAAC;AAE/B,UAAMgC,WAAiBhC,sCAAQO,WAARP,mBAAgBgC,WAAU,KAAKxB;AACtD,UAAMyB,iBAA2B,KAAKxB;AAEtCP,iCAAS+B,eAAeC,SAASF,MAAAA,GAAS,+BAA+BA,MAAAA,eAAqBG,KAAKC,UAAUH,cAAAA,CAAAA,GAAkB;AAC/H,UAAMI,gBAA6C;MAAE,GAAGrC,iCAAQO;MAAQyB;IAAO;AAC/EhC,2CAAQsC,WAARtC,mBAAgBuC,MAAM,WAAWJ,KAAKC,UAAUC,eAAe,MAAM,CAAA,CAAA;AACrE,UAAMlC,gBAAmC;MAAE,GAAGH;MAAQO,QAAQ8B;IAAc;AAE5E,UAAMG,gBAAexC,iCAAQsC,WAAU3D,gBAAe8D;AACtD,UAAMC,mBAAmB,MAAM/D,gBAAegE,iBAAiB;MAAE1C;IAAQ,CAAA;AACzE,UAAMS,UAAUgC,iBAAiBhC;AACjCP,kBAAcmC,SAASE,eAAe,IAAII,uBAASJ,cAAc,MAAM,KAAK9B,OAAAA,EAAS,IAAIzB;AAEzF,UAAM4D,YAAY,IAAI,KAAKlE,gBAAeoB,uBAAuBI,eAAeuC,gBAAAA;AAEhF,QAAI,CAAC/D,gBAAemE,gBAAgB;AAClC,cAAMD,eAAUE,UAAVF;IACR;AACA,WAAOA;EACT;EAEA,aAAaF,iBAAiB3C,QAID;AAC3B,WAAO,MAAM2C,iBAAiB3C,QAAQ,KAAKgD,kBAAkB;EAC/D;EAEA,OAAOC,QAELjD,QACiC;AACjC,WAAOkD,kCAAcC,WAAW,MAAMnD,MAAAA;EACxC;EAEAqB,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;AACvCxB,iCAASyB,aAAaC,UAAU,6BAA6BF,YAAAA,gBAA4BA,YAAAA,iBAA6B;EACxH;EAEA,MAAM0B,KAAQC,SAA2B;AACvC,QAAI,KAAKxD,cAAc,GAAG;AACxB,WAAKA,aAAa;AAClB,YAAMyD,OAA4B;QAAEF,MAAM;QAAMG,QAAQ;MAAK;AAC7D,YAAM,KAAKC,KAAK,cAAcF,IAAAA;IAChC;AACA,SAAKzD;AACL,QAAI;AACF,aAAO,MAAMwD,QAAAA;IACf,UAAA;AACE,WAAKxD;AACL,UAAI,KAAKA,cAAc,GAAG;AACxB,aAAKA,aAAa;AAClB,cAAMyD,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,KAAK1D,QAAQ0D;EACtB;EAEA,MAAMC,MACJA,OACAC,UACAC,aAC4B;AAC5B,SAAKrC,YAAY,OAAA;AACjB,UAAMsC,cAAc,MAAMC,uCAAeC,UAAM/D,yBAAS,MAAMgE,sDAAyBC,OAAOP,KAAAA,GAAQ,eAAA,CAAA;AACtG,WAAO,MAAM,KAAKR,KAAK,YAAA;AACrB,YAAMgB,iBAA4B,CAAA;AAClC,YAAMC,gBAA+B,CAAA;AACrC,YAAMC,eAAe,KAAKzD,+BAA+B0D,wBAAQC,WAAU,IAAKvF;AAChF,UAAI;AACF,cAAM,KAAKwF,QAAQ,OAAA;AACnB,YAAI,CAAC,KAAK9D,kBAAkBiD,MAAMc,UAAU5C,WAAW,GAAG;AACxD,gBAAM,IAAIC,MAAM,sDAAsD,KAAKxB,OAAOQ,IAAI,OAAO,KAAKL,OAAO,GAAG;QAC9G;AACA0D,uBAAeO,KAAI,GAAK,MAAM,KAAKC,aAAab,aAAaF,UAAUC,WAAAA,CAAAA;MACzE,SAASe,IAAI;AACX,kBAAMC,+BAAiBD,IAAI,OAAOE,UAAAA;AAChCV,wBAAcM,KACZ,MAAM,IAAIK,mBAAAA,EACPC,QAAQ;YAAClB,YAAYmB;WAAM,EAC3BnE,KAAK,KAAKR,OAAOQ,QAAQ,WAAA,EACzB6C,MAAMG,YAAY/B,MAAM,EACxBmD,QAAQJ,MAAMI,OAAO,EACrBlB,MAAK,CAAA;QAEZ,CAAA;MACF;AACA,UAAI,KAAK7C,WAAW;AAClB,cAAMA,YAAY;UAAEY,QAAQ;UAAyBZ,WAAWgE,KAAKC,IAAG;QAAG;AAC3EjB,uBAAeO,KAAKvD,SAAAA;MACtB;AACA,YAAMkE,SAAS,MAAM,KAAKC,gBAAgBxB,aAAaK,gBAAgBE,eAAe;QAACA;UAAgB,CAAA,GAAID,aAAAA;AAC3G,YAAMf,OAA+B;QAAEC,QAAQ;QAAMM;QAAUD,OAAOG;QAAauB;MAAO;AAC1F,YAAM,KAAK9B,KAAK,iBAAiBF,IAAAA;AACjC,aAAOgC;IACT,CAAA;EACF;EAEA,MAAMjF,UACJuD,OACAC,UACAC,aACkB;AAClB,QAAI,CAAE,MAAM,KAAKW,QAAQ,MAAA;AAAU,aAAO;AAC1C,UAAMe,kBAAkB1B,cACpB,IAAIxD,2BAA2BmF,OAAOC,OAAO,CAAC,GAAG,KAAKnF,QAAQuD,WAAAA,CAAAA,EAAczD,YAC5E,KAAKV;AACT,UAAMgG,aAAa;MAAC,KAAK/F;MAAyB4F;;AAElD,WAAOG,WAAWC,MAAM,CAACC,cAAcA,UAAUjC,OAAOC,QAAAA,CAAAA;EAC1D;EAIA,MAAMiC,QACJC,uBACAC,SAC8B;AAC9B,UAAMC,aAAYD,mCAASC,cAAa;AACxC,UAAMC,KAAKD,cAAc,QAAQA,cAAc;AAC/C,UAAME,OAAOF,cAAc,UAAUA,cAAc;AACnD,YAAQ,OAAOF,uBAAAA;MACb,KAAK,UAAU;AACb,gBACGI,OAAO,MAAO,KAAKtH,aAAyCiH,QAAWC,uBAAuBC,OAAAA,IAAW/G,YACzGiH,KAAK,MAAO,KAAKnH,WAAuC+G,QAAWC,uBAAuBC,OAAAA,IAAW/G;MAE1G;MACA,SAAS;AACP,cAAMmH,SAAsCL;AAC5C,eAAO;aACDI,OAAO,MAAO,KAAKtH,aAAyCiH,QAAWM,QAAQJ,OAAAA,IAAW,CAAA;aAC1FE,KAAK,MAAO,KAAKnH,WAAuC+G,QAAWM,QAAQJ,OAAAA,IAAW,CAAA;UAC1FI,OAAOC,oCAAAA;MACX;IACF;EACF;EAEAtD,MAAMuD,UAAwC;AAE5C,SAAK7G,gBAAgB,KAAKA,iBAAiB,KAAK8G,aAAY;AAC5D,WAAO,KAAK9G;EACd;EAEA,MAAMgF,QAAQ+B,mBAAgE,OAAOC,WAAW,MAAwB;AACtH,UAAMhC,UAAU,MAAM,KAAK/E;AAC3B,QAAI+E,YAAY,MAAM;AACpB,aAAO;IACT;AACA,QAAI,CAACA,SAAS;AAEZ,WAAK/E,YAAY,YAAA;AAjWvB;AAkWQ,YAAI+G,UAAU;AACZ,cAAI;AACF,kBAAM,KAAK1D,MAAK;AAChB,mBAAO;UACT,SAAS8B,IAAI;AACX6B,0CAAY7B,IAAI,CAACE,UAAAA;AAvW7B,kBAAA4B;AAwWc,eAAAA,MAAA,KAAKrE,WAAL,gBAAAqE,IAAaC,KAAK,+BAA+B7B,MAAMI,OAAO;AAC9D,mBAAKzF,WAAWT;YAClB,CAAA;UACF;QACF;AACA,gBAAQuH,kBAAAA;UACN,KAAK,SAAS;AACZ,kBAAM,IAAIzE,MAAM,uBAAuB,KAAKrB,OAAO,GAAG;UACxD;UACA,KAAK,QAAQ;AACX,uBAAK4B,WAAL,mBAAasE,KAAK;AAClB;UACF;UACA,KAAK,SAAS;AACZ,uBAAKtE,WAAL,mBAAayC,MAAM;AACnB;UACF;UACA,KAAK,QAAQ;AACX;UACF;UACA,SAAS;AACP,uBAAKzC,WAAL,mBAAauE,IAAI;AACjB;UACF;QACF;AACA,eAAO;MACT,GAAA;IACF;AACA,QAAI,CAAC,KAAKnH,UAAU;AAClB,YAAM;IACR;AACA,WAAO,MAAM,KAAKA;EACpB;EAEA,MAAMoH,KAAKR,UAAqC;AAC9C,WAAO,MAAM,KAAKlD,KAAK,YAAA;AACrB,YAAMkC,SAAS,MAAM,KAAKyB,YAAW;AACrC,WAAKrH,WAAWT;AAChB,WAAKQ,gBAAgBR;AACrB,aAAOqG;IACT,CAAA;EACF;EAEU0B,WAAWC,QAAkBjF,QAAwB/B,SAA2B;AAExF,UAAMiH,UAAU,IAAIC,yBAAU,CAACrB,YAAAA;AAC7B,YAAMR,SAAS,KAAK8B,mBAAmBH,QAAQjF,QAAQ/B,OAAAA;AACvD6F,yCAAUR;AACV,aAAOA;IACT,GAAGrF,OAAAA;AACH,WAAOiH;EACT;EAEA,MAAgBE,mBAAmBH,QAAkBjF,QAAwB/B,SAAkD;AA7ZjI;AA8ZI,UAAMoH,UAAU,IAAIC,iDAAAA,EAAsBL,OAAOA,QAAQjF,MAAAA,EAAQuF,QAAQ,KAAKtH,OAAO;AACrF,UAAMqF,UAAU,OAAOrF,UAAUoH,QAAQE,QAAQtH,OAAAA,IAAWoH,SAASpD,MAAK,GAAI,CAAA;AAC9E,eAAK3B,WAAL,mBAAaC,MAAM,WAAWJ,KAAKC,UAAUkD,QAAQ,MAAM,CAAA,CAAA;AAC3D,WAAOA;EACT;EAEUkC,UACR5D,OACAC,UACA5D,SACuE;AAEvE,UAAMiH,UAAU,IAAIC,yBAAsE,OAAOrB,YAAAA;AAC/F,YAAMR,SAAS,MAAM,KAAKmC,kBAAkB7D,OAAOC,UAAU5D,OAAAA;AAC7D6F,yCAAUR;AACV,aAAOA;IACT,GAAGrF,OAAAA;AACH,WAAOiH;EACT;EAEA,MAAgBO,kBACd7D,OACAC,UACA5D,SACoD;AACpD,UAAMoH,UAAU,OAAO,MAAM,IAAIK,sDAAAA,EAA2B7D,SAASA,QAAAA,GAAW0D,QAAQ,KAAKtH,OAAO,EAAE2D,MAAMA,KAAAA;AAC5G,UAAM0B,SAAS,OAAOrF,UAAUoH,QAAQE,QAAQtH,OAAAA,IAAWoH,SAASpD,MAAK;AACzE,WAAOqB;EACT;EAEA,MAAgBC,gBACd3B,OACAC,UACA8D,sBAAyC,CAAA,GACzCC,QAC4B;AAC5B,UAAMP,WAAW,OAAO,MAAM,IAAIC,iDAAAA,EAAsBzD,SAASA,QAAAA,GAAW+D,OAAOA,MAAAA,GAAS7D,YAAYH,MAAMsB,KAAK;AACnH,UAAM2C,sBAAsB,KAAK1G,cAAcyC,MAAM5B,MAAM;AAC3D,UAAM8F,YAAY;MAAC,KAAK7H;MAAS4H;SAAwBF;MAAqBvB,OAAO2B,oBAAAA;AACrFV,YAAQS,UAAUA,SAAAA;AAClB,UAAMxC,SAA4B;OAAE,MAAM+B,QAAQpD,MAAK,GAAI,CAAA;MAAIJ;MAAU+D,UAAU,CAAA;;AACnF,QAAI,KAAKrH,OAAOyH,WAAW;AACzB,YAAM,KAAKC,kBAAkB3C,OAAO4C,KAAI,CAAA;IAC1C;AACA,WAAO5C;EACT;EAEA,MAAgB6C,kBAAqD;AA7cvE;AA8cI,UAAMC,cAAwC;MAC5C1H,SAAS,KAAKA;MACdM,SAAS,KAAKA;MACdgB,QAAQqG;IACV;AACA,SAAI,UAAK9H,WAAL,mBAAaQ,MAAM;AACrBqH,kBAAYrH,OAAO,KAAKR,OAAOQ;IACjC;AAEA,UAAMuH,WAAW,MAAM,KAAKC,gBAAe;AAE3CH,gBAAYI,eAAWC,wBACrBH,qCAAUI,IAAI,CAACC,YAAAA;AACb,YAAMjI,UAAUiI,QAAQ3G,WAAW4G,8CAAiBD,QAA2BjI,UAAUzB;AACzF,aAAOyB,WAAW,KAAKA,UAAUzB,SAAYyB;IAC/C,OAAM,CAAA,CAAE;AAGV,WAAO0H;EACT;EAEA,MAAgBG,gBAAgBM,WAAwC;AAne1E;AAoeI,UAAMtI,SAAS,KAAKA;AACpB,UAAMG,UAAU,MAAM,IAAIsD,uCAA+B;MAAEhC,QAAQ4G;IAAc,CAAA,EAC9EE,OAAO;MAAEpI,SAAS,KAAKA;MAASK,OAAM,UAAKR,WAAL,mBAAaQ;IAAK,CAAA,EACxDkD,MAAK;AACR,UAAMjD,UAAU,MAAM+H,QAAQC,IAC5B,KAAKhI,QAAQ0H,IAAI,OAAO9E,UAAAA;AACtB,aAAO,MAAM,IAAII,uCAA6B;QAAEhC,QAAQiH;MAAY,CAAA,EAAGH,OAAO;QAAElF;MAAM,CAAA,EAAGK,MAAK;IAChG,CAAA,CAAA;AAEF,UAAMzD,eAA8B;MAClCD,QAAQA,OAAOyB;MACfA,QAAQkH;IACV;AACA,eAAOT,uBAAQ;MAAClI;MAAQC;MAAcE;SAAYM;KAAQ;EAC5D;EAEA,MAAgBmI,eAAuD;AACrE,QAAI,CAAC,KAAK5I,OAAO6I;AAAW,aAAOnK;AACnC,UAAMoK,WAAW,MAAM,KAAKtK,WAAW+G,QAAQ,KAAKvF,OAAO6I,SAAS;AACpE,eAAOE,4CAAoBD,QAAAA;EAC7B;EAEA,MAAgBE,0BAA0B;AA1f5C;AA4fI,UAAMC,QAAQ/D,OAAOgE,OAAO,KAAKxI,iBAAiB,EAAEmF,OAAO2B,oBAAAA;AAC3D,UAAM2B,gBAAgB,IAAIC,IAAYH,KAAAA;AACtCtJ,iCAASwJ,cAAcE,SAASJ,MAAM1H,QAAQ,KAAG,UAAKvB,WAAL,mBAAaQ,QAAO,KAAKR,OAAOQ,OAAO,OAAO,EAAA,+BAAiC;AAEhI,UAAM8I,SAAS,KAAK5J;AACpB,QAAI4J,iCAAQC,YAAY;AACtB,iBAAWC,OAAO,KAAK9I,mBAAmB;AACxC,YAAIwE,OAAOuE,UAAUC,eAAeC,KAAK,KAAKjJ,mBAAmB8I,GAAAA,GAAM;AACrE,gBAAMnG,QAAQmG;AACd,gBAAMI,mBAAmB,KAAKlJ,kBAAkB2C,KAAAA;AAChD,cAAIuG,kBAAkB;AACpB,iBAAK3K,eAAeoE,KAAAA,IAAS,QAAMiG,YAAOC,eAAPD,gCAAoBM;UACzD;QACF;MACF;IACF;EACF;EAEUC,gBAAgBC,QAAiBC,kBAAgE;AACzG,UAAMvJ,OAAO,KAAKR,OAAOQ,QAAQ;AACjC,WAAO;MAAER,QAAQ;QAAEQ;QAAM,GAAG,KAAKR;MAAO;MAAGyB,QAAQuI;MAA6BC,QAAQ;QAAE9J,SAAS,KAAKA;MAAQ;IAAE;EACpH;EAEU+J,uBAAiE;AAEzE,UAAMtJ,gBAAgBsE,OAAOiF,QAAQ,KAAKvJ,aAAa,EACpDiF,OAAO,CAACuE,UAAAA;AACP,iBAAO5C,sBAAO4C,MAAM,CAAA,CAAE;IACxB,CAAA,EACCjC,IAAI,CAAC,CAAC3H,OAAMd,OAAAA,MAAQ;AACnB,YAAMS,WAAUT,QAAQS;AACxB,YAAMiD,gBAAe1D,QAAQ0D;AAC7B,aAAO;QACL;UAAEjD,SAAAA;UAASK,MAAAA;UAAMiB,QAAQ4G;QAAc;QACvC;UAAElI,SAAAA;UAASiD,cAAAA;UAAc3B,QAAQ4I;QAA0B;;IAE/D,CAAA;AACF,UAAMlK,UAAU,KAAKA;AACrB,UAAMK,OAAO,KAAKR,OAAOQ;AACzB,UAAM4C,eAAe,KAAKjD;AAC1B,UAAMmK,gBAAgB9J,OAAO;MAAEL;MAASK;MAAMiB,QAAQ4G;IAAc,IAAI;MAAElI;MAASsB,QAAQ4G;IAAc;AACzG,UAAMkC,4BAA4BnH,eAC9B;MAAEjD;MAASiD;MAAc3B,QAAQ4I;IAA0B,IAC3D;MAAElK;MAASsB,QAAQ4I;IAA0B;AACjD,WAAO;MAACC;MAAeC;SAA8B3J;MAAe+G,KAAI;EAC1E;EAEA,MAAgBtD,aACdhB,OACAC,UACAC,aACmC;AACnC,UAAM,KAAKW,QAAQ,OAAA;AACnB,UAAMsG,UAAU,MAAM7G,sDAAyB8G,WAAwBpH,OAAOC,QAAAA;AAC9E,UAAMoH,eAAe,MAAMF,QAAQG,SAAQ;AAC3ChL,iCAAS,MAAM,KAAKG,UAAUuD,OAAOC,UAAUC,WAAAA,CAAAA;AAC/C,UAAMM,iBAA4B,CAAA;AAClC,YAAQ6G,aAAajJ,QAAM;MACzB,KAAK1C,+CAA2B;AAC9B8E,uBAAeO,KAAK,MAAM,KAAKyF,gBAAgBa,aAAaE,QAAQ,CAAA;AACpE;MACF;MACA,KAAK9L,+CAA2B;AAC9B,cAAM,EAAE8L,SAAQ,IAAKF;AACrB7G,uBAAeO,KAAI,GAAK,MAAM,KAAK4D,gBAAgB4C,QAAAA,CAAAA;AACnD;MACF;MACA,KAAK/L,+CAA2B;AAC9BgF,uBAAeO,KAAK,MAAM,KAAKwD,gBAAe,CAAA;AAC9C;MACF;MACA,KAAKhJ,8CAA0B;AAC7BiF,uBAAeO,KAAI,GAAK,MAAM,KAAK8F,qBAAoB,CAAA;AACvD;MACF;MACA,KAAKlL,gDAA4B;AAC/B,aAAK6L,iBAAgB;AACrB;MACF;MACA,SAAS;AACP,cAAM,IAAIrJ,MAAM,sBAAuBkJ,aAAyBjJ,MAAM,GAAG;MAC3E;IACF;AACA,WAAOoC;EACT;EAEA,MAAgBiH,6BAA2D;AAllB7E;AAmlBI,UAAMC,cAAa,UAAK/K,OAAOyH,cAAZ,mBAAuBsD;AAC1C,QAAI,CAACA;AAAY,aAAO,CAAA;AACxB,UAAMjC,WAAW,MAAMN,QAAQC,IAAIsC,WAAW5C,IAAI,CAACU,cAAc,KAAKtD,QAAQsD,SAAAA,CAAAA,CAAAA;AAC9E,eAAOX,uBAAQY,SAASX,IAAI,CAAC6C,YAAQjC,4CAAoBiC,GAAAA,CAAAA,CAAAA;EAC3D;EAEA,MAAgBhF,eAAiC;AAC/C,SAAKiF,eAAc;AACnB,UAAM,KAAKjC,wBAAuB;AAClC,SAAK7J,WAAW;AAChB,WAAO;EACT;EAEUqH,YAAYT,UAAwC;AAC5D,SAAK5G,WAAWT;AAChB,WAAO;EACT;EAEA,MAAgBgJ,kBAAkBpE,UAAyC;AACzE,UAAMyH,aAAa,MAAM,KAAKD,2BAA0B;AACxD,YACE,MAAMtC,QAAQC,IACZsC,WAAW5C,IAAI,CAACU,cAAAA;AAzmBxB;AA0mBU,cAAOA,eAAUqC,WAAVrC,mCAAmBvF;IAC5B,CAAA,CAAA,GAEF6E,IAAI,CAAC,CAACgD,EAAAA,MAAQA,EAAAA;EAClB;EAEUN,mBAAmB;AAC3B;EACF;EAEUI,eAAejL,QAAkBoL,UAAoB,CAAA,GAAa;AAE1E,WAAOlG,OAAOiF,QAAQnK,UAAU,KAAKA,UAAU,CAAC,CAAA,EAAGqL,OAAO,CAACC,OAAO,CAAC9B,KAAKY,KAAAA,MAAM;AAtnBlF;AAunBM,cAAQ,OAAOA,OAAAA;QACb,KAAK,YAAY;AACf,qBAAKrI,WAAL,mBAAasE,KAAK,kDAAkD+E,mCAASG,KAAK,IAAA,IAAQ/B,GAAAA;AAC1F,iBAAO;QACT;QACA,KAAK,UAAU;AACb,cAAIgC,MAAMC,QAAQrB,KAAAA,GAAQ;AACxB;;cAEEA,MAAMiB,OAAO,CAACC,QAAOlB,WAAAA;AACnB,uBAAO,KAAKa,eAAeb,QAAO;qBAAIgB;kBAAS5B;iBAAI,KAAK8B;cAC1D,GAAG,IAAA,KAASA;;UAEhB;AAEA,cAAI,KAACI,uCAAkBtB,KAAAA,GAAQ;AAC7B,uBAAKrI,WAAL,mBAAasE,KAAK,uEAAuE+E,mCAASG,KAAK,IAAA,IAAQ/B,GAAAA;AAC/G,mBAAO;UACT;AACA,iBAAOY,QAAQ,KAAKa,eAAeb,OAAO;eAAIgB;YAAS5B;WAAI,KAAK8B,QAAQ;QAC1E;QACA,SAAS;AACP,iBAAOA;QACT;MACF;IACF,GAAG,IAAA;EACL;AACF;AAzlBUjN;AAGR,cAJoBD,iBAIJqE,sBAA8B;AAC9C,cALoBrE,iBAKb8B;AACP,cANoB9B,iBAMbmE,kBAAiB;AAExB,cARoBnE,iBAQHoB,yBAAwBqF,KAAKC,IAAG,EAAG6G,SAAQ;AARvD,IAAevN,iBAAf;;;AMxDP,IAAAwN,iBAAyB;AAQlB,IAAeC,0BAAf,MAAeA,gCACZC,eAAAA;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;AAvCUvB;AADH,IAAeD,yBAAf;","names":["import_assert","import_account","import_boundwitness_builder","import_payload_builder","BaseEmitter","Base","eventData","events","constructor","params","Events","clearListeners","eventNames","emit","eventName","eventArgs","emitSerial","listenerCount","off","listener","offAny","on","onAny","once","isDetermineAccountFromAccountParams","params","assertEx","accountPath","account","isDetermineAccountFromWalletParams","wallet","determineAccount","allowRandomAccount","Account","randomSync","derivePath","console","warn","ModuleErrorBuilder","PayloadBuilder","_message","_name","_query","_sources","constructor","schema","ModuleErrorSchema","build","fields","message","name","query","sources","delimiter","ModuleConfigQueryValidator","allowed","disallowed","hasAllowedRules","hasDisallowedRules","hasRules","constructor","config","security","schema","addresses","Object","entries","map","toAddressesString","keys","length","queryable","query","payloads","wrapper","QueryBoundWitnessWrapper","parseQuery","getQuery","queryAllowed","queryDisallowed","signatories","validCosigners","includes","every","address","_a","_b","some","Array","isArray","sort","toLowerCase","join","import_boundwitness_builder","isQuerySupportedByModule","mod","query","payloads","wrapper","QueryBoundWitnessWrapper","parseQuery","schema","getQuery","queries","includes","SupportedQueryValidator","constructor","queryable","AbstractModule","BaseEmitter","downResolver","CompositeModuleResolver","upResolver","_account","undefined","_baseModuleQueryAccountPaths","ModuleAddressQuerySchema","ModuleDescribeQuerySchema","ModuleDiscoverQuerySchema","ModuleManifestQuerySchema","ModuleSubscribeQuerySchema","_queryAccounts","_startPromise","_started","moduleConfigQueryValidator","supportedQueryValidator","_busyCount","constructor","privateConstructorKey","params","account","assertEx","mutatedParams","SupportedQueryValidator","queryable","ModuleConfigQueryValidator","config","configSchema","configSchemas","address","allowAnonymous","security","ephemeralQueryAccountEnabled","id","name","queries","queryAccountPaths","_queryAccountPaths","queryAccounts","timestamp","_getRootFunction","funcName","anyThis","__proto__","_noOverride","functionName","thisFunc","rootFunc","create","length","Error","schema","allowedSchemas","includes","JSON","stringify","mutatedConfig","logger","debug","activeLogger","defaultLogger","generatedAccount","determineAccount","IdLogger","newModule","enableLazyLoad","start","allowRandomAccount","factory","ModuleFactory","withParams","busy","closure","args","module","emit","eventName","eventArgs","previousHash","query","payloads","queryConfig","sourceQuery","PayloadBuilder","build","QueryBoundWitnessWrapper","unwrap","resultPayloads","errorPayloads","queryAccount","Account","randomSync","started","addresses","push","queryHandler","ex","handleErrorAsync","error","ModuleErrorBuilder","sources","$hash","message","Date","now","result","bindQueryResult","configValidator","Object","assign","validators","every","validator","resolve","nameOrAddressOrFilter","options","direction","up","down","filter","duplicateModules","_timeout","startHandler","notStartedAction","tryStart","handleError","_a","warn","log","stop","stopHandler","bindHashes","hashes","promise","PromiseEx","bindHashesInternal","builder","BoundWitnessBuilder","witness","bindQuery","bindQueryInternal","QueryBoundWitnessBuilder","additionalWitnesses","errors","queryWitnessAccount","witnesses","exists","archiving","storeToArchivists","flat","describeHandler","description","ModuleDescriptionSchema","discover","discoverHandler","children","compact","map","payload","AddressSchema","_maxDepth","fields","Promise","all","QuerySchema","ConfigSchema","getArchivist","archivist","resolved","asArchivistInstance","initializeQueryAccounts","paths","values","distinctPaths","Set","size","wallet","derivePath","key","prototype","hasOwnProperty","call","queryAccountPath","manifestHandler","_depth","_ignoreAddresses","ModuleManifestPayloadSchema","status","moduleAddressHandler","entries","value","AddressPreviousHashSchema","moduleAccount","moduleAccountPreviousHash","wrapper","parseQuery","queryPayload","getQuery","maxDepth","subscribeHandler","resolveArchivingArchivists","archivists","mod","validateConfig","insert","bw","parents","reduce","valid","join","Array","isArray","serializableField","toString","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"]}
@@ -18,7 +18,6 @@ import { AddressSchema } from "@xyo-network/address-payload-plugin";
18
18
  import { asArchivistInstance } from "@xyo-network/archivist-model";
19
19
  import { BoundWitnessBuilder, QueryBoundWitnessBuilder, QueryBoundWitnessWrapper as QueryBoundWitnessWrapper3 } from "@xyo-network/boundwitness-builder";
20
20
  import { ConfigSchema } from "@xyo-network/config-payload-plugin";
21
- import { PayloadHasher } from "@xyo-network/hash";
22
21
  import { ModuleManifestPayloadSchema } from "@xyo-network/manifest-model";
23
22
  import { AddressPreviousHashSchema, duplicateModules, ModuleAddressQuerySchema, ModuleDescribeQuerySchema, ModuleDescriptionSchema, ModuleDiscoverQuerySchema, ModuleFactory, ModuleManifestQuerySchema, ModuleSubscribeQuerySchema, serializableField } from "@xyo-network/module-model";
24
23
  import { CompositeModuleResolver } from "@xyo-network/module-resolver";
@@ -107,13 +106,14 @@ var _ModuleErrorBuilder = class _ModuleErrorBuilder extends PayloadBuilder {
107
106
  });
108
107
  }
109
108
  build() {
110
- return Promise.resolve({
109
+ this.fields({
111
110
  message: this._message,
112
111
  name: this._name,
113
112
  query: this._query,
114
113
  schema: ModuleErrorSchema,
115
114
  sources: this._sources
116
115
  });
116
+ return super.build();
117
117
  }
118
118
  message(message) {
119
119
  this._message = message;
@@ -166,7 +166,7 @@ var _ModuleConfigQueryValidator = class _ModuleConfigQueryValidator {
166
166
  const addresses = query.addresses;
167
167
  if (addresses.length === 0)
168
168
  return false;
169
- const wrapper = QueryBoundWitnessWrapper.parseQuery(query, payloads);
169
+ const wrapper = await QueryBoundWitnessWrapper.parseQuery(query, payloads);
170
170
  const schema = (await wrapper.getQuery()).schema;
171
171
  return this.queryAllowed(schema, addresses) && !this.queryDisallowed(schema, addresses);
172
172
  };
@@ -203,7 +203,7 @@ var toAddressesString = /* @__PURE__ */ __name((addresses) => {
203
203
  // src/QueryValidator/SupportedQueryValidator.ts
204
204
  import { QueryBoundWitnessWrapper as QueryBoundWitnessWrapper2 } from "@xyo-network/boundwitness-builder";
205
205
  var isQuerySupportedByModule = /* @__PURE__ */ __name(async (mod, query, payloads) => {
206
- const wrapper = QueryBoundWitnessWrapper2.parseQuery(query, payloads);
206
+ const wrapper = await QueryBoundWitnessWrapper2.parseQuery(query, payloads);
207
207
  const schema = (await wrapper.getQuery()).schema;
208
208
  return mod.queries.includes(schema);
209
209
  }, "isQuerySupportedByModule");
@@ -390,7 +390,7 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
390
390
  }
391
391
  async query(query, payloads, queryConfig) {
392
392
  this._noOverride("query");
393
- const sourceQuery = await PayloadHasher.hashAsync(query);
393
+ const sourceQuery = await PayloadBuilder2.build(assertEx2(await QueryBoundWitnessWrapper3.unwrap(query), "Invalid query"));
394
394
  return await this.busy(async () => {
395
395
  const resultPayloads = [];
396
396
  const errorPayloads = [];
@@ -400,12 +400,12 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
400
400
  if (!this.allowAnonymous && query.addresses.length === 0) {
401
401
  throw new Error(`Anonymous Queries not allowed, but running anyway [${this.config.name}], [${this.address}]`);
402
402
  }
403
- resultPayloads.push(...await this.queryHandler(assertEx2(QueryBoundWitnessWrapper3.unwrap(query)), payloads, queryConfig));
403
+ resultPayloads.push(...await this.queryHandler(sourceQuery, payloads, queryConfig));
404
404
  } catch (ex) {
405
405
  await handleErrorAsync(ex, async (error) => {
406
406
  errorPayloads.push(await new ModuleErrorBuilder().sources([
407
- await PayloadHasher.hashAsync(query)
408
- ]).name(this.config.name ?? "<Unknown>").query(query.schema).message(error.message).build());
407
+ sourceQuery.$hash
408
+ ]).name(this.config.name ?? "<Unknown>").query(sourceQuery.schema).message(error.message).build());
409
409
  });
410
410
  }
411
411
  if (this.timestamp) {
@@ -415,21 +415,21 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
415
415
  };
416
416
  resultPayloads.push(timestamp);
417
417
  }
418
- const result = await this.bindQueryResult(query, resultPayloads, sourceQuery, queryAccount ? [
418
+ const result = await this.bindQueryResult(sourceQuery, resultPayloads, queryAccount ? [
419
419
  queryAccount
420
420
  ] : [], errorPayloads);
421
421
  const args = {
422
422
  module: this,
423
423
  payloads,
424
- query,
424
+ query: sourceQuery,
425
425
  result
426
426
  };
427
427
  await this.emit("moduleQueried", args);
428
428
  return result;
429
429
  });
430
430
  }
431
- queryable(query, payloads, queryConfig) {
432
- if (!this.started("warn"))
431
+ async queryable(query, payloads, queryConfig) {
432
+ if (!await this.started("warn"))
433
433
  return false;
434
434
  const configValidator = queryConfig ? new ModuleConfigQueryValidator(Object.assign({}, this.config, queryConfig)).queryable : this.moduleConfigQueryValidator;
435
435
  const validators = [
@@ -539,12 +539,12 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
539
539
  return promise;
540
540
  }
541
541
  async bindQueryInternal(query, payloads, account) {
542
- const builder = new QueryBoundWitnessBuilder().payloads(payloads).witness(this.account).query(query);
542
+ const builder = await (await new QueryBoundWitnessBuilder().payloads(payloads)).witness(this.account).query(query);
543
543
  const result = await (account ? builder.witness(account) : builder).build();
544
544
  return result;
545
545
  }
546
- async bindQueryResult(query, payloads, sourceQuery, additionalWitnesses = [], errors) {
547
- const builder = new BoundWitnessBuilder().payloads(payloads).errors(errors).sourceQuery(sourceQuery);
546
+ async bindQueryResult(query, payloads, additionalWitnesses = [], errors) {
547
+ const builder = (await (await new BoundWitnessBuilder().payloads(payloads)).errors(errors)).sourceQuery(query.$hash);
548
548
  const queryWitnessAccount = this.queryAccounts[query.schema];
549
549
  const witnesses = [
550
550
  this.account,
@@ -689,9 +689,9 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
689
689
  }
690
690
  async queryHandler(query, payloads, queryConfig) {
691
691
  await this.started("throw");
692
- const wrapper = QueryBoundWitnessWrapper3.parseQuery(query, payloads);
692
+ const wrapper = await QueryBoundWitnessWrapper3.parseQuery(query, payloads);
693
693
  const queryPayload = await wrapper.getQuery();
694
- assertEx2(this.queryable(query, payloads, queryConfig));
694
+ assertEx2(await this.queryable(query, payloads, queryConfig));
695
695
  const resultPayloads = [];
696
696
  switch (queryPayload.schema) {
697
697
  case ModuleManifestQuerySchema: {