@xyo-network/module-abstract 2.84.5 → 2.84.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/AbstractModule.d.cts.map +1 -1
- package/dist/browser/AbstractModule.d.mts.map +1 -1
- package/dist/browser/AbstractModule.d.ts.map +1 -1
- package/dist/browser/index.cjs +36 -28
- package/dist/browser/index.cjs.map +1 -1
- package/dist/browser/index.js +36 -28
- package/dist/browser/index.js.map +1 -1
- package/dist/node/AbstractModule.d.cts.map +1 -1
- package/dist/node/AbstractModule.d.mts.map +1 -1
- package/dist/node/AbstractModule.d.ts.map +1 -1
- package/dist/node/index.cjs +36 -28
- package/dist/node/index.cjs.map +1 -1
- package/dist/node/index.js +36 -28
- package/dist/node/index.js.map +1 -1
- package/package.json +20 -20
- package/src/AbstractModule.ts +24 -20
- package/src/QueryValidator/ModuleConfigQueryValidator.ts +5 -5
package/dist/node/index.cjs
CHANGED
|
@@ -173,14 +173,14 @@ var _ModuleConfigQueryValidator = class _ModuleConfigQueryValidator {
|
|
|
173
173
|
constructor(config) {
|
|
174
174
|
var _a, _b, _c, _d;
|
|
175
175
|
if ((_a = config == null ? void 0 : config.security) == null ? void 0 : _a.allowed) {
|
|
176
|
-
Object.entries((_b = config.security) == null ? void 0 : _b.allowed)
|
|
176
|
+
for (const [schema, addresses] of Object.entries((_b = config.security) == null ? void 0 : _b.allowed)) {
|
|
177
177
|
this.allowed[schema] = addresses.map(toAddressesString);
|
|
178
|
-
}
|
|
178
|
+
}
|
|
179
179
|
}
|
|
180
180
|
if ((_c = config == null ? void 0 : config.security) == null ? void 0 : _c.disallowed) {
|
|
181
|
-
Object.entries((_d = config.security) == null ? void 0 : _d.disallowed)
|
|
181
|
+
for (const [schema, addresses] of Object.entries((_d = config.security) == null ? void 0 : _d.disallowed)) {
|
|
182
182
|
this.disallowed[schema] = addresses.map(toAddressesString);
|
|
183
|
-
}
|
|
183
|
+
}
|
|
184
184
|
}
|
|
185
185
|
this.hasAllowedRules = Object.keys(this.allowed).length > 0;
|
|
186
186
|
this.hasDisallowedRules = Object.keys(this.disallowed).length > 0;
|
|
@@ -190,7 +190,7 @@ var _ModuleConfigQueryValidator = class _ModuleConfigQueryValidator {
|
|
|
190
190
|
if (!this.hasRules)
|
|
191
191
|
return true;
|
|
192
192
|
const addresses = query.addresses;
|
|
193
|
-
if (
|
|
193
|
+
if (addresses.length === 0)
|
|
194
194
|
return false;
|
|
195
195
|
const wrapper = import_boundwitness_builder.QueryBoundWitnessWrapper.parseQuery(query, payloads);
|
|
196
196
|
const schema = (await wrapper.getQuery()).schema;
|
|
@@ -336,14 +336,14 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
336
336
|
var _a, _b, _c, _d;
|
|
337
337
|
this._noOverride("create");
|
|
338
338
|
if (!this.configSchemas || this.configSchemas.length === 0) {
|
|
339
|
-
throw Error(`Missing configSchema [${(_a = params == null ? void 0 : params.config) == null ? void 0 : _a.schema}][${this.name}]`);
|
|
339
|
+
throw new Error(`Missing configSchema [${(_a = params == null ? void 0 : params.config) == null ? void 0 : _a.schema}][${this.name}]`);
|
|
340
340
|
}
|
|
341
341
|
const { account, config, wallet } = params ?? {};
|
|
342
342
|
const { accountDerivationPath } = config ?? {};
|
|
343
343
|
(0, import_assert2.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}]`);
|
|
344
344
|
const schema = ((_b = params == null ? void 0 : params.config) == null ? void 0 : _b.schema) ?? this.configSchema;
|
|
345
345
|
const allowedSchemas = this.configSchemas;
|
|
346
|
-
(0, import_assert2.assertEx)(allowedSchemas.
|
|
346
|
+
(0, import_assert2.assertEx)(allowedSchemas.includes(schema), `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`);
|
|
347
347
|
const mutatedConfig = {
|
|
348
348
|
...params == null ? void 0 : params.config,
|
|
349
349
|
schema
|
|
@@ -424,10 +424,8 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
424
424
|
const queryAccount = this.ephemeralQueryAccountEnabled ? import_account2.Account.randomSync() : void 0;
|
|
425
425
|
try {
|
|
426
426
|
await this.started("throw");
|
|
427
|
-
if (!this.allowAnonymous) {
|
|
428
|
-
|
|
429
|
-
throw Error(`Anonymous Queries not allowed, but running anyway [${this.config.name}], [${this.address}]`);
|
|
430
|
-
}
|
|
427
|
+
if (!this.allowAnonymous && query.addresses.length === 0) {
|
|
428
|
+
throw new Error(`Anonymous Queries not allowed, but running anyway [${this.config.name}], [${this.address}]`);
|
|
431
429
|
}
|
|
432
430
|
resultPayloads.push(...await this.queryHandler((0, import_assert2.assertEx)(import_boundwitness_builder3.QueryBoundWitnessWrapper.unwrap(query)), payloads, queryConfig));
|
|
433
431
|
} catch (ex) {
|
|
@@ -509,17 +507,20 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
509
507
|
}
|
|
510
508
|
}
|
|
511
509
|
switch (notStartedAction) {
|
|
512
|
-
case "throw":
|
|
513
|
-
throw Error(`Module not Started [${this.address}]`);
|
|
514
|
-
|
|
510
|
+
case "throw": {
|
|
511
|
+
throw new Error(`Module not Started [${this.address}]`);
|
|
512
|
+
}
|
|
513
|
+
case "warn": {
|
|
515
514
|
(_a = this.logger) == null ? void 0 : _a.warn("Module not started");
|
|
516
515
|
break;
|
|
517
|
-
|
|
516
|
+
}
|
|
517
|
+
case "error": {
|
|
518
518
|
(_b = this.logger) == null ? void 0 : _b.error("Module not started");
|
|
519
519
|
break;
|
|
520
|
-
|
|
520
|
+
}
|
|
521
|
+
case "none": {
|
|
521
522
|
break;
|
|
522
|
-
|
|
523
|
+
}
|
|
523
524
|
default: {
|
|
524
525
|
(_c = this.logger) == null ? void 0 : _c.log("Module not started");
|
|
525
526
|
break;
|
|
@@ -602,7 +603,7 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
602
603
|
const discover = await this.discoverHandler();
|
|
603
604
|
description.children = (0, import_lodash.compact)((discover == null ? void 0 : discover.map((payload) => {
|
|
604
605
|
const address = payload.schema === import_address_payload_plugin.AddressSchema ? payload.address : void 0;
|
|
605
|
-
return address
|
|
606
|
+
return address == this.address ? void 0 : address;
|
|
606
607
|
})) ?? []);
|
|
607
608
|
return description;
|
|
608
609
|
}
|
|
@@ -633,6 +634,7 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
633
634
|
...queries
|
|
634
635
|
]);
|
|
635
636
|
}
|
|
637
|
+
// eslint-disable-next-line import/no-deprecated
|
|
636
638
|
async getArchivist(kind) {
|
|
637
639
|
var _a, _b;
|
|
638
640
|
if (!this.config.archivist)
|
|
@@ -744,8 +746,9 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
744
746
|
this.subscribeHandler();
|
|
745
747
|
break;
|
|
746
748
|
}
|
|
747
|
-
default:
|
|
748
|
-
throw Error(`Unsupported Query [${queryPayload.schema}]`);
|
|
749
|
+
default: {
|
|
750
|
+
throw new Error(`Unsupported Query [${queryPayload.schema}]`);
|
|
751
|
+
}
|
|
749
752
|
}
|
|
750
753
|
return resultPayloads;
|
|
751
754
|
}
|
|
@@ -782,17 +785,21 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
782
785
|
return Object.entries(config ?? this.config ?? {}).reduce((valid, [key, value]) => {
|
|
783
786
|
var _a, _b;
|
|
784
787
|
switch (typeof value) {
|
|
785
|
-
case "function":
|
|
788
|
+
case "function": {
|
|
786
789
|
(_a = this.logger) == null ? void 0 : _a.warn(`Fields of type function not allowed in config [${parents == null ? void 0 : parents.join(".")}.${key}]`);
|
|
787
790
|
return false;
|
|
791
|
+
}
|
|
788
792
|
case "object": {
|
|
789
793
|
if (Array.isArray(value)) {
|
|
790
|
-
return
|
|
791
|
-
|
|
792
|
-
|
|
793
|
-
|
|
794
|
-
|
|
795
|
-
|
|
794
|
+
return (
|
|
795
|
+
// eslint-disable-next-line unicorn/no-array-reduce
|
|
796
|
+
value.reduce((valid2, value2) => {
|
|
797
|
+
return this.validateConfig(value2, [
|
|
798
|
+
...parents,
|
|
799
|
+
key
|
|
800
|
+
]) && valid2;
|
|
801
|
+
}, true) && valid
|
|
802
|
+
);
|
|
796
803
|
}
|
|
797
804
|
if (!(0, import_module_model.serializableField)(value)) {
|
|
798
805
|
(_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}]`);
|
|
@@ -803,8 +810,9 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
803
810
|
key
|
|
804
811
|
]) && valid : true;
|
|
805
812
|
}
|
|
806
|
-
default:
|
|
813
|
+
default: {
|
|
807
814
|
return valid;
|
|
815
|
+
}
|
|
808
816
|
}
|
|
809
817
|
}, true);
|
|
810
818
|
}
|
package/dist/node/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/AbstractModule.ts","../../src/BaseEmitter.ts","../../src/determineAccount.ts","../../src/Error.ts","../../src/QueryValidator/ModuleConfigQueryValidator.ts","../../src/QueryValidator/SupportedQueryValidator.ts","../../src/AbstractModuleInstance.ts"],"sourcesContent":["export * from './AbstractModule'\nexport * from './AbstractModuleInstance'\nexport * from './BaseEmitter'\nexport * from './Error'\nexport * from './QueryValidator'\n","/* eslint-disable max-lines */\nimport { assertEx } from '@xylabs/assert'\nimport { handleError, handleErrorAsync } from '@xylabs/error'\nimport { exists } from '@xylabs/exists'\nimport { compact } from '@xylabs/lodash'\nimport { IdLogger } from '@xylabs/logger'\nimport { Promisable, PromiseEx } from '@xylabs/promise'\nimport { Account, HDWallet } from '@xyo-network/account'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { AddressPayload, AddressSchema } from '@xyo-network/address-payload-plugin'\nimport { ArchivistInstance, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitnessBuilder, QueryBoundWitnessBuilder, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { ConfigPayload, ConfigSchema } from '@xyo-network/config-payload-plugin'\nimport { PayloadHasher } from '@xyo-network/hash'\nimport { ModuleManifestPayload, ModuleManifestPayloadSchema } from '@xyo-network/manifest-model'\nimport {\n AddressPreviousHashPayload,\n AddressPreviousHashSchema,\n CreatableModule,\n CreatableModuleFactory,\n duplicateModules,\n 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 { QueryPayload, QuerySchema } from '@xyo-network/query-payload-plugin'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nimport { BaseEmitter } from './BaseEmitter'\nimport { determineAccount } from './determineAccount'\nimport { ModuleErrorBuilder } from './Error'\nimport { ModuleConfigQueryValidator, Queryable, SupportedQueryValidator } from './QueryValidator'\n\nexport abstract class AbstractModule<TParams extends ModuleParams = ModuleParams, TEventData extends ModuleEventData = ModuleEventData>\n extends BaseEmitter<TParams, TEventData>\n implements Module<TParams, TEventData>\n{\n static configSchemas: string[]\n static enableLazyLoad = false\n\n protected static privateConstructorKey = Date.now().toString()\n\n readonly downResolver: Omit<CompositeModuleResolver, 'resolve'> = new CompositeModuleResolver()\n readonly upResolver: Omit<CompositeModuleResolver, 'resolve>'> = new CompositeModuleResolver()\n\n protected _account: AccountInstance | undefined = undefined\n protected readonly _baseModuleQueryAccountPaths: Record<ModuleQueryBase['schema'], string> = {\n [ModuleAddressQuerySchema]: '1',\n [ModuleDescribeQuerySchema]: '4',\n [ModuleDiscoverQuerySchema]: '2',\n [ModuleManifestQuerySchema]: '5',\n [ModuleSubscribeQuerySchema]: '3',\n }\n protected readonly _queryAccounts: Record<ModuleQueryBase['schema'], AccountInstance | undefined> = {\n [ModuleAddressQuerySchema]: undefined,\n [ModuleDescribeQuerySchema]: undefined,\n [ModuleDiscoverQuerySchema]: undefined,\n [ModuleManifestQuerySchema]: undefined,\n [ModuleSubscribeQuerySchema]: undefined,\n }\n protected _startPromise: Promisable<boolean> | undefined = undefined\n protected _started: Promisable<boolean> | undefined = undefined\n protected readonly moduleConfigQueryValidator: Queryable\n protected readonly supportedQueryValidator: Queryable\n\n private _busyCount = 0\n\n constructor(privateConstructorKey: string, params: TParams, account: AccountInstance) {\n assertEx(AbstractModule.privateConstructorKey === privateConstructorKey, 'Use create function instead of constructor')\n // Clone params to prevent mutation of the incoming object\n const mutatedParams = { ...params } as TParams\n super(mutatedParams)\n\n this._account = account\n\n this.supportedQueryValidator = new SupportedQueryValidator(this as Module).queryable\n this.moduleConfigQueryValidator = new ModuleConfigQueryValidator(mutatedParams?.config).queryable\n }\n\n static get configSchema(): string {\n return this.configSchemas[0]\n }\n\n get account() {\n return assertEx(this._account, 'Missing account')\n }\n\n get address() {\n return this.account.address\n }\n\n get allowAnonymous() {\n return !!this.config.security?.allowAnonymous\n }\n\n get config(): TParams['config'] {\n return this.params.config\n }\n\n get ephemeralQueryAccountEnabled(): boolean {\n return !!this.params.ephemeralQueryAccountEnabled\n }\n\n get queries(): string[] {\n return [ModuleDiscoverQuerySchema, ModuleAddressQuerySchema, ModuleSubscribeQuerySchema, ModuleDescribeQuerySchema, ModuleManifestQuerySchema]\n }\n\n get queryAccountPaths(): Readonly<Record<Query['schema'], string | undefined>> {\n return { ...this._baseModuleQueryAccountPaths, ...this._queryAccountPaths }\n }\n\n get queryAccounts(): Readonly<Record<Query['schema'], AccountInstance | undefined>> {\n return this._queryAccounts\n }\n\n get timestamp() {\n return this.config.timestamp ?? false\n }\n\n protected abstract get _queryAccountPaths(): Record<Query['schema'], string>\n\n static _getRootFunction(funcName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let anyThis = this as any\n while (anyThis.__proto__[funcName]) {\n anyThis = anyThis.__proto__\n }\n return anyThis[funcName]\n }\n\n static _noOverride(functionName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const thisFunc = (this as any)[functionName]\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const rootFunc = this._getRootFunction(functionName)\n assertEx(thisFunc === rootFunc, `Override not allowed for [${functionName}] - override ${functionName}Handler instead`)\n }\n\n static async create<TModule extends ModuleInstance>(\n this: CreatableModule<TModule>,\n params?: Omit<TModule['params'], 'config'> & { config?: TModule['params']['config'] },\n ) {\n this._noOverride('create')\n if (!this.configSchemas || this.configSchemas.length === 0) {\n throw Error(`Missing configSchema [${params?.config?.schema}][${this.name}]`)\n }\n\n const { account, config, wallet } = params ?? {}\n const { accountDerivationPath } = config ?? {}\n\n assertEx(\n !(!!account && !!wallet),\n `Specifying both {account} and {wallet} are not allowed [${config?.schema}] [${\n account === 'random' ? 'random' : account?.address\n }, ${wallet?.address}]`,\n )\n\n const schema: string = params?.config?.schema ?? this.configSchema\n const allowedSchemas: string[] = this.configSchemas\n\n assertEx(\n allowedSchemas.filter((allowedSchema) => allowedSchema === schema).length > 0,\n `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`,\n )\n const mutatedConfig: TModule['params']['config'] = { ...params?.config, schema } as TModule['params']['config']\n params?.logger?.debug(`config: ${JSON.stringify(mutatedConfig, null, 2)}`)\n const mutatedParams: TModule['params'] = { ...params, config: mutatedConfig } as TModule['params']\n\n const activeLogger = params?.logger ?? AbstractModule.defaultLogger\n const generatedAccount = await AbstractModule.determineAccount({ account, accountDerivationPath, wallet })\n const address = generatedAccount.address\n mutatedParams.logger = activeLogger ? new IdLogger(activeLogger, () => `0x${address}`) : undefined\n\n const newModule = new this(AbstractModule.privateConstructorKey, mutatedParams, generatedAccount)\n\n if (!AbstractModule.enableLazyLoad) {\n await newModule.start?.()\n }\n return newModule\n }\n\n static async determineAccount(params: {\n account?: AccountInstance | 'random'\n accountDerivationPath?: string\n wallet?: WalletInstance\n }): Promise<AccountInstance> {\n return await determineAccount(params)\n }\n\n static factory<TModule extends ModuleInstance>(\n this: CreatableModule<TModule>,\n params?: Omit<TModule['params'], 'config'> & { config?: TModule['params']['config'] },\n ): CreatableModuleFactory<TModule> {\n return ModuleFactory.withParams(this, params)\n }\n\n _getRootFunction(funcName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let anyThis = this as any\n while (anyThis.__proto__[funcName]) {\n anyThis = anyThis.__proto__\n }\n return anyThis[funcName]\n }\n\n _noOverride(functionName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const thisFunc = (this as any)[functionName]\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const rootFunc = this._getRootFunction(functionName)\n assertEx(thisFunc === rootFunc, `Override not allowed for [${functionName}] - override ${functionName}Handler instead`)\n }\n\n async busy<R>(closure: () => Promise<R>) {\n if (this._busyCount <= 0) {\n this._busyCount = 0\n const args: ModuleBusyEventArgs = { busy: true, module: this }\n await this.emit('moduleBusy', args)\n }\n this._busyCount++\n try {\n return await closure()\n } finally {\n this._busyCount--\n if (this._busyCount <= 0) {\n this._busyCount = 0\n const args: ModuleBusyEventArgs = { busy: false, module: this }\n await this.emit('moduleBusy', args)\n }\n }\n }\n\n override emit<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return super.emit(eventName, eventArgs)\n }\n\n previousHash(): Promisable<string | undefined> {\n return this.account.previousHash\n }\n\n async query<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryResult> {\n this._noOverride('query')\n const sourceQuery = await PayloadHasher.hashAsync(query)\n return await this.busy(async () => {\n const resultPayloads: Payload[] = []\n const errorPayloads: ModuleError[] = []\n const queryAccount = this.ephemeralQueryAccountEnabled ? Account.randomSync() : 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 await new ModuleErrorBuilder()\n .sources([await PayloadHasher.hashAsync(query)])\n .name(this.config.name ?? '<Unknown>')\n .query(query.schema)\n .message(error.message)\n .build(),\n )\n })\n }\n if (this.timestamp) {\n const timestamp = { schema: 'network.xyo.timestamp', timestamp: Date.now() }\n resultPayloads.push(timestamp)\n }\n const result = await this.bindQueryResult(query, resultPayloads, sourceQuery, queryAccount ? [queryAccount] : [], errorPayloads)\n const args: ModuleQueriedEventArgs = { module: this, payloads, query, result }\n await this.emit('moduleQueried', args)\n return result\n })\n }\n\n queryable<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): boolean {\n if (!this.started('warn')) return false\n const configValidator = queryConfig\n ? new ModuleConfigQueryValidator(Object.assign({}, this.config, queryConfig)).queryable\n : this.moduleConfigQueryValidator\n const validators = [this.supportedQueryValidator, configValidator]\n\n return validators.every((validator) => validator(query, payloads))\n }\n\n async resolve<T extends ModuleInstance = ModuleInstance>(filter?: ModuleFilter, options?: ModuleFilterOptions<T>): Promise<T[]>\n async resolve<T extends ModuleInstance = ModuleInstance>(nameOrAddress: string, options?: ModuleFilterOptions<T>): Promise<T | undefined>\n async resolve<T extends ModuleInstance = ModuleInstance>(\n nameOrAddressOrFilter?: ModuleFilter<T> | string,\n options?: ModuleFilterOptions<T>,\n ): Promise<T | T[] | undefined> {\n const direction = options?.direction ?? 'all'\n const up = direction === 'up' || direction === 'all'\n const down = direction === 'down' || direction === 'all'\n switch (typeof nameOrAddressOrFilter) {\n case 'string': {\n return (\n (down ? await (this.downResolver as CompositeModuleResolver).resolve<T>(nameOrAddressOrFilter, options) : undefined) ??\n (up ? await (this.upResolver as CompositeModuleResolver).resolve<T>(nameOrAddressOrFilter, options) : undefined)\n )\n }\n default: {\n const filter: ModuleFilter<T> | undefined = nameOrAddressOrFilter\n return [\n ...(down ? await (this.downResolver as CompositeModuleResolver).resolve<T>(filter, options) : []),\n ...(up ? await (this.upResolver as CompositeModuleResolver).resolve<T>(filter, options) : []),\n ].filter(duplicateModules)\n }\n }\n }\n\n start(_timeout?: number): Promisable<boolean> {\n //using promise as mutex\n this._startPromise = this._startPromise ?? this.startHandler()\n return this._startPromise\n }\n\n async started(notStartedAction: 'error' | 'throw' | 'warn' | 'log' | 'none' = 'log', tryStart = true): Promise<boolean> {\n const started = await this._started\n if (started === true) {\n return true\n }\n if (!started) {\n //using promise as mutex\n this._started = (async () => {\n if (tryStart) {\n try {\n await this.start()\n return true\n } catch (ex) {\n handleError(ex, (error) => {\n this.logger?.warn(`Autostart of Module Failed: ${error.message})`)\n this._started = undefined\n })\n }\n }\n switch (notStartedAction) {\n case 'throw':\n throw Error(`Module not Started [${this.address}]`)\n case 'warn':\n this.logger?.warn('Module not started')\n break\n case 'error':\n this.logger?.error('Module not started')\n break\n case 'none':\n break\n case 'log':\n default: {\n this.logger?.log('Module not started')\n break\n }\n }\n return false\n })()\n }\n if (!this._started) {\n throw 'Failed to create start promise'\n }\n return await this._started\n }\n\n async stop(_timeout?: number): Promise<boolean> {\n return await this.busy(async () => {\n const result = await this.stopHandler()\n this._started = undefined\n this._startPromise = undefined\n return result\n })\n }\n\n protected bindHashes(hashes: string[], schema: SchemaString[], account?: AccountInstance) {\n const promise = new PromiseEx((resolve) => {\n const result = this.bindHashesInternal(hashes, schema, account)\n resolve?.(result)\n return result\n }, account)\n return promise\n }\n\n protected async bindHashesInternal(hashes: string[], schema: SchemaString[], account?: AccountInstance): Promise<BoundWitness> {\n const builder = new BoundWitnessBuilder().hashes(hashes, schema).witness(this.account)\n const result = (await (account ? builder.witness(account) : builder).build())[0]\n this.logger?.debug(`result: ${JSON.stringify(result, null, 2)}`)\n return result\n }\n\n protected bindQuery<T extends Query>(\n query: T,\n payloads?: Payload[],\n account?: AccountInstance,\n ): PromiseEx<[QueryBoundWitness, Payload[], Payload[]], AccountInstance> {\n const promise = new PromiseEx<[QueryBoundWitness, Payload[], Payload[]], AccountInstance>(async (resolve) => {\n const result = await this.bindQueryInternal(query, payloads, account)\n resolve?.(result)\n return result\n }, account)\n return promise\n }\n\n protected async bindQueryInternal<T extends Query>(\n query: T,\n payloads?: Payload[],\n account?: AccountInstance,\n ): Promise<[QueryBoundWitness, Payload[], Payload[]]> {\n const builder = new QueryBoundWitnessBuilder().payloads(payloads).witness(this.account).query(query)\n const result = await (account ? builder.witness(account) : builder).build()\n return result\n }\n\n protected async bindQueryResult<T extends Query>(\n query: T,\n payloads: Payload[],\n sourceQuery?: string,\n additionalWitnesses: AccountInstance[] = [],\n errors?: ModuleError[],\n ): Promise<ModuleQueryResult> {\n const builder = new BoundWitnessBuilder().payloads(payloads).errors(errors).sourceQuery(sourceQuery)\n const queryWitnessAccount = this.queryAccounts[query.schema as ModuleQueryBase['schema']]\n const witnesses = [this.account, queryWitnessAccount, ...additionalWitnesses].filter(exists)\n builder.witnesses(witnesses)\n const result: ModuleQueryResult = [(await builder.build())[0], payloads, errors ?? []]\n if (this.config.archiving) {\n await this.storeToArchivists(result.flat())\n }\n return result\n }\n\n protected commitArchivist = () => this.getArchivist('commit')\n\n protected async describeHandler(): Promise<ModuleDescriptionPayload> {\n const description: ModuleDescriptionPayload = {\n address: this.address,\n queries: this.queries,\n schema: ModuleDescriptionSchema,\n }\n if (this.config?.name) {\n description.name = this.config.name\n }\n\n const discover = await this.discoverHandler()\n\n description.children = compact(\n discover?.map((payload) => {\n const address = payload.schema === AddressSchema ? (payload as AddressPayload).address : undefined\n return address != this.address ? address : undefined\n }) ?? [],\n )\n\n return description\n }\n\n protected async discoverHandler(_maxDepth?: number): Promise<Payload[]> {\n const config = this.config\n const address = await new PayloadBuilder<AddressPayload>({ schema: AddressSchema })\n .fields({ address: this.address, name: this.config?.name })\n .build()\n const queries = await Promise.all(\n this.queries.map(async (query) => {\n return await new PayloadBuilder<QueryPayload>({ schema: QuerySchema }).fields({ query }).build()\n }),\n )\n const configSchema: ConfigPayload = {\n config: config.schema,\n schema: ConfigSchema,\n }\n return compact([config, configSchema, address, ...queries])\n }\n\n protected async getArchivist(kind: keyof IndividualArchivistConfig): Promise<ArchivistInstance | undefined> {\n if (!this.config.archivist) return undefined\n const filter =\n typeof this.config.archivist === 'string' || this.config.archivist instanceof String\n ? (this.config.archivist as string)\n : (this.config?.archivist?.[kind] as string)\n const resolved = await this.upResolver.resolve(filter)\n return asArchivistInstance(resolved)\n }\n\n protected async initializeQueryAccounts() {\n // Ensure distinct/unique wallet paths\n const paths = Object.values(this.queryAccountPaths).filter(exists)\n const distinctPaths = new Set<string>(paths)\n assertEx(distinctPaths.size === paths.length, `${this.config?.name ? this.config.name + ': ' : ''}Duplicate query account paths`)\n // Create an account for query this module supports\n const wallet = this.account as unknown as HDWallet\n if (wallet?.derivePath) {\n for (const key in this.queryAccountPaths) {\n if (Object.prototype.hasOwnProperty.call(this.queryAccountPaths, key)) {\n const query = key as ModuleQueryBase['schema']\n const queryAccountPath = this.queryAccountPaths[query]\n if (queryAccountPath) {\n this._queryAccounts[query] = await wallet.derivePath?.(queryAccountPath)\n }\n }\n }\n }\n }\n\n protected manifestHandler(_depth?: number, _ignoreAddresses?: string[]): Promisable<ModuleManifestPayload> {\n const name = this.config.name ?? 'Anonymous'\n return { config: { name, ...this.config }, schema: ModuleManifestPayloadSchema, status: { address: this.address } }\n }\n\n protected moduleAddressHandler(): Promisable<AddressPreviousHashPayload[]> {\n // Return array of all addresses and their previous hash\n const queryAccounts = Object.entries(this.queryAccounts)\n .filter((value): value is [string, AccountInstance] => {\n return exists(value[1])\n })\n .map(([name, account]) => {\n const address = account.address\n const previousHash = account.previousHash\n return [\n { address, name, schema: AddressSchema },\n { address, previousHash, schema: AddressPreviousHashSchema },\n ]\n })\n const address = this.address\n const name = this.config.name\n const previousHash = this.address\n const moduleAccount = name ? { address, name, schema: AddressSchema } : { address, schema: AddressSchema }\n const moduleAccountPreviousHash = previousHash\n ? { address, previousHash, schema: AddressPreviousHashSchema }\n : { address, schema: AddressPreviousHashSchema }\n return [moduleAccount, moduleAccountPreviousHash, ...queryAccounts].flat()\n }\n\n protected async queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryHandlerResult> {\n await this.started('throw')\n const wrapper = QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n switch (queryPayload.schema) {\n case ModuleManifestQuerySchema: {\n resultPayloads.push(await this.manifestHandler(queryPayload.maxDepth))\n break\n }\n case ModuleDiscoverQuerySchema: {\n const { maxDepth } = queryPayload\n resultPayloads.push(...(await this.discoverHandler(maxDepth)))\n break\n }\n case ModuleDescribeQuerySchema: {\n resultPayloads.push(await this.describeHandler())\n break\n }\n case ModuleAddressQuerySchema: {\n resultPayloads.push(...(await this.moduleAddressHandler()))\n break\n }\n case ModuleSubscribeQuerySchema: {\n this.subscribeHandler()\n break\n }\n default:\n throw Error(`Unsupported Query [${(queryPayload as Payload).schema}]`)\n }\n return resultPayloads\n }\n\n protected readArchivist = () => this.getArchivist('read')\n\n protected async resolveArchivingArchivists(): Promise<ArchivistInstance[]> {\n const archivists = this.config.archiving?.archivists\n if (!archivists) return []\n const resolved = await Promise.all(archivists.map((archivist) => this.resolve(archivist)))\n return compact(resolved.map((mod) => asArchivistInstance(mod)))\n }\n\n protected async startHandler(): Promise<boolean> {\n this.validateConfig()\n await this.initializeQueryAccounts()\n this._started = true\n return true\n }\n\n protected stopHandler(_timeout?: number): Promisable<boolean> {\n this._started = undefined\n return true\n }\n\n protected async storeToArchivists(payloads: Payload[]): Promise<Payload[]> {\n const archivists = await this.resolveArchivingArchivists()\n return (\n await Promise.all(\n archivists.map((archivist) => {\n return archivist.insert?.(payloads)\n }),\n )\n ).map(([bw]) => bw)\n }\n\n protected subscribeHandler() {\n return\n }\n\n protected validateConfig(config?: unknown, parents: string[] = []): boolean {\n return Object.entries(config ?? this.config ?? {}).reduce((valid, [key, value]) => {\n switch (typeof value) {\n case 'function':\n this.logger?.warn(`Fields of type function not allowed in config [${parents?.join('.')}.${key}]`)\n return false\n case 'object': {\n if (Array.isArray(value)) {\n return (\n value.reduce((valid, value) => {\n return this.validateConfig(value, [...parents, key]) && valid\n }, true) && valid\n )\n }\n\n if (!serializableField(value)) {\n this.logger?.warn(`Fields that are not serializable to JSON are not allowed in config [${parents?.join('.')}.${key}]`)\n return false\n }\n return value ? this.validateConfig(value, [...parents, key]) && valid : true\n }\n default:\n return valid\n }\n }, true)\n }\n\n protected writeArchivist = () => this.getArchivist('write')\n}\n","import { EventAnyListener, EventData, EventFunctions, EventListener, Events } from '@xyo-network/module-events'\nimport { Base, BaseParams } from '@xyo-network/object'\n\nexport class BaseEmitter<TParams extends BaseParams = BaseParams, TEventData extends EventData = EventData>\n extends Base<TParams>\n implements EventFunctions<TEventData>\n{\n //just here to query types\n eventData = {} as TEventData\n\n private events: Events<TEventData>\n\n constructor(params: TParams) {\n super(params)\n this.events = new Events<TEventData>()\n }\n\n clearListeners(eventNames: keyof TEventData | (keyof TEventData)[]) {\n return this.events.clearListeners(eventNames)\n }\n\n emit<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return this.events.emit(eventName, eventArgs)\n }\n\n emitSerial<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return this.events.emitSerial(eventName, eventArgs)\n }\n\n listenerCount(eventNames: keyof TEventData | (keyof TEventData)[]) {\n return this.events.listenerCount(eventNames)\n }\n\n off<TEventName extends keyof TEventData>(eventNames: TEventName | TEventName[], listener: EventListener<TEventData[TEventName]>) {\n return this.events.off(eventNames, listener)\n }\n\n offAny(listener: EventAnyListener) {\n return this.events.offAny(listener)\n }\n\n on<TEventName extends keyof TEventData>(eventNames: TEventName | TEventName[], listener: EventListener<TEventData[TEventName]>) {\n return this.events.on(eventNames, listener)\n }\n\n onAny(listener: EventAnyListener) {\n return this.events.onAny(listener)\n }\n\n once<TEventName extends keyof TEventData>(eventName: TEventName, listener: EventListener<TEventData[TEventName]>) {\n return this.events.once(eventName, listener)\n }\n}\n","/* eslint-disable max-lines */\nimport { assertEx } from '@xylabs/assert'\nimport { Account } from '@xyo-network/account'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nexport interface DetermineAccountFromAccountParams {\n account: AccountInstance | 'random'\n}\n\nexport interface DetermineAccountFromWalletParams {\n accountDerivationPath?: string\n wallet: WalletInstance\n}\n\nexport interface DetermineRandomParams {}\n\nexport type DetermineAccountParams = DetermineAccountFromAccountParams | DetermineAccountFromWalletParams | DetermineRandomParams\n\nconst isDetermineAccountFromAccountParams = (params: DetermineAccountParams): params is DetermineAccountFromAccountParams => {\n assertEx(!(params as DetermineAccountFromWalletParams).accountDerivationPath, 'accountDerivationPath may not be provided when account is provided')\n return !!(params as DetermineAccountFromAccountParams).account\n}\n\nconst isDetermineAccountFromWalletParams = (params: DetermineAccountParams): params is DetermineAccountFromWalletParams => {\n return !!(params as DetermineAccountFromWalletParams).wallet\n}\n\nexport async function determineAccount(params: DetermineAccountParams): Promise<AccountInstance> {\n if (isDetermineAccountFromAccountParams(params)) {\n return params.account === 'random' ? Account.randomSync() : params.account\n }\n\n if (isDetermineAccountFromWalletParams(params)) {\n return assertEx(\n params.accountDerivationPath ? await params.wallet.derivePath(params.accountDerivationPath) : params.wallet,\n 'Failed to derive account from path',\n )\n }\n\n //this should eventually be removed/thrown\n console.warn('AbstractModule.determineAccount: No account or wallet provided - Creating Random account')\n return Account.randomSync()\n}\n","import { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { ModuleError, ModuleErrorSchema } from '@xyo-network/payload-model'\n\nexport class ModuleErrorBuilder extends PayloadBuilder<ModuleError> {\n _message?: string\n _name?: string\n _query?: string\n _sources?: string[]\n constructor() {\n super({ schema: ModuleErrorSchema })\n }\n\n override build(): Promise<ModuleError> {\n return Promise.resolve({\n message: this._message,\n name: this._name,\n query: this._query,\n schema: ModuleErrorSchema,\n sources: this._sources,\n })\n }\n\n message(message: string) {\n this._message = message\n return this\n }\n\n name(name: string) {\n this._name = name\n return this\n }\n\n query(query: string) {\n this._query = query\n return this\n }\n\n sources(sources: string[]) {\n this._sources = sources\n return this\n }\n}\n","import { Address } from '@xylabs/hex'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { AnyConfigSchema, CosigningAddressSet, ModuleConfig, ModuleQuery, SchemaString } from '@xyo-network/module-model'\n\nimport { Queryable, QueryValidator } from './QueryValidator'\n\nexport type SortedPipedAddressesString = string\n\nconst delimiter = ''\n\nexport class ModuleConfigQueryValidator<TConfig extends AnyConfigSchema<ModuleConfig>> implements QueryValidator {\n protected allowed: Record<SchemaString, SortedPipedAddressesString[]> = {}\n protected disallowed: Record<SchemaString, Address[]> = {}\n protected readonly hasAllowedRules: boolean\n protected readonly hasDisallowedRules: boolean\n protected readonly hasRules: boolean\n\n constructor(config?: TConfig) {\n if (config?.security?.allowed) {\n Object.entries(config.security?.allowed).forEach(([schema, addresses]) => {\n this.allowed[schema] = addresses.map(toAddressesString)\n })\n }\n if (config?.security?.disallowed) {\n Object.entries(config.security?.disallowed).forEach(([schema, addresses]) => {\n this.disallowed[schema] = addresses.map(toAddressesString)\n })\n }\n this.hasAllowedRules = Object.keys(this.allowed).length > 0\n this.hasDisallowedRules = Object.keys(this.disallowed).length > 0\n this.hasRules = this.hasAllowedRules || this.hasDisallowedRules\n }\n\n queryable: Queryable = async (query, payloads) => {\n if (!this.hasRules) return true\n const addresses = query.addresses\n if (!addresses.length) return false\n const wrapper = QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)\n const schema = (await wrapper.getQuery()).schema\n return this.queryAllowed(schema, addresses) && !this.queryDisallowed(schema, addresses)\n }\n\n protected queryAllowed = (schema: SchemaString, addresses: string[]): boolean => {\n if (!this.hasAllowedRules) return true\n // All cosigners must sign\n if (addresses.length > 1) {\n const signatories = toAddressesString(addresses)\n const validCosigners = this.allowed?.[schema]?.includes(signatories)\n if (validCosigners) return true\n }\n // OR all signers have to be allowed individually\n return addresses.every((address) => this.allowed?.[schema]?.includes(address) || false)\n }\n protected queryDisallowed = (schema: SchemaString, addresses: string[]): boolean => {\n if (!this.hasDisallowedRules) return false\n return addresses.some((address) => this.disallowed?.[schema]?.includes(address))\n }\n}\n\n// TODO: Handle 0x prefix\nconst toAddressesString = (addresses: string | CosigningAddressSet): SortedPipedAddressesString => {\n return Array.isArray(addresses)\n ? addresses\n .sort()\n .map((address) => address.toLowerCase())\n .join(delimiter)\n : addresses.toLowerCase()\n}\n","import { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { Module, ModuleQuery } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nimport { Queryable, QueryValidator } from './QueryValidator'\n\nexport const isQuerySupportedByModule = async <T extends QueryBoundWitness = QueryBoundWitness>(\n mod: Module,\n query: T,\n payloads?: Payload[],\n): Promise<boolean> => {\n const wrapper = QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)\n const schema = (await wrapper.getQuery()).schema\n return mod.queries.includes(schema)\n}\n\nexport class SupportedQueryValidator implements QueryValidator {\n constructor(protected readonly mod: Module) {}\n queryable: Queryable = (query, payloads) => {\n return isQuerySupportedByModule(this.mod, query, payloads)\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { ModuleManifestPayload } from '@xyo-network/manifest-model'\nimport { AddressPreviousHashPayload, Module, ModuleDescriptionPayload, ModuleEventData, ModuleParams } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nimport { AbstractModule } from './AbstractModule'\n\nexport abstract class AbstractModuleInstance<TParams extends ModuleParams = ModuleParams, TEventData extends ModuleEventData = ModuleEventData>\n extends AbstractModule<TParams, TEventData>\n implements Module<TParams, TEventData>\n{\n constructor(privateConstructorKey: string, params: TParams, account: AccountInstance) {\n assertEx(AbstractModule.privateConstructorKey === privateConstructorKey, 'Use create function instead of constructor')\n // Clone params to prevent mutation of the incoming object\n const mutatedParams = { ...params } as TParams\n super(privateConstructorKey, mutatedParams, account)\n this.upResolver.add(this)\n this.downResolver.add(this)\n }\n\n describe(): Promise<ModuleDescriptionPayload> {\n return this.busy(async () => {\n return await this.describeHandler()\n })\n }\n\n discover(): Promise<Payload[]> {\n return this.busy(async () => {\n return await this.discoverHandler()\n })\n }\n\n manifest(maxDepth?: number, ignoreAddresses?: string[]): Promise<ModuleManifestPayload> {\n return this.busy(async () => {\n return await this.manifestHandler(maxDepth, ignoreAddresses)\n })\n }\n\n moduleAddress(): Promise<AddressPreviousHashPayload[]> {\n return this.busy(async () => {\n return await this.moduleAddressHandler()\n })\n }\n\n subscribe(_queryAccount?: AccountInstance) {\n return this.subscribeHandler()\n }\n}\n"],"mappings":"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","names":["import_assert","import_account","import_boundwitness_builder","import_payload_builder","BaseEmitter","Base","eventData","events","constructor","params","Events","clearListeners","eventNames","emit","eventName","eventArgs","emitSerial","listenerCount","off","listener","offAny","on","onAny","once","isDetermineAccountFromAccountParams","params","assertEx","accountDerivationPath","account","isDetermineAccountFromWalletParams","wallet","determineAccount","Account","randomSync","derivePath","console","warn","ModuleErrorBuilder","PayloadBuilder","_message","_name","_query","_sources","constructor","schema","ModuleErrorSchema","build","Promise","resolve","message","name","query","sources","delimiter","ModuleConfigQueryValidator","allowed","disallowed","hasAllowedRules","hasDisallowedRules","hasRules","constructor","config","security","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","factory","ModuleFactory","withParams","busy","closure","args","module","emit","eventName","eventArgs","previousHash","query","payloads","queryConfig","sourceQuery","PayloadHasher","hashAsync","resultPayloads","errorPayloads","queryAccount","Account","randomSync","started","addresses","push","queryHandler","QueryBoundWitnessWrapper","unwrap","ex","handleErrorAsync","error","ModuleErrorBuilder","sources","message","build","Date","now","result","bindQueryResult","configValidator","Object","assign","validators","every","validator","resolve","nameOrAddressOrFilter","options","direction","up","down","duplicateModules","_timeout","startHandler","notStartedAction","tryStart","handleError","_a","warn","log","stop","stopHandler","bindHashes","hashes","promise","PromiseEx","bindHashesInternal","builder","BoundWitnessBuilder","witness","bindQuery","bindQueryInternal","QueryBoundWitnessBuilder","additionalWitnesses","errors","queryWitnessAccount","witnesses","exists","archiving","storeToArchivists","flat","commitArchivist","getArchivist","describeHandler","description","ModuleDescriptionSchema","discover","discoverHandler","children","compact","map","payload","AddressSchema","_maxDepth","PayloadBuilder","fields","Promise","all","QuerySchema","ConfigSchema","kind","archivist","String","resolved","asArchivistInstance","initializeQueryAccounts","paths","values","distinctPaths","Set","size","derivePath","key","prototype","hasOwnProperty","call","queryAccountPath","manifestHandler","_depth","_ignoreAddresses","ModuleManifestPayloadSchema","status","moduleAddressHandler","entries","value","AddressPreviousHashSchema","moduleAccount","moduleAccountPreviousHash","wrapper","parseQuery","queryPayload","getQuery","maxDepth","subscribeHandler","readArchivist","resolveArchivingArchivists","archivists","mod","validateConfig","insert","bw","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","maxDepth","ignoreAddresses","manifestHandler","moduleAddress","moduleAddressHandler","subscribe","_queryAccount","subscribeHandler"]}
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/AbstractModule.ts","../../src/BaseEmitter.ts","../../src/determineAccount.ts","../../src/Error.ts","../../src/QueryValidator/ModuleConfigQueryValidator.ts","../../src/QueryValidator/SupportedQueryValidator.ts","../../src/AbstractModuleInstance.ts"],"sourcesContent":["export * from './AbstractModule'\nexport * from './AbstractModuleInstance'\nexport * from './BaseEmitter'\nexport * from './Error'\nexport * from './QueryValidator'\n","/* eslint-disable max-lines */\nimport { assertEx } from '@xylabs/assert'\nimport { handleError, handleErrorAsync } from '@xylabs/error'\nimport { exists } from '@xylabs/exists'\nimport { compact } from '@xylabs/lodash'\nimport { IdLogger } from '@xylabs/logger'\nimport { Promisable, PromiseEx } from '@xylabs/promise'\nimport { Account, HDWallet } from '@xyo-network/account'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { AddressPayload, AddressSchema } from '@xyo-network/address-payload-plugin'\nimport { ArchivistInstance, asArchivistInstance } from '@xyo-network/archivist-model'\nimport { BoundWitnessBuilder, QueryBoundWitnessBuilder, QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { ConfigPayload, ConfigSchema } from '@xyo-network/config-payload-plugin'\nimport { PayloadHasher } from '@xyo-network/hash'\nimport { ModuleManifestPayload, ModuleManifestPayloadSchema } from '@xyo-network/manifest-model'\nimport {\n AddressPreviousHashPayload,\n AddressPreviousHashSchema,\n CreatableModule,\n CreatableModuleFactory,\n duplicateModules,\n 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 { QueryPayload, QuerySchema } from '@xyo-network/query-payload-plugin'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nimport { BaseEmitter } from './BaseEmitter'\nimport { determineAccount } from './determineAccount'\nimport { ModuleErrorBuilder } from './Error'\nimport { ModuleConfigQueryValidator, Queryable, SupportedQueryValidator } from './QueryValidator'\n\nexport abstract class AbstractModule<TParams extends ModuleParams = ModuleParams, TEventData extends ModuleEventData = ModuleEventData>\n extends BaseEmitter<TParams, TEventData>\n implements Module<TParams, TEventData>\n{\n static 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 new 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(allowedSchemas.includes(schema), `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`)\n const mutatedConfig: TModule['params']['config'] = { ...params?.config, schema } as TModule['params']['config']\n params?.logger?.debug(`config: ${JSON.stringify(mutatedConfig, null, 2)}`)\n const mutatedParams: TModule['params'] = { ...params, config: mutatedConfig } as TModule['params']\n\n const activeLogger = params?.logger ?? AbstractModule.defaultLogger\n const generatedAccount = await AbstractModule.determineAccount({ account, accountDerivationPath, wallet })\n const address = generatedAccount.address\n mutatedParams.logger = activeLogger ? new IdLogger(activeLogger, () => `0x${address}`) : undefined\n\n const newModule = new this(AbstractModule.privateConstructorKey, mutatedParams, generatedAccount)\n\n if (!AbstractModule.enableLazyLoad) {\n await newModule.start?.()\n }\n return newModule\n }\n\n static async determineAccount(params: {\n account?: AccountInstance | 'random'\n accountDerivationPath?: string\n wallet?: WalletInstance\n }): Promise<AccountInstance> {\n return await determineAccount(params)\n }\n\n static factory<TModule extends ModuleInstance>(\n this: CreatableModule<TModule>,\n params?: Omit<TModule['params'], 'config'> & { config?: TModule['params']['config'] },\n ): CreatableModuleFactory<TModule> {\n return ModuleFactory.withParams(this, params)\n }\n\n _getRootFunction(funcName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let anyThis = this as any\n while (anyThis.__proto__[funcName]) {\n anyThis = anyThis.__proto__\n }\n return anyThis[funcName]\n }\n\n _noOverride(functionName: string) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const thisFunc = (this as any)[functionName]\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const rootFunc = this._getRootFunction(functionName)\n assertEx(thisFunc === rootFunc, `Override not allowed for [${functionName}] - override ${functionName}Handler instead`)\n }\n\n async busy<R>(closure: () => Promise<R>) {\n if (this._busyCount <= 0) {\n this._busyCount = 0\n const args: ModuleBusyEventArgs = { busy: true, module: this }\n await this.emit('moduleBusy', args)\n }\n this._busyCount++\n try {\n return await closure()\n } finally {\n this._busyCount--\n if (this._busyCount <= 0) {\n this._busyCount = 0\n const args: ModuleBusyEventArgs = { busy: false, module: this }\n await this.emit('moduleBusy', args)\n }\n }\n }\n\n override emit<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return super.emit(eventName, eventArgs)\n }\n\n previousHash(): Promisable<string | undefined> {\n return this.account.previousHash\n }\n\n async query<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryResult> {\n this._noOverride('query')\n const sourceQuery = await PayloadHasher.hashAsync(query)\n return await this.busy(async () => {\n const resultPayloads: Payload[] = []\n const errorPayloads: ModuleError[] = []\n const queryAccount = this.ephemeralQueryAccountEnabled ? Account.randomSync() : undefined\n try {\n await this.started('throw')\n if (!this.allowAnonymous && query.addresses.length === 0) {\n throw new Error(`Anonymous Queries not allowed, but running anyway [${this.config.name}], [${this.address}]`)\n }\n resultPayloads.push(...(await this.queryHandler(assertEx(QueryBoundWitnessWrapper.unwrap(query)), payloads, queryConfig)))\n } catch (ex) {\n await handleErrorAsync(ex, async (error) => {\n errorPayloads.push(\n await new ModuleErrorBuilder()\n .sources([await PayloadHasher.hashAsync(query)])\n .name(this.config.name ?? '<Unknown>')\n .query(query.schema)\n .message(error.message)\n .build(),\n )\n })\n }\n if (this.timestamp) {\n const timestamp = { schema: 'network.xyo.timestamp', timestamp: Date.now() }\n resultPayloads.push(timestamp)\n }\n const result = await this.bindQueryResult(query, resultPayloads, sourceQuery, queryAccount ? [queryAccount] : [], errorPayloads)\n const args: ModuleQueriedEventArgs = { module: this, payloads, query, result }\n await this.emit('moduleQueried', args)\n return result\n })\n }\n\n queryable<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): boolean {\n if (!this.started('warn')) return false\n const configValidator = queryConfig\n ? new ModuleConfigQueryValidator(Object.assign({}, this.config, queryConfig)).queryable\n : this.moduleConfigQueryValidator\n const validators = [this.supportedQueryValidator, configValidator]\n\n return validators.every((validator) => validator(query, payloads))\n }\n\n async resolve<T extends ModuleInstance = ModuleInstance>(filter?: ModuleFilter, options?: ModuleFilterOptions<T>): Promise<T[]>\n async resolve<T extends ModuleInstance = ModuleInstance>(nameOrAddress: string, options?: ModuleFilterOptions<T>): Promise<T | undefined>\n async resolve<T extends ModuleInstance = ModuleInstance>(\n nameOrAddressOrFilter?: ModuleFilter<T> | string,\n options?: ModuleFilterOptions<T>,\n ): Promise<T | T[] | undefined> {\n const direction = options?.direction ?? 'all'\n const up = direction === 'up' || direction === 'all'\n const down = direction === 'down' || direction === 'all'\n switch (typeof nameOrAddressOrFilter) {\n case 'string': {\n return (\n (down ? await (this.downResolver as CompositeModuleResolver).resolve<T>(nameOrAddressOrFilter, options) : undefined) ??\n (up ? await (this.upResolver as CompositeModuleResolver).resolve<T>(nameOrAddressOrFilter, options) : undefined)\n )\n }\n default: {\n const filter: ModuleFilter<T> | undefined = nameOrAddressOrFilter\n return [\n ...(down ? await (this.downResolver as CompositeModuleResolver).resolve<T>(filter, options) : []),\n ...(up ? await (this.upResolver as CompositeModuleResolver).resolve<T>(filter, options) : []),\n ].filter(duplicateModules)\n }\n }\n }\n\n start(_timeout?: number): Promisable<boolean> {\n //using promise as mutex\n this._startPromise = this._startPromise ?? this.startHandler()\n return this._startPromise\n }\n\n async started(notStartedAction: 'error' | 'throw' | 'warn' | 'log' | 'none' = 'log', tryStart = true): Promise<boolean> {\n const started = await this._started\n if (started === true) {\n return true\n }\n if (!started) {\n //using promise as mutex\n this._started = (async () => {\n if (tryStart) {\n try {\n await this.start()\n return true\n } catch (ex) {\n handleError(ex, (error) => {\n this.logger?.warn(`Autostart of Module Failed: ${error.message})`)\n this._started = undefined\n })\n }\n }\n switch (notStartedAction) {\n case 'throw': {\n throw new Error(`Module not Started [${this.address}]`)\n }\n case 'warn': {\n this.logger?.warn('Module not started')\n break\n }\n case 'error': {\n this.logger?.error('Module not started')\n break\n }\n case 'none': {\n break\n }\n default: {\n this.logger?.log('Module not started')\n break\n }\n }\n return false\n })()\n }\n if (!this._started) {\n throw 'Failed to create start promise'\n }\n return await this._started\n }\n\n async stop(_timeout?: number): Promise<boolean> {\n return await this.busy(async () => {\n const result = await this.stopHandler()\n this._started = undefined\n this._startPromise = undefined\n return result\n })\n }\n\n protected bindHashes(hashes: string[], schema: SchemaString[], account?: AccountInstance) {\n const promise = new PromiseEx((resolve) => {\n const result = this.bindHashesInternal(hashes, schema, account)\n resolve?.(result)\n return result\n }, account)\n return promise\n }\n\n protected async bindHashesInternal(hashes: string[], schema: SchemaString[], account?: AccountInstance): Promise<BoundWitness> {\n const builder = new BoundWitnessBuilder().hashes(hashes, schema).witness(this.account)\n const result = (await (account ? builder.witness(account) : builder).build())[0]\n this.logger?.debug(`result: ${JSON.stringify(result, null, 2)}`)\n return result\n }\n\n protected bindQuery<T extends Query>(\n query: T,\n payloads?: Payload[],\n account?: AccountInstance,\n ): PromiseEx<[QueryBoundWitness, Payload[], Payload[]], AccountInstance> {\n const promise = new PromiseEx<[QueryBoundWitness, Payload[], Payload[]], AccountInstance>(async (resolve) => {\n const result = await this.bindQueryInternal(query, payloads, account)\n resolve?.(result)\n return result\n }, account)\n return promise\n }\n\n protected async bindQueryInternal<T extends Query>(\n query: T,\n payloads?: Payload[],\n account?: AccountInstance,\n ): Promise<[QueryBoundWitness, Payload[], Payload[]]> {\n const builder = new QueryBoundWitnessBuilder().payloads(payloads).witness(this.account).query(query)\n const result = await (account ? builder.witness(account) : builder).build()\n return result\n }\n\n protected async bindQueryResult<T extends Query>(\n query: T,\n payloads: Payload[],\n sourceQuery?: string,\n additionalWitnesses: AccountInstance[] = [],\n errors?: ModuleError[],\n ): Promise<ModuleQueryResult> {\n const builder = new BoundWitnessBuilder().payloads(payloads).errors(errors).sourceQuery(sourceQuery)\n const queryWitnessAccount = this.queryAccounts[query.schema as ModuleQueryBase['schema']]\n const witnesses = [this.account, queryWitnessAccount, ...additionalWitnesses].filter(exists)\n builder.witnesses(witnesses)\n const result: ModuleQueryResult = [(await builder.build())[0], payloads, errors ?? []]\n if (this.config.archiving) {\n await this.storeToArchivists(result.flat())\n }\n return result\n }\n\n protected 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 ? undefined : address\n }) ?? [],\n )\n\n return description\n }\n\n protected async discoverHandler(_maxDepth?: number): Promise<Payload[]> {\n const config = this.config\n const address = await new PayloadBuilder<AddressPayload>({ schema: AddressSchema })\n .fields({ address: this.address, name: this.config?.name })\n .build()\n const queries = await Promise.all(\n this.queries.map(async (query) => {\n return await new PayloadBuilder<QueryPayload>({ schema: QuerySchema }).fields({ query }).build()\n }),\n )\n const configSchema: ConfigPayload = {\n config: config.schema,\n schema: ConfigSchema,\n }\n return compact([config, configSchema, address, ...queries])\n }\n\n // eslint-disable-next-line import/no-deprecated\n protected async getArchivist(kind: keyof IndividualArchivistConfig): Promise<ArchivistInstance | undefined> {\n if (!this.config.archivist) return undefined\n const filter =\n typeof this.config.archivist === 'string' || this.config.archivist instanceof String\n ? (this.config.archivist as string)\n : (this.config?.archivist?.[kind] as string)\n const resolved = await this.upResolver.resolve(filter)\n return asArchivistInstance(resolved)\n }\n\n protected async initializeQueryAccounts() {\n // Ensure distinct/unique wallet paths\n const paths = Object.values(this.queryAccountPaths).filter(exists)\n const distinctPaths = new Set<string>(paths)\n assertEx(distinctPaths.size === paths.length, `${this.config?.name ? this.config.name + ': ' : ''}Duplicate query account paths`)\n // Create an account for query this module supports\n const wallet = this.account as unknown as HDWallet\n if (wallet?.derivePath) {\n for (const key in this.queryAccountPaths) {\n if (Object.prototype.hasOwnProperty.call(this.queryAccountPaths, key)) {\n const query = key as ModuleQueryBase['schema']\n const queryAccountPath = this.queryAccountPaths[query]\n if (queryAccountPath) {\n this._queryAccounts[query] = await wallet.derivePath?.(queryAccountPath)\n }\n }\n }\n }\n }\n\n protected manifestHandler(_depth?: number, _ignoreAddresses?: string[]): Promisable<ModuleManifestPayload> {\n const name = this.config.name ?? 'Anonymous'\n return { config: { name, ...this.config }, schema: ModuleManifestPayloadSchema, status: { address: this.address } }\n }\n\n protected moduleAddressHandler(): Promisable<AddressPreviousHashPayload[]> {\n // Return array of all addresses and their previous hash\n const queryAccounts = Object.entries(this.queryAccounts)\n .filter((value): value is [string, AccountInstance] => {\n return exists(value[1])\n })\n .map(([name, account]) => {\n const address = account.address\n const previousHash = account.previousHash\n return [\n { address, name, schema: AddressSchema },\n { address, previousHash, schema: AddressPreviousHashSchema },\n ]\n })\n const address = this.address\n const name = this.config.name\n const previousHash = this.address\n const moduleAccount = name ? { address, name, schema: AddressSchema } : { address, schema: AddressSchema }\n const moduleAccountPreviousHash = previousHash\n ? { address, previousHash, schema: AddressPreviousHashSchema }\n : { address, schema: AddressPreviousHashSchema }\n return [moduleAccount, moduleAccountPreviousHash, ...queryAccounts].flat()\n }\n\n protected async queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryHandlerResult> {\n await this.started('throw')\n const wrapper = QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n switch (queryPayload.schema) {\n case ModuleManifestQuerySchema: {\n resultPayloads.push(await this.manifestHandler(queryPayload.maxDepth))\n break\n }\n case ModuleDiscoverQuerySchema: {\n const { maxDepth } = queryPayload\n resultPayloads.push(...(await this.discoverHandler(maxDepth)))\n break\n }\n case ModuleDescribeQuerySchema: {\n resultPayloads.push(await this.describeHandler())\n break\n }\n case ModuleAddressQuerySchema: {\n resultPayloads.push(...(await this.moduleAddressHandler()))\n break\n }\n case ModuleSubscribeQuerySchema: {\n this.subscribeHandler()\n break\n }\n default: {\n throw new Error(`Unsupported Query [${(queryPayload as Payload).schema}]`)\n }\n }\n return resultPayloads\n }\n\n protected readArchivist = () => this.getArchivist('read')\n\n protected async resolveArchivingArchivists(): Promise<ArchivistInstance[]> {\n const archivists = this.config.archiving?.archivists\n if (!archivists) return []\n const resolved = await Promise.all(archivists.map((archivist) => this.resolve(archivist)))\n return compact(resolved.map((mod) => asArchivistInstance(mod)))\n }\n\n protected async startHandler(): Promise<boolean> {\n this.validateConfig()\n await this.initializeQueryAccounts()\n this._started = true\n return true\n }\n\n protected stopHandler(_timeout?: number): Promisable<boolean> {\n this._started = undefined\n return true\n }\n\n protected async storeToArchivists(payloads: Payload[]): Promise<Payload[]> {\n const archivists = await this.resolveArchivingArchivists()\n return (\n await Promise.all(\n archivists.map((archivist) => {\n return archivist.insert?.(payloads)\n }),\n )\n ).map(([bw]) => bw)\n }\n\n protected subscribeHandler() {\n return\n }\n\n protected validateConfig(config?: unknown, parents: string[] = []): boolean {\n // eslint-disable-next-line unicorn/no-array-reduce\n return Object.entries(config ?? this.config ?? {}).reduce((valid, [key, value]) => {\n switch (typeof value) {\n case 'function': {\n this.logger?.warn(`Fields of type function not allowed in config [${parents?.join('.')}.${key}]`)\n return false\n }\n case 'object': {\n if (Array.isArray(value)) {\n return (\n // eslint-disable-next-line unicorn/no-array-reduce\n value.reduce((valid, value) => {\n return this.validateConfig(value, [...parents, key]) && valid\n }, true) && valid\n )\n }\n\n if (!serializableField(value)) {\n this.logger?.warn(`Fields that are not serializable to JSON are not allowed in config [${parents?.join('.')}.${key}]`)\n return false\n }\n return value ? this.validateConfig(value, [...parents, key]) && valid : true\n }\n default: {\n return valid\n }\n }\n }, true)\n }\n\n protected writeArchivist = () => this.getArchivist('write')\n}\n","import { EventAnyListener, EventData, EventFunctions, EventListener, Events } from '@xyo-network/module-events'\nimport { Base, BaseParams } from '@xyo-network/object'\n\nexport class BaseEmitter<TParams extends BaseParams = BaseParams, TEventData extends EventData = EventData>\n extends Base<TParams>\n implements EventFunctions<TEventData>\n{\n //just here to query types\n eventData = {} as TEventData\n\n private events: Events<TEventData>\n\n constructor(params: TParams) {\n super(params)\n this.events = new Events<TEventData>()\n }\n\n clearListeners(eventNames: keyof TEventData | (keyof TEventData)[]) {\n return this.events.clearListeners(eventNames)\n }\n\n emit<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return this.events.emit(eventName, eventArgs)\n }\n\n emitSerial<TEventName extends keyof TEventData = keyof TEventData, TEventArgs extends TEventData[TEventName] = TEventData[TEventName]>(\n eventName: TEventName,\n eventArgs: TEventArgs,\n ) {\n return this.events.emitSerial(eventName, eventArgs)\n }\n\n listenerCount(eventNames: keyof TEventData | (keyof TEventData)[]) {\n return this.events.listenerCount(eventNames)\n }\n\n off<TEventName extends keyof TEventData>(eventNames: TEventName | TEventName[], listener: EventListener<TEventData[TEventName]>) {\n return this.events.off(eventNames, listener)\n }\n\n offAny(listener: EventAnyListener) {\n return this.events.offAny(listener)\n }\n\n on<TEventName extends keyof TEventData>(eventNames: TEventName | TEventName[], listener: EventListener<TEventData[TEventName]>) {\n return this.events.on(eventNames, listener)\n }\n\n onAny(listener: EventAnyListener) {\n return this.events.onAny(listener)\n }\n\n once<TEventName extends keyof TEventData>(eventName: TEventName, listener: EventListener<TEventData[TEventName]>) {\n return this.events.once(eventName, listener)\n }\n}\n","/* eslint-disable max-lines */\nimport { assertEx } from '@xylabs/assert'\nimport { Account } from '@xyo-network/account'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { WalletInstance } from '@xyo-network/wallet-model'\n\nexport interface DetermineAccountFromAccountParams {\n account: AccountInstance | 'random'\n}\n\nexport interface DetermineAccountFromWalletParams {\n accountDerivationPath?: string\n wallet: WalletInstance\n}\n\nexport interface DetermineRandomParams {}\n\nexport type DetermineAccountParams = DetermineAccountFromAccountParams | DetermineAccountFromWalletParams | DetermineRandomParams\n\nconst isDetermineAccountFromAccountParams = (params: DetermineAccountParams): params is DetermineAccountFromAccountParams => {\n assertEx(!(params as DetermineAccountFromWalletParams).accountDerivationPath, 'accountDerivationPath may not be provided when account is provided')\n return !!(params as DetermineAccountFromAccountParams).account\n}\n\nconst isDetermineAccountFromWalletParams = (params: DetermineAccountParams): params is DetermineAccountFromWalletParams => {\n return !!(params as DetermineAccountFromWalletParams).wallet\n}\n\nexport async function determineAccount(params: DetermineAccountParams): Promise<AccountInstance> {\n if (isDetermineAccountFromAccountParams(params)) {\n return params.account === 'random' ? Account.randomSync() : params.account\n }\n\n if (isDetermineAccountFromWalletParams(params)) {\n return assertEx(\n params.accountDerivationPath ? await params.wallet.derivePath(params.accountDerivationPath) : params.wallet,\n 'Failed to derive account from path',\n )\n }\n\n //this should eventually be removed/thrown\n console.warn('AbstractModule.determineAccount: No account or wallet provided - Creating Random account')\n return Account.randomSync()\n}\n","import { PayloadBuilder } from '@xyo-network/payload-builder'\nimport { ModuleError, ModuleErrorSchema } from '@xyo-network/payload-model'\n\nexport class ModuleErrorBuilder extends PayloadBuilder<ModuleError> {\n _message?: string\n _name?: string\n _query?: string\n _sources?: string[]\n constructor() {\n super({ schema: ModuleErrorSchema })\n }\n\n override build(): Promise<ModuleError> {\n return Promise.resolve({\n message: this._message,\n name: this._name,\n query: this._query,\n schema: ModuleErrorSchema,\n sources: this._sources,\n })\n }\n\n message(message: string) {\n this._message = message\n return this\n }\n\n name(name: string) {\n this._name = name\n return this\n }\n\n query(query: string) {\n this._query = query\n return this\n }\n\n sources(sources: string[]) {\n this._sources = sources\n return this\n }\n}\n","import { Address } from '@xylabs/hex'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { AnyConfigSchema, CosigningAddressSet, ModuleConfig, ModuleQuery, SchemaString } from '@xyo-network/module-model'\n\nimport { Queryable, QueryValidator } from './QueryValidator'\n\nexport type SortedPipedAddressesString = string\n\nconst delimiter = ''\n\nexport class ModuleConfigQueryValidator<TConfig extends AnyConfigSchema<ModuleConfig>> implements QueryValidator {\n protected allowed: Record<SchemaString, SortedPipedAddressesString[]> = {}\n protected disallowed: Record<SchemaString, Address[]> = {}\n protected readonly hasAllowedRules: boolean\n protected readonly hasDisallowedRules: boolean\n protected readonly hasRules: boolean\n\n constructor(config?: TConfig) {\n if (config?.security?.allowed) {\n for (const [schema, addresses] of Object.entries(config.security?.allowed)) {\n this.allowed[schema] = addresses.map(toAddressesString)\n }\n }\n if (config?.security?.disallowed) {\n for (const [schema, addresses] of Object.entries(config.security?.disallowed)) {\n this.disallowed[schema] = addresses.map(toAddressesString)\n }\n }\n this.hasAllowedRules = Object.keys(this.allowed).length > 0\n this.hasDisallowedRules = Object.keys(this.disallowed).length > 0\n this.hasRules = this.hasAllowedRules || this.hasDisallowedRules\n }\n\n queryable: Queryable = async (query, payloads) => {\n if (!this.hasRules) return true\n const addresses = query.addresses\n if (addresses.length === 0) return false\n const wrapper = QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)\n const schema = (await wrapper.getQuery()).schema\n return this.queryAllowed(schema, addresses) && !this.queryDisallowed(schema, addresses)\n }\n\n protected queryAllowed = (schema: SchemaString, addresses: string[]): boolean => {\n if (!this.hasAllowedRules) return true\n // All cosigners must sign\n if (addresses.length > 1) {\n const signatories = toAddressesString(addresses)\n const validCosigners = this.allowed?.[schema]?.includes(signatories)\n if (validCosigners) return true\n }\n // OR all signers have to be allowed individually\n return addresses.every((address) => this.allowed?.[schema]?.includes(address) || false)\n }\n protected queryDisallowed = (schema: SchemaString, addresses: string[]): boolean => {\n if (!this.hasDisallowedRules) return false\n return addresses.some((address) => this.disallowed?.[schema]?.includes(address))\n }\n}\n\n// TODO: Handle 0x prefix\nconst toAddressesString = (addresses: string | CosigningAddressSet): SortedPipedAddressesString => {\n return Array.isArray(addresses)\n ? addresses\n .sort()\n .map((address) => address.toLowerCase())\n .join(delimiter)\n : addresses.toLowerCase()\n}\n","import { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-builder'\nimport { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { Module, ModuleQuery } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nimport { Queryable, QueryValidator } from './QueryValidator'\n\nexport const isQuerySupportedByModule = async <T extends QueryBoundWitness = QueryBoundWitness>(\n mod: Module,\n query: T,\n payloads?: Payload[],\n): Promise<boolean> => {\n const wrapper = QueryBoundWitnessWrapper.parseQuery<ModuleQuery>(query, payloads)\n const schema = (await wrapper.getQuery()).schema\n return mod.queries.includes(schema)\n}\n\nexport class SupportedQueryValidator implements QueryValidator {\n constructor(protected readonly mod: Module) {}\n queryable: Queryable = (query, payloads) => {\n return isQuerySupportedByModule(this.mod, query, payloads)\n }\n}\n","import { assertEx } from '@xylabs/assert'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { ModuleManifestPayload } from '@xyo-network/manifest-model'\nimport { AddressPreviousHashPayload, Module, ModuleDescriptionPayload, ModuleEventData, ModuleParams } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\n\nimport { AbstractModule } from './AbstractModule'\n\nexport abstract class AbstractModuleInstance<TParams extends ModuleParams = ModuleParams, TEventData extends ModuleEventData = ModuleEventData>\n extends AbstractModule<TParams, TEventData>\n implements Module<TParams, TEventData>\n{\n constructor(privateConstructorKey: string, params: TParams, account: AccountInstance) {\n assertEx(AbstractModule.privateConstructorKey === privateConstructorKey, 'Use create function instead of constructor')\n // Clone params to prevent mutation of the incoming object\n const mutatedParams = { ...params } as TParams\n super(privateConstructorKey, mutatedParams, account)\n this.upResolver.add(this)\n this.downResolver.add(this)\n }\n\n describe(): Promise<ModuleDescriptionPayload> {\n return this.busy(async () => {\n return await this.describeHandler()\n })\n }\n\n discover(): Promise<Payload[]> {\n return this.busy(async () => {\n return await this.discoverHandler()\n })\n }\n\n manifest(maxDepth?: number, ignoreAddresses?: string[]): Promise<ModuleManifestPayload> {\n return this.busy(async () => {\n return await this.manifestHandler(maxDepth, ignoreAddresses)\n })\n }\n\n moduleAddress(): Promise<AddressPreviousHashPayload[]> {\n return this.busy(async () => {\n return await this.moduleAddressHandler()\n })\n }\n\n subscribe(_queryAccount?: AccountInstance) {\n return this.subscribeHandler()\n }\n}\n"],"mappings":"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","names":["import_assert","import_account","import_boundwitness_builder","import_payload_builder","BaseEmitter","Base","eventData","events","constructor","params","Events","clearListeners","eventNames","emit","eventName","eventArgs","emitSerial","listenerCount","off","listener","offAny","on","onAny","once","isDetermineAccountFromAccountParams","params","assertEx","accountDerivationPath","account","isDetermineAccountFromWalletParams","wallet","determineAccount","Account","randomSync","derivePath","console","warn","ModuleErrorBuilder","PayloadBuilder","_message","_name","_query","_sources","constructor","schema","ModuleErrorSchema","build","Promise","resolve","message","name","query","sources","delimiter","ModuleConfigQueryValidator","allowed","disallowed","hasAllowedRules","hasDisallowedRules","hasRules","constructor","config","security","schema","addresses","Object","entries","map","toAddressesString","keys","length","queryable","query","payloads","wrapper","QueryBoundWitnessWrapper","parseQuery","getQuery","queryAllowed","queryDisallowed","signatories","validCosigners","includes","every","address","_a","_b","some","Array","isArray","sort","toLowerCase","join","import_boundwitness_builder","isQuerySupportedByModule","mod","query","payloads","wrapper","QueryBoundWitnessWrapper","parseQuery","schema","getQuery","queries","includes","SupportedQueryValidator","constructor","queryable","AbstractModule","BaseEmitter","downResolver","CompositeModuleResolver","upResolver","_account","undefined","_baseModuleQueryAccountPaths","ModuleAddressQuerySchema","ModuleDescribeQuerySchema","ModuleDiscoverQuerySchema","ModuleManifestQuerySchema","ModuleSubscribeQuerySchema","_queryAccounts","_startPromise","_started","moduleConfigQueryValidator","supportedQueryValidator","_busyCount","constructor","privateConstructorKey","params","account","assertEx","mutatedParams","SupportedQueryValidator","queryable","ModuleConfigQueryValidator","config","configSchema","configSchemas","address","allowAnonymous","security","ephemeralQueryAccountEnabled","queries","queryAccountPaths","_queryAccountPaths","queryAccounts","timestamp","_getRootFunction","funcName","anyThis","__proto__","_noOverride","functionName","thisFunc","rootFunc","create","length","Error","schema","name","wallet","accountDerivationPath","allowedSchemas","includes","JSON","stringify","mutatedConfig","logger","debug","activeLogger","defaultLogger","generatedAccount","determineAccount","IdLogger","newModule","enableLazyLoad","start","factory","ModuleFactory","withParams","busy","closure","args","module","emit","eventName","eventArgs","previousHash","query","payloads","queryConfig","sourceQuery","PayloadHasher","hashAsync","resultPayloads","errorPayloads","queryAccount","Account","randomSync","started","addresses","push","queryHandler","QueryBoundWitnessWrapper","unwrap","ex","handleErrorAsync","error","ModuleErrorBuilder","sources","message","build","Date","now","result","bindQueryResult","configValidator","Object","assign","validators","every","validator","resolve","nameOrAddressOrFilter","options","direction","up","down","filter","duplicateModules","_timeout","startHandler","notStartedAction","tryStart","handleError","_a","warn","log","stop","stopHandler","bindHashes","hashes","promise","PromiseEx","bindHashesInternal","builder","BoundWitnessBuilder","witness","bindQuery","bindQueryInternal","QueryBoundWitnessBuilder","additionalWitnesses","errors","queryWitnessAccount","witnesses","exists","archiving","storeToArchivists","flat","commitArchivist","getArchivist","describeHandler","description","ModuleDescriptionSchema","discover","discoverHandler","children","compact","map","payload","AddressSchema","_maxDepth","PayloadBuilder","fields","Promise","all","QuerySchema","ConfigSchema","kind","archivist","String","resolved","asArchivistInstance","initializeQueryAccounts","paths","values","distinctPaths","Set","size","derivePath","key","prototype","hasOwnProperty","call","queryAccountPath","manifestHandler","_depth","_ignoreAddresses","ModuleManifestPayloadSchema","status","moduleAddressHandler","entries","value","AddressPreviousHashSchema","moduleAccount","moduleAccountPreviousHash","wrapper","parseQuery","queryPayload","getQuery","maxDepth","subscribeHandler","readArchivist","resolveArchivingArchivists","archivists","mod","validateConfig","insert","bw","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","maxDepth","ignoreAddresses","manifestHandler","moduleAddress","moduleAddressHandler","subscribe","_queryAccount","subscribeHandler"]}
|
package/dist/node/index.js
CHANGED
|
@@ -143,14 +143,14 @@ var _ModuleConfigQueryValidator = class _ModuleConfigQueryValidator {
|
|
|
143
143
|
constructor(config) {
|
|
144
144
|
var _a, _b, _c, _d;
|
|
145
145
|
if ((_a = config == null ? void 0 : config.security) == null ? void 0 : _a.allowed) {
|
|
146
|
-
Object.entries((_b = config.security) == null ? void 0 : _b.allowed)
|
|
146
|
+
for (const [schema, addresses] of Object.entries((_b = config.security) == null ? void 0 : _b.allowed)) {
|
|
147
147
|
this.allowed[schema] = addresses.map(toAddressesString);
|
|
148
|
-
}
|
|
148
|
+
}
|
|
149
149
|
}
|
|
150
150
|
if ((_c = config == null ? void 0 : config.security) == null ? void 0 : _c.disallowed) {
|
|
151
|
-
Object.entries((_d = config.security) == null ? void 0 : _d.disallowed)
|
|
151
|
+
for (const [schema, addresses] of Object.entries((_d = config.security) == null ? void 0 : _d.disallowed)) {
|
|
152
152
|
this.disallowed[schema] = addresses.map(toAddressesString);
|
|
153
|
-
}
|
|
153
|
+
}
|
|
154
154
|
}
|
|
155
155
|
this.hasAllowedRules = Object.keys(this.allowed).length > 0;
|
|
156
156
|
this.hasDisallowedRules = Object.keys(this.disallowed).length > 0;
|
|
@@ -160,7 +160,7 @@ var _ModuleConfigQueryValidator = class _ModuleConfigQueryValidator {
|
|
|
160
160
|
if (!this.hasRules)
|
|
161
161
|
return true;
|
|
162
162
|
const addresses = query.addresses;
|
|
163
|
-
if (
|
|
163
|
+
if (addresses.length === 0)
|
|
164
164
|
return false;
|
|
165
165
|
const wrapper = QueryBoundWitnessWrapper.parseQuery(query, payloads);
|
|
166
166
|
const schema = (await wrapper.getQuery()).schema;
|
|
@@ -306,14 +306,14 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
306
306
|
var _a, _b, _c, _d;
|
|
307
307
|
this._noOverride("create");
|
|
308
308
|
if (!this.configSchemas || this.configSchemas.length === 0) {
|
|
309
|
-
throw Error(`Missing configSchema [${(_a = params == null ? void 0 : params.config) == null ? void 0 : _a.schema}][${this.name}]`);
|
|
309
|
+
throw new Error(`Missing configSchema [${(_a = params == null ? void 0 : params.config) == null ? void 0 : _a.schema}][${this.name}]`);
|
|
310
310
|
}
|
|
311
311
|
const { account, config, wallet } = params ?? {};
|
|
312
312
|
const { accountDerivationPath } = config ?? {};
|
|
313
313
|
assertEx2(!(!!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}]`);
|
|
314
314
|
const schema = ((_b = params == null ? void 0 : params.config) == null ? void 0 : _b.schema) ?? this.configSchema;
|
|
315
315
|
const allowedSchemas = this.configSchemas;
|
|
316
|
-
assertEx2(allowedSchemas.
|
|
316
|
+
assertEx2(allowedSchemas.includes(schema), `Bad Config Schema [Received ${schema}] [Expected ${JSON.stringify(allowedSchemas)}]`);
|
|
317
317
|
const mutatedConfig = {
|
|
318
318
|
...params == null ? void 0 : params.config,
|
|
319
319
|
schema
|
|
@@ -394,10 +394,8 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
394
394
|
const queryAccount = this.ephemeralQueryAccountEnabled ? Account2.randomSync() : void 0;
|
|
395
395
|
try {
|
|
396
396
|
await this.started("throw");
|
|
397
|
-
if (!this.allowAnonymous) {
|
|
398
|
-
|
|
399
|
-
throw Error(`Anonymous Queries not allowed, but running anyway [${this.config.name}], [${this.address}]`);
|
|
400
|
-
}
|
|
397
|
+
if (!this.allowAnonymous && query.addresses.length === 0) {
|
|
398
|
+
throw new Error(`Anonymous Queries not allowed, but running anyway [${this.config.name}], [${this.address}]`);
|
|
401
399
|
}
|
|
402
400
|
resultPayloads.push(...await this.queryHandler(assertEx2(QueryBoundWitnessWrapper3.unwrap(query)), payloads, queryConfig));
|
|
403
401
|
} catch (ex) {
|
|
@@ -479,17 +477,20 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
479
477
|
}
|
|
480
478
|
}
|
|
481
479
|
switch (notStartedAction) {
|
|
482
|
-
case "throw":
|
|
483
|
-
throw Error(`Module not Started [${this.address}]`);
|
|
484
|
-
|
|
480
|
+
case "throw": {
|
|
481
|
+
throw new Error(`Module not Started [${this.address}]`);
|
|
482
|
+
}
|
|
483
|
+
case "warn": {
|
|
485
484
|
(_a = this.logger) == null ? void 0 : _a.warn("Module not started");
|
|
486
485
|
break;
|
|
487
|
-
|
|
486
|
+
}
|
|
487
|
+
case "error": {
|
|
488
488
|
(_b = this.logger) == null ? void 0 : _b.error("Module not started");
|
|
489
489
|
break;
|
|
490
|
-
|
|
490
|
+
}
|
|
491
|
+
case "none": {
|
|
491
492
|
break;
|
|
492
|
-
|
|
493
|
+
}
|
|
493
494
|
default: {
|
|
494
495
|
(_c = this.logger) == null ? void 0 : _c.log("Module not started");
|
|
495
496
|
break;
|
|
@@ -572,7 +573,7 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
572
573
|
const discover = await this.discoverHandler();
|
|
573
574
|
description.children = compact((discover == null ? void 0 : discover.map((payload) => {
|
|
574
575
|
const address = payload.schema === AddressSchema ? payload.address : void 0;
|
|
575
|
-
return address
|
|
576
|
+
return address == this.address ? void 0 : address;
|
|
576
577
|
})) ?? []);
|
|
577
578
|
return description;
|
|
578
579
|
}
|
|
@@ -603,6 +604,7 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
603
604
|
...queries
|
|
604
605
|
]);
|
|
605
606
|
}
|
|
607
|
+
// eslint-disable-next-line import/no-deprecated
|
|
606
608
|
async getArchivist(kind) {
|
|
607
609
|
var _a, _b;
|
|
608
610
|
if (!this.config.archivist)
|
|
@@ -714,8 +716,9 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
714
716
|
this.subscribeHandler();
|
|
715
717
|
break;
|
|
716
718
|
}
|
|
717
|
-
default:
|
|
718
|
-
throw Error(`Unsupported Query [${queryPayload.schema}]`);
|
|
719
|
+
default: {
|
|
720
|
+
throw new Error(`Unsupported Query [${queryPayload.schema}]`);
|
|
721
|
+
}
|
|
719
722
|
}
|
|
720
723
|
return resultPayloads;
|
|
721
724
|
}
|
|
@@ -752,17 +755,21 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
752
755
|
return Object.entries(config ?? this.config ?? {}).reduce((valid, [key, value]) => {
|
|
753
756
|
var _a, _b;
|
|
754
757
|
switch (typeof value) {
|
|
755
|
-
case "function":
|
|
758
|
+
case "function": {
|
|
756
759
|
(_a = this.logger) == null ? void 0 : _a.warn(`Fields of type function not allowed in config [${parents == null ? void 0 : parents.join(".")}.${key}]`);
|
|
757
760
|
return false;
|
|
761
|
+
}
|
|
758
762
|
case "object": {
|
|
759
763
|
if (Array.isArray(value)) {
|
|
760
|
-
return
|
|
761
|
-
|
|
762
|
-
|
|
763
|
-
|
|
764
|
-
|
|
765
|
-
|
|
764
|
+
return (
|
|
765
|
+
// eslint-disable-next-line unicorn/no-array-reduce
|
|
766
|
+
value.reduce((valid2, value2) => {
|
|
767
|
+
return this.validateConfig(value2, [
|
|
768
|
+
...parents,
|
|
769
|
+
key
|
|
770
|
+
]) && valid2;
|
|
771
|
+
}, true) && valid
|
|
772
|
+
);
|
|
766
773
|
}
|
|
767
774
|
if (!serializableField(value)) {
|
|
768
775
|
(_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}]`);
|
|
@@ -773,8 +780,9 @@ var _AbstractModule = class _AbstractModule extends BaseEmitter {
|
|
|
773
780
|
key
|
|
774
781
|
]) && valid : true;
|
|
775
782
|
}
|
|
776
|
-
default:
|
|
783
|
+
default: {
|
|
777
784
|
return valid;
|
|
785
|
+
}
|
|
778
786
|
}
|
|
779
787
|
}, true);
|
|
780
788
|
}
|