@xyo-network/sentinel-abstract 2.111.3 → 3.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/neutral/index.d.ts +26 -2
- package/package.json +18 -37
- package/xy.config.ts +12 -0
- package/dist/browser/AbstractSentinel.d.cts +0 -24
- package/dist/browser/AbstractSentinel.d.cts.map +0 -1
- package/dist/browser/AbstractSentinel.d.mts +0 -24
- package/dist/browser/AbstractSentinel.d.mts.map +0 -1
- package/dist/browser/AbstractSentinel.d.ts +0 -24
- package/dist/browser/AbstractSentinel.d.ts.map +0 -1
- package/dist/browser/index.cjs +0 -156
- package/dist/browser/index.cjs.map +0 -1
- package/dist/browser/index.d.cts +0 -2
- package/dist/browser/index.d.cts.map +0 -1
- package/dist/browser/index.d.mts +0 -2
- package/dist/browser/index.d.mts.map +0 -1
- package/dist/browser/index.d.ts +0 -2
- package/dist/browser/index.d.ts.map +0 -1
- package/dist/browser/index.mjs +0 -135
- package/dist/browser/index.mjs.map +0 -1
- package/dist/neutral/AbstractSentinel.d.cts +0 -24
- package/dist/neutral/AbstractSentinel.d.cts.map +0 -1
- package/dist/neutral/AbstractSentinel.d.mts +0 -24
- package/dist/neutral/AbstractSentinel.d.mts.map +0 -1
- package/dist/neutral/AbstractSentinel.d.ts +0 -24
- package/dist/neutral/AbstractSentinel.d.ts.map +0 -1
- package/dist/neutral/index.cjs +0 -156
- package/dist/neutral/index.cjs.map +0 -1
- package/dist/neutral/index.d.cts +0 -2
- package/dist/neutral/index.d.cts.map +0 -1
- package/dist/neutral/index.d.mts +0 -2
- package/dist/neutral/index.d.mts.map +0 -1
- package/dist/neutral/index.d.ts.map +0 -1
- package/dist/node/AbstractSentinel.d.cts +0 -24
- package/dist/node/AbstractSentinel.d.cts.map +0 -1
- package/dist/node/AbstractSentinel.d.mts +0 -24
- package/dist/node/AbstractSentinel.d.mts.map +0 -1
- package/dist/node/AbstractSentinel.d.ts +0 -24
- package/dist/node/AbstractSentinel.d.ts.map +0 -1
- package/dist/node/index.cjs +0 -164
- package/dist/node/index.cjs.map +0 -1
- package/dist/node/index.d.cts +0 -2
- package/dist/node/index.d.cts.map +0 -1
- package/dist/node/index.d.mts +0 -2
- package/dist/node/index.d.mts.map +0 -1
- package/dist/node/index.d.ts +0 -2
- package/dist/node/index.d.ts.map +0 -1
- package/dist/node/index.mjs +0 -139
- package/dist/node/index.mjs.map +0 -1
package/dist/neutral/index.d.ts
CHANGED
|
@@ -1,2 +1,26 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import { AccountInstance } from '@xyo-network/account-model';
|
|
2
|
+
import { BoundWitness, QueryBoundWitness } from '@xyo-network/boundwitness-model';
|
|
3
|
+
import { AbstractModuleInstance } from '@xyo-network/module-abstract';
|
|
4
|
+
import { ModuleQueryResult, ModuleConfig, ModuleQueryHandlerResult } from '@xyo-network/module-model';
|
|
5
|
+
import { Schema, Payload } from '@xyo-network/payload-model';
|
|
6
|
+
import { SentinelParams, SentinelModuleEventData, SentinelInstance, CustomSentinelInstance, SentinelJob } from '@xyo-network/sentinel-model';
|
|
7
|
+
|
|
8
|
+
declare abstract class AbstractSentinel<TParams extends SentinelParams = SentinelParams, TEventData extends SentinelModuleEventData<SentinelInstance<TParams>> = SentinelModuleEventData<SentinelInstance<TParams>>> extends AbstractModuleInstance<TParams, TEventData> implements CustomSentinelInstance<TParams, TEventData> {
|
|
9
|
+
static readonly configSchemas: Schema[];
|
|
10
|
+
static readonly defaultConfigSchema: Schema;
|
|
11
|
+
static readonly uniqueName: string;
|
|
12
|
+
history: BoundWitness[];
|
|
13
|
+
private _jobPromise?;
|
|
14
|
+
get jobPromise(): Promise<SentinelJob>;
|
|
15
|
+
get queries(): string[];
|
|
16
|
+
get synchronous(): boolean;
|
|
17
|
+
get throwErrors(): boolean;
|
|
18
|
+
report(inPayloads?: Payload[]): Promise<Payload[]>;
|
|
19
|
+
reportQuery(payloads?: Payload[], account?: AccountInstance): Promise<ModuleQueryResult>;
|
|
20
|
+
protected emitReportEnd(inPayloads?: Payload[], payloads?: Payload[]): Promise<void>;
|
|
21
|
+
protected generateJob(): Promise<SentinelJob>;
|
|
22
|
+
protected queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(query: T, payloads?: Payload[], queryConfig?: TConfig): Promise<ModuleQueryHandlerResult>;
|
|
23
|
+
abstract reportHandler(payloads?: Payload[]): Promise<Payload[]>;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
export { AbstractSentinel };
|
package/package.json
CHANGED
|
@@ -10,52 +10,33 @@
|
|
|
10
10
|
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/issues"
|
|
11
11
|
},
|
|
12
12
|
"dependencies": {
|
|
13
|
-
"@xylabs/assert": "^
|
|
14
|
-
"@xylabs/forget": "^
|
|
15
|
-
"@xylabs/object": "^
|
|
16
|
-
"@xyo-network/account-model": "^
|
|
17
|
-
"@xyo-network/boundwitness-builder": "^
|
|
18
|
-
"@xyo-network/boundwitness-model": "^
|
|
19
|
-
"@xyo-network/boundwitness-wrapper": "^
|
|
20
|
-
"@xyo-network/module-abstract": "^
|
|
21
|
-
"@xyo-network/module-model": "^
|
|
22
|
-
"@xyo-network/payload-model": "^
|
|
23
|
-
"@xyo-network/sentinel-model": "^
|
|
13
|
+
"@xylabs/assert": "^4.0.0",
|
|
14
|
+
"@xylabs/forget": "^4.0.0",
|
|
15
|
+
"@xylabs/object": "^4.0.0",
|
|
16
|
+
"@xyo-network/account-model": "^3.0.1",
|
|
17
|
+
"@xyo-network/boundwitness-builder": "^3.0.1",
|
|
18
|
+
"@xyo-network/boundwitness-model": "^3.0.1",
|
|
19
|
+
"@xyo-network/boundwitness-wrapper": "^3.0.1",
|
|
20
|
+
"@xyo-network/module-abstract": "^3.0.1",
|
|
21
|
+
"@xyo-network/module-model": "^3.0.1",
|
|
22
|
+
"@xyo-network/payload-model": "^3.0.1",
|
|
23
|
+
"@xyo-network/sentinel-model": "^3.0.1"
|
|
24
24
|
},
|
|
25
25
|
"description": "Primary SDK for using XYO Protocol 2.0",
|
|
26
26
|
"devDependencies": {
|
|
27
|
-
"@xylabs/ts-scripts-yarn3": "^
|
|
28
|
-
"@xylabs/tsconfig": "^
|
|
27
|
+
"@xylabs/ts-scripts-yarn3": "^4.0.0-rc.15",
|
|
28
|
+
"@xylabs/tsconfig": "^4.0.0-rc.15",
|
|
29
29
|
"typescript": "^5.5.4"
|
|
30
30
|
},
|
|
31
|
-
"types": "dist/
|
|
31
|
+
"types": "dist/neutral/index.d.ts",
|
|
32
32
|
"exports": {
|
|
33
33
|
".": {
|
|
34
|
-
"
|
|
35
|
-
|
|
36
|
-
"types": "./dist/browser/index.d.cts",
|
|
37
|
-
"default": "./dist/browser/index.cjs"
|
|
38
|
-
},
|
|
39
|
-
"import": {
|
|
40
|
-
"types": "./dist/browser/index.d.mts",
|
|
41
|
-
"default": "./dist/browser/index.mjs"
|
|
42
|
-
}
|
|
43
|
-
},
|
|
44
|
-
"node": {
|
|
45
|
-
"require": {
|
|
46
|
-
"types": "./dist/node/index.d.cts",
|
|
47
|
-
"default": "./dist/node/index.cjs"
|
|
48
|
-
},
|
|
49
|
-
"import": {
|
|
50
|
-
"types": "./dist/node/index.d.mts",
|
|
51
|
-
"default": "./dist/node/index.mjs"
|
|
52
|
-
}
|
|
53
|
-
}
|
|
34
|
+
"types": "./dist/neutral/index.d.ts",
|
|
35
|
+
"default": "./dist/neutral/index.mjs"
|
|
54
36
|
},
|
|
55
37
|
"./package.json": "./package.json"
|
|
56
38
|
},
|
|
57
|
-
"
|
|
58
|
-
"module": "dist/node/index.mjs",
|
|
39
|
+
"module": "dist/neutral/index.mjs",
|
|
59
40
|
"homepage": "https://xyo.network",
|
|
60
41
|
"license": "LGPL-3.0-only",
|
|
61
42
|
"publishConfig": {
|
|
@@ -66,6 +47,6 @@
|
|
|
66
47
|
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
|
|
67
48
|
},
|
|
68
49
|
"sideEffects": false,
|
|
69
|
-
"version": "
|
|
50
|
+
"version": "3.0.1",
|
|
70
51
|
"type": "module"
|
|
71
52
|
}
|
package/xy.config.ts
ADDED
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import { AccountInstance } from '@xyo-network/account-model';
|
|
2
|
-
import { BoundWitness, QueryBoundWitness } from '@xyo-network/boundwitness-model';
|
|
3
|
-
import { AbstractModuleInstance } from '@xyo-network/module-abstract';
|
|
4
|
-
import { ModuleConfig, ModuleQueryHandlerResult, ModuleQueryResult } from '@xyo-network/module-model';
|
|
5
|
-
import { Payload, Schema } from '@xyo-network/payload-model';
|
|
6
|
-
import { CustomSentinelInstance, SentinelInstance, SentinelJob, SentinelModuleEventData, SentinelParams } from '@xyo-network/sentinel-model';
|
|
7
|
-
export declare abstract class AbstractSentinel<TParams extends SentinelParams = SentinelParams, TEventData extends SentinelModuleEventData<SentinelInstance<TParams>> = SentinelModuleEventData<SentinelInstance<TParams>>> extends AbstractModuleInstance<TParams, TEventData> implements CustomSentinelInstance<TParams, TEventData> {
|
|
8
|
-
static readonly configSchemas: Schema[];
|
|
9
|
-
static readonly defaultConfigSchema: Schema;
|
|
10
|
-
static readonly uniqueName: string;
|
|
11
|
-
history: BoundWitness[];
|
|
12
|
-
private _jobPromise?;
|
|
13
|
-
get jobPromise(): Promise<SentinelJob>;
|
|
14
|
-
get queries(): string[];
|
|
15
|
-
get synchronous(): boolean;
|
|
16
|
-
get throwErrors(): boolean;
|
|
17
|
-
report(inPayloads?: Payload[]): Promise<Payload[]>;
|
|
18
|
-
reportQuery(payloads?: Payload[], account?: AccountInstance): Promise<ModuleQueryResult>;
|
|
19
|
-
protected emitReportEnd(inPayloads?: Payload[], payloads?: Payload[]): Promise<void>;
|
|
20
|
-
protected generateJob(): Promise<SentinelJob>;
|
|
21
|
-
protected queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(query: T, payloads?: Payload[], queryConfig?: TConfig): Promise<ModuleQueryHandlerResult>;
|
|
22
|
-
abstract reportHandler(payloads?: Payload[]): Promise<Payload[]>;
|
|
23
|
-
}
|
|
24
|
-
//# sourceMappingURL=AbstractSentinel.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AbstractSentinel.d.ts","sourceRoot":"","sources":["../../src/AbstractSentinel.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAA;AAE5D,OAAO,EAAE,YAAY,EAAmC,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAElH,OAAO,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAA;AACrE,OAAO,EAAE,YAAY,EAAE,wBAAwB,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAA;AACrG,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAC5D,OAAO,EACL,sBAAsB,EAGtB,gBAAgB,EAChB,WAAW,EACX,uBAAuB,EACvB,cAAc,EAIf,MAAM,6BAA6B,CAAA;AAEpC,8BAAsB,gBAAgB,CACpC,OAAO,SAAS,cAAc,GAAG,cAAc,EAC/C,UAAU,SAAS,uBAAuB,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,GAAG,uBAAuB,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAE1H,SAAQ,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAClD,YAAW,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAiD;IACjG,gBAAyB,mBAAmB,EAAE,MAAM,CAAuB;IAC3E,gBAAyB,UAAU,SAA8D;IACjG,OAAO,EAAE,YAAY,EAAE,CAAK;IAC5B,OAAO,CAAC,WAAW,CAAC,CAAsB;IAE1C,IAAI,UAAU,yBAGb;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAE/B;IAED,IAAI,WAAW,IAAI,OAAO,CAEzB;IAED,IAAI,WAAW,IAAI,OAAO,CAEzB;IAEK,MAAM,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAwBlD,WAAW,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,EAAE,OAAO,CAAC,EAAE,eAAe,GAAG,OAAO,CAAC,iBAAiB,CAAC;cAK9E,aAAa,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,EAAE,QAAQ,CAAC,EAAE,OAAO,EAAE;cAO1D,WAAW;cA+CF,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;IAiBpC,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;CACjE"}
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import { AccountInstance } from '@xyo-network/account-model';
|
|
2
|
-
import { BoundWitness, QueryBoundWitness } from '@xyo-network/boundwitness-model';
|
|
3
|
-
import { AbstractModuleInstance } from '@xyo-network/module-abstract';
|
|
4
|
-
import { ModuleConfig, ModuleQueryHandlerResult, ModuleQueryResult } from '@xyo-network/module-model';
|
|
5
|
-
import { Payload, Schema } from '@xyo-network/payload-model';
|
|
6
|
-
import { CustomSentinelInstance, SentinelInstance, SentinelJob, SentinelModuleEventData, SentinelParams } from '@xyo-network/sentinel-model';
|
|
7
|
-
export declare abstract class AbstractSentinel<TParams extends SentinelParams = SentinelParams, TEventData extends SentinelModuleEventData<SentinelInstance<TParams>> = SentinelModuleEventData<SentinelInstance<TParams>>> extends AbstractModuleInstance<TParams, TEventData> implements CustomSentinelInstance<TParams, TEventData> {
|
|
8
|
-
static readonly configSchemas: Schema[];
|
|
9
|
-
static readonly defaultConfigSchema: Schema;
|
|
10
|
-
static readonly uniqueName: string;
|
|
11
|
-
history: BoundWitness[];
|
|
12
|
-
private _jobPromise?;
|
|
13
|
-
get jobPromise(): Promise<SentinelJob>;
|
|
14
|
-
get queries(): string[];
|
|
15
|
-
get synchronous(): boolean;
|
|
16
|
-
get throwErrors(): boolean;
|
|
17
|
-
report(inPayloads?: Payload[]): Promise<Payload[]>;
|
|
18
|
-
reportQuery(payloads?: Payload[], account?: AccountInstance): Promise<ModuleQueryResult>;
|
|
19
|
-
protected emitReportEnd(inPayloads?: Payload[], payloads?: Payload[]): Promise<void>;
|
|
20
|
-
protected generateJob(): Promise<SentinelJob>;
|
|
21
|
-
protected queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(query: T, payloads?: Payload[], queryConfig?: TConfig): Promise<ModuleQueryHandlerResult>;
|
|
22
|
-
abstract reportHandler(payloads?: Payload[]): Promise<Payload[]>;
|
|
23
|
-
}
|
|
24
|
-
//# sourceMappingURL=AbstractSentinel.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AbstractSentinel.d.ts","sourceRoot":"","sources":["../../src/AbstractSentinel.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAA;AAE5D,OAAO,EAAE,YAAY,EAAmC,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAElH,OAAO,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAA;AACrE,OAAO,EAAE,YAAY,EAAE,wBAAwB,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAA;AACrG,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAC5D,OAAO,EACL,sBAAsB,EAGtB,gBAAgB,EAChB,WAAW,EACX,uBAAuB,EACvB,cAAc,EAIf,MAAM,6BAA6B,CAAA;AAEpC,8BAAsB,gBAAgB,CACpC,OAAO,SAAS,cAAc,GAAG,cAAc,EAC/C,UAAU,SAAS,uBAAuB,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,GAAG,uBAAuB,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAE1H,SAAQ,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAClD,YAAW,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAiD;IACjG,gBAAyB,mBAAmB,EAAE,MAAM,CAAuB;IAC3E,gBAAyB,UAAU,SAA8D;IACjG,OAAO,EAAE,YAAY,EAAE,CAAK;IAC5B,OAAO,CAAC,WAAW,CAAC,CAAsB;IAE1C,IAAI,UAAU,yBAGb;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAE/B;IAED,IAAI,WAAW,IAAI,OAAO,CAEzB;IAED,IAAI,WAAW,IAAI,OAAO,CAEzB;IAEK,MAAM,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAwBlD,WAAW,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,EAAE,OAAO,CAAC,EAAE,eAAe,GAAG,OAAO,CAAC,iBAAiB,CAAC;cAK9E,aAAa,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,EAAE,QAAQ,CAAC,EAAE,OAAO,EAAE;cAO1D,WAAW;cA+CF,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;IAiBpC,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;CACjE"}
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import { AccountInstance } from '@xyo-network/account-model';
|
|
2
|
-
import { BoundWitness, QueryBoundWitness } from '@xyo-network/boundwitness-model';
|
|
3
|
-
import { AbstractModuleInstance } from '@xyo-network/module-abstract';
|
|
4
|
-
import { ModuleConfig, ModuleQueryHandlerResult, ModuleQueryResult } from '@xyo-network/module-model';
|
|
5
|
-
import { Payload, Schema } from '@xyo-network/payload-model';
|
|
6
|
-
import { CustomSentinelInstance, SentinelInstance, SentinelJob, SentinelModuleEventData, SentinelParams } from '@xyo-network/sentinel-model';
|
|
7
|
-
export declare abstract class AbstractSentinel<TParams extends SentinelParams = SentinelParams, TEventData extends SentinelModuleEventData<SentinelInstance<TParams>> = SentinelModuleEventData<SentinelInstance<TParams>>> extends AbstractModuleInstance<TParams, TEventData> implements CustomSentinelInstance<TParams, TEventData> {
|
|
8
|
-
static readonly configSchemas: Schema[];
|
|
9
|
-
static readonly defaultConfigSchema: Schema;
|
|
10
|
-
static readonly uniqueName: string;
|
|
11
|
-
history: BoundWitness[];
|
|
12
|
-
private _jobPromise?;
|
|
13
|
-
get jobPromise(): Promise<SentinelJob>;
|
|
14
|
-
get queries(): string[];
|
|
15
|
-
get synchronous(): boolean;
|
|
16
|
-
get throwErrors(): boolean;
|
|
17
|
-
report(inPayloads?: Payload[]): Promise<Payload[]>;
|
|
18
|
-
reportQuery(payloads?: Payload[], account?: AccountInstance): Promise<ModuleQueryResult>;
|
|
19
|
-
protected emitReportEnd(inPayloads?: Payload[], payloads?: Payload[]): Promise<void>;
|
|
20
|
-
protected generateJob(): Promise<SentinelJob>;
|
|
21
|
-
protected queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(query: T, payloads?: Payload[], queryConfig?: TConfig): Promise<ModuleQueryHandlerResult>;
|
|
22
|
-
abstract reportHandler(payloads?: Payload[]): Promise<Payload[]>;
|
|
23
|
-
}
|
|
24
|
-
//# sourceMappingURL=AbstractSentinel.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AbstractSentinel.d.ts","sourceRoot":"","sources":["../../src/AbstractSentinel.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAA;AAE5D,OAAO,EAAE,YAAY,EAAmC,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAElH,OAAO,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAA;AACrE,OAAO,EAAE,YAAY,EAAE,wBAAwB,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAA;AACrG,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAC5D,OAAO,EACL,sBAAsB,EAGtB,gBAAgB,EAChB,WAAW,EACX,uBAAuB,EACvB,cAAc,EAIf,MAAM,6BAA6B,CAAA;AAEpC,8BAAsB,gBAAgB,CACpC,OAAO,SAAS,cAAc,GAAG,cAAc,EAC/C,UAAU,SAAS,uBAAuB,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,GAAG,uBAAuB,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAE1H,SAAQ,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAClD,YAAW,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAiD;IACjG,gBAAyB,mBAAmB,EAAE,MAAM,CAAuB;IAC3E,gBAAyB,UAAU,SAA8D;IACjG,OAAO,EAAE,YAAY,EAAE,CAAK;IAC5B,OAAO,CAAC,WAAW,CAAC,CAAsB;IAE1C,IAAI,UAAU,yBAGb;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAE/B;IAED,IAAI,WAAW,IAAI,OAAO,CAEzB;IAED,IAAI,WAAW,IAAI,OAAO,CAEzB;IAEK,MAAM,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAwBlD,WAAW,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,EAAE,OAAO,CAAC,EAAE,eAAe,GAAG,OAAO,CAAC,iBAAiB,CAAC;cAK9E,aAAa,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,EAAE,QAAQ,CAAC,EAAE,OAAO,EAAE;cAO1D,WAAW;cA+CF,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;IAiBpC,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;CACjE"}
|
package/dist/browser/index.cjs
DELETED
|
@@ -1,156 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
7
|
-
var __export = (target, all) => {
|
|
8
|
-
for (var name in all)
|
|
9
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
-
};
|
|
11
|
-
var __copyProps = (to, from, except, desc) => {
|
|
12
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
-
for (let key of __getOwnPropNames(from))
|
|
14
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
-
}
|
|
17
|
-
return to;
|
|
18
|
-
};
|
|
19
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
20
|
-
|
|
21
|
-
// src/index.ts
|
|
22
|
-
var src_exports = {};
|
|
23
|
-
__export(src_exports, {
|
|
24
|
-
AbstractSentinel: () => AbstractSentinel
|
|
25
|
-
});
|
|
26
|
-
module.exports = __toCommonJS(src_exports);
|
|
27
|
-
|
|
28
|
-
// src/AbstractSentinel.ts
|
|
29
|
-
var import_assert = require("@xylabs/assert");
|
|
30
|
-
var import_forget = require("@xylabs/forget");
|
|
31
|
-
var import_object = require("@xylabs/object");
|
|
32
|
-
var import_boundwitness_builder = require("@xyo-network/boundwitness-builder");
|
|
33
|
-
var import_boundwitness_model = require("@xyo-network/boundwitness-model");
|
|
34
|
-
var import_boundwitness_wrapper = require("@xyo-network/boundwitness-wrapper");
|
|
35
|
-
var import_module_abstract = require("@xyo-network/module-abstract");
|
|
36
|
-
var import_sentinel_model = require("@xyo-network/sentinel-model");
|
|
37
|
-
var AbstractSentinel = class _AbstractSentinel extends import_module_abstract.AbstractModuleInstance {
|
|
38
|
-
static {
|
|
39
|
-
__name(this, "AbstractSentinel");
|
|
40
|
-
}
|
|
41
|
-
static configSchemas = [
|
|
42
|
-
...super.configSchemas,
|
|
43
|
-
import_sentinel_model.SentinelConfigSchema
|
|
44
|
-
];
|
|
45
|
-
static defaultConfigSchema = import_sentinel_model.SentinelConfigSchema;
|
|
46
|
-
static uniqueName = (0, import_object.globallyUnique)("AbstractSentinel", _AbstractSentinel, "xyo");
|
|
47
|
-
history = [];
|
|
48
|
-
_jobPromise;
|
|
49
|
-
get jobPromise() {
|
|
50
|
-
this._jobPromise = this._jobPromise ?? this.generateJob();
|
|
51
|
-
return this._jobPromise;
|
|
52
|
-
}
|
|
53
|
-
get queries() {
|
|
54
|
-
return [
|
|
55
|
-
import_sentinel_model.SentinelReportQuerySchema,
|
|
56
|
-
...super.queries
|
|
57
|
-
];
|
|
58
|
-
}
|
|
59
|
-
get synchronous() {
|
|
60
|
-
return this.config.synchronous ?? false;
|
|
61
|
-
}
|
|
62
|
-
get throwErrors() {
|
|
63
|
-
return this.config.throwErrors ?? true;
|
|
64
|
-
}
|
|
65
|
-
async report(inPayloads) {
|
|
66
|
-
this._noOverride("report");
|
|
67
|
-
const reportPromise = (async () => {
|
|
68
|
-
await this.emit("reportStart", {
|
|
69
|
-
inPayloads,
|
|
70
|
-
mod: this
|
|
71
|
-
});
|
|
72
|
-
const payloads = await this.reportHandler(inPayloads);
|
|
73
|
-
const result = (await new import_boundwitness_builder.BoundWitnessBuilder().payloads(payloads).signer(this.account).build()).flat();
|
|
74
|
-
if (this.config.archiving) {
|
|
75
|
-
(0, import_forget.forget)(this.storeToArchivists(result));
|
|
76
|
-
}
|
|
77
|
-
await this.emitReportEnd(inPayloads, result);
|
|
78
|
-
return result;
|
|
79
|
-
})();
|
|
80
|
-
if (this.synchronous) {
|
|
81
|
-
return await reportPromise;
|
|
82
|
-
} else {
|
|
83
|
-
(0, import_forget.forget)(reportPromise);
|
|
84
|
-
return [];
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
async reportQuery(payloads, account) {
|
|
88
|
-
const queryPayload = {
|
|
89
|
-
schema: import_sentinel_model.SentinelReportQuerySchema
|
|
90
|
-
};
|
|
91
|
-
return await this.sendQueryRaw(queryPayload, payloads, account);
|
|
92
|
-
}
|
|
93
|
-
async emitReportEnd(inPayloads, payloads) {
|
|
94
|
-
const boundwitnesses = payloads?.filter(import_boundwitness_model.isBoundWitness) ?? [];
|
|
95
|
-
const outPayloads = payloads?.filter(import_boundwitness_model.notBoundWitness) ?? [];
|
|
96
|
-
const boundwitness = boundwitnesses.find((bw) => bw.addresses.includes(this.address));
|
|
97
|
-
await this.emit("reportEnd", {
|
|
98
|
-
boundwitness,
|
|
99
|
-
inPayloads,
|
|
100
|
-
mod: this,
|
|
101
|
-
outPayloads
|
|
102
|
-
});
|
|
103
|
-
}
|
|
104
|
-
async generateJob() {
|
|
105
|
-
const job = {
|
|
106
|
-
tasks: []
|
|
107
|
-
};
|
|
108
|
-
let tasks = await Promise.all(this.config.tasks.map(async (task) => ({
|
|
109
|
-
input: task.input ?? false,
|
|
110
|
-
mod: (0, import_assert.assertEx)(await this.resolve(task.mod), () => `Unable to resolve task module [${task.mod}]`)
|
|
111
|
-
})));
|
|
112
|
-
while (tasks.length > 0) {
|
|
113
|
-
const previousTasks = job.tasks.at(-1) ?? [];
|
|
114
|
-
const newListCandidates = tasks.filter((task) => {
|
|
115
|
-
const input = task.input;
|
|
116
|
-
if (input === void 0) {
|
|
117
|
-
return true;
|
|
118
|
-
}
|
|
119
|
-
if (typeof input === "boolean") {
|
|
120
|
-
return true;
|
|
121
|
-
}
|
|
122
|
-
if (typeof input === "string") {
|
|
123
|
-
return previousTasks.find((prevTask) => prevTask.mod.address === input || prevTask.mod.modName === input);
|
|
124
|
-
}
|
|
125
|
-
if (Array.isArray(input)) {
|
|
126
|
-
return previousTasks.find((prevTask) => input.includes(prevTask.mod.address) || input.includes(prevTask.mod.modName ?? prevTask.mod.address));
|
|
127
|
-
}
|
|
128
|
-
});
|
|
129
|
-
const newList = newListCandidates.filter((taskCandidate) => {
|
|
130
|
-
const input = taskCandidate.input;
|
|
131
|
-
return !(Array.isArray(input) && tasks.some((remainingTask) => input.includes(remainingTask.mod.address) || input.includes(remainingTask.mod.modName ?? remainingTask.mod.address)));
|
|
132
|
-
});
|
|
133
|
-
(0, import_assert.assertEx)(newList.length > 0, () => `Unable to generateJob [${tasks.length}]`);
|
|
134
|
-
job.tasks.push(newList);
|
|
135
|
-
tasks = tasks.filter((task) => !newList.includes(task));
|
|
136
|
-
}
|
|
137
|
-
return job;
|
|
138
|
-
}
|
|
139
|
-
async queryHandler(query, payloads, queryConfig) {
|
|
140
|
-
const wrapper = await import_boundwitness_wrapper.QueryBoundWitnessWrapper.parseQuery(query, payloads);
|
|
141
|
-
const queryPayload = await wrapper.getQuery();
|
|
142
|
-
(0, import_assert.assertEx)(await this.queryable(query, payloads, queryConfig));
|
|
143
|
-
const resultPayloads = [];
|
|
144
|
-
switch (queryPayload.schema) {
|
|
145
|
-
case import_sentinel_model.SentinelReportQuerySchema: {
|
|
146
|
-
resultPayloads.push(...await this.report(payloads));
|
|
147
|
-
break;
|
|
148
|
-
}
|
|
149
|
-
default: {
|
|
150
|
-
return super.queryHandler(query, payloads);
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
return resultPayloads;
|
|
154
|
-
}
|
|
155
|
-
};
|
|
156
|
-
//# sourceMappingURL=index.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/AbstractSentinel.ts"],"sourcesContent":["export * from './AbstractSentinel.ts'\n","import { assertEx } from '@xylabs/assert'\nimport { forget } from '@xylabs/forget'\nimport { globallyUnique } from '@xylabs/object'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { BoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, isBoundWitness, notBoundWitness, QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { AbstractModuleInstance } from '@xyo-network/module-abstract'\nimport { ModuleConfig, ModuleQueryHandlerResult, ModuleQueryResult } from '@xyo-network/module-model'\nimport { Payload, Schema } from '@xyo-network/payload-model'\nimport {\n CustomSentinelInstance,\n ResolvedTask,\n SentinelConfigSchema,\n SentinelInstance,\n SentinelJob,\n SentinelModuleEventData,\n SentinelParams,\n SentinelQueries,\n SentinelReportQuery,\n SentinelReportQuerySchema,\n} from '@xyo-network/sentinel-model'\n\nexport abstract class AbstractSentinel<\n TParams extends SentinelParams = SentinelParams,\n TEventData extends SentinelModuleEventData<SentinelInstance<TParams>> = SentinelModuleEventData<SentinelInstance<TParams>>,\n>\n extends AbstractModuleInstance<TParams, TEventData>\n implements CustomSentinelInstance<TParams, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, SentinelConfigSchema]\n static override readonly defaultConfigSchema: Schema = SentinelConfigSchema\n static override readonly uniqueName = globallyUnique('AbstractSentinel', AbstractSentinel, 'xyo')\n history: BoundWitness[] = []\n private _jobPromise?: Promise<SentinelJob>\n\n get jobPromise() {\n this._jobPromise = this._jobPromise ?? this.generateJob()\n return this._jobPromise\n }\n\n override get queries(): string[] {\n return [SentinelReportQuerySchema, ...super.queries]\n }\n\n get synchronous(): boolean {\n return this.config.synchronous ?? false\n }\n\n get throwErrors(): boolean {\n return this.config.throwErrors ?? true\n }\n\n async report(inPayloads?: Payload[]): Promise<Payload[]> {\n this._noOverride('report')\n const reportPromise = (async () => {\n await this.emit('reportStart', { inPayloads, mod: this })\n const payloads = await this.reportHandler(inPayloads)\n\n // create boundwitness\n const result = (await new BoundWitnessBuilder().payloads(payloads).signer(this.account).build()).flat()\n\n if (this.config.archiving) {\n forget(this.storeToArchivists(result))\n }\n\n await this.emitReportEnd(inPayloads, result)\n return result\n })()\n if (this.synchronous) {\n return await reportPromise\n } else {\n forget(reportPromise)\n return []\n }\n }\n\n async reportQuery(payloads?: Payload[], account?: AccountInstance): Promise<ModuleQueryResult> {\n const queryPayload: SentinelReportQuery = { schema: SentinelReportQuerySchema }\n return await this.sendQueryRaw(queryPayload, payloads, account)\n }\n\n protected async emitReportEnd(inPayloads?: Payload[], payloads?: Payload[]) {\n const boundwitnesses = payloads?.filter(isBoundWitness) ?? []\n const outPayloads = payloads?.filter(notBoundWitness) ?? []\n const boundwitness = boundwitnesses.find(bw => bw.addresses.includes(this.address))\n await this.emit('reportEnd', { boundwitness, inPayloads, mod: this, outPayloads })\n }\n\n protected async generateJob() {\n const job: SentinelJob = { tasks: [] }\n let tasks: ResolvedTask[] = await Promise.all(\n this.config.tasks.map(async task => ({\n input: task.input ?? false,\n mod: assertEx(await this.resolve(task.mod), () => `Unable to resolve task module [${task.mod}]`),\n })),\n )\n while (tasks.length > 0) {\n const previousTasks = job.tasks.at(-1) ?? []\n const newListCandidates\n // add all tasks that either require no previous input or have the previous input module already added\n = tasks.filter((task) => {\n const input = task.input\n if (input === undefined) {\n return true\n }\n if (typeof input === 'boolean') {\n return true\n }\n if (typeof input === 'string') {\n return previousTasks.find(prevTask => prevTask.mod.address === input || prevTask.mod.modName === input)\n }\n if (Array.isArray(input)) {\n return previousTasks.find(\n prevTask => input.includes(prevTask.mod.address) || input.includes(prevTask.mod.modName ?? prevTask.mod.address),\n )\n }\n })\n // remove any tasks that have inputs that are in the current list or the remaining tasks\n const newList = newListCandidates.filter((taskCandidate) => {\n const input = taskCandidate.input\n return !(\n Array.isArray(input)\n && tasks.some(\n remainingTask => input.includes(remainingTask.mod.address) || input.includes(remainingTask.mod.modName ?? remainingTask.mod.address),\n )\n )\n })\n assertEx(newList.length > 0, () => `Unable to generateJob [${tasks.length}]`)\n job.tasks.push(newList)\n // remove the tasks we just added\n tasks = tasks.filter(task => !newList.includes(task))\n }\n return job\n }\n\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 = await QueryBoundWitnessWrapper.parseQuery<SentinelQueries>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(await this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n switch (queryPayload.schema) {\n case SentinelReportQuerySchema: {\n resultPayloads.push(...(await this.report(payloads)))\n break\n }\n default: {\n return super.queryHandler(query, payloads)\n }\n }\n return resultPayloads\n }\n\n abstract reportHandler(payloads?: Payload[]): Promise<Payload[]>\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACAA,oBAAyB;AACzB,oBAAuB;AACvB,oBAA+B;AAE/B,kCAAoC;AACpC,gCAAiF;AACjF,kCAAyC;AACzC,6BAAuC;AAGvC,4BAWO;AAEA,IAAeA,mBAAf,MAAeA,0BAIZC,8CAAAA;EA3BV,OA2BUA;;;EAER,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EACvD,OAAyBE,iBAAaC,8BAAe,oBAAoBN,mBAAkB,KAAA;EAC3FO,UAA0B,CAAA;EAClBC;EAER,IAAIC,aAAa;AACf,SAAKD,cAAc,KAAKA,eAAe,KAAKE,YAAW;AACvD,WAAO,KAAKF;EACd;EAEA,IAAaG,UAAoB;AAC/B,WAAO;MAACC;SAA8B,MAAMD;;EAC9C;EAEA,IAAIE,cAAuB;AACzB,WAAO,KAAKC,OAAOD,eAAe;EACpC;EAEA,IAAIE,cAAuB;AACzB,WAAO,KAAKD,OAAOC,eAAe;EACpC;EAEA,MAAMC,OAAOC,YAA4C;AACvD,SAAKC,YAAY,QAAA;AACjB,UAAMC,iBAAiB,YAAA;AACrB,YAAM,KAAKC,KAAK,eAAe;QAAEH;QAAYI,KAAK;MAAK,CAAA;AACvD,YAAMC,WAAW,MAAM,KAAKC,cAAcN,UAAAA;AAG1C,YAAMO,UAAU,MAAM,IAAIC,gDAAAA,EAAsBH,SAASA,QAAAA,EAAUI,OAAO,KAAKC,OAAO,EAAEC,MAAK,GAAIC,KAAI;AAErG,UAAI,KAAKf,OAAOgB,WAAW;AACzBC,kCAAO,KAAKC,kBAAkBR,MAAAA,CAAAA;MAChC;AAEA,YAAM,KAAKS,cAAchB,YAAYO,MAAAA;AACrC,aAAOA;IACT,GAAA;AACA,QAAI,KAAKX,aAAa;AACpB,aAAO,MAAMM;IACf,OAAO;AACLY,gCAAOZ,aAAAA;AACP,aAAO,CAAA;IACT;EACF;EAEA,MAAMe,YAAYZ,UAAsBK,SAAuD;AAC7F,UAAMQ,eAAoC;MAAEC,QAAQxB;IAA0B;AAC9E,WAAO,MAAM,KAAKyB,aAAaF,cAAcb,UAAUK,OAAAA;EACzD;EAEA,MAAgBM,cAAchB,YAAwBK,UAAsB;AAC1E,UAAMgB,iBAAiBhB,UAAUiB,OAAOC,wCAAAA,KAAmB,CAAA;AAC3D,UAAMC,cAAcnB,UAAUiB,OAAOG,yCAAAA,KAAoB,CAAA;AACzD,UAAMC,eAAeL,eAAeM,KAAKC,CAAAA,OAAMA,GAAGC,UAAUC,SAAS,KAAKC,OAAO,CAAA;AACjF,UAAM,KAAK5B,KAAK,aAAa;MAAEuB;MAAc1B;MAAYI,KAAK;MAAMoB;IAAY,CAAA;EAClF;EAEA,MAAgB/B,cAAc;AAC5B,UAAMuC,MAAmB;MAAEC,OAAO,CAAA;IAAG;AACrC,QAAIA,QAAwB,MAAMC,QAAQC,IACxC,KAAKtC,OAAOoC,MAAMG,IAAI,OAAMC,UAAS;MACnCC,OAAOD,KAAKC,SAAS;MACrBlC,SAAKmC,wBAAS,MAAM,KAAKC,QAAQH,KAAKjC,GAAG,GAAG,MAAM,kCAAkCiC,KAAKjC,GAAG,GAAG;IACjG,EAAA,CAAA;AAEF,WAAO6B,MAAMQ,SAAS,GAAG;AACvB,YAAMC,gBAAgBV,IAAIC,MAAMU,GAAG,EAAC,KAAM,CAAA;AAC1C,YAAMC,oBAEFX,MAAMX,OAAO,CAACe,SAAAA;AACd,cAAMC,QAAQD,KAAKC;AACnB,YAAIA,UAAUO,QAAW;AACvB,iBAAO;QACT;AACA,YAAI,OAAOP,UAAU,WAAW;AAC9B,iBAAO;QACT;AACA,YAAI,OAAOA,UAAU,UAAU;AAC7B,iBAAOI,cAAcf,KAAKmB,CAAAA,aAAYA,SAAS1C,IAAI2B,YAAYO,SAASQ,SAAS1C,IAAI2C,YAAYT,KAAAA;QACnG;AACA,YAAIU,MAAMC,QAAQX,KAAAA,GAAQ;AACxB,iBAAOI,cAAcf,KACnBmB,CAAAA,aAAYR,MAAMR,SAASgB,SAAS1C,IAAI2B,OAAO,KAAKO,MAAMR,SAASgB,SAAS1C,IAAI2C,WAAWD,SAAS1C,IAAI2B,OAAO,CAAA;QAEnH;MACF,CAAA;AAEF,YAAMmB,UAAUN,kBAAkBtB,OAAO,CAAC6B,kBAAAA;AACxC,cAAMb,QAAQa,cAAcb;AAC5B,eAAO,EACLU,MAAMC,QAAQX,KAAAA,KACXL,MAAMmB,KACPC,CAAAA,kBAAiBf,MAAMR,SAASuB,cAAcjD,IAAI2B,OAAO,KAAKO,MAAMR,SAASuB,cAAcjD,IAAI2C,WAAWM,cAAcjD,IAAI2B,OAAO,CAAA;MAGzI,CAAA;AACAQ,kCAASW,QAAQT,SAAS,GAAG,MAAM,0BAA0BR,MAAMQ,MAAM,GAAG;AAC5ET,UAAIC,MAAMqB,KAAKJ,OAAAA;AAEfjB,cAAQA,MAAMX,OAAOe,CAAAA,SAAQ,CAACa,QAAQpB,SAASO,IAAAA,CAAAA;IACjD;AACA,WAAOL;EACT;EAEA,MAAyBuB,aACvBC,OACAnD,UACAoD,aACmC;AACnC,UAAMC,UAAU,MAAMC,qDAAyBC,WAA4BJ,OAAOnD,QAAAA;AAClF,UAAMa,eAAe,MAAMwC,QAAQG,SAAQ;AAC3CtB,gCAAS,MAAM,KAAKuB,UAAUN,OAAOnD,UAAUoD,WAAAA,CAAAA;AAC/C,UAAMM,iBAA4B,CAAA;AAClC,YAAQ7C,aAAaC,QAAM;MACzB,KAAKxB,iDAA2B;AAC9BoE,uBAAeT,KAAI,GAAK,MAAM,KAAKvD,OAAOM,QAAAA,CAAAA;AAC1C;MACF;MACA,SAAS;AACP,eAAO,MAAMkD,aAAaC,OAAOnD,QAAAA;MACnC;IACF;AACA,WAAO0D;EACT;AAGF;","names":["AbstractSentinel","AbstractModuleInstance","configSchemas","SentinelConfigSchema","defaultConfigSchema","uniqueName","globallyUnique","history","_jobPromise","jobPromise","generateJob","queries","SentinelReportQuerySchema","synchronous","config","throwErrors","report","inPayloads","_noOverride","reportPromise","emit","mod","payloads","reportHandler","result","BoundWitnessBuilder","signer","account","build","flat","archiving","forget","storeToArchivists","emitReportEnd","reportQuery","queryPayload","schema","sendQueryRaw","boundwitnesses","filter","isBoundWitness","outPayloads","notBoundWitness","boundwitness","find","bw","addresses","includes","address","job","tasks","Promise","all","map","task","input","assertEx","resolve","length","previousTasks","at","newListCandidates","undefined","prevTask","modName","Array","isArray","newList","taskCandidate","some","remainingTask","push","queryHandler","query","queryConfig","wrapper","QueryBoundWitnessWrapper","parseQuery","getQuery","queryable","resultPayloads"]}
|
package/dist/browser/index.d.cts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAA"}
|
package/dist/browser/index.d.mts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAA"}
|
package/dist/browser/index.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAA"}
|
package/dist/browser/index.mjs
DELETED
|
@@ -1,135 +0,0 @@
|
|
|
1
|
-
var __defProp = Object.defineProperty;
|
|
2
|
-
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
3
|
-
|
|
4
|
-
// src/AbstractSentinel.ts
|
|
5
|
-
import { assertEx } from "@xylabs/assert";
|
|
6
|
-
import { forget } from "@xylabs/forget";
|
|
7
|
-
import { globallyUnique } from "@xylabs/object";
|
|
8
|
-
import { BoundWitnessBuilder } from "@xyo-network/boundwitness-builder";
|
|
9
|
-
import { isBoundWitness, notBoundWitness } from "@xyo-network/boundwitness-model";
|
|
10
|
-
import { QueryBoundWitnessWrapper } from "@xyo-network/boundwitness-wrapper";
|
|
11
|
-
import { AbstractModuleInstance } from "@xyo-network/module-abstract";
|
|
12
|
-
import { SentinelConfigSchema, SentinelReportQuerySchema } from "@xyo-network/sentinel-model";
|
|
13
|
-
var AbstractSentinel = class _AbstractSentinel extends AbstractModuleInstance {
|
|
14
|
-
static {
|
|
15
|
-
__name(this, "AbstractSentinel");
|
|
16
|
-
}
|
|
17
|
-
static configSchemas = [
|
|
18
|
-
...super.configSchemas,
|
|
19
|
-
SentinelConfigSchema
|
|
20
|
-
];
|
|
21
|
-
static defaultConfigSchema = SentinelConfigSchema;
|
|
22
|
-
static uniqueName = globallyUnique("AbstractSentinel", _AbstractSentinel, "xyo");
|
|
23
|
-
history = [];
|
|
24
|
-
_jobPromise;
|
|
25
|
-
get jobPromise() {
|
|
26
|
-
this._jobPromise = this._jobPromise ?? this.generateJob();
|
|
27
|
-
return this._jobPromise;
|
|
28
|
-
}
|
|
29
|
-
get queries() {
|
|
30
|
-
return [
|
|
31
|
-
SentinelReportQuerySchema,
|
|
32
|
-
...super.queries
|
|
33
|
-
];
|
|
34
|
-
}
|
|
35
|
-
get synchronous() {
|
|
36
|
-
return this.config.synchronous ?? false;
|
|
37
|
-
}
|
|
38
|
-
get throwErrors() {
|
|
39
|
-
return this.config.throwErrors ?? true;
|
|
40
|
-
}
|
|
41
|
-
async report(inPayloads) {
|
|
42
|
-
this._noOverride("report");
|
|
43
|
-
const reportPromise = (async () => {
|
|
44
|
-
await this.emit("reportStart", {
|
|
45
|
-
inPayloads,
|
|
46
|
-
mod: this
|
|
47
|
-
});
|
|
48
|
-
const payloads = await this.reportHandler(inPayloads);
|
|
49
|
-
const result = (await new BoundWitnessBuilder().payloads(payloads).signer(this.account).build()).flat();
|
|
50
|
-
if (this.config.archiving) {
|
|
51
|
-
forget(this.storeToArchivists(result));
|
|
52
|
-
}
|
|
53
|
-
await this.emitReportEnd(inPayloads, result);
|
|
54
|
-
return result;
|
|
55
|
-
})();
|
|
56
|
-
if (this.synchronous) {
|
|
57
|
-
return await reportPromise;
|
|
58
|
-
} else {
|
|
59
|
-
forget(reportPromise);
|
|
60
|
-
return [];
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
async reportQuery(payloads, account) {
|
|
64
|
-
const queryPayload = {
|
|
65
|
-
schema: SentinelReportQuerySchema
|
|
66
|
-
};
|
|
67
|
-
return await this.sendQueryRaw(queryPayload, payloads, account);
|
|
68
|
-
}
|
|
69
|
-
async emitReportEnd(inPayloads, payloads) {
|
|
70
|
-
const boundwitnesses = payloads?.filter(isBoundWitness) ?? [];
|
|
71
|
-
const outPayloads = payloads?.filter(notBoundWitness) ?? [];
|
|
72
|
-
const boundwitness = boundwitnesses.find((bw) => bw.addresses.includes(this.address));
|
|
73
|
-
await this.emit("reportEnd", {
|
|
74
|
-
boundwitness,
|
|
75
|
-
inPayloads,
|
|
76
|
-
mod: this,
|
|
77
|
-
outPayloads
|
|
78
|
-
});
|
|
79
|
-
}
|
|
80
|
-
async generateJob() {
|
|
81
|
-
const job = {
|
|
82
|
-
tasks: []
|
|
83
|
-
};
|
|
84
|
-
let tasks = await Promise.all(this.config.tasks.map(async (task) => ({
|
|
85
|
-
input: task.input ?? false,
|
|
86
|
-
mod: assertEx(await this.resolve(task.mod), () => `Unable to resolve task module [${task.mod}]`)
|
|
87
|
-
})));
|
|
88
|
-
while (tasks.length > 0) {
|
|
89
|
-
const previousTasks = job.tasks.at(-1) ?? [];
|
|
90
|
-
const newListCandidates = tasks.filter((task) => {
|
|
91
|
-
const input = task.input;
|
|
92
|
-
if (input === void 0) {
|
|
93
|
-
return true;
|
|
94
|
-
}
|
|
95
|
-
if (typeof input === "boolean") {
|
|
96
|
-
return true;
|
|
97
|
-
}
|
|
98
|
-
if (typeof input === "string") {
|
|
99
|
-
return previousTasks.find((prevTask) => prevTask.mod.address === input || prevTask.mod.modName === input);
|
|
100
|
-
}
|
|
101
|
-
if (Array.isArray(input)) {
|
|
102
|
-
return previousTasks.find((prevTask) => input.includes(prevTask.mod.address) || input.includes(prevTask.mod.modName ?? prevTask.mod.address));
|
|
103
|
-
}
|
|
104
|
-
});
|
|
105
|
-
const newList = newListCandidates.filter((taskCandidate) => {
|
|
106
|
-
const input = taskCandidate.input;
|
|
107
|
-
return !(Array.isArray(input) && tasks.some((remainingTask) => input.includes(remainingTask.mod.address) || input.includes(remainingTask.mod.modName ?? remainingTask.mod.address)));
|
|
108
|
-
});
|
|
109
|
-
assertEx(newList.length > 0, () => `Unable to generateJob [${tasks.length}]`);
|
|
110
|
-
job.tasks.push(newList);
|
|
111
|
-
tasks = tasks.filter((task) => !newList.includes(task));
|
|
112
|
-
}
|
|
113
|
-
return job;
|
|
114
|
-
}
|
|
115
|
-
async queryHandler(query, payloads, queryConfig) {
|
|
116
|
-
const wrapper = await QueryBoundWitnessWrapper.parseQuery(query, payloads);
|
|
117
|
-
const queryPayload = await wrapper.getQuery();
|
|
118
|
-
assertEx(await this.queryable(query, payloads, queryConfig));
|
|
119
|
-
const resultPayloads = [];
|
|
120
|
-
switch (queryPayload.schema) {
|
|
121
|
-
case SentinelReportQuerySchema: {
|
|
122
|
-
resultPayloads.push(...await this.report(payloads));
|
|
123
|
-
break;
|
|
124
|
-
}
|
|
125
|
-
default: {
|
|
126
|
-
return super.queryHandler(query, payloads);
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
return resultPayloads;
|
|
130
|
-
}
|
|
131
|
-
};
|
|
132
|
-
export {
|
|
133
|
-
AbstractSentinel
|
|
134
|
-
};
|
|
135
|
-
//# sourceMappingURL=index.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/AbstractSentinel.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { forget } from '@xylabs/forget'\nimport { globallyUnique } from '@xylabs/object'\nimport { AccountInstance } from '@xyo-network/account-model'\nimport { BoundWitnessBuilder } from '@xyo-network/boundwitness-builder'\nimport { BoundWitness, isBoundWitness, notBoundWitness, QueryBoundWitness } from '@xyo-network/boundwitness-model'\nimport { QueryBoundWitnessWrapper } from '@xyo-network/boundwitness-wrapper'\nimport { AbstractModuleInstance } from '@xyo-network/module-abstract'\nimport { ModuleConfig, ModuleQueryHandlerResult, ModuleQueryResult } from '@xyo-network/module-model'\nimport { Payload, Schema } from '@xyo-network/payload-model'\nimport {\n CustomSentinelInstance,\n ResolvedTask,\n SentinelConfigSchema,\n SentinelInstance,\n SentinelJob,\n SentinelModuleEventData,\n SentinelParams,\n SentinelQueries,\n SentinelReportQuery,\n SentinelReportQuerySchema,\n} from '@xyo-network/sentinel-model'\n\nexport abstract class AbstractSentinel<\n TParams extends SentinelParams = SentinelParams,\n TEventData extends SentinelModuleEventData<SentinelInstance<TParams>> = SentinelModuleEventData<SentinelInstance<TParams>>,\n>\n extends AbstractModuleInstance<TParams, TEventData>\n implements CustomSentinelInstance<TParams, TEventData> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, SentinelConfigSchema]\n static override readonly defaultConfigSchema: Schema = SentinelConfigSchema\n static override readonly uniqueName = globallyUnique('AbstractSentinel', AbstractSentinel, 'xyo')\n history: BoundWitness[] = []\n private _jobPromise?: Promise<SentinelJob>\n\n get jobPromise() {\n this._jobPromise = this._jobPromise ?? this.generateJob()\n return this._jobPromise\n }\n\n override get queries(): string[] {\n return [SentinelReportQuerySchema, ...super.queries]\n }\n\n get synchronous(): boolean {\n return this.config.synchronous ?? false\n }\n\n get throwErrors(): boolean {\n return this.config.throwErrors ?? true\n }\n\n async report(inPayloads?: Payload[]): Promise<Payload[]> {\n this._noOverride('report')\n const reportPromise = (async () => {\n await this.emit('reportStart', { inPayloads, mod: this })\n const payloads = await this.reportHandler(inPayloads)\n\n // create boundwitness\n const result = (await new BoundWitnessBuilder().payloads(payloads).signer(this.account).build()).flat()\n\n if (this.config.archiving) {\n forget(this.storeToArchivists(result))\n }\n\n await this.emitReportEnd(inPayloads, result)\n return result\n })()\n if (this.synchronous) {\n return await reportPromise\n } else {\n forget(reportPromise)\n return []\n }\n }\n\n async reportQuery(payloads?: Payload[], account?: AccountInstance): Promise<ModuleQueryResult> {\n const queryPayload: SentinelReportQuery = { schema: SentinelReportQuerySchema }\n return await this.sendQueryRaw(queryPayload, payloads, account)\n }\n\n protected async emitReportEnd(inPayloads?: Payload[], payloads?: Payload[]) {\n const boundwitnesses = payloads?.filter(isBoundWitness) ?? []\n const outPayloads = payloads?.filter(notBoundWitness) ?? []\n const boundwitness = boundwitnesses.find(bw => bw.addresses.includes(this.address))\n await this.emit('reportEnd', { boundwitness, inPayloads, mod: this, outPayloads })\n }\n\n protected async generateJob() {\n const job: SentinelJob = { tasks: [] }\n let tasks: ResolvedTask[] = await Promise.all(\n this.config.tasks.map(async task => ({\n input: task.input ?? false,\n mod: assertEx(await this.resolve(task.mod), () => `Unable to resolve task module [${task.mod}]`),\n })),\n )\n while (tasks.length > 0) {\n const previousTasks = job.tasks.at(-1) ?? []\n const newListCandidates\n // add all tasks that either require no previous input or have the previous input module already added\n = tasks.filter((task) => {\n const input = task.input\n if (input === undefined) {\n return true\n }\n if (typeof input === 'boolean') {\n return true\n }\n if (typeof input === 'string') {\n return previousTasks.find(prevTask => prevTask.mod.address === input || prevTask.mod.modName === input)\n }\n if (Array.isArray(input)) {\n return previousTasks.find(\n prevTask => input.includes(prevTask.mod.address) || input.includes(prevTask.mod.modName ?? prevTask.mod.address),\n )\n }\n })\n // remove any tasks that have inputs that are in the current list or the remaining tasks\n const newList = newListCandidates.filter((taskCandidate) => {\n const input = taskCandidate.input\n return !(\n Array.isArray(input)\n && tasks.some(\n remainingTask => input.includes(remainingTask.mod.address) || input.includes(remainingTask.mod.modName ?? remainingTask.mod.address),\n )\n )\n })\n assertEx(newList.length > 0, () => `Unable to generateJob [${tasks.length}]`)\n job.tasks.push(newList)\n // remove the tasks we just added\n tasks = tasks.filter(task => !newList.includes(task))\n }\n return job\n }\n\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 = await QueryBoundWitnessWrapper.parseQuery<SentinelQueries>(query, payloads)\n const queryPayload = await wrapper.getQuery()\n assertEx(await this.queryable(query, payloads, queryConfig))\n const resultPayloads: Payload[] = []\n switch (queryPayload.schema) {\n case SentinelReportQuerySchema: {\n resultPayloads.push(...(await this.report(payloads)))\n break\n }\n default: {\n return super.queryHandler(query, payloads)\n }\n }\n return resultPayloads\n }\n\n abstract reportHandler(payloads?: Payload[]): Promise<Payload[]>\n}\n"],"mappings":";;;;AAAA,SAASA,gBAAgB;AACzB,SAASC,cAAc;AACvB,SAASC,sBAAsB;AAE/B,SAASC,2BAA2B;AACpC,SAAuBC,gBAAgBC,uBAA0C;AACjF,SAASC,gCAAgC;AACzC,SAASC,8BAA8B;AAGvC,SAGEC,sBAOAC,iCACK;AAEA,IAAeC,mBAAf,MAAeA,0BAIZC,uBAAAA;EA3BV,OA2BUA;;;EAER,OAAyBC,gBAA0B;OAAI,MAAMA;IAAeC;;EAC5E,OAAyBC,sBAA8BD;EACvD,OAAyBE,aAAaC,eAAe,oBAAoBN,mBAAkB,KAAA;EAC3FO,UAA0B,CAAA;EAClBC;EAER,IAAIC,aAAa;AACf,SAAKD,cAAc,KAAKA,eAAe,KAAKE,YAAW;AACvD,WAAO,KAAKF;EACd;EAEA,IAAaG,UAAoB;AAC/B,WAAO;MAACC;SAA8B,MAAMD;;EAC9C;EAEA,IAAIE,cAAuB;AACzB,WAAO,KAAKC,OAAOD,eAAe;EACpC;EAEA,IAAIE,cAAuB;AACzB,WAAO,KAAKD,OAAOC,eAAe;EACpC;EAEA,MAAMC,OAAOC,YAA4C;AACvD,SAAKC,YAAY,QAAA;AACjB,UAAMC,iBAAiB,YAAA;AACrB,YAAM,KAAKC,KAAK,eAAe;QAAEH;QAAYI,KAAK;MAAK,CAAA;AACvD,YAAMC,WAAW,MAAM,KAAKC,cAAcN,UAAAA;AAG1C,YAAMO,UAAU,MAAM,IAAIC,oBAAAA,EAAsBH,SAASA,QAAAA,EAAUI,OAAO,KAAKC,OAAO,EAAEC,MAAK,GAAIC,KAAI;AAErG,UAAI,KAAKf,OAAOgB,WAAW;AACzBC,eAAO,KAAKC,kBAAkBR,MAAAA,CAAAA;MAChC;AAEA,YAAM,KAAKS,cAAchB,YAAYO,MAAAA;AACrC,aAAOA;IACT,GAAA;AACA,QAAI,KAAKX,aAAa;AACpB,aAAO,MAAMM;IACf,OAAO;AACLY,aAAOZ,aAAAA;AACP,aAAO,CAAA;IACT;EACF;EAEA,MAAMe,YAAYZ,UAAsBK,SAAuD;AAC7F,UAAMQ,eAAoC;MAAEC,QAAQxB;IAA0B;AAC9E,WAAO,MAAM,KAAKyB,aAAaF,cAAcb,UAAUK,OAAAA;EACzD;EAEA,MAAgBM,cAAchB,YAAwBK,UAAsB;AAC1E,UAAMgB,iBAAiBhB,UAAUiB,OAAOC,cAAAA,KAAmB,CAAA;AAC3D,UAAMC,cAAcnB,UAAUiB,OAAOG,eAAAA,KAAoB,CAAA;AACzD,UAAMC,eAAeL,eAAeM,KAAKC,CAAAA,OAAMA,GAAGC,UAAUC,SAAS,KAAKC,OAAO,CAAA;AACjF,UAAM,KAAK5B,KAAK,aAAa;MAAEuB;MAAc1B;MAAYI,KAAK;MAAMoB;IAAY,CAAA;EAClF;EAEA,MAAgB/B,cAAc;AAC5B,UAAMuC,MAAmB;MAAEC,OAAO,CAAA;IAAG;AACrC,QAAIA,QAAwB,MAAMC,QAAQC,IACxC,KAAKtC,OAAOoC,MAAMG,IAAI,OAAMC,UAAS;MACnCC,OAAOD,KAAKC,SAAS;MACrBlC,KAAKmC,SAAS,MAAM,KAAKC,QAAQH,KAAKjC,GAAG,GAAG,MAAM,kCAAkCiC,KAAKjC,GAAG,GAAG;IACjG,EAAA,CAAA;AAEF,WAAO6B,MAAMQ,SAAS,GAAG;AACvB,YAAMC,gBAAgBV,IAAIC,MAAMU,GAAG,EAAC,KAAM,CAAA;AAC1C,YAAMC,oBAEFX,MAAMX,OAAO,CAACe,SAAAA;AACd,cAAMC,QAAQD,KAAKC;AACnB,YAAIA,UAAUO,QAAW;AACvB,iBAAO;QACT;AACA,YAAI,OAAOP,UAAU,WAAW;AAC9B,iBAAO;QACT;AACA,YAAI,OAAOA,UAAU,UAAU;AAC7B,iBAAOI,cAAcf,KAAKmB,CAAAA,aAAYA,SAAS1C,IAAI2B,YAAYO,SAASQ,SAAS1C,IAAI2C,YAAYT,KAAAA;QACnG;AACA,YAAIU,MAAMC,QAAQX,KAAAA,GAAQ;AACxB,iBAAOI,cAAcf,KACnBmB,CAAAA,aAAYR,MAAMR,SAASgB,SAAS1C,IAAI2B,OAAO,KAAKO,MAAMR,SAASgB,SAAS1C,IAAI2C,WAAWD,SAAS1C,IAAI2B,OAAO,CAAA;QAEnH;MACF,CAAA;AAEF,YAAMmB,UAAUN,kBAAkBtB,OAAO,CAAC6B,kBAAAA;AACxC,cAAMb,QAAQa,cAAcb;AAC5B,eAAO,EACLU,MAAMC,QAAQX,KAAAA,KACXL,MAAMmB,KACPC,CAAAA,kBAAiBf,MAAMR,SAASuB,cAAcjD,IAAI2B,OAAO,KAAKO,MAAMR,SAASuB,cAAcjD,IAAI2C,WAAWM,cAAcjD,IAAI2B,OAAO,CAAA;MAGzI,CAAA;AACAQ,eAASW,QAAQT,SAAS,GAAG,MAAM,0BAA0BR,MAAMQ,MAAM,GAAG;AAC5ET,UAAIC,MAAMqB,KAAKJ,OAAAA;AAEfjB,cAAQA,MAAMX,OAAOe,CAAAA,SAAQ,CAACa,QAAQpB,SAASO,IAAAA,CAAAA;IACjD;AACA,WAAOL;EACT;EAEA,MAAyBuB,aACvBC,OACAnD,UACAoD,aACmC;AACnC,UAAMC,UAAU,MAAMC,yBAAyBC,WAA4BJ,OAAOnD,QAAAA;AAClF,UAAMa,eAAe,MAAMwC,QAAQG,SAAQ;AAC3CtB,aAAS,MAAM,KAAKuB,UAAUN,OAAOnD,UAAUoD,WAAAA,CAAAA;AAC/C,UAAMM,iBAA4B,CAAA;AAClC,YAAQ7C,aAAaC,QAAM;MACzB,KAAKxB,2BAA2B;AAC9BoE,uBAAeT,KAAI,GAAK,MAAM,KAAKvD,OAAOM,QAAAA,CAAAA;AAC1C;MACF;MACA,SAAS;AACP,eAAO,MAAMkD,aAAaC,OAAOnD,QAAAA;MACnC;IACF;AACA,WAAO0D;EACT;AAGF;","names":["assertEx","forget","globallyUnique","BoundWitnessBuilder","isBoundWitness","notBoundWitness","QueryBoundWitnessWrapper","AbstractModuleInstance","SentinelConfigSchema","SentinelReportQuerySchema","AbstractSentinel","AbstractModuleInstance","configSchemas","SentinelConfigSchema","defaultConfigSchema","uniqueName","globallyUnique","history","_jobPromise","jobPromise","generateJob","queries","SentinelReportQuerySchema","synchronous","config","throwErrors","report","inPayloads","_noOverride","reportPromise","emit","mod","payloads","reportHandler","result","BoundWitnessBuilder","signer","account","build","flat","archiving","forget","storeToArchivists","emitReportEnd","reportQuery","queryPayload","schema","sendQueryRaw","boundwitnesses","filter","isBoundWitness","outPayloads","notBoundWitness","boundwitness","find","bw","addresses","includes","address","job","tasks","Promise","all","map","task","input","assertEx","resolve","length","previousTasks","at","newListCandidates","undefined","prevTask","modName","Array","isArray","newList","taskCandidate","some","remainingTask","push","queryHandler","query","queryConfig","wrapper","QueryBoundWitnessWrapper","parseQuery","getQuery","queryable","resultPayloads"]}
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import { AccountInstance } from '@xyo-network/account-model';
|
|
2
|
-
import { BoundWitness, QueryBoundWitness } from '@xyo-network/boundwitness-model';
|
|
3
|
-
import { AbstractModuleInstance } from '@xyo-network/module-abstract';
|
|
4
|
-
import { ModuleConfig, ModuleQueryHandlerResult, ModuleQueryResult } from '@xyo-network/module-model';
|
|
5
|
-
import { Payload, Schema } from '@xyo-network/payload-model';
|
|
6
|
-
import { CustomSentinelInstance, SentinelInstance, SentinelJob, SentinelModuleEventData, SentinelParams } from '@xyo-network/sentinel-model';
|
|
7
|
-
export declare abstract class AbstractSentinel<TParams extends SentinelParams = SentinelParams, TEventData extends SentinelModuleEventData<SentinelInstance<TParams>> = SentinelModuleEventData<SentinelInstance<TParams>>> extends AbstractModuleInstance<TParams, TEventData> implements CustomSentinelInstance<TParams, TEventData> {
|
|
8
|
-
static readonly configSchemas: Schema[];
|
|
9
|
-
static readonly defaultConfigSchema: Schema;
|
|
10
|
-
static readonly uniqueName: string;
|
|
11
|
-
history: BoundWitness[];
|
|
12
|
-
private _jobPromise?;
|
|
13
|
-
get jobPromise(): Promise<SentinelJob>;
|
|
14
|
-
get queries(): string[];
|
|
15
|
-
get synchronous(): boolean;
|
|
16
|
-
get throwErrors(): boolean;
|
|
17
|
-
report(inPayloads?: Payload[]): Promise<Payload[]>;
|
|
18
|
-
reportQuery(payloads?: Payload[], account?: AccountInstance): Promise<ModuleQueryResult>;
|
|
19
|
-
protected emitReportEnd(inPayloads?: Payload[], payloads?: Payload[]): Promise<void>;
|
|
20
|
-
protected generateJob(): Promise<SentinelJob>;
|
|
21
|
-
protected queryHandler<T extends QueryBoundWitness = QueryBoundWitness, TConfig extends ModuleConfig = ModuleConfig>(query: T, payloads?: Payload[], queryConfig?: TConfig): Promise<ModuleQueryHandlerResult>;
|
|
22
|
-
abstract reportHandler(payloads?: Payload[]): Promise<Payload[]>;
|
|
23
|
-
}
|
|
24
|
-
//# sourceMappingURL=AbstractSentinel.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AbstractSentinel.d.ts","sourceRoot":"","sources":["../../src/AbstractSentinel.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAA;AAE5D,OAAO,EAAE,YAAY,EAAmC,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AAElH,OAAO,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAA;AACrE,OAAO,EAAE,YAAY,EAAE,wBAAwB,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAA;AACrG,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAC5D,OAAO,EACL,sBAAsB,EAGtB,gBAAgB,EAChB,WAAW,EACX,uBAAuB,EACvB,cAAc,EAIf,MAAM,6BAA6B,CAAA;AAEpC,8BAAsB,gBAAgB,CACpC,OAAO,SAAS,cAAc,GAAG,cAAc,EAC/C,UAAU,SAAS,uBAAuB,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,GAAG,uBAAuB,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAE1H,SAAQ,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAClD,YAAW,sBAAsB,CAAC,OAAO,EAAE,UAAU,CAAC;IACtD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAAiD;IACjG,gBAAyB,mBAAmB,EAAE,MAAM,CAAuB;IAC3E,gBAAyB,UAAU,SAA8D;IACjG,OAAO,EAAE,YAAY,EAAE,CAAK;IAC5B,OAAO,CAAC,WAAW,CAAC,CAAsB;IAE1C,IAAI,UAAU,yBAGb;IAED,IAAa,OAAO,IAAI,MAAM,EAAE,CAE/B;IAED,IAAI,WAAW,IAAI,OAAO,CAEzB;IAED,IAAI,WAAW,IAAI,OAAO,CAEzB;IAEK,MAAM,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAwBlD,WAAW,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,EAAE,OAAO,CAAC,EAAE,eAAe,GAAG,OAAO,CAAC,iBAAiB,CAAC;cAK9E,aAAa,CAAC,UAAU,CAAC,EAAE,OAAO,EAAE,EAAE,QAAQ,CAAC,EAAE,OAAO,EAAE;cAO1D,WAAW;cA+CF,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;IAiBpC,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;CACjE"}
|