@xyo-network/module-abstract 2.74.4 → 2.75.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.
Files changed (166) hide show
  1. package/dist/browser/AbstractModule.cjs +756 -0
  2. package/dist/browser/AbstractModule.cjs.map +1 -0
  3. package/dist/browser/AbstractModule.d.mts.map +1 -0
  4. package/dist/browser/AbstractModule.d.ts.map +1 -0
  5. package/dist/browser/AbstractModule.js +737 -0
  6. package/dist/browser/AbstractModule.js.map +1 -0
  7. package/dist/browser/AbstractModuleInstance.cjs +798 -0
  8. package/dist/browser/AbstractModuleInstance.cjs.map +1 -0
  9. package/dist/browser/AbstractModuleInstance.d.mts.map +1 -0
  10. package/dist/browser/AbstractModuleInstance.d.ts.map +1 -0
  11. package/dist/browser/AbstractModuleInstance.js +779 -0
  12. package/dist/browser/AbstractModuleInstance.js.map +1 -0
  13. package/dist/browser/BaseEmitter.cjs +68 -0
  14. package/dist/browser/BaseEmitter.cjs.map +1 -0
  15. package/dist/browser/BaseEmitter.d.mts.map +1 -0
  16. package/dist/browser/BaseEmitter.d.ts.map +1 -0
  17. package/dist/browser/BaseEmitter.js +49 -0
  18. package/dist/browser/BaseEmitter.js.map +1 -0
  19. package/dist/browser/Error.cjs +68 -0
  20. package/dist/browser/Error.cjs.map +1 -0
  21. package/dist/browser/Error.d.mts.map +1 -0
  22. package/dist/browser/Error.d.ts.map +1 -0
  23. package/dist/browser/Error.js +49 -0
  24. package/dist/browser/Error.js.map +1 -0
  25. package/dist/browser/QueryValidator/ModuleConfigQueryValidator.cjs +83 -0
  26. package/dist/browser/QueryValidator/ModuleConfigQueryValidator.cjs.map +1 -0
  27. package/dist/browser/QueryValidator/ModuleConfigQueryValidator.d.mts.map +1 -0
  28. package/dist/browser/QueryValidator/ModuleConfigQueryValidator.d.ts.map +1 -0
  29. package/dist/browser/QueryValidator/ModuleConfigQueryValidator.js +64 -0
  30. package/dist/browser/QueryValidator/ModuleConfigQueryValidator.js.map +1 -0
  31. package/dist/browser/QueryValidator/QueryValidator.cjs +19 -0
  32. package/dist/browser/QueryValidator/QueryValidator.cjs.map +1 -0
  33. package/dist/browser/QueryValidator/QueryValidator.d.mts.map +1 -0
  34. package/dist/browser/QueryValidator/QueryValidator.d.ts.map +1 -0
  35. package/dist/browser/QueryValidator/QueryValidator.js +1 -0
  36. package/dist/browser/QueryValidator/QueryValidator.js.map +1 -0
  37. package/dist/browser/QueryValidator/SupportedQueryValidator.cjs +47 -0
  38. package/dist/browser/QueryValidator/SupportedQueryValidator.cjs.map +1 -0
  39. package/dist/browser/QueryValidator/SupportedQueryValidator.d.mts.map +1 -0
  40. package/dist/browser/QueryValidator/SupportedQueryValidator.d.ts.map +1 -0
  41. package/dist/browser/QueryValidator/SupportedQueryValidator.js +28 -0
  42. package/dist/browser/QueryValidator/SupportedQueryValidator.js.map +1 -0
  43. package/dist/browser/QueryValidator/index.cjs +108 -0
  44. package/dist/browser/QueryValidator/index.cjs.map +1 -0
  45. package/dist/browser/QueryValidator/index.d.mts.map +1 -0
  46. package/dist/browser/QueryValidator/index.d.ts.map +1 -0
  47. package/dist/browser/QueryValidator/index.js +87 -0
  48. package/dist/browser/QueryValidator/index.js.map +1 -0
  49. package/dist/{index.js → browser/index.cjs} +1 -11
  50. package/dist/browser/index.cjs.map +1 -0
  51. package/dist/browser/index.d.mts.map +1 -0
  52. package/dist/browser/index.d.ts.map +1 -0
  53. package/dist/{index.mjs → browser/index.js} +1 -1
  54. package/dist/browser/index.js.map +1 -0
  55. package/dist/node/AbstractModule.d.mts +84 -0
  56. package/dist/node/AbstractModule.d.mts.map +1 -0
  57. package/dist/node/AbstractModule.d.ts +84 -0
  58. package/dist/node/AbstractModule.d.ts.map +1 -0
  59. package/dist/node/AbstractModule.js +594 -0
  60. package/dist/node/AbstractModule.js.map +1 -0
  61. package/dist/node/AbstractModule.mjs +571 -0
  62. package/dist/node/AbstractModule.mjs.map +1 -0
  63. package/dist/node/AbstractModuleInstance.d.mts +14 -0
  64. package/dist/node/AbstractModuleInstance.d.mts.map +1 -0
  65. package/dist/node/AbstractModuleInstance.d.ts +14 -0
  66. package/dist/node/AbstractModuleInstance.d.ts.map +1 -0
  67. package/dist/node/AbstractModuleInstance.js +68 -0
  68. package/dist/node/AbstractModuleInstance.js.map +1 -0
  69. package/dist/node/AbstractModuleInstance.mjs +45 -0
  70. package/dist/node/AbstractModuleInstance.mjs.map +1 -0
  71. package/dist/node/BaseEmitter.d.mts +17 -0
  72. package/dist/node/BaseEmitter.d.mts.map +1 -0
  73. package/dist/node/BaseEmitter.d.ts +17 -0
  74. package/dist/node/BaseEmitter.d.ts.map +1 -0
  75. package/dist/node/BaseEmitter.js +70 -0
  76. package/dist/node/BaseEmitter.js.map +1 -0
  77. package/dist/node/BaseEmitter.mjs +47 -0
  78. package/dist/node/BaseEmitter.mjs.map +1 -0
  79. package/dist/node/Error.d.mts +15 -0
  80. package/dist/node/Error.d.mts.map +1 -0
  81. package/dist/node/Error.d.ts +15 -0
  82. package/dist/node/Error.d.ts.map +1 -0
  83. package/dist/node/Error.js +70 -0
  84. package/dist/node/Error.js.map +1 -0
  85. package/dist/node/Error.mjs +47 -0
  86. package/dist/node/Error.mjs.map +1 -0
  87. package/dist/node/QueryValidator/ModuleConfigQueryValidator.d.mts +15 -0
  88. package/dist/node/QueryValidator/ModuleConfigQueryValidator.d.mts.map +1 -0
  89. package/dist/node/QueryValidator/ModuleConfigQueryValidator.d.ts +15 -0
  90. package/dist/node/QueryValidator/ModuleConfigQueryValidator.d.ts.map +1 -0
  91. package/dist/node/QueryValidator/ModuleConfigQueryValidator.js +85 -0
  92. package/dist/node/QueryValidator/ModuleConfigQueryValidator.js.map +1 -0
  93. package/dist/node/QueryValidator/ModuleConfigQueryValidator.mjs +62 -0
  94. package/dist/node/QueryValidator/ModuleConfigQueryValidator.mjs.map +1 -0
  95. package/dist/node/QueryValidator/QueryValidator.d.mts +8 -0
  96. package/dist/node/QueryValidator/QueryValidator.d.mts.map +1 -0
  97. package/dist/node/QueryValidator/QueryValidator.d.ts +8 -0
  98. package/dist/node/QueryValidator/QueryValidator.d.ts.map +1 -0
  99. package/dist/node/QueryValidator/QueryValidator.js +17 -0
  100. package/dist/node/QueryValidator/QueryValidator.js.map +1 -0
  101. package/dist/node/QueryValidator/QueryValidator.mjs +1 -0
  102. package/dist/node/QueryValidator/QueryValidator.mjs.map +1 -0
  103. package/dist/node/QueryValidator/SupportedQueryValidator.d.mts +22 -0
  104. package/dist/node/QueryValidator/SupportedQueryValidator.d.mts.map +1 -0
  105. package/dist/node/QueryValidator/SupportedQueryValidator.d.ts +22 -0
  106. package/dist/node/QueryValidator/SupportedQueryValidator.d.ts.map +1 -0
  107. package/dist/node/QueryValidator/SupportedQueryValidator.js +50 -0
  108. package/dist/node/QueryValidator/SupportedQueryValidator.js.map +1 -0
  109. package/dist/node/QueryValidator/SupportedQueryValidator.mjs +26 -0
  110. package/dist/node/QueryValidator/SupportedQueryValidator.mjs.map +1 -0
  111. package/dist/node/QueryValidator/index.d.mts +4 -0
  112. package/dist/node/QueryValidator/index.d.mts.map +1 -0
  113. package/dist/node/QueryValidator/index.d.ts +4 -0
  114. package/dist/node/QueryValidator/index.d.ts.map +1 -0
  115. package/dist/node/QueryValidator/index.js +27 -0
  116. package/dist/node/QueryValidator/index.js.map +1 -0
  117. package/dist/node/QueryValidator/index.mjs +4 -0
  118. package/dist/node/QueryValidator/index.mjs.map +1 -0
  119. package/dist/node/index.d.mts +6 -0
  120. package/dist/node/index.d.mts.map +1 -0
  121. package/dist/node/index.d.ts +6 -0
  122. package/dist/node/index.d.ts.map +1 -0
  123. package/dist/node/index.js +31 -0
  124. package/dist/node/index.js.map +1 -0
  125. package/dist/node/index.mjs +6 -0
  126. package/dist/node/index.mjs.map +1 -0
  127. package/package.json +46 -43
  128. package/dist/AbstractModule.d.mts.map +0 -1
  129. package/dist/AbstractModule.d.ts.map +0 -1
  130. package/dist/AbstractModuleInstance.d.mts.map +0 -1
  131. package/dist/AbstractModuleInstance.d.ts.map +0 -1
  132. package/dist/BaseEmitter.d.mts.map +0 -1
  133. package/dist/BaseEmitter.d.ts.map +0 -1
  134. package/dist/Error.d.mts.map +0 -1
  135. package/dist/Error.d.ts.map +0 -1
  136. package/dist/QueryValidator/ModuleConfigQueryValidator.d.mts.map +0 -1
  137. package/dist/QueryValidator/ModuleConfigQueryValidator.d.ts.map +0 -1
  138. package/dist/QueryValidator/QueryValidator.d.mts.map +0 -1
  139. package/dist/QueryValidator/QueryValidator.d.ts.map +0 -1
  140. package/dist/QueryValidator/SupportedQueryValidator.d.mts.map +0 -1
  141. package/dist/QueryValidator/SupportedQueryValidator.d.ts.map +0 -1
  142. package/dist/QueryValidator/index.d.mts.map +0 -1
  143. package/dist/QueryValidator/index.d.ts.map +0 -1
  144. package/dist/docs.json +0 -42701
  145. package/dist/index.d.mts.map +0 -1
  146. package/dist/index.d.ts.map +0 -1
  147. package/dist/index.js.map +0 -1
  148. package/dist/index.mjs.map +0 -1
  149. /package/dist/{AbstractModule.d.mts → browser/AbstractModule.d.mts} +0 -0
  150. /package/dist/{AbstractModule.d.ts → browser/AbstractModule.d.ts} +0 -0
  151. /package/dist/{AbstractModuleInstance.d.mts → browser/AbstractModuleInstance.d.mts} +0 -0
  152. /package/dist/{AbstractModuleInstance.d.ts → browser/AbstractModuleInstance.d.ts} +0 -0
  153. /package/dist/{BaseEmitter.d.mts → browser/BaseEmitter.d.mts} +0 -0
  154. /package/dist/{BaseEmitter.d.ts → browser/BaseEmitter.d.ts} +0 -0
  155. /package/dist/{Error.d.mts → browser/Error.d.mts} +0 -0
  156. /package/dist/{Error.d.ts → browser/Error.d.ts} +0 -0
  157. /package/dist/{QueryValidator → browser/QueryValidator}/ModuleConfigQueryValidator.d.mts +0 -0
  158. /package/dist/{QueryValidator → browser/QueryValidator}/ModuleConfigQueryValidator.d.ts +0 -0
  159. /package/dist/{QueryValidator → browser/QueryValidator}/QueryValidator.d.mts +0 -0
  160. /package/dist/{QueryValidator → browser/QueryValidator}/QueryValidator.d.ts +0 -0
  161. /package/dist/{QueryValidator → browser/QueryValidator}/SupportedQueryValidator.d.mts +0 -0
  162. /package/dist/{QueryValidator → browser/QueryValidator}/SupportedQueryValidator.d.ts +0 -0
  163. /package/dist/{QueryValidator → browser/QueryValidator}/index.d.mts +0 -0
  164. /package/dist/{QueryValidator → browser/QueryValidator}/index.d.ts +0 -0
  165. /package/dist/{index.d.mts → browser/index.d.mts} +0 -0
  166. /package/dist/{index.d.ts → browser/index.d.ts} +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/AbstractModule.ts"],"sourcesContent":["/* eslint-disable max-lines */\nimport { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { compact } from '@xylabs/lodash'\nimport { HDWallet } from '@xyo-network/account'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { AddressPayload, AddressSchema } from '@xyo-network/address-payload-plugin'\nimport { ArchivistInstance, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitnessBuilder, QueryBoundWitness, QueryBoundWitnessBuilder, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { ConfigPayload, ConfigSchema } from '@xyo-network/config-payload-plugin'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { handleError, handleErrorAsync } from '@xyo-network/error'\nimport { ModuleManifestPayload, ModuleManifestPayloadSchema } from '@xyo-network/manifest-model'\nimport {\n AddressPreviousHashPayload,\n AddressPreviousHashSchema,\n CreatableModule,\n CreatableModuleFactory,\n duplicateModules,\n IndividualArchivistConfig,\n Module,\n ModuleAddressQuerySchema,\n ModuleBusyEventArgs,\n ModuleConfig,\n ModuleDescribeQuerySchema,\n ModuleDescriptionPayload,\n ModuleDescriptionSchema,\n ModuleDiscoverQuerySchema,\n ModuleEventData,\n ModuleFactory,\n ModuleFilter,\n ModuleFilterOptions,\n ModuleInstance,\n ModuleManifestQuerySchema,\n ModuleParams,\n ModuleQueriedEventArgs,\n ModuleQuery,\n ModuleQueryBase,\n ModuleQueryHandlerResult,\n ModuleQueryResult,\n ModuleSubscribeQuerySchema,\n SchemaString,\n serializableField,\n} from '@xyo-network/module-model'\nimport { CompositeModuleResolver } from '@xyo-network/module-resolver'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { ModuleError, Payload, Query } from '@xyo-network/payload-model'\nimport { Promisable, PromiseEx } from '@xyo-network/promise'\nimport { QueryPayload, QuerySchema } from '@xyo-network/query-payload-plugin'\nimport { IdLogger } from '@xyo-network/shared'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nimport { BaseEmitter } from './BaseEmitter'\nimport { ModuleErrorBuilder } from './Error'\nimport { ModuleConfigQueryValidator, Queryable, SupportedQueryValidator } from './QueryValidator'\n\nexport abstract class AbstractModule<TParams extends ModuleParams = ModuleParams, TEventData extends ModuleEventData = ModuleEventData>\n extends BaseEmitter<TParams, TEventData>\n implements Module<TParams, TEventData>\n{\n static configSchemas: string[]\n static enableLazyLoad = false\n\n protected static privateConstructorKey = Date.now().toString()\n\n readonly downResolver: Omit<CompositeModuleResolver, 'resolve'> = new CompositeModuleResolver()\n readonly upResolver: Omit<CompositeModuleResolver, 'resolve>'> = new CompositeModuleResolver()\n\n protected _account: AccountInstance | undefined = undefined\n protected readonly _baseModuleQueryAccountPaths: Record<ModuleQueryBase['schema'], string> = {\n [ModuleAddressQuerySchema]: '1',\n [ModuleDescribeQuerySchema]: '4',\n [ModuleDiscoverQuerySchema]: '2',\n [ModuleManifestQuerySchema]: '5',\n [ModuleSubscribeQuerySchema]: '3',\n }\n protected readonly _queryAccounts: Record<ModuleQueryBase['schema'], AccountInstance | undefined> = {\n [ModuleAddressQuerySchema]: undefined,\n [ModuleDescribeQuerySchema]: undefined,\n [ModuleDiscoverQuerySchema]: undefined,\n [ModuleManifestQuerySchema]: undefined,\n [ModuleSubscribeQuerySchema]: undefined,\n }\n protected _startPromise: Promisable<boolean> | undefined = undefined\n protected _started: Promisable<boolean> | undefined = undefined\n protected readonly moduleConfigQueryValidator: Queryable\n protected readonly supportedQueryValidator: Queryable\n\n private _busyCount = 0\n\n constructor(privateConstructorKey: string, params: TParams, account: AccountInstance) {\n assertEx(AbstractModule.privateConstructorKey === privateConstructorKey, 'Use create function instead of constructor')\n // Clone params to prevent mutation of the incoming object\n const mutatedParams = { ...params } as TParams\n super(mutatedParams)\n\n this._account = account\n\n this.supportedQueryValidator = new SupportedQueryValidator(this as Module).queryable\n this.moduleConfigQueryValidator = new ModuleConfigQueryValidator(mutatedParams?.config).queryable\n }\n\n static get configSchema(): string {\n return this.configSchemas[0]\n }\n\n get account() {\n return assertEx(this._account, 'Missing account')\n }\n\n get address() {\n return this.account.address\n }\n\n get allowAnonymous() {\n return !!this.config.security?.allowAnonymous\n }\n\n get config(): TParams['config'] {\n return this.params.config\n }\n\n get ephemeralQueryAccountEnabled(): boolean {\n return !!this.params.ephemeralQueryAccountEnabled\n }\n\n get queries(): string[] {\n return [ModuleDiscoverQuerySchema, ModuleAddressQuerySchema, ModuleSubscribeQuerySchema, ModuleDescribeQuerySchema, ModuleManifestQuerySchema]\n }\n\n get queryAccountPaths(): Readonly<Record<Query['schema'], string | undefined>> {\n return { ...this._baseModuleQueryAccountPaths, ...this._queryAccountPaths }\n }\n\n get queryAccounts(): Readonly<Record<Query['schema'], AccountInstance | undefined>> {\n return this._queryAccounts\n }\n\n get timestamp() {\n return this.config.timestamp ?? false\n }\n\n protected abstract get _queryAccountPaths(): Record<Query['schema'], string>\n\n static _getRootFunction(funcName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let anyThis = this as any\n while (anyThis.__proto__[funcName]) {\n anyThis = anyThis.__proto__\n }\n return anyThis[funcName]\n }\n\n static _noOverride(functionName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const thisFunc = (this as any)[functionName]\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const rootFunc = this._getRootFunction(functionName)\n assertEx(thisFunc === rootFunc, `Override not allowed for [${functionName}] - override ${functionName}Handler instead`)\n }\n\n static async create<TModule extends ModuleInstance>(\n this: CreatableModule<TModule>,\n params?: Omit<TModule['params'], 'config'> & { config?: TModule['params']['config'] },\n ) {\n this._noOverride('create')\n if (!this.configSchemas || this.configSchemas.length === 0) {\n throw Error(`Missing configSchema [${params?.config?.schema}][${this.name}]`)\n }\n\n const { account, config, wallet } = params ?? {}\n const { accountDerivationPath } = config ?? {}\n\n assertEx(\n !(!!account && !!wallet),\n `Specifying both {account} and {wallet} are not allowed [${config?.schema}] [${\n account === 'random' ? 'random' : account?.address\n }, ${wallet?.address}]`,\n )\n\n const schema: string = params?.config?.schema ?? this.configSchema\n const allowedSchemas: string[] = this.configSchemas\n\n assertEx(\n allowedSchemas.filter((allowedSchema) => allowedSchema === schema).length > 0,\n `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`,\n )\n const mutatedConfig: TModule['params']['config'] = { ...params?.config, schema } as TModule['params']['config']\n params?.logger?.debug(`config: ${JSON.stringify(mutatedConfig, null, 2)}`)\n const mutatedParams: TModule['params'] = { ...params, config: mutatedConfig } as TModule['params']\n\n const activeLogger = params?.logger ?? AbstractModule.defaultLogger\n const generatedAccount = await AbstractModule.determineAccount({ account, accountDerivationPath, wallet })\n const address = generatedAccount.address\n mutatedParams.logger = activeLogger ? new IdLogger(activeLogger, () => `0x${address}`) : undefined\n\n const newModule = new this(AbstractModule.privateConstructorKey, mutatedParams, generatedAccount)\n\n if (!AbstractModule.enableLazyLoad) {\n await newModule.start?.()\n }\n return newModule\n }\n\n static async determineAccount({\n account,\n accountDerivationPath,\n wallet,\n }: {\n account?: AccountInstance | 'random'\n accountDerivationPath?: string\n wallet?: WalletInstance\n }): Promise<AccountInstance> {\n if (wallet) {\n return assertEx(accountDerivationPath ? await wallet.derivePath(accountDerivationPath) : wallet, 'Failed to derive account from path')\n } else if (account === 'random') {\n return await HDWallet.random()\n } else if (account) {\n return account\n } else {\n //this should eventually be removed/thrown\n console.warn('AbstractModule.determineAccount: No account provided - Creating Random account')\n return await HDWallet.random()\n }\n }\n\n static factory<TModule extends ModuleInstance>(\n this: CreatableModule<TModule>,\n params?: Omit<TModule['params'], 'config'> & { config?: TModule['params']['config'] },\n ): CreatableModuleFactory<TModule> {\n return ModuleFactory.withParams(this, params)\n }\n\n _getRootFunction(funcName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let anyThis = this as any\n while (anyThis.__proto__[funcName]) {\n anyThis = anyThis.__proto__\n }\n return anyThis[funcName]\n }\n\n _noOverride(functionName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const thisFunc = (this as any)[functionName]\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const rootFunc = this._getRootFunction(functionName)\n assertEx(thisFunc === rootFunc, `Override not allowed for [${functionName}] - override ${functionName}Handler instead`)\n }\n\n async busy<R>(closure: () => Promise<R>) {\n if (this._busyCount <= 0) {\n this._busyCount = 0\n const args: ModuleBusyEventArgs = { busy: true, module: this }\n await this.emit('moduleBusy', args)\n }\n this._busyCount++\n try {\n return await closure()\n } finally {\n this._busyCount--\n if (this._busyCount <= 0) {\n this._busyCount = 0\n const args: ModuleBusyEventArgs = { busy: false, module: this }\n await this.emit('moduleBusy', args)\n }\n }\n }\n\n override emit<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return super.emit(eventName, eventArgs)\n }\n\n previousHash(): Promisable<string | undefined> {\n return this.account.previousHash\n }\n\n async query<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryResult> {\n this._noOverride('query')\n return await this.busy(async () => {\n const resultPayloads: Payload[] = []\n const errorPayloads: ModuleError[] = []\n const queryAccount = this.ephemeralQueryAccountEnabled ? await HDWallet.random() : undefined\n try {\n await this.started('throw')\n if (!this.allowAnonymous) {\n if (query.addresses.length === 0) {\n throw Error(`Anonymous Queries not allowed, but running anyway [${this.config.name}], [${this.address}]`)\n }\n }\n resultPayloads.push(...(await this.queryHandler(assertEx(QueryBoundWitnessWrapper.unwrap(query)), payloads, queryConfig)))\n } catch (ex) {\n await handleErrorAsync(ex, async (error) => {\n errorPayloads.push(\n new ModuleErrorBuilder()\n .sources([await PayloadHasher.hashAsync(query)])\n .name(this.config.name ?? '<Unknown>')\n .query(query.schema)\n .message(error.message)\n .build(),\n )\n })\n }\n if (this.timestamp) {\n const timestamp = { schema: 'network.xyo.timestamp', timestamp: Date.now() }\n resultPayloads.push(timestamp)\n }\n const result = await this.bindQueryResult(query, resultPayloads, queryAccount ? [queryAccount] : [], errorPayloads)\n const args: ModuleQueriedEventArgs = { module: this, payloads, query, result }\n await this.emit('moduleQueried', args)\n return result\n })\n }\n\n queryable<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): boolean {\n if (!this.started('warn')) return false\n const configValidator = queryConfig\n ? new ModuleConfigQueryValidator(Object.assign({}, this.config, queryConfig)).queryable\n : this.moduleConfigQueryValidator\n const validators = [this.supportedQueryValidator, configValidator]\n\n return validators.every((validator) => validator(query, payloads))\n }\n\n async resolve<T extends ModuleInstance = ModuleInstance>(filter?: ModuleFilter, options?: ModuleFilterOptions<T>): Promise<T[]>\n async resolve<T extends ModuleInstance = ModuleInstance>(nameOrAddress: string, options?: ModuleFilterOptions<T>): Promise<T | undefined>\n async resolve<T extends ModuleInstance = ModuleInstance>(\n nameOrAddressOrFilter?: ModuleFilter<T> | string,\n options?: ModuleFilterOptions<T>,\n ): Promise<T | T[] | undefined> {\n const direction = options?.direction ?? 'all'\n const up = direction === 'up' || direction === 'all'\n const down = direction === 'down' || direction === 'all'\n switch (typeof nameOrAddressOrFilter) {\n case 'string': {\n return (\n (down ? await (this.downResolver as CompositeModuleResolver).resolve<T>(nameOrAddressOrFilter, options) : undefined) ??\n (up ? await (this.upResolver as CompositeModuleResolver).resolve<T>(nameOrAddressOrFilter, options) : undefined)\n )\n }\n default: {\n const filter: ModuleFilter<T> | undefined = nameOrAddressOrFilter\n return [\n ...(down ? await (this.downResolver as CompositeModuleResolver).resolve<T>(filter, options) : []),\n ...(up ? await (this.upResolver as CompositeModuleResolver).resolve<T>(filter, options) : []),\n ].filter(duplicateModules)\n }\n }\n }\n\n start(_timeout?: number): Promisable<boolean> {\n //using promise as mutex\n this._startPromise = this._startPromise ?? this.startHandler()\n return this._startPromise\n }\n\n async started(notStartedAction: 'error' | 'throw' | 'warn' | 'log' | 'none' = 'log', tryStart = true): Promise<boolean> {\n const started = await this._started\n if (started === true) {\n return true\n }\n if (!started) {\n //using promise as mutex\n this._started = (async () => {\n if (tryStart) {\n try {\n await this.start()\n return true\n } catch (ex) {\n handleError(ex, (error) => {\n this.logger?.warn(`Autostart of Module Failed: ${error.message})`)\n this._started = undefined\n })\n }\n }\n switch (notStartedAction) {\n case 'throw':\n throw Error(`Module not Started [${this.address}]`)\n case 'warn':\n this.logger?.warn('Module not started')\n break\n case 'error':\n this.logger?.error('Module not started')\n break\n case 'none':\n break\n case 'log':\n default: {\n this.logger?.log('Module not started')\n break\n }\n }\n return false\n })()\n }\n if (!this._started) {\n throw 'Failed to create start promise'\n }\n return await this._started\n }\n\n async stop(_timeout?: number): Promise<boolean> {\n return await this.busy(async () => {\n const result = await this.stopHandler()\n this._started = undefined\n this._startPromise = undefined\n return result\n })\n }\n\n protected bindHashes(hashes: string[], schema: SchemaString[], account?: AccountInstance) {\n const promise = new PromiseEx((resolve) => {\n const result = this.bindHashesInternal(hashes, schema, account)\n resolve?.(result)\n return result\n }, account)\n return promise\n }\n\n protected async bindHashesInternal(hashes: string[], schema: SchemaString[], account?: AccountInstance): Promise<BoundWitness> {\n const builder = new BoundWitnessBuilder().hashes(hashes, schema).witness(this.account)\n const result = (await (account ? builder.witness(account) : builder).build())[0]\n this.logger?.debug(`result: ${JSON.stringify(result, null, 2)}`)\n return result\n }\n\n protected bindQuery<T extends Query>(\n query: T,\n payloads?: Payload[],\n account?: AccountInstance,\n ): PromiseEx<[QueryBoundWitness, Payload[], Payload[]], AccountInstance> {\n const promise = new PromiseEx<[QueryBoundWitness, Payload[], Payload[]], AccountInstance>(async (resolve) => {\n const result = await this.bindQueryInternal(query, payloads, account)\n resolve?.(result)\n return result\n }, account)\n return promise\n }\n\n protected async bindQueryInternal<T extends Query>(\n query: T,\n payloads?: Payload[],\n account?: AccountInstance,\n ): Promise<[QueryBoundWitness, Payload[], Payload[]]> {\n const builder = new QueryBoundWitnessBuilder().payloads(payloads).witness(this.account).query(query)\n const result = await (account ? builder.witness(account) : builder).build()\n return result\n }\n\n protected async bindQueryResult<T extends Query>(\n query: T,\n payloads: Payload[],\n additionalWitnesses: AccountInstance[] = [],\n errors?: ModuleError[],\n ): Promise<ModuleQueryResult> {\n const builder = new BoundWitnessBuilder().payloads(payloads).errors(errors)\n const queryWitnessAccount = this.queryAccounts[query.schema as ModuleQueryBase['schema']]\n const witnesses = [this.account, queryWitnessAccount, ...additionalWitnesses].filter(exists)\n builder.witnesses(witnesses)\n const result: ModuleQueryResult = [(await builder.build())[0], payloads, errors ?? []]\n return result\n }\n\n protected commitArchivist = () => this.getArchivist('commit')\n\n protected async describeHandler(): Promise<ModuleDescriptionPayload> {\n const description: ModuleDescriptionPayload = {\n address: this.address,\n queries: this.queries,\n schema: ModuleDescriptionSchema,\n }\n if (this.config?.name) {\n description.name = this.config.name\n }\n\n const discover = await this.discoverHandler()\n\n description.children = compact(\n discover?.map((payload) => {\n const address = payload.schema === AddressSchema ? (payload as AddressPayload).address : undefined\n return address != this.address ? address : undefined\n }) ?? [],\n )\n\n return description\n }\n\n protected discoverHandler(): Promisable<Payload[]> {\n const config = this.config\n const address = new PayloadBuilder<AddressPayload>({ schema: AddressSchema }).fields({ address: this.address, name: this.config?.name }).build()\n const queries = this.queries.map((query) => {\n return new PayloadBuilder<QueryPayload>({ schema: QuerySchema }).fields({ query }).build()\n })\n const configSchema: ConfigPayload = {\n config: config.schema,\n schema: ConfigSchema,\n }\n return compact([config, configSchema, address, ...queries])\n }\n\n protected async getArchivist(kind: keyof IndividualArchivistConfig): Promise<ArchivistInstance | undefined> {\n if (!this.config.archivist) return undefined\n const filter =\n typeof this.config.archivist === 'string' || this.config.archivist instanceof String\n ? (this.config.archivist as string)\n : (this.config?.archivist?.[kind] as string)\n const resolved = await this.upResolver.resolve(filter)\n return asArchivistInstance(resolved)\n }\n\n protected async initializeQueryAccounts() {\n // Ensure distinct/unique wallet paths\n const paths = Object.values(this.queryAccountPaths).filter(exists)\n const distinctPaths = new Set<string>(paths)\n assertEx(distinctPaths.size === paths.length, `${this.config?.name ? this.config.name + ': ' : ''}Duplicate query account paths`)\n // Create an account for query this module supports\n const wallet = this.account as unknown as HDWallet\n if (wallet?.derivePath) {\n for (const key in this.queryAccountPaths) {\n if (Object.prototype.hasOwnProperty.call(this.queryAccountPaths, key)) {\n const query = key as ModuleQueryBase['schema']\n const queryAccountPath = this.queryAccountPaths[query]\n if (queryAccountPath) {\n this._queryAccounts[query] = await wallet.derivePath?.(queryAccountPath)\n }\n }\n }\n }\n }\n\n protected manifestHandler(_ignoreAddresses?: string[]): Promisable<ModuleManifestPayload> {\n const name = this.config.name ?? 'Anonymous'\n return { config: { name, ...this.config }, schema: ModuleManifestPayloadSchema }\n }\n\n protected moduleAddressHandler(): Promisable<AddressPreviousHashPayload[]> {\n // Return array of all addresses and their previous hash\n const queryAccounts = Object.entries(this.queryAccounts)\n .filter((value): value is [string, AccountInstance] => {\n return exists(value[1])\n })\n .map(([name, account]) => {\n const address = account.address\n const previousHash = account.previousHash\n return [\n { address, name, schema: AddressSchema },\n { address, previousHash, schema: AddressPreviousHashSchema },\n ]\n })\n const address = this.address\n const name = this.config.name\n const previousHash = this.address\n const moduleAccount = name ? { address, name, schema: AddressSchema } : { address, schema: AddressSchema }\n const moduleAccountPreviousHash = previousHash\n ? { address, previousHash, schema: AddressPreviousHashSchema }\n : { address, schema: AddressPreviousHashSchema }\n return [moduleAccount, moduleAccountPreviousHash, ...queryAccounts].flat()\n }\n\n protected async queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryHandlerResult> {\n await this.started('throw')\n const wrapper = QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n switch (queryPayload.schema) {\n case ModuleManifestQuerySchema: {\n resultPayloads.push(await this.manifestHandler())\n break\n }\n case ModuleDiscoverQuerySchema: {\n resultPayloads.push(...(await this.discoverHandler()))\n break\n }\n case ModuleDescribeQuerySchema: {\n resultPayloads.push(await this.describeHandler())\n break\n }\n case ModuleAddressQuerySchema: {\n resultPayloads.push(...(await this.moduleAddressHandler()))\n break\n }\n case ModuleSubscribeQuerySchema: {\n this.subscribeHandler()\n break\n }\n default:\n throw Error(`Unsupported Query [${(queryPayload as Payload).schema}]`)\n }\n return resultPayloads\n }\n\n protected readArchivist = () => this.getArchivist('read')\n\n protected async startHandler(): Promise<boolean> {\n this.validateConfig()\n await this.initializeQueryAccounts()\n this._started = true\n return true\n }\n\n protected stopHandler(_timeout?: number): Promisable<boolean> {\n this._started = undefined\n return true\n }\n\n protected subscribeHandler() {\n return\n }\n\n protected validateConfig(config?: unknown, parents: string[] = []): boolean {\n return Object.entries(config ?? this.config ?? {}).reduce((valid, [key, value]) => {\n switch (typeof value) {\n case 'function':\n this.logger?.warn(`Fields of type function not allowed in config [${parents?.join('.')}.${key}]`)\n return false\n case 'object': {\n if (Array.isArray(value)) {\n return (\n value.reduce((valid, value) => {\n return this.validateConfig(value, [...parents, key]) && valid\n }, true) && valid\n )\n }\n\n if (!serializableField(value)) {\n this.logger?.warn(`Fields that are not serializable to JSON are not allowed in config [${parents?.join('.')}.${key}]`)\n return false\n }\n return value ? this.validateConfig(value, [...parents, key]) && valid : true\n }\n default:\n return valid\n }\n }, true)\n }\n\n protected writeArchivist = () => this.getArchivist('write')\n}\n"],"mappings":"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","names":["AbstractModule","BaseEmitter","configSchemas","enableLazyLoad","privateConstructorKey","Date","now","toString","downResolver","CompositeModuleResolver","upResolver","_account","undefined","_baseModuleQueryAccountPaths","ModuleAddressQuerySchema","ModuleDescribeQuerySchema","ModuleDiscoverQuerySchema","ModuleManifestQuerySchema","ModuleSubscribeQuerySchema","_queryAccounts","_startPromise","_started","moduleConfigQueryValidator","supportedQueryValidator","_busyCount","constructor","params","account","assertEx","mutatedParams","SupportedQueryValidator","queryable","ModuleConfigQueryValidator","config","configSchema","address","allowAnonymous","security","ephemeralQueryAccountEnabled","queries","queryAccountPaths","_queryAccountPaths","queryAccounts","timestamp","_getRootFunction","funcName","anyThis","__proto__","_noOverride","functionName","thisFunc","rootFunc","create","length","Error","schema","name","wallet","accountDerivationPath","allowedSchemas","filter","allowedSchema","JSON","stringify","mutatedConfig","logger","debug","activeLogger","defaultLogger","generatedAccount","determineAccount","IdLogger","newModule","start","derivePath","HDWallet","random","console","warn","factory","ModuleFactory","withParams","busy","closure","args","module","emit","eventName","eventArgs","previousHash","query","payloads","queryConfig","resultPayloads","errorPayloads","queryAccount","started","addresses","push","queryHandler","QueryBoundWitnessWrapper","unwrap","ex","handleErrorAsync","error","ModuleErrorBuilder","sources","PayloadHasher","hashAsync","message","build","result","bindQueryResult","configValidator","Object","assign","validators","every","validator","resolve","nameOrAddressOrFilter","options","direction","up","down","duplicateModules","_timeout","startHandler","notStartedAction","tryStart","handleError","log","stop","stopHandler","bindHashes","hashes","promise","PromiseEx","bindHashesInternal","builder","BoundWitnessBuilder","witness","bindQuery","bindQueryInternal","QueryBoundWitnessBuilder","additionalWitnesses","errors","queryWitnessAccount","witnesses","exists","commitArchivist","getArchivist","describeHandler","description","ModuleDescriptionSchema","discover","discoverHandler","children","compact","map","payload","AddressSchema","PayloadBuilder","fields","QuerySchema","ConfigSchema","kind","archivist","String","resolved","asArchivistInstance","initializeQueryAccounts","paths","values","distinctPaths","Set","size","key","prototype","hasOwnProperty","call","queryAccountPath","manifestHandler","_ignoreAddresses","ModuleManifestPayloadSchema","moduleAddressHandler","entries","value","AddressPreviousHashSchema","moduleAccount","moduleAccountPreviousHash","flat","wrapper","parseQuery","queryPayload","getQuery","subscribeHandler","readArchivist","validateConfig","parents","reduce","valid","join","Array","isArray","serializableField","writeArchivist"]}
@@ -0,0 +1,571 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
+ import { assertEx } from "@xylabs/assert";
4
+ import { exists } from "@xylabs/exists";
5
+ import { compact } from "@xylabs/lodash";
6
+ import { HDWallet } from "@xyo-network/account";
7
+ import { AddressSchema } from "@xyo-network/address-payload-plugin";
8
+ import { asArchivistInstance } from "@xyo-network/archivist-model";
9
+ import { BoundWitnessBuilder, QueryBoundWitnessBuilder, QueryBoundWitnessWrapper } from "@xyo-network/boundwitness-builder";
10
+ import { ConfigSchema } from "@xyo-network/config-payload-plugin";
11
+ import { PayloadHasher } from "@xyo-network/core";
12
+ import { handleError, handleErrorAsync } from "@xyo-network/error";
13
+ import { ModuleManifestPayloadSchema } from "@xyo-network/manifest-model";
14
+ import { AddressPreviousHashSchema, duplicateModules, ModuleAddressQuerySchema, ModuleDescribeQuerySchema, ModuleDescriptionSchema, ModuleDiscoverQuerySchema, ModuleFactory, ModuleManifestQuerySchema, ModuleSubscribeQuerySchema, serializableField } from "@xyo-network/module-model";
15
+ import { CompositeModuleResolver } from "@xyo-network/module-resolver";
16
+ import { PayloadBuilder } from "@xyo-network/payload-builder";
17
+ import { PromiseEx } from "@xyo-network/promise";
18
+ import { QuerySchema } from "@xyo-network/query-payload-plugin";
19
+ import { IdLogger } from "@xyo-network/shared";
20
+ import { BaseEmitter } from "./BaseEmitter";
21
+ import { ModuleErrorBuilder } from "./Error";
22
+ import { ModuleConfigQueryValidator, SupportedQueryValidator } from "./QueryValidator";
23
+ class AbstractModule extends BaseEmitter {
24
+ static {
25
+ __name(this, "AbstractModule");
26
+ }
27
+ static configSchemas;
28
+ static enableLazyLoad = false;
29
+ static privateConstructorKey = Date.now().toString();
30
+ downResolver = new CompositeModuleResolver();
31
+ upResolver = new CompositeModuleResolver();
32
+ _account = void 0;
33
+ _baseModuleQueryAccountPaths = {
34
+ [ModuleAddressQuerySchema]: "1",
35
+ [ModuleDescribeQuerySchema]: "4",
36
+ [ModuleDiscoverQuerySchema]: "2",
37
+ [ModuleManifestQuerySchema]: "5",
38
+ [ModuleSubscribeQuerySchema]: "3"
39
+ };
40
+ _queryAccounts = {
41
+ [ModuleAddressQuerySchema]: void 0,
42
+ [ModuleDescribeQuerySchema]: void 0,
43
+ [ModuleDiscoverQuerySchema]: void 0,
44
+ [ModuleManifestQuerySchema]: void 0,
45
+ [ModuleSubscribeQuerySchema]: void 0
46
+ };
47
+ _startPromise = void 0;
48
+ _started = void 0;
49
+ moduleConfigQueryValidator;
50
+ supportedQueryValidator;
51
+ _busyCount = 0;
52
+ constructor(privateConstructorKey, params, account) {
53
+ assertEx(AbstractModule.privateConstructorKey === privateConstructorKey, "Use create function instead of constructor");
54
+ const mutatedParams = {
55
+ ...params
56
+ };
57
+ super(mutatedParams);
58
+ this._account = account;
59
+ this.supportedQueryValidator = new SupportedQueryValidator(this).queryable;
60
+ this.moduleConfigQueryValidator = new ModuleConfigQueryValidator(mutatedParams?.config).queryable;
61
+ }
62
+ static get configSchema() {
63
+ return this.configSchemas[0];
64
+ }
65
+ get account() {
66
+ return assertEx(this._account, "Missing account");
67
+ }
68
+ get address() {
69
+ return this.account.address;
70
+ }
71
+ get allowAnonymous() {
72
+ return !!this.config.security?.allowAnonymous;
73
+ }
74
+ get config() {
75
+ return this.params.config;
76
+ }
77
+ get ephemeralQueryAccountEnabled() {
78
+ return !!this.params.ephemeralQueryAccountEnabled;
79
+ }
80
+ get queries() {
81
+ return [
82
+ ModuleDiscoverQuerySchema,
83
+ ModuleAddressQuerySchema,
84
+ ModuleSubscribeQuerySchema,
85
+ ModuleDescribeQuerySchema,
86
+ ModuleManifestQuerySchema
87
+ ];
88
+ }
89
+ get queryAccountPaths() {
90
+ return {
91
+ ...this._baseModuleQueryAccountPaths,
92
+ ...this._queryAccountPaths
93
+ };
94
+ }
95
+ get queryAccounts() {
96
+ return this._queryAccounts;
97
+ }
98
+ get timestamp() {
99
+ return this.config.timestamp ?? false;
100
+ }
101
+ static _getRootFunction(funcName) {
102
+ let anyThis = this;
103
+ while (anyThis.__proto__[funcName]) {
104
+ anyThis = anyThis.__proto__;
105
+ }
106
+ return anyThis[funcName];
107
+ }
108
+ static _noOverride(functionName) {
109
+ const thisFunc = this[functionName];
110
+ const rootFunc = this._getRootFunction(functionName);
111
+ assertEx(thisFunc === rootFunc, `Override not allowed for [${functionName}] - override ${functionName}Handler instead`);
112
+ }
113
+ static async create(params) {
114
+ this._noOverride("create");
115
+ if (!this.configSchemas || this.configSchemas.length === 0) {
116
+ throw Error(`Missing configSchema [${params?.config?.schema}][${this.name}]`);
117
+ }
118
+ const { account, config, wallet } = params ?? {};
119
+ const { accountDerivationPath } = config ?? {};
120
+ assertEx(!(!!account && !!wallet), `Specifying both {account} and {wallet} are not allowed [${config?.schema}] [${account === "random" ? "random" : account?.address}, ${wallet?.address}]`);
121
+ const schema = params?.config?.schema ?? this.configSchema;
122
+ const allowedSchemas = this.configSchemas;
123
+ assertEx(allowedSchemas.filter((allowedSchema) => allowedSchema === schema).length > 0, `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`);
124
+ const mutatedConfig = {
125
+ ...params?.config,
126
+ schema
127
+ };
128
+ params?.logger?.debug(`config: ${JSON.stringify(mutatedConfig, null, 2)}`);
129
+ const mutatedParams = {
130
+ ...params,
131
+ config: mutatedConfig
132
+ };
133
+ const activeLogger = params?.logger ?? AbstractModule.defaultLogger;
134
+ const generatedAccount = await AbstractModule.determineAccount({
135
+ account,
136
+ accountDerivationPath,
137
+ wallet
138
+ });
139
+ const address = generatedAccount.address;
140
+ mutatedParams.logger = activeLogger ? new IdLogger(activeLogger, () => `0x${address}`) : void 0;
141
+ const newModule = new this(AbstractModule.privateConstructorKey, mutatedParams, generatedAccount);
142
+ if (!AbstractModule.enableLazyLoad) {
143
+ await newModule.start?.();
144
+ }
145
+ return newModule;
146
+ }
147
+ static async determineAccount({ account, accountDerivationPath, wallet }) {
148
+ if (wallet) {
149
+ return assertEx(accountDerivationPath ? await wallet.derivePath(accountDerivationPath) : wallet, "Failed to derive account from path");
150
+ } else if (account === "random") {
151
+ return await HDWallet.random();
152
+ } else if (account) {
153
+ return account;
154
+ } else {
155
+ console.warn("AbstractModule.determineAccount: No account provided - Creating Random account");
156
+ return await HDWallet.random();
157
+ }
158
+ }
159
+ static factory(params) {
160
+ return ModuleFactory.withParams(this, params);
161
+ }
162
+ _getRootFunction(funcName) {
163
+ let anyThis = this;
164
+ while (anyThis.__proto__[funcName]) {
165
+ anyThis = anyThis.__proto__;
166
+ }
167
+ return anyThis[funcName];
168
+ }
169
+ _noOverride(functionName) {
170
+ const thisFunc = this[functionName];
171
+ const rootFunc = this._getRootFunction(functionName);
172
+ assertEx(thisFunc === rootFunc, `Override not allowed for [${functionName}] - override ${functionName}Handler instead`);
173
+ }
174
+ async busy(closure) {
175
+ if (this._busyCount <= 0) {
176
+ this._busyCount = 0;
177
+ const args = {
178
+ busy: true,
179
+ module: this
180
+ };
181
+ await this.emit("moduleBusy", args);
182
+ }
183
+ this._busyCount++;
184
+ try {
185
+ return await closure();
186
+ } finally {
187
+ this._busyCount--;
188
+ if (this._busyCount <= 0) {
189
+ this._busyCount = 0;
190
+ const args = {
191
+ busy: false,
192
+ module: this
193
+ };
194
+ await this.emit("moduleBusy", args);
195
+ }
196
+ }
197
+ }
198
+ emit(eventName, eventArgs) {
199
+ return super.emit(eventName, eventArgs);
200
+ }
201
+ previousHash() {
202
+ return this.account.previousHash;
203
+ }
204
+ async query(query, payloads, queryConfig) {
205
+ this._noOverride("query");
206
+ return await this.busy(async () => {
207
+ const resultPayloads = [];
208
+ const errorPayloads = [];
209
+ const queryAccount = this.ephemeralQueryAccountEnabled ? await HDWallet.random() : void 0;
210
+ try {
211
+ await this.started("throw");
212
+ if (!this.allowAnonymous) {
213
+ if (query.addresses.length === 0) {
214
+ throw Error(`Anonymous Queries not allowed, but running anyway [${this.config.name}], [${this.address}]`);
215
+ }
216
+ }
217
+ resultPayloads.push(...await this.queryHandler(assertEx(QueryBoundWitnessWrapper.unwrap(query)), payloads, queryConfig));
218
+ } catch (ex) {
219
+ await handleErrorAsync(ex, async (error) => {
220
+ errorPayloads.push(new ModuleErrorBuilder().sources([
221
+ await PayloadHasher.hashAsync(query)
222
+ ]).name(this.config.name ?? "<Unknown>").query(query.schema).message(error.message).build());
223
+ });
224
+ }
225
+ if (this.timestamp) {
226
+ const timestamp = {
227
+ schema: "network.xyo.timestamp",
228
+ timestamp: Date.now()
229
+ };
230
+ resultPayloads.push(timestamp);
231
+ }
232
+ const result = await this.bindQueryResult(query, resultPayloads, queryAccount ? [
233
+ queryAccount
234
+ ] : [], errorPayloads);
235
+ const args = {
236
+ module: this,
237
+ payloads,
238
+ query,
239
+ result
240
+ };
241
+ await this.emit("moduleQueried", args);
242
+ return result;
243
+ });
244
+ }
245
+ queryable(query, payloads, queryConfig) {
246
+ if (!this.started("warn"))
247
+ return false;
248
+ const configValidator = queryConfig ? new ModuleConfigQueryValidator(Object.assign({}, this.config, queryConfig)).queryable : this.moduleConfigQueryValidator;
249
+ const validators = [
250
+ this.supportedQueryValidator,
251
+ configValidator
252
+ ];
253
+ return validators.every((validator) => validator(query, payloads));
254
+ }
255
+ async resolve(nameOrAddressOrFilter, options) {
256
+ const direction = options?.direction ?? "all";
257
+ const up = direction === "up" || direction === "all";
258
+ const down = direction === "down" || direction === "all";
259
+ switch (typeof nameOrAddressOrFilter) {
260
+ case "string": {
261
+ return (down ? await this.downResolver.resolve(nameOrAddressOrFilter, options) : void 0) ?? (up ? await this.upResolver.resolve(nameOrAddressOrFilter, options) : void 0);
262
+ }
263
+ default: {
264
+ const filter = nameOrAddressOrFilter;
265
+ return [
266
+ ...down ? await this.downResolver.resolve(filter, options) : [],
267
+ ...up ? await this.upResolver.resolve(filter, options) : []
268
+ ].filter(duplicateModules);
269
+ }
270
+ }
271
+ }
272
+ start(_timeout) {
273
+ this._startPromise = this._startPromise ?? this.startHandler();
274
+ return this._startPromise;
275
+ }
276
+ async started(notStartedAction = "log", tryStart = true) {
277
+ const started = await this._started;
278
+ if (started === true) {
279
+ return true;
280
+ }
281
+ if (!started) {
282
+ this._started = (async () => {
283
+ if (tryStart) {
284
+ try {
285
+ await this.start();
286
+ return true;
287
+ } catch (ex) {
288
+ handleError(ex, (error) => {
289
+ this.logger?.warn(`Autostart of Module Failed: ${error.message})`);
290
+ this._started = void 0;
291
+ });
292
+ }
293
+ }
294
+ switch (notStartedAction) {
295
+ case "throw":
296
+ throw Error(`Module not Started [${this.address}]`);
297
+ case "warn":
298
+ this.logger?.warn("Module not started");
299
+ break;
300
+ case "error":
301
+ this.logger?.error("Module not started");
302
+ break;
303
+ case "none":
304
+ break;
305
+ case "log":
306
+ default: {
307
+ this.logger?.log("Module not started");
308
+ break;
309
+ }
310
+ }
311
+ return false;
312
+ })();
313
+ }
314
+ if (!this._started) {
315
+ throw "Failed to create start promise";
316
+ }
317
+ return await this._started;
318
+ }
319
+ async stop(_timeout) {
320
+ return await this.busy(async () => {
321
+ const result = await this.stopHandler();
322
+ this._started = void 0;
323
+ this._startPromise = void 0;
324
+ return result;
325
+ });
326
+ }
327
+ bindHashes(hashes, schema, account) {
328
+ const promise = new PromiseEx((resolve) => {
329
+ const result = this.bindHashesInternal(hashes, schema, account);
330
+ resolve?.(result);
331
+ return result;
332
+ }, account);
333
+ return promise;
334
+ }
335
+ async bindHashesInternal(hashes, schema, account) {
336
+ const builder = new BoundWitnessBuilder().hashes(hashes, schema).witness(this.account);
337
+ const result = (await (account ? builder.witness(account) : builder).build())[0];
338
+ this.logger?.debug(`result: ${JSON.stringify(result, null, 2)}`);
339
+ return result;
340
+ }
341
+ bindQuery(query, payloads, account) {
342
+ const promise = new PromiseEx(async (resolve) => {
343
+ const result = await this.bindQueryInternal(query, payloads, account);
344
+ resolve?.(result);
345
+ return result;
346
+ }, account);
347
+ return promise;
348
+ }
349
+ async bindQueryInternal(query, payloads, account) {
350
+ const builder = new QueryBoundWitnessBuilder().payloads(payloads).witness(this.account).query(query);
351
+ const result = await (account ? builder.witness(account) : builder).build();
352
+ return result;
353
+ }
354
+ async bindQueryResult(query, payloads, additionalWitnesses = [], errors) {
355
+ const builder = new BoundWitnessBuilder().payloads(payloads).errors(errors);
356
+ const queryWitnessAccount = this.queryAccounts[query.schema];
357
+ const witnesses = [
358
+ this.account,
359
+ queryWitnessAccount,
360
+ ...additionalWitnesses
361
+ ].filter(exists);
362
+ builder.witnesses(witnesses);
363
+ const result = [
364
+ (await builder.build())[0],
365
+ payloads,
366
+ errors ?? []
367
+ ];
368
+ return result;
369
+ }
370
+ commitArchivist = () => this.getArchivist("commit");
371
+ async describeHandler() {
372
+ const description = {
373
+ address: this.address,
374
+ queries: this.queries,
375
+ schema: ModuleDescriptionSchema
376
+ };
377
+ if (this.config?.name) {
378
+ description.name = this.config.name;
379
+ }
380
+ const discover = await this.discoverHandler();
381
+ description.children = compact(discover?.map((payload) => {
382
+ const address = payload.schema === AddressSchema ? payload.address : void 0;
383
+ return address != this.address ? address : void 0;
384
+ }) ?? []);
385
+ return description;
386
+ }
387
+ discoverHandler() {
388
+ const config = this.config;
389
+ const address = new PayloadBuilder({
390
+ schema: AddressSchema
391
+ }).fields({
392
+ address: this.address,
393
+ name: this.config?.name
394
+ }).build();
395
+ const queries = this.queries.map((query) => {
396
+ return new PayloadBuilder({
397
+ schema: QuerySchema
398
+ }).fields({
399
+ query
400
+ }).build();
401
+ });
402
+ const configSchema = {
403
+ config: config.schema,
404
+ schema: ConfigSchema
405
+ };
406
+ return compact([
407
+ config,
408
+ configSchema,
409
+ address,
410
+ ...queries
411
+ ]);
412
+ }
413
+ async getArchivist(kind) {
414
+ if (!this.config.archivist)
415
+ return void 0;
416
+ const filter = typeof this.config.archivist === "string" || this.config.archivist instanceof String ? this.config.archivist : this.config?.archivist?.[kind];
417
+ const resolved = await this.upResolver.resolve(filter);
418
+ return asArchivistInstance(resolved);
419
+ }
420
+ async initializeQueryAccounts() {
421
+ const paths = Object.values(this.queryAccountPaths).filter(exists);
422
+ const distinctPaths = new Set(paths);
423
+ assertEx(distinctPaths.size === paths.length, `${this.config?.name ? this.config.name + ": " : ""}Duplicate query account paths`);
424
+ const wallet = this.account;
425
+ if (wallet?.derivePath) {
426
+ for (const key in this.queryAccountPaths) {
427
+ if (Object.prototype.hasOwnProperty.call(this.queryAccountPaths, key)) {
428
+ const query = key;
429
+ const queryAccountPath = this.queryAccountPaths[query];
430
+ if (queryAccountPath) {
431
+ this._queryAccounts[query] = await wallet.derivePath?.(queryAccountPath);
432
+ }
433
+ }
434
+ }
435
+ }
436
+ }
437
+ manifestHandler(_ignoreAddresses) {
438
+ const name = this.config.name ?? "Anonymous";
439
+ return {
440
+ config: {
441
+ name,
442
+ ...this.config
443
+ },
444
+ schema: ModuleManifestPayloadSchema
445
+ };
446
+ }
447
+ moduleAddressHandler() {
448
+ const queryAccounts = Object.entries(this.queryAccounts).filter((value) => {
449
+ return exists(value[1]);
450
+ }).map(([name2, account]) => {
451
+ const address2 = account.address;
452
+ const previousHash2 = account.previousHash;
453
+ return [
454
+ {
455
+ address: address2,
456
+ name: name2,
457
+ schema: AddressSchema
458
+ },
459
+ {
460
+ address: address2,
461
+ previousHash: previousHash2,
462
+ schema: AddressPreviousHashSchema
463
+ }
464
+ ];
465
+ });
466
+ const address = this.address;
467
+ const name = this.config.name;
468
+ const previousHash = this.address;
469
+ const moduleAccount = name ? {
470
+ address,
471
+ name,
472
+ schema: AddressSchema
473
+ } : {
474
+ address,
475
+ schema: AddressSchema
476
+ };
477
+ const moduleAccountPreviousHash = previousHash ? {
478
+ address,
479
+ previousHash,
480
+ schema: AddressPreviousHashSchema
481
+ } : {
482
+ address,
483
+ schema: AddressPreviousHashSchema
484
+ };
485
+ return [
486
+ moduleAccount,
487
+ moduleAccountPreviousHash,
488
+ ...queryAccounts
489
+ ].flat();
490
+ }
491
+ async queryHandler(query, payloads, queryConfig) {
492
+ await this.started("throw");
493
+ const wrapper = QueryBoundWitnessWrapper.parseQuery(query, payloads);
494
+ const queryPayload = await wrapper.getQuery();
495
+ assertEx(this.queryable(query, payloads, queryConfig));
496
+ const resultPayloads = [];
497
+ switch (queryPayload.schema) {
498
+ case ModuleManifestQuerySchema: {
499
+ resultPayloads.push(await this.manifestHandler());
500
+ break;
501
+ }
502
+ case ModuleDiscoverQuerySchema: {
503
+ resultPayloads.push(...await this.discoverHandler());
504
+ break;
505
+ }
506
+ case ModuleDescribeQuerySchema: {
507
+ resultPayloads.push(await this.describeHandler());
508
+ break;
509
+ }
510
+ case ModuleAddressQuerySchema: {
511
+ resultPayloads.push(...await this.moduleAddressHandler());
512
+ break;
513
+ }
514
+ case ModuleSubscribeQuerySchema: {
515
+ this.subscribeHandler();
516
+ break;
517
+ }
518
+ default:
519
+ throw Error(`Unsupported Query [${queryPayload.schema}]`);
520
+ }
521
+ return resultPayloads;
522
+ }
523
+ readArchivist = () => this.getArchivist("read");
524
+ async startHandler() {
525
+ this.validateConfig();
526
+ await this.initializeQueryAccounts();
527
+ this._started = true;
528
+ return true;
529
+ }
530
+ stopHandler(_timeout) {
531
+ this._started = void 0;
532
+ return true;
533
+ }
534
+ subscribeHandler() {
535
+ return;
536
+ }
537
+ validateConfig(config, parents = []) {
538
+ return Object.entries(config ?? this.config ?? {}).reduce((valid, [key, value]) => {
539
+ switch (typeof value) {
540
+ case "function":
541
+ this.logger?.warn(`Fields of type function not allowed in config [${parents?.join(".")}.${key}]`);
542
+ return false;
543
+ case "object": {
544
+ if (Array.isArray(value)) {
545
+ return value.reduce((valid2, value2) => {
546
+ return this.validateConfig(value2, [
547
+ ...parents,
548
+ key
549
+ ]) && valid2;
550
+ }, true) && valid;
551
+ }
552
+ if (!serializableField(value)) {
553
+ this.logger?.warn(`Fields that are not serializable to JSON are not allowed in config [${parents?.join(".")}.${key}]`);
554
+ return false;
555
+ }
556
+ return value ? this.validateConfig(value, [
557
+ ...parents,
558
+ key
559
+ ]) && valid : true;
560
+ }
561
+ default:
562
+ return valid;
563
+ }
564
+ }, true);
565
+ }
566
+ writeArchivist = () => this.getArchivist("write");
567
+ }
568
+ export {
569
+ AbstractModule
570
+ };
571
+ //# sourceMappingURL=AbstractModule.mjs.map