@xyo-network/module-abstract 2.74.5 → 2.75.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/AbstractModule.cjs +756 -0
- package/dist/browser/AbstractModule.cjs.map +1 -0
- package/dist/browser/AbstractModule.d.cts.map +1 -0
- package/dist/browser/AbstractModule.d.mts.map +1 -0
- package/dist/browser/AbstractModule.d.ts +84 -0
- package/dist/browser/AbstractModule.d.ts.map +1 -0
- package/dist/browser/AbstractModule.js +571 -0
- package/dist/browser/AbstractModule.js.map +1 -0
- package/dist/browser/AbstractModuleInstance.cjs +798 -0
- package/dist/browser/AbstractModuleInstance.cjs.map +1 -0
- package/dist/browser/AbstractModuleInstance.d.cts.map +1 -0
- package/dist/browser/AbstractModuleInstance.d.mts.map +1 -0
- package/dist/browser/AbstractModuleInstance.d.ts +14 -0
- package/dist/browser/AbstractModuleInstance.d.ts.map +1 -0
- package/dist/browser/AbstractModuleInstance.js +45 -0
- package/dist/browser/AbstractModuleInstance.js.map +1 -0
- package/dist/browser/BaseEmitter.cjs +68 -0
- package/dist/browser/BaseEmitter.cjs.map +1 -0
- package/dist/browser/BaseEmitter.d.cts.map +1 -0
- package/dist/browser/BaseEmitter.d.mts.map +1 -0
- package/dist/browser/BaseEmitter.d.ts +17 -0
- package/dist/browser/BaseEmitter.d.ts.map +1 -0
- package/dist/browser/BaseEmitter.js +47 -0
- package/dist/browser/BaseEmitter.js.map +1 -0
- package/dist/browser/Error.cjs +68 -0
- package/dist/browser/Error.cjs.map +1 -0
- package/dist/browser/Error.d.cts.map +1 -0
- package/dist/browser/Error.d.mts.map +1 -0
- package/dist/browser/Error.d.ts +15 -0
- package/dist/browser/Error.d.ts.map +1 -0
- package/dist/browser/Error.js +47 -0
- package/dist/browser/Error.js.map +1 -0
- package/dist/browser/QueryValidator/ModuleConfigQueryValidator.cjs +83 -0
- package/dist/browser/QueryValidator/ModuleConfigQueryValidator.cjs.map +1 -0
- package/dist/browser/QueryValidator/ModuleConfigQueryValidator.d.cts.map +1 -0
- package/dist/browser/QueryValidator/ModuleConfigQueryValidator.d.mts.map +1 -0
- package/dist/browser/QueryValidator/ModuleConfigQueryValidator.d.ts +15 -0
- package/dist/browser/QueryValidator/ModuleConfigQueryValidator.d.ts.map +1 -0
- package/dist/browser/QueryValidator/ModuleConfigQueryValidator.js +62 -0
- package/dist/browser/QueryValidator/ModuleConfigQueryValidator.js.map +1 -0
- package/dist/browser/QueryValidator/QueryValidator.cjs +19 -0
- package/dist/browser/QueryValidator/QueryValidator.cjs.map +1 -0
- package/dist/browser/QueryValidator/QueryValidator.d.cts.map +1 -0
- package/dist/browser/QueryValidator/QueryValidator.d.mts.map +1 -0
- package/dist/browser/QueryValidator/QueryValidator.d.ts +8 -0
- package/dist/browser/QueryValidator/QueryValidator.d.ts.map +1 -0
- package/dist/browser/QueryValidator/QueryValidator.js +1 -0
- package/dist/browser/QueryValidator/QueryValidator.js.map +1 -0
- package/dist/browser/QueryValidator/SupportedQueryValidator.cjs +47 -0
- package/dist/browser/QueryValidator/SupportedQueryValidator.cjs.map +1 -0
- package/dist/browser/QueryValidator/SupportedQueryValidator.d.cts.map +1 -0
- package/dist/browser/QueryValidator/SupportedQueryValidator.d.mts.map +1 -0
- package/dist/browser/QueryValidator/SupportedQueryValidator.d.ts +22 -0
- package/dist/browser/QueryValidator/SupportedQueryValidator.d.ts.map +1 -0
- package/dist/browser/QueryValidator/SupportedQueryValidator.js +26 -0
- package/dist/browser/QueryValidator/SupportedQueryValidator.js.map +1 -0
- package/dist/browser/QueryValidator/index.cjs +108 -0
- package/dist/browser/QueryValidator/index.cjs.map +1 -0
- package/dist/browser/QueryValidator/index.d.cts.map +1 -0
- package/dist/browser/QueryValidator/index.d.mts.map +1 -0
- package/dist/browser/QueryValidator/index.d.ts +4 -0
- package/dist/browser/QueryValidator/index.d.ts.map +1 -0
- package/dist/browser/QueryValidator/index.js +4 -0
- package/dist/browser/QueryValidator/index.js.map +1 -0
- package/dist/{index.js → browser/index.cjs} +1 -11
- package/dist/browser/index.cjs.map +1 -0
- package/dist/browser/index.d.cts.map +1 -0
- package/dist/browser/index.d.mts.map +1 -0
- package/dist/browser/index.d.ts +6 -0
- package/dist/browser/index.d.ts.map +1 -0
- package/dist/browser/index.js +6 -0
- package/dist/browser/index.js.map +1 -0
- package/dist/docs.json +1031 -1031
- package/dist/node/AbstractModule.d.cts +84 -0
- package/dist/node/AbstractModule.d.cts.map +1 -0
- package/dist/node/AbstractModule.d.mts +84 -0
- package/dist/node/AbstractModule.d.mts.map +1 -0
- package/dist/node/AbstractModule.d.ts +84 -0
- package/dist/node/AbstractModule.d.ts.map +1 -0
- package/dist/node/AbstractModule.js +778 -0
- package/dist/node/AbstractModule.js.map +1 -0
- package/dist/node/AbstractModule.mjs +755 -0
- package/dist/node/AbstractModule.mjs.map +1 -0
- package/dist/node/AbstractModuleInstance.d.cts +14 -0
- package/dist/node/AbstractModuleInstance.d.cts.map +1 -0
- package/dist/node/AbstractModuleInstance.d.mts +14 -0
- package/dist/node/AbstractModuleInstance.d.mts.map +1 -0
- package/dist/node/AbstractModuleInstance.d.ts +14 -0
- package/dist/node/AbstractModuleInstance.d.ts.map +1 -0
- package/dist/node/AbstractModuleInstance.js +819 -0
- package/dist/node/AbstractModuleInstance.js.map +1 -0
- package/dist/node/AbstractModuleInstance.mjs +796 -0
- package/dist/node/AbstractModuleInstance.mjs.map +1 -0
- package/dist/node/BaseEmitter.d.cts +17 -0
- package/dist/node/BaseEmitter.d.cts.map +1 -0
- package/dist/node/BaseEmitter.d.mts +17 -0
- package/dist/node/BaseEmitter.d.mts.map +1 -0
- package/dist/node/BaseEmitter.d.ts +17 -0
- package/dist/node/BaseEmitter.d.ts.map +1 -0
- package/dist/node/BaseEmitter.js +71 -0
- package/dist/node/BaseEmitter.js.map +1 -0
- package/dist/node/BaseEmitter.mjs +48 -0
- package/dist/node/BaseEmitter.mjs.map +1 -0
- package/dist/node/Error.d.cts +15 -0
- package/dist/node/Error.d.cts.map +1 -0
- package/dist/node/Error.d.mts +15 -0
- package/dist/node/Error.d.mts.map +1 -0
- package/dist/node/Error.d.ts +15 -0
- package/dist/node/Error.d.ts.map +1 -0
- package/dist/node/Error.js +71 -0
- package/dist/node/Error.js.map +1 -0
- package/dist/node/Error.mjs +48 -0
- package/dist/node/Error.mjs.map +1 -0
- package/dist/node/QueryValidator/ModuleConfigQueryValidator.d.cts +15 -0
- package/dist/node/QueryValidator/ModuleConfigQueryValidator.d.cts.map +1 -0
- package/dist/node/QueryValidator/ModuleConfigQueryValidator.d.mts +15 -0
- package/dist/node/QueryValidator/ModuleConfigQueryValidator.d.mts.map +1 -0
- package/dist/node/QueryValidator/ModuleConfigQueryValidator.d.ts +15 -0
- package/dist/node/QueryValidator/ModuleConfigQueryValidator.d.ts.map +1 -0
- package/dist/node/QueryValidator/ModuleConfigQueryValidator.js +94 -0
- package/dist/node/QueryValidator/ModuleConfigQueryValidator.js.map +1 -0
- package/dist/node/QueryValidator/ModuleConfigQueryValidator.mjs +71 -0
- package/dist/node/QueryValidator/ModuleConfigQueryValidator.mjs.map +1 -0
- package/dist/node/QueryValidator/QueryValidator.d.cts +8 -0
- package/dist/node/QueryValidator/QueryValidator.d.cts.map +1 -0
- package/dist/node/QueryValidator/QueryValidator.d.mts +8 -0
- package/dist/node/QueryValidator/QueryValidator.d.mts.map +1 -0
- package/dist/node/QueryValidator/QueryValidator.d.ts +8 -0
- package/dist/node/QueryValidator/QueryValidator.d.ts.map +1 -0
- package/dist/node/QueryValidator/QueryValidator.js +19 -0
- package/dist/node/QueryValidator/QueryValidator.js.map +1 -0
- package/dist/node/QueryValidator/QueryValidator.mjs +1 -0
- package/dist/node/QueryValidator/QueryValidator.mjs.map +1 -0
- package/dist/node/QueryValidator/SupportedQueryValidator.d.cts +22 -0
- package/dist/node/QueryValidator/SupportedQueryValidator.d.cts.map +1 -0
- package/dist/node/QueryValidator/SupportedQueryValidator.d.mts +22 -0
- package/dist/node/QueryValidator/SupportedQueryValidator.d.mts.map +1 -0
- package/dist/node/QueryValidator/SupportedQueryValidator.d.ts +22 -0
- package/dist/node/QueryValidator/SupportedQueryValidator.d.ts.map +1 -0
- package/dist/node/QueryValidator/SupportedQueryValidator.js +51 -0
- package/dist/node/QueryValidator/SupportedQueryValidator.js.map +1 -0
- package/dist/node/QueryValidator/SupportedQueryValidator.mjs +27 -0
- package/dist/node/QueryValidator/SupportedQueryValidator.mjs.map +1 -0
- package/dist/node/QueryValidator/index.d.cts +4 -0
- package/dist/node/QueryValidator/index.d.cts.map +1 -0
- package/dist/node/QueryValidator/index.d.mts +4 -0
- package/dist/node/QueryValidator/index.d.mts.map +1 -0
- package/dist/node/QueryValidator/index.d.ts +4 -0
- package/dist/node/QueryValidator/index.d.ts.map +1 -0
- package/dist/node/QueryValidator/index.js +120 -0
- package/dist/node/QueryValidator/index.js.map +1 -0
- package/dist/node/QueryValidator/index.mjs +93 -0
- package/dist/node/QueryValidator/index.mjs.map +1 -0
- package/dist/node/index.d.cts +6 -0
- package/dist/node/index.d.cts.map +1 -0
- package/dist/node/index.d.mts +6 -0
- package/dist/node/index.d.mts.map +1 -0
- package/dist/node/index.d.ts +6 -0
- package/dist/node/index.d.ts.map +1 -0
- package/dist/node/index.js +831 -0
- package/dist/node/index.js.map +1 -0
- package/dist/{index.mjs → node/index.mjs} +78 -61
- package/dist/node/index.mjs.map +1 -0
- package/package.json +46 -43
- package/dist/AbstractModule.d.mts.map +0 -1
- package/dist/AbstractModule.d.ts.map +0 -1
- package/dist/AbstractModuleInstance.d.mts.map +0 -1
- package/dist/AbstractModuleInstance.d.ts.map +0 -1
- package/dist/BaseEmitter.d.mts.map +0 -1
- package/dist/BaseEmitter.d.ts.map +0 -1
- package/dist/Error.d.mts.map +0 -1
- package/dist/Error.d.ts.map +0 -1
- package/dist/QueryValidator/ModuleConfigQueryValidator.d.mts.map +0 -1
- package/dist/QueryValidator/ModuleConfigQueryValidator.d.ts.map +0 -1
- package/dist/QueryValidator/QueryValidator.d.mts.map +0 -1
- package/dist/QueryValidator/QueryValidator.d.ts.map +0 -1
- package/dist/QueryValidator/SupportedQueryValidator.d.mts.map +0 -1
- package/dist/QueryValidator/SupportedQueryValidator.d.ts.map +0 -1
- package/dist/QueryValidator/index.d.mts.map +0 -1
- package/dist/QueryValidator/index.d.ts.map +0 -1
- package/dist/index.d.mts.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/index.mjs.map +0 -1
- /package/dist/{AbstractModule.d.mts → browser/AbstractModule.d.cts} +0 -0
- /package/dist/{AbstractModule.d.ts → browser/AbstractModule.d.mts} +0 -0
- /package/dist/{AbstractModuleInstance.d.mts → browser/AbstractModuleInstance.d.cts} +0 -0
- /package/dist/{AbstractModuleInstance.d.ts → browser/AbstractModuleInstance.d.mts} +0 -0
- /package/dist/{BaseEmitter.d.mts → browser/BaseEmitter.d.cts} +0 -0
- /package/dist/{BaseEmitter.d.ts → browser/BaseEmitter.d.mts} +0 -0
- /package/dist/{Error.d.mts → browser/Error.d.cts} +0 -0
- /package/dist/{Error.d.ts → browser/Error.d.mts} +0 -0
- /package/dist/{QueryValidator/ModuleConfigQueryValidator.d.mts → browser/QueryValidator/ModuleConfigQueryValidator.d.cts} +0 -0
- /package/dist/{QueryValidator/ModuleConfigQueryValidator.d.ts → browser/QueryValidator/ModuleConfigQueryValidator.d.mts} +0 -0
- /package/dist/{QueryValidator/QueryValidator.d.mts → browser/QueryValidator/QueryValidator.d.cts} +0 -0
- /package/dist/{QueryValidator/QueryValidator.d.ts → browser/QueryValidator/QueryValidator.d.mts} +0 -0
- /package/dist/{QueryValidator/SupportedQueryValidator.d.mts → browser/QueryValidator/SupportedQueryValidator.d.cts} +0 -0
- /package/dist/{QueryValidator/SupportedQueryValidator.d.ts → browser/QueryValidator/SupportedQueryValidator.d.mts} +0 -0
- /package/dist/{QueryValidator/index.d.mts → browser/QueryValidator/index.d.cts} +0 -0
- /package/dist/{QueryValidator/index.d.ts → browser/QueryValidator/index.d.mts} +0 -0
- /package/dist/{index.d.mts → browser/index.d.cts} +0 -0
- /package/dist/{index.d.ts → browser/index.d.mts} +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/AbstractModule.ts","../../src/BaseEmitter.ts","../../src/Error.ts","../../src/QueryValidator/ModuleConfigQueryValidator.ts","../../src/QueryValidator/SupportedQueryValidator.ts","../../src/AbstractModuleInstance.ts"],"sourcesContent":["export * from './AbstractModule'\nexport * from './AbstractModuleInstance'\nexport * from './BaseEmitter'\nexport * from './Error'\nexport * from './QueryValidator'\n","/* eslint-disable max-lines */\nimport { assertEx } from '@xylabs/assert'\nimport { exists } from '@xylabs/exists'\nimport { compact } from '@xylabs/lodash'\nimport { HDWallet } from '@xyo-network/account'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { AddressPayload, AddressSchema } from '@xyo-network/address-payload-plugin'\nimport { ArchivistInstance, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitnessBuilder, QueryBoundWitness, QueryBoundWitnessBuilder, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness } from '@xyo-network/boundwitness-model'\nimport { ConfigPayload, ConfigSchema } from '@xyo-network/config-payload-plugin'\nimport { PayloadHasher } from '@xyo-network/core'\nimport { handleError, handleErrorAsync } from '@xyo-network/error'\nimport { ModuleManifestPayload, ModuleManifestPayloadSchema } from '@xyo-network/manifest-model'\nimport {\n AddressPreviousHashPayload,\n AddressPreviousHashSchema,\n CreatableModule,\n CreatableModuleFactory,\n duplicateModules,\n IndividualArchivistConfig,\n Module,\n ModuleAddressQuerySchema,\n ModuleBusyEventArgs,\n ModuleConfig,\n ModuleDescribeQuerySchema,\n ModuleDescriptionPayload,\n ModuleDescriptionSchema,\n ModuleDiscoverQuerySchema,\n ModuleEventData,\n ModuleFactory,\n ModuleFilter,\n ModuleFilterOptions,\n ModuleInstance,\n ModuleManifestQuerySchema,\n ModuleParams,\n ModuleQueriedEventArgs,\n ModuleQuery,\n ModuleQueryBase,\n ModuleQueryHandlerResult,\n ModuleQueryResult,\n ModuleSubscribeQuerySchema,\n SchemaString,\n serializableField,\n} from '@xyo-network/module-model'\nimport { CompositeModuleResolver } from '@xyo-network/module-resolver'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { ModuleError, Payload, Query } from '@xyo-network/payload-model'\nimport { Promisable, PromiseEx } from '@xyo-network/promise'\nimport { QueryPayload, QuerySchema } from '@xyo-network/query-payload-plugin'\nimport { IdLogger } from '@xyo-network/shared'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nimport { BaseEmitter } from './BaseEmitter'\nimport { ModuleErrorBuilder } from './Error'\nimport { ModuleConfigQueryValidator, Queryable, SupportedQueryValidator } from './QueryValidator'\n\nexport abstract class AbstractModule<TParams extends ModuleParams = ModuleParams, TEventData extends ModuleEventData = ModuleEventData>\n extends BaseEmitter<TParams, TEventData>\n implements Module<TParams, TEventData>\n{\n static configSchemas: string[]\n static enableLazyLoad = false\n\n protected static privateConstructorKey = Date.now().toString()\n\n readonly downResolver: Omit<CompositeModuleResolver, 'resolve'> = new CompositeModuleResolver()\n readonly upResolver: Omit<CompositeModuleResolver, 'resolve>'> = new CompositeModuleResolver()\n\n protected _account: AccountInstance | undefined = undefined\n protected readonly _baseModuleQueryAccountPaths: Record<ModuleQueryBase['schema'], string> = {\n [ModuleAddressQuerySchema]: '1',\n [ModuleDescribeQuerySchema]: '4',\n [ModuleDiscoverQuerySchema]: '2',\n [ModuleManifestQuerySchema]: '5',\n [ModuleSubscribeQuerySchema]: '3',\n }\n protected readonly _queryAccounts: Record<ModuleQueryBase['schema'], AccountInstance | undefined> = {\n [ModuleAddressQuerySchema]: undefined,\n [ModuleDescribeQuerySchema]: undefined,\n [ModuleDiscoverQuerySchema]: undefined,\n [ModuleManifestQuerySchema]: undefined,\n [ModuleSubscribeQuerySchema]: undefined,\n }\n protected _startPromise: Promisable<boolean> | undefined = undefined\n protected _started: Promisable<boolean> | undefined = undefined\n protected readonly moduleConfigQueryValidator: Queryable\n protected readonly supportedQueryValidator: Queryable\n\n private _busyCount = 0\n\n constructor(privateConstructorKey: string, params: TParams, account: AccountInstance) {\n assertEx(AbstractModule.privateConstructorKey === privateConstructorKey, 'Use create function instead of constructor')\n // Clone params to prevent mutation of the incoming object\n const mutatedParams = { ...params } as TParams\n super(mutatedParams)\n\n this._account = account\n\n this.supportedQueryValidator = new SupportedQueryValidator(this as Module).queryable\n this.moduleConfigQueryValidator = new ModuleConfigQueryValidator(mutatedParams?.config).queryable\n }\n\n static get configSchema(): string {\n return this.configSchemas[0]\n }\n\n get account() {\n return assertEx(this._account, 'Missing account')\n }\n\n get address() {\n return this.account.address\n }\n\n get allowAnonymous() {\n return !!this.config.security?.allowAnonymous\n }\n\n get config(): TParams['config'] {\n return this.params.config\n }\n\n get ephemeralQueryAccountEnabled(): boolean {\n return !!this.params.ephemeralQueryAccountEnabled\n }\n\n get queries(): string[] {\n return [ModuleDiscoverQuerySchema, ModuleAddressQuerySchema, ModuleSubscribeQuerySchema, ModuleDescribeQuerySchema, ModuleManifestQuerySchema]\n }\n\n get queryAccountPaths(): Readonly<Record<Query['schema'], string | undefined>> {\n return { ...this._baseModuleQueryAccountPaths, ...this._queryAccountPaths }\n }\n\n get queryAccounts(): Readonly<Record<Query['schema'], AccountInstance | undefined>> {\n return this._queryAccounts\n }\n\n get timestamp() {\n return this.config.timestamp ?? false\n }\n\n protected abstract get _queryAccountPaths(): Record<Query['schema'], string>\n\n static _getRootFunction(funcName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let anyThis = this as any\n while (anyThis.__proto__[funcName]) {\n anyThis = anyThis.__proto__\n }\n return anyThis[funcName]\n }\n\n static _noOverride(functionName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const thisFunc = (this as any)[functionName]\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const rootFunc = this._getRootFunction(functionName)\n assertEx(thisFunc === rootFunc, `Override not allowed for [${functionName}] - override ${functionName}Handler instead`)\n }\n\n static async create<TModule extends ModuleInstance>(\n this: CreatableModule<TModule>,\n params?: Omit<TModule['params'], 'config'> & { config?: TModule['params']['config'] },\n ) {\n this._noOverride('create')\n if (!this.configSchemas || this.configSchemas.length === 0) {\n throw Error(`Missing configSchema [${params?.config?.schema}][${this.name}]`)\n }\n\n const { account, config, wallet } = params ?? {}\n const { accountDerivationPath } = config ?? {}\n\n assertEx(\n !(!!account && !!wallet),\n `Specifying both {account} and {wallet} are not allowed [${config?.schema}] [${\n account === 'random' ? 'random' : account?.address\n }, ${wallet?.address}]`,\n )\n\n const schema: string = params?.config?.schema ?? this.configSchema\n const allowedSchemas: string[] = this.configSchemas\n\n assertEx(\n allowedSchemas.filter((allowedSchema) => allowedSchema === schema).length > 0,\n `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`,\n )\n const mutatedConfig: TModule['params']['config'] = { ...params?.config, schema } as TModule['params']['config']\n params?.logger?.debug(`config: ${JSON.stringify(mutatedConfig, null, 2)}`)\n const mutatedParams: TModule['params'] = { ...params, config: mutatedConfig } as TModule['params']\n\n const activeLogger = params?.logger ?? AbstractModule.defaultLogger\n const generatedAccount = await AbstractModule.determineAccount({ account, accountDerivationPath, wallet })\n const address = generatedAccount.address\n mutatedParams.logger = activeLogger ? new IdLogger(activeLogger, () => `0x${address}`) : undefined\n\n const newModule = new this(AbstractModule.privateConstructorKey, mutatedParams, generatedAccount)\n\n if (!AbstractModule.enableLazyLoad) {\n await newModule.start?.()\n }\n return newModule\n }\n\n static async determineAccount({\n account,\n accountDerivationPath,\n wallet,\n }: {\n account?: AccountInstance | 'random'\n accountDerivationPath?: string\n wallet?: WalletInstance\n }): Promise<AccountInstance> {\n if (wallet) {\n return assertEx(accountDerivationPath ? await wallet.derivePath(accountDerivationPath) : wallet, 'Failed to derive account from path')\n } else if (account === 'random') {\n return await HDWallet.random()\n } else if (account) {\n return account\n } else {\n //this should eventually be removed/thrown\n console.warn('AbstractModule.determineAccount: No account provided - Creating Random account')\n return await HDWallet.random()\n }\n }\n\n static factory<TModule extends ModuleInstance>(\n this: CreatableModule<TModule>,\n params?: Omit<TModule['params'], 'config'> & { config?: TModule['params']['config'] },\n ): CreatableModuleFactory<TModule> {\n return ModuleFactory.withParams(this, params)\n }\n\n _getRootFunction(funcName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let anyThis = this as any\n while (anyThis.__proto__[funcName]) {\n anyThis = anyThis.__proto__\n }\n return anyThis[funcName]\n }\n\n _noOverride(functionName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const thisFunc = (this as any)[functionName]\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const rootFunc = this._getRootFunction(functionName)\n assertEx(thisFunc === rootFunc, `Override not allowed for [${functionName}] - override ${functionName}Handler instead`)\n }\n\n async busy<R>(closure: () => Promise<R>) {\n if (this._busyCount <= 0) {\n this._busyCount = 0\n const args: ModuleBusyEventArgs = { busy: true, module: this }\n await this.emit('moduleBusy', args)\n }\n this._busyCount++\n try {\n return await closure()\n } finally {\n this._busyCount--\n if (this._busyCount <= 0) {\n this._busyCount = 0\n const args: ModuleBusyEventArgs = { busy: false, module: this }\n await this.emit('moduleBusy', args)\n }\n }\n }\n\n override emit<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return super.emit(eventName, eventArgs)\n }\n\n previousHash(): Promisable<string | undefined> {\n return this.account.previousHash\n }\n\n async query<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryResult> {\n this._noOverride('query')\n return await this.busy(async () => {\n const resultPayloads: Payload[] = []\n const errorPayloads: ModuleError[] = []\n const queryAccount = this.ephemeralQueryAccountEnabled ? await HDWallet.random() : undefined\n try {\n await this.started('throw')\n if (!this.allowAnonymous) {\n if (query.addresses.length === 0) {\n throw Error(`Anonymous Queries not allowed, but running anyway [${this.config.name}], [${this.address}]`)\n }\n }\n resultPayloads.push(...(await this.queryHandler(assertEx(QueryBoundWitnessWrapper.unwrap(query)), payloads, queryConfig)))\n } catch (ex) {\n await handleErrorAsync(ex, async (error) => {\n errorPayloads.push(\n new ModuleErrorBuilder()\n .sources([await PayloadHasher.hashAsync(query)])\n .name(this.config.name ?? '<Unknown>')\n .query(query.schema)\n .message(error.message)\n .build(),\n )\n })\n }\n if (this.timestamp) {\n const timestamp = { schema: 'network.xyo.timestamp', timestamp: Date.now() }\n resultPayloads.push(timestamp)\n }\n const result = await this.bindQueryResult(query, resultPayloads, queryAccount ? [queryAccount] : [], errorPayloads)\n const args: ModuleQueriedEventArgs = { module: this, payloads, query, result }\n await this.emit('moduleQueried', args)\n return result\n })\n }\n\n queryable<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): boolean {\n if (!this.started('warn')) return false\n const configValidator = queryConfig\n ? new ModuleConfigQueryValidator(Object.assign({}, this.config, queryConfig)).queryable\n : this.moduleConfigQueryValidator\n const validators = [this.supportedQueryValidator, configValidator]\n\n return validators.every((validator) => validator(query, payloads))\n }\n\n async resolve<T extends ModuleInstance = ModuleInstance>(filter?: ModuleFilter, options?: ModuleFilterOptions<T>): Promise<T[]>\n async resolve<T extends ModuleInstance = ModuleInstance>(nameOrAddress: string, options?: ModuleFilterOptions<T>): Promise<T | undefined>\n async resolve<T extends ModuleInstance = ModuleInstance>(\n nameOrAddressOrFilter?: ModuleFilter<T> | string,\n options?: ModuleFilterOptions<T>,\n ): Promise<T | T[] | undefined> {\n const direction = options?.direction ?? 'all'\n const up = direction === 'up' || direction === 'all'\n const down = direction === 'down' || direction === 'all'\n switch (typeof nameOrAddressOrFilter) {\n case 'string': {\n return (\n (down ? await (this.downResolver as CompositeModuleResolver).resolve<T>(nameOrAddressOrFilter, options) : undefined) ??\n (up ? await (this.upResolver as CompositeModuleResolver).resolve<T>(nameOrAddressOrFilter, options) : undefined)\n )\n }\n default: {\n const filter: ModuleFilter<T> | undefined = nameOrAddressOrFilter\n return [\n ...(down ? await (this.downResolver as CompositeModuleResolver).resolve<T>(filter, options) : []),\n ...(up ? await (this.upResolver as CompositeModuleResolver).resolve<T>(filter, options) : []),\n ].filter(duplicateModules)\n }\n }\n }\n\n start(_timeout?: number): Promisable<boolean> {\n //using promise as mutex\n this._startPromise = this._startPromise ?? this.startHandler()\n return this._startPromise\n }\n\n async started(notStartedAction: 'error' | 'throw' | 'warn' | 'log' | 'none' = 'log', tryStart = true): Promise<boolean> {\n const started = await this._started\n if (started === true) {\n return true\n }\n if (!started) {\n //using promise as mutex\n this._started = (async () => {\n if (tryStart) {\n try {\n await this.start()\n return true\n } catch (ex) {\n handleError(ex, (error) => {\n this.logger?.warn(`Autostart of Module Failed: ${error.message})`)\n this._started = undefined\n })\n }\n }\n switch (notStartedAction) {\n case 'throw':\n throw Error(`Module not Started [${this.address}]`)\n case 'warn':\n this.logger?.warn('Module not started')\n break\n case 'error':\n this.logger?.error('Module not started')\n break\n case 'none':\n break\n case 'log':\n default: {\n this.logger?.log('Module not started')\n break\n }\n }\n return false\n })()\n }\n if (!this._started) {\n throw 'Failed to create start promise'\n }\n return await this._started\n }\n\n async stop(_timeout?: number): Promise<boolean> {\n return await this.busy(async () => {\n const result = await this.stopHandler()\n this._started = undefined\n this._startPromise = undefined\n return result\n })\n }\n\n protected bindHashes(hashes: string[], schema: SchemaString[], account?: AccountInstance) {\n const promise = new PromiseEx((resolve) => {\n const result = this.bindHashesInternal(hashes, schema, account)\n resolve?.(result)\n return result\n }, account)\n return promise\n }\n\n protected async bindHashesInternal(hashes: string[], schema: SchemaString[], account?: AccountInstance): Promise<BoundWitness> {\n const builder = new BoundWitnessBuilder().hashes(hashes, schema).witness(this.account)\n const result = (await (account ? builder.witness(account) : builder).build())[0]\n this.logger?.debug(`result: ${JSON.stringify(result, null, 2)}`)\n return result\n }\n\n protected bindQuery<T extends Query>(\n query: T,\n payloads?: Payload[],\n account?: AccountInstance,\n ): PromiseEx<[QueryBoundWitness, Payload[], Payload[]], AccountInstance> {\n const promise = new PromiseEx<[QueryBoundWitness, Payload[], Payload[]], AccountInstance>(async (resolve) => {\n const result = await this.bindQueryInternal(query, payloads, account)\n resolve?.(result)\n return result\n }, account)\n return promise\n }\n\n protected async bindQueryInternal<T extends Query>(\n query: T,\n payloads?: Payload[],\n account?: AccountInstance,\n ): Promise<[QueryBoundWitness, Payload[], Payload[]]> {\n const builder = new QueryBoundWitnessBuilder().payloads(payloads).witness(this.account).query(query)\n const result = await (account ? builder.witness(account) : builder).build()\n return result\n }\n\n protected async bindQueryResult<T extends Query>(\n query: T,\n payloads: Payload[],\n additionalWitnesses: AccountInstance[] = [],\n errors?: ModuleError[],\n ): Promise<ModuleQueryResult> {\n const builder = new BoundWitnessBuilder().payloads(payloads).errors(errors)\n const queryWitnessAccount = this.queryAccounts[query.schema as ModuleQueryBase['schema']]\n const witnesses = [this.account, queryWitnessAccount, ...additionalWitnesses].filter(exists)\n builder.witnesses(witnesses)\n const result: ModuleQueryResult = [(await builder.build())[0], payloads, errors ?? []]\n 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","import { Base, BaseParams } from '@xyo-network/core'\nimport { EventAnyListener, EventData, EventFunctions, EventListener, Events } from '@xyo-network/module-events'\n\nexport class BaseEmitter<TParams extends BaseParams = BaseParams, TEventData extends EventData = EventData>\n extends Base<TParams>\n implements EventFunctions<TEventData>\n{\n //just here to query types\n eventData = {} as TEventData\n\n private events: Events<TEventData>\n\n constructor(params: TParams) {\n super(params)\n this.events = new Events<TEventData>()\n }\n\n clearListeners(eventNames: keyof TEventData | (keyof TEventData)[]) {\n return this.events.clearListeners(eventNames)\n }\n\n emit<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return this.events.emit(eventName, eventArgs)\n }\n\n emitSerial<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return this.events.emitSerial(eventName, eventArgs)\n }\n\n listenerCount(eventNames: keyof TEventData | (keyof TEventData)[]) {\n return this.events.listenerCount(eventNames)\n }\n\n off<TEventName extends keyof TEventData>(eventNames: TEventName | TEventName[], listener: EventListener<TEventData[TEventName]>) {\n return this.events.off(eventNames, listener)\n }\n\n offAny(listener: EventAnyListener) {\n return this.events.offAny(listener)\n }\n\n on<TEventName extends keyof TEventData>(eventNames: TEventName | TEventName[], listener: EventListener<TEventData[TEventName]>) {\n return this.events.on(eventNames, listener)\n }\n\n onAny(listener: EventAnyListener) {\n return this.events.onAny(listener)\n }\n\n once<TEventName extends keyof TEventData>(eventName: TEventName, listener: EventListener<TEventData[TEventName]>) {\n return this.events.once(eventName, listener)\n }\n}\n","import { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { ModuleError, ModuleErrorSchema } from '@xyo-network/payload-model'\n\nexport class ModuleErrorBuilder extends PayloadBuilder {\n _message?: string\n _name?: string\n _query?: string\n _sources?: string[]\n constructor() {\n super({ schema: ModuleErrorSchema })\n }\n\n override build(): ModuleError {\n return {\n message: this._message,\n name: this._name,\n query: this._query,\n schema: ModuleErrorSchema,\n sources: this._sources,\n }\n }\n\n message(message: string) {\n this._message = message\n return this\n }\n\n name(name: string) {\n this._name = name\n return this\n }\n\n query(query: string) {\n this._query = query\n return this\n }\n\n sources(sources: string[]) {\n this._sources = sources\n return this\n }\n}\n","import { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { AddressString, AnyConfigSchema, CosigningAddressSet, ModuleConfig, ModuleQuery, SchemaString } from '@xyo-network/module-model'\n\nimport { Queryable, QueryValidator } from './QueryValidator'\n\nexport type SortedPipedAddressesString = string\n\nconst delimiter = ''\n\nexport class ModuleConfigQueryValidator<TConfig extends AnyConfigSchema<ModuleConfig>> implements QueryValidator {\n protected allowed: Record<SchemaString, SortedPipedAddressesString[]> = {}\n protected disallowed: Record<SchemaString, AddressString[]> = {}\n protected readonly hasAllowedRules: boolean\n protected readonly hasDisallowedRules: boolean\n protected readonly hasRules: boolean\n\n constructor(config?: TConfig) {\n if (config?.security?.allowed) {\n Object.entries(config.security?.allowed).forEach(([schema, addresses]) => {\n this.allowed[schema] = addresses.map(toAddressesString)\n })\n }\n if (config?.security?.disallowed) {\n Object.entries(config.security?.disallowed).forEach(([schema, addresses]) => {\n this.disallowed[schema] = addresses.map(toAddressesString)\n })\n }\n this.hasAllowedRules = Object.keys(this.allowed).length > 0\n this.hasDisallowedRules = Object.keys(this.disallowed).length > 0\n this.hasRules = this.hasAllowedRules || this.hasDisallowedRules\n }\n\n queryable: Queryable = async (query, payloads) => {\n if (!this.hasRules) return true\n const addresses = query.addresses\n if (!addresses.length) return false\n const wrapper = QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)\n const schema = (await wrapper.getQuery()).schema\n return this.queryAllowed(schema, addresses) && !this.queryDisallowed(schema, addresses)\n }\n\n protected queryAllowed = (schema: SchemaString, addresses: string[]): boolean => {\n if (!this.hasAllowedRules) return true\n // All cosigners must sign\n if (addresses.length > 1) {\n const signatories = toAddressesString(addresses)\n const validCosigners = this.allowed?.[schema]?.includes(signatories)\n if (validCosigners) return true\n }\n // OR all signers have to be allowed individually\n return addresses.every((address) => this.allowed?.[schema]?.includes(address) || false)\n }\n protected queryDisallowed = (schema: SchemaString, addresses: string[]): boolean => {\n if (!this.hasDisallowedRules) return false\n return addresses.some((address) => this.disallowed?.[schema]?.includes(address))\n }\n}\n\n// TODO: Handle 0x prefix\nconst toAddressesString = (addresses: string | CosigningAddressSet): SortedPipedAddressesString => {\n return Array.isArray(addresses)\n ? addresses\n .sort()\n .map((address) => address.toLowerCase())\n .join(delimiter)\n : addresses.toLowerCase()\n}\n","import { QueryBoundWitness, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { Module, ModuleQuery } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nimport { Queryable, QueryValidator } from './QueryValidator'\n\nexport const isQuerySupportedByModule = async <T extends QueryBoundWitness = QueryBoundWitness>(\n mod: Module,\n query: T,\n payloads?: Payload[],\n): Promise<boolean> => {\n const wrapper = QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)\n const schema = (await wrapper.getQuery()).schema\n return mod.queries.includes(schema)\n}\n\nexport class SupportedQueryValidator implements QueryValidator {\n constructor(protected readonly mod: Module) {}\n queryable: Queryable = (query, payloads) => {\n return isQuerySupportedByModule(this.mod, query, payloads)\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { ModuleManifestPayload } from '@xyo-network/manifest-model'\nimport { AddressPreviousHashPayload, Module, ModuleDescriptionPayload, ModuleEventData, ModuleParams } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nimport { AbstractModule } from './AbstractModule'\n\nexport abstract class AbstractModuleInstance<TParams extends ModuleParams = ModuleParams, TEventData extends ModuleEventData = ModuleEventData>\n extends AbstractModule<TParams, TEventData>\n implements Module<TParams, TEventData>\n{\n constructor(privateConstructorKey: string, params: TParams, account: AccountInstance) {\n assertEx(AbstractModule.privateConstructorKey === privateConstructorKey, 'Use create function instead of constructor')\n // Clone params to prevent mutation of the incoming object\n const mutatedParams = { ...params } as TParams\n super(privateConstructorKey, mutatedParams, account)\n this.upResolver.add(this)\n this.downResolver.add(this)\n }\n\n describe(): Promise<ModuleDescriptionPayload> {\n return this.busy(async () => {\n return await this.describeHandler()\n })\n }\n\n discover(): Promise<Payload[]> {\n return this.busy(async () => {\n return await this.discoverHandler()\n })\n }\n\n manifest(ignoreAddresses?: string[]): Promise<ModuleManifestPayload> {\n return this.busy(async () => {\n return await this.manifestHandler(ignoreAddresses)\n })\n }\n\n moduleAddress(): Promise<AddressPreviousHashPayload[]> {\n return this.busy(async () => {\n return await this.moduleAddressHandler()\n })\n }\n\n subscribe(_queryAccount?: AccountInstance) {\n return this.subscribeHandler()\n }\n}\n"],"mappings":"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","names":["import_boundwitness_builder","import_core","import_payload_builder","BaseEmitter","Base","eventData","events","constructor","params","Events","clearListeners","eventNames","emit","eventName","eventArgs","emitSerial","listenerCount","off","listener","offAny","on","onAny","once","ModuleErrorBuilder","PayloadBuilder","_message","_name","_query","_sources","constructor","schema","ModuleErrorSchema","build","message","name","query","sources","delimiter","ModuleConfigQueryValidator","allowed","disallowed","hasAllowedRules","hasDisallowedRules","hasRules","constructor","config","security","Object","entries","forEach","schema","addresses","map","toAddressesString","keys","length","queryable","query","payloads","wrapper","QueryBoundWitnessWrapper","parseQuery","getQuery","queryAllowed","queryDisallowed","signatories","validCosigners","includes","every","address","_a","_b","some","Array","isArray","sort","toLowerCase","join","import_boundwitness_builder","isQuerySupportedByModule","mod","query","payloads","wrapper","QueryBoundWitnessWrapper","parseQuery","schema","getQuery","queries","includes","SupportedQueryValidator","constructor","queryable","AbstractModule","BaseEmitter","downResolver","CompositeModuleResolver","upResolver","_account","undefined","_baseModuleQueryAccountPaths","ModuleAddressQuerySchema","ModuleDescribeQuerySchema","ModuleDiscoverQuerySchema","ModuleManifestQuerySchema","ModuleSubscribeQuerySchema","_queryAccounts","_startPromise","_started","moduleConfigQueryValidator","supportedQueryValidator","_busyCount","constructor","privateConstructorKey","params","account","assertEx","mutatedParams","SupportedQueryValidator","queryable","ModuleConfigQueryValidator","config","configSchema","configSchemas","address","allowAnonymous","security","ephemeralQueryAccountEnabled","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","enableLazyLoad","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","Date","now","result","bindQueryResult","configValidator","Object","assign","validators","every","validator","resolve","nameOrAddressOrFilter","options","direction","up","down","duplicateModules","_timeout","startHandler","notStartedAction","tryStart","handleError","_a","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","toString","import_assert","AbstractModuleInstance","AbstractModule","constructor","privateConstructorKey","params","account","assertEx","mutatedParams","upResolver","add","downResolver","describe","busy","describeHandler","discover","discoverHandler","manifest","ignoreAddresses","manifestHandler","moduleAddress","moduleAddressHandler","subscribe","_queryAccount","subscribeHandler"]}
|
|
@@ -1,5 +1,10 @@
|
|
|
1
1
|
var __defProp = Object.defineProperty;
|
|
2
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
2
3
|
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
4
|
+
var __publicField = (obj, key, value) => {
|
|
5
|
+
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
6
|
+
return value;
|
|
7
|
+
};
|
|
3
8
|
|
|
4
9
|
// src/AbstractModule.ts
|
|
5
10
|
import { assertEx } from "@xylabs/assert";
|
|
@@ -23,10 +28,7 @@ import { IdLogger } from "@xyo-network/shared";
|
|
|
23
28
|
// src/BaseEmitter.ts
|
|
24
29
|
import { Base } from "@xyo-network/core";
|
|
25
30
|
import { Events } from "@xyo-network/module-events";
|
|
26
|
-
var
|
|
27
|
-
static {
|
|
28
|
-
__name(this, "BaseEmitter");
|
|
29
|
-
}
|
|
31
|
+
var _BaseEmitter = class _BaseEmitter extends Base {
|
|
30
32
|
//just here to query types
|
|
31
33
|
eventData = {};
|
|
32
34
|
events;
|
|
@@ -62,14 +64,13 @@ var BaseEmitter = class extends Base {
|
|
|
62
64
|
return this.events.once(eventName, listener);
|
|
63
65
|
}
|
|
64
66
|
};
|
|
67
|
+
__name(_BaseEmitter, "BaseEmitter");
|
|
68
|
+
var BaseEmitter = _BaseEmitter;
|
|
65
69
|
|
|
66
70
|
// src/Error.ts
|
|
67
71
|
import { PayloadBuilder } from "@xyo-network/payload-builder";
|
|
68
72
|
import { ModuleErrorSchema } from "@xyo-network/payload-model";
|
|
69
|
-
var
|
|
70
|
-
static {
|
|
71
|
-
__name(this, "ModuleErrorBuilder");
|
|
72
|
-
}
|
|
73
|
+
var _ModuleErrorBuilder = class _ModuleErrorBuilder extends PayloadBuilder {
|
|
73
74
|
_message;
|
|
74
75
|
_name;
|
|
75
76
|
_query;
|
|
@@ -105,27 +106,27 @@ var ModuleErrorBuilder = class extends PayloadBuilder {
|
|
|
105
106
|
return this;
|
|
106
107
|
}
|
|
107
108
|
};
|
|
109
|
+
__name(_ModuleErrorBuilder, "ModuleErrorBuilder");
|
|
110
|
+
var ModuleErrorBuilder = _ModuleErrorBuilder;
|
|
108
111
|
|
|
109
112
|
// src/QueryValidator/ModuleConfigQueryValidator.ts
|
|
110
113
|
import { QueryBoundWitnessWrapper } from "@xyo-network/boundwitness-builder";
|
|
111
114
|
var delimiter = "";
|
|
112
|
-
var
|
|
113
|
-
static {
|
|
114
|
-
__name(this, "ModuleConfigQueryValidator");
|
|
115
|
-
}
|
|
115
|
+
var _ModuleConfigQueryValidator = class _ModuleConfigQueryValidator {
|
|
116
116
|
allowed = {};
|
|
117
117
|
disallowed = {};
|
|
118
118
|
hasAllowedRules;
|
|
119
119
|
hasDisallowedRules;
|
|
120
120
|
hasRules;
|
|
121
121
|
constructor(config) {
|
|
122
|
-
|
|
123
|
-
|
|
122
|
+
var _a, _b, _c, _d;
|
|
123
|
+
if ((_a = config == null ? void 0 : config.security) == null ? void 0 : _a.allowed) {
|
|
124
|
+
Object.entries((_b = config.security) == null ? void 0 : _b.allowed).forEach(([schema, addresses]) => {
|
|
124
125
|
this.allowed[schema] = addresses.map(toAddressesString);
|
|
125
126
|
});
|
|
126
127
|
}
|
|
127
|
-
if (config
|
|
128
|
-
Object.entries(config.security
|
|
128
|
+
if ((_c = config == null ? void 0 : config.security) == null ? void 0 : _c.disallowed) {
|
|
129
|
+
Object.entries((_d = config.security) == null ? void 0 : _d.disallowed).forEach(([schema, addresses]) => {
|
|
129
130
|
this.disallowed[schema] = addresses.map(toAddressesString);
|
|
130
131
|
});
|
|
131
132
|
}
|
|
@@ -144,22 +145,31 @@ var ModuleConfigQueryValidator = class {
|
|
|
144
145
|
return this.queryAllowed(schema, addresses) && !this.queryDisallowed(schema, addresses);
|
|
145
146
|
};
|
|
146
147
|
queryAllowed = (schema, addresses) => {
|
|
148
|
+
var _a, _b;
|
|
147
149
|
if (!this.hasAllowedRules)
|
|
148
150
|
return true;
|
|
149
151
|
if (addresses.length > 1) {
|
|
150
152
|
const signatories = toAddressesString(addresses);
|
|
151
|
-
const validCosigners = this.allowed
|
|
153
|
+
const validCosigners = (_b = (_a = this.allowed) == null ? void 0 : _a[schema]) == null ? void 0 : _b.includes(signatories);
|
|
152
154
|
if (validCosigners)
|
|
153
155
|
return true;
|
|
154
156
|
}
|
|
155
|
-
return addresses.every((address) =>
|
|
157
|
+
return addresses.every((address) => {
|
|
158
|
+
var _a2, _b2;
|
|
159
|
+
return ((_b2 = (_a2 = this.allowed) == null ? void 0 : _a2[schema]) == null ? void 0 : _b2.includes(address)) || false;
|
|
160
|
+
});
|
|
156
161
|
};
|
|
157
162
|
queryDisallowed = (schema, addresses) => {
|
|
158
163
|
if (!this.hasDisallowedRules)
|
|
159
164
|
return false;
|
|
160
|
-
return addresses.some((address) =>
|
|
165
|
+
return addresses.some((address) => {
|
|
166
|
+
var _a, _b;
|
|
167
|
+
return (_b = (_a = this.disallowed) == null ? void 0 : _a[schema]) == null ? void 0 : _b.includes(address);
|
|
168
|
+
});
|
|
161
169
|
};
|
|
162
170
|
};
|
|
171
|
+
__name(_ModuleConfigQueryValidator, "ModuleConfigQueryValidator");
|
|
172
|
+
var ModuleConfigQueryValidator = _ModuleConfigQueryValidator;
|
|
163
173
|
var toAddressesString = /* @__PURE__ */ __name((addresses) => {
|
|
164
174
|
return Array.isArray(addresses) ? addresses.sort().map((address) => address.toLowerCase()).join(delimiter) : addresses.toLowerCase();
|
|
165
175
|
}, "toAddressesString");
|
|
@@ -171,10 +181,7 @@ var isQuerySupportedByModule = /* @__PURE__ */ __name(async (mod, query, payload
|
|
|
171
181
|
const schema = (await wrapper.getQuery()).schema;
|
|
172
182
|
return mod.queries.includes(schema);
|
|
173
183
|
}, "isQuerySupportedByModule");
|
|
174
|
-
var
|
|
175
|
-
static {
|
|
176
|
-
__name(this, "SupportedQueryValidator");
|
|
177
|
-
}
|
|
184
|
+
var _SupportedQueryValidator = class _SupportedQueryValidator {
|
|
178
185
|
mod;
|
|
179
186
|
constructor(mod) {
|
|
180
187
|
this.mod = mod;
|
|
@@ -184,15 +191,11 @@ var SupportedQueryValidator = class {
|
|
|
184
191
|
}
|
|
185
192
|
queryable;
|
|
186
193
|
};
|
|
194
|
+
__name(_SupportedQueryValidator, "SupportedQueryValidator");
|
|
195
|
+
var SupportedQueryValidator = _SupportedQueryValidator;
|
|
187
196
|
|
|
188
197
|
// src/AbstractModule.ts
|
|
189
|
-
var
|
|
190
|
-
static {
|
|
191
|
-
__name(this, "AbstractModule");
|
|
192
|
-
}
|
|
193
|
-
static configSchemas;
|
|
194
|
-
static enableLazyLoad = false;
|
|
195
|
-
static privateConstructorKey = Date.now().toString();
|
|
198
|
+
var _AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
196
199
|
downResolver = new CompositeModuleResolver();
|
|
197
200
|
upResolver = new CompositeModuleResolver();
|
|
198
201
|
_account = void 0;
|
|
@@ -223,7 +226,7 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
223
226
|
super(mutatedParams);
|
|
224
227
|
this._account = account;
|
|
225
228
|
this.supportedQueryValidator = new SupportedQueryValidator(this).queryable;
|
|
226
|
-
this.moduleConfigQueryValidator = new ModuleConfigQueryValidator(mutatedParams
|
|
229
|
+
this.moduleConfigQueryValidator = new ModuleConfigQueryValidator(mutatedParams == null ? void 0 : mutatedParams.config).queryable;
|
|
227
230
|
}
|
|
228
231
|
static get configSchema() {
|
|
229
232
|
return this.configSchemas[0];
|
|
@@ -235,7 +238,8 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
235
238
|
return this.account.address;
|
|
236
239
|
}
|
|
237
240
|
get allowAnonymous() {
|
|
238
|
-
|
|
241
|
+
var _a;
|
|
242
|
+
return !!((_a = this.config.security) == null ? void 0 : _a.allowAnonymous);
|
|
239
243
|
}
|
|
240
244
|
get config() {
|
|
241
245
|
return this.params.config;
|
|
@@ -277,26 +281,27 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
277
281
|
assertEx(thisFunc === rootFunc, `Override not allowed for [${functionName}] - override ${functionName}Handler instead`);
|
|
278
282
|
}
|
|
279
283
|
static async create(params) {
|
|
284
|
+
var _a, _b, _c, _d;
|
|
280
285
|
this._noOverride("create");
|
|
281
286
|
if (!this.configSchemas || this.configSchemas.length === 0) {
|
|
282
|
-
throw Error(`Missing configSchema [${params
|
|
287
|
+
throw Error(`Missing configSchema [${(_a = params == null ? void 0 : params.config) == null ? void 0 : _a.schema}][${this.name}]`);
|
|
283
288
|
}
|
|
284
289
|
const { account, config, wallet } = params ?? {};
|
|
285
290
|
const { accountDerivationPath } = config ?? {};
|
|
286
|
-
assertEx(!(!!account && !!wallet), `Specifying both {account} and {wallet} are not allowed [${config
|
|
287
|
-
const schema = params
|
|
291
|
+
assertEx(!(!!account && !!wallet), `Specifying both {account} and {wallet} are not allowed [${config == null ? void 0 : config.schema}] [${account === "random" ? "random" : account == null ? void 0 : account.address}, ${wallet == null ? void 0 : wallet.address}]`);
|
|
292
|
+
const schema = ((_b = params == null ? void 0 : params.config) == null ? void 0 : _b.schema) ?? this.configSchema;
|
|
288
293
|
const allowedSchemas = this.configSchemas;
|
|
289
294
|
assertEx(allowedSchemas.filter((allowedSchema) => allowedSchema === schema).length > 0, `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`);
|
|
290
295
|
const mutatedConfig = {
|
|
291
|
-
...params
|
|
296
|
+
...params == null ? void 0 : params.config,
|
|
292
297
|
schema
|
|
293
298
|
};
|
|
294
|
-
params
|
|
299
|
+
(_c = params == null ? void 0 : params.logger) == null ? void 0 : _c.debug(`config: ${JSON.stringify(mutatedConfig, null, 2)}`);
|
|
295
300
|
const mutatedParams = {
|
|
296
301
|
...params,
|
|
297
302
|
config: mutatedConfig
|
|
298
303
|
};
|
|
299
|
-
const activeLogger = params
|
|
304
|
+
const activeLogger = (params == null ? void 0 : params.logger) ?? _AbstractModule.defaultLogger;
|
|
300
305
|
const generatedAccount = await _AbstractModule.determineAccount({
|
|
301
306
|
account,
|
|
302
307
|
accountDerivationPath,
|
|
@@ -306,7 +311,7 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
306
311
|
mutatedParams.logger = activeLogger ? new IdLogger(activeLogger, () => `0x${address}`) : void 0;
|
|
307
312
|
const newModule = new this(_AbstractModule.privateConstructorKey, mutatedParams, generatedAccount);
|
|
308
313
|
if (!_AbstractModule.enableLazyLoad) {
|
|
309
|
-
await newModule.start
|
|
314
|
+
await ((_d = newModule.start) == null ? void 0 : _d.call(newModule));
|
|
310
315
|
}
|
|
311
316
|
return newModule;
|
|
312
317
|
}
|
|
@@ -419,7 +424,7 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
419
424
|
return validators.every((validator) => validator(query, payloads));
|
|
420
425
|
}
|
|
421
426
|
async resolve(nameOrAddressOrFilter, options) {
|
|
422
|
-
const direction = options
|
|
427
|
+
const direction = (options == null ? void 0 : options.direction) ?? "all";
|
|
423
428
|
const up = direction === "up" || direction === "all";
|
|
424
429
|
const down = direction === "down" || direction === "all";
|
|
425
430
|
switch (typeof nameOrAddressOrFilter) {
|
|
@@ -446,13 +451,15 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
446
451
|
}
|
|
447
452
|
if (!started) {
|
|
448
453
|
this._started = (async () => {
|
|
454
|
+
var _a, _b, _c;
|
|
449
455
|
if (tryStart) {
|
|
450
456
|
try {
|
|
451
457
|
await this.start();
|
|
452
458
|
return true;
|
|
453
459
|
} catch (ex) {
|
|
454
460
|
handleError(ex, (error) => {
|
|
455
|
-
|
|
461
|
+
var _a2;
|
|
462
|
+
(_a2 = this.logger) == null ? void 0 : _a2.warn(`Autostart of Module Failed: ${error.message})`);
|
|
456
463
|
this._started = void 0;
|
|
457
464
|
});
|
|
458
465
|
}
|
|
@@ -461,16 +468,16 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
461
468
|
case "throw":
|
|
462
469
|
throw Error(`Module not Started [${this.address}]`);
|
|
463
470
|
case "warn":
|
|
464
|
-
this.logger
|
|
471
|
+
(_a = this.logger) == null ? void 0 : _a.warn("Module not started");
|
|
465
472
|
break;
|
|
466
473
|
case "error":
|
|
467
|
-
this.logger
|
|
474
|
+
(_b = this.logger) == null ? void 0 : _b.error("Module not started");
|
|
468
475
|
break;
|
|
469
476
|
case "none":
|
|
470
477
|
break;
|
|
471
478
|
case "log":
|
|
472
479
|
default: {
|
|
473
|
-
this.logger
|
|
480
|
+
(_c = this.logger) == null ? void 0 : _c.log("Module not started");
|
|
474
481
|
break;
|
|
475
482
|
}
|
|
476
483
|
}
|
|
@@ -493,21 +500,22 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
493
500
|
bindHashes(hashes, schema, account) {
|
|
494
501
|
const promise = new PromiseEx((resolve) => {
|
|
495
502
|
const result = this.bindHashesInternal(hashes, schema, account);
|
|
496
|
-
resolve
|
|
503
|
+
resolve == null ? void 0 : resolve(result);
|
|
497
504
|
return result;
|
|
498
505
|
}, account);
|
|
499
506
|
return promise;
|
|
500
507
|
}
|
|
501
508
|
async bindHashesInternal(hashes, schema, account) {
|
|
509
|
+
var _a;
|
|
502
510
|
const builder = new BoundWitnessBuilder().hashes(hashes, schema).witness(this.account);
|
|
503
511
|
const result = (await (account ? builder.witness(account) : builder).build())[0];
|
|
504
|
-
this.logger
|
|
512
|
+
(_a = this.logger) == null ? void 0 : _a.debug(`result: ${JSON.stringify(result, null, 2)}`);
|
|
505
513
|
return result;
|
|
506
514
|
}
|
|
507
515
|
bindQuery(query, payloads, account) {
|
|
508
516
|
const promise = new PromiseEx(async (resolve) => {
|
|
509
517
|
const result = await this.bindQueryInternal(query, payloads, account);
|
|
510
|
-
resolve
|
|
518
|
+
resolve == null ? void 0 : resolve(result);
|
|
511
519
|
return result;
|
|
512
520
|
}, account);
|
|
513
521
|
return promise;
|
|
@@ -535,28 +543,30 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
535
543
|
}
|
|
536
544
|
commitArchivist = () => this.getArchivist("commit");
|
|
537
545
|
async describeHandler() {
|
|
546
|
+
var _a;
|
|
538
547
|
const description = {
|
|
539
548
|
address: this.address,
|
|
540
549
|
queries: this.queries,
|
|
541
550
|
schema: ModuleDescriptionSchema
|
|
542
551
|
};
|
|
543
|
-
if (this.config
|
|
552
|
+
if ((_a = this.config) == null ? void 0 : _a.name) {
|
|
544
553
|
description.name = this.config.name;
|
|
545
554
|
}
|
|
546
555
|
const discover = await this.discoverHandler();
|
|
547
|
-
description.children = compact(discover
|
|
556
|
+
description.children = compact((discover == null ? void 0 : discover.map((payload) => {
|
|
548
557
|
const address = payload.schema === AddressSchema ? payload.address : void 0;
|
|
549
558
|
return address != this.address ? address : void 0;
|
|
550
|
-
}) ?? []);
|
|
559
|
+
})) ?? []);
|
|
551
560
|
return description;
|
|
552
561
|
}
|
|
553
562
|
discoverHandler() {
|
|
563
|
+
var _a;
|
|
554
564
|
const config = this.config;
|
|
555
565
|
const address = new PayloadBuilder2({
|
|
556
566
|
schema: AddressSchema
|
|
557
567
|
}).fields({
|
|
558
568
|
address: this.address,
|
|
559
|
-
name: this.config
|
|
569
|
+
name: (_a = this.config) == null ? void 0 : _a.name
|
|
560
570
|
}).build();
|
|
561
571
|
const queries = this.queries.map((query) => {
|
|
562
572
|
return new PayloadBuilder2({
|
|
@@ -577,24 +587,26 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
577
587
|
]);
|
|
578
588
|
}
|
|
579
589
|
async getArchivist(kind) {
|
|
590
|
+
var _a, _b;
|
|
580
591
|
if (!this.config.archivist)
|
|
581
592
|
return void 0;
|
|
582
|
-
const filter = typeof this.config.archivist === "string" || this.config.archivist instanceof String ? this.config.archivist : this.config
|
|
593
|
+
const filter = typeof this.config.archivist === "string" || this.config.archivist instanceof String ? this.config.archivist : (_b = (_a = this.config) == null ? void 0 : _a.archivist) == null ? void 0 : _b[kind];
|
|
583
594
|
const resolved = await this.upResolver.resolve(filter);
|
|
584
595
|
return asArchivistInstance(resolved);
|
|
585
596
|
}
|
|
586
597
|
async initializeQueryAccounts() {
|
|
598
|
+
var _a, _b;
|
|
587
599
|
const paths = Object.values(this.queryAccountPaths).filter(exists);
|
|
588
600
|
const distinctPaths = new Set(paths);
|
|
589
|
-
assertEx(distinctPaths.size === paths.length, `${this.config
|
|
601
|
+
assertEx(distinctPaths.size === paths.length, `${((_a = this.config) == null ? void 0 : _a.name) ? this.config.name + ": " : ""}Duplicate query account paths`);
|
|
590
602
|
const wallet = this.account;
|
|
591
|
-
if (wallet
|
|
603
|
+
if (wallet == null ? void 0 : wallet.derivePath) {
|
|
592
604
|
for (const key in this.queryAccountPaths) {
|
|
593
605
|
if (Object.prototype.hasOwnProperty.call(this.queryAccountPaths, key)) {
|
|
594
606
|
const query = key;
|
|
595
607
|
const queryAccountPath = this.queryAccountPaths[query];
|
|
596
608
|
if (queryAccountPath) {
|
|
597
|
-
this._queryAccounts[query] = await wallet.derivePath
|
|
609
|
+
this._queryAccounts[query] = await ((_b = wallet.derivePath) == null ? void 0 : _b.call(wallet, queryAccountPath));
|
|
598
610
|
}
|
|
599
611
|
}
|
|
600
612
|
}
|
|
@@ -702,9 +714,10 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
702
714
|
}
|
|
703
715
|
validateConfig(config, parents = []) {
|
|
704
716
|
return Object.entries(config ?? this.config ?? {}).reduce((valid, [key, value]) => {
|
|
717
|
+
var _a, _b;
|
|
705
718
|
switch (typeof value) {
|
|
706
719
|
case "function":
|
|
707
|
-
this.logger
|
|
720
|
+
(_a = this.logger) == null ? void 0 : _a.warn(`Fields of type function not allowed in config [${parents == null ? void 0 : parents.join(".")}.${key}]`);
|
|
708
721
|
return false;
|
|
709
722
|
case "object": {
|
|
710
723
|
if (Array.isArray(value)) {
|
|
@@ -716,7 +729,7 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
716
729
|
}, true) && valid;
|
|
717
730
|
}
|
|
718
731
|
if (!serializableField(value)) {
|
|
719
|
-
this.logger
|
|
732
|
+
(_b = this.logger) == null ? void 0 : _b.warn(`Fields that are not serializable to JSON are not allowed in config [${parents == null ? void 0 : parents.join(".")}.${key}]`);
|
|
720
733
|
return false;
|
|
721
734
|
}
|
|
722
735
|
return value ? this.validateConfig(value, [
|
|
@@ -731,13 +744,15 @@ var AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
731
744
|
}
|
|
732
745
|
writeArchivist = () => this.getArchivist("write");
|
|
733
746
|
};
|
|
747
|
+
__name(_AbstractModule, "AbstractModule");
|
|
748
|
+
__publicField(_AbstractModule, "configSchemas");
|
|
749
|
+
__publicField(_AbstractModule, "enableLazyLoad", false);
|
|
750
|
+
__publicField(_AbstractModule, "privateConstructorKey", Date.now().toString());
|
|
751
|
+
var AbstractModule = _AbstractModule;
|
|
734
752
|
|
|
735
753
|
// src/AbstractModuleInstance.ts
|
|
736
754
|
import { assertEx as assertEx2 } from "@xylabs/assert";
|
|
737
|
-
var
|
|
738
|
-
static {
|
|
739
|
-
__name(this, "AbstractModuleInstance");
|
|
740
|
-
}
|
|
755
|
+
var _AbstractModuleInstance = class _AbstractModuleInstance extends AbstractModule {
|
|
741
756
|
constructor(privateConstructorKey, params, account) {
|
|
742
757
|
assertEx2(AbstractModule.privateConstructorKey === privateConstructorKey, "Use create function instead of constructor");
|
|
743
758
|
const mutatedParams = {
|
|
@@ -771,6 +786,8 @@ var AbstractModuleInstance = class extends AbstractModule {
|
|
|
771
786
|
return this.subscribeHandler();
|
|
772
787
|
}
|
|
773
788
|
};
|
|
789
|
+
__name(_AbstractModuleInstance, "AbstractModuleInstance");
|
|
790
|
+
var AbstractModuleInstance = _AbstractModuleInstance;
|
|
774
791
|
export {
|
|
775
792
|
AbstractModule,
|
|
776
793
|
AbstractModuleInstance,
|