@xyo-network/module-abstract 3.14.18 → 3.15.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -10,6 +10,7 @@ import {
10
10
  LogLevel
11
11
  } from "@xylabs/logger";
12
12
  import { PromiseEx } from "@xylabs/promise";
13
+ import { spanAsync } from "@xylabs/telemetry";
13
14
  import { Account as Account2 } from "@xyo-network/account";
14
15
  import { asArchivistInstance } from "@xyo-network/archivist-model";
15
16
  import { BoundWitnessBuilder, QueryBoundWitnessBuilder } from "@xyo-network/boundwitness-builder";
@@ -281,29 +282,31 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
281
282
  }
282
283
  static async create(params) {
283
284
  this._noOverride("create");
284
- if (!this.configSchemas || this.configSchemas.length === 0) {
285
- throw new Error(`Missing configSchema [${params?.config?.schema}][${this.name}]`);
286
- }
287
- if (!this.defaultConfigSchema) {
288
- throw new Error(`Missing defaultConfigSchema [${params?.config?.schema}][${this.name}]`);
289
- }
290
- assertEx2(params?.config?.name === void 0 || isModuleName(params.config.name), () => `Invalid module name: ${params?.config?.name}`);
291
- const { account } = params ?? {};
292
- const schema = params?.config?.schema ?? this.defaultConfigSchema;
293
- const allowedSchemas = this.configSchemas;
294
- assertEx2(allowedSchemas.includes(schema), () => `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`);
295
- const mutatedConfig = { ...params?.config, schema };
296
- params?.logger?.debug(`config: ${JSON.stringify(mutatedConfig, null, 2)}`);
297
- const mutatedParams = { ...params, config: mutatedConfig };
298
- const activeLogger = params?.logger ?? _AbstractModule.defaultLogger;
299
- const generatedAccount = await _AbstractModule.determineAccount({ account });
300
- const address = generatedAccount.address;
301
- mutatedParams.logger = activeLogger ? new IdLogger(activeLogger, () => `0x${address}`) : void 0;
302
- const newModule = new this(_AbstractModule.privateConstructorKey, mutatedParams, generatedAccount, address);
303
- if (!_AbstractModule.enableLazyLoad) {
304
- await newModule.start?.();
305
- }
306
- return newModule;
285
+ return await spanAsync("create", async () => {
286
+ if (!this.configSchemas || this.configSchemas.length === 0) {
287
+ throw new Error(`Missing configSchema [${params?.config?.schema}][${this.name}]`);
288
+ }
289
+ if (!this.defaultConfigSchema) {
290
+ throw new Error(`Missing defaultConfigSchema [${params?.config?.schema}][${this.name}]`);
291
+ }
292
+ assertEx2(params?.config?.name === void 0 || isModuleName(params.config.name), () => `Invalid module name: ${params?.config?.name}`);
293
+ const { account } = params ?? {};
294
+ const schema = params?.config?.schema ?? this.defaultConfigSchema;
295
+ const allowedSchemas = this.configSchemas;
296
+ assertEx2(allowedSchemas.includes(schema), () => `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`);
297
+ const mutatedConfig = { ...params?.config, schema };
298
+ params?.logger?.debug(`config: ${JSON.stringify(mutatedConfig, null, 2)}`);
299
+ const mutatedParams = { ...params, config: mutatedConfig };
300
+ const activeLogger = params?.logger ?? _AbstractModule.defaultLogger;
301
+ const generatedAccount = await _AbstractModule.determineAccount({ account });
302
+ const address = generatedAccount.address;
303
+ mutatedParams.logger = activeLogger ? new IdLogger(activeLogger, () => `0x${address}`) : void 0;
304
+ const newModule = new this(_AbstractModule.privateConstructorKey, mutatedParams, generatedAccount, address);
305
+ if (!_AbstractModule.enableLazyLoad) {
306
+ await newModule.start?.();
307
+ }
308
+ return newModule;
309
+ }, params.traceProvider?.getTracer("AbstractModule[static]"));
307
310
  }
308
311
  static async determineAccount(params) {
309
312
  return await determineAccount(params, this.allowRandomAccount);
@@ -347,43 +350,45 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
347
350
  async query(query, payloads, queryConfig) {
348
351
  this._checkDead();
349
352
  this._noOverride("query");
350
- const sourceQuery = assertEx2(isQueryBoundWitness(query) ? query : void 0, () => "Unable to parse query");
351
- return await this.busy(async () => {
352
- const resultPayloads = [];
353
- const errorPayloads = [];
354
- const queryAccount = this.ephemeralQueryAccountEnabled ? await Account2.random() : void 0;
355
- try {
356
- await this.started("throw");
357
- if (!this.allowAnonymous && query.addresses.length === 0) {
358
- throw new Error(`Anonymous Queries not allowed, but running anyway [${this.modName}], [${this.address}]`);
353
+ return await spanAsync("query", async () => {
354
+ const sourceQuery = assertEx2(isQueryBoundWitness(query) ? query : void 0, () => "Unable to parse query");
355
+ return await this.busy(async () => {
356
+ const resultPayloads = [];
357
+ const errorPayloads = [];
358
+ const queryAccount = this.ephemeralQueryAccountEnabled ? await Account2.random() : void 0;
359
+ try {
360
+ await this.started("throw");
361
+ if (!this.allowAnonymous && query.addresses.length === 0) {
362
+ throw new Error(`Anonymous Queries not allowed, but running anyway [${this.modName}], [${this.address}]`);
363
+ }
364
+ if (queryConfig?.allowedQueries) {
365
+ assertEx2(queryConfig?.allowedQueries.includes(sourceQuery.schema), () => `Query not allowed [${sourceQuery.schema}]`);
366
+ }
367
+ resultPayloads.push(...await this.queryHandler(sourceQuery, payloads, queryConfig));
368
+ } catch (ex) {
369
+ await handleErrorAsync(ex, async (err) => {
370
+ const error = err;
371
+ this._lastError = error;
372
+ errorPayloads.push(
373
+ new ModuleErrorBuilder().meta({ $sources: [await PayloadBuilder2.dataHash(sourceQuery)] }).name(this.modName ?? "<Unknown>").query(sourceQuery.schema).details(error.details).message(error.message).build()
374
+ );
375
+ });
359
376
  }
360
- if (queryConfig?.allowedQueries) {
361
- assertEx2(queryConfig?.allowedQueries.includes(sourceQuery.schema), () => `Query not allowed [${sourceQuery.schema}]`);
377
+ if (this.timestamp) {
378
+ const timestamp = { schema: "network.xyo.timestamp", timestamp: Date.now() };
379
+ resultPayloads.push(timestamp);
362
380
  }
363
- resultPayloads.push(...await this.queryHandler(sourceQuery, payloads, queryConfig));
364
- } catch (ex) {
365
- await handleErrorAsync(ex, async (err) => {
366
- const error = err;
367
- this._lastError = error;
368
- errorPayloads.push(
369
- new ModuleErrorBuilder().meta({ $sources: [await PayloadBuilder2.dataHash(sourceQuery)] }).name(this.modName ?? "<Unknown>").query(sourceQuery.schema).details(error.details).message(error.message).build()
370
- );
371
- });
372
- }
373
- if (this.timestamp) {
374
- const timestamp = { schema: "network.xyo.timestamp", timestamp: Date.now() };
375
- resultPayloads.push(timestamp);
376
- }
377
- const result = await this.bindQueryResult(sourceQuery, resultPayloads, queryAccount ? [queryAccount] : [], errorPayloads);
378
- const args = {
379
- mod: this,
380
- payloads,
381
- query: sourceQuery,
382
- result
383
- };
384
- await this.emit("moduleQueried", args);
385
- return result;
386
- });
381
+ const result = await this.bindQueryResult(sourceQuery, resultPayloads, queryAccount ? [queryAccount] : [], errorPayloads);
382
+ const args = {
383
+ mod: this,
384
+ payloads,
385
+ query: sourceQuery,
386
+ result
387
+ };
388
+ await this.emit("moduleQueried", args);
389
+ return result;
390
+ });
391
+ }, this.tracer);
387
392
  }
388
393
  async queryable(query, payloads, queryConfig) {
389
394
  if (this.dead) {
@@ -400,11 +405,14 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
400
405
  }
401
406
  return true;
402
407
  }
403
- start(_timeout) {
404
- this._startPromise = this._startPromise ?? this.startHandler();
405
- const result = this._startPromise;
406
- this.status = result ? "started" : "dead";
407
- return result;
408
+ async start(timeout) {
409
+ this._noOverride("start");
410
+ return await spanAsync("start", async () => {
411
+ this._startPromise = this._startPromise ?? await this.startHandler(timeout);
412
+ const result = this._startPromise;
413
+ this.status = result ? "started" : "dead";
414
+ return result;
415
+ }, this.tracer);
408
416
  }
409
417
  async started(notStartedAction = "log", tryStart = true) {
410
418
  const started = await this._started;
@@ -453,13 +461,16 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
453
461
  return await this._started;
454
462
  }
455
463
  async stop(_timeout) {
456
- return await this.busy(async () => {
457
- const result = await this.stopHandler();
458
- this._started = void 0;
459
- this._startPromise = void 0;
460
- this.status = result ? "stopped" : "dead";
461
- return result;
462
- });
464
+ this._noOverride("stop");
465
+ return await spanAsync("start", async () => {
466
+ return await this.busy(async () => {
467
+ const result = await this.stopHandler();
468
+ this._started = void 0;
469
+ this._startPromise = void 0;
470
+ this.status = result ? "stopped" : "dead";
471
+ return result;
472
+ });
473
+ }, this.tracer);
463
474
  }
464
475
  _checkDead() {
465
476
  if (this.dead) {
@@ -614,7 +625,7 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
614
625
  }
615
626
  return PayloadBuilder2.omitPrivateStorageMeta(resultPayloads);
616
627
  }
617
- async startHandler() {
628
+ async startHandler(_timeout) {
618
629
  this.validateConfig();
619
630
  await Promise.resolve();
620
631
  this._started = true;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/AbstractModule.ts","../../src/determineAccount.ts","../../src/Error.ts","../../src/QueryValidator/ModuleConfigQueryValidator.ts","../../src/QueryValidator/SupportedQueryValidator.ts","../../src/AbstractModuleInstance.ts"],"sourcesContent":["/* eslint-disable complexity */\n/* eslint-disable max-lines */\nimport { assertEx } from '@xylabs/assert'\nimport { Base, globallyUnique } from '@xylabs/base'\nimport { handleError, handleErrorAsync } from '@xylabs/error'\nimport { exists } from '@xylabs/exists'\nimport { forget } from '@xylabs/forget'\nimport type { Address, Hash } from '@xylabs/hex'\nimport type { Logger } from '@xylabs/logger'\nimport {\n ConsoleLogger, IdLogger,\n LogLevel,\n} from '@xylabs/logger'\nimport type { Promisable } from '@xylabs/promise'\nimport { PromiseEx } from '@xylabs/promise'\nimport { Account } from '@xyo-network/account'\nimport type { AccountInstance } from '@xyo-network/account-model'\nimport type { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { asArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitnessBuilder, QueryBoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport type { BoundWitness, QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { isQueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport type { ConfigPayload } from '@xyo-network/config-payload-plugin'\nimport { ConfigSchema } from '@xyo-network/config-payload-plugin'\nimport type { ModuleManifestPayload } from '@xyo-network/manifest-model'\nimport { BaseEmitter } from '@xyo-network/module-event-emitter'\nimport type {\n AddressPayload,\n AddressPreviousHashPayload,\n ArchivingModuleConfig,\n AttachableModuleInstance,\n CreatableModule,\n CreatableModuleFactory,\n Labels,\n Module,\n ModuleBusyEventArgs,\n ModuleConfig,\n ModuleDescriptionPayload,\n ModuleDetailsError,\n ModuleEventData,\n ModuleParams,\n ModuleQueriedEventArgs,\n ModuleQueries,\n ModuleQueryHandlerResult,\n ModuleQueryResult,\n ModuleResolverInstance,\n ModuleStatus,\n} from '@xyo-network/module-model'\nimport {\n AddressPreviousHashSchema,\n AddressSchema,\n DeadModuleError,\n isModuleName,\n isSerializable,\n ModuleAddressQuerySchema,\n ModuleConfigSchema,\n ModuleDescriptionSchema,\n ModuleFactory,\n ModuleManifestQuerySchema,\n ModuleStateQuerySchema,\n ModuleSubscribeQuerySchema,\n ObjectResolverPriority,\n} from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type {\n ModuleError, Payload, Query, Schema,\n} from '@xyo-network/payload-model'\nimport { QuerySchema } from '@xyo-network/query-payload-plugin'\nimport type { WalletInstance } from '@xyo-network/wallet-model'\nimport { Mutex } from 'async-mutex'\nimport { LRUCache } from 'lru-cache'\n\nimport { determineAccount } from './determineAccount.ts'\nimport { ModuleErrorBuilder } from './Error.ts'\nimport type { Queryable } from './QueryValidator/index.ts'\nimport { ModuleConfigQueryValidator, SupportedQueryValidator } from './QueryValidator/index.ts'\n\nconst MODULE_NOT_STARTED = 'Module not Started' as const\nexport abstract class AbstractModule<TParams extends ModuleParams = ModuleParams, TEventData extends ModuleEventData = ModuleEventData>\n extends BaseEmitter<TParams, TEventData>\n implements Module<TParams, TEventData> {\n static readonly allowRandomAccount: boolean = true\n static readonly configSchemas: Schema[] = [ModuleConfigSchema]\n static readonly defaultConfigSchema: Schema = ModuleConfigSchema\n // eslint-disable-next-line sonarjs/public-static-readonly\n static override defaultLogger: Logger = new ConsoleLogger(LogLevel.warn)\n // eslint-disable-next-line sonarjs/public-static-readonly\n static enableLazyLoad = false\n static readonly labels: Labels = {}\n static override readonly uniqueName = globallyUnique('AbstractModule', AbstractModule, 'xyo')\n\n protected static privateConstructorKey = Date.now().toString()\n\n protected _account: AccountInstance\n\n // cache manifest based on maxDepth\n protected _cachedManifests = new LRUCache<number, ModuleManifestPayload>({ max: 10, ttl: 1000 * 60 * 5 })\n\n protected _globalReentrancyMutex: Mutex | undefined = undefined\n\n protected _lastError?: ModuleDetailsError\n\n protected _startPromise: Promisable<boolean> | undefined = undefined\n protected _started: Promisable<boolean> | undefined = undefined\n protected readonly moduleConfigQueryValidator: Queryable\n protected readonly supportedQueryValidator: Queryable\n\n private _busyCount = 0\n private _logger: Logger | undefined = undefined\n private _status: ModuleStatus = 'stopped'\n\n constructor(privateConstructorKey: string, params: TParams, account: AccountInstance) {\n assertEx(AbstractModule.privateConstructorKey === privateConstructorKey, () => 'Use create function instead of constructor')\n // Clone params to prevent mutation of the incoming object\n const mutatedParams = { ...params } as TParams\n super(mutatedParams)\n\n this._account = account\n\n this.supportedQueryValidator = new SupportedQueryValidator(this as Module).queryable\n this.moduleConfigQueryValidator = new ModuleConfigQueryValidator(mutatedParams?.config).queryable\n }\n\n get account() {\n return assertEx(this._account, () => 'Missing account')\n }\n\n get additionalSigners(): AccountInstance[] {\n return this.params.additionalSigners ?? []\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 allowNameResolution() {\n return this.params.allowNameResolution ?? true\n }\n\n get archiving(): ArchivingModuleConfig['archiving'] | undefined {\n return this.config.archiving\n }\n\n get archivist() {\n return this.config.archivist\n }\n\n get config(): TParams['config'] {\n return this.params.config\n }\n\n get dead() {\n return this.status === 'dead'\n }\n\n get ephemeralQueryAccountEnabled(): boolean {\n return !!this.params.ephemeralQueryAccountEnabled\n }\n\n get globalReentrancyMutex() {\n this._globalReentrancyMutex = this._globalReentrancyMutex ?? this.reentrancy?.scope === 'global' ? new Mutex() : undefined\n return this._globalReentrancyMutex\n }\n\n get id() {\n return this.modName ?? this.address\n }\n\n override get logger() {\n const logLevel = this.config.logLevel\n this._logger\n = (this._logger ?? logLevel) ? new ConsoleLogger(logLevel) : (this.params?.logger ?? AbstractModule.defaultLogger ?? Base.defaultLogger)\n return this._logger\n }\n\n get modName() {\n return this.config.name\n }\n\n get priority() {\n return ObjectResolverPriority.Normal\n }\n\n get queries(): Schema[] {\n return [ModuleAddressQuerySchema, ModuleSubscribeQuerySchema, ModuleManifestQuerySchema, ModuleStateQuerySchema]\n }\n\n get reentrancy() {\n return this.config.reentrancy\n }\n\n get status() {\n return this._status\n }\n\n get timestamp() {\n return this.config.timestamp ?? false\n }\n\n protected set status(value: ModuleStatus) {\n if (this._status !== 'dead') {\n this._status = value\n }\n }\n\n abstract get downResolver(): ModuleResolverInstance\n\n abstract get upResolver(): ModuleResolverInstance\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\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 AttachableModuleInstance>(\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 if (!this.defaultConfigSchema) {\n throw new Error(`Missing defaultConfigSchema [${params?.config?.schema}][${this.name}]`)\n }\n\n assertEx(params?.config?.name === undefined || isModuleName(params.config.name), () => `Invalid module name: ${params?.config?.name}`)\n\n const { account } = params ?? {}\n\n const schema: Schema = params?.config?.schema ?? this.defaultConfigSchema\n const allowedSchemas: Schema[] = 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, address)\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 AttachableModuleInstance>(\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 // eslint-disable-next-line sonarjs/no-identical-functions\n _getRootFunction(funcName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let anyThis = this as any\n while (anyThis.__proto__[funcName]) {\n anyThis = anyThis.__proto__\n }\n return anyThis[funcName]\n }\n\n async busy<R>(closure: () => Promise<R>) {\n if (this._busyCount <= 0) {\n this._busyCount = 0\n const args: ModuleBusyEventArgs = { busy: true, mod: 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, mod: this }\n await this.emit('moduleBusy', args)\n }\n }\n }\n\n override emit<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return super.emit(eventName, eventArgs)\n }\n\n previousHash(): Promisable<string | undefined> {\n this._checkDead()\n return this.account.previousHash\n }\n\n async query<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryResult> {\n this._checkDead()\n this._noOverride('query')\n const sourceQuery = assertEx(isQueryBoundWitness(query) ? query : undefined, () => 'Unable to parse query')\n return await this.busy(async () => {\n const resultPayloads: Payload[] = []\n const errorPayloads: ModuleError[] = []\n const queryAccount = this.ephemeralQueryAccountEnabled ? await Account.random() : undefined\n\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.modName}], [${this.address}]`)\n }\n if (queryConfig?.allowedQueries) {\n assertEx(queryConfig?.allowedQueries.includes(sourceQuery.schema), () => `Query not allowed [${sourceQuery.schema}]`)\n }\n resultPayloads.push(...(await this.queryHandler(sourceQuery, payloads, queryConfig)))\n } catch (ex) {\n await handleErrorAsync(ex, async (err) => {\n const error = err as ModuleDetailsError\n this._lastError = error\n // this.status = 'dead'\n errorPayloads.push(\n new ModuleErrorBuilder()\n .meta({ $sources: [await PayloadBuilder.dataHash(sourceQuery)] })\n .name(this.modName ?? '<Unknown>')\n .query(sourceQuery.schema)\n .details(error.details)\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 = {\n mod: this, payloads, query: sourceQuery, result,\n }\n await this.emit('moduleQueried', args)\n return result\n })\n }\n\n async queryable<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<boolean> {\n if (this.dead) {\n return false\n }\n if (!(await this.started('warn'))) return false\n const configValidator\n = queryConfig ? new ModuleConfigQueryValidator(Object.assign({}, this.config, queryConfig)).queryable : this.moduleConfigQueryValidator\n const validators = [this.supportedQueryValidator, configValidator]\n\n const results = await Promise.all(validators.map(validator => validator(query, payloads)))\n for (const result of results) {\n if (!result) {\n return false\n }\n }\n return true\n }\n\n start(_timeout?: number): Promisable<boolean> {\n // using promise as mutex\n this._startPromise = this._startPromise ?? this.startHandler()\n const result = this._startPromise\n this.status = result ? 'started' : 'dead'\n return result\n }\n\n async started(notStartedAction: 'error' | 'throw' | 'warn' | 'log' | 'none' = 'log', tryStart = true): Promise<boolean> {\n const started = await this._started\n if (started === true) {\n return true\n }\n if (!started) {\n // using promise as mutex\n this._started = (async () => {\n if (tryStart) {\n try {\n await this.start()\n return true\n } catch (ex) {\n handleError(ex, (error) => {\n this.logger?.warn(`Autostart of Module Failed: ${error.message})`)\n this._started = undefined\n })\n }\n }\n switch (notStartedAction) {\n case 'throw': {\n throw new Error(`${MODULE_NOT_STARTED} [${this.address}]`)\n }\n case 'warn': {\n this.logger?.warn(MODULE_NOT_STARTED)\n break\n }\n case 'error': {\n this.logger?.error(MODULE_NOT_STARTED)\n break\n }\n case 'none': {\n break\n }\n default: {\n this.logger?.log(MODULE_NOT_STARTED)\n break\n }\n }\n return false\n })()\n }\n if (!this._started) {\n throw 'Failed to create start promise'\n }\n return await this._started\n }\n\n async stop(_timeout?: number): Promise<boolean> {\n return await this.busy(async () => {\n const result = await this.stopHandler()\n this._started = undefined\n this._startPromise = undefined\n this.status = result ? 'stopped' : 'dead'\n return result\n })\n }\n\n protected _checkDead() {\n if (this.dead) {\n throw new DeadModuleError(this.id, this._lastError)\n }\n }\n\n // eslint-disable-next-line sonarjs/no-identical-functions\n protected _noOverride(functionName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const thisFunc = (this as any)[functionName]\n\n const rootFunc = this._getRootFunction(functionName)\n assertEx(thisFunc === rootFunc, () => `Override not allowed for [${functionName}] - override ${functionName}Handler instead`)\n }\n\n protected async archivistInstance(): Promise<ArchivistInstance | undefined>\n protected async archivistInstance(required: true): Promise<ArchivistInstance>\n protected async archivistInstance(required = false): Promise<ArchivistInstance | undefined> {\n const archivist = this.archivist\n if (!archivist) {\n if (required) {\n throw new Error('No archivist specified')\n }\n return undefined\n }\n const resolved = (await this.upResolver.resolve(archivist)) ?? (await this.downResolver.resolve(archivist))\n if (required) {\n assertEx(resolved, () => `Unable to resolve archivist [${archivist}]`)\n }\n return resolved ? asArchivistInstance(resolved, () => `Specified archivist is not an Archivist [${archivist}]`) : undefined\n }\n\n protected bindHashes(hashes: Hash[], schema: Schema[], account?: AccountInstance) {\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n return new PromiseEx((resolve) => {\n const result = this.bindHashesInternal(hashes, schema, account)\n resolve?.(result)\n return result\n }, account)\n }\n\n protected async bindHashesInternal(hashes: Hash[], schema: Schema[], account: AccountInstance = this.account): Promise<BoundWitness> {\n const builder = new BoundWitnessBuilder().hashes(hashes, schema).signer(account)\n const result: BoundWitness = (await 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 additionalSigners?: AccountInstance[],\n ): PromiseEx<[QueryBoundWitness, Payload[], Payload[]], AccountInstance> {\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n return new PromiseEx<[QueryBoundWitness, Payload[], Payload[]], AccountInstance>(async (resolve) => {\n const result = await this.bindQueryInternal(query, payloads, account, additionalSigners)\n resolve?.(result)\n return result\n }, account)\n }\n\n protected async bindQueryInternal<T extends Query>(\n query: T,\n payloads?: Payload[],\n account: AccountInstance = this.account,\n additionalSigners: AccountInstance[] = [],\n ): Promise<[QueryBoundWitness, Payload[], Payload[]]> {\n const accounts = [account, ...additionalSigners].filter(exists)\n const builder = new QueryBoundWitnessBuilder().payloads(payloads).signers(accounts).query(query)\n\n const [bw, payloadsOut, errors] = await builder.build()\n return [bw, [...payloadsOut], errors]\n }\n\n protected async bindQueryResult<T extends Query>(\n query: T,\n payloads: Payload[],\n additionalWitnesses: AccountInstance[] = [],\n errors?: ModuleError[],\n ): Promise<ModuleQueryResult> {\n const queryDataHash = await PayloadBuilder.dataHash(query)\n const builder = new BoundWitnessBuilder().payloads(payloads).errors(errors).sourceQuery(queryDataHash)\n const witnesses = [this.account, ...additionalWitnesses].filter(exists)\n builder.signers(witnesses)\n const result: ModuleQueryResult = [\n PayloadBuilder.omitPrivateStorageMeta((await builder.build())[0]),\n PayloadBuilder.omitPrivateStorageMeta(payloads),\n PayloadBuilder.omitPrivateStorageMeta(errors ?? []),\n ]\n if (this.archiving && this.isAllowedArchivingQuery(query.schema)) {\n forget(this.storeToArchivists(result.flat()))\n }\n return result\n }\n\n protected generateConfigAndAddress(_maxDepth?: number): Promisable<Payload[]> {\n const config = this.config\n const address: AddressPayload = { schema: AddressSchema, address: this.address }\n const queries = this.queries.map((query) => {\n return { schema: QuerySchema, query }\n })\n const configSchema: ConfigPayload = {\n config: config.schema,\n schema: ConfigSchema,\n }\n return ([config, configSchema, address, ...queries]).filter(exists)\n }\n\n protected async generateDescribe(): 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.modName\n }\n\n const discover = await this.generateConfigAndAddress()\n\n description.children = (\n discover?.map((payload) => {\n const address = payload.schema === AddressSchema ? (payload as AddressPayload).address : undefined\n return address == this.address ? undefined : address\n }) ?? []\n ).filter(exists)\n\n return description\n }\n\n /** @deprecated use archivistInstance() instead */\n protected async getArchivist(): Promise<ArchivistInstance | undefined> {\n return await this.archivistInstance()\n }\n\n protected isAllowedArchivingQuery(schema: Schema): boolean {\n const queries = this.archiving?.queries\n if (queries) {\n return queries.includes(schema)\n }\n return true\n }\n\n protected manifestHandler(_maxDepth: number = 1, _ignoreAddresses: Address[] = []): Promisable<ModuleManifestPayload> {\n throw new Error('Not supported')\n }\n\n protected moduleAddressHandler(): Promisable<(AddressPreviousHashPayload | AddressPayload)[]> {\n const address = this.address\n const name = this.modName\n const previousHash = this.address\n const moduleAccount = name\n ? {\n address, name, schema: AddressSchema,\n }\n : { address, schema: AddressSchema }\n const moduleAccountPreviousHash = previousHash\n ? {\n address, previousHash, schema: AddressPreviousHashSchema,\n }\n : { address, schema: AddressSchema }\n return [moduleAccount, moduleAccountPreviousHash]\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<ModuleQueries>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(await this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n switch (queryPayload.schema) {\n case ModuleManifestQuerySchema: {\n resultPayloads.push(await this.manifestHandler(queryPayload.maxDepth))\n break\n }\n case ModuleAddressQuerySchema: {\n resultPayloads.push(...(await this.moduleAddressHandler()))\n break\n }\n case ModuleStateQuerySchema: {\n resultPayloads.push(...(await this.stateHandler()))\n break\n }\n case ModuleSubscribeQuerySchema: {\n this.subscribeHandler()\n break\n }\n default: {\n throw new Error(`Unsupported Query [${(queryPayload as Payload).schema}]`)\n }\n }\n return PayloadBuilder.omitPrivateStorageMeta(resultPayloads)\n }\n\n protected async startHandler(): Promise<boolean> {\n this.validateConfig()\n await Promise.resolve()\n this._started = true\n return true\n }\n\n protected async stateHandler(): Promise<Payload[]> {\n return [await this.manifestHandler(), ...(await this.generateConfigAndAddress()), await this.generateDescribe()]\n }\n\n protected stopHandler(_timeout?: number): Promisable<boolean> {\n this._started = undefined\n return true\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 (!isSerializable(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 protected abstract certifyParents(): Promise<Payload[]>\n protected abstract storeToArchivists(payloads: Payload[]): Promise<Payload[]>\n}\n","import { assertEx } from '@xylabs/assert'\nimport { Account } from '@xyo-network/account'\nimport type { AccountInstance } from '@xyo-network/account-model'\nimport type { 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 await Account.random()\n }\n return params.account\n }\n\n if (isDetermineAccountFromWalletParams(params)) {\n return assertEx(\n params.accountPath ? await params.wallet.derivePath(params.accountPath) : params.wallet,\n () => 'Failed to derive account from path',\n )\n }\n\n // this should eventually be removed/thrown\n console.warn('AbstractModule.determineAccount: No account or wallet provided - Creating Random account')\n return await Account.random()\n}\n","import type { Hash } from '@xylabs/hex'\nimport type { JsonValue } from '@xylabs/object'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type { ModuleError } from '@xyo-network/payload-model'\nimport { ModuleErrorSchema } from '@xyo-network/payload-model'\n\nexport class ModuleErrorBuilder extends PayloadBuilder<ModuleError> {\n _details?: JsonValue\n _message?: string\n _name?: string\n _query?: Hash\n constructor() {\n super({ schema: ModuleErrorSchema })\n }\n\n override build(): ModuleError {\n this.fields({\n details: this._details,\n message: this._message,\n name: this._name,\n query: this._query,\n })\n return super.build()\n }\n\n details(details?: JsonValue) {\n this._details = details\n return this\n }\n\n message(message: string) {\n this._message = message\n return this\n }\n\n name(name: string) {\n this._name = name\n return this\n }\n\n query(query: Hash) {\n this._query = query\n return this\n }\n}\n","import type { Address } from '@xylabs/hex'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport type {\n AnyConfigSchema, CosigningAddressSet, ModuleConfig, ModuleQueries,\n} from '@xyo-network/module-model'\nimport type { Schema } from '@xyo-network/payload-model'\n\nimport type { Queryable, QueryValidator } from './QueryValidator.ts'\n\n// eslint-disable-next-line sonarjs/redundant-type-aliases\nexport type SortedPipedAddressesString = string\n\nconst delimiter = ''\n\nexport class ModuleConfigQueryValidator<TConfig extends AnyConfigSchema<ModuleConfig>> implements QueryValidator {\n protected allowed: Record<Schema, SortedPipedAddressesString[]> = {}\n protected disallowed: Record<Schema, SortedPipedAddressesString[]> = {}\n protected readonly hasAllowedRules: boolean\n protected readonly hasDisallowedRules: boolean\n protected readonly hasRules: boolean\n\n constructor(config?: TConfig) {\n if (config?.security?.allowed) {\n for (const [schema, addresses] of Object.entries(config.security?.allowed)) {\n this.allowed[schema] = addresses.map(toAddressesString)\n }\n }\n if (config?.security?.disallowed) {\n for (const [schema, addresses] of Object.entries(config.security?.disallowed)) {\n this.disallowed[schema] = addresses.map(toAddressesString)\n }\n }\n this.hasAllowedRules = Object.keys(this.allowed).length > 0\n this.hasDisallowedRules = Object.keys(this.disallowed).length > 0\n this.hasRules = this.hasAllowedRules || this.hasDisallowedRules\n }\n\n queryable: Queryable = async (query, payloads) => {\n if (!this.hasRules) return true\n const addresses = query.addresses\n if (addresses.length === 0) return false\n const wrapper = QueryBoundWitnessWrapper.parseQuery<ModuleQueries>(query, payloads)\n const schema = (await wrapper.getQuery()).schema\n return this.queryAllowed(schema, addresses) && !this.queryDisallowed(schema, addresses)\n }\n\n protected queryAllowed = (schema: Schema, addresses: Address[]): boolean => {\n if (!this.hasAllowedRules) return true\n // All cosigners must sign\n if (addresses.length > 1) {\n const signatories = toAddressesString(addresses)\n const validCosigners = this.allowed?.[schema]?.includes(signatories)\n if (validCosigners) return true\n }\n // OR all signers have to be allowed individually\n return addresses.every(address => this.allowed?.[schema]?.includes(address) || false)\n }\n\n protected queryDisallowed = (schema: Schema, addresses: string[]): boolean => {\n if (!this.hasDisallowedRules) return false\n return addresses.some(address => this.disallowed?.[schema]?.includes(address))\n }\n}\n\n// TODO: Handle 0x prefix\nconst toAddressesString = (addresses: string | CosigningAddressSet): SortedPipedAddressesString => {\n return Array.isArray(addresses)\n ? addresses\n // eslint-disable-next-line sonarjs/no-alphabetical-sort\n .toSorted()\n .map(address => address.toLowerCase())\n .join(delimiter)\n : addresses.toLowerCase()\n}\n","import type { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport type { Module, ModuleQueries } from '@xyo-network/module-model'\nimport type { Payload } from '@xyo-network/payload-model'\n\nimport type { Queryable, QueryValidator } from './QueryValidator.ts'\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<ModuleQueries>(query, payloads)\n const schema = (await wrapper.getQuery()).schema\n return mod.queries.includes(schema)\n}\n\nexport class SupportedQueryValidator implements QueryValidator {\n constructor(protected readonly mod: Module) {}\n queryable: Queryable = (query, payloads) => {\n return isQuerySupportedByModule(this.mod, query, payloads)\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { globallyUnique } from '@xylabs/base'\nimport { exists } from '@xylabs/exists'\nimport type { Address } from '@xylabs/hex'\nimport type { TypeCheck } from '@xylabs/object'\nimport type { Promisable } from '@xylabs/promise'\nimport type { TypedValue } from '@xylabs/typeof'\nimport type { AccountInstance } from '@xyo-network/account-model'\nimport type { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { asArchivistInstance } from '@xyo-network/archivist-model'\nimport type { ModuleManifestPayload } from '@xyo-network/manifest-model'\nimport { ModuleManifestPayloadSchema } from '@xyo-network/manifest-model'\nimport type {\n AddressPayload,\n AddressPreviousHashPayload,\n AttachableModuleInstance,\n ModuleEventData,\n ModuleFilterOptions,\n ModuleIdentifier,\n ModuleInstance,\n ModuleManifestQuery,\n ModuleName,\n ModuleNameResolver,\n ModuleParams,\n ModuleQueryResult,\n ModuleStateQuery,\n ObjectFilterOptions,\n ResolveHelperConfig,\n} from '@xyo-network/module-model'\nimport {\n duplicateModules,\n ModuleManifestQuerySchema,\n ModuleStateQuerySchema,\n resolveAll,\n resolveAllDown,\n resolveAllUp,\n ResolveHelper,\n resolvePathToInstance,\n} from '@xyo-network/module-model'\nimport { CompositeModuleResolver } from '@xyo-network/module-resolver'\nimport type { NodeInstance } from '@xyo-network/node-model'\nimport { asNodeInstance } from '@xyo-network/node-model'\nimport type { Payload, Query } from '@xyo-network/payload-model'\n\nimport { AbstractModule } from './AbstractModule.ts'\n\nfunction filterIdentity<T extends TypedValue>(mod?: ModuleInstance, identityFunc?: TypeCheck<T>): T\nfunction filterIdentity<T extends TypedValue>(mods?: ModuleInstance[], identityFunc?: TypeCheck<T>): T[]\nfunction filterIdentity<T extends TypedValue>(mod?: ModuleInstance | ModuleInstance[], identityFunc?: TypeCheck<T>) {\n if (Array.isArray(mod)) {\n if (identityFunc) {\n return mod.map(m => identityFunc(m)).filter(exists)\n }\n return mod\n }\n return (mod ? (identityFunc ? identityFunc(mod) : true) : false) ? mod : undefined\n}\n\nexport abstract class AbstractModuleInstance<TParams extends ModuleParams = ModuleParams, TEventData extends ModuleEventData = ModuleEventData>\n extends AbstractModule<TParams, TEventData>\n implements AttachableModuleInstance<TParams, TEventData>, ModuleNameResolver {\n static override readonly uniqueName = globallyUnique('AbstractModuleInstance', AbstractModuleInstance, 'xyo')\n\n // switches between old and new resolution system\n static readonly useNewResolver = false\n\n private _downResolver?: CompositeModuleResolver\n private _parents: NodeInstance[] = []\n private _privateResolver?: CompositeModuleResolver\n private _upResolver?: CompositeModuleResolver\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 const addToResolvers = mutatedParams.addToResolvers ?? true\n super(privateConstructorKey, mutatedParams, account)\n if (addToResolvers) {\n this.upResolver.add(this)\n this.downResolver.add(this)\n }\n }\n\n get downResolver() {\n this._downResolver\n = this._downResolver\n ?? new CompositeModuleResolver({\n allowNameResolution: this.allowNameResolution,\n moduleIdentifierTransformers: this.params.moduleIdentifierTransformers,\n root: this,\n })\n return this._downResolver\n }\n\n override get modName() {\n return super.modName\n }\n\n get moduleIdentifierTransformers() {\n return this.params.moduleIdentifierTransformers ?? ResolveHelper.transformers\n }\n\n get privateResolver() {\n this._privateResolver\n = this._privateResolver\n ?? new CompositeModuleResolver({\n allowNameResolution: this.allowNameResolution,\n moduleIdentifierTransformers: this.params.moduleIdentifierTransformers,\n root: this,\n })\n return this._privateResolver\n }\n\n get root() {\n return this\n }\n\n get upResolver() {\n this._upResolver\n = this._upResolver\n ?? new CompositeModuleResolver({\n allowNameResolution: this.allowNameResolution,\n moduleIdentifierTransformers: this.params.moduleIdentifierTransformers,\n root: this,\n })\n return this._upResolver\n }\n\n addParent(mod: ModuleInstance) {\n const existingEntry = this._parents.find(parent => parent.address === mod.address)\n if (!existingEntry) {\n this._parents.push(asNodeInstance(mod, 'Only NodeInstances can be parents'))\n }\n }\n\n async certifyParents(): Promise<Payload[]> {\n const parents = await this.parents()\n return (\n await Promise.all(\n parents.map(async (parent) => {\n const [bw, payloads, errors] = await parent.certifyQuery(this.address)\n return errors.length === 0 ? [bw, ...payloads] : []\n }),\n )\n ).flat()\n }\n\n manifest(maxDepth?: number): Promise<ModuleManifestPayload> {\n this._checkDead()\n return this.busy(async () => {\n return await this.manifestHandler(maxDepth)\n })\n }\n\n async manifestQuery(account: AccountInstance, maxDepth?: number): Promise<ModuleQueryResult<ModuleManifestPayload>> {\n const queryPayload: ModuleManifestQuery = { schema: ModuleManifestQuerySchema, ...(maxDepth === undefined ? {} : { maxDepth }) }\n return await this.sendQueryRaw<ModuleManifestQuery, Payload, ModuleManifestPayload>(queryPayload, undefined, account)\n }\n\n moduleAddress(): Promise<(AddressPayload | AddressPreviousHashPayload)[]> {\n this._checkDead()\n return this.busy(async () => {\n return await this.moduleAddressHandler()\n })\n }\n\n parents(): Promisable<NodeInstance[]> {\n return this._parents\n }\n\n privateChildren(): Promisable<ModuleInstance[]> {\n return [...this.params.privateChildren ?? []]\n }\n\n publicChildren(): Promisable<ModuleInstance[]> {\n return [...this.params.publicChildren ?? []]\n }\n\n removeParent(address: Address) {\n this._parents = this._parents.filter(item => item.address !== address)\n }\n\n async resolve(): Promise<ModuleInstance[]>\n async resolve<T extends ModuleInstance = ModuleInstance>(all: '*', options?: ModuleFilterOptions<T>): Promise<T[]>\n async resolve<T extends ModuleInstance = ModuleInstance>(id: ModuleIdentifier, options?: ModuleFilterOptions<T>): Promise<T | undefined>\n async resolve<T extends ModuleInstance = ModuleInstance>(\n id: ModuleIdentifier = '*',\n options: ModuleFilterOptions<T> = {},\n ): Promise<T | T[] | undefined> {\n if (AbstractModuleInstance.useNewResolver) {\n if (id === '*') {\n const { maxDepth = 10, direction } = options\n if (direction === 'down') {\n return filterIdentity<T>((await resolveAllDown(this, maxDepth)) ?? [], options.identity)\n }\n if (direction === 'up') {\n return filterIdentity<T>(await resolveAllUp(this, maxDepth) ?? [], options.identity)\n }\n return filterIdentity<T>(await resolveAll(this, maxDepth) ?? [], options.identity)\n } else if (typeof id === 'string') {\n return filterIdentity<T>(await resolvePathToInstance(this, id, true), options.identity)\n } else {\n throw new TypeError('Invalid id type')\n }\n } else {\n const config: ResolveHelperConfig = {\n address: this.address,\n dead: this.dead,\n downResolver: this.downResolver,\n logger: this.logger,\n mod: this,\n transformers: this.moduleIdentifierTransformers,\n upResolver: this.upResolver,\n }\n if (id === '*') {\n return filterIdentity<T>(await ResolveHelper.resolve(config, id, options) ?? [], options.identity)\n }\n return filterIdentity<T>(await ResolveHelper.resolve(config, id, options), options.identity)\n }\n }\n\n resolveIdentifier(id: ModuleIdentifier, options?: ObjectFilterOptions): Promise<Address | undefined> {\n const { direction = 'all' } = options ?? {}\n switch (direction) {\n case 'down': {\n return this.downResolver.resolveIdentifier(id, options)\n }\n default: {\n const mutatedOptions = { ...options, direction: 'all' } as ObjectFilterOptions\n return this.upResolver.resolveIdentifier(id, mutatedOptions)\n }\n }\n }\n\n async resolvePrivate<T extends ModuleInstance = ModuleInstance>(all: '*', options?: ModuleFilterOptions<T>): Promise<T[]>\n async resolvePrivate<T extends ModuleInstance = ModuleInstance>(id: ModuleIdentifier, options?: ModuleFilterOptions<T>): Promise<T | undefined>\n async resolvePrivate<T extends ModuleInstance = ModuleInstance>(\n id: ModuleIdentifier = '*',\n options: ModuleFilterOptions<T> = {},\n ): Promise<T | T[] | undefined> {\n return (\n (await this.privateResolver.resolve(id, options))\n ?? (await this.upResolver.resolve(id, options))\n ?? (await this.downResolver.resolve(id, options))\n )\n }\n\n async siblings(): Promise<ModuleInstance[]> {\n return (await Promise.all((await this.parents()).map(parent => parent.publicChildren()))).flat().filter(duplicateModules)\n }\n\n /* override start(_timeout?: number): Promisable<boolean> {\n if (this.parents.length === 0) {\n this.logger.warn(`Module is being started without being attached to a parent: ${this.id} [${this.address}]`)\n }\n return super.start()\n } */\n\n state() {\n this._checkDead()\n return this.busy(async () => {\n return await this.stateHandler()\n })\n }\n\n async stateQuery(account: AccountInstance): Promise<ModuleQueryResult> {\n const queryPayload: ModuleStateQuery = { schema: ModuleStateQuerySchema }\n return await this.sendQueryRaw(queryPayload, undefined, account)\n }\n\n subscribe(_queryAccount?: AccountInstance) {\n this._checkDead()\n return this.subscribeHandler()\n }\n\n protected override async manifestHandler(maxDepth: number = 1, _ignoreAddresses: Address[] = []): Promise<ModuleManifestPayload> {\n const cachedResult = this._cachedManifests.get(maxDepth)\n if (cachedResult) {\n return cachedResult\n }\n const modName = this.modName ?? '<Anonymous>'\n const children = await this.publicChildren()\n const childAddressToName: Record<Address, ModuleName | null> = {}\n for (const child of children) {\n if (child.address !== this.address) {\n childAddressToName[child.address] = child.modName ?? null\n }\n }\n const result = {\n config: { name: modName, ...this.config },\n schema: ModuleManifestPayloadSchema,\n status: { address: this.address, children: childAddressToName },\n }\n this._cachedManifests.set(maxDepth, result)\n return result\n }\n\n protected async resolveArchivingArchivists(): Promise<ArchivistInstance[]> {\n const archivists = this.archiving?.archivists\n if (!archivists) return []\n const resolved = await Promise.all(archivists.map(archivist => this.resolve(archivist)))\n return (resolved.map(mod => asArchivistInstance(mod))).filter(exists)\n }\n\n protected async sendQuery<T extends Query, P extends Payload = Payload, R extends Payload = Payload>(\n queryPayload: T,\n payloads?: P[],\n account?: AccountInstance,\n ): Promise<R[]> {\n const queryResults = await this.sendQueryRaw(queryPayload, payloads, account)\n const [, resultPayloads, errors] = queryResults\n\n /* TODO: Figure out what to do with the returning BW. Should we store them in a queue in case the caller wants to see them? */\n\n if (errors && errors.length > 0) {\n /* TODO: Figure out how to rollup multiple Errors */\n throw errors[0]\n }\n\n return resultPayloads as R[]\n }\n\n protected async sendQueryRaw<T extends Query, P extends Payload = Payload, R extends Payload = Payload>(\n queryPayload: T,\n payloads?: P[],\n account?: AccountInstance,\n ): Promise<ModuleQueryResult<R>> {\n // Bind them\n const query = await this.bindQuery(queryPayload, payloads, account, this.additionalSigners)\n\n // Send them off\n return (await this.query(query[0], query[1])) as ModuleQueryResult<R>\n }\n\n protected async storeToArchivists(payloads: Payload[]): Promise<Payload[]> {\n try {\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 } catch (ex) {\n const error = ex as Error\n this.logger.error(`Error storing to archivists: ${error.message}`)\n return []\n }\n }\n}\n"],"mappings":";AAEA,SAAS,YAAAA,iBAAgB;AACzB,SAAS,MAAM,sBAAsB;AACrC,SAAS,aAAa,wBAAwB;AAC9C,SAAS,cAAc;AACvB,SAAS,cAAc;AAGvB;AAAA,EACE;AAAA,EAAe;AAAA,EACf;AAAA,OACK;AAEP,SAAS,iBAAiB;AAC1B,SAAS,WAAAC,gBAAe;AAGxB,SAAS,2BAA2B;AACpC,SAAS,qBAAqB,gCAAgC;AAE9D,SAAS,2BAA2B;AACpC,SAAS,4BAAAC,iCAAgC;AAEzC,SAAS,oBAAoB;AAE7B,SAAS,mBAAmB;AAuB5B;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,kBAAAC,uBAAsB;AAI/B,SAAS,mBAAmB;AAE5B,SAAS,aAAa;AACtB,SAAS,gBAAgB;;;ACvEzB,SAAS,gBAAgB;AACzB,SAAS,eAAe;AAiBxB,IAAM,sCAAsC,CAAC,WAAgF;AAC3H,WAAS,CAAE,OAA4C,aAAa,MAAM,0DAA0D;AACpI,SAAO,CAAC,CAAE,OAA6C;AACzD;AAEA,IAAM,qCAAqC,CAAC,WAA+E;AACzH,SAAO,CAAC,CAAE,OAA4C;AACxD;AAEA,eAAsB,iBAAiB,QAAgC,qBAAqB,MAAgC;AAC1H,MAAI,oCAAoC,MAAM,GAAG;AAC/C,QAAI,OAAO,YAAY,UAAU;AAC/B,eAAS,oBAAoB,MAAM,4BAA4B;AAC/D,aAAO,MAAM,QAAQ,OAAO;AAAA,IAC9B;AACA,WAAO,OAAO;AAAA,EAChB;AAEA,MAAI,mCAAmC,MAAM,GAAG;AAC9C,WAAO;AAAA,MACL,OAAO,cAAc,MAAM,OAAO,OAAO,WAAW,OAAO,WAAW,IAAI,OAAO;AAAA,MACjF,MAAM;AAAA,IACR;AAAA,EACF;AAGA,UAAQ,KAAK,0FAA0F;AACvG,SAAO,MAAM,QAAQ,OAAO;AAC9B;;;AC5CA,SAAS,sBAAsB;AAE/B,SAAS,yBAAyB;AAE3B,IAAM,qBAAN,cAAiC,eAA4B;AAAA,EAClE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,cAAc;AACZ,UAAM,EAAE,QAAQ,kBAAkB,CAAC;AAAA,EACrC;AAAA,EAES,QAAqB;AAC5B,SAAK,OAAO;AAAA,MACV,SAAS,KAAK;AAAA,MACd,SAAS,KAAK;AAAA,MACd,MAAM,KAAK;AAAA,MACX,OAAO,KAAK;AAAA,IACd,CAAC;AACD,WAAO,MAAM,MAAM;AAAA,EACrB;AAAA,EAEA,QAAQ,SAAqB;AAC3B,SAAK,WAAW;AAChB,WAAO;AAAA,EACT;AAAA,EAEA,QAAQ,SAAiB;AACvB,SAAK,WAAW;AAChB,WAAO;AAAA,EACT;AAAA,EAEA,KAAK,MAAc;AACjB,SAAK,QAAQ;AACb,WAAO;AAAA,EACT;AAAA,EAEA,MAAM,OAAa;AACjB,SAAK,SAAS;AACd,WAAO;AAAA,EACT;AACF;;;AC3CA,SAAS,gCAAgC;AAWzC,IAAM,YAAY;AAEX,IAAM,6BAAN,MAA0G;AAAA,EACrG,UAAwD,CAAC;AAAA,EACzD,aAA2D,CAAC;AAAA,EACnD;AAAA,EACA;AAAA,EACA;AAAA,EAEnB,YAAY,QAAkB;AAC5B,QAAI,QAAQ,UAAU,SAAS;AAC7B,iBAAW,CAAC,QAAQ,SAAS,KAAK,OAAO,QAAQ,OAAO,UAAU,OAAO,GAAG;AAC1E,aAAK,QAAQ,MAAM,IAAI,UAAU,IAAI,iBAAiB;AAAA,MACxD;AAAA,IACF;AACA,QAAI,QAAQ,UAAU,YAAY;AAChC,iBAAW,CAAC,QAAQ,SAAS,KAAK,OAAO,QAAQ,OAAO,UAAU,UAAU,GAAG;AAC7E,aAAK,WAAW,MAAM,IAAI,UAAU,IAAI,iBAAiB;AAAA,MAC3D;AAAA,IACF;AACA,SAAK,kBAAkB,OAAO,KAAK,KAAK,OAAO,EAAE,SAAS;AAC1D,SAAK,qBAAqB,OAAO,KAAK,KAAK,UAAU,EAAE,SAAS;AAChE,SAAK,WAAW,KAAK,mBAAmB,KAAK;AAAA,EAC/C;AAAA,EAEA,YAAuB,OAAO,OAAO,aAAa;AAChD,QAAI,CAAC,KAAK,SAAU,QAAO;AAC3B,UAAM,YAAY,MAAM;AACxB,QAAI,UAAU,WAAW,EAAG,QAAO;AACnC,UAAM,UAAU,yBAAyB,WAA0B,OAAO,QAAQ;AAClF,UAAM,UAAU,MAAM,QAAQ,SAAS,GAAG;AAC1C,WAAO,KAAK,aAAa,QAAQ,SAAS,KAAK,CAAC,KAAK,gBAAgB,QAAQ,SAAS;AAAA,EACxF;AAAA,EAEU,eAAe,CAAC,QAAgB,cAAkC;AAC1E,QAAI,CAAC,KAAK,gBAAiB,QAAO;AAElC,QAAI,UAAU,SAAS,GAAG;AACxB,YAAM,cAAc,kBAAkB,SAAS;AAC/C,YAAM,iBAAiB,KAAK,UAAU,MAAM,GAAG,SAAS,WAAW;AACnE,UAAI,eAAgB,QAAO;AAAA,IAC7B;AAEA,WAAO,UAAU,MAAM,aAAW,KAAK,UAAU,MAAM,GAAG,SAAS,OAAO,KAAK,KAAK;AAAA,EACtF;AAAA,EAEU,kBAAkB,CAAC,QAAgB,cAAiC;AAC5E,QAAI,CAAC,KAAK,mBAAoB,QAAO;AACrC,WAAO,UAAU,KAAK,aAAW,KAAK,aAAa,MAAM,GAAG,SAAS,OAAO,CAAC;AAAA,EAC/E;AACF;AAGA,IAAM,oBAAoB,CAAC,cAAwE;AACjG,SAAO,MAAM,QAAQ,SAAS,IAC1B,UAEG,SAAS,EACT,IAAI,aAAW,QAAQ,YAAY,CAAC,EACpC,KAAK,SAAS,IACjB,UAAU,YAAY;AAC5B;;;ACxEA,SAAS,4BAAAC,iCAAgC;AAMlC,IAAM,2BAA2B,OACtC,KACA,OACA,aACqB;AACrB,QAAM,UAAUA,0BAAyB,WAA0B,OAAO,QAAQ;AAClF,QAAM,UAAU,MAAM,QAAQ,SAAS,GAAG;AAC1C,SAAO,IAAI,QAAQ,SAAS,MAAM;AACpC;AAEO,IAAM,0BAAN,MAAwD;AAAA,EAC7D,YAA+B,KAAa;AAAb;AAAA,EAAc;AAAA,EAC7C,YAAuB,CAAC,OAAO,aAAa;AAC1C,WAAO,yBAAyB,KAAK,KAAK,OAAO,QAAQ;AAAA,EAC3D;AACF;;;AJwDA,IAAM,qBAAqB;AACpB,IAAe,iBAAf,MAAe,wBACZ,YAC+B;AAAA,EACvC,OAAgB,qBAA8B;AAAA,EAC9C,OAAgB,gBAA0B,CAAC,kBAAkB;AAAA,EAC7D,OAAgB,sBAA8B;AAAA;AAAA,EAE9C,OAAgB,gBAAwB,IAAI,cAAc,SAAS,IAAI;AAAA;AAAA,EAEvE,OAAO,iBAAiB;AAAA,EACxB,OAAgB,SAAiB,CAAC;AAAA,EAClC,OAAyB,aAAa,eAAe,kBAAkB,iBAAgB,KAAK;AAAA,EAE5F,OAAiB,wBAAwB,KAAK,IAAI,EAAE,SAAS;AAAA,EAEnD;AAAA;AAAA,EAGA,mBAAmB,IAAI,SAAwC,EAAE,KAAK,IAAI,KAAK,MAAO,KAAK,EAAE,CAAC;AAAA,EAE9F,yBAA4C;AAAA,EAE5C;AAAA,EAEA,gBAAiD;AAAA,EACjD,WAA4C;AAAA,EACnC;AAAA,EACA;AAAA,EAEX,aAAa;AAAA,EACb,UAA8B;AAAA,EAC9B,UAAwB;AAAA,EAEhC,YAAY,uBAA+B,QAAiB,SAA0B;AACpF,IAAAC,UAAS,gBAAe,0BAA0B,uBAAuB,MAAM,4CAA4C;AAE3H,UAAM,gBAAgB,EAAE,GAAG,OAAO;AAClC,UAAM,aAAa;AAEnB,SAAK,WAAW;AAEhB,SAAK,0BAA0B,IAAI,wBAAwB,IAAc,EAAE;AAC3E,SAAK,6BAA6B,IAAI,2BAA2B,eAAe,MAAM,EAAE;AAAA,EAC1F;AAAA,EAEA,IAAI,UAAU;AACZ,WAAOA,UAAS,KAAK,UAAU,MAAM,iBAAiB;AAAA,EACxD;AAAA,EAEA,IAAI,oBAAuC;AACzC,WAAO,KAAK,OAAO,qBAAqB,CAAC;AAAA,EAC3C;AAAA,EAEA,IAAI,UAAU;AACZ,WAAO,KAAK,UAAU;AAAA,EACxB;AAAA,EAEA,IAAI,iBAAiB;AACnB,WAAO,CAAC,CAAC,KAAK,OAAO,UAAU;AAAA,EACjC;AAAA,EAEA,IAAI,sBAAsB;AACxB,WAAO,KAAK,OAAO,uBAAuB;AAAA,EAC5C;AAAA,EAEA,IAAI,YAA4D;AAC9D,WAAO,KAAK,OAAO;AAAA,EACrB;AAAA,EAEA,IAAI,YAAY;AACd,WAAO,KAAK,OAAO;AAAA,EACrB;AAAA,EAEA,IAAI,SAA4B;AAC9B,WAAO,KAAK,OAAO;AAAA,EACrB;AAAA,EAEA,IAAI,OAAO;AACT,WAAO,KAAK,WAAW;AAAA,EACzB;AAAA,EAEA,IAAI,+BAAwC;AAC1C,WAAO,CAAC,CAAC,KAAK,OAAO;AAAA,EACvB;AAAA,EAEA,IAAI,wBAAwB;AAC1B,SAAK,yBAAyB,KAAK,0BAA0B,KAAK,YAAY,UAAU,WAAW,IAAI,MAAM,IAAI;AACjH,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAI,KAAK;AACP,WAAO,KAAK,WAAW,KAAK;AAAA,EAC9B;AAAA,EAEA,IAAa,SAAS;AACpB,UAAM,WAAW,KAAK,OAAO;AAC7B,SAAK,UACA,KAAK,WAAW,WAAY,IAAI,cAAc,QAAQ,IAAK,KAAK,QAAQ,UAAU,gBAAe,iBAAiB,KAAK;AAC5H,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAI,UAAU;AACZ,WAAO,KAAK,OAAO;AAAA,EACrB;AAAA,EAEA,IAAI,WAAW;AACb,WAAO,uBAAuB;AAAA,EAChC;AAAA,EAEA,IAAI,UAAoB;AACtB,WAAO,CAAC,0BAA0B,4BAA4B,2BAA2B,sBAAsB;AAAA,EACjH;AAAA,EAEA,IAAI,aAAa;AACf,WAAO,KAAK,OAAO;AAAA,EACrB;AAAA,EAEA,IAAI,SAAS;AACX,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAI,YAAY;AACd,WAAO,KAAK,OAAO,aAAa;AAAA,EAClC;AAAA,EAEA,IAAc,OAAO,OAAqB;AACxC,QAAI,KAAK,YAAY,QAAQ;AAC3B,WAAK,UAAU;AAAA,IACjB;AAAA,EACF;AAAA,EAMA,OAAO,iBAAiB,UAAkB;AAExC,QAAI,UAAU;AACd,WAAO,QAAQ,UAAU,QAAQ,GAAG;AAClC,gBAAU,QAAQ;AAAA,IACpB;AACA,WAAO,QAAQ,QAAQ;AAAA,EACzB;AAAA,EAEA,OAAO,YAAY,cAAsB;AAEvC,UAAM,WAAY,KAAa,YAAY;AAE3C,UAAM,WAAW,KAAK,iBAAiB,YAAY;AACnD,IAAAA,UAAS,aAAa,UAAU,MAAM,6BAA6B,YAAY,gBAAgB,YAAY,iBAAiB;AAAA,EAC9H;AAAA,EAEA,aAAa,OAEX,QACA;AACA,SAAK,YAAY,QAAQ;AACzB,QAAI,CAAC,KAAK,iBAAiB,KAAK,cAAc,WAAW,GAAG;AAC1D,YAAM,IAAI,MAAM,yBAAyB,QAAQ,QAAQ,MAAM,KAAK,KAAK,IAAI,GAAG;AAAA,IAClF;AAEA,QAAI,CAAC,KAAK,qBAAqB;AAC7B,YAAM,IAAI,MAAM,gCAAgC,QAAQ,QAAQ,MAAM,KAAK,KAAK,IAAI,GAAG;AAAA,IACzF;AAEA,IAAAA,UAAS,QAAQ,QAAQ,SAAS,UAAa,aAAa,OAAO,OAAO,IAAI,GAAG,MAAM,wBAAwB,QAAQ,QAAQ,IAAI,EAAE;AAErI,UAAM,EAAE,QAAQ,IAAI,UAAU,CAAC;AAE/B,UAAM,SAAiB,QAAQ,QAAQ,UAAU,KAAK;AACtD,UAAM,iBAA2B,KAAK;AAEtC,IAAAA,UAAS,eAAe,SAAS,MAAM,GAAG,MAAM,+BAA+B,MAAM,eAAe,KAAK,UAAU,cAAc,CAAC,GAAG;AACrI,UAAM,gBAA6C,EAAE,GAAG,QAAQ,QAAQ,OAAO;AAC/E,YAAQ,QAAQ,MAAM,WAAW,KAAK,UAAU,eAAe,MAAM,CAAC,CAAC,EAAE;AACzE,UAAM,gBAAmC,EAAE,GAAG,QAAQ,QAAQ,cAAc;AAE5E,UAAM,eAAe,QAAQ,UAAU,gBAAe;AACtD,UAAM,mBAAmB,MAAM,gBAAe,iBAAiB,EAAE,QAAQ,CAAC;AAC1E,UAAM,UAAU,iBAAiB;AACjC,kBAAc,SAAS,eAAe,IAAI,SAAS,cAAc,MAAM,KAAK,OAAO,EAAE,IAAI;AAEzF,UAAM,YAAY,IAAI,KAAK,gBAAe,uBAAuB,eAAe,kBAAkB,OAAO;AAEzG,QAAI,CAAC,gBAAe,gBAAgB;AAClC,YAAM,UAAU,QAAQ;AAAA,IAC1B;AACA,WAAO;AAAA,EACT;AAAA,EAEA,aAAa,iBAAiB,QAID;AAC3B,WAAO,MAAM,iBAAiB,QAAQ,KAAK,kBAAkB;AAAA,EAC/D;AAAA,EAEA,OAAO,QAEL,QACiC;AACjC,WAAO,cAAc,WAAW,MAAM,MAAM;AAAA,EAC9C;AAAA;AAAA,EAGA,iBAAiB,UAAkB;AAEjC,QAAI,UAAU;AACd,WAAO,QAAQ,UAAU,QAAQ,GAAG;AAClC,gBAAU,QAAQ;AAAA,IACpB;AACA,WAAO,QAAQ,QAAQ;AAAA,EACzB;AAAA,EAEA,MAAM,KAAQ,SAA2B;AACvC,QAAI,KAAK,cAAc,GAAG;AACxB,WAAK,aAAa;AAClB,YAAM,OAA4B,EAAE,MAAM,MAAM,KAAK,KAAK;AAC1D,YAAM,KAAK,KAAK,cAAc,IAAI;AAAA,IACpC;AACA,SAAK;AACL,QAAI;AACF,aAAO,MAAM,QAAQ;AAAA,IACvB,UAAE;AACA,WAAK;AACL,UAAI,KAAK,cAAc,GAAG;AACxB,aAAK,aAAa;AAClB,cAAM,OAA4B,EAAE,MAAM,OAAO,KAAK,KAAK;AAC3D,cAAM,KAAK,KAAK,cAAc,IAAI;AAAA,MACpC;AAAA,IACF;AAAA,EACF;AAAA,EAES,KACP,WACA,WACA;AACA,WAAO,MAAM,KAAK,WAAW,SAAS;AAAA,EACxC;AAAA,EAEA,eAA+C;AAC7C,SAAK,WAAW;AAChB,WAAO,KAAK,QAAQ;AAAA,EACtB;AAAA,EAEA,MAAM,MACJ,OACA,UACA,aAC4B;AAC5B,SAAK,WAAW;AAChB,SAAK,YAAY,OAAO;AACxB,UAAM,cAAcA,UAAS,oBAAoB,KAAK,IAAI,QAAQ,QAAW,MAAM,uBAAuB;AAC1G,WAAO,MAAM,KAAK,KAAK,YAAY;AACjC,YAAM,iBAA4B,CAAC;AACnC,YAAM,gBAA+B,CAAC;AACtC,YAAM,eAAe,KAAK,+BAA+B,MAAMC,SAAQ,OAAO,IAAI;AAElF,UAAI;AACF,cAAM,KAAK,QAAQ,OAAO;AAC1B,YAAI,CAAC,KAAK,kBAAkB,MAAM,UAAU,WAAW,GAAG;AACxD,gBAAM,IAAI,MAAM,sDAAsD,KAAK,OAAO,OAAO,KAAK,OAAO,GAAG;AAAA,QAC1G;AACA,YAAI,aAAa,gBAAgB;AAC/B,UAAAD,UAAS,aAAa,eAAe,SAAS,YAAY,MAAM,GAAG,MAAM,sBAAsB,YAAY,MAAM,GAAG;AAAA,QACtH;AACA,uBAAe,KAAK,GAAI,MAAM,KAAK,aAAa,aAAa,UAAU,WAAW,CAAE;AAAA,MACtF,SAAS,IAAI;AACX,cAAM,iBAAiB,IAAI,OAAO,QAAQ;AACxC,gBAAM,QAAQ;AACd,eAAK,aAAa;AAElB,wBAAc;AAAA,YACZ,IAAI,mBAAmB,EACpB,KAAK,EAAE,UAAU,CAAC,MAAME,gBAAe,SAAS,WAAW,CAAC,EAAE,CAAC,EAC/D,KAAK,KAAK,WAAW,WAAW,EAChC,MAAM,YAAY,MAAM,EACxB,QAAQ,MAAM,OAAO,EACrB,QAAQ,MAAM,OAAO,EACrB,MAAM;AAAA,UACX;AAAA,QACF,CAAC;AAAA,MACH;AACA,UAAI,KAAK,WAAW;AAClB,cAAM,YAAY,EAAE,QAAQ,yBAAyB,WAAW,KAAK,IAAI,EAAE;AAC3E,uBAAe,KAAK,SAAS;AAAA,MAC/B;AACA,YAAM,SAAS,MAAM,KAAK,gBAAgB,aAAa,gBAAgB,eAAe,CAAC,YAAY,IAAI,CAAC,GAAG,aAAa;AACxH,YAAM,OAA+B;AAAA,QACnC,KAAK;AAAA,QAAM;AAAA,QAAU,OAAO;AAAA,QAAa;AAAA,MAC3C;AACA,YAAM,KAAK,KAAK,iBAAiB,IAAI;AACrC,aAAO;AAAA,IACT,CAAC;AAAA,EACH;AAAA,EAEA,MAAM,UACJ,OACA,UACA,aACkB;AAClB,QAAI,KAAK,MAAM;AACb,aAAO;AAAA,IACT;AACA,QAAI,CAAE,MAAM,KAAK,QAAQ,MAAM,EAAI,QAAO;AAC1C,UAAM,kBACF,cAAc,IAAI,2BAA2B,OAAO,OAAO,CAAC,GAAG,KAAK,QAAQ,WAAW,CAAC,EAAE,YAAY,KAAK;AAC/G,UAAM,aAAa,CAAC,KAAK,yBAAyB,eAAe;AAEjE,UAAM,UAAU,MAAM,QAAQ,IAAI,WAAW,IAAI,eAAa,UAAU,OAAO,QAAQ,CAAC,CAAC;AACzF,eAAW,UAAU,SAAS;AAC5B,UAAI,CAAC,QAAQ;AACX,eAAO;AAAA,MACT;AAAA,IACF;AACA,WAAO;AAAA,EACT;AAAA,EAEA,MAAM,UAAwC;AAE5C,SAAK,gBAAgB,KAAK,iBAAiB,KAAK,aAAa;AAC7D,UAAM,SAAS,KAAK;AACpB,SAAK,SAAS,SAAS,YAAY;AACnC,WAAO;AAAA,EACT;AAAA,EAEA,MAAM,QAAQ,mBAAgE,OAAO,WAAW,MAAwB;AACtH,UAAM,UAAU,MAAM,KAAK;AAC3B,QAAI,YAAY,MAAM;AACpB,aAAO;AAAA,IACT;AACA,QAAI,CAAC,SAAS;AAEZ,WAAK,YAAY,YAAY;AAC3B,YAAI,UAAU;AACZ,cAAI;AACF,kBAAM,KAAK,MAAM;AACjB,mBAAO;AAAA,UACT,SAAS,IAAI;AACX,wBAAY,IAAI,CAAC,UAAU;AACzB,mBAAK,QAAQ,KAAK,+BAA+B,MAAM,OAAO,GAAG;AACjE,mBAAK,WAAW;AAAA,YAClB,CAAC;AAAA,UACH;AAAA,QACF;AACA,gBAAQ,kBAAkB;AAAA,UACxB,KAAK,SAAS;AACZ,kBAAM,IAAI,MAAM,GAAG,kBAAkB,KAAK,KAAK,OAAO,GAAG;AAAA,UAC3D;AAAA,UACA,KAAK,QAAQ;AACX,iBAAK,QAAQ,KAAK,kBAAkB;AACpC;AAAA,UACF;AAAA,UACA,KAAK,SAAS;AACZ,iBAAK,QAAQ,MAAM,kBAAkB;AACrC;AAAA,UACF;AAAA,UACA,KAAK,QAAQ;AACX;AAAA,UACF;AAAA,UACA,SAAS;AACP,iBAAK,QAAQ,IAAI,kBAAkB;AACnC;AAAA,UACF;AAAA,QACF;AACA,eAAO;AAAA,MACT,GAAG;AAAA,IACL;AACA,QAAI,CAAC,KAAK,UAAU;AAClB,YAAM;AAAA,IACR;AACA,WAAO,MAAM,KAAK;AAAA,EACpB;AAAA,EAEA,MAAM,KAAK,UAAqC;AAC9C,WAAO,MAAM,KAAK,KAAK,YAAY;AACjC,YAAM,SAAS,MAAM,KAAK,YAAY;AACtC,WAAK,WAAW;AAChB,WAAK,gBAAgB;AACrB,WAAK,SAAS,SAAS,YAAY;AACnC,aAAO;AAAA,IACT,CAAC;AAAA,EACH;AAAA,EAEU,aAAa;AACrB,QAAI,KAAK,MAAM;AACb,YAAM,IAAI,gBAAgB,KAAK,IAAI,KAAK,UAAU;AAAA,IACpD;AAAA,EACF;AAAA;AAAA,EAGU,YAAY,cAAsB;AAE1C,UAAM,WAAY,KAAa,YAAY;AAE3C,UAAM,WAAW,KAAK,iBAAiB,YAAY;AACnD,IAAAF,UAAS,aAAa,UAAU,MAAM,6BAA6B,YAAY,gBAAgB,YAAY,iBAAiB;AAAA,EAC9H;AAAA,EAIA,MAAgB,kBAAkB,WAAW,OAA+C;AAC1F,UAAM,YAAY,KAAK;AACvB,QAAI,CAAC,WAAW;AACd,UAAI,UAAU;AACZ,cAAM,IAAI,MAAM,wBAAwB;AAAA,MAC1C;AACA,aAAO;AAAA,IACT;AACA,UAAM,WAAY,MAAM,KAAK,WAAW,QAAQ,SAAS,KAAO,MAAM,KAAK,aAAa,QAAQ,SAAS;AACzG,QAAI,UAAU;AACZ,MAAAA,UAAS,UAAU,MAAM,gCAAgC,SAAS,GAAG;AAAA,IACvE;AACA,WAAO,WAAW,oBAAoB,UAAU,MAAM,4CAA4C,SAAS,GAAG,IAAI;AAAA,EACpH;AAAA,EAEU,WAAW,QAAgB,QAAkB,SAA2B;AAEhF,WAAO,IAAI,UAAU,CAAC,YAAY;AAChC,YAAM,SAAS,KAAK,mBAAmB,QAAQ,QAAQ,OAAO;AAC9D,gBAAU,MAAM;AAChB,aAAO;AAAA,IACT,GAAG,OAAO;AAAA,EACZ;AAAA,EAEA,MAAgB,mBAAmB,QAAgB,QAAkB,UAA2B,KAAK,SAAgC;AACnI,UAAM,UAAU,IAAI,oBAAoB,EAAE,OAAO,QAAQ,MAAM,EAAE,OAAO,OAAO;AAC/E,UAAM,UAAwB,MAAM,QAAQ,MAAM,GAAG,CAAC;AACtD,SAAK,QAAQ,MAAM,WAAW,KAAK,UAAU,QAAQ,MAAM,CAAC,CAAC,EAAE;AAC/D,WAAO;AAAA,EACT;AAAA,EAEU,UACR,OACA,UACA,SACA,mBACuE;AAEvE,WAAO,IAAI,UAAsE,OAAO,YAAY;AAClG,YAAM,SAAS,MAAM,KAAK,kBAAkB,OAAO,UAAU,SAAS,iBAAiB;AACvF,gBAAU,MAAM;AAChB,aAAO;AAAA,IACT,GAAG,OAAO;AAAA,EACZ;AAAA,EAEA,MAAgB,kBACd,OACA,UACA,UAA2B,KAAK,SAChC,oBAAuC,CAAC,GACY;AACpD,UAAM,WAAW,CAAC,SAAS,GAAG,iBAAiB,EAAE,OAAO,MAAM;AAC9D,UAAM,UAAU,IAAI,yBAAyB,EAAE,SAAS,QAAQ,EAAE,QAAQ,QAAQ,EAAE,MAAM,KAAK;AAE/F,UAAM,CAAC,IAAI,aAAa,MAAM,IAAI,MAAM,QAAQ,MAAM;AACtD,WAAO,CAAC,IAAI,CAAC,GAAG,WAAW,GAAG,MAAM;AAAA,EACtC;AAAA,EAEA,MAAgB,gBACd,OACA,UACA,sBAAyC,CAAC,GAC1C,QAC4B;AAC5B,UAAM,gBAAgB,MAAME,gBAAe,SAAS,KAAK;AACzD,UAAM,UAAU,IAAI,oBAAoB,EAAE,SAAS,QAAQ,EAAE,OAAO,MAAM,EAAE,YAAY,aAAa;AACrG,UAAM,YAAY,CAAC,KAAK,SAAS,GAAG,mBAAmB,EAAE,OAAO,MAAM;AACtE,YAAQ,QAAQ,SAAS;AACzB,UAAM,SAA4B;AAAA,MAChCA,gBAAe,wBAAwB,MAAM,QAAQ,MAAM,GAAG,CAAC,CAAC;AAAA,MAChEA,gBAAe,uBAAuB,QAAQ;AAAA,MAC9CA,gBAAe,uBAAuB,UAAU,CAAC,CAAC;AAAA,IACpD;AACA,QAAI,KAAK,aAAa,KAAK,wBAAwB,MAAM,MAAM,GAAG;AAChE,aAAO,KAAK,kBAAkB,OAAO,KAAK,CAAC,CAAC;AAAA,IAC9C;AACA,WAAO;AAAA,EACT;AAAA,EAEU,yBAAyB,WAA2C;AAC5E,UAAM,SAAS,KAAK;AACpB,UAAM,UAA0B,EAAE,QAAQ,eAAe,SAAS,KAAK,QAAQ;AAC/E,UAAM,UAAU,KAAK,QAAQ,IAAI,CAAC,UAAU;AAC1C,aAAO,EAAE,QAAQ,aAAa,MAAM;AAAA,IACtC,CAAC;AACD,UAAM,eAA8B;AAAA,MAClC,QAAQ,OAAO;AAAA,MACf,QAAQ;AAAA,IACV;AACA,WAAQ,CAAC,QAAQ,cAAc,SAAS,GAAG,OAAO,EAAG,OAAO,MAAM;AAAA,EACpE;AAAA,EAEA,MAAgB,mBAAsD;AACpE,UAAM,cAAwC;AAAA,MAC5C,SAAS,KAAK;AAAA,MACd,SAAS,KAAK;AAAA,MACd,QAAQ;AAAA,IACV;AACA,QAAI,KAAK,QAAQ,MAAM;AACrB,kBAAY,OAAO,KAAK;AAAA,IAC1B;AAEA,UAAM,WAAW,MAAM,KAAK,yBAAyB;AAErD,gBAAY,YACV,UAAU,IAAI,CAAC,YAAY;AACzB,YAAM,UAAU,QAAQ,WAAW,gBAAiB,QAA2B,UAAU;AACzF,aAAO,WAAW,KAAK,UAAU,SAAY;AAAA,IAC/C,CAAC,KAAK,CAAC,GACP,OAAO,MAAM;AAEf,WAAO;AAAA,EACT;AAAA;AAAA,EAGA,MAAgB,eAAuD;AACrE,WAAO,MAAM,KAAK,kBAAkB;AAAA,EACtC;AAAA,EAEU,wBAAwB,QAAyB;AACzD,UAAM,UAAU,KAAK,WAAW;AAChC,QAAI,SAAS;AACX,aAAO,QAAQ,SAAS,MAAM;AAAA,IAChC;AACA,WAAO;AAAA,EACT;AAAA,EAEU,gBAAgB,YAAoB,GAAG,mBAA8B,CAAC,GAAsC;AACpH,UAAM,IAAI,MAAM,eAAe;AAAA,EACjC;AAAA,EAEU,uBAAoF;AAC5F,UAAM,UAAU,KAAK;AACrB,UAAM,OAAO,KAAK;AAClB,UAAM,eAAe,KAAK;AAC1B,UAAM,gBAAgB,OAClB;AAAA,MACE;AAAA,MAAS;AAAA,MAAM,QAAQ;AAAA,IACzB,IACA,EAAE,SAAS,QAAQ,cAAc;AACrC,UAAM,4BAA4B,eAC9B;AAAA,MACE;AAAA,MAAS;AAAA,MAAc,QAAQ;AAAA,IACjC,IACA,EAAE,SAAS,QAAQ,cAAc;AACrC,WAAO,CAAC,eAAe,yBAAyB;AAAA,EAClD;AAAA,EAEA,MAAgB,aACd,OACA,UACA,aACmC;AACnC,UAAM,KAAK,QAAQ,OAAO;AAC1B,UAAM,UAAUC,0BAAyB,WAA0B,OAAO,QAAQ;AAClF,UAAM,eAAe,MAAM,QAAQ,SAAS;AAC5C,IAAAH,UAAS,MAAM,KAAK,UAAU,OAAO,UAAU,WAAW,CAAC;AAC3D,UAAM,iBAA4B,CAAC;AACnC,YAAQ,aAAa,QAAQ;AAAA,MAC3B,KAAK,2BAA2B;AAC9B,uBAAe,KAAK,MAAM,KAAK,gBAAgB,aAAa,QAAQ,CAAC;AACrE;AAAA,MACF;AAAA,MACA,KAAK,0BAA0B;AAC7B,uBAAe,KAAK,GAAI,MAAM,KAAK,qBAAqB,CAAE;AAC1D;AAAA,MACF;AAAA,MACA,KAAK,wBAAwB;AAC3B,uBAAe,KAAK,GAAI,MAAM,KAAK,aAAa,CAAE;AAClD;AAAA,MACF;AAAA,MACA,KAAK,4BAA4B;AAC/B,aAAK,iBAAiB;AACtB;AAAA,MACF;AAAA,MACA,SAAS;AACP,cAAM,IAAI,MAAM,sBAAuB,aAAyB,MAAM,GAAG;AAAA,MAC3E;AAAA,IACF;AACA,WAAOE,gBAAe,uBAAuB,cAAc;AAAA,EAC7D;AAAA,EAEA,MAAgB,eAAiC;AAC/C,SAAK,eAAe;AACpB,UAAM,QAAQ,QAAQ;AACtB,SAAK,WAAW;AAChB,WAAO;AAAA,EACT;AAAA,EAEA,MAAgB,eAAmC;AACjD,WAAO,CAAC,MAAM,KAAK,gBAAgB,GAAG,GAAI,MAAM,KAAK,yBAAyB,GAAI,MAAM,KAAK,iBAAiB,CAAC;AAAA,EACjH;AAAA,EAEU,YAAY,UAAwC;AAC5D,SAAK,WAAW;AAChB,WAAO;AAAA,EACT;AAAA,EAEU,mBAAmB;AAC3B;AAAA,EACF;AAAA,EAEU,eAAe,QAAkB,UAAoB,CAAC,GAAY;AAE1E,WAAO,OAAO,QAAQ,UAAU,KAAK,UAAU,CAAC,CAAC,EAAE,OAAO,CAAC,OAAO,CAAC,KAAK,KAAK,MAAM;AACjF,cAAQ,OAAO,OAAO;AAAA,QACpB,KAAK,YAAY;AACf,eAAK,QAAQ,KAAK,kDAAkD,SAAS,KAAK,GAAG,CAAC,IAAI,GAAG,GAAG;AAChG,iBAAO;AAAA,QACT;AAAA,QACA,KAAK,UAAU;AACb,cAAI,MAAM,QAAQ,KAAK,GAAG;AACxB;AAAA;AAAA,cAEE,MAAM,OAAO,CAACE,QAAOC,WAAU;AAC7B,uBAAO,KAAK,eAAeA,QAAO,CAAC,GAAG,SAAS,GAAG,CAAC,KAAKD;AAAA,cAC1D,GAAG,IAAI,KAAK;AAAA;AAAA,UAEhB;AAEA,cAAI,CAAC,eAAe,KAAK,GAAG;AAC1B,iBAAK,QAAQ,KAAK,uEAAuE,SAAS,KAAK,GAAG,CAAC,IAAI,GAAG,GAAG;AACrH,mBAAO;AAAA,UACT;AACA,iBAAO,QAAQ,KAAK,eAAe,OAAO,CAAC,GAAG,SAAS,GAAG,CAAC,KAAK,QAAQ;AAAA,QAC1E;AAAA,QACA,SAAS;AACP,iBAAO;AAAA,QACT;AAAA,MACF;AAAA,IACF,GAAG,IAAI;AAAA,EACT;AAIF;;;AK5sBA,SAAS,YAAAE,iBAAgB;AACzB,SAAS,kBAAAC,uBAAsB;AAC/B,SAAS,UAAAC,eAAc;AAOvB,SAAS,uBAAAC,4BAA2B;AAEpC,SAAS,mCAAmC;AAkB5C;AAAA,EACE;AAAA,EACA,6BAAAC;AAAA,EACA,0BAAAC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,+BAA+B;AAExC,SAAS,sBAAsB;AAO/B,SAAS,eAAqC,KAAyC,cAA6B;AAClH,MAAI,MAAM,QAAQ,GAAG,GAAG;AACtB,QAAI,cAAc;AAChB,aAAO,IAAI,IAAI,OAAK,aAAa,CAAC,CAAC,EAAE,OAAOC,OAAM;AAAA,IACpD;AACA,WAAO;AAAA,EACT;AACA,UAAQ,MAAO,eAAe,aAAa,GAAG,IAAI,OAAQ,SAAS,MAAM;AAC3E;AAEO,IAAe,yBAAf,MAAe,gCACZ,eACqE;AAAA,EAC7E,OAAyB,aAAaC,gBAAe,0BAA0B,yBAAwB,KAAK;AAAA;AAAA,EAG5G,OAAgB,iBAAiB;AAAA,EAEzB;AAAA,EACA,WAA2B,CAAC;AAAA,EAC5B;AAAA,EACA;AAAA,EAER,YAAY,uBAA+B,QAAiB,SAA0B;AACpF,IAAAC,UAAS,eAAe,0BAA0B,uBAAuB,MAAM,4CAA4C;AAE3H,UAAM,gBAAgB,EAAE,GAAG,OAAO;AAClC,UAAM,iBAAiB,cAAc,kBAAkB;AACvD,UAAM,uBAAuB,eAAe,OAAO;AACnD,QAAI,gBAAgB;AAClB,WAAK,WAAW,IAAI,IAAI;AACxB,WAAK,aAAa,IAAI,IAAI;AAAA,IAC5B;AAAA,EACF;AAAA,EAEA,IAAI,eAAe;AACjB,SAAK,gBACD,KAAK,iBACF,IAAI,wBAAwB;AAAA,MAC7B,qBAAqB,KAAK;AAAA,MAC1B,8BAA8B,KAAK,OAAO;AAAA,MAC1C,MAAM;AAAA,IACR,CAAC;AACL,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAa,UAAU;AACrB,WAAO,MAAM;AAAA,EACf;AAAA,EAEA,IAAI,+BAA+B;AACjC,WAAO,KAAK,OAAO,gCAAgC,cAAc;AAAA,EACnE;AAAA,EAEA,IAAI,kBAAkB;AACpB,SAAK,mBACD,KAAK,oBACF,IAAI,wBAAwB;AAAA,MAC7B,qBAAqB,KAAK;AAAA,MAC1B,8BAA8B,KAAK,OAAO;AAAA,MAC1C,MAAM;AAAA,IACR,CAAC;AACL,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,IAAI,OAAO;AACT,WAAO;AAAA,EACT;AAAA,EAEA,IAAI,aAAa;AACf,SAAK,cACD,KAAK,eACF,IAAI,wBAAwB;AAAA,MAC7B,qBAAqB,KAAK;AAAA,MAC1B,8BAA8B,KAAK,OAAO;AAAA,MAC1C,MAAM;AAAA,IACR,CAAC;AACL,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,UAAU,KAAqB;AAC7B,UAAM,gBAAgB,KAAK,SAAS,KAAK,YAAU,OAAO,YAAY,IAAI,OAAO;AACjF,QAAI,CAAC,eAAe;AAClB,WAAK,SAAS,KAAK,eAAe,KAAK,mCAAmC,CAAC;AAAA,IAC7E;AAAA,EACF;AAAA,EAEA,MAAM,iBAAqC;AACzC,UAAM,UAAU,MAAM,KAAK,QAAQ;AACnC,YACE,MAAM,QAAQ;AAAA,MACZ,QAAQ,IAAI,OAAO,WAAW;AAC5B,cAAM,CAAC,IAAI,UAAU,MAAM,IAAI,MAAM,OAAO,aAAa,KAAK,OAAO;AACrE,eAAO,OAAO,WAAW,IAAI,CAAC,IAAI,GAAG,QAAQ,IAAI,CAAC;AAAA,MACpD,CAAC;AAAA,IACH,GACA,KAAK;AAAA,EACT;AAAA,EAEA,SAAS,UAAmD;AAC1D,SAAK,WAAW;AAChB,WAAO,KAAK,KAAK,YAAY;AAC3B,aAAO,MAAM,KAAK,gBAAgB,QAAQ;AAAA,IAC5C,CAAC;AAAA,EACH;AAAA,EAEA,MAAM,cAAc,SAA0B,UAAsE;AAClH,UAAM,eAAoC,EAAE,QAAQC,4BAA2B,GAAI,aAAa,SAAY,CAAC,IAAI,EAAE,SAAS,EAAG;AAC/H,WAAO,MAAM,KAAK,aAAkE,cAAc,QAAW,OAAO;AAAA,EACtH;AAAA,EAEA,gBAA0E;AACxE,SAAK,WAAW;AAChB,WAAO,KAAK,KAAK,YAAY;AAC3B,aAAO,MAAM,KAAK,qBAAqB;AAAA,IACzC,CAAC;AAAA,EACH;AAAA,EAEA,UAAsC;AACpC,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,kBAAgD;AAC9C,WAAO,CAAC,GAAG,KAAK,OAAO,mBAAmB,CAAC,CAAC;AAAA,EAC9C;AAAA,EAEA,iBAA+C;AAC7C,WAAO,CAAC,GAAG,KAAK,OAAO,kBAAkB,CAAC,CAAC;AAAA,EAC7C;AAAA,EAEA,aAAa,SAAkB;AAC7B,SAAK,WAAW,KAAK,SAAS,OAAO,UAAQ,KAAK,YAAY,OAAO;AAAA,EACvE;AAAA,EAKA,MAAM,QACJ,KAAuB,KACvB,UAAkC,CAAC,GACL;AAC9B,QAAI,wBAAuB,gBAAgB;AACzC,UAAI,OAAO,KAAK;AACd,cAAM,EAAE,WAAW,IAAI,UAAU,IAAI;AACrC,YAAI,cAAc,QAAQ;AACxB,iBAAO,eAAmB,MAAM,eAAe,MAAM,QAAQ,KAAM,CAAC,GAAG,QAAQ,QAAQ;AAAA,QACzF;AACA,YAAI,cAAc,MAAM;AACtB,iBAAO,eAAkB,MAAM,aAAa,MAAM,QAAQ,KAAK,CAAC,GAAG,QAAQ,QAAQ;AAAA,QACrF;AACA,eAAO,eAAkB,MAAM,WAAW,MAAM,QAAQ,KAAK,CAAC,GAAG,QAAQ,QAAQ;AAAA,MACnF,WAAW,OAAO,OAAO,UAAU;AACjC,eAAO,eAAkB,MAAM,sBAAsB,MAAM,IAAI,IAAI,GAAG,QAAQ,QAAQ;AAAA,MACxF,OAAO;AACL,cAAM,IAAI,UAAU,iBAAiB;AAAA,MACvC;AAAA,IACF,OAAO;AACL,YAAM,SAA8B;AAAA,QAClC,SAAS,KAAK;AAAA,QACd,MAAM,KAAK;AAAA,QACX,cAAc,KAAK;AAAA,QACnB,QAAQ,KAAK;AAAA,QACb,KAAK;AAAA,QACL,cAAc,KAAK;AAAA,QACnB,YAAY,KAAK;AAAA,MACnB;AACA,UAAI,OAAO,KAAK;AACd,eAAO,eAAkB,MAAM,cAAc,QAAQ,QAAQ,IAAI,OAAO,KAAK,CAAC,GAAG,QAAQ,QAAQ;AAAA,MACnG;AACA,aAAO,eAAkB,MAAM,cAAc,QAAQ,QAAQ,IAAI,OAAO,GAAG,QAAQ,QAAQ;AAAA,IAC7F;AAAA,EACF;AAAA,EAEA,kBAAkB,IAAsB,SAA6D;AACnG,UAAM,EAAE,YAAY,MAAM,IAAI,WAAW,CAAC;AAC1C,YAAQ,WAAW;AAAA,MACjB,KAAK,QAAQ;AACX,eAAO,KAAK,aAAa,kBAAkB,IAAI,OAAO;AAAA,MACxD;AAAA,MACA,SAAS;AACP,cAAM,iBAAiB,EAAE,GAAG,SAAS,WAAW,MAAM;AACtD,eAAO,KAAK,WAAW,kBAAkB,IAAI,cAAc;AAAA,MAC7D;AAAA,IACF;AAAA,EACF;AAAA,EAIA,MAAM,eACJ,KAAuB,KACvB,UAAkC,CAAC,GACL;AAC9B,WACG,MAAM,KAAK,gBAAgB,QAAQ,IAAI,OAAO,KAC3C,MAAM,KAAK,WAAW,QAAQ,IAAI,OAAO,KACzC,MAAM,KAAK,aAAa,QAAQ,IAAI,OAAO;AAAA,EAEnD;AAAA,EAEA,MAAM,WAAsC;AAC1C,YAAQ,MAAM,QAAQ,KAAK,MAAM,KAAK,QAAQ,GAAG,IAAI,YAAU,OAAO,eAAe,CAAC,CAAC,GAAG,KAAK,EAAE,OAAO,gBAAgB;AAAA,EAC1H;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,QAAQ;AACN,SAAK,WAAW;AAChB,WAAO,KAAK,KAAK,YAAY;AAC3B,aAAO,MAAM,KAAK,aAAa;AAAA,IACjC,CAAC;AAAA,EACH;AAAA,EAEA,MAAM,WAAW,SAAsD;AACrE,UAAM,eAAiC,EAAE,QAAQC,wBAAuB;AACxE,WAAO,MAAM,KAAK,aAAa,cAAc,QAAW,OAAO;AAAA,EACjE;AAAA,EAEA,UAAU,eAAiC;AACzC,SAAK,WAAW;AAChB,WAAO,KAAK,iBAAiB;AAAA,EAC/B;AAAA,EAEA,MAAyB,gBAAgB,WAAmB,GAAG,mBAA8B,CAAC,GAAmC;AAC/H,UAAM,eAAe,KAAK,iBAAiB,IAAI,QAAQ;AACvD,QAAI,cAAc;AAChB,aAAO;AAAA,IACT;AACA,UAAM,UAAU,KAAK,WAAW;AAChC,UAAM,WAAW,MAAM,KAAK,eAAe;AAC3C,UAAM,qBAAyD,CAAC;AAChE,eAAW,SAAS,UAAU;AAC5B,UAAI,MAAM,YAAY,KAAK,SAAS;AAClC,2BAAmB,MAAM,OAAO,IAAI,MAAM,WAAW;AAAA,MACvD;AAAA,IACF;AACA,UAAM,SAAS;AAAA,MACb,QAAQ,EAAE,MAAM,SAAS,GAAG,KAAK,OAAO;AAAA,MACxC,QAAQ;AAAA,MACR,QAAQ,EAAE,SAAS,KAAK,SAAS,UAAU,mBAAmB;AAAA,IAChE;AACA,SAAK,iBAAiB,IAAI,UAAU,MAAM;AAC1C,WAAO;AAAA,EACT;AAAA,EAEA,MAAgB,6BAA2D;AACzE,UAAM,aAAa,KAAK,WAAW;AACnC,QAAI,CAAC,WAAY,QAAO,CAAC;AACzB,UAAM,WAAW,MAAM,QAAQ,IAAI,WAAW,IAAI,eAAa,KAAK,QAAQ,SAAS,CAAC,CAAC;AACvF,WAAQ,SAAS,IAAI,SAAOC,qBAAoB,GAAG,CAAC,EAAG,OAAOL,OAAM;AAAA,EACtE;AAAA,EAEA,MAAgB,UACd,cACA,UACA,SACc;AACd,UAAM,eAAe,MAAM,KAAK,aAAa,cAAc,UAAU,OAAO;AAC5E,UAAM,CAAC,EAAE,gBAAgB,MAAM,IAAI;AAInC,QAAI,UAAU,OAAO,SAAS,GAAG;AAE/B,YAAM,OAAO,CAAC;AAAA,IAChB;AAEA,WAAO;AAAA,EACT;AAAA,EAEA,MAAgB,aACd,cACA,UACA,SAC+B;AAE/B,UAAM,QAAQ,MAAM,KAAK,UAAU,cAAc,UAAU,SAAS,KAAK,iBAAiB;AAG1F,WAAQ,MAAM,KAAK,MAAM,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC;AAAA,EAC7C;AAAA,EAEA,MAAgB,kBAAkB,UAAyC;AACzE,QAAI;AACF,YAAM,aAAa,MAAM,KAAK,2BAA2B;AACzD,cACE,MAAM,QAAQ;AAAA,QACZ,WAAW,IAAI,CAAC,cAAc;AAC5B,iBAAO,UAAU,SAAS,QAAQ;AAAA,QACpC,CAAC;AAAA,MACH,GACA,IAAI,CAAC,CAAC,EAAE,MAAM,EAAE;AAAA,IACpB,SAAS,IAAI;AACX,YAAM,QAAQ;AACd,WAAK,OAAO,MAAM,gCAAgC,MAAM,OAAO,EAAE;AACjE,aAAO,CAAC;AAAA,IACV;AAAA,EACF;AACF;","names":["assertEx","Account","QueryBoundWitnessWrapper","PayloadBuilder","QueryBoundWitnessWrapper","assertEx","Account","PayloadBuilder","QueryBoundWitnessWrapper","valid","value","assertEx","globallyUnique","exists","asArchivistInstance","ModuleManifestQuerySchema","ModuleStateQuerySchema","exists","globallyUnique","assertEx","ModuleManifestQuerySchema","ModuleStateQuerySchema","asArchivistInstance"]}
1
+ {"version":3,"sources":["../../src/AbstractModule.ts","../../src/determineAccount.ts","../../src/Error.ts","../../src/QueryValidator/ModuleConfigQueryValidator.ts","../../src/QueryValidator/SupportedQueryValidator.ts","../../src/AbstractModuleInstance.ts"],"sourcesContent":["/* eslint-disable complexity */\n/* eslint-disable max-lines */\nimport { assertEx } from '@xylabs/assert'\nimport { Base, globallyUnique } from '@xylabs/base'\nimport { handleError, handleErrorAsync } from '@xylabs/error'\nimport { exists } from '@xylabs/exists'\nimport { forget } from '@xylabs/forget'\nimport type { Address, Hash } from '@xylabs/hex'\nimport type { Logger } from '@xylabs/logger'\nimport {\n ConsoleLogger, IdLogger,\n LogLevel,\n} from '@xylabs/logger'\nimport type { Promisable } from '@xylabs/promise'\nimport { PromiseEx } from '@xylabs/promise'\nimport { spanAsync } from '@xylabs/telemetry'\nimport { Account } from '@xyo-network/account'\nimport type { AccountInstance } from '@xyo-network/account-model'\nimport type { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { asArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitnessBuilder, QueryBoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport type { BoundWitness, QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { isQueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport type { ConfigPayload } from '@xyo-network/config-payload-plugin'\nimport { ConfigSchema } from '@xyo-network/config-payload-plugin'\nimport type { ModuleManifestPayload } from '@xyo-network/manifest-model'\nimport { BaseEmitter } from '@xyo-network/module-event-emitter'\nimport type {\n AddressPayload,\n AddressPreviousHashPayload,\n ArchivingModuleConfig,\n AttachableModuleInstance,\n CreatableModule,\n CreatableModuleFactory,\n Labels,\n Module,\n ModuleBusyEventArgs,\n ModuleConfig,\n ModuleDescriptionPayload,\n ModuleDetailsError,\n ModuleEventData,\n ModuleParams,\n ModuleQueriedEventArgs,\n ModuleQueries,\n ModuleQueryHandlerResult,\n ModuleQueryResult,\n ModuleResolverInstance,\n ModuleStatus,\n} from '@xyo-network/module-model'\nimport {\n AddressPreviousHashSchema,\n AddressSchema,\n DeadModuleError,\n isModuleName,\n isSerializable,\n ModuleAddressQuerySchema,\n ModuleConfigSchema,\n ModuleDescriptionSchema,\n ModuleFactory,\n ModuleManifestQuerySchema,\n ModuleStateQuerySchema,\n ModuleSubscribeQuerySchema,\n ObjectResolverPriority,\n} from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type {\n ModuleError, Payload, Query, Schema,\n} from '@xyo-network/payload-model'\nimport { QuerySchema } from '@xyo-network/query-payload-plugin'\nimport type { WalletInstance } from '@xyo-network/wallet-model'\nimport { Mutex } from 'async-mutex'\nimport { LRUCache } from 'lru-cache'\n\nimport { determineAccount } from './determineAccount.ts'\nimport { ModuleErrorBuilder } from './Error.ts'\nimport type { Queryable } from './QueryValidator/index.ts'\nimport { ModuleConfigQueryValidator, SupportedQueryValidator } from './QueryValidator/index.ts'\n\nconst MODULE_NOT_STARTED = 'Module not Started' as const\nexport abstract class AbstractModule<TParams extends ModuleParams = ModuleParams, TEventData extends ModuleEventData = ModuleEventData>\n extends BaseEmitter<TParams, TEventData>\n implements Module<TParams, TEventData> {\n static readonly allowRandomAccount: boolean = true\n static readonly configSchemas: Schema[] = [ModuleConfigSchema]\n static readonly defaultConfigSchema: Schema = ModuleConfigSchema\n // eslint-disable-next-line sonarjs/public-static-readonly\n static override defaultLogger: Logger = new ConsoleLogger(LogLevel.warn)\n // eslint-disable-next-line sonarjs/public-static-readonly\n static enableLazyLoad = false\n static readonly labels: Labels = {}\n static override readonly uniqueName = globallyUnique('AbstractModule', AbstractModule, 'xyo')\n\n protected static privateConstructorKey = Date.now().toString()\n\n protected _account: AccountInstance\n\n // cache manifest based on maxDepth\n protected _cachedManifests = new LRUCache<number, ModuleManifestPayload>({ max: 10, ttl: 1000 * 60 * 5 })\n\n protected _globalReentrancyMutex: Mutex | undefined = undefined\n\n protected _lastError?: ModuleDetailsError\n\n protected _startPromise: Promisable<boolean> | undefined = undefined\n protected _started: Promisable<boolean> | undefined = undefined\n protected readonly moduleConfigQueryValidator: Queryable\n protected readonly supportedQueryValidator: Queryable\n\n private _busyCount = 0\n private _logger: Logger | undefined = undefined\n private _status: ModuleStatus = 'stopped'\n\n constructor(privateConstructorKey: string, params: TParams, account: AccountInstance) {\n assertEx(AbstractModule.privateConstructorKey === privateConstructorKey, () => 'Use create function instead of constructor')\n // Clone params to prevent mutation of the incoming object\n const mutatedParams = { ...params } as TParams\n super(mutatedParams)\n\n this._account = account\n\n this.supportedQueryValidator = new SupportedQueryValidator(this as Module).queryable\n this.moduleConfigQueryValidator = new ModuleConfigQueryValidator(mutatedParams?.config).queryable\n }\n\n get account() {\n return assertEx(this._account, () => 'Missing account')\n }\n\n get additionalSigners(): AccountInstance[] {\n return this.params.additionalSigners ?? []\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 allowNameResolution() {\n return this.params.allowNameResolution ?? true\n }\n\n get archiving(): ArchivingModuleConfig['archiving'] | undefined {\n return this.config.archiving\n }\n\n get archivist() {\n return this.config.archivist\n }\n\n get config(): TParams['config'] {\n return this.params.config\n }\n\n get dead() {\n return this.status === 'dead'\n }\n\n get ephemeralQueryAccountEnabled(): boolean {\n return !!this.params.ephemeralQueryAccountEnabled\n }\n\n get globalReentrancyMutex() {\n this._globalReentrancyMutex = this._globalReentrancyMutex ?? this.reentrancy?.scope === 'global' ? new Mutex() : undefined\n return this._globalReentrancyMutex\n }\n\n get id() {\n return this.modName ?? this.address\n }\n\n override get logger() {\n const logLevel = this.config.logLevel\n this._logger\n = (this._logger ?? logLevel) ? new ConsoleLogger(logLevel) : (this.params?.logger ?? AbstractModule.defaultLogger ?? Base.defaultLogger)\n return this._logger\n }\n\n get modName() {\n return this.config.name\n }\n\n get priority() {\n return ObjectResolverPriority.Normal\n }\n\n get queries(): Schema[] {\n return [ModuleAddressQuerySchema, ModuleSubscribeQuerySchema, ModuleManifestQuerySchema, ModuleStateQuerySchema]\n }\n\n get reentrancy() {\n return this.config.reentrancy\n }\n\n get status() {\n return this._status\n }\n\n get timestamp() {\n return this.config.timestamp ?? false\n }\n\n protected set status(value: ModuleStatus) {\n if (this._status !== 'dead') {\n this._status = value\n }\n }\n\n abstract get downResolver(): ModuleResolverInstance\n\n abstract get upResolver(): ModuleResolverInstance\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\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 AttachableModuleInstance>(\n this: CreatableModule<TModule>,\n params: Omit<TModule['params'], 'config'> & { config?: TModule['params']['config'] },\n ) {\n this._noOverride('create')\n return await spanAsync('create', async () => {\n if (!this.configSchemas || this.configSchemas.length === 0) {\n throw new Error(`Missing configSchema [${params?.config?.schema}][${this.name}]`)\n }\n\n if (!this.defaultConfigSchema) {\n throw new Error(`Missing defaultConfigSchema [${params?.config?.schema}][${this.name}]`)\n }\n\n assertEx(params?.config?.name === undefined || isModuleName(params.config.name), () => `Invalid module name: ${params?.config?.name}`)\n\n const { account } = params ?? {}\n\n const schema: Schema = params?.config?.schema ?? this.defaultConfigSchema\n const allowedSchemas: Schema[] = 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, address)\n\n if (!AbstractModule.enableLazyLoad) {\n await newModule.start?.()\n }\n return newModule\n }, params.traceProvider?.getTracer('AbstractModule[static]'))\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 AttachableModuleInstance>(\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 // eslint-disable-next-line sonarjs/no-identical-functions\n _getRootFunction(funcName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let anyThis = this as any\n while (anyThis.__proto__[funcName]) {\n anyThis = anyThis.__proto__\n }\n return anyThis[funcName]\n }\n\n async busy<R>(closure: () => Promise<R>) {\n if (this._busyCount <= 0) {\n this._busyCount = 0\n const args: ModuleBusyEventArgs = { busy: true, mod: 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, mod: this }\n await this.emit('moduleBusy', args)\n }\n }\n }\n\n override emit<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return super.emit(eventName, eventArgs)\n }\n\n previousHash(): Promisable<string | undefined> {\n this._checkDead()\n return this.account.previousHash\n }\n\n async query<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryResult> {\n this._checkDead()\n this._noOverride('query')\n return await spanAsync('query', async () => {\n const sourceQuery = assertEx(isQueryBoundWitness(query) ? query : undefined, () => 'Unable to parse query')\n return await this.busy(async () => {\n const resultPayloads: Payload[] = []\n const errorPayloads: ModuleError[] = []\n const queryAccount = this.ephemeralQueryAccountEnabled ? await Account.random() : undefined\n\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.modName}], [${this.address}]`)\n }\n if (queryConfig?.allowedQueries) {\n assertEx(queryConfig?.allowedQueries.includes(sourceQuery.schema), () => `Query not allowed [${sourceQuery.schema}]`)\n }\n resultPayloads.push(...(await this.queryHandler(sourceQuery, payloads, queryConfig)))\n } catch (ex) {\n await handleErrorAsync(ex, async (err) => {\n const error = err as ModuleDetailsError\n this._lastError = error\n // this.status = 'dead'\n errorPayloads.push(\n new ModuleErrorBuilder()\n .meta({ $sources: [await PayloadBuilder.dataHash(sourceQuery)] })\n .name(this.modName ?? '<Unknown>')\n .query(sourceQuery.schema)\n .details(error.details)\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 = {\n mod: this, payloads, query: sourceQuery, result,\n }\n await this.emit('moduleQueried', args)\n return result\n })\n }, this.tracer)\n }\n\n async queryable<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<boolean> {\n if (this.dead) {\n return false\n }\n if (!(await this.started('warn'))) return false\n const configValidator\n = queryConfig ? new ModuleConfigQueryValidator(Object.assign({}, this.config, queryConfig)).queryable : this.moduleConfigQueryValidator\n const validators = [this.supportedQueryValidator, configValidator]\n\n const results = await Promise.all(validators.map(validator => validator(query, payloads)))\n for (const result of results) {\n if (!result) {\n return false\n }\n }\n return true\n }\n\n async start(timeout?: number): Promise<boolean> {\n this._noOverride('start')\n return await spanAsync('start', async () => {\n // using promise as mutex\n this._startPromise = this._startPromise ?? await this.startHandler(timeout)\n const result = this._startPromise\n this.status = result ? 'started' : 'dead'\n return result\n }, this.tracer)\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 this._noOverride('stop')\n return await spanAsync('start', async () => {\n return await this.busy(async () => {\n const result = await this.stopHandler()\n this._started = undefined\n this._startPromise = undefined\n this.status = result ? 'stopped' : 'dead'\n return result\n })\n }, this.tracer)\n }\n\n protected _checkDead() {\n if (this.dead) {\n throw new DeadModuleError(this.id, this._lastError)\n }\n }\n\n // eslint-disable-next-line sonarjs/no-identical-functions\n protected _noOverride(functionName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const thisFunc = (this as any)[functionName]\n\n const rootFunc = this._getRootFunction(functionName)\n assertEx(thisFunc === rootFunc, () => `Override not allowed for [${functionName}] - override ${functionName}Handler instead`)\n }\n\n protected async archivistInstance(): Promise<ArchivistInstance | undefined>\n protected async archivistInstance(required: true): Promise<ArchivistInstance>\n protected async archivistInstance(required = false): Promise<ArchivistInstance | undefined> {\n const archivist = this.archivist\n if (!archivist) {\n if (required) {\n throw new Error('No archivist specified')\n }\n return undefined\n }\n const resolved = (await this.upResolver.resolve(archivist)) ?? (await this.downResolver.resolve(archivist))\n if (required) {\n assertEx(resolved, () => `Unable to resolve archivist [${archivist}]`)\n }\n return resolved ? asArchivistInstance(resolved, () => `Specified archivist is not an Archivist [${archivist}]`) : undefined\n }\n\n protected bindHashes(hashes: Hash[], schema: Schema[], account?: AccountInstance) {\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n return new PromiseEx((resolve) => {\n const result = this.bindHashesInternal(hashes, schema, account)\n resolve?.(result)\n return result\n }, account)\n }\n\n protected async bindHashesInternal(hashes: Hash[], schema: Schema[], account: AccountInstance = this.account): Promise<BoundWitness> {\n const builder = new BoundWitnessBuilder().hashes(hashes, schema).signer(account)\n const result: BoundWitness = (await 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 additionalSigners?: AccountInstance[],\n ): PromiseEx<[QueryBoundWitness, Payload[], Payload[]], AccountInstance> {\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n return new PromiseEx<[QueryBoundWitness, Payload[], Payload[]], AccountInstance>(async (resolve) => {\n const result = await this.bindQueryInternal(query, payloads, account, additionalSigners)\n resolve?.(result)\n return result\n }, account)\n }\n\n protected async bindQueryInternal<T extends Query>(\n query: T,\n payloads?: Payload[],\n account: AccountInstance = this.account,\n additionalSigners: AccountInstance[] = [],\n ): Promise<[QueryBoundWitness, Payload[], Payload[]]> {\n const accounts = [account, ...additionalSigners].filter(exists)\n const builder = new QueryBoundWitnessBuilder().payloads(payloads).signers(accounts).query(query)\n\n const [bw, payloadsOut, errors] = await builder.build()\n return [bw, [...payloadsOut], errors]\n }\n\n protected async bindQueryResult<T extends Query>(\n query: T,\n payloads: Payload[],\n additionalWitnesses: AccountInstance[] = [],\n errors?: ModuleError[],\n ): Promise<ModuleQueryResult> {\n const queryDataHash = await PayloadBuilder.dataHash(query)\n const builder = new BoundWitnessBuilder().payloads(payloads).errors(errors).sourceQuery(queryDataHash)\n const witnesses = [this.account, ...additionalWitnesses].filter(exists)\n builder.signers(witnesses)\n const result: ModuleQueryResult = [\n PayloadBuilder.omitPrivateStorageMeta((await builder.build())[0]),\n PayloadBuilder.omitPrivateStorageMeta(payloads),\n PayloadBuilder.omitPrivateStorageMeta(errors ?? []),\n ]\n if (this.archiving && this.isAllowedArchivingQuery(query.schema)) {\n forget(this.storeToArchivists(result.flat()))\n }\n return result\n }\n\n protected generateConfigAndAddress(_maxDepth?: number): Promisable<Payload[]> {\n const config = this.config\n const address: AddressPayload = { schema: AddressSchema, address: this.address }\n const queries = this.queries.map((query) => {\n return { schema: QuerySchema, query }\n })\n const configSchema: ConfigPayload = {\n config: config.schema,\n schema: ConfigSchema,\n }\n return ([config, configSchema, address, ...queries]).filter(exists)\n }\n\n protected async generateDescribe(): 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.modName\n }\n\n const discover = await this.generateConfigAndAddress()\n\n description.children = (\n discover?.map((payload) => {\n const address = payload.schema === AddressSchema ? (payload as AddressPayload).address : undefined\n return address == this.address ? undefined : address\n }) ?? []\n ).filter(exists)\n\n return description\n }\n\n /** @deprecated use archivistInstance() instead */\n protected async getArchivist(): Promise<ArchivistInstance | undefined> {\n return await this.archivistInstance()\n }\n\n protected isAllowedArchivingQuery(schema: Schema): boolean {\n const queries = this.archiving?.queries\n if (queries) {\n return queries.includes(schema)\n }\n return true\n }\n\n protected manifestHandler(_maxDepth: number = 1, _ignoreAddresses: Address[] = []): Promisable<ModuleManifestPayload> {\n throw new Error('Not supported')\n }\n\n protected moduleAddressHandler(): Promisable<(AddressPreviousHashPayload | AddressPayload)[]> {\n const address = this.address\n const name = this.modName\n const previousHash = this.address\n const moduleAccount = name\n ? {\n address, name, schema: AddressSchema,\n }\n : { address, schema: AddressSchema }\n const moduleAccountPreviousHash = previousHash\n ? {\n address, previousHash, schema: AddressPreviousHashSchema,\n }\n : { address, schema: AddressSchema }\n return [moduleAccount, moduleAccountPreviousHash]\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<ModuleQueries>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(await this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n switch (queryPayload.schema) {\n case ModuleManifestQuerySchema: {\n resultPayloads.push(await this.manifestHandler(queryPayload.maxDepth))\n break\n }\n case ModuleAddressQuerySchema: {\n resultPayloads.push(...(await this.moduleAddressHandler()))\n break\n }\n case ModuleStateQuerySchema: {\n resultPayloads.push(...(await this.stateHandler()))\n break\n }\n case ModuleSubscribeQuerySchema: {\n this.subscribeHandler()\n break\n }\n default: {\n throw new Error(`Unsupported Query [${(queryPayload as Payload).schema}]`)\n }\n }\n return PayloadBuilder.omitPrivateStorageMeta(resultPayloads)\n }\n\n protected async startHandler(_timeout?: number): Promise<boolean> {\n this.validateConfig()\n await Promise.resolve()\n this._started = true\n return true\n }\n\n protected async stateHandler(): Promise<Payload[]> {\n return [await this.manifestHandler(), ...(await this.generateConfigAndAddress()), await this.generateDescribe()]\n }\n\n protected stopHandler(_timeout?: number): Promisable<boolean> {\n this._started = undefined\n return true\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 (!isSerializable(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 protected abstract certifyParents(): Promise<Payload[]>\n protected abstract storeToArchivists(payloads: Payload[]): Promise<Payload[]>\n}\n","import { assertEx } from '@xylabs/assert'\nimport { Account } from '@xyo-network/account'\nimport type { AccountInstance } from '@xyo-network/account-model'\nimport type { 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 await Account.random()\n }\n return params.account\n }\n\n if (isDetermineAccountFromWalletParams(params)) {\n return assertEx(\n params.accountPath ? await params.wallet.derivePath(params.accountPath) : params.wallet,\n () => 'Failed to derive account from path',\n )\n }\n\n // this should eventually be removed/thrown\n console.warn('AbstractModule.determineAccount: No account or wallet provided - Creating Random account')\n return await Account.random()\n}\n","import type { Hash } from '@xylabs/hex'\nimport type { JsonValue } from '@xylabs/object'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type { ModuleError } from '@xyo-network/payload-model'\nimport { ModuleErrorSchema } from '@xyo-network/payload-model'\n\nexport class ModuleErrorBuilder extends PayloadBuilder<ModuleError> {\n _details?: JsonValue\n _message?: string\n _name?: string\n _query?: Hash\n constructor() {\n super({ schema: ModuleErrorSchema })\n }\n\n override build(): ModuleError {\n this.fields({\n details: this._details,\n message: this._message,\n name: this._name,\n query: this._query,\n })\n return super.build()\n }\n\n details(details?: JsonValue) {\n this._details = details\n return this\n }\n\n message(message: string) {\n this._message = message\n return this\n }\n\n name(name: string) {\n this._name = name\n return this\n }\n\n query(query: Hash) {\n this._query = query\n return this\n }\n}\n","import type { Address } from '@xylabs/hex'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport type {\n AnyConfigSchema, CosigningAddressSet, ModuleConfig, ModuleQueries,\n} from '@xyo-network/module-model'\nimport type { Schema } from '@xyo-network/payload-model'\n\nimport type { Queryable, QueryValidator } from './QueryValidator.ts'\n\n// eslint-disable-next-line sonarjs/redundant-type-aliases\nexport type SortedPipedAddressesString = string\n\nconst delimiter = ''\n\nexport class ModuleConfigQueryValidator<TConfig extends AnyConfigSchema<ModuleConfig>> implements QueryValidator {\n protected allowed: Record<Schema, SortedPipedAddressesString[]> = {}\n protected disallowed: Record<Schema, SortedPipedAddressesString[]> = {}\n protected readonly hasAllowedRules: boolean\n protected readonly hasDisallowedRules: boolean\n protected readonly hasRules: boolean\n\n constructor(config?: TConfig) {\n if (config?.security?.allowed) {\n for (const [schema, addresses] of Object.entries(config.security?.allowed)) {\n this.allowed[schema] = addresses.map(toAddressesString)\n }\n }\n if (config?.security?.disallowed) {\n for (const [schema, addresses] of Object.entries(config.security?.disallowed)) {\n this.disallowed[schema] = addresses.map(toAddressesString)\n }\n }\n this.hasAllowedRules = Object.keys(this.allowed).length > 0\n this.hasDisallowedRules = Object.keys(this.disallowed).length > 0\n this.hasRules = this.hasAllowedRules || this.hasDisallowedRules\n }\n\n queryable: Queryable = async (query, payloads) => {\n if (!this.hasRules) return true\n const addresses = query.addresses\n if (addresses.length === 0) return false\n const wrapper = QueryBoundWitnessWrapper.parseQuery<ModuleQueries>(query, payloads)\n const schema = (await wrapper.getQuery()).schema\n return this.queryAllowed(schema, addresses) && !this.queryDisallowed(schema, addresses)\n }\n\n protected queryAllowed = (schema: Schema, addresses: Address[]): boolean => {\n if (!this.hasAllowedRules) return true\n // All cosigners must sign\n if (addresses.length > 1) {\n const signatories = toAddressesString(addresses)\n const validCosigners = this.allowed?.[schema]?.includes(signatories)\n if (validCosigners) return true\n }\n // OR all signers have to be allowed individually\n return addresses.every(address => this.allowed?.[schema]?.includes(address) || false)\n }\n\n protected queryDisallowed = (schema: Schema, addresses: string[]): boolean => {\n if (!this.hasDisallowedRules) return false\n return addresses.some(address => this.disallowed?.[schema]?.includes(address))\n }\n}\n\n// TODO: Handle 0x prefix\nconst toAddressesString = (addresses: string | CosigningAddressSet): SortedPipedAddressesString => {\n return Array.isArray(addresses)\n ? addresses\n // eslint-disable-next-line sonarjs/no-alphabetical-sort\n .toSorted()\n .map(address => address.toLowerCase())\n .join(delimiter)\n : addresses.toLowerCase()\n}\n","import type { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport type { Module, ModuleQueries } from '@xyo-network/module-model'\nimport type { Payload } from '@xyo-network/payload-model'\n\nimport type { Queryable, QueryValidator } from './QueryValidator.ts'\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<ModuleQueries>(query, payloads)\n const schema = (await wrapper.getQuery()).schema\n return mod.queries.includes(schema)\n}\n\nexport class SupportedQueryValidator implements QueryValidator {\n constructor(protected readonly mod: Module) {}\n queryable: Queryable = (query, payloads) => {\n return isQuerySupportedByModule(this.mod, query, payloads)\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { globallyUnique } from '@xylabs/base'\nimport { exists } from '@xylabs/exists'\nimport type { Address } from '@xylabs/hex'\nimport type { TypeCheck } from '@xylabs/object'\nimport type { Promisable } from '@xylabs/promise'\nimport type { TypedValue } from '@xylabs/typeof'\nimport type { AccountInstance } from '@xyo-network/account-model'\nimport type { ArchivistInstance } from '@xyo-network/archivist-model'\nimport { asArchivistInstance } from '@xyo-network/archivist-model'\nimport type { ModuleManifestPayload } from '@xyo-network/manifest-model'\nimport { ModuleManifestPayloadSchema } from '@xyo-network/manifest-model'\nimport type {\n AddressPayload,\n AddressPreviousHashPayload,\n AttachableModuleInstance,\n ModuleEventData,\n ModuleFilterOptions,\n ModuleIdentifier,\n ModuleInstance,\n ModuleManifestQuery,\n ModuleName,\n ModuleNameResolver,\n ModuleParams,\n ModuleQueryResult,\n ModuleStateQuery,\n ObjectFilterOptions,\n ResolveHelperConfig,\n} from '@xyo-network/module-model'\nimport {\n duplicateModules,\n ModuleManifestQuerySchema,\n ModuleStateQuerySchema,\n resolveAll,\n resolveAllDown,\n resolveAllUp,\n ResolveHelper,\n resolvePathToInstance,\n} from '@xyo-network/module-model'\nimport { CompositeModuleResolver } from '@xyo-network/module-resolver'\nimport type { NodeInstance } from '@xyo-network/node-model'\nimport { asNodeInstance } from '@xyo-network/node-model'\nimport type { Payload, Query } from '@xyo-network/payload-model'\n\nimport { AbstractModule } from './AbstractModule.ts'\n\nfunction filterIdentity<T extends TypedValue>(mod?: ModuleInstance, identityFunc?: TypeCheck<T>): T\nfunction filterIdentity<T extends TypedValue>(mods?: ModuleInstance[], identityFunc?: TypeCheck<T>): T[]\nfunction filterIdentity<T extends TypedValue>(mod?: ModuleInstance | ModuleInstance[], identityFunc?: TypeCheck<T>) {\n if (Array.isArray(mod)) {\n if (identityFunc) {\n return mod.map(m => identityFunc(m)).filter(exists)\n }\n return mod\n }\n return (mod ? (identityFunc ? identityFunc(mod) : true) : false) ? mod : undefined\n}\n\nexport abstract class AbstractModuleInstance<TParams extends ModuleParams = ModuleParams, TEventData extends ModuleEventData = ModuleEventData>\n extends AbstractModule<TParams, TEventData>\n implements AttachableModuleInstance<TParams, TEventData>, ModuleNameResolver {\n static override readonly uniqueName = globallyUnique('AbstractModuleInstance', AbstractModuleInstance, 'xyo')\n\n // switches between old and new resolution system\n static readonly useNewResolver = false\n\n private _downResolver?: CompositeModuleResolver\n private _parents: NodeInstance[] = []\n private _privateResolver?: CompositeModuleResolver\n private _upResolver?: CompositeModuleResolver\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 const addToResolvers = mutatedParams.addToResolvers ?? true\n super(privateConstructorKey, mutatedParams, account)\n if (addToResolvers) {\n this.upResolver.add(this)\n this.downResolver.add(this)\n }\n }\n\n get downResolver() {\n this._downResolver\n = this._downResolver\n ?? new CompositeModuleResolver({\n allowNameResolution: this.allowNameResolution,\n moduleIdentifierTransformers: this.params.moduleIdentifierTransformers,\n root: this,\n })\n return this._downResolver\n }\n\n override get modName() {\n return super.modName\n }\n\n get moduleIdentifierTransformers() {\n return this.params.moduleIdentifierTransformers ?? ResolveHelper.transformers\n }\n\n get privateResolver() {\n this._privateResolver\n = this._privateResolver\n ?? new CompositeModuleResolver({\n allowNameResolution: this.allowNameResolution,\n moduleIdentifierTransformers: this.params.moduleIdentifierTransformers,\n root: this,\n })\n return this._privateResolver\n }\n\n get root() {\n return this\n }\n\n get upResolver() {\n this._upResolver\n = this._upResolver\n ?? new CompositeModuleResolver({\n allowNameResolution: this.allowNameResolution,\n moduleIdentifierTransformers: this.params.moduleIdentifierTransformers,\n root: this,\n })\n return this._upResolver\n }\n\n addParent(mod: ModuleInstance) {\n const existingEntry = this._parents.find(parent => parent.address === mod.address)\n if (!existingEntry) {\n this._parents.push(asNodeInstance(mod, 'Only NodeInstances can be parents'))\n }\n }\n\n async certifyParents(): Promise<Payload[]> {\n const parents = await this.parents()\n return (\n await Promise.all(\n parents.map(async (parent) => {\n const [bw, payloads, errors] = await parent.certifyQuery(this.address)\n return errors.length === 0 ? [bw, ...payloads] : []\n }),\n )\n ).flat()\n }\n\n manifest(maxDepth?: number): Promise<ModuleManifestPayload> {\n this._checkDead()\n return this.busy(async () => {\n return await this.manifestHandler(maxDepth)\n })\n }\n\n async manifestQuery(account: AccountInstance, maxDepth?: number): Promise<ModuleQueryResult<ModuleManifestPayload>> {\n const queryPayload: ModuleManifestQuery = { schema: ModuleManifestQuerySchema, ...(maxDepth === undefined ? {} : { maxDepth }) }\n return await this.sendQueryRaw<ModuleManifestQuery, Payload, ModuleManifestPayload>(queryPayload, undefined, account)\n }\n\n moduleAddress(): Promise<(AddressPayload | AddressPreviousHashPayload)[]> {\n this._checkDead()\n return this.busy(async () => {\n return await this.moduleAddressHandler()\n })\n }\n\n parents(): Promisable<NodeInstance[]> {\n return this._parents\n }\n\n privateChildren(): Promisable<ModuleInstance[]> {\n return [...this.params.privateChildren ?? []]\n }\n\n publicChildren(): Promisable<ModuleInstance[]> {\n return [...this.params.publicChildren ?? []]\n }\n\n removeParent(address: Address) {\n this._parents = this._parents.filter(item => item.address !== address)\n }\n\n async resolve(): Promise<ModuleInstance[]>\n async resolve<T extends ModuleInstance = ModuleInstance>(all: '*', options?: ModuleFilterOptions<T>): Promise<T[]>\n async resolve<T extends ModuleInstance = ModuleInstance>(id: ModuleIdentifier, options?: ModuleFilterOptions<T>): Promise<T | undefined>\n async resolve<T extends ModuleInstance = ModuleInstance>(\n id: ModuleIdentifier = '*',\n options: ModuleFilterOptions<T> = {},\n ): Promise<T | T[] | undefined> {\n if (AbstractModuleInstance.useNewResolver) {\n if (id === '*') {\n const { maxDepth = 10, direction } = options\n if (direction === 'down') {\n return filterIdentity<T>((await resolveAllDown(this, maxDepth)) ?? [], options.identity)\n }\n if (direction === 'up') {\n return filterIdentity<T>(await resolveAllUp(this, maxDepth) ?? [], options.identity)\n }\n return filterIdentity<T>(await resolveAll(this, maxDepth) ?? [], options.identity)\n } else if (typeof id === 'string') {\n return filterIdentity<T>(await resolvePathToInstance(this, id, true), options.identity)\n } else {\n throw new TypeError('Invalid id type')\n }\n } else {\n const config: ResolveHelperConfig = {\n address: this.address,\n dead: this.dead,\n downResolver: this.downResolver,\n logger: this.logger,\n mod: this,\n transformers: this.moduleIdentifierTransformers,\n upResolver: this.upResolver,\n }\n if (id === '*') {\n return filterIdentity<T>(await ResolveHelper.resolve(config, id, options) ?? [], options.identity)\n }\n return filterIdentity<T>(await ResolveHelper.resolve(config, id, options), options.identity)\n }\n }\n\n resolveIdentifier(id: ModuleIdentifier, options?: ObjectFilterOptions): Promise<Address | undefined> {\n const { direction = 'all' } = options ?? {}\n switch (direction) {\n case 'down': {\n return this.downResolver.resolveIdentifier(id, options)\n }\n default: {\n const mutatedOptions = { ...options, direction: 'all' } as ObjectFilterOptions\n return this.upResolver.resolveIdentifier(id, mutatedOptions)\n }\n }\n }\n\n async resolvePrivate<T extends ModuleInstance = ModuleInstance>(all: '*', options?: ModuleFilterOptions<T>): Promise<T[]>\n async resolvePrivate<T extends ModuleInstance = ModuleInstance>(id: ModuleIdentifier, options?: ModuleFilterOptions<T>): Promise<T | undefined>\n async resolvePrivate<T extends ModuleInstance = ModuleInstance>(\n id: ModuleIdentifier = '*',\n options: ModuleFilterOptions<T> = {},\n ): Promise<T | T[] | undefined> {\n return (\n (await this.privateResolver.resolve(id, options))\n ?? (await this.upResolver.resolve(id, options))\n ?? (await this.downResolver.resolve(id, options))\n )\n }\n\n async siblings(): Promise<ModuleInstance[]> {\n return (await Promise.all((await this.parents()).map(parent => parent.publicChildren()))).flat().filter(duplicateModules)\n }\n\n /* override start(_timeout?: number): Promisable<boolean> {\n if (this.parents.length === 0) {\n this.logger.warn(`Module is being started without being attached to a parent: ${this.id} [${this.address}]`)\n }\n return super.start()\n } */\n\n state() {\n this._checkDead()\n return this.busy(async () => {\n return await this.stateHandler()\n })\n }\n\n async stateQuery(account: AccountInstance): Promise<ModuleQueryResult> {\n const queryPayload: ModuleStateQuery = { schema: ModuleStateQuerySchema }\n return await this.sendQueryRaw(queryPayload, undefined, account)\n }\n\n subscribe(_queryAccount?: AccountInstance) {\n this._checkDead()\n return this.subscribeHandler()\n }\n\n protected override async manifestHandler(maxDepth: number = 1, _ignoreAddresses: Address[] = []): Promise<ModuleManifestPayload> {\n const cachedResult = this._cachedManifests.get(maxDepth)\n if (cachedResult) {\n return cachedResult\n }\n const modName = this.modName ?? '<Anonymous>'\n const children = await this.publicChildren()\n const childAddressToName: Record<Address, ModuleName | null> = {}\n for (const child of children) {\n if (child.address !== this.address) {\n childAddressToName[child.address] = child.modName ?? null\n }\n }\n const result = {\n config: { name: modName, ...this.config },\n schema: ModuleManifestPayloadSchema,\n status: { address: this.address, children: childAddressToName },\n }\n this._cachedManifests.set(maxDepth, result)\n return result\n }\n\n protected async resolveArchivingArchivists(): Promise<ArchivistInstance[]> {\n const archivists = this.archiving?.archivists\n if (!archivists) return []\n const resolved = await Promise.all(archivists.map(archivist => this.resolve(archivist)))\n return (resolved.map(mod => asArchivistInstance(mod))).filter(exists)\n }\n\n protected async sendQuery<T extends Query, P extends Payload = Payload, R extends Payload = Payload>(\n queryPayload: T,\n payloads?: P[],\n account?: AccountInstance,\n ): Promise<R[]> {\n const queryResults = await this.sendQueryRaw(queryPayload, payloads, account)\n const [, resultPayloads, errors] = queryResults\n\n /* TODO: Figure out what to do with the returning BW. Should we store them in a queue in case the caller wants to see them? */\n\n if (errors && errors.length > 0) {\n /* TODO: Figure out how to rollup multiple Errors */\n throw errors[0]\n }\n\n return resultPayloads as R[]\n }\n\n protected async sendQueryRaw<T extends Query, P extends Payload = Payload, R extends Payload = Payload>(\n queryPayload: T,\n payloads?: P[],\n account?: AccountInstance,\n ): Promise<ModuleQueryResult<R>> {\n // Bind them\n const query = await this.bindQuery(queryPayload, payloads, account, this.additionalSigners)\n\n // Send them off\n return (await this.query(query[0], query[1])) as ModuleQueryResult<R>\n }\n\n protected async storeToArchivists(payloads: Payload[]): Promise<Payload[]> {\n try {\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 } catch (ex) {\n const error = ex as Error\n this.logger.error(`Error storing to archivists: ${error.message}`)\n return []\n }\n }\n}\n"],"mappings":"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","names":["assertEx","Account","QueryBoundWitnessWrapper","PayloadBuilder","QueryBoundWitnessWrapper","assertEx","Account","PayloadBuilder","QueryBoundWitnessWrapper","valid","value","assertEx","globallyUnique","exists","asArchivistInstance","ModuleManifestQuerySchema","ModuleStateQuerySchema","exists","globallyUnique","assertEx","ModuleManifestQuerySchema","ModuleStateQuerySchema","asArchivistInstance"]}
@@ -78,7 +78,7 @@ export declare abstract class AbstractModule<TParams extends ModuleParams = Modu
78
78
  previousHash(): Promisable<string | undefined>;
79
79
  query<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(query: T, payloads?: Payload[], queryConfig?: TConfig): Promise<ModuleQueryResult>;
80
80
  queryable<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(query: T, payloads?: Payload[], queryConfig?: TConfig): Promise<boolean>;
81
- start(_timeout?: number): Promisable<boolean>;
81
+ start(timeout?: number): Promise<boolean>;
82
82
  started(notStartedAction?: 'error' | 'throw' | 'warn' | 'log' | 'none', tryStart?: boolean): Promise<boolean>;
83
83
  stop(_timeout?: number): Promise<boolean>;
84
84
  protected _checkDead(): void;
@@ -98,7 +98,7 @@ export declare abstract class AbstractModule<TParams extends ModuleParams = Modu
98
98
  protected manifestHandler(_maxDepth?: number, _ignoreAddresses?: Address[]): Promisable<ModuleManifestPayload>;
99
99
  protected moduleAddressHandler(): Promisable<(AddressPreviousHashPayload | AddressPayload)[]>;
100
100
  protected queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(query: T, payloads?: Payload[], queryConfig?: TConfig): Promise<ModuleQueryHandlerResult>;
101
- protected startHandler(): Promise<boolean>;
101
+ protected startHandler(_timeout?: number): Promise<boolean>;
102
102
  protected stateHandler(): Promise<Payload[]>;
103
103
  protected stopHandler(_timeout?: number): Promisable<boolean>;
104
104
  protected subscribeHandler(): void;
@@ -1 +1 @@
1
- {"version":3,"file":"AbstractModule.d.ts","sourceRoot":"","sources":["../../src/AbstractModule.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"AbstractModule.d.ts","sourceRoot":"","sources":["../../src/AbstractModule.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAChD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAA;AAK5C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAA;AAG3C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAA;AACjE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAA;AAGrE,OAAO,KAAK,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAKtF,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAA;AACxE,OAAO,EAAE,WAAW,EAAE,MAAM,mCAAmC,CAAA;AAC/D,OAAO,KAAK,EACV,cAAc,EACd,0BAA0B,EAC1B,qBAAqB,EACrB,wBAAwB,EACxB,eAAe,EACf,sBAAsB,EACtB,MAAM,EACN,MAAM,EAEN,YAAY,EACZ,wBAAwB,EACxB,kBAAkB,EAClB,eAAe,EACf,YAAY,EAGZ,wBAAwB,EACxB,iBAAiB,EACjB,sBAAsB,EACtB,YAAY,EACb,MAAM,2BAA2B,CAAA;AAiBlC,OAAO,KAAK,EACV,WAAW,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EACpC,MAAM,4BAA4B,CAAA;AAEnC,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAA;AAC/D,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAA;AACnC,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAA;AAIpC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAA;AAI1D,8BAAsB,cAAc,CAAC,OAAO,SAAS,YAAY,GAAG,YAAY,EAAE,UAAU,SAAS,eAAe,GAAG,eAAe,CACpI,SAAQ,WAAW,CAAC,OAAO,EAAE,UAAU,CACvC,YAAW,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC;IACtC,MAAM,CAAC,QAAQ,CAAC,kBAAkB,EAAE,OAAO,CAAO;IAClD,MAAM,CAAC,QAAQ,CAAC,aAAa,EAAE,MAAM,EAAE,CAAuB;IAC9D,MAAM,CAAC,QAAQ,CAAC,mBAAmB,EAAE,MAAM,CAAqB;IAEhE,OAAgB,aAAa,EAAE,MAAM,CAAmC;IAExE,MAAM,CAAC,cAAc,UAAQ;IAC7B,MAAM,CAAC,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAK;IACnC,gBAAyB,UAAU,SAA0D;IAE7F,SAAS,CAAC,MAAM,CAAC,qBAAqB,SAAwB;IAE9D,SAAS,CAAC,QAAQ,EAAE,eAAe,CAAA;IAGnC,SAAS,CAAC,gBAAgB,mDAA+E;IAEzG,SAAS,CAAC,sBAAsB,EAAE,KAAK,GAAG,SAAS,CAAY;IAE/D,SAAS,CAAC,UAAU,CAAC,EAAE,kBAAkB,CAAA;IAEzC,SAAS,CAAC,aAAa,EAAE,UAAU,CAAC,OAAO,CAAC,GAAG,SAAS,CAAY;IACpE,SAAS,CAAC,QAAQ,EAAE,UAAU,CAAC,OAAO,CAAC,GAAG,SAAS,CAAY;IAC/D,SAAS,CAAC,QAAQ,CAAC,0BAA0B,EAAE,SAAS,CAAA;IACxD,SAAS,CAAC,QAAQ,CAAC,uBAAuB,EAAE,SAAS,CAAA;IAErD,OAAO,CAAC,UAAU,CAAI;IACtB,OAAO,CAAC,OAAO,CAAgC;IAC/C,OAAO,CAAC,OAAO,CAA0B;gBAE7B,qBAAqB,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,eAAe;IAYpF,IAAI,OAAO,oBAEV;IAED,IAAI,iBAAiB,IAAI,eAAe,EAAE,CAEzC;IAED,IAAI,OAAO,sBAEV;IAED,IAAI,cAAc,YAEjB;IAED,IAAI,mBAAmB,YAEtB;IAED,IAAI,SAAS,IAAI,qBAAqB,CAAC,WAAW,CAAC,GAAG,SAAS,CAE9D;IAED,IAAI,SAAS,uBAEZ;IAED,IAAI,MAAM,IAAI,OAAO,CAAC,QAAQ,CAAC,CAE9B;IAED,IAAI,IAAI,YAEP;IAED,IAAI,4BAA4B,IAAI,OAAO,CAE1C;IAED,IAAI,qBAAqB,sBAGxB;IAED,IAAI,EAAE,WAEL;IAED,IAAa,MAAM,WAKlB;IAED,IAAI,OAAO,uBAEV;IAED,IAAI,QAAQ,MAEX;IAED,IAAI,OAAO,IAAI,MAAM,EAAE,CAEtB;IAED,IAAI,UAAU;;;kBAEb;IAED,IAAI,MAAM,IAQkB,YAAY,CANvC;IAED,IAAI,SAAS,YAEZ;IAED,SAAS,KAAK,MAAM,CAAC,KAAK,EAAE,YAAY,EAIvC;IAED,QAAQ,KAAK,YAAY,IAAI,sBAAsB,CAAA;IAEnD,QAAQ,KAAK,UAAU,IAAI,sBAAsB,CAAA;IAEjD,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,MAAM;IASxC,MAAM,CAAC,WAAW,CAAC,YAAY,EAAE,MAAM;WAQ1B,MAAM,CAAC,OAAO,SAAS,wBAAwB,EAC1D,IAAI,EAAE,eAAe,CAAC,OAAO,CAAC,EAC9B,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,QAAQ,CAAC,GAAG;QAAE,MAAM,CAAC,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAA;KAAE;WAsCzE,gBAAgB,CAAC,MAAM,EAAE;QACpC,OAAO,CAAC,EAAE,eAAe,GAAG,QAAQ,CAAA;QACpC,WAAW,CAAC,EAAE,MAAM,CAAA;QACpB,MAAM,CAAC,EAAE,cAAc,CAAA;KACxB,GAAG,OAAO,CAAC,eAAe,CAAC;IAI5B,MAAM,CAAC,OAAO,CAAC,OAAO,SAAS,wBAAwB,EACrD,IAAI,EAAE,eAAe,CAAC,OAAO,CAAC,EAC9B,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,QAAQ,CAAC,GAAG;QAAE,MAAM,CAAC,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAA;KAAE,GACnF,sBAAsB,CAAC,OAAO,CAAC;IAKlC,gBAAgB,CAAC,QAAQ,EAAE,MAAM;IAS3B,IAAI,CAAC,CAAC,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC;IAmB9B,IAAI,CAAC,UAAU,SAAS,MAAM,UAAU,GAAG,MAAM,UAAU,EAAE,UAAU,SAAS,UAAU,CAAC,UAAU,CAAC,GAAG,UAAU,CAAC,UAAU,CAAC,EACtI,SAAS,EAAE,UAAU,EACrB,SAAS,EAAE,UAAU;IAKvB,YAAY,IAAI,UAAU,CAAC,MAAM,GAAG,SAAS,CAAC;IAKxC,KAAK,CAAC,CAAC,SAAS,iBAAiB,GAAG,iBAAiB,EAAE,OAAO,SAAS,YAAY,GAAG,YAAY,EACtG,KAAK,EAAE,CAAC,EACR,QAAQ,CAAC,EAAE,OAAO,EAAE,EACpB,WAAW,CAAC,EAAE,OAAO,GACpB,OAAO,CAAC,iBAAiB,CAAC;IAiDvB,SAAS,CAAC,CAAC,SAAS,iBAAiB,GAAG,iBAAiB,EAAE,OAAO,SAAS,YAAY,GAAG,YAAY,EAC1G,KAAK,EAAE,CAAC,EACR,QAAQ,CAAC,EAAE,OAAO,EAAE,EACpB,WAAW,CAAC,EAAE,OAAO,GACpB,OAAO,CAAC,OAAO,CAAC;IAkBb,KAAK,CAAC,OAAO,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAWzC,OAAO,CAAC,gBAAgB,GAAE,OAAO,GAAG,OAAO,GAAG,MAAM,GAAG,KAAK,GAAG,MAAc,EAAE,QAAQ,UAAO,GAAG,OAAO,CAAC,OAAO,CAAC;IAgDjH,IAAI,CAAC,QAAQ,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAa/C,SAAS,CAAC,UAAU;IAOpB,SAAS,CAAC,WAAW,CAAC,YAAY,EAAE,MAAM;cAQ1B,iBAAiB,IAAI,OAAO,CAAC,iBAAiB,GAAG,SAAS,CAAC;cAC3D,iBAAiB,CAAC,QAAQ,EAAE,IAAI,GAAG,OAAO,CAAC,iBAAiB,CAAC;IAgB7E,SAAS,CAAC,UAAU,CAAC,MAAM,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,EAAE,OAAO,CAAC,EAAE,eAAe;cAShE,kBAAkB,CAAC,MAAM,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,EAAE,OAAO,GAAE,eAA8B,GAAG,OAAO,CAAC,YAAY,CAAC;IAOpI,SAAS,CAAC,SAAS,CAAC,CAAC,SAAS,KAAK,EACjC,KAAK,EAAE,CAAC,EACR,QAAQ,CAAC,EAAE,OAAO,EAAE,EACpB,OAAO,CAAC,EAAE,eAAe,EACzB,iBAAiB,CAAC,EAAE,eAAe,EAAE,GACpC,SAAS,CAAC,CAAC,iBAAiB,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE,CAAC,EAAE,eAAe,CAAC;cASxD,iBAAiB,CAAC,CAAC,SAAS,KAAK,EAC/C,KAAK,EAAE,CAAC,EACR,QAAQ,CAAC,EAAE,OAAO,EAAE,EACpB,OAAO,GAAE,eAA8B,EACvC,iBAAiB,GAAE,eAAe,EAAO,GACxC,OAAO,CAAC,CAAC,iBAAiB,EAAE,OAAO,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;cAQrC,eAAe,CAAC,CAAC,SAAS,KAAK,EAC7C,KAAK,EAAE,CAAC,EACR,QAAQ,EAAE,OAAO,EAAE,EACnB,mBAAmB,GAAE,eAAe,EAAO,EAC3C,MAAM,CAAC,EAAE,WAAW,EAAE,GACrB,OAAO,CAAC,iBAAiB,CAAC;IAgB7B,SAAS,CAAC,wBAAwB,CAAC,SAAS,CAAC,EAAE,MAAM,GAAG,UAAU,CAAC,OAAO,EAAE,CAAC;cAa7D,gBAAgB,IAAI,OAAO,CAAC,wBAAwB,CAAC;IAsBrE,kDAAkD;cAClC,YAAY,IAAI,OAAO,CAAC,iBAAiB,GAAG,SAAS,CAAC;IAItE,SAAS,CAAC,uBAAuB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO;IAQ1D,SAAS,CAAC,eAAe,CAAC,SAAS,GAAE,MAAU,EAAE,gBAAgB,GAAE,OAAO,EAAO,GAAG,UAAU,CAAC,qBAAqB,CAAC;IAIrH,SAAS,CAAC,oBAAoB,IAAI,UAAU,CAAC,CAAC,0BAA0B,GAAG,cAAc,CAAC,EAAE,CAAC;cAiB7E,YAAY,CAAC,CAAC,SAAS,iBAAiB,GAAG,iBAAiB,EAAE,OAAO,SAAS,YAAY,GAAG,YAAY,EACvH,KAAK,EAAE,CAAC,EACR,QAAQ,CAAC,EAAE,OAAO,EAAE,EACpB,WAAW,CAAC,EAAE,OAAO,GACpB,OAAO,CAAC,wBAAwB,CAAC;cA8BpB,YAAY,CAAC,QAAQ,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;cAOjD,YAAY,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;IAIlD,SAAS,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE,MAAM,GAAG,UAAU,CAAC,OAAO,CAAC;IAK7D,SAAS,CAAC,gBAAgB;IAI1B,SAAS,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE,OAAO,EAAE,OAAO,GAAE,MAAM,EAAO,GAAG,OAAO;IA+B3E,SAAS,CAAC,QAAQ,CAAC,cAAc,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;IACvD,SAAS,CAAC,QAAQ,CAAC,iBAAiB,CAAC,QAAQ,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;CAC9E"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@xyo-network/module-abstract",
3
- "version": "3.14.18",
3
+ "version": "3.15.0",
4
4
  "description": "Primary SDK for using XYO Protocol 2.0",
5
5
  "homepage": "https://xyo.network",
6
6
  "bugs": {
@@ -29,39 +29,40 @@
29
29
  "module": "dist/neutral/index.mjs",
30
30
  "types": "dist/types/index.d.ts",
31
31
  "dependencies": {
32
- "@xylabs/assert": "^4.9.3",
33
- "@xylabs/base": "^4.9.3",
34
- "@xylabs/error": "^4.9.3",
35
- "@xylabs/exists": "^4.9.3",
36
- "@xylabs/forget": "^4.9.3",
37
- "@xylabs/hex": "^4.9.3",
38
- "@xylabs/logger": "^4.9.3",
39
- "@xylabs/object": "^4.9.3",
40
- "@xylabs/promise": "^4.9.3",
41
- "@xyo-network/account": "^3.14.18",
42
- "@xyo-network/account-model": "^3.14.18",
43
- "@xyo-network/archivist-model": "^3.14.18",
44
- "@xyo-network/boundwitness-builder": "^3.14.18",
45
- "@xyo-network/boundwitness-model": "^3.14.18",
46
- "@xyo-network/boundwitness-wrapper": "^3.14.18",
47
- "@xyo-network/config-payload-plugin": "^3.14.18",
48
- "@xyo-network/manifest-model": "^3.14.18",
49
- "@xyo-network/module-event-emitter": "^3.14.18",
50
- "@xyo-network/module-model": "^3.14.18",
51
- "@xyo-network/module-resolver": "^3.14.18",
52
- "@xyo-network/node-model": "^3.14.18",
53
- "@xyo-network/payload-builder": "^3.14.18",
54
- "@xyo-network/payload-model": "^3.14.18",
55
- "@xyo-network/query-payload-plugin": "^3.14.18",
56
- "@xyo-network/wallet-model": "^3.14.18",
32
+ "@xylabs/assert": "^4.9.7",
33
+ "@xylabs/base": "^4.9.7",
34
+ "@xylabs/error": "^4.9.7",
35
+ "@xylabs/exists": "^4.9.7",
36
+ "@xylabs/forget": "^4.9.7",
37
+ "@xylabs/hex": "^4.9.7",
38
+ "@xylabs/logger": "^4.9.7",
39
+ "@xylabs/object": "^4.9.7",
40
+ "@xylabs/promise": "^4.9.7",
41
+ "@xylabs/telemetry": "^4.9.7",
42
+ "@xyo-network/account": "^3.15.0",
43
+ "@xyo-network/account-model": "^3.15.0",
44
+ "@xyo-network/archivist-model": "^3.15.0",
45
+ "@xyo-network/boundwitness-builder": "^3.15.0",
46
+ "@xyo-network/boundwitness-model": "^3.15.0",
47
+ "@xyo-network/boundwitness-wrapper": "^3.15.0",
48
+ "@xyo-network/config-payload-plugin": "^3.15.0",
49
+ "@xyo-network/manifest-model": "^3.15.0",
50
+ "@xyo-network/module-event-emitter": "^3.15.0",
51
+ "@xyo-network/module-model": "^3.15.0",
52
+ "@xyo-network/module-resolver": "^3.15.0",
53
+ "@xyo-network/node-model": "^3.15.0",
54
+ "@xyo-network/payload-builder": "^3.15.0",
55
+ "@xyo-network/payload-model": "^3.15.0",
56
+ "@xyo-network/query-payload-plugin": "^3.15.0",
57
+ "@xyo-network/wallet-model": "^3.15.0",
57
58
  "async-mutex": "^0.5.0",
58
59
  "lru-cache": "^11.1.0"
59
60
  },
60
61
  "devDependencies": {
61
62
  "@xylabs/ts-scripts-yarn3": "^6.5.5",
62
63
  "@xylabs/tsconfig": "^6.5.5",
63
- "@xylabs/typeof": "^4.9.3",
64
- "@xylabs/vitest-extended": "^4.9.3",
64
+ "@xylabs/typeof": "^4.9.7",
65
+ "@xylabs/vitest-extended": "^4.9.7",
65
66
  "typescript": "^5.8.3",
66
67
  "vitest": "^3.1.3"
67
68
  },
@@ -13,6 +13,7 @@ import {
13
13
  } from '@xylabs/logger'
14
14
  import type { Promisable } from '@xylabs/promise'
15
15
  import { PromiseEx } from '@xylabs/promise'
16
+ import { spanAsync } from '@xylabs/telemetry'
16
17
  import { Account } from '@xyo-network/account'
17
18
  import type { AccountInstance } from '@xyo-network/account-model'
18
19
  import type { ArchivistInstance } from '@xyo-network/archivist-model'
@@ -234,37 +235,39 @@ export abstract class AbstractModule<TParams extends ModuleParams = ModuleParams
234
235
  params: Omit<TModule['params'], 'config'> & { config?: TModule['params']['config'] },
235
236
  ) {
236
237
  this._noOverride('create')
237
- if (!this.configSchemas || this.configSchemas.length === 0) {
238
- throw new Error(`Missing configSchema [${params?.config?.schema}][${this.name}]`)
239
- }
238
+ return await spanAsync('create', async () => {
239
+ if (!this.configSchemas || this.configSchemas.length === 0) {
240
+ throw new Error(`Missing configSchema [${params?.config?.schema}][${this.name}]`)
241
+ }
240
242
 
241
- if (!this.defaultConfigSchema) {
242
- throw new Error(`Missing defaultConfigSchema [${params?.config?.schema}][${this.name}]`)
243
- }
243
+ if (!this.defaultConfigSchema) {
244
+ throw new Error(`Missing defaultConfigSchema [${params?.config?.schema}][${this.name}]`)
245
+ }
244
246
 
245
- assertEx(params?.config?.name === undefined || isModuleName(params.config.name), () => `Invalid module name: ${params?.config?.name}`)
247
+ assertEx(params?.config?.name === undefined || isModuleName(params.config.name), () => `Invalid module name: ${params?.config?.name}`)
246
248
 
247
- const { account } = params ?? {}
249
+ const { account } = params ?? {}
248
250
 
249
- const schema: Schema = params?.config?.schema ?? this.defaultConfigSchema
250
- const allowedSchemas: Schema[] = this.configSchemas
251
+ const schema: Schema = params?.config?.schema ?? this.defaultConfigSchema
252
+ const allowedSchemas: Schema[] = this.configSchemas
251
253
 
252
- assertEx(allowedSchemas.includes(schema), () => `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`)
253
- const mutatedConfig: TModule['params']['config'] = { ...params?.config, schema } as TModule['params']['config']
254
- params?.logger?.debug(`config: ${JSON.stringify(mutatedConfig, null, 2)}`)
255
- const mutatedParams: TModule['params'] = { ...params, config: mutatedConfig } as TModule['params']
254
+ assertEx(allowedSchemas.includes(schema), () => `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`)
255
+ const mutatedConfig: TModule['params']['config'] = { ...params?.config, schema } as TModule['params']['config']
256
+ params?.logger?.debug(`config: ${JSON.stringify(mutatedConfig, null, 2)}`)
257
+ const mutatedParams: TModule['params'] = { ...params, config: mutatedConfig } as TModule['params']
256
258
 
257
- const activeLogger = params?.logger ?? AbstractModule.defaultLogger
258
- const generatedAccount = await AbstractModule.determineAccount({ account })
259
- const address = generatedAccount.address
260
- mutatedParams.logger = activeLogger ? new IdLogger(activeLogger, () => `0x${address}`) : undefined
259
+ const activeLogger = params?.logger ?? AbstractModule.defaultLogger
260
+ const generatedAccount = await AbstractModule.determineAccount({ account })
261
+ const address = generatedAccount.address
262
+ mutatedParams.logger = activeLogger ? new IdLogger(activeLogger, () => `0x${address}`) : undefined
261
263
 
262
- const newModule = new this(AbstractModule.privateConstructorKey, mutatedParams, generatedAccount, address)
264
+ const newModule = new this(AbstractModule.privateConstructorKey, mutatedParams, generatedAccount, address)
263
265
 
264
- if (!AbstractModule.enableLazyLoad) {
265
- await newModule.start?.()
266
- }
267
- return newModule
266
+ if (!AbstractModule.enableLazyLoad) {
267
+ await newModule.start?.()
268
+ }
269
+ return newModule
270
+ }, params.traceProvider?.getTracer('AbstractModule[static]'))
268
271
  }
269
272
 
270
273
  static async determineAccount(params: {
@@ -330,48 +333,50 @@ export abstract class AbstractModule<TParams extends ModuleParams = ModuleParams
330
333
  ): Promise<ModuleQueryResult> {
331
334
  this._checkDead()
332
335
  this._noOverride('query')
333
- const sourceQuery = assertEx(isQueryBoundWitness(query) ? query : undefined, () => 'Unable to parse query')
334
- return await this.busy(async () => {
335
- const resultPayloads: Payload[] = []
336
- const errorPayloads: ModuleError[] = []
337
- const queryAccount = this.ephemeralQueryAccountEnabled ? await Account.random() : undefined
338
-
339
- try {
340
- await this.started('throw')
341
- if (!this.allowAnonymous && query.addresses.length === 0) {
342
- throw new Error(`Anonymous Queries not allowed, but running anyway [${this.modName}], [${this.address}]`)
336
+ return await spanAsync('query', async () => {
337
+ const sourceQuery = assertEx(isQueryBoundWitness(query) ? query : undefined, () => 'Unable to parse query')
338
+ return await this.busy(async () => {
339
+ const resultPayloads: Payload[] = []
340
+ const errorPayloads: ModuleError[] = []
341
+ const queryAccount = this.ephemeralQueryAccountEnabled ? await Account.random() : undefined
342
+
343
+ try {
344
+ await this.started('throw')
345
+ if (!this.allowAnonymous && query.addresses.length === 0) {
346
+ throw new Error(`Anonymous Queries not allowed, but running anyway [${this.modName}], [${this.address}]`)
347
+ }
348
+ if (queryConfig?.allowedQueries) {
349
+ assertEx(queryConfig?.allowedQueries.includes(sourceQuery.schema), () => `Query not allowed [${sourceQuery.schema}]`)
350
+ }
351
+ resultPayloads.push(...(await this.queryHandler(sourceQuery, payloads, queryConfig)))
352
+ } catch (ex) {
353
+ await handleErrorAsync(ex, async (err) => {
354
+ const error = err as ModuleDetailsError
355
+ this._lastError = error
356
+ // this.status = 'dead'
357
+ errorPayloads.push(
358
+ new ModuleErrorBuilder()
359
+ .meta({ $sources: [await PayloadBuilder.dataHash(sourceQuery)] })
360
+ .name(this.modName ?? '<Unknown>')
361
+ .query(sourceQuery.schema)
362
+ .details(error.details)
363
+ .message(error.message)
364
+ .build(),
365
+ )
366
+ })
343
367
  }
344
- if (queryConfig?.allowedQueries) {
345
- assertEx(queryConfig?.allowedQueries.includes(sourceQuery.schema), () => `Query not allowed [${sourceQuery.schema}]`)
368
+ if (this.timestamp) {
369
+ const timestamp = { schema: 'network.xyo.timestamp', timestamp: Date.now() }
370
+ resultPayloads.push(timestamp)
346
371
  }
347
- resultPayloads.push(...(await this.queryHandler(sourceQuery, payloads, queryConfig)))
348
- } catch (ex) {
349
- await handleErrorAsync(ex, async (err) => {
350
- const error = err as ModuleDetailsError
351
- this._lastError = error
352
- // this.status = 'dead'
353
- errorPayloads.push(
354
- new ModuleErrorBuilder()
355
- .meta({ $sources: [await PayloadBuilder.dataHash(sourceQuery)] })
356
- .name(this.modName ?? '<Unknown>')
357
- .query(sourceQuery.schema)
358
- .details(error.details)
359
- .message(error.message)
360
- .build(),
361
- )
362
- })
363
- }
364
- if (this.timestamp) {
365
- const timestamp = { schema: 'network.xyo.timestamp', timestamp: Date.now() }
366
- resultPayloads.push(timestamp)
367
- }
368
- const result = await this.bindQueryResult(sourceQuery, resultPayloads, queryAccount ? [queryAccount] : [], errorPayloads)
369
- const args: ModuleQueriedEventArgs = {
370
- mod: this, payloads, query: sourceQuery, result,
371
- }
372
- await this.emit('moduleQueried', args)
373
- return result
374
- })
372
+ const result = await this.bindQueryResult(sourceQuery, resultPayloads, queryAccount ? [queryAccount] : [], errorPayloads)
373
+ const args: ModuleQueriedEventArgs = {
374
+ mod: this, payloads, query: sourceQuery, result,
375
+ }
376
+ await this.emit('moduleQueried', args)
377
+ return result
378
+ })
379
+ }, this.tracer)
375
380
  }
376
381
 
377
382
  async queryable<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(
@@ -396,12 +401,15 @@ export abstract class AbstractModule<TParams extends ModuleParams = ModuleParams
396
401
  return true
397
402
  }
398
403
 
399
- start(_timeout?: number): Promisable<boolean> {
400
- // using promise as mutex
401
- this._startPromise = this._startPromise ?? this.startHandler()
402
- const result = this._startPromise
403
- this.status = result ? 'started' : 'dead'
404
- return result
404
+ async start(timeout?: number): Promise<boolean> {
405
+ this._noOverride('start')
406
+ return await spanAsync('start', async () => {
407
+ // using promise as mutex
408
+ this._startPromise = this._startPromise ?? await this.startHandler(timeout)
409
+ const result = this._startPromise
410
+ this.status = result ? 'started' : 'dead'
411
+ return result
412
+ }, this.tracer)
405
413
  }
406
414
 
407
415
  async started(notStartedAction: 'error' | 'throw' | 'warn' | 'log' | 'none' = 'log', tryStart = true): Promise<boolean> {
@@ -453,13 +461,16 @@ export abstract class AbstractModule<TParams extends ModuleParams = ModuleParams
453
461
  }
454
462
 
455
463
  async stop(_timeout?: number): Promise<boolean> {
456
- return await this.busy(async () => {
457
- const result = await this.stopHandler()
458
- this._started = undefined
459
- this._startPromise = undefined
460
- this.status = result ? 'stopped' : 'dead'
461
- return result
462
- })
464
+ this._noOverride('stop')
465
+ return await spanAsync('start', async () => {
466
+ return await this.busy(async () => {
467
+ const result = await this.stopHandler()
468
+ this._started = undefined
469
+ this._startPromise = undefined
470
+ this.status = result ? 'stopped' : 'dead'
471
+ return result
472
+ })
473
+ }, this.tracer)
463
474
  }
464
475
 
465
476
  protected _checkDead() {
@@ -661,7 +672,7 @@ export abstract class AbstractModule<TParams extends ModuleParams = ModuleParams
661
672
  return PayloadBuilder.omitPrivateStorageMeta(resultPayloads)
662
673
  }
663
674
 
664
- protected async startHandler(): Promise<boolean> {
675
+ protected async startHandler(_timeout?: number): Promise<boolean> {
665
676
  this.validateConfig()
666
677
  await Promise.resolve()
667
678
  this._started = true