@xyo-network/crypto-contract-function-read-plugin 6.0.2 → 6.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +5 -0
- package/package.json +33 -36
- package/dist/browser/Diviner/Diviner.d.ts +0 -19
- package/dist/browser/Diviner/Diviner.d.ts.map +0 -1
- package/dist/browser/Diviner/index.d.ts +0 -2
- package/dist/browser/Diviner/index.d.ts.map +0 -1
- package/dist/browser/Plugin.d.ts +0 -4
- package/dist/browser/Plugin.d.ts.map +0 -1
- package/dist/browser/Witness.d.ts +0 -16
- package/dist/browser/Witness.d.ts.map +0 -1
- package/dist/browser/index.d.ts +0 -4
- package/dist/browser/index.d.ts.map +0 -1
- package/dist/browser/index.mjs +0 -150
- package/dist/browser/index.mjs.map +0 -7
- package/dist/node/Diviner/Diviner.d.ts +0 -19
- package/dist/node/Diviner/Diviner.d.ts.map +0 -1
- package/dist/node/Diviner/index.d.ts +0 -2
- package/dist/node/Diviner/index.d.ts.map +0 -1
- package/dist/node/Plugin.d.ts +0 -4
- package/dist/node/Plugin.d.ts.map +0 -1
- package/dist/node/Witness.d.ts +0 -16
- package/dist/node/Witness.d.ts.map +0 -1
- package/dist/node/index.d.ts +0 -4
- package/dist/node/index.d.ts.map +0 -1
- package/dist/node/index.mjs +0 -150
- package/dist/node/index.mjs.map +0 -7
package/README.md
CHANGED
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
[![logo][]](https://xyo.network)
|
|
2
|
+
|
|
1
3
|
# @xyo-network/crypto-contract-function-read-plugin
|
|
2
4
|
|
|
3
5
|
[![npm][npm-badge]][npm-link]
|
|
@@ -36,9 +38,12 @@ bun add {{name}}
|
|
|
36
38
|
|
|
37
39
|
See the [LICENSE](LICENSE) file for license rights and limitations (LGPL-3.0-only).
|
|
38
40
|
|
|
41
|
+
## Credits
|
|
39
42
|
|
|
43
|
+
[Made with 🔥 and ❄️ by XYO Foundation](https://xyo.network)
|
|
40
44
|
|
|
41
45
|
[npm-badge]: https://img.shields.io/npm/v/@xyo-network/crypto-contract-function-read-plugin.svg
|
|
42
46
|
[npm-link]: https://www.npmjs.com/package/@xyo-network/crypto-contract-function-read-plugin
|
|
43
47
|
[license-badge]: https://img.shields.io/npm/l/@xyo-network/crypto-contract-function-read-plugin.svg
|
|
44
48
|
[license-link]: https://github.com/xylabs/sdk-js/blob/main/LICENSE
|
|
49
|
+
[logo]: https://cdn.xy.company/img/brand/XYO_full_colored.png
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@xyo-network/crypto-contract-function-read-plugin",
|
|
3
|
-
"version": "6.0
|
|
3
|
+
"version": "6.1.0",
|
|
4
4
|
"description": "Typescript/Javascript Plugins for XYO Platform",
|
|
5
5
|
"homepage": "https://xyo.network",
|
|
6
6
|
"bugs": {
|
|
@@ -31,8 +31,8 @@
|
|
|
31
31
|
"README.md"
|
|
32
32
|
],
|
|
33
33
|
"dependencies": {
|
|
34
|
-
"@xyo-network/crypto-
|
|
35
|
-
"@xyo-network/crypto-
|
|
34
|
+
"@xyo-network/crypto-nft-payload-plugin": "~6.1.0",
|
|
35
|
+
"@xyo-network/crypto-contract-function-read-payload-plugin": "~6.1.0"
|
|
36
36
|
},
|
|
37
37
|
"devDependencies": {
|
|
38
38
|
"@bitauth/libauth": "~3.0.0",
|
|
@@ -42,36 +42,34 @@
|
|
|
42
42
|
"@opentelemetry/sdk-trace-base": "^2.7.1",
|
|
43
43
|
"@scure/base": "^2.2.0",
|
|
44
44
|
"@scure/bip39": "~2.2.0",
|
|
45
|
-
"@xylabs/geo": "^6.0
|
|
46
|
-
"@xylabs/sdk-js": "^6.0
|
|
47
|
-
"@xylabs/threads": "^6.0
|
|
48
|
-
"@xylabs/toolchain": "~8.1.
|
|
49
|
-
"@xylabs/tsconfig": "~8.1.
|
|
50
|
-
"@xylabs/vitest-extended": "
|
|
51
|
-
"@xyo-network/diviner-boundwitness": "^6.0
|
|
52
|
-
"@xyo-network/diviner-jsonpatch": "
|
|
53
|
-
"@xyo-network/diviner-jsonpath-aggregate-memory": "
|
|
54
|
-
"@xyo-network/diviner-model": "^6.0
|
|
55
|
-
"@xyo-network/diviner-payload-generic": "
|
|
56
|
-
"@xyo-network/diviner-payload-model": "^6.0
|
|
57
|
-
"@xyo-network/diviner-range": "
|
|
58
|
-
"@xyo-network/diviner-temporal-indexing": "
|
|
59
|
-
"@xyo-network/module-model": "^6.0
|
|
60
|
-
"@xyo-network/node-memory": "
|
|
45
|
+
"@xylabs/geo": "^6.1.0",
|
|
46
|
+
"@xylabs/sdk-js": "^6.1.0",
|
|
47
|
+
"@xylabs/threads": "^6.1.0",
|
|
48
|
+
"@xylabs/toolchain": "~8.1.20",
|
|
49
|
+
"@xylabs/tsconfig": "~8.1.20",
|
|
50
|
+
"@xylabs/vitest-extended": "^6.1.0",
|
|
51
|
+
"@xyo-network/diviner-boundwitness": "^6.1.0",
|
|
52
|
+
"@xyo-network/diviner-jsonpatch": "^6.1.0",
|
|
53
|
+
"@xyo-network/diviner-jsonpath-aggregate-memory": "^6.1.0",
|
|
54
|
+
"@xyo-network/diviner-model": "^6.1.0",
|
|
55
|
+
"@xyo-network/diviner-payload-generic": "^6.1.0",
|
|
56
|
+
"@xyo-network/diviner-payload-model": "^6.1.0",
|
|
57
|
+
"@xyo-network/diviner-range": "^6.1.0",
|
|
58
|
+
"@xyo-network/diviner-temporal-indexing": "^6.1.0",
|
|
59
|
+
"@xyo-network/module-model": "^6.1.0",
|
|
60
|
+
"@xyo-network/node-memory": "^6.1.0",
|
|
61
61
|
"@xyo-network/open-zeppelin-typechain": "^4.1.3",
|
|
62
|
-
"@xyo-network/payload-model": "^6.0
|
|
63
|
-
"@xyo-network/payload-utils": "
|
|
64
|
-
"@xyo-network/sdk-js": "^6.0
|
|
65
|
-
"@xyo-network/sdk-protocol-js": "~6.
|
|
66
|
-
"@xyo-network/sentinel-model": "
|
|
67
|
-
"@xyo-network/wallet-model": "
|
|
68
|
-
"@xyo-network/witness-blockchain-abstract": "^6.0
|
|
69
|
-
"@xyo-network/witness-model": "
|
|
70
|
-
"@xyo-network/witness-timestamp": "^6.0
|
|
62
|
+
"@xyo-network/payload-model": "^6.1.0",
|
|
63
|
+
"@xyo-network/payload-utils": "^6.1.0",
|
|
64
|
+
"@xyo-network/sdk-js": "^6.1.0",
|
|
65
|
+
"@xyo-network/sdk-protocol-js": "~6.1",
|
|
66
|
+
"@xyo-network/sentinel-model": "^6.1.0",
|
|
67
|
+
"@xyo-network/wallet-model": "^6.1.0",
|
|
68
|
+
"@xyo-network/witness-blockchain-abstract": "^6.1.0",
|
|
69
|
+
"@xyo-network/witness-model": "^6.1.0",
|
|
70
|
+
"@xyo-network/witness-timestamp": "^6.1.0",
|
|
71
71
|
"ajv": "^8.20.0",
|
|
72
72
|
"async-mutex": "^0.5.0",
|
|
73
|
-
"bn.js": "^5.2.3",
|
|
74
|
-
"buffer": "^6.0.3",
|
|
75
73
|
"debug": "~4.4.3",
|
|
76
74
|
"eslint": "^10.4.1",
|
|
77
75
|
"ethers": "^6.16.0",
|
|
@@ -81,13 +79,12 @@
|
|
|
81
79
|
"jsonpath-plus": "^10.4.0",
|
|
82
80
|
"lru-cache": "^11.5.1",
|
|
83
81
|
"observable-fns": "~0.6.1",
|
|
84
|
-
"pako": "~2.1.0",
|
|
85
82
|
"typescript": "~6.0.3",
|
|
86
83
|
"vite": "^8.0.16",
|
|
87
84
|
"vitest": "^4.1.8",
|
|
88
85
|
"webextension-polyfill": "^0.12.0",
|
|
89
86
|
"zod": "^4.4.3",
|
|
90
|
-
"@xyo-network/evm-nft-id-payload-plugin": "~6.0
|
|
87
|
+
"@xyo-network/evm-nft-id-payload-plugin": "~6.1.0"
|
|
91
88
|
},
|
|
92
89
|
"peerDependencies": {
|
|
93
90
|
"@bitauth/libauth": "~3.0",
|
|
@@ -101,21 +98,21 @@
|
|
|
101
98
|
"@xylabs/sdk-js": "^6.0",
|
|
102
99
|
"@xylabs/threads": "^6.0",
|
|
103
100
|
"@xyo-network/sdk-js": "^6.0",
|
|
104
|
-
"@xyo-network/sdk-protocol-js": "
|
|
101
|
+
"@xyo-network/sdk-protocol-js": "^6.1",
|
|
105
102
|
"ajv": "^8.20",
|
|
106
103
|
"async-mutex": "^0.5",
|
|
107
|
-
"bn.js": "^5.2",
|
|
108
|
-
"buffer": "^6.0",
|
|
109
104
|
"debug": "~4.4",
|
|
110
105
|
"ethers": "^6.16",
|
|
111
106
|
"hash-wasm": "^4.12",
|
|
112
107
|
"idb": "^8.0",
|
|
113
108
|
"lru-cache": "^11.3",
|
|
114
109
|
"observable-fns": "~0.6",
|
|
115
|
-
"pako": "~2.1",
|
|
116
110
|
"webextension-polyfill": "^0.12",
|
|
117
111
|
"zod": "^4.4"
|
|
118
112
|
},
|
|
113
|
+
"engines": {
|
|
114
|
+
"node": "^24"
|
|
115
|
+
},
|
|
119
116
|
"publishConfig": {
|
|
120
117
|
"access": "public"
|
|
121
118
|
}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import type { Promisable } from '@xylabs/sdk-js';
|
|
2
|
-
import type { ContractInfo, CryptoContractDivinerParams, CryptoContractFunctionCallResult } from '@xyo-network/crypto-contract-function-read-payload-plugin';
|
|
3
|
-
import { CryptoContractDivinerLabels } from '@xyo-network/crypto-contract-function-read-payload-plugin';
|
|
4
|
-
import type { Payload, Schema } from '@xyo-network/sdk-js';
|
|
5
|
-
import { AbstractDiviner } from '@xyo-network/sdk-js';
|
|
6
|
-
/** @deprecated use EvmCallDiviner instead */
|
|
7
|
-
export type FindCallResult<TResult = string, TPayload = Payload> = [TResult, TPayload] | [undefined, TPayload] | [undefined, undefined];
|
|
8
|
-
/** @deprecated use EvmCallDiviner instead */
|
|
9
|
-
export declare class CryptoContractDiviner<TParams extends CryptoContractDivinerParams = CryptoContractDivinerParams> extends AbstractDiviner<TParams> {
|
|
10
|
-
static readonly configSchemas: Schema[];
|
|
11
|
-
static readonly defaultConfigSchema: Schema;
|
|
12
|
-
static readonly labels: CryptoContractDivinerLabels;
|
|
13
|
-
protected static findCallResult<TResult = string>(address: string, functionName: string, payloads: CryptoContractFunctionCallResult[]): TResult | undefined;
|
|
14
|
-
protected static matchingExistingField<R = string, T extends Payload = Payload>(objs: T[], field: keyof T): R | undefined;
|
|
15
|
-
protected contractInfoRequiredFields(callResults: CryptoContractFunctionCallResult[]): ContractInfo;
|
|
16
|
-
protected divineHandler(inPayloads?: CryptoContractFunctionCallResult[]): Promise<ContractInfo[]>;
|
|
17
|
-
protected reduceResults(callResults: CryptoContractFunctionCallResult[]): Promisable<ContractInfo['results']>;
|
|
18
|
-
}
|
|
19
|
-
//# sourceMappingURL=Diviner.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Diviner.d.ts","sourceRoot":"","sources":["../../../src/Diviner/Diviner.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAA;AAEhD,OAAO,KAAK,EACV,YAAY,EACZ,2BAA2B,EAC3B,gCAAgC,EACjC,MAAM,2DAA2D,CAAA;AAClE,OAAO,EAIL,2BAA2B,EAE5B,MAAM,2DAA2D,CAAA;AAClE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAA;AAC1D,OAAO,EAAE,eAAe,EAAyB,MAAM,qBAAqB,CAAA;AAE5E,6CAA6C;AAC7C,MAAM,MAAM,cAAc,CAAC,OAAO,GAAG,MAAM,EAAE,QAAQ,GAAG,OAAO,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,GAAG,CAAC,SAAS,EAAE,QAAQ,CAAC,GAAG,CAAC,SAAS,EAAE,SAAS,CAAC,CAAA;AAEvI,6CAA6C;AAC7C,qBAAa,qBAAqB,CAAC,OAAO,SAAS,2BAA2B,GAAG,2BAA2B,CAAE,SAAQ,eAAe,CAAC,OAAO,CAAC;IAC5I,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAA8D;IAC9G,gBAAyB,mBAAmB,EAAE,MAAM,CAAoC;IACxF,gBAAyB,MAAM,EAAE,2BAA2B,CAAsD;IAElH,SAAS,CAAC,MAAM,CAAC,cAAc,CAAC,OAAO,GAAG,MAAM,EAC9C,OAAO,EAAE,MAAM,EACf,YAAY,EAAE,MAAM,EACpB,QAAQ,EAAE,gCAAgC,EAAE,GAC3C,OAAO,GAAG,SAAS;IAKtB,SAAS,CAAC,MAAM,CAAC,qBAAqB,CAAC,CAAC,GAAG,MAAM,EAAE,CAAC,SAAS,OAAO,GAAG,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,GAAG,CAAC,GAAG,SAAS;IASzH,SAAS,CAAC,0BAA0B,CAAC,WAAW,EAAE,gCAAgC,EAAE,GAAG,YAAY;cAQ1E,aAAa,CAAC,UAAU,GAAE,gCAAgC,EAAO,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;IAyBpH,SAAS,CAAC,aAAa,CAAC,WAAW,EAAE,gCAAgC,EAAE,GAAG,UAAU,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;CAO9G"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/Diviner/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA"}
|
package/dist/browser/Plugin.d.ts
DELETED
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import { CryptoContractFunctionReadWitness } from './Witness.ts';
|
|
2
|
-
/** @deprecated use EvmCallWitness instead */
|
|
3
|
-
export declare const CryptoContractFunctionReadWitnessPlugin: () => import("@xyo-network/sdk-js").PayloadSetWitnessPlugin<CryptoContractFunctionReadWitness<import("./Witness.ts").CryptoContractFunctionReadWitnessParams>>;
|
|
4
|
-
//# sourceMappingURL=Plugin.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Plugin.d.ts","sourceRoot":"","sources":["../../src/Plugin.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,iCAAiC,EAAE,MAAM,cAAc,CAAA;AAEhE,6CAA6C;AAC7C,eAAO,MAAM,uCAAuC,gKAUjD,CAAA"}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import type { CryptoContractFunctionCall, CryptoContractFunctionCallResult, CryptoContractFunctionReadWitnessConfig } from '@xyo-network/crypto-contract-function-read-payload-plugin';
|
|
2
|
-
import type { AnyConfigSchema, Schema, WitnessParams } from '@xyo-network/sdk-js';
|
|
3
|
-
import { AbstractWitness } from '@xyo-network/sdk-js';
|
|
4
|
-
import type { InterfaceAbi, Provider } from 'ethers';
|
|
5
|
-
/** @deprecated use EvmCallWitness instead */
|
|
6
|
-
export interface CryptoContractFunctionReadWitnessParams extends WitnessParams<AnyConfigSchema<CryptoContractFunctionReadWitnessConfig>> {
|
|
7
|
-
providers: Provider[];
|
|
8
|
-
}
|
|
9
|
-
/** @deprecated use EvmCallWitness instead */
|
|
10
|
-
export declare class CryptoContractFunctionReadWitness<TParams extends CryptoContractFunctionReadWitnessParams = CryptoContractFunctionReadWitnessParams> extends AbstractWitness<TParams, CryptoContractFunctionCall, CryptoContractFunctionCallResult> {
|
|
11
|
-
static readonly configSchemas: Schema[];
|
|
12
|
-
static readonly defaultConfigSchema: Schema;
|
|
13
|
-
get abi(): InterfaceAbi;
|
|
14
|
-
protected observeHandler(inPayloads?: CryptoContractFunctionCall[]): Promise<CryptoContractFunctionCallResult[]>;
|
|
15
|
-
}
|
|
16
|
-
//# sourceMappingURL=Witness.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,0BAA0B,EAE1B,gCAAgC,EAEhC,uCAAuC,EACxC,MAAM,2DAA2D,CAAA;AAMlE,OAAO,KAAK,EACV,eAAe,EAAE,MAAM,EAAE,aAAa,EACvC,MAAM,qBAAqB,CAAA;AAC5B,OAAO,EAAE,eAAe,EAAyB,MAAM,qBAAqB,CAAA;AAC5E,OAAO,KAAK,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AAGpD,6CAA6C;AAC7C,MAAM,WAAW,uCAAwC,SAAQ,aAAa,CAC5E,eAAe,CAAC,uCAAuC,CAAC,CAAC;IAEzD,SAAS,EAAE,QAAQ,EAAE,CAAA;CACtB;AAED,6CAA6C;AAC7C,qBAAa,iCAAiC,CAC5C,OAAO,SAAS,uCAAuC,GAAG,uCAAuC,CACjG,SAAQ,eAAe,CAAC,OAAO,EAAE,0BAA0B,EAAE,gCAAgC,CAAC;IAC9F,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAA0E;IAC1H,gBAAyB,mBAAmB,EAAE,MAAM,CAAgD;IAEpG,IAAI,GAAG,IACoD,YAAY,CACtE;cAEwB,cAAc,CAAC,UAAU,GAAE,0BAA0B,EAAO,GAAG,OAAO,CAAC,gCAAgC,EAAE,CAAC;CAgDpI"}
|
package/dist/browser/index.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AACA,cAAc,oBAAoB,CAAA;AAClC,OAAO,EAAE,uCAAuC,EAAE,uCAAuC,IAAI,OAAO,EAAE,MAAM,aAAa,CAAA;AACzH,cAAc,cAAc,CAAA"}
|
package/dist/browser/index.mjs
DELETED
|
@@ -1,150 +0,0 @@
|
|
|
1
|
-
// src/Diviner/Diviner.ts
|
|
2
|
-
import { assertEx } from "@xylabs/sdk-js";
|
|
3
|
-
import {
|
|
4
|
-
asCryptoContractFunctionCallSuccess,
|
|
5
|
-
ContractInfoSchema,
|
|
6
|
-
CryptoContractDivinerConfigSchema,
|
|
7
|
-
CryptoContractDivinerLabels,
|
|
8
|
-
CryptoContractFunctionCallResultSchema
|
|
9
|
-
} from "@xyo-network/crypto-contract-function-read-payload-plugin";
|
|
10
|
-
import { AbstractDiviner, isPayloadOfSchemaType } from "@xyo-network/sdk-js";
|
|
11
|
-
var CryptoContractDiviner = class _CryptoContractDiviner extends AbstractDiviner {
|
|
12
|
-
static configSchemas = [...super.configSchemas, CryptoContractDivinerConfigSchema];
|
|
13
|
-
static defaultConfigSchema = CryptoContractDivinerConfigSchema;
|
|
14
|
-
static labels = { ...super.labels, ...CryptoContractDivinerLabels };
|
|
15
|
-
static findCallResult(address, functionName, payloads) {
|
|
16
|
-
const foundPayload = payloads.find((payload) => payload.functionName === functionName && payload.address === address);
|
|
17
|
-
return asCryptoContractFunctionCallSuccess(foundPayload)?.result;
|
|
18
|
-
}
|
|
19
|
-
static matchingExistingField(objs, field) {
|
|
20
|
-
const expectedValue = objs.at(0)?.[field];
|
|
21
|
-
const didNotMatch = objs.reduce((prev, obj) => {
|
|
22
|
-
return prev || obj[field] !== expectedValue;
|
|
23
|
-
}, false);
|
|
24
|
-
return didNotMatch ? void 0 : expectedValue;
|
|
25
|
-
}
|
|
26
|
-
contractInfoRequiredFields(callResults) {
|
|
27
|
-
return {
|
|
28
|
-
address: assertEx(_CryptoContractDiviner.matchingExistingField(callResults, "address"), () => "Mismatched address"),
|
|
29
|
-
chainId: assertEx(_CryptoContractDiviner.matchingExistingField(callResults, "chainId"), () => "Mismatched chainId"),
|
|
30
|
-
schema: ContractInfoSchema
|
|
31
|
-
};
|
|
32
|
-
}
|
|
33
|
-
async divineHandler(inPayloads = []) {
|
|
34
|
-
const callResults = inPayloads.filter(isPayloadOfSchemaType(CryptoContractFunctionCallResultSchema));
|
|
35
|
-
const addresses = Object.keys(
|
|
36
|
-
// eslint-disable-next-line unicorn/no-array-reduce
|
|
37
|
-
callResults.reduce((prev, result2) => {
|
|
38
|
-
if (result2.address) {
|
|
39
|
-
prev[result2.address] = true;
|
|
40
|
-
}
|
|
41
|
-
return prev;
|
|
42
|
-
}, {})
|
|
43
|
-
);
|
|
44
|
-
const result = await Promise.all(
|
|
45
|
-
addresses.map(async (address) => {
|
|
46
|
-
const foundCallResults = callResults.filter((callResult) => callResult.address === address);
|
|
47
|
-
const info = {
|
|
48
|
-
results: await this.reduceResults(foundCallResults),
|
|
49
|
-
...this.contractInfoRequiredFields(foundCallResults)
|
|
50
|
-
};
|
|
51
|
-
return info;
|
|
52
|
-
})
|
|
53
|
-
);
|
|
54
|
-
return result;
|
|
55
|
-
}
|
|
56
|
-
reduceResults(callResults) {
|
|
57
|
-
return callResults.reduce((prev, callResult) => {
|
|
58
|
-
prev[callResult.functionName] = asCryptoContractFunctionCallSuccess(callResult)?.result;
|
|
59
|
-
return prev;
|
|
60
|
-
}, {});
|
|
61
|
-
}
|
|
62
|
-
};
|
|
63
|
-
|
|
64
|
-
// src/Plugin.ts
|
|
65
|
-
import { NftSchema } from "@xyo-network/crypto-nft-payload-plugin";
|
|
66
|
-
import { createPayloadSetWitnessPlugin, PayloadSetSchema } from "@xyo-network/sdk-js";
|
|
67
|
-
|
|
68
|
-
// src/Witness.ts
|
|
69
|
-
import { assertEx as assertEx2 } from "@xylabs/sdk-js";
|
|
70
|
-
import {
|
|
71
|
-
CryptoContractFunctionCallResultSchema as CryptoContractFunctionCallResultSchema2,
|
|
72
|
-
CryptoContractFunctionCallSchema,
|
|
73
|
-
CryptoContractFunctionReadWitnessConfigSchema
|
|
74
|
-
} from "@xyo-network/crypto-contract-function-read-payload-plugin";
|
|
75
|
-
import { AbstractWitness, isPayloadOfSchemaType as isPayloadOfSchemaType2 } from "@xyo-network/sdk-js";
|
|
76
|
-
import { Contract } from "ethers";
|
|
77
|
-
var CryptoContractFunctionReadWitness = class extends AbstractWitness {
|
|
78
|
-
static configSchemas = [...super.configSchemas, CryptoContractFunctionReadWitnessConfigSchema];
|
|
79
|
-
static defaultConfigSchema = CryptoContractFunctionReadWitnessConfigSchema;
|
|
80
|
-
get abi() {
|
|
81
|
-
return assertEx2(this.config.abi, () => "Missing abi");
|
|
82
|
-
}
|
|
83
|
-
async observeHandler(inPayloads = []) {
|
|
84
|
-
await this.startedAsync("throw");
|
|
85
|
-
try {
|
|
86
|
-
const observations = await Promise.all(
|
|
87
|
-
inPayloads.filter(isPayloadOfSchemaType2(CryptoContractFunctionCallSchema)).map(async ({
|
|
88
|
-
functionName,
|
|
89
|
-
args,
|
|
90
|
-
address
|
|
91
|
-
}) => {
|
|
92
|
-
const { providers } = this.params;
|
|
93
|
-
const provider = providers[Date.now() % providers.length];
|
|
94
|
-
const validatedAddress = assertEx2(address ?? this.config.address, () => "Missing address");
|
|
95
|
-
const validatedFunctionName = assertEx2(functionName ?? this.config.functionName, () => "Missing address");
|
|
96
|
-
const mergedArgs = [...args ?? this.config.args ?? []];
|
|
97
|
-
const contract = new Contract(validatedAddress, this.abi, provider);
|
|
98
|
-
try {
|
|
99
|
-
const result = await contract[validatedFunctionName](...mergedArgs);
|
|
100
|
-
const transformedResult = typeof result === "bigint" ? result.toString(16) : result;
|
|
101
|
-
const observation = {
|
|
102
|
-
address: validatedAddress,
|
|
103
|
-
args: mergedArgs,
|
|
104
|
-
chainId: Number((await provider.getNetwork()).chainId),
|
|
105
|
-
functionName: validatedFunctionName,
|
|
106
|
-
result: transformedResult,
|
|
107
|
-
schema: CryptoContractFunctionCallResultSchema2
|
|
108
|
-
};
|
|
109
|
-
return observation;
|
|
110
|
-
} catch (ex) {
|
|
111
|
-
const error = ex;
|
|
112
|
-
console.log(`Error [${this.config.name}]: ${error.code}`);
|
|
113
|
-
const observation = {
|
|
114
|
-
address: validatedAddress,
|
|
115
|
-
args: mergedArgs,
|
|
116
|
-
chainId: Number((await provider.getNetwork()).chainId),
|
|
117
|
-
error: error.code,
|
|
118
|
-
functionName: validatedFunctionName,
|
|
119
|
-
schema: CryptoContractFunctionCallResultSchema2
|
|
120
|
-
};
|
|
121
|
-
return observation;
|
|
122
|
-
}
|
|
123
|
-
})
|
|
124
|
-
);
|
|
125
|
-
return observations;
|
|
126
|
-
} catch (ex) {
|
|
127
|
-
const error = ex;
|
|
128
|
-
console.log(`Error [${this.config.name}]: ${error.message}`);
|
|
129
|
-
throw error;
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
};
|
|
133
|
-
|
|
134
|
-
// src/Plugin.ts
|
|
135
|
-
var CryptoContractFunctionReadWitnessPlugin = () => createPayloadSetWitnessPlugin(
|
|
136
|
-
{ required: { [NftSchema]: 1 }, schema: PayloadSetSchema },
|
|
137
|
-
{
|
|
138
|
-
witness: async (params) => {
|
|
139
|
-
const result = await CryptoContractFunctionReadWitness.create(params);
|
|
140
|
-
return result;
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
);
|
|
144
|
-
export {
|
|
145
|
-
CryptoContractDiviner,
|
|
146
|
-
CryptoContractFunctionReadWitness,
|
|
147
|
-
CryptoContractFunctionReadWitnessPlugin,
|
|
148
|
-
CryptoContractFunctionReadWitnessPlugin as default
|
|
149
|
-
};
|
|
150
|
-
//# sourceMappingURL=index.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../src/Diviner/Diviner.ts", "../../src/Plugin.ts", "../../src/Witness.ts"],
|
|
4
|
-
"sourcesContent": ["/* eslint-disable @typescript-eslint/no-deprecated -- This package is the deprecated CryptoContractDiviner implementation; intra-package references are intentional. */\nimport type { Promisable } from '@xylabs/sdk-js'\nimport { assertEx } from '@xylabs/sdk-js'\nimport type {\n ContractInfo,\n CryptoContractDivinerParams,\n CryptoContractFunctionCallResult,\n} from '@xyo-network/crypto-contract-function-read-payload-plugin'\nimport {\n asCryptoContractFunctionCallSuccess,\n ContractInfoSchema,\n CryptoContractDivinerConfigSchema,\n CryptoContractDivinerLabels,\n CryptoContractFunctionCallResultSchema,\n} from '@xyo-network/crypto-contract-function-read-payload-plugin'\nimport type { Payload, Schema } from '@xyo-network/sdk-js'\nimport { AbstractDiviner, isPayloadOfSchemaType } from '@xyo-network/sdk-js'\n\n/** @deprecated use EvmCallDiviner instead */\nexport type FindCallResult<TResult = string, TPayload = Payload> = [TResult, TPayload] | [undefined, TPayload] | [undefined, undefined]\n\n/** @deprecated use EvmCallDiviner instead */\nexport class CryptoContractDiviner<TParams extends CryptoContractDivinerParams = CryptoContractDivinerParams> extends AbstractDiviner<TParams> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, CryptoContractDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = CryptoContractDivinerConfigSchema\n static override readonly labels: CryptoContractDivinerLabels = { ...super.labels, ...CryptoContractDivinerLabels }\n\n protected static findCallResult<TResult = string>(\n address: string,\n functionName: string,\n payloads: CryptoContractFunctionCallResult[],\n ): TResult | undefined {\n const foundPayload = payloads.find(payload => payload.functionName === functionName && payload.address === address)\n return asCryptoContractFunctionCallSuccess(foundPayload)?.result as TResult | undefined\n }\n\n protected static matchingExistingField<R = string, T extends Payload = Payload>(objs: T[], field: keyof T): R | undefined {\n const expectedValue = objs.at(0)?.[field] as R\n // eslint-disable-next-line unicorn/no-array-reduce\n const didNotMatch = objs.reduce((prev, obj) => {\n return prev || obj[field] !== expectedValue\n }, false)\n return didNotMatch ? undefined : expectedValue\n }\n\n protected contractInfoRequiredFields(callResults: CryptoContractFunctionCallResult[]): ContractInfo {\n return {\n address: assertEx(CryptoContractDiviner.matchingExistingField(callResults, 'address'), () => 'Mismatched address'),\n chainId: assertEx(CryptoContractDiviner.matchingExistingField(callResults, 'chainId'), () => 'Mismatched chainId'),\n schema: ContractInfoSchema,\n }\n }\n\n protected override async divineHandler(inPayloads: CryptoContractFunctionCallResult[] = []): Promise<ContractInfo[]> {\n const callResults = inPayloads.filter(isPayloadOfSchemaType<CryptoContractFunctionCallResult>(CryptoContractFunctionCallResultSchema))\n const addresses = Object.keys(\n // eslint-disable-next-line unicorn/no-array-reduce\n callResults.reduce<Record<string, boolean>>((prev, result) => {\n if (result.address) {\n prev[result.address] = true\n }\n return prev\n }, {}),\n )\n const result = await Promise.all(\n addresses.map(async (address) => {\n const foundCallResults = callResults.filter(callResult => callResult.address === address)\n const info: ContractInfo = {\n results: await this.reduceResults(foundCallResults),\n ...this.contractInfoRequiredFields(foundCallResults),\n }\n return info\n }),\n )\n\n return result\n }\n\n protected reduceResults(callResults: CryptoContractFunctionCallResult[]): Promisable<ContractInfo['results']> {\n // eslint-disable-next-line unicorn/no-array-reduce\n return callResults.reduce<Record<string, unknown>>((prev, callResult) => {\n prev[callResult.functionName] = asCryptoContractFunctionCallSuccess(callResult)?.result\n return prev\n }, {})\n }\n}\n", "/* eslint-disable @typescript-eslint/no-deprecated -- This package is the deprecated CryptoContractFunctionRead* implementation; intra-package references to the deprecated witness are intentional. */\nimport { NftSchema } from '@xyo-network/crypto-nft-payload-plugin'\nimport { createPayloadSetWitnessPlugin, PayloadSetSchema } from '@xyo-network/sdk-js'\n\nimport { CryptoContractFunctionReadWitness } from './Witness.ts'\n\n/** @deprecated use EvmCallWitness instead */\nexport const CryptoContractFunctionReadWitnessPlugin = () =>\n\n createPayloadSetWitnessPlugin<CryptoContractFunctionReadWitness>(\n { required: { [NftSchema]: 1 }, schema: PayloadSetSchema },\n {\n witness: async (params) => {\n const result = await CryptoContractFunctionReadWitness.create(params)\n return result\n },\n },\n )\n", "/* eslint-disable @typescript-eslint/no-deprecated -- This package is the deprecated CryptoContractFunctionRead* implementation; intra-package references are intentional. */\nimport type { JsonObject } from '@xylabs/sdk-js'\nimport { assertEx } from '@xylabs/sdk-js'\nimport type {\n CryptoContractFunctionCall,\n CryptoContractFunctionCallFailure,\n CryptoContractFunctionCallResult,\n CryptoContractFunctionCallSuccess,\n CryptoContractFunctionReadWitnessConfig,\n} from '@xyo-network/crypto-contract-function-read-payload-plugin'\nimport {\n CryptoContractFunctionCallResultSchema,\n CryptoContractFunctionCallSchema,\n CryptoContractFunctionReadWitnessConfigSchema,\n} from '@xyo-network/crypto-contract-function-read-payload-plugin'\nimport type {\n AnyConfigSchema, Schema, WitnessParams,\n} from '@xyo-network/sdk-js'\nimport { AbstractWitness, isPayloadOfSchemaType } from '@xyo-network/sdk-js'\nimport type { InterfaceAbi, Provider } from 'ethers'\nimport { Contract } from 'ethers'\n\n/** @deprecated use EvmCallWitness instead */\nexport interface CryptoContractFunctionReadWitnessParams extends WitnessParams<\n AnyConfigSchema<CryptoContractFunctionReadWitnessConfig>>\n{\n providers: Provider[]\n}\n\n/** @deprecated use EvmCallWitness instead */\nexport class CryptoContractFunctionReadWitness<\n TParams extends CryptoContractFunctionReadWitnessParams = CryptoContractFunctionReadWitnessParams,\n> extends AbstractWitness<TParams, CryptoContractFunctionCall, CryptoContractFunctionCallResult> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, CryptoContractFunctionReadWitnessConfigSchema]\n static override readonly defaultConfigSchema: Schema = CryptoContractFunctionReadWitnessConfigSchema\n\n get abi() {\n return assertEx(this.config.abi, () => 'Missing abi') as InterfaceAbi\n }\n\n protected override async observeHandler(inPayloads: CryptoContractFunctionCall[] = []): Promise<CryptoContractFunctionCallResult[]> {\n await this.startedAsync('throw')\n try {\n const observations = await Promise.all(\n inPayloads.filter(isPayloadOfSchemaType<CryptoContractFunctionCall>(CryptoContractFunctionCallSchema)).map(async ({\n functionName, args, address,\n }) => {\n const { providers } = this.params\n const provider = providers[Date.now() % providers.length] // pick a random provider\n const validatedAddress = assertEx(address ?? this.config.address, () => 'Missing address')\n const validatedFunctionName = assertEx(functionName ?? this.config.functionName, () => 'Missing address')\n const mergedArgs = [...(args ?? this.config.args ?? [])] as JsonObject[]\n\n const contract = new Contract(validatedAddress, this.abi, provider)\n try {\n const result = await contract[validatedFunctionName](...mergedArgs)\n const transformedResult = typeof result === 'bigint' ? result.toString(16) : result\n const observation: CryptoContractFunctionCallSuccess = {\n address: validatedAddress,\n args: mergedArgs,\n chainId: Number((await provider.getNetwork()).chainId),\n functionName: validatedFunctionName,\n result: transformedResult,\n schema: CryptoContractFunctionCallResultSchema,\n }\n return observation\n } catch (ex) {\n const error = ex as Error & { code: string }\n console.log(`Error [${this.config.name}]: ${error.code}`)\n const observation: CryptoContractFunctionCallFailure = {\n address: validatedAddress,\n args: mergedArgs,\n chainId: Number((await provider.getNetwork()).chainId),\n error: error.code,\n functionName: validatedFunctionName,\n schema: CryptoContractFunctionCallResultSchema,\n }\n return observation\n }\n }),\n )\n return observations\n } catch (ex) {\n const error = ex as Error\n console.log(`Error [${this.config.name}]: ${error.message}`)\n throw error\n }\n }\n}\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["result", "assertEx", "CryptoContractFunctionCallResultSchema", "isPayloadOfSchemaType"]
|
|
7
|
-
}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import type { Promisable } from '@xylabs/sdk-js';
|
|
2
|
-
import type { ContractInfo, CryptoContractDivinerParams, CryptoContractFunctionCallResult } from '@xyo-network/crypto-contract-function-read-payload-plugin';
|
|
3
|
-
import { CryptoContractDivinerLabels } from '@xyo-network/crypto-contract-function-read-payload-plugin';
|
|
4
|
-
import type { Payload, Schema } from '@xyo-network/sdk-js';
|
|
5
|
-
import { AbstractDiviner } from '@xyo-network/sdk-js';
|
|
6
|
-
/** @deprecated use EvmCallDiviner instead */
|
|
7
|
-
export type FindCallResult<TResult = string, TPayload = Payload> = [TResult, TPayload] | [undefined, TPayload] | [undefined, undefined];
|
|
8
|
-
/** @deprecated use EvmCallDiviner instead */
|
|
9
|
-
export declare class CryptoContractDiviner<TParams extends CryptoContractDivinerParams = CryptoContractDivinerParams> extends AbstractDiviner<TParams> {
|
|
10
|
-
static readonly configSchemas: Schema[];
|
|
11
|
-
static readonly defaultConfigSchema: Schema;
|
|
12
|
-
static readonly labels: CryptoContractDivinerLabels;
|
|
13
|
-
protected static findCallResult<TResult = string>(address: string, functionName: string, payloads: CryptoContractFunctionCallResult[]): TResult | undefined;
|
|
14
|
-
protected static matchingExistingField<R = string, T extends Payload = Payload>(objs: T[], field: keyof T): R | undefined;
|
|
15
|
-
protected contractInfoRequiredFields(callResults: CryptoContractFunctionCallResult[]): ContractInfo;
|
|
16
|
-
protected divineHandler(inPayloads?: CryptoContractFunctionCallResult[]): Promise<ContractInfo[]>;
|
|
17
|
-
protected reduceResults(callResults: CryptoContractFunctionCallResult[]): Promisable<ContractInfo['results']>;
|
|
18
|
-
}
|
|
19
|
-
//# sourceMappingURL=Diviner.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Diviner.d.ts","sourceRoot":"","sources":["../../../src/Diviner/Diviner.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAA;AAEhD,OAAO,KAAK,EACV,YAAY,EACZ,2BAA2B,EAC3B,gCAAgC,EACjC,MAAM,2DAA2D,CAAA;AAClE,OAAO,EAIL,2BAA2B,EAE5B,MAAM,2DAA2D,CAAA;AAClE,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAA;AAC1D,OAAO,EAAE,eAAe,EAAyB,MAAM,qBAAqB,CAAA;AAE5E,6CAA6C;AAC7C,MAAM,MAAM,cAAc,CAAC,OAAO,GAAG,MAAM,EAAE,QAAQ,GAAG,OAAO,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,GAAG,CAAC,SAAS,EAAE,QAAQ,CAAC,GAAG,CAAC,SAAS,EAAE,SAAS,CAAC,CAAA;AAEvI,6CAA6C;AAC7C,qBAAa,qBAAqB,CAAC,OAAO,SAAS,2BAA2B,GAAG,2BAA2B,CAAE,SAAQ,eAAe,CAAC,OAAO,CAAC;IAC5I,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAA8D;IAC9G,gBAAyB,mBAAmB,EAAE,MAAM,CAAoC;IACxF,gBAAyB,MAAM,EAAE,2BAA2B,CAAsD;IAElH,SAAS,CAAC,MAAM,CAAC,cAAc,CAAC,OAAO,GAAG,MAAM,EAC9C,OAAO,EAAE,MAAM,EACf,YAAY,EAAE,MAAM,EACpB,QAAQ,EAAE,gCAAgC,EAAE,GAC3C,OAAO,GAAG,SAAS;IAKtB,SAAS,CAAC,MAAM,CAAC,qBAAqB,CAAC,CAAC,GAAG,MAAM,EAAE,CAAC,SAAS,OAAO,GAAG,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,GAAG,CAAC,GAAG,SAAS;IASzH,SAAS,CAAC,0BAA0B,CAAC,WAAW,EAAE,gCAAgC,EAAE,GAAG,YAAY;cAQ1E,aAAa,CAAC,UAAU,GAAE,gCAAgC,EAAO,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;IAyBpH,SAAS,CAAC,aAAa,CAAC,WAAW,EAAE,gCAAgC,EAAE,GAAG,UAAU,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;CAO9G"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/Diviner/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA"}
|
package/dist/node/Plugin.d.ts
DELETED
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import { CryptoContractFunctionReadWitness } from './Witness.ts';
|
|
2
|
-
/** @deprecated use EvmCallWitness instead */
|
|
3
|
-
export declare const CryptoContractFunctionReadWitnessPlugin: () => import("@xyo-network/sdk-js").PayloadSetWitnessPlugin<CryptoContractFunctionReadWitness<import("./Witness.ts").CryptoContractFunctionReadWitnessParams>>;
|
|
4
|
-
//# sourceMappingURL=Plugin.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Plugin.d.ts","sourceRoot":"","sources":["../../src/Plugin.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,iCAAiC,EAAE,MAAM,cAAc,CAAA;AAEhE,6CAA6C;AAC7C,eAAO,MAAM,uCAAuC,gKAUjD,CAAA"}
|
package/dist/node/Witness.d.ts
DELETED
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import type { CryptoContractFunctionCall, CryptoContractFunctionCallResult, CryptoContractFunctionReadWitnessConfig } from '@xyo-network/crypto-contract-function-read-payload-plugin';
|
|
2
|
-
import type { AnyConfigSchema, Schema, WitnessParams } from '@xyo-network/sdk-js';
|
|
3
|
-
import { AbstractWitness } from '@xyo-network/sdk-js';
|
|
4
|
-
import type { InterfaceAbi, Provider } from 'ethers';
|
|
5
|
-
/** @deprecated use EvmCallWitness instead */
|
|
6
|
-
export interface CryptoContractFunctionReadWitnessParams extends WitnessParams<AnyConfigSchema<CryptoContractFunctionReadWitnessConfig>> {
|
|
7
|
-
providers: Provider[];
|
|
8
|
-
}
|
|
9
|
-
/** @deprecated use EvmCallWitness instead */
|
|
10
|
-
export declare class CryptoContractFunctionReadWitness<TParams extends CryptoContractFunctionReadWitnessParams = CryptoContractFunctionReadWitnessParams> extends AbstractWitness<TParams, CryptoContractFunctionCall, CryptoContractFunctionCallResult> {
|
|
11
|
-
static readonly configSchemas: Schema[];
|
|
12
|
-
static readonly defaultConfigSchema: Schema;
|
|
13
|
-
get abi(): InterfaceAbi;
|
|
14
|
-
protected observeHandler(inPayloads?: CryptoContractFunctionCall[]): Promise<CryptoContractFunctionCallResult[]>;
|
|
15
|
-
}
|
|
16
|
-
//# sourceMappingURL=Witness.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,0BAA0B,EAE1B,gCAAgC,EAEhC,uCAAuC,EACxC,MAAM,2DAA2D,CAAA;AAMlE,OAAO,KAAK,EACV,eAAe,EAAE,MAAM,EAAE,aAAa,EACvC,MAAM,qBAAqB,CAAA;AAC5B,OAAO,EAAE,eAAe,EAAyB,MAAM,qBAAqB,CAAA;AAC5E,OAAO,KAAK,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAA;AAGpD,6CAA6C;AAC7C,MAAM,WAAW,uCAAwC,SAAQ,aAAa,CAC5E,eAAe,CAAC,uCAAuC,CAAC,CAAC;IAEzD,SAAS,EAAE,QAAQ,EAAE,CAAA;CACtB;AAED,6CAA6C;AAC7C,qBAAa,iCAAiC,CAC5C,OAAO,SAAS,uCAAuC,GAAG,uCAAuC,CACjG,SAAQ,eAAe,CAAC,OAAO,EAAE,0BAA0B,EAAE,gCAAgC,CAAC;IAC9F,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAA0E;IAC1H,gBAAyB,mBAAmB,EAAE,MAAM,CAAgD;IAEpG,IAAI,GAAG,IACoD,YAAY,CACtE;cAEwB,cAAc,CAAC,UAAU,GAAE,0BAA0B,EAAO,GAAG,OAAO,CAAC,gCAAgC,EAAE,CAAC;CAgDpI"}
|
package/dist/node/index.d.ts
DELETED
package/dist/node/index.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AACA,cAAc,oBAAoB,CAAA;AAClC,OAAO,EAAE,uCAAuC,EAAE,uCAAuC,IAAI,OAAO,EAAE,MAAM,aAAa,CAAA;AACzH,cAAc,cAAc,CAAA"}
|
package/dist/node/index.mjs
DELETED
|
@@ -1,150 +0,0 @@
|
|
|
1
|
-
// src/Diviner/Diviner.ts
|
|
2
|
-
import { assertEx } from "@xylabs/sdk-js";
|
|
3
|
-
import {
|
|
4
|
-
asCryptoContractFunctionCallSuccess,
|
|
5
|
-
ContractInfoSchema,
|
|
6
|
-
CryptoContractDivinerConfigSchema,
|
|
7
|
-
CryptoContractDivinerLabels,
|
|
8
|
-
CryptoContractFunctionCallResultSchema
|
|
9
|
-
} from "@xyo-network/crypto-contract-function-read-payload-plugin";
|
|
10
|
-
import { AbstractDiviner, isPayloadOfSchemaType } from "@xyo-network/sdk-js";
|
|
11
|
-
var CryptoContractDiviner = class _CryptoContractDiviner extends AbstractDiviner {
|
|
12
|
-
static configSchemas = [...super.configSchemas, CryptoContractDivinerConfigSchema];
|
|
13
|
-
static defaultConfigSchema = CryptoContractDivinerConfigSchema;
|
|
14
|
-
static labels = { ...super.labels, ...CryptoContractDivinerLabels };
|
|
15
|
-
static findCallResult(address, functionName, payloads) {
|
|
16
|
-
const foundPayload = payloads.find((payload) => payload.functionName === functionName && payload.address === address);
|
|
17
|
-
return asCryptoContractFunctionCallSuccess(foundPayload)?.result;
|
|
18
|
-
}
|
|
19
|
-
static matchingExistingField(objs, field) {
|
|
20
|
-
const expectedValue = objs.at(0)?.[field];
|
|
21
|
-
const didNotMatch = objs.reduce((prev, obj) => {
|
|
22
|
-
return prev || obj[field] !== expectedValue;
|
|
23
|
-
}, false);
|
|
24
|
-
return didNotMatch ? void 0 : expectedValue;
|
|
25
|
-
}
|
|
26
|
-
contractInfoRequiredFields(callResults) {
|
|
27
|
-
return {
|
|
28
|
-
address: assertEx(_CryptoContractDiviner.matchingExistingField(callResults, "address"), () => "Mismatched address"),
|
|
29
|
-
chainId: assertEx(_CryptoContractDiviner.matchingExistingField(callResults, "chainId"), () => "Mismatched chainId"),
|
|
30
|
-
schema: ContractInfoSchema
|
|
31
|
-
};
|
|
32
|
-
}
|
|
33
|
-
async divineHandler(inPayloads = []) {
|
|
34
|
-
const callResults = inPayloads.filter(isPayloadOfSchemaType(CryptoContractFunctionCallResultSchema));
|
|
35
|
-
const addresses = Object.keys(
|
|
36
|
-
// eslint-disable-next-line unicorn/no-array-reduce
|
|
37
|
-
callResults.reduce((prev, result2) => {
|
|
38
|
-
if (result2.address) {
|
|
39
|
-
prev[result2.address] = true;
|
|
40
|
-
}
|
|
41
|
-
return prev;
|
|
42
|
-
}, {})
|
|
43
|
-
);
|
|
44
|
-
const result = await Promise.all(
|
|
45
|
-
addresses.map(async (address) => {
|
|
46
|
-
const foundCallResults = callResults.filter((callResult) => callResult.address === address);
|
|
47
|
-
const info = {
|
|
48
|
-
results: await this.reduceResults(foundCallResults),
|
|
49
|
-
...this.contractInfoRequiredFields(foundCallResults)
|
|
50
|
-
};
|
|
51
|
-
return info;
|
|
52
|
-
})
|
|
53
|
-
);
|
|
54
|
-
return result;
|
|
55
|
-
}
|
|
56
|
-
reduceResults(callResults) {
|
|
57
|
-
return callResults.reduce((prev, callResult) => {
|
|
58
|
-
prev[callResult.functionName] = asCryptoContractFunctionCallSuccess(callResult)?.result;
|
|
59
|
-
return prev;
|
|
60
|
-
}, {});
|
|
61
|
-
}
|
|
62
|
-
};
|
|
63
|
-
|
|
64
|
-
// src/Plugin.ts
|
|
65
|
-
import { NftSchema } from "@xyo-network/crypto-nft-payload-plugin";
|
|
66
|
-
import { createPayloadSetWitnessPlugin, PayloadSetSchema } from "@xyo-network/sdk-js";
|
|
67
|
-
|
|
68
|
-
// src/Witness.ts
|
|
69
|
-
import { assertEx as assertEx2 } from "@xylabs/sdk-js";
|
|
70
|
-
import {
|
|
71
|
-
CryptoContractFunctionCallResultSchema as CryptoContractFunctionCallResultSchema2,
|
|
72
|
-
CryptoContractFunctionCallSchema,
|
|
73
|
-
CryptoContractFunctionReadWitnessConfigSchema
|
|
74
|
-
} from "@xyo-network/crypto-contract-function-read-payload-plugin";
|
|
75
|
-
import { AbstractWitness, isPayloadOfSchemaType as isPayloadOfSchemaType2 } from "@xyo-network/sdk-js";
|
|
76
|
-
import { Contract } from "ethers";
|
|
77
|
-
var CryptoContractFunctionReadWitness = class extends AbstractWitness {
|
|
78
|
-
static configSchemas = [...super.configSchemas, CryptoContractFunctionReadWitnessConfigSchema];
|
|
79
|
-
static defaultConfigSchema = CryptoContractFunctionReadWitnessConfigSchema;
|
|
80
|
-
get abi() {
|
|
81
|
-
return assertEx2(this.config.abi, () => "Missing abi");
|
|
82
|
-
}
|
|
83
|
-
async observeHandler(inPayloads = []) {
|
|
84
|
-
await this.startedAsync("throw");
|
|
85
|
-
try {
|
|
86
|
-
const observations = await Promise.all(
|
|
87
|
-
inPayloads.filter(isPayloadOfSchemaType2(CryptoContractFunctionCallSchema)).map(async ({
|
|
88
|
-
functionName,
|
|
89
|
-
args,
|
|
90
|
-
address
|
|
91
|
-
}) => {
|
|
92
|
-
const { providers } = this.params;
|
|
93
|
-
const provider = providers[Date.now() % providers.length];
|
|
94
|
-
const validatedAddress = assertEx2(address ?? this.config.address, () => "Missing address");
|
|
95
|
-
const validatedFunctionName = assertEx2(functionName ?? this.config.functionName, () => "Missing address");
|
|
96
|
-
const mergedArgs = [...args ?? this.config.args ?? []];
|
|
97
|
-
const contract = new Contract(validatedAddress, this.abi, provider);
|
|
98
|
-
try {
|
|
99
|
-
const result = await contract[validatedFunctionName](...mergedArgs);
|
|
100
|
-
const transformedResult = typeof result === "bigint" ? result.toString(16) : result;
|
|
101
|
-
const observation = {
|
|
102
|
-
address: validatedAddress,
|
|
103
|
-
args: mergedArgs,
|
|
104
|
-
chainId: Number((await provider.getNetwork()).chainId),
|
|
105
|
-
functionName: validatedFunctionName,
|
|
106
|
-
result: transformedResult,
|
|
107
|
-
schema: CryptoContractFunctionCallResultSchema2
|
|
108
|
-
};
|
|
109
|
-
return observation;
|
|
110
|
-
} catch (ex) {
|
|
111
|
-
const error = ex;
|
|
112
|
-
console.log(`Error [${this.config.name}]: ${error.code}`);
|
|
113
|
-
const observation = {
|
|
114
|
-
address: validatedAddress,
|
|
115
|
-
args: mergedArgs,
|
|
116
|
-
chainId: Number((await provider.getNetwork()).chainId),
|
|
117
|
-
error: error.code,
|
|
118
|
-
functionName: validatedFunctionName,
|
|
119
|
-
schema: CryptoContractFunctionCallResultSchema2
|
|
120
|
-
};
|
|
121
|
-
return observation;
|
|
122
|
-
}
|
|
123
|
-
})
|
|
124
|
-
);
|
|
125
|
-
return observations;
|
|
126
|
-
} catch (ex) {
|
|
127
|
-
const error = ex;
|
|
128
|
-
console.log(`Error [${this.config.name}]: ${error.message}`);
|
|
129
|
-
throw error;
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
};
|
|
133
|
-
|
|
134
|
-
// src/Plugin.ts
|
|
135
|
-
var CryptoContractFunctionReadWitnessPlugin = () => createPayloadSetWitnessPlugin(
|
|
136
|
-
{ required: { [NftSchema]: 1 }, schema: PayloadSetSchema },
|
|
137
|
-
{
|
|
138
|
-
witness: async (params) => {
|
|
139
|
-
const result = await CryptoContractFunctionReadWitness.create(params);
|
|
140
|
-
return result;
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
);
|
|
144
|
-
export {
|
|
145
|
-
CryptoContractDiviner,
|
|
146
|
-
CryptoContractFunctionReadWitness,
|
|
147
|
-
CryptoContractFunctionReadWitnessPlugin,
|
|
148
|
-
CryptoContractFunctionReadWitnessPlugin as default
|
|
149
|
-
};
|
|
150
|
-
//# sourceMappingURL=index.mjs.map
|
package/dist/node/index.mjs.map
DELETED
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../src/Diviner/Diviner.ts", "../../src/Plugin.ts", "../../src/Witness.ts"],
|
|
4
|
-
"sourcesContent": ["/* eslint-disable @typescript-eslint/no-deprecated -- This package is the deprecated CryptoContractDiviner implementation; intra-package references are intentional. */\nimport type { Promisable } from '@xylabs/sdk-js'\nimport { assertEx } from '@xylabs/sdk-js'\nimport type {\n ContractInfo,\n CryptoContractDivinerParams,\n CryptoContractFunctionCallResult,\n} from '@xyo-network/crypto-contract-function-read-payload-plugin'\nimport {\n asCryptoContractFunctionCallSuccess,\n ContractInfoSchema,\n CryptoContractDivinerConfigSchema,\n CryptoContractDivinerLabels,\n CryptoContractFunctionCallResultSchema,\n} from '@xyo-network/crypto-contract-function-read-payload-plugin'\nimport type { Payload, Schema } from '@xyo-network/sdk-js'\nimport { AbstractDiviner, isPayloadOfSchemaType } from '@xyo-network/sdk-js'\n\n/** @deprecated use EvmCallDiviner instead */\nexport type FindCallResult<TResult = string, TPayload = Payload> = [TResult, TPayload] | [undefined, TPayload] | [undefined, undefined]\n\n/** @deprecated use EvmCallDiviner instead */\nexport class CryptoContractDiviner<TParams extends CryptoContractDivinerParams = CryptoContractDivinerParams> extends AbstractDiviner<TParams> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, CryptoContractDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = CryptoContractDivinerConfigSchema\n static override readonly labels: CryptoContractDivinerLabels = { ...super.labels, ...CryptoContractDivinerLabels }\n\n protected static findCallResult<TResult = string>(\n address: string,\n functionName: string,\n payloads: CryptoContractFunctionCallResult[],\n ): TResult | undefined {\n const foundPayload = payloads.find(payload => payload.functionName === functionName && payload.address === address)\n return asCryptoContractFunctionCallSuccess(foundPayload)?.result as TResult | undefined\n }\n\n protected static matchingExistingField<R = string, T extends Payload = Payload>(objs: T[], field: keyof T): R | undefined {\n const expectedValue = objs.at(0)?.[field] as R\n // eslint-disable-next-line unicorn/no-array-reduce\n const didNotMatch = objs.reduce((prev, obj) => {\n return prev || obj[field] !== expectedValue\n }, false)\n return didNotMatch ? undefined : expectedValue\n }\n\n protected contractInfoRequiredFields(callResults: CryptoContractFunctionCallResult[]): ContractInfo {\n return {\n address: assertEx(CryptoContractDiviner.matchingExistingField(callResults, 'address'), () => 'Mismatched address'),\n chainId: assertEx(CryptoContractDiviner.matchingExistingField(callResults, 'chainId'), () => 'Mismatched chainId'),\n schema: ContractInfoSchema,\n }\n }\n\n protected override async divineHandler(inPayloads: CryptoContractFunctionCallResult[] = []): Promise<ContractInfo[]> {\n const callResults = inPayloads.filter(isPayloadOfSchemaType<CryptoContractFunctionCallResult>(CryptoContractFunctionCallResultSchema))\n const addresses = Object.keys(\n // eslint-disable-next-line unicorn/no-array-reduce\n callResults.reduce<Record<string, boolean>>((prev, result) => {\n if (result.address) {\n prev[result.address] = true\n }\n return prev\n }, {}),\n )\n const result = await Promise.all(\n addresses.map(async (address) => {\n const foundCallResults = callResults.filter(callResult => callResult.address === address)\n const info: ContractInfo = {\n results: await this.reduceResults(foundCallResults),\n ...this.contractInfoRequiredFields(foundCallResults),\n }\n return info\n }),\n )\n\n return result\n }\n\n protected reduceResults(callResults: CryptoContractFunctionCallResult[]): Promisable<ContractInfo['results']> {\n // eslint-disable-next-line unicorn/no-array-reduce\n return callResults.reduce<Record<string, unknown>>((prev, callResult) => {\n prev[callResult.functionName] = asCryptoContractFunctionCallSuccess(callResult)?.result\n return prev\n }, {})\n }\n}\n", "/* eslint-disable @typescript-eslint/no-deprecated -- This package is the deprecated CryptoContractFunctionRead* implementation; intra-package references to the deprecated witness are intentional. */\nimport { NftSchema } from '@xyo-network/crypto-nft-payload-plugin'\nimport { createPayloadSetWitnessPlugin, PayloadSetSchema } from '@xyo-network/sdk-js'\n\nimport { CryptoContractFunctionReadWitness } from './Witness.ts'\n\n/** @deprecated use EvmCallWitness instead */\nexport const CryptoContractFunctionReadWitnessPlugin = () =>\n\n createPayloadSetWitnessPlugin<CryptoContractFunctionReadWitness>(\n { required: { [NftSchema]: 1 }, schema: PayloadSetSchema },\n {\n witness: async (params) => {\n const result = await CryptoContractFunctionReadWitness.create(params)\n return result\n },\n },\n )\n", "/* eslint-disable @typescript-eslint/no-deprecated -- This package is the deprecated CryptoContractFunctionRead* implementation; intra-package references are intentional. */\nimport type { JsonObject } from '@xylabs/sdk-js'\nimport { assertEx } from '@xylabs/sdk-js'\nimport type {\n CryptoContractFunctionCall,\n CryptoContractFunctionCallFailure,\n CryptoContractFunctionCallResult,\n CryptoContractFunctionCallSuccess,\n CryptoContractFunctionReadWitnessConfig,\n} from '@xyo-network/crypto-contract-function-read-payload-plugin'\nimport {\n CryptoContractFunctionCallResultSchema,\n CryptoContractFunctionCallSchema,\n CryptoContractFunctionReadWitnessConfigSchema,\n} from '@xyo-network/crypto-contract-function-read-payload-plugin'\nimport type {\n AnyConfigSchema, Schema, WitnessParams,\n} from '@xyo-network/sdk-js'\nimport { AbstractWitness, isPayloadOfSchemaType } from '@xyo-network/sdk-js'\nimport type { InterfaceAbi, Provider } from 'ethers'\nimport { Contract } from 'ethers'\n\n/** @deprecated use EvmCallWitness instead */\nexport interface CryptoContractFunctionReadWitnessParams extends WitnessParams<\n AnyConfigSchema<CryptoContractFunctionReadWitnessConfig>>\n{\n providers: Provider[]\n}\n\n/** @deprecated use EvmCallWitness instead */\nexport class CryptoContractFunctionReadWitness<\n TParams extends CryptoContractFunctionReadWitnessParams = CryptoContractFunctionReadWitnessParams,\n> extends AbstractWitness<TParams, CryptoContractFunctionCall, CryptoContractFunctionCallResult> {\n static override readonly configSchemas: Schema[] = [...super.configSchemas, CryptoContractFunctionReadWitnessConfigSchema]\n static override readonly defaultConfigSchema: Schema = CryptoContractFunctionReadWitnessConfigSchema\n\n get abi() {\n return assertEx(this.config.abi, () => 'Missing abi') as InterfaceAbi\n }\n\n protected override async observeHandler(inPayloads: CryptoContractFunctionCall[] = []): Promise<CryptoContractFunctionCallResult[]> {\n await this.startedAsync('throw')\n try {\n const observations = await Promise.all(\n inPayloads.filter(isPayloadOfSchemaType<CryptoContractFunctionCall>(CryptoContractFunctionCallSchema)).map(async ({\n functionName, args, address,\n }) => {\n const { providers } = this.params\n const provider = providers[Date.now() % providers.length] // pick a random provider\n const validatedAddress = assertEx(address ?? this.config.address, () => 'Missing address')\n const validatedFunctionName = assertEx(functionName ?? this.config.functionName, () => 'Missing address')\n const mergedArgs = [...(args ?? this.config.args ?? [])] as JsonObject[]\n\n const contract = new Contract(validatedAddress, this.abi, provider)\n try {\n const result = await contract[validatedFunctionName](...mergedArgs)\n const transformedResult = typeof result === 'bigint' ? result.toString(16) : result\n const observation: CryptoContractFunctionCallSuccess = {\n address: validatedAddress,\n args: mergedArgs,\n chainId: Number((await provider.getNetwork()).chainId),\n functionName: validatedFunctionName,\n result: transformedResult,\n schema: CryptoContractFunctionCallResultSchema,\n }\n return observation\n } catch (ex) {\n const error = ex as Error & { code: string }\n console.log(`Error [${this.config.name}]: ${error.code}`)\n const observation: CryptoContractFunctionCallFailure = {\n address: validatedAddress,\n args: mergedArgs,\n chainId: Number((await provider.getNetwork()).chainId),\n error: error.code,\n functionName: validatedFunctionName,\n schema: CryptoContractFunctionCallResultSchema,\n }\n return observation\n }\n }),\n )\n return observations\n } catch (ex) {\n const error = ex as Error\n console.log(`Error [${this.config.name}]: ${error.message}`)\n throw error\n }\n }\n}\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["result", "assertEx", "CryptoContractFunctionCallResultSchema", "isPayloadOfSchemaType"]
|
|
7
|
-
}
|