@xyo-network/crypto-contract-function-read-plugin 2.77.16
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/LICENSE +165 -0
- package/README.md +13 -0
- package/dist/browser/CryptoContractDiviner.d.cts +27 -0
- package/dist/browser/CryptoContractDiviner.d.cts.map +1 -0
- package/dist/browser/CryptoContractDiviner.d.mts +27 -0
- package/dist/browser/CryptoContractDiviner.d.mts.map +1 -0
- package/dist/browser/CryptoContractDiviner.d.ts +27 -0
- package/dist/browser/CryptoContractDiviner.d.ts.map +1 -0
- package/dist/browser/Erc1155Diviner.d.cts +17 -0
- package/dist/browser/Erc1155Diviner.d.cts.map +1 -0
- package/dist/browser/Erc1155Diviner.d.mts +17 -0
- package/dist/browser/Erc1155Diviner.d.mts.map +1 -0
- package/dist/browser/Erc1155Diviner.d.ts +17 -0
- package/dist/browser/Erc1155Diviner.d.ts.map +1 -0
- package/dist/browser/Erc721Diviner.d.cts +19 -0
- package/dist/browser/Erc721Diviner.d.cts.map +1 -0
- package/dist/browser/Erc721Diviner.d.mts +19 -0
- package/dist/browser/Erc721Diviner.d.mts.map +1 -0
- package/dist/browser/Erc721Diviner.d.ts +19 -0
- package/dist/browser/Erc721Diviner.d.ts.map +1 -0
- package/dist/browser/Plugin.d.cts +30 -0
- package/dist/browser/Plugin.d.cts.map +1 -0
- package/dist/browser/Plugin.d.mts +30 -0
- package/dist/browser/Plugin.d.mts.map +1 -0
- package/dist/browser/Plugin.d.ts +30 -0
- package/dist/browser/Plugin.d.ts.map +1 -0
- package/dist/browser/Witness.d.cts +13 -0
- package/dist/browser/Witness.d.cts.map +1 -0
- package/dist/browser/Witness.d.mts +13 -0
- package/dist/browser/Witness.d.mts.map +1 -0
- package/dist/browser/Witness.d.ts +13 -0
- package/dist/browser/Witness.d.ts.map +1 -0
- package/dist/browser/index.cjs +81 -0
- package/dist/browser/index.cjs.map +1 -0
- package/dist/browser/index.d.cts +5 -0
- package/dist/browser/index.d.cts.map +1 -0
- package/dist/browser/index.d.mts +5 -0
- package/dist/browser/index.d.mts.map +1 -0
- package/dist/browser/index.d.ts +5 -0
- package/dist/browser/index.d.ts.map +1 -0
- package/dist/browser/index.js +62 -0
- package/dist/browser/index.js.map +1 -0
- package/dist/node/CryptoContractDiviner.d.cts +27 -0
- package/dist/node/CryptoContractDiviner.d.cts.map +1 -0
- package/dist/node/CryptoContractDiviner.d.mts +27 -0
- package/dist/node/CryptoContractDiviner.d.mts.map +1 -0
- package/dist/node/CryptoContractDiviner.d.ts +27 -0
- package/dist/node/CryptoContractDiviner.d.ts.map +1 -0
- package/dist/node/Erc1155Diviner.d.cts +17 -0
- package/dist/node/Erc1155Diviner.d.cts.map +1 -0
- package/dist/node/Erc1155Diviner.d.mts +17 -0
- package/dist/node/Erc1155Diviner.d.mts.map +1 -0
- package/dist/node/Erc1155Diviner.d.ts +17 -0
- package/dist/node/Erc1155Diviner.d.ts.map +1 -0
- package/dist/node/Erc721Diviner.d.cts +19 -0
- package/dist/node/Erc721Diviner.d.cts.map +1 -0
- package/dist/node/Erc721Diviner.d.mts +19 -0
- package/dist/node/Erc721Diviner.d.mts.map +1 -0
- package/dist/node/Erc721Diviner.d.ts +19 -0
- package/dist/node/Erc721Diviner.d.ts.map +1 -0
- package/dist/node/Plugin.d.cts +30 -0
- package/dist/node/Plugin.d.cts.map +1 -0
- package/dist/node/Plugin.d.mts +30 -0
- package/dist/node/Plugin.d.mts.map +1 -0
- package/dist/node/Plugin.d.ts +30 -0
- package/dist/node/Plugin.d.ts.map +1 -0
- package/dist/node/Witness.d.cts +13 -0
- package/dist/node/Witness.d.cts.map +1 -0
- package/dist/node/Witness.d.mts +13 -0
- package/dist/node/Witness.d.mts.map +1 -0
- package/dist/node/Witness.d.ts +13 -0
- package/dist/node/Witness.d.ts.map +1 -0
- package/dist/node/index.d.cts +5 -0
- package/dist/node/index.d.cts.map +1 -0
- package/dist/node/index.d.mts +5 -0
- package/dist/node/index.d.mts.map +1 -0
- package/dist/node/index.d.ts +5 -0
- package/dist/node/index.d.ts.map +1 -0
- package/dist/node/index.js +86 -0
- package/dist/node/index.js.map +1 -0
- package/dist/node/index.mjs +62 -0
- package/dist/node/index.mjs.map +1 -0
- package/package.json +80 -0
- package/src/CryptoContractDiviner.ts +109 -0
- package/src/Erc1155Diviner.ts +37 -0
- package/src/Erc721Diviner.ts +41 -0
- package/src/Erc721Sentinel.json +134 -0
- package/src/Plugin.ts +16 -0
- package/src/Witness.ts +58 -0
- package/src/index.ts +8 -0
- package/typedoc.json +5 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EACL,0BAA0B,EAC1B,gCAAgC,EAGhC,uCAAuC,EAExC,MAAM,2DAA2D,CAAA;AAElE,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAE3D,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AAC1D,OAAO,EAAa,QAAQ,EAAE,MAAM,QAAQ,CAAA;AAE5C,MAAM,MAAM,uCAAuC,CAAC,SAAS,SAAS,QAAQ,IAAI,aAAa,CAC7F,eAAe,CAAC,uCAAuC,CAAC,EACxD;IACE,OAAO,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,SAAS,CAAA;CACxC,CACF,CAAA;AAED,qBAAa,iCAAiC,CAC5C,SAAS,SAAS,QAAQ,GAAG,QAAQ,EACrC,OAAO,SAAS,uCAAuC,CAAC,SAAS,CAAC,GAAG,uCAAuC,CAAC,SAAS,CAAC,CACvH,SAAQ,eAAe,CAAC,OAAO,EAAE,0BAA0B,CAAC,MAAM,SAAS,CAAC,YAAY,CAAC,CAAC,EAAE,gCAAgC,CAAC;IAC7H,OAAgB,aAAa,WAAkD;cAEtD,cAAc,CACrC,UAAU,GAAE,0BAA0B,CAAC,MAAM,SAAS,CAAC,YAAY,CAAC,CAAC,EAAO,GAC3E,OAAO,CAAC,gCAAgC,EAAE,CAAC;CA0B/C"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { AbstractWitness } from '@xyo-network/abstract-witness';
|
|
2
|
+
import { CryptoContractFunctionCall, CryptoContractFunctionCallResult, CryptoContractFunctionReadWitnessConfig } from '@xyo-network/crypto-contract-function-read-payload-plugin';
|
|
3
|
+
import { AnyConfigSchema } from '@xyo-network/module-model';
|
|
4
|
+
import { WitnessParams } from '@xyo-network/witness-model';
|
|
5
|
+
import { Contract } from 'ethers';
|
|
6
|
+
export type CryptoContractFunctionReadWitnessParams<TContract extends Contract> = WitnessParams<AnyConfigSchema<CryptoContractFunctionReadWitnessConfig>, {
|
|
7
|
+
factory: (address: string) => TContract;
|
|
8
|
+
}>;
|
|
9
|
+
export declare class CryptoContractFunctionReadWitness<TContract extends Contract = Contract, TParams extends CryptoContractFunctionReadWitnessParams<TContract> = CryptoContractFunctionReadWitnessParams<TContract>> extends AbstractWitness<TParams, CryptoContractFunctionCall<keyof TContract['callStatic']>, CryptoContractFunctionCallResult> {
|
|
10
|
+
static configSchemas: string[];
|
|
11
|
+
protected observeHandler(inPayloads?: CryptoContractFunctionCall<keyof TContract['callStatic']>[]): Promise<CryptoContractFunctionCallResult[]>;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=Witness.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EACL,0BAA0B,EAC1B,gCAAgC,EAGhC,uCAAuC,EAExC,MAAM,2DAA2D,CAAA;AAElE,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAE3D,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AAC1D,OAAO,EAAa,QAAQ,EAAE,MAAM,QAAQ,CAAA;AAE5C,MAAM,MAAM,uCAAuC,CAAC,SAAS,SAAS,QAAQ,IAAI,aAAa,CAC7F,eAAe,CAAC,uCAAuC,CAAC,EACxD;IACE,OAAO,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,SAAS,CAAA;CACxC,CACF,CAAA;AAED,qBAAa,iCAAiC,CAC5C,SAAS,SAAS,QAAQ,GAAG,QAAQ,EACrC,OAAO,SAAS,uCAAuC,CAAC,SAAS,CAAC,GAAG,uCAAuC,CAAC,SAAS,CAAC,CACvH,SAAQ,eAAe,CAAC,OAAO,EAAE,0BAA0B,CAAC,MAAM,SAAS,CAAC,YAAY,CAAC,CAAC,EAAE,gCAAgC,CAAC;IAC7H,OAAgB,aAAa,WAAkD;cAEtD,cAAc,CACrC,UAAU,GAAE,0BAA0B,CAAC,MAAM,SAAS,CAAC,YAAY,CAAC,CAAC,EAAO,GAC3E,OAAO,CAAC,gCAAgC,EAAE,CAAC;CA0B/C"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uCAAuC,EAAE,MAAM,UAAU,CAAA;AAElE,cAAc,WAAW,CAAA;AAEzB,OAAO,EAAE,uCAAuC,EAAE,CAAA;AAGlD,eAAe,uCAAuC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uCAAuC,EAAE,MAAM,UAAU,CAAA;AAElE,cAAc,WAAW,CAAA;AAEzB,OAAO,EAAE,uCAAuC,EAAE,CAAA;AAGlD,eAAe,uCAAuC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uCAAuC,EAAE,MAAM,UAAU,CAAA;AAElE,cAAc,WAAW,CAAA;AAEzB,OAAO,EAAE,uCAAuC,EAAE,CAAA;AAGlD,eAAe,uCAAuC,CAAA"}
|
|
@@ -0,0 +1,86 @@
|
|
|
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 __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/index.ts
|
|
21
|
+
var src_exports = {};
|
|
22
|
+
__export(src_exports, {
|
|
23
|
+
CryptoContractFunctionReadWitness: () => CryptoContractFunctionReadWitness,
|
|
24
|
+
CryptoContractFunctionReadWitnessPlugin: () => CryptoContractFunctionReadWitnessPlugin,
|
|
25
|
+
default: () => src_default
|
|
26
|
+
});
|
|
27
|
+
module.exports = __toCommonJS(src_exports);
|
|
28
|
+
|
|
29
|
+
// src/Plugin.ts
|
|
30
|
+
var import_crypto_nft_payload_plugin = require("@xyo-network/crypto-nft-payload-plugin");
|
|
31
|
+
var import_payload_model2 = require("@xyo-network/payload-model");
|
|
32
|
+
var import_payloadset_plugin = require("@xyo-network/payloadset-plugin");
|
|
33
|
+
|
|
34
|
+
// src/Witness.ts
|
|
35
|
+
var import_assert = require("@xylabs/assert");
|
|
36
|
+
var import_abstract_witness = require("@xyo-network/abstract-witness");
|
|
37
|
+
var import_crypto_contract_function_read_payload_plugin = require("@xyo-network/crypto-contract-function-read-payload-plugin");
|
|
38
|
+
var import_hash = require("@xyo-network/hash");
|
|
39
|
+
var import_payload_model = require("@xyo-network/payload-model");
|
|
40
|
+
var import_ethers = require("ethers");
|
|
41
|
+
var CryptoContractFunctionReadWitness = class extends import_abstract_witness.AbstractWitness {
|
|
42
|
+
static configSchemas = [import_crypto_contract_function_read_payload_plugin.CryptoContractFunctionReadWitnessConfigSchema];
|
|
43
|
+
async observeHandler(inPayloads = []) {
|
|
44
|
+
await this.started("throw");
|
|
45
|
+
const observations = await Promise.all(
|
|
46
|
+
inPayloads.filter((0, import_payload_model.isPayloadOfSchemaType)(import_crypto_contract_function_read_payload_plugin.CryptoContractFunctionCallSchema)).map(async (callPayload) => {
|
|
47
|
+
const fullCallPayload = { ...{ params: [] }, ...this.config.call, ...callPayload };
|
|
48
|
+
const { address, functionName, params } = fullCallPayload;
|
|
49
|
+
const validatedAddress = (0, import_assert.assertEx)(address, "Missing address");
|
|
50
|
+
const contract = this.params.factory(validatedAddress);
|
|
51
|
+
const func = (0, import_assert.assertEx)(contract.callStatic[(0, import_assert.assertEx)(functionName, "missing functionName")], `functionName [${functionName}] not found`);
|
|
52
|
+
const rawResult = await func(...params ?? []);
|
|
53
|
+
const result = import_ethers.BigNumber.isBigNumber(rawResult) ? { type: "BigNumber", value: rawResult.toHexString() } : { value: rawResult };
|
|
54
|
+
const observation = {
|
|
55
|
+
address: validatedAddress,
|
|
56
|
+
call: await import_hash.PayloadHasher.hashAsync(fullCallPayload),
|
|
57
|
+
chainId: (await contract.provider.getNetwork()).chainId,
|
|
58
|
+
result,
|
|
59
|
+
schema: import_crypto_contract_function_read_payload_plugin.CryptoContractFunctionCallResultSchema
|
|
60
|
+
};
|
|
61
|
+
return observation;
|
|
62
|
+
})
|
|
63
|
+
);
|
|
64
|
+
return observations.flat();
|
|
65
|
+
}
|
|
66
|
+
};
|
|
67
|
+
|
|
68
|
+
// src/Plugin.ts
|
|
69
|
+
var CryptoContractFunctionReadWitnessPlugin = () => (0, import_payloadset_plugin.createPayloadSetWitnessPlugin)(
|
|
70
|
+
{ required: { [import_crypto_nft_payload_plugin.NftSchema]: 1 }, schema: import_payload_model2.PayloadSetSchema },
|
|
71
|
+
{
|
|
72
|
+
witness: async (params) => {
|
|
73
|
+
const result = await CryptoContractFunctionReadWitness.create(params);
|
|
74
|
+
return result;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
);
|
|
78
|
+
|
|
79
|
+
// src/index.ts
|
|
80
|
+
var src_default = CryptoContractFunctionReadWitnessPlugin;
|
|
81
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
82
|
+
0 && (module.exports = {
|
|
83
|
+
CryptoContractFunctionReadWitness,
|
|
84
|
+
CryptoContractFunctionReadWitnessPlugin
|
|
85
|
+
});
|
|
86
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/Plugin.ts","../../src/Witness.ts"],"sourcesContent":["import { CryptoContractFunctionReadWitnessPlugin } from './Plugin'\n\nexport * from './Witness'\n\nexport { CryptoContractFunctionReadWitnessPlugin }\n\n// eslint-disable-next-line import/no-default-export\nexport default CryptoContractFunctionReadWitnessPlugin\n","import { NftSchema } from '@xyo-network/crypto-nft-payload-plugin'\nimport { PayloadSetSchema } from '@xyo-network/payload-model'\nimport { createPayloadSetWitnessPlugin } from '@xyo-network/payloadset-plugin'\n\nimport { CryptoContractFunctionReadWitness } from './Witness'\n\nexport const CryptoContractFunctionReadWitnessPlugin = () =>\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","import { assertEx } from '@xylabs/assert'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport {\n CryptoContractFunctionCall,\n CryptoContractFunctionCallResult,\n CryptoContractFunctionCallResultSchema,\n CryptoContractFunctionCallSchema,\n CryptoContractFunctionReadWitnessConfig,\n CryptoContractFunctionReadWitnessConfigSchema,\n} from '@xyo-network/crypto-contract-function-read-payload-plugin'\nimport { PayloadHasher } from '@xyo-network/hash'\nimport { AnyConfigSchema } from '@xyo-network/module-model'\nimport { isPayloadOfSchemaType } from '@xyo-network/payload-model'\nimport { WitnessParams } from '@xyo-network/witness-model'\nimport { BigNumber, Contract } from 'ethers'\n\nexport type CryptoContractFunctionReadWitnessParams<TContract extends Contract> = WitnessParams<\n AnyConfigSchema<CryptoContractFunctionReadWitnessConfig>,\n {\n factory: (address: string) => TContract\n }\n>\n\nexport class CryptoContractFunctionReadWitness<\n TContract extends Contract = Contract,\n TParams extends CryptoContractFunctionReadWitnessParams<TContract> = CryptoContractFunctionReadWitnessParams<TContract>,\n> extends AbstractWitness<TParams, CryptoContractFunctionCall<keyof TContract['callStatic']>, CryptoContractFunctionCallResult> {\n static override configSchemas = [CryptoContractFunctionReadWitnessConfigSchema]\n\n protected override async observeHandler(\n inPayloads: CryptoContractFunctionCall<keyof TContract['callStatic']>[] = [],\n ): Promise<CryptoContractFunctionCallResult[]> {\n await this.started('throw')\n const observations = await Promise.all(\n inPayloads.filter(isPayloadOfSchemaType(CryptoContractFunctionCallSchema)).map(async (callPayload) => {\n const fullCallPayload = { ...{ params: [] }, ...this.config.call, ...callPayload }\n const { address, functionName, params } = fullCallPayload\n const validatedAddress = assertEx(address, 'Missing address')\n const contract = this.params.factory(validatedAddress)\n const func = assertEx(contract.callStatic[assertEx(functionName, 'missing functionName')], `functionName [${functionName}] not found`)\n const rawResult = await func(...(params ?? []))\n const result: CryptoContractFunctionCallResult['result'] = BigNumber.isBigNumber(rawResult)\n ? { type: 'BigNumber', value: rawResult.toHexString() }\n : { value: rawResult }\n const observation: CryptoContractFunctionCallResult = {\n address: validatedAddress,\n call: await PayloadHasher.hashAsync(fullCallPayload),\n chainId: (await contract.provider.getNetwork()).chainId,\n result,\n schema: CryptoContractFunctionCallResultSchema,\n }\n return observation\n }),\n )\n\n return observations.flat()\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,uCAA0B;AAC1B,IAAAA,wBAAiC;AACjC,+BAA8C;;;ACF9C,oBAAyB;AACzB,8BAAgC;AAChC,0DAOO;AACP,kBAA8B;AAE9B,2BAAsC;AAEtC,oBAAoC;AAS7B,IAAM,oCAAN,cAGG,wCAAsH;AAAA,EAC9H,OAAgB,gBAAgB,CAAC,iGAA6C;AAAA,EAE9E,MAAyB,eACvB,aAA0E,CAAC,GAC9B;AAC7C,UAAM,KAAK,QAAQ,OAAO;AAC1B,UAAM,eAAe,MAAM,QAAQ;AAAA,MACjC,WAAW,WAAO,4CAAsB,oFAAgC,CAAC,EAAE,IAAI,OAAO,gBAAgB;AACpG,cAAM,kBAAkB,EAAE,GAAG,EAAE,QAAQ,CAAC,EAAE,GAAG,GAAG,KAAK,OAAO,MAAM,GAAG,YAAY;AACjF,cAAM,EAAE,SAAS,cAAc,OAAO,IAAI;AAC1C,cAAM,uBAAmB,wBAAS,SAAS,iBAAiB;AAC5D,cAAM,WAAW,KAAK,OAAO,QAAQ,gBAAgB;AACrD,cAAM,WAAO,wBAAS,SAAS,eAAW,wBAAS,cAAc,sBAAsB,CAAC,GAAG,iBAAiB,YAAY,aAAa;AACrI,cAAM,YAAY,MAAM,KAAK,GAAI,UAAU,CAAC,CAAE;AAC9C,cAAM,SAAqD,wBAAU,YAAY,SAAS,IACtF,EAAE,MAAM,aAAa,OAAO,UAAU,YAAY,EAAE,IACpD,EAAE,OAAO,UAAU;AACvB,cAAM,cAAgD;AAAA,UACpD,SAAS;AAAA,UACT,MAAM,MAAM,0BAAc,UAAU,eAAe;AAAA,UACnD,UAAU,MAAM,SAAS,SAAS,WAAW,GAAG;AAAA,UAChD;AAAA,UACA,QAAQ;AAAA,QACV;AACA,eAAO;AAAA,MACT,CAAC;AAAA,IACH;AAEA,WAAO,aAAa,KAAK;AAAA,EAC3B;AACF;;;ADnDO,IAAM,0CAA0C,UACrD;AAAA,EACE,EAAE,UAAU,EAAE,CAAC,0CAAS,GAAG,EAAE,GAAG,QAAQ,uCAAiB;AAAA,EACzD;AAAA,IACE,SAAS,OAAO,WAAW;AACzB,YAAM,SAAS,MAAM,kCAAkC,OAAO,MAAM;AACpE,aAAO;AAAA,IACT;AAAA,EACF;AACF;;;ADRF,IAAO,cAAQ;","names":["import_payload_model"]}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
// src/Plugin.ts
|
|
2
|
+
import { NftSchema } from "@xyo-network/crypto-nft-payload-plugin";
|
|
3
|
+
import { PayloadSetSchema } from "@xyo-network/payload-model";
|
|
4
|
+
import { createPayloadSetWitnessPlugin } from "@xyo-network/payloadset-plugin";
|
|
5
|
+
|
|
6
|
+
// src/Witness.ts
|
|
7
|
+
import { assertEx } from "@xylabs/assert";
|
|
8
|
+
import { AbstractWitness } from "@xyo-network/abstract-witness";
|
|
9
|
+
import {
|
|
10
|
+
CryptoContractFunctionCallResultSchema,
|
|
11
|
+
CryptoContractFunctionCallSchema,
|
|
12
|
+
CryptoContractFunctionReadWitnessConfigSchema
|
|
13
|
+
} from "@xyo-network/crypto-contract-function-read-payload-plugin";
|
|
14
|
+
import { PayloadHasher } from "@xyo-network/hash";
|
|
15
|
+
import { isPayloadOfSchemaType } from "@xyo-network/payload-model";
|
|
16
|
+
import { BigNumber } from "ethers";
|
|
17
|
+
var CryptoContractFunctionReadWitness = class extends AbstractWitness {
|
|
18
|
+
static configSchemas = [CryptoContractFunctionReadWitnessConfigSchema];
|
|
19
|
+
async observeHandler(inPayloads = []) {
|
|
20
|
+
await this.started("throw");
|
|
21
|
+
const observations = await Promise.all(
|
|
22
|
+
inPayloads.filter(isPayloadOfSchemaType(CryptoContractFunctionCallSchema)).map(async (callPayload) => {
|
|
23
|
+
const fullCallPayload = { ...{ params: [] }, ...this.config.call, ...callPayload };
|
|
24
|
+
const { address, functionName, params } = fullCallPayload;
|
|
25
|
+
const validatedAddress = assertEx(address, "Missing address");
|
|
26
|
+
const contract = this.params.factory(validatedAddress);
|
|
27
|
+
const func = assertEx(contract.callStatic[assertEx(functionName, "missing functionName")], `functionName [${functionName}] not found`);
|
|
28
|
+
const rawResult = await func(...params ?? []);
|
|
29
|
+
const result = BigNumber.isBigNumber(rawResult) ? { type: "BigNumber", value: rawResult.toHexString() } : { value: rawResult };
|
|
30
|
+
const observation = {
|
|
31
|
+
address: validatedAddress,
|
|
32
|
+
call: await PayloadHasher.hashAsync(fullCallPayload),
|
|
33
|
+
chainId: (await contract.provider.getNetwork()).chainId,
|
|
34
|
+
result,
|
|
35
|
+
schema: CryptoContractFunctionCallResultSchema
|
|
36
|
+
};
|
|
37
|
+
return observation;
|
|
38
|
+
})
|
|
39
|
+
);
|
|
40
|
+
return observations.flat();
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
// src/Plugin.ts
|
|
45
|
+
var CryptoContractFunctionReadWitnessPlugin = () => createPayloadSetWitnessPlugin(
|
|
46
|
+
{ required: { [NftSchema]: 1 }, schema: PayloadSetSchema },
|
|
47
|
+
{
|
|
48
|
+
witness: async (params) => {
|
|
49
|
+
const result = await CryptoContractFunctionReadWitness.create(params);
|
|
50
|
+
return result;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
);
|
|
54
|
+
|
|
55
|
+
// src/index.ts
|
|
56
|
+
var src_default = CryptoContractFunctionReadWitnessPlugin;
|
|
57
|
+
export {
|
|
58
|
+
CryptoContractFunctionReadWitness,
|
|
59
|
+
CryptoContractFunctionReadWitnessPlugin,
|
|
60
|
+
src_default as default
|
|
61
|
+
};
|
|
62
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/Plugin.ts","../../src/Witness.ts","../../src/index.ts"],"sourcesContent":["import { NftSchema } from '@xyo-network/crypto-nft-payload-plugin'\nimport { PayloadSetSchema } from '@xyo-network/payload-model'\nimport { createPayloadSetWitnessPlugin } from '@xyo-network/payloadset-plugin'\n\nimport { CryptoContractFunctionReadWitness } from './Witness'\n\nexport const CryptoContractFunctionReadWitnessPlugin = () =>\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","import { assertEx } from '@xylabs/assert'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport {\n CryptoContractFunctionCall,\n CryptoContractFunctionCallResult,\n CryptoContractFunctionCallResultSchema,\n CryptoContractFunctionCallSchema,\n CryptoContractFunctionReadWitnessConfig,\n CryptoContractFunctionReadWitnessConfigSchema,\n} from '@xyo-network/crypto-contract-function-read-payload-plugin'\nimport { PayloadHasher } from '@xyo-network/hash'\nimport { AnyConfigSchema } from '@xyo-network/module-model'\nimport { isPayloadOfSchemaType } from '@xyo-network/payload-model'\nimport { WitnessParams } from '@xyo-network/witness-model'\nimport { BigNumber, Contract } from 'ethers'\n\nexport type CryptoContractFunctionReadWitnessParams<TContract extends Contract> = WitnessParams<\n AnyConfigSchema<CryptoContractFunctionReadWitnessConfig>,\n {\n factory: (address: string) => TContract\n }\n>\n\nexport class CryptoContractFunctionReadWitness<\n TContract extends Contract = Contract,\n TParams extends CryptoContractFunctionReadWitnessParams<TContract> = CryptoContractFunctionReadWitnessParams<TContract>,\n> extends AbstractWitness<TParams, CryptoContractFunctionCall<keyof TContract['callStatic']>, CryptoContractFunctionCallResult> {\n static override configSchemas = [CryptoContractFunctionReadWitnessConfigSchema]\n\n protected override async observeHandler(\n inPayloads: CryptoContractFunctionCall<keyof TContract['callStatic']>[] = [],\n ): Promise<CryptoContractFunctionCallResult[]> {\n await this.started('throw')\n const observations = await Promise.all(\n inPayloads.filter(isPayloadOfSchemaType(CryptoContractFunctionCallSchema)).map(async (callPayload) => {\n const fullCallPayload = { ...{ params: [] }, ...this.config.call, ...callPayload }\n const { address, functionName, params } = fullCallPayload\n const validatedAddress = assertEx(address, 'Missing address')\n const contract = this.params.factory(validatedAddress)\n const func = assertEx(contract.callStatic[assertEx(functionName, 'missing functionName')], `functionName [${functionName}] not found`)\n const rawResult = await func(...(params ?? []))\n const result: CryptoContractFunctionCallResult['result'] = BigNumber.isBigNumber(rawResult)\n ? { type: 'BigNumber', value: rawResult.toHexString() }\n : { value: rawResult }\n const observation: CryptoContractFunctionCallResult = {\n address: validatedAddress,\n call: await PayloadHasher.hashAsync(fullCallPayload),\n chainId: (await contract.provider.getNetwork()).chainId,\n result,\n schema: CryptoContractFunctionCallResultSchema,\n }\n return observation\n }),\n )\n\n return observations.flat()\n }\n}\n","import { CryptoContractFunctionReadWitnessPlugin } from './Plugin'\n\nexport * from './Witness'\n\nexport { CryptoContractFunctionReadWitnessPlugin }\n\n// eslint-disable-next-line import/no-default-export\nexport default CryptoContractFunctionReadWitnessPlugin\n"],"mappings":";AAAA,SAAS,iBAAiB;AAC1B,SAAS,wBAAwB;AACjC,SAAS,qCAAqC;;;ACF9C,SAAS,gBAAgB;AACzB,SAAS,uBAAuB;AAChC;AAAA,EAGE;AAAA,EACA;AAAA,EAEA;AAAA,OACK;AACP,SAAS,qBAAqB;AAE9B,SAAS,6BAA6B;AAEtC,SAAS,iBAA2B;AAS7B,IAAM,oCAAN,cAGG,gBAAsH;AAAA,EAC9H,OAAgB,gBAAgB,CAAC,6CAA6C;AAAA,EAE9E,MAAyB,eACvB,aAA0E,CAAC,GAC9B;AAC7C,UAAM,KAAK,QAAQ,OAAO;AAC1B,UAAM,eAAe,MAAM,QAAQ;AAAA,MACjC,WAAW,OAAO,sBAAsB,gCAAgC,CAAC,EAAE,IAAI,OAAO,gBAAgB;AACpG,cAAM,kBAAkB,EAAE,GAAG,EAAE,QAAQ,CAAC,EAAE,GAAG,GAAG,KAAK,OAAO,MAAM,GAAG,YAAY;AACjF,cAAM,EAAE,SAAS,cAAc,OAAO,IAAI;AAC1C,cAAM,mBAAmB,SAAS,SAAS,iBAAiB;AAC5D,cAAM,WAAW,KAAK,OAAO,QAAQ,gBAAgB;AACrD,cAAM,OAAO,SAAS,SAAS,WAAW,SAAS,cAAc,sBAAsB,CAAC,GAAG,iBAAiB,YAAY,aAAa;AACrI,cAAM,YAAY,MAAM,KAAK,GAAI,UAAU,CAAC,CAAE;AAC9C,cAAM,SAAqD,UAAU,YAAY,SAAS,IACtF,EAAE,MAAM,aAAa,OAAO,UAAU,YAAY,EAAE,IACpD,EAAE,OAAO,UAAU;AACvB,cAAM,cAAgD;AAAA,UACpD,SAAS;AAAA,UACT,MAAM,MAAM,cAAc,UAAU,eAAe;AAAA,UACnD,UAAU,MAAM,SAAS,SAAS,WAAW,GAAG;AAAA,UAChD;AAAA,UACA,QAAQ;AAAA,QACV;AACA,eAAO;AAAA,MACT,CAAC;AAAA,IACH;AAEA,WAAO,aAAa,KAAK;AAAA,EAC3B;AACF;;;ADnDO,IAAM,0CAA0C,MACrD;AAAA,EACE,EAAE,UAAU,EAAE,CAAC,SAAS,GAAG,EAAE,GAAG,QAAQ,iBAAiB;AAAA,EACzD;AAAA,IACE,SAAS,OAAO,WAAW;AACzB,YAAM,SAAS,MAAM,kCAAkC,OAAO,MAAM;AACpE,aAAO;AAAA,IACT;AAAA,EACF;AACF;;;AERF,IAAO,cAAQ;","names":[]}
|
package/package.json
ADDED
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@xyo-network/crypto-contract-function-read-plugin",
|
|
3
|
+
"author": {
|
|
4
|
+
"email": "support@xyo.network",
|
|
5
|
+
"name": "XYO Development Team",
|
|
6
|
+
"url": "https://xyo.network"
|
|
7
|
+
},
|
|
8
|
+
"bugs": {
|
|
9
|
+
"email": "support@xyo.network",
|
|
10
|
+
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/issues"
|
|
11
|
+
},
|
|
12
|
+
"dependencies": {
|
|
13
|
+
"@xylabs/assert": "^2.13.3",
|
|
14
|
+
"@xylabs/promise": "^2.13.3",
|
|
15
|
+
"@xyo-network/abstract-diviner": "~2.77.16",
|
|
16
|
+
"@xyo-network/abstract-witness": "~2.77.16",
|
|
17
|
+
"@xyo-network/crypto-contract-function-read-payload-plugin": "~2.77.16",
|
|
18
|
+
"@xyo-network/crypto-nft-payload-plugin": "~2.77.16",
|
|
19
|
+
"@xyo-network/diviner-model": "~2.77.16",
|
|
20
|
+
"@xyo-network/hash": "~2.77.16",
|
|
21
|
+
"@xyo-network/module-model": "~2.77.16",
|
|
22
|
+
"@xyo-network/payload-model": "~2.77.16",
|
|
23
|
+
"@xyo-network/payloadset-plugin": "~2.77.16",
|
|
24
|
+
"@xyo-network/witness-model": "~2.77.16"
|
|
25
|
+
},
|
|
26
|
+
"devDependencies": {
|
|
27
|
+
"@ethersproject/providers": "^5.7.2",
|
|
28
|
+
"@xylabs/jest-helpers": "^2.13.3",
|
|
29
|
+
"@xylabs/ts-scripts-yarn3": "^3.1.13",
|
|
30
|
+
"@xylabs/tsconfig": "^3.1.13",
|
|
31
|
+
"@xyo-network/account": "~2.77.16",
|
|
32
|
+
"@xyo-network/manifest": "~2.77.16",
|
|
33
|
+
"@xyo-network/open-zeppelin-typechain": "^2.2.11",
|
|
34
|
+
"@xyo-network/sentinel-model": "~2.77.16",
|
|
35
|
+
"ethers": "^5.7.2",
|
|
36
|
+
"jest": "^29.7.0",
|
|
37
|
+
"typescript": "^5.2.2"
|
|
38
|
+
},
|
|
39
|
+
"description": "Primary SDK for using XYO Protocol 2.0",
|
|
40
|
+
"docs": "dist/docs.json",
|
|
41
|
+
"types": "dist/node/index.d.ts",
|
|
42
|
+
"exports": {
|
|
43
|
+
".": {
|
|
44
|
+
"browser": {
|
|
45
|
+
"require": {
|
|
46
|
+
"types": "./dist/browser/index.d.cts",
|
|
47
|
+
"default": "./dist/browser/index.cjs"
|
|
48
|
+
},
|
|
49
|
+
"import": {
|
|
50
|
+
"types": "./dist/browser/index.d.mts",
|
|
51
|
+
"default": "./dist/browser/index.js"
|
|
52
|
+
}
|
|
53
|
+
},
|
|
54
|
+
"node": {
|
|
55
|
+
"require": {
|
|
56
|
+
"types": "./dist/node/index.d.ts",
|
|
57
|
+
"default": "./dist/node/index.js"
|
|
58
|
+
},
|
|
59
|
+
"import": {
|
|
60
|
+
"types": "./dist/node/index.d.mts",
|
|
61
|
+
"default": "./dist/node/index.mjs"
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
},
|
|
65
|
+
"./package.json": "./package.json"
|
|
66
|
+
},
|
|
67
|
+
"main": "dist/node/index.js",
|
|
68
|
+
"module": "dist/node/index.mjs",
|
|
69
|
+
"homepage": "https://xyo.network",
|
|
70
|
+
"license": "LGPL-3.0-only",
|
|
71
|
+
"publishConfig": {
|
|
72
|
+
"access": "public"
|
|
73
|
+
},
|
|
74
|
+
"repository": {
|
|
75
|
+
"type": "git",
|
|
76
|
+
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
|
|
77
|
+
},
|
|
78
|
+
"sideEffects": false,
|
|
79
|
+
"version": "2.77.16"
|
|
80
|
+
}
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
import { assertEx } from '@xylabs/assert'
|
|
2
|
+
import { Promisable } from '@xylabs/promise'
|
|
3
|
+
import { AbstractDiviner } from '@xyo-network/abstract-diviner'
|
|
4
|
+
import {
|
|
5
|
+
CryptoContractFunctionCall,
|
|
6
|
+
CryptoContractFunctionCallResult,
|
|
7
|
+
CryptoContractFunctionCallResultSchema,
|
|
8
|
+
CryptoContractFunctionCallSchema,
|
|
9
|
+
} from '@xyo-network/crypto-contract-function-read-payload-plugin'
|
|
10
|
+
import { DivinerConfig, DivinerParams } from '@xyo-network/diviner-model'
|
|
11
|
+
import { PayloadHasher } from '@xyo-network/hash'
|
|
12
|
+
import { isPayloadOfSchemaType, Payload } from '@xyo-network/payload-model'
|
|
13
|
+
|
|
14
|
+
export type FindCallResult<TResult = string, TPayload = Payload> = [TResult, TPayload] | [undefined, TPayload] | [undefined, undefined]
|
|
15
|
+
|
|
16
|
+
export const CryptoContractDivinerConfigSchema = 'network.xyo.crypto.contract.diviner.config'
|
|
17
|
+
export type CryptoContractDivinerConfigSchema = typeof CryptoContractDivinerConfigSchema
|
|
18
|
+
|
|
19
|
+
export type CryptoContractDivinerConfig = DivinerConfig
|
|
20
|
+
export type CryptoContractDivinerParams = DivinerParams<CryptoContractDivinerConfig>
|
|
21
|
+
|
|
22
|
+
export const ContractInfoSchema = 'network.xyo.crypto.contract.info'
|
|
23
|
+
export type ContractInfoSchema = typeof ContractInfoSchema
|
|
24
|
+
|
|
25
|
+
export type OmittedContractInfo<TFields extends object | Payload | null = null, TSchema extends string | null = null> = Omit<
|
|
26
|
+
ContractInfo<TFields, TSchema extends null ? (TFields extends Payload ? TFields['schema'] : never) : TSchema>,
|
|
27
|
+
'address' | 'chainId'
|
|
28
|
+
>
|
|
29
|
+
|
|
30
|
+
export type ContractInfo<TFields extends object | null = null, TSchema extends string = ContractInfoSchema> = Payload<
|
|
31
|
+
TFields extends null
|
|
32
|
+
? object
|
|
33
|
+
: TFields & {
|
|
34
|
+
address: string
|
|
35
|
+
chainId: string
|
|
36
|
+
},
|
|
37
|
+
TSchema
|
|
38
|
+
>
|
|
39
|
+
|
|
40
|
+
export abstract class CryptoContractDiviner<
|
|
41
|
+
TContractInfo extends Payload<Omit<ContractInfo, 'schema'>> = ContractInfo,
|
|
42
|
+
TParams extends CryptoContractDivinerParams = CryptoContractDivinerParams,
|
|
43
|
+
> extends AbstractDiviner<TParams> {
|
|
44
|
+
static override configSchemas = [CryptoContractDivinerConfigSchema]
|
|
45
|
+
|
|
46
|
+
protected static async findCallResult<TResult = string>(
|
|
47
|
+
address: string,
|
|
48
|
+
functionName: string,
|
|
49
|
+
params: unknown[],
|
|
50
|
+
payloads: CryptoContractFunctionCallResult[],
|
|
51
|
+
): Promise<TResult | undefined> {
|
|
52
|
+
const callHash = await this.generateCallHash(address, functionName, params)
|
|
53
|
+
const foundPayload = payloads.find((payload) => payload.call === callHash)
|
|
54
|
+
return foundPayload?.result.value as TResult | undefined
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
protected static async generateCallHash(address: string, functionName: string, params: unknown[]) {
|
|
58
|
+
const callPayload: CryptoContractFunctionCall = {
|
|
59
|
+
address,
|
|
60
|
+
functionName,
|
|
61
|
+
params,
|
|
62
|
+
schema: CryptoContractFunctionCallSchema,
|
|
63
|
+
}
|
|
64
|
+
return await PayloadHasher.hashAsync(callPayload)
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
protected static matchingExistingField<R = string, T extends Payload = Payload>(objs: T[], field: keyof T) {
|
|
68
|
+
const expectedValue = objs.at(0)?.[field] as R
|
|
69
|
+
const didNotMatch = objs.reduce((prev, obj) => {
|
|
70
|
+
return prev || obj[field] !== expectedValue
|
|
71
|
+
}, false)
|
|
72
|
+
return didNotMatch ? undefined : expectedValue
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
protected contractInfoRequiredFields(callResults: CryptoContractFunctionCallResult[]): Promisable<Omit<ContractInfo, 'schema'>> {
|
|
76
|
+
return {
|
|
77
|
+
address: assertEx(CryptoContractDiviner.matchingExistingField(callResults, 'address'), 'Mismatched address'),
|
|
78
|
+
chainId: assertEx(CryptoContractDiviner.matchingExistingField(callResults, 'chainId'), 'Mismatched chainId'),
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
protected override async divineHandler(inPayloads: CryptoContractFunctionCallResult[] = []): Promise<TContractInfo[]> {
|
|
83
|
+
const callResults = inPayloads.filter(isPayloadOfSchemaType<CryptoContractFunctionCallResult>(CryptoContractFunctionCallResultSchema))
|
|
84
|
+
const addresses = Object.keys(
|
|
85
|
+
callResults.reduce<Record<string, boolean>>((prev, result) => {
|
|
86
|
+
if (result.address) {
|
|
87
|
+
prev[result.address] = true
|
|
88
|
+
}
|
|
89
|
+
return prev
|
|
90
|
+
}, {}),
|
|
91
|
+
)
|
|
92
|
+
const result = await Promise.all(
|
|
93
|
+
addresses.map(async (address) => {
|
|
94
|
+
const foundCallResults = callResults.filter((callResult) => callResult.address === address)
|
|
95
|
+
return {
|
|
96
|
+
...(await this.reduceResults(address, foundCallResults)),
|
|
97
|
+
...this.contractInfoRequiredFields(foundCallResults),
|
|
98
|
+
} as TContractInfo
|
|
99
|
+
}),
|
|
100
|
+
)
|
|
101
|
+
|
|
102
|
+
return result
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
protected abstract reduceResults(
|
|
106
|
+
address: string,
|
|
107
|
+
callResults: CryptoContractFunctionCallResult[],
|
|
108
|
+
): Promisable<Omit<TContractInfo, 'address' | 'chainId'>>
|
|
109
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { CryptoContractFunctionCallResult } from '@xyo-network/crypto-contract-function-read-payload-plugin'
|
|
2
|
+
import { DivinerConfig, DivinerParams } from '@xyo-network/diviner-model'
|
|
3
|
+
|
|
4
|
+
import { ContractInfo, CryptoContractDiviner, OmittedContractInfo } from './CryptoContractDiviner'
|
|
5
|
+
|
|
6
|
+
export const CryptoContractErc1155DivinerConfigSchema = 'network.xyo.crypto.contract.erc1155.info.diviner.config'
|
|
7
|
+
export type CryptoContractErc1155DivinerConfigSchema = typeof CryptoContractErc1155DivinerConfigSchema
|
|
8
|
+
|
|
9
|
+
export type CryptoContractErc1155DivinerConfig = DivinerConfig
|
|
10
|
+
export type CryptoContractErc1155DivinerParams = DivinerParams<CryptoContractErc1155DivinerConfig>
|
|
11
|
+
|
|
12
|
+
export const Erc1155ContractInfoSchema = 'network.xyo.crypto.contract.erc1155.info'
|
|
13
|
+
export type Erc1155ContractInfoSchema = typeof Erc1155ContractInfoSchema
|
|
14
|
+
|
|
15
|
+
export type Erc1155ContractInfo = ContractInfo<
|
|
16
|
+
{
|
|
17
|
+
uri?: string
|
|
18
|
+
},
|
|
19
|
+
Erc1155ContractInfoSchema
|
|
20
|
+
>
|
|
21
|
+
|
|
22
|
+
export class CryptoContractErc1155Diviner<
|
|
23
|
+
TParams extends CryptoContractErc1155DivinerParams = CryptoContractErc1155DivinerParams,
|
|
24
|
+
> extends CryptoContractDiviner<Erc1155ContractInfo, TParams> {
|
|
25
|
+
static override configSchemas = [CryptoContractErc1155DivinerConfigSchema]
|
|
26
|
+
|
|
27
|
+
protected override async reduceResults(
|
|
28
|
+
address: string,
|
|
29
|
+
callResults: CryptoContractFunctionCallResult[],
|
|
30
|
+
): Promise<OmittedContractInfo<Erc1155ContractInfo>> {
|
|
31
|
+
const uri = await CryptoContractErc1155Diviner.findCallResult(address, 'uri', [], callResults)
|
|
32
|
+
return {
|
|
33
|
+
schema: Erc1155ContractInfoSchema,
|
|
34
|
+
uri,
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { CryptoContractFunctionCallResult } from '@xyo-network/crypto-contract-function-read-payload-plugin'
|
|
2
|
+
import { DivinerConfig, DivinerParams } from '@xyo-network/diviner-model'
|
|
3
|
+
|
|
4
|
+
import { ContractInfo, CryptoContractDiviner, OmittedContractInfo } from './CryptoContractDiviner'
|
|
5
|
+
|
|
6
|
+
export const CryptoContractErc721DivinerConfigSchema = 'network.xyo.crypto.contract.erc721.info.diviner.config'
|
|
7
|
+
export type CryptoContractErc721DivinerConfigSchema = typeof CryptoContractErc721DivinerConfigSchema
|
|
8
|
+
|
|
9
|
+
export type CryptoContractErc721DivinerConfig = DivinerConfig
|
|
10
|
+
export type CryptoContractErc721DivinerParams = DivinerParams<CryptoContractErc721DivinerConfig>
|
|
11
|
+
|
|
12
|
+
export const Erc721ContractInfoSchema = 'network.xyo.crypto.contract.erc721.info'
|
|
13
|
+
export type Erc721ContractInfoSchema = typeof Erc721ContractInfoSchema
|
|
14
|
+
|
|
15
|
+
export type Erc721ContractInfo = ContractInfo<
|
|
16
|
+
{
|
|
17
|
+
name?: string
|
|
18
|
+
symbol?: string
|
|
19
|
+
totalSupply?: string
|
|
20
|
+
},
|
|
21
|
+
Erc721ContractInfoSchema
|
|
22
|
+
>
|
|
23
|
+
|
|
24
|
+
export class CryptoContractErc721Diviner<
|
|
25
|
+
TParams extends CryptoContractErc721DivinerParams = CryptoContractErc721DivinerParams,
|
|
26
|
+
> extends CryptoContractDiviner<Erc721ContractInfo, TParams> {
|
|
27
|
+
static override configSchemas = [CryptoContractErc721DivinerConfigSchema]
|
|
28
|
+
|
|
29
|
+
protected override async reduceResults(
|
|
30
|
+
address: string,
|
|
31
|
+
callResults: CryptoContractFunctionCallResult[],
|
|
32
|
+
): Promise<OmittedContractInfo<Erc721ContractInfo>> {
|
|
33
|
+
const name = await CryptoContractErc721Diviner.findCallResult(address, 'name', [], callResults)
|
|
34
|
+
const symbol = await CryptoContractErc721Diviner.findCallResult(address, 'symbol', [], callResults)
|
|
35
|
+
return {
|
|
36
|
+
name,
|
|
37
|
+
schema: Erc721ContractInfoSchema,
|
|
38
|
+
symbol,
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
{
|
|
2
|
+
"$schema": "https://raw.githubusercontent.com/XYOracleNetwork/sdk-xyo-client-js/a5a229a767e3998e13cce8160fd1c2b027317424/packages/manifest/src/schema.json",
|
|
3
|
+
"nodes": [
|
|
4
|
+
{
|
|
5
|
+
"config": {
|
|
6
|
+
"accountPath": "m/44'/60'/1'/0'/0'",
|
|
7
|
+
"name": "Erc721Info",
|
|
8
|
+
"schema": "network.xyo.node.config"
|
|
9
|
+
},
|
|
10
|
+
"modules": {
|
|
11
|
+
"public": [
|
|
12
|
+
{
|
|
13
|
+
"config": {
|
|
14
|
+
"accountPath": "m/44'/60'/1'/1'/0'",
|
|
15
|
+
"call": {
|
|
16
|
+
"functionName": "name",
|
|
17
|
+
"params": []
|
|
18
|
+
},
|
|
19
|
+
"labels": {
|
|
20
|
+
"network.xyo.crypto.contract.interface": "Erc721"
|
|
21
|
+
},
|
|
22
|
+
"language": "javascript",
|
|
23
|
+
"name": "Erc721NameWitness",
|
|
24
|
+
"schema": "network.xyo.crypto.contract.function.read.config"
|
|
25
|
+
}
|
|
26
|
+
},
|
|
27
|
+
{
|
|
28
|
+
"config": {
|
|
29
|
+
"accountPath": "m/44'/60'/1'/1'/1'",
|
|
30
|
+
"call": {
|
|
31
|
+
"functionName": "symbol",
|
|
32
|
+
"params": []
|
|
33
|
+
},
|
|
34
|
+
"labels": {
|
|
35
|
+
"network.xyo.crypto.contract.interface": "Erc721"
|
|
36
|
+
},
|
|
37
|
+
"language": "javascript",
|
|
38
|
+
"name": "Erc721SymbolWitness",
|
|
39
|
+
"schema": "network.xyo.crypto.contract.function.read.config"
|
|
40
|
+
}
|
|
41
|
+
},
|
|
42
|
+
{
|
|
43
|
+
"config": {
|
|
44
|
+
"accountPath": "m/44'/60'/1'/1'/2'",
|
|
45
|
+
"call": {
|
|
46
|
+
"functionName": "totalSupply",
|
|
47
|
+
"params": []
|
|
48
|
+
},
|
|
49
|
+
"labels": {
|
|
50
|
+
"network.xyo.crypto.contract.interface": "Erc721"
|
|
51
|
+
},
|
|
52
|
+
"language": "javascript",
|
|
53
|
+
"name": "Erc721TotalSupplyWitness",
|
|
54
|
+
"schema": "network.xyo.crypto.contract.function.read.config"
|
|
55
|
+
}
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
"config": {
|
|
59
|
+
"accountPath": "m/44'/60'/1'/1'/3'",
|
|
60
|
+
"call": {
|
|
61
|
+
"functionName": "uri",
|
|
62
|
+
"params": []
|
|
63
|
+
},
|
|
64
|
+
"labels": {
|
|
65
|
+
"network.xyo.crypto.contract.interface": "Erc1155"
|
|
66
|
+
},
|
|
67
|
+
"language": "javascript",
|
|
68
|
+
"name": "Erc1155UriWitness",
|
|
69
|
+
"schema": "network.xyo.crypto.contract.function.read.config"
|
|
70
|
+
}
|
|
71
|
+
},
|
|
72
|
+
{
|
|
73
|
+
"config": {
|
|
74
|
+
"accountPath": "m/44'/60'/1'/2'/0'",
|
|
75
|
+
"language": "javascript",
|
|
76
|
+
"name": "Erc721ContractInfoDiviner",
|
|
77
|
+
"schema": "network.xyo.crypto.contract.erc721.info.diviner.config"
|
|
78
|
+
}
|
|
79
|
+
},
|
|
80
|
+
{
|
|
81
|
+
"config": {
|
|
82
|
+
"accountPath": "m/44'/60'/1'/2'/1'",
|
|
83
|
+
"language": "javascript",
|
|
84
|
+
"name": "Erc1155ContractInfoDiviner",
|
|
85
|
+
"schema": "network.xyo.crypto.contract.erc1155.info.diviner.config"
|
|
86
|
+
}
|
|
87
|
+
},
|
|
88
|
+
{
|
|
89
|
+
"config": {
|
|
90
|
+
"accountPath": "m/44'/60'/1'/3'/0'",
|
|
91
|
+
"language": "javascript",
|
|
92
|
+
"name": "Erc721InfoSentinel",
|
|
93
|
+
"schema": "network.xyo.sentinel.config",
|
|
94
|
+
"synchronous": "true",
|
|
95
|
+
"tasks": [
|
|
96
|
+
{
|
|
97
|
+
"input": true,
|
|
98
|
+
"module": "Erc721NameWitness"
|
|
99
|
+
},
|
|
100
|
+
{
|
|
101
|
+
"input": true,
|
|
102
|
+
"module": "Erc721SymbolWitness"
|
|
103
|
+
},
|
|
104
|
+
{
|
|
105
|
+
"input": true,
|
|
106
|
+
"module": "Erc721TotalSupplyWitness"
|
|
107
|
+
},
|
|
108
|
+
{
|
|
109
|
+
"input": true,
|
|
110
|
+
"module": "Erc1155UriWitness"
|
|
111
|
+
},
|
|
112
|
+
{
|
|
113
|
+
"input": [
|
|
114
|
+
"Erc721NameWitness",
|
|
115
|
+
"Erc721SymbolWitness",
|
|
116
|
+
"Erc721TotalSupplyWitness"
|
|
117
|
+
],
|
|
118
|
+
"module": "Erc721ContractInfoDiviner"
|
|
119
|
+
},
|
|
120
|
+
{
|
|
121
|
+
"input": [
|
|
122
|
+
"Erc1155UriWitness"
|
|
123
|
+
],
|
|
124
|
+
"module": "Erc1155ContractInfoDiviner"
|
|
125
|
+
}
|
|
126
|
+
]
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
]
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
],
|
|
133
|
+
"schema": "network.xyo.manifest"
|
|
134
|
+
}
|
package/src/Plugin.ts
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { NftSchema } from '@xyo-network/crypto-nft-payload-plugin'
|
|
2
|
+
import { PayloadSetSchema } from '@xyo-network/payload-model'
|
|
3
|
+
import { createPayloadSetWitnessPlugin } from '@xyo-network/payloadset-plugin'
|
|
4
|
+
|
|
5
|
+
import { CryptoContractFunctionReadWitness } from './Witness'
|
|
6
|
+
|
|
7
|
+
export const CryptoContractFunctionReadWitnessPlugin = () =>
|
|
8
|
+
createPayloadSetWitnessPlugin<CryptoContractFunctionReadWitness>(
|
|
9
|
+
{ required: { [NftSchema]: 1 }, schema: PayloadSetSchema },
|
|
10
|
+
{
|
|
11
|
+
witness: async (params) => {
|
|
12
|
+
const result = await CryptoContractFunctionReadWitness.create(params)
|
|
13
|
+
return result
|
|
14
|
+
},
|
|
15
|
+
},
|
|
16
|
+
)
|