@xyo-network/abstract-witness 5.2.22 → 5.2.25

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.
@@ -1 +1 @@
1
- {"version":3,"file":"AbstractWitness.d.ts","sourceRoot":"","sources":["../../src/AbstractWitness.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAA;AAKhD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAA;AACjE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAA;AACrE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAExE,OAAO,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAA;AACrE,OAAO,KAAK,EACV,YAAY,EAAE,wBAAwB,EAAE,iBAAiB,EAC1D,MAAM,2BAA2B,CAAA;AAGlC,OAAO,KAAK,EACV,OAAO,EAAE,MAAM,EAAE,yBAAyB,EAC3C,MAAM,4BAA4B,CAAA;AACnC,OAAO,KAAK,EACV,qBAAqB,EACrB,eAAe,EACf,sBAAsB,EAEtB,aAAa,EAEd,MAAM,4BAA4B,CAAA;AAOnC,8BAAsB,eAAe,CACnC,OAAO,SAAS,aAAa,GAAG,aAAa,EAC7C,GAAG,SAAS,OAAO,GAAG,OAAO,EAC7B,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CAED,SAAQ,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAClD,YAAW,qBAAqB,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IAChE,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAgD;IAChG,gBAAyB,mBAAmB,EAAE,MAAM,CAAsB;IAC1E,gBAAyB,UAAU,SAA4D;IAE/F,OAAO,CAAC,kBAAkB,CAA+B;IAEzD,IAAa,OAAO,IAAI,MAAM,EAAE,CAE/B;IAEK,oBAAoB;IAM1B,wJAAwJ;IAClJ,OAAO,CAAC,UAAU,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,CAAC,yBAAyB,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC;IAkCzE,YAAY,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,EAAE,OAAO,CAAC,EAAE,eAAe,GAAG,OAAO,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;IAMjG,0GAA0G;cACjF,YAAY,CAAC,CAAC,SAAS,iBAAiB,GAAG,iBAAiB,EAAE,OAAO,SAAS,YAAY,GAAG,YAAY,EAChI,KAAK,EAAE,CAAC,EACR,QAAQ,CAAC,EAAE,OAAO,EAAE,EACpB,WAAW,CAAC,EAAE,OAAO,GACpB,OAAO,CAAC,wBAAwB,CAAC;IAoBpC,8FAA8F;IAC9F,SAAS,CAAC,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,UAAU,CAAC,IAAI,EAAE,CAAC;CACxE"}
1
+ {"version":3,"file":"AbstractWitness.d.ts","sourceRoot":"","sources":["../../src/AbstractWitness.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAA;AAIhD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAA;AACjE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAA;AACrE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAExE,OAAO,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAA;AACrE,OAAO,KAAK,EACV,YAAY,EAAE,wBAAwB,EAAE,iBAAiB,EAC1D,MAAM,2BAA2B,CAAA;AAGlC,OAAO,KAAK,EACV,OAAO,EAAE,MAAM,EAAE,yBAAyB,EAC3C,MAAM,4BAA4B,CAAA;AACnC,OAAO,KAAK,EACV,qBAAqB,EACrB,eAAe,EACf,sBAAsB,EAEtB,aAAa,EAEd,MAAM,4BAA4B,CAAA;AAOnC,8BAAsB,eAAe,CACnC,OAAO,SAAS,aAAa,GAAG,aAAa,EAC7C,GAAG,SAAS,OAAO,GAAG,OAAO,EAC7B,IAAI,SAAS,OAAO,GAAG,OAAO,EAC9B,UAAU,SAAS,sBAAsB,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,sBAAsB,CAChH,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,EACnC,GAAG,EACH,IAAI,CACL,CAED,SAAQ,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAClD,YAAW,qBAAqB,CAAC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,UAAU,CAAC;IAChE,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAgD;IAChG,gBAAyB,mBAAmB,EAAE,MAAM,CAAsB;IAC1E,gBAAyB,UAAU,SAA4D;IAE/F,OAAO,CAAC,kBAAkB,CAA+B;IAEzD,IAAa,OAAO,IAAI,MAAM,EAAE,CAE/B;IAEK,oBAAoB;IAM1B,wJAAwJ;IAClJ,OAAO,CAAC,UAAU,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,CAAC,yBAAyB,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC;IAkCzE,YAAY,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,EAAE,OAAO,CAAC,EAAE,eAAe,GAAG,OAAO,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;IAMjG,0GAA0G;cACjF,YAAY,CAAC,CAAC,SAAS,iBAAiB,GAAG,iBAAiB,EAAE,OAAO,SAAS,YAAY,GAAG,YAAY,EAChI,KAAK,EAAE,CAAC,EACR,QAAQ,CAAC,EAAE,OAAO,EAAE,EACpB,WAAW,CAAC,EAAE,OAAO,GACpB,OAAO,CAAC,wBAAwB,CAAC;IAoBpC,8FAA8F;IAC9F,SAAS,CAAC,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,UAAU,CAAC,IAAI,EAAE,CAAC;CACxE"}
@@ -4,7 +4,6 @@ import {
4
4
  globallyUnique,
5
5
  isAddress
6
6
  } from "@xylabs/sdk-js";
7
- import { spanAsync } from "@xylabs/telemetry";
8
7
  import { QueryBoundWitnessWrapper } from "@xyo-network/boundwitness-wrapper";
9
8
  import { AbstractModuleInstance } from "@xyo-network/module-abstract";
10
9
  import { creatableModule } from "@xyo-network/module-model";
@@ -31,7 +30,7 @@ var AbstractWitness = class _AbstractWitness extends AbstractModuleInstance {
31
30
  async observe(inPayloads) {
32
31
  this._noOverride("observe");
33
32
  this.isSupportedQuery(WitnessObserveQuerySchema, "observe");
34
- return await spanAsync("observe", async () => {
33
+ return await this.spanAsync("observe", async () => {
35
34
  if (this.reentrancy?.scope === "global" && this.reentrancy.action === "skip" && this.globalReentrancyMutex?.isLocked()) {
36
35
  return [];
37
36
  }
@@ -57,7 +56,7 @@ var AbstractWitness = class _AbstractWitness extends AbstractModuleInstance {
57
56
  } finally {
58
57
  this.globalReentrancyMutex?.release();
59
58
  }
60
- }, this.tracer);
59
+ }, { timeBudgetLimit: 200 });
61
60
  }
62
61
  async observeQuery(payloads, account) {
63
62
  this._noOverride("observeQuery");
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/AbstractWitness.ts"],"sourcesContent":["import type { Promisable } from '@xylabs/sdk-js'\nimport {\n assertEx, globallyUnique, isAddress,\n} from '@xylabs/sdk-js'\nimport { spanAsync } from '@xylabs/telemetry'\nimport type { AccountInstance } from '@xyo-network/account-model'\nimport type { ArchivistInstance } from '@xyo-network/archivist-model'\nimport type { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { AbstractModuleInstance } from '@xyo-network/module-abstract'\nimport type {\n ModuleConfig, ModuleQueryHandlerResult, ModuleQueryResult,\n} from '@xyo-network/module-model'\nimport { creatableModule } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type {\n Payload, Schema, WithoutPrivateStorageMeta,\n} from '@xyo-network/payload-model'\nimport type {\n CustomWitnessInstance,\n WitnessInstance,\n WitnessModuleEventData,\n WitnessObserveQuery,\n WitnessParams,\n WitnessQueries,\n} from '@xyo-network/witness-model'\nimport {\n WitnessConfigSchema,\n WitnessObserveQuerySchema,\n} from '@xyo-network/witness-model'\n\ncreatableModule()\nexport abstract class AbstractWitness<\n TParams extends WitnessParams = WitnessParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<\n WitnessInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n>\n extends AbstractModuleInstance<TParams, TEventData>\n implements CustomWitnessInstance<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, WitnessConfigSchema]\n static override readonly defaultConfigSchema: Schema = WitnessConfigSchema\n static override readonly uniqueName = globallyUnique('AbstractWitness', AbstractWitness, 'xyo')\n\n private _archivistInstance: ArchivistInstance | undefined\n\n override get queries(): string[] {\n return [WitnessObserveQuerySchema, ...super.queries]\n }\n\n async getArchivistInstance() {\n const archivistAddress = this.archivist\n this._archivistInstance = this._archivistInstance ?? (isAddress(archivistAddress) ? await this.resolve(archivistAddress) : undefined)\n return this._archivistInstance\n }\n\n /** @function observe The main entry point for a witness. Do not override this function. Implement/override observeHandler for custom functionality */\n async observe(inPayloads?: TIn[]): Promise<(WithoutPrivateStorageMeta<TOut>)[]> {\n this._noOverride('observe')\n this.isSupportedQuery(WitnessObserveQuerySchema, 'observe')\n return await spanAsync('observe', async () => {\n if (this.reentrancy?.scope === 'global' && this.reentrancy.action === 'skip' && this.globalReentrancyMutex?.isLocked()) {\n return []\n }\n try {\n return await this.busy(async () => {\n await this.globalReentrancyMutex?.acquire()\n this._noOverride('observe')\n await this.startedAsync('throw')\n await this.emit('observeStart', { inPayloads, mod: this } as TEventData['observeStart'])\n const outPayloads = assertEx(await this.observeHandler(inPayloads), () => 'Trying to witness nothing')\n // assertEx(outPayloads.length > 0, 'Trying to witness empty list')\n for (const payload of outPayloads ?? []) assertEx(payload.schema, () => 'observe: Missing Schema')\n\n const archivist = await this.getArchivistInstance()\n if (archivist) {\n await archivist.insert(outPayloads)\n }\n\n await this.emit('observeEnd', {\n inPayloads, mod: this, outPayloads,\n } as TEventData['observeEnd'])\n\n return PayloadBuilder.omitPrivateStorageMeta<TOut>(outPayloads)\n })\n } finally {\n this.globalReentrancyMutex?.release()\n }\n }, this.tracer)\n }\n\n async observeQuery(payloads?: TIn[], account?: AccountInstance): Promise<ModuleQueryResult<TOut>> {\n this._noOverride('observeQuery')\n const queryPayload: WitnessObserveQuery = { schema: WitnessObserveQuerySchema }\n return await this.sendQueryRaw(queryPayload, payloads, account)\n }\n\n /** @function queryHandler Calls observe for an observe query. Override to support additional queries. */\n protected override async queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryHandlerResult> {\n const wrapper = QueryBoundWitnessWrapper.parseQuery<WitnessQueries>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(await this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n // Remove the query payload from the arguments passed to us so we don't observe it\n const filteredObservation = (await PayloadBuilder.filterExclude(payloads, query.query)) as TIn[]\n switch (queryPayload.schema) {\n case WitnessObserveQuerySchema: {\n const observePayloads = await this.observe(filteredObservation)\n resultPayloads.push(...observePayloads)\n break\n }\n default: {\n return super.queryHandler(query, payloads)\n }\n }\n return PayloadBuilder.omitPrivateStorageMeta(resultPayloads) as ModuleQueryHandlerResult\n }\n\n /** @function observeHandler Implement or override to add custom functionality to a witness */\n protected abstract observeHandler(payloads?: TIn[]): Promisable<TOut[]>\n}\n"],"mappings":";AACA;AAAA,EACE;AAAA,EAAU;AAAA,EAAgB;AAAA,OACrB;AACP,SAAS,iBAAiB;AAI1B,SAAS,gCAAgC;AACzC,SAAS,8BAA8B;AAIvC,SAAS,uBAAuB;AAChC,SAAS,sBAAsB;AAY/B;AAAA,EACE;AAAA,EACA;AAAA,OACK;AAEP,gBAAgB;AACT,IAAe,kBAAf,MAAe,yBAUZ,uBACyD;AAAA,EACjE,OAAyB,gBAA0B,CAAC,GAAG,MAAM,eAAe,mBAAmB;AAAA,EAC/F,OAAyB,sBAA8B;AAAA,EACvD,OAAyB,aAAa,eAAe,mBAAmB,kBAAiB,KAAK;AAAA,EAEtF;AAAA,EAER,IAAa,UAAoB;AAC/B,WAAO,CAAC,2BAA2B,GAAG,MAAM,OAAO;AAAA,EACrD;AAAA,EAEA,MAAM,uBAAuB;AAC3B,UAAM,mBAAmB,KAAK;AAC9B,SAAK,qBAAqB,KAAK,uBAAuB,UAAU,gBAAgB,IAAI,MAAM,KAAK,QAAQ,gBAAgB,IAAI;AAC3H,WAAO,KAAK;AAAA,EACd;AAAA;AAAA,EAGA,MAAM,QAAQ,YAAkE;AAC9E,SAAK,YAAY,SAAS;AAC1B,SAAK,iBAAiB,2BAA2B,SAAS;AAC1D,WAAO,MAAM,UAAU,WAAW,YAAY;AAC5C,UAAI,KAAK,YAAY,UAAU,YAAY,KAAK,WAAW,WAAW,UAAU,KAAK,uBAAuB,SAAS,GAAG;AACtH,eAAO,CAAC;AAAA,MACV;AACA,UAAI;AACF,eAAO,MAAM,KAAK,KAAK,YAAY;AACjC,gBAAM,KAAK,uBAAuB,QAAQ;AAC1C,eAAK,YAAY,SAAS;AAC1B,gBAAM,KAAK,aAAa,OAAO;AAC/B,gBAAM,KAAK,KAAK,gBAAgB,EAAE,YAAY,KAAK,KAAK,CAA+B;AACvF,gBAAM,cAAc,SAAS,MAAM,KAAK,eAAe,UAAU,GAAG,MAAM,2BAA2B;AAErG,qBAAW,WAAW,eAAe,CAAC,EAAG,UAAS,QAAQ,QAAQ,MAAM,yBAAyB;AAEjG,gBAAM,YAAY,MAAM,KAAK,qBAAqB;AAClD,cAAI,WAAW;AACb,kBAAM,UAAU,OAAO,WAAW;AAAA,UACpC;AAEA,gBAAM,KAAK,KAAK,cAAc;AAAA,YAC5B;AAAA,YAAY,KAAK;AAAA,YAAM;AAAA,UACzB,CAA6B;AAE7B,iBAAO,eAAe,uBAA6B,WAAW;AAAA,QAChE,CAAC;AAAA,MACH,UAAE;AACA,aAAK,uBAAuB,QAAQ;AAAA,MACtC;AAAA,IACF,GAAG,KAAK,MAAM;AAAA,EAChB;AAAA,EAEA,MAAM,aAAa,UAAkB,SAA6D;AAChG,SAAK,YAAY,cAAc;AAC/B,UAAM,eAAoC,EAAE,QAAQ,0BAA0B;AAC9E,WAAO,MAAM,KAAK,aAAa,cAAc,UAAU,OAAO;AAAA,EAChE;AAAA;AAAA,EAGA,MAAyB,aACvB,OACA,UACA,aACmC;AACnC,UAAM,UAAU,yBAAyB,WAA2B,OAAO,QAAQ;AACnF,UAAM,eAAe,MAAM,QAAQ,SAAS;AAC5C,aAAS,MAAM,KAAK,UAAU,OAAO,UAAU,WAAW,CAAC;AAC3D,UAAM,iBAA4B,CAAC;AAEnC,UAAM,sBAAuB,MAAM,eAAe,cAAc,UAAU,MAAM,KAAK;AACrF,YAAQ,aAAa,QAAQ;AAAA,MAC3B,KAAK,2BAA2B;AAC9B,cAAM,kBAAkB,MAAM,KAAK,QAAQ,mBAAmB;AAC9D,uBAAe,KAAK,GAAG,eAAe;AACtC;AAAA,MACF;AAAA,MACA,SAAS;AACP,eAAO,MAAM,aAAa,OAAO,QAAQ;AAAA,MAC3C;AAAA,IACF;AACA,WAAO,eAAe,uBAAuB,cAAc;AAAA,EAC7D;AAIF;","names":[]}
1
+ {"version":3,"sources":["../../src/AbstractWitness.ts"],"sourcesContent":["import type { Promisable } from '@xylabs/sdk-js'\nimport {\n assertEx, globallyUnique, isAddress,\n} from '@xylabs/sdk-js'\nimport type { AccountInstance } from '@xyo-network/account-model'\nimport type { ArchivistInstance } from '@xyo-network/archivist-model'\nimport type { QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { AbstractModuleInstance } from '@xyo-network/module-abstract'\nimport type {\n ModuleConfig, ModuleQueryHandlerResult, ModuleQueryResult,\n} from '@xyo-network/module-model'\nimport { creatableModule } from '@xyo-network/module-model'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type {\n Payload, Schema, WithoutPrivateStorageMeta,\n} from '@xyo-network/payload-model'\nimport type {\n CustomWitnessInstance,\n WitnessInstance,\n WitnessModuleEventData,\n WitnessObserveQuery,\n WitnessParams,\n WitnessQueries,\n} from '@xyo-network/witness-model'\nimport {\n WitnessConfigSchema,\n WitnessObserveQuerySchema,\n} from '@xyo-network/witness-model'\n\ncreatableModule()\nexport abstract class AbstractWitness<\n TParams extends WitnessParams = WitnessParams,\n TIn extends Payload = Payload,\n TOut extends Payload = Payload,\n TEventData extends WitnessModuleEventData<WitnessInstance<TParams, TIn, TOut>, TIn, TOut> = WitnessModuleEventData<\n WitnessInstance<TParams, TIn, TOut>,\n TIn,\n TOut\n >,\n>\n extends AbstractModuleInstance<TParams, TEventData>\n implements CustomWitnessInstance<TParams, TIn, TOut, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, WitnessConfigSchema]\n static override readonly defaultConfigSchema: Schema = WitnessConfigSchema\n static override readonly uniqueName = globallyUnique('AbstractWitness', AbstractWitness, 'xyo')\n\n private _archivistInstance: ArchivistInstance | undefined\n\n override get queries(): string[] {\n return [WitnessObserveQuerySchema, ...super.queries]\n }\n\n async getArchivistInstance() {\n const archivistAddress = this.archivist\n this._archivistInstance = this._archivistInstance ?? (isAddress(archivistAddress) ? await this.resolve(archivistAddress) : undefined)\n return this._archivistInstance\n }\n\n /** @function observe The main entry point for a witness. Do not override this function. Implement/override observeHandler for custom functionality */\n async observe(inPayloads?: TIn[]): Promise<(WithoutPrivateStorageMeta<TOut>)[]> {\n this._noOverride('observe')\n this.isSupportedQuery(WitnessObserveQuerySchema, 'observe')\n return await this.spanAsync('observe', async () => {\n if (this.reentrancy?.scope === 'global' && this.reentrancy.action === 'skip' && this.globalReentrancyMutex?.isLocked()) {\n return []\n }\n try {\n return await this.busy(async () => {\n await this.globalReentrancyMutex?.acquire()\n this._noOverride('observe')\n await this.startedAsync('throw')\n await this.emit('observeStart', { inPayloads, mod: this } as TEventData['observeStart'])\n const outPayloads = assertEx(await this.observeHandler(inPayloads), () => 'Trying to witness nothing')\n // assertEx(outPayloads.length > 0, 'Trying to witness empty list')\n for (const payload of outPayloads ?? []) assertEx(payload.schema, () => 'observe: Missing Schema')\n\n const archivist = await this.getArchivistInstance()\n if (archivist) {\n await archivist.insert(outPayloads)\n }\n\n await this.emit('observeEnd', {\n inPayloads, mod: this, outPayloads,\n } as TEventData['observeEnd'])\n\n return PayloadBuilder.omitPrivateStorageMeta<TOut>(outPayloads)\n })\n } finally {\n this.globalReentrancyMutex?.release()\n }\n }, { timeBudgetLimit: 200 })\n }\n\n async observeQuery(payloads?: TIn[], account?: AccountInstance): Promise<ModuleQueryResult<TOut>> {\n this._noOverride('observeQuery')\n const queryPayload: WitnessObserveQuery = { schema: WitnessObserveQuerySchema }\n return await this.sendQueryRaw(queryPayload, payloads, account)\n }\n\n /** @function queryHandler Calls observe for an observe query. Override to support additional queries. */\n protected override async queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(\n query: T,\n payloads?: Payload[],\n queryConfig?: TConfig,\n ): Promise<ModuleQueryHandlerResult> {\n const wrapper = QueryBoundWitnessWrapper.parseQuery<WitnessQueries>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(await this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n // Remove the query payload from the arguments passed to us so we don't observe it\n const filteredObservation = (await PayloadBuilder.filterExclude(payloads, query.query)) as TIn[]\n switch (queryPayload.schema) {\n case WitnessObserveQuerySchema: {\n const observePayloads = await this.observe(filteredObservation)\n resultPayloads.push(...observePayloads)\n break\n }\n default: {\n return super.queryHandler(query, payloads)\n }\n }\n return PayloadBuilder.omitPrivateStorageMeta(resultPayloads) as ModuleQueryHandlerResult\n }\n\n /** @function observeHandler Implement or override to add custom functionality to a witness */\n protected abstract observeHandler(payloads?: TIn[]): Promisable<TOut[]>\n}\n"],"mappings":";AACA;AAAA,EACE;AAAA,EAAU;AAAA,EAAgB;AAAA,OACrB;AAIP,SAAS,gCAAgC;AACzC,SAAS,8BAA8B;AAIvC,SAAS,uBAAuB;AAChC,SAAS,sBAAsB;AAY/B;AAAA,EACE;AAAA,EACA;AAAA,OACK;AAEP,gBAAgB;AACT,IAAe,kBAAf,MAAe,yBAUZ,uBACyD;AAAA,EACjE,OAAyB,gBAA0B,CAAC,GAAG,MAAM,eAAe,mBAAmB;AAAA,EAC/F,OAAyB,sBAA8B;AAAA,EACvD,OAAyB,aAAa,eAAe,mBAAmB,kBAAiB,KAAK;AAAA,EAEtF;AAAA,EAER,IAAa,UAAoB;AAC/B,WAAO,CAAC,2BAA2B,GAAG,MAAM,OAAO;AAAA,EACrD;AAAA,EAEA,MAAM,uBAAuB;AAC3B,UAAM,mBAAmB,KAAK;AAC9B,SAAK,qBAAqB,KAAK,uBAAuB,UAAU,gBAAgB,IAAI,MAAM,KAAK,QAAQ,gBAAgB,IAAI;AAC3H,WAAO,KAAK;AAAA,EACd;AAAA;AAAA,EAGA,MAAM,QAAQ,YAAkE;AAC9E,SAAK,YAAY,SAAS;AAC1B,SAAK,iBAAiB,2BAA2B,SAAS;AAC1D,WAAO,MAAM,KAAK,UAAU,WAAW,YAAY;AACjD,UAAI,KAAK,YAAY,UAAU,YAAY,KAAK,WAAW,WAAW,UAAU,KAAK,uBAAuB,SAAS,GAAG;AACtH,eAAO,CAAC;AAAA,MACV;AACA,UAAI;AACF,eAAO,MAAM,KAAK,KAAK,YAAY;AACjC,gBAAM,KAAK,uBAAuB,QAAQ;AAC1C,eAAK,YAAY,SAAS;AAC1B,gBAAM,KAAK,aAAa,OAAO;AAC/B,gBAAM,KAAK,KAAK,gBAAgB,EAAE,YAAY,KAAK,KAAK,CAA+B;AACvF,gBAAM,cAAc,SAAS,MAAM,KAAK,eAAe,UAAU,GAAG,MAAM,2BAA2B;AAErG,qBAAW,WAAW,eAAe,CAAC,EAAG,UAAS,QAAQ,QAAQ,MAAM,yBAAyB;AAEjG,gBAAM,YAAY,MAAM,KAAK,qBAAqB;AAClD,cAAI,WAAW;AACb,kBAAM,UAAU,OAAO,WAAW;AAAA,UACpC;AAEA,gBAAM,KAAK,KAAK,cAAc;AAAA,YAC5B;AAAA,YAAY,KAAK;AAAA,YAAM;AAAA,UACzB,CAA6B;AAE7B,iBAAO,eAAe,uBAA6B,WAAW;AAAA,QAChE,CAAC;AAAA,MACH,UAAE;AACA,aAAK,uBAAuB,QAAQ;AAAA,MACtC;AAAA,IACF,GAAG,EAAE,iBAAiB,IAAI,CAAC;AAAA,EAC7B;AAAA,EAEA,MAAM,aAAa,UAAkB,SAA6D;AAChG,SAAK,YAAY,cAAc;AAC/B,UAAM,eAAoC,EAAE,QAAQ,0BAA0B;AAC9E,WAAO,MAAM,KAAK,aAAa,cAAc,UAAU,OAAO;AAAA,EAChE;AAAA;AAAA,EAGA,MAAyB,aACvB,OACA,UACA,aACmC;AACnC,UAAM,UAAU,yBAAyB,WAA2B,OAAO,QAAQ;AACnF,UAAM,eAAe,MAAM,QAAQ,SAAS;AAC5C,aAAS,MAAM,KAAK,UAAU,OAAO,UAAU,WAAW,CAAC;AAC3D,UAAM,iBAA4B,CAAC;AAEnC,UAAM,sBAAuB,MAAM,eAAe,cAAc,UAAU,MAAM,KAAK;AACrF,YAAQ,aAAa,QAAQ;AAAA,MAC3B,KAAK,2BAA2B;AAC9B,cAAM,kBAAkB,MAAM,KAAK,QAAQ,mBAAmB;AAC9D,uBAAe,KAAK,GAAG,eAAe;AACtC;AAAA,MACF;AAAA,MACA,SAAS;AACP,eAAO,MAAM,aAAa,OAAO,QAAQ;AAAA,MAC3C;AAAA,IACF;AACA,WAAO,eAAe,uBAAuB,cAAc;AAAA,EAC7D;AAIF;","names":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@xyo-network/abstract-witness",
3
- "version": "5.2.22",
3
+ "version": "5.2.25",
4
4
  "description": "Primary SDK for using XYO Protocol 2.0",
5
5
  "homepage": "https://xyo.network",
6
6
  "bugs": {
@@ -36,24 +36,23 @@
36
36
  "!**/*.test.*"
37
37
  ],
38
38
  "dependencies": {
39
- "@xylabs/sdk-js": "~5.0.61",
40
- "@xylabs/telemetry": "~5.0.61",
41
- "@xyo-network/account-model": "~5.2.22",
42
- "@xyo-network/archivist-model": "~5.2.22",
43
- "@xyo-network/boundwitness-model": "~5.2.22",
44
- "@xyo-network/boundwitness-wrapper": "~5.2.22",
45
- "@xyo-network/module-abstract": "~5.2.22",
46
- "@xyo-network/module-model": "~5.2.22",
47
- "@xyo-network/payload-builder": "~5.2.22",
48
- "@xyo-network/payload-model": "~5.2.22",
49
- "@xyo-network/witness-model": "~5.2.22"
39
+ "@xylabs/sdk-js": "~5.0.63",
40
+ "@xyo-network/account-model": "~5.2.25",
41
+ "@xyo-network/archivist-model": "~5.2.25",
42
+ "@xyo-network/boundwitness-model": "~5.2.25",
43
+ "@xyo-network/boundwitness-wrapper": "~5.2.25",
44
+ "@xyo-network/module-abstract": "~5.2.25",
45
+ "@xyo-network/module-model": "~5.2.25",
46
+ "@xyo-network/payload-builder": "~5.2.25",
47
+ "@xyo-network/payload-model": "~5.2.25",
48
+ "@xyo-network/witness-model": "~5.2.25"
50
49
  },
51
50
  "devDependencies": {
52
51
  "@xylabs/ts-scripts-yarn3": "~7.2.32",
53
52
  "@xylabs/tsconfig": "~7.2.32",
54
- "@xylabs/vitest-extended": "~5.0.61",
53
+ "@xylabs/vitest-extended": "~5.0.63",
55
54
  "typescript": "~5.9.3",
56
- "vitest": "~4.0.16"
55
+ "vitest": "~4.0.17"
57
56
  },
58
57
  "publishConfig": {
59
58
  "access": "public"
@@ -2,7 +2,6 @@ import type { Promisable } from '@xylabs/sdk-js'
2
2
  import {
3
3
  assertEx, globallyUnique, isAddress,
4
4
  } from '@xylabs/sdk-js'
5
- import { spanAsync } from '@xylabs/telemetry'
6
5
  import type { AccountInstance } from '@xyo-network/account-model'
7
6
  import type { ArchivistInstance } from '@xyo-network/archivist-model'
8
7
  import type { QueryBoundWitness } from '@xyo-network/boundwitness-model'
@@ -62,7 +61,7 @@ export abstract class AbstractWitness<
62
61
  async observe(inPayloads?: TIn[]): Promise<(WithoutPrivateStorageMeta<TOut>)[]> {
63
62
  this._noOverride('observe')
64
63
  this.isSupportedQuery(WitnessObserveQuerySchema, 'observe')
65
- return await spanAsync('observe', async () => {
64
+ return await this.spanAsync('observe', async () => {
66
65
  if (this.reentrancy?.scope === 'global' && this.reentrancy.action === 'skip' && this.globalReentrancyMutex?.isLocked()) {
67
66
  return []
68
67
  }
@@ -90,7 +89,7 @@ export abstract class AbstractWitness<
90
89
  } finally {
91
90
  this.globalReentrancyMutex?.release()
92
91
  }
93
- }, this.tracer)
92
+ }, { timeBudgetLimit: 200 })
94
93
  }
95
94
 
96
95
  async observeQuery(payloads?: TIn[], account?: AccountInstance): Promise<ModuleQueryResult<TOut>> {