@xyo-network/evm-token-interface-diviner 2.97.0-rc.1 → 2.97.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/dist/browser/Diviner.d.cts +0 -9
- package/dist/browser/Diviner.d.cts.map +1 -1
- package/dist/browser/Diviner.d.mts +0 -9
- package/dist/browser/Diviner.d.mts.map +1 -1
- package/dist/browser/Diviner.d.ts +0 -9
- package/dist/browser/Diviner.d.ts.map +1 -1
- package/dist/browser/Payload.d.cts +1 -49
- package/dist/browser/Payload.d.cts.map +1 -1
- package/dist/browser/Payload.d.mts +1 -49
- package/dist/browser/Payload.d.mts.map +1 -1
- package/dist/browser/Payload.d.ts +1 -49
- package/dist/browser/Payload.d.ts.map +1 -1
- package/dist/browser/index.cjs +1 -108
- package/dist/browser/index.cjs.map +1 -1
- package/dist/browser/index.js +1 -94
- package/dist/browser/index.js.map +1 -1
- package/dist/neutral/Diviner.d.cts +0 -9
- package/dist/neutral/Diviner.d.cts.map +1 -1
- package/dist/neutral/Diviner.d.mts +0 -9
- package/dist/neutral/Diviner.d.mts.map +1 -1
- package/dist/neutral/Diviner.d.ts +0 -9
- package/dist/neutral/Diviner.d.ts.map +1 -1
- package/dist/neutral/Payload.d.cts +1 -49
- package/dist/neutral/Payload.d.cts.map +1 -1
- package/dist/neutral/Payload.d.mts +1 -49
- package/dist/neutral/Payload.d.mts.map +1 -1
- package/dist/neutral/Payload.d.ts +1 -49
- package/dist/neutral/Payload.d.ts.map +1 -1
- package/dist/neutral/index.cjs +1 -108
- package/dist/neutral/index.cjs.map +1 -1
- package/dist/neutral/index.js +1 -94
- package/dist/neutral/index.js.map +1 -1
- package/dist/node/Diviner.d.cts +0 -9
- package/dist/node/Diviner.d.cts.map +1 -1
- package/dist/node/Diviner.d.mts +0 -9
- package/dist/node/Diviner.d.mts.map +1 -1
- package/dist/node/Diviner.d.ts +0 -9
- package/dist/node/Diviner.d.ts.map +1 -1
- package/dist/node/Payload.d.cts +1 -49
- package/dist/node/Payload.d.cts.map +1 -1
- package/dist/node/Payload.d.mts +1 -49
- package/dist/node/Payload.d.mts.map +1 -1
- package/dist/node/Payload.d.ts +1 -49
- package/dist/node/Payload.d.ts.map +1 -1
- package/dist/node/index.cjs +1 -116
- package/dist/node/index.cjs.map +1 -1
- package/dist/node/index.js +1 -95
- package/dist/node/index.js.map +1 -1
- package/package.json +26 -27
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/Diviner.ts","../../src/Payload.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { DivinerConfig, DivinerParams } from '@xyo-network/diviner-model'\nimport { EvmContract, isEvmContract } from '@xyo-network/evm-contract-witness'\nimport { AnyConfigSchema } from '@xyo-network/module-model'\nimport {\n ERC20__factory,\n ERC721__factory,\n ERC1155__factory,\n IERC721Enumerable__factory,\n IERC721Metadata__factory,\n IERC721Receiver__factory,\n IERC1155MetadataURI__factory,\n IERC1155Receiver__factory,\n} from '@xyo-network/open-zeppelin-typechain'\nimport { Schema } from '@xyo-network/payload-model'\nimport { Interface, JsonFragment } from 'ethers'\n\nimport { EvmTokenInterfaceImplemented, EvmTokenInterfaceImplementedSchema, TokenInterface } from './Payload'\n\nexport const EvmTokenInterfaceImplementedDivinerConfigSchema = `${EvmTokenInterfaceImplementedSchema}.diviner.config`\nexport type EvmTokenInterfaceImplementedDivinerConfigSchema = typeof EvmTokenInterfaceImplementedDivinerConfigSchema\n\nexport type EvmTokenInterfaceImplementedDivinerConfig = DivinerConfig<{\n schema: EvmTokenInterfaceImplementedDivinerConfigSchema\n tokenInterfaces?: TokenInterface[]\n}>\n\nexport type EvmTokenInterfaceImplementedDivinerParams = DivinerParams<AnyConfigSchema<EvmTokenInterfaceImplementedDivinerConfig>>\n\ntype DistributiveMappedType<T> = T extends string ? { [K in T]: readonly JsonFragment[] } : never\ntype TokenInterfaceDictionary = DistributiveMappedType<TokenInterface>\n\n/**\n * A diviner that checks if a contract implements a token interface\n */\nexport class EvmTokenInterfaceImplementedDiviner<\n TParams extends EvmTokenInterfaceImplementedDivinerParams = EvmTokenInterfaceImplementedDivinerParams,\n> extends AbstractDiviner<TParams, EvmContract, EvmTokenInterfaceImplemented> {\n /**\n * The list of supported token interfaces\n */\n static readonly SupportedTokenInterfaces: Readonly<Record<TokenInterface, readonly JsonFragment[]>> = {\n ERC1155: ERC1155__factory.abi,\n ERC1155Metadata_URI: IERC1155MetadataURI__factory.abi,\n ERC1155TokenReceiver: IERC1155Receiver__factory.abi,\n ERC20: ERC20__factory.abi,\n ERC721: ERC721__factory.abi,\n ERC721Enumerable: IERC721Enumerable__factory.abi,\n ERC721Metadata: IERC721Metadata__factory.abi,\n ERC721TokenReceiver: IERC721Receiver__factory.abi,\n }\n static override readonly configSchemas: Schema[] = [...super.configSchemas, EvmTokenInterfaceImplementedDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = EvmTokenInterfaceImplementedDivinerConfigSchema\n\n private _tokenInterfaces?: TokenInterfaceDictionary\n\n /**\n * The list of token interfaces to check against the contract\n */\n get tokenInterfaces() {\n if (!this._tokenInterfaces) {\n this._tokenInterfaces =\n this.config?.tokenInterfaces ?\n (Object.fromEntries(\n this.config?.tokenInterfaces.map((tokenInterface) => {\n return [tokenInterface, EvmTokenInterfaceImplementedDiviner.SupportedTokenInterfaces[tokenInterface]] as const\n }),\n ) as TokenInterfaceDictionary) ?? {}\n : EvmTokenInterfaceImplementedDiviner.SupportedTokenInterfaces\n }\n return this._tokenInterfaces\n }\n\n protected override async divineHandler(inPayloads: EvmContract[] = []): Promise<EvmTokenInterfaceImplemented[]> {\n await this.started('throw')\n try {\n const allResults = await Promise.all(\n // Iterate over each contract passed in\n inPayloads.filter(isEvmContract).map(({ address, code, chainId }) => {\n // Ensure we have the contract code\n const byteCode = assertEx(code, () => 'Missing code')\n const results: EvmTokenInterfaceImplemented[] = []\n // Iterate over each token interface\n for (const [tokenInterface, abi] of Object.entries(this.tokenInterfaces)) {\n // Check if the contract implements the interface abi\n const contractInterface = new Interface(abi)\n const implementations: boolean[] = []\n contractInterface.forEachFunction(({ selector }) => {\n implementations.push(byteCode.includes(BigInt(selector).toString(16)))\n })\n const implemented = implementations.every(Boolean)\n const result: EvmTokenInterfaceImplemented = {\n address,\n chainId,\n implemented,\n schema: EvmTokenInterfaceImplementedSchema,\n tokenInterface: tokenInterface as TokenInterface,\n }\n results.push(result)\n }\n\n return results\n }),\n )\n return allResults.flat()\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","import { isPayloadOfSchemaType, Payload } from '@xyo-network/payload-model'\n\n/**\n * ERC20 Token Interfaces\n */\nexport type ERC20TokenInterfaces = 'ERC20'\n\n/**\n * ERC721 Token Interfaces\n */\nexport type ERC721TokenInterfaces = 'ERC721' | 'ERC721TokenReceiver' | 'ERC721Metadata' | 'ERC721Enumerable'\n\n/**\n * ERC1155 Token Interfaces\n */\nexport type ERC1155TokenInterfaces = 'ERC1155' | 'ERC1155TokenReceiver' | 'ERC1155Metadata_URI'\n\n/**\n * All Token Interfaces\n */\nexport type TokenInterface = ERC20TokenInterfaces | ERC721TokenInterfaces | ERC1155TokenInterfaces\n\n/**\n * The schema for the EVM Token Interface Implemented payload\n */\nexport const EvmTokenInterfaceImplementedSchema = 'network.xyo.evm.token.interface.implemented'\n/**\n * The schema for the EVM Token Interface Implemented payload\n */\nexport type EvmTokenInterfaceImplementedSchema = typeof EvmTokenInterfaceImplementedSchema\n\n/**\n * The EVM Token Interface Implemented payload\n */\nexport type EvmTokenInterfaceImplemented = Payload<\n {\n /**\n * The contract address\n */\n address: string\n /**\n * The chain id\n */\n chainId: number\n /**\n * True if the contract implements the interface\n */\n implemented: boolean\n /**\n * The specific token interface\n */\n tokenInterface: TokenInterface\n },\n EvmTokenInterfaceImplementedSchema\n>\n\n/**\n * Identity function for EvmTokenInterfaceImplemented payload\n */\nexport const isEvmTokenInterfaceImplemented = isPayloadOfSchemaType<EvmTokenInterfaceImplemented>(EvmTokenInterfaceImplementedSchema)\n"],"mappings":"
|
|
1
|
+
{"version":3,"sources":["../../src/Diviner.ts","../../src/Payload.ts"],"sourcesContent":["import { assertEx } from '@xylabs/assert'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { DivinerConfig, DivinerParams } from '@xyo-network/diviner-model'\nimport { EvmContract, isEvmContract } from '@xyo-network/evm-contract-witness'\nimport { AnyConfigSchema } from '@xyo-network/module-model'\nimport {\n ERC20__factory,\n ERC721__factory,\n ERC1155__factory,\n IERC721Enumerable__factory,\n IERC721Metadata__factory,\n IERC721Receiver__factory,\n IERC1155MetadataURI__factory,\n IERC1155Receiver__factory,\n} from '@xyo-network/open-zeppelin-typechain'\nimport { Schema } from '@xyo-network/payload-model'\nimport { Interface, JsonFragment } from 'ethers'\n\nimport { EvmTokenInterfaceImplemented, EvmTokenInterfaceImplementedSchema, TokenInterface } from './Payload'\n\nexport const EvmTokenInterfaceImplementedDivinerConfigSchema = `${EvmTokenInterfaceImplementedSchema}.diviner.config`\nexport type EvmTokenInterfaceImplementedDivinerConfigSchema = typeof EvmTokenInterfaceImplementedDivinerConfigSchema\n\nexport type EvmTokenInterfaceImplementedDivinerConfig = DivinerConfig<{\n schema: EvmTokenInterfaceImplementedDivinerConfigSchema\n tokenInterfaces?: TokenInterface[]\n}>\n\nexport type EvmTokenInterfaceImplementedDivinerParams = DivinerParams<AnyConfigSchema<EvmTokenInterfaceImplementedDivinerConfig>>\n\ntype DistributiveMappedType<T> = T extends string ? { [K in T]: readonly JsonFragment[] } : never\ntype TokenInterfaceDictionary = DistributiveMappedType<TokenInterface>\n\n/**\n * A diviner that checks if a contract implements a token interface\n */\nexport class EvmTokenInterfaceImplementedDiviner<\n TParams extends EvmTokenInterfaceImplementedDivinerParams = EvmTokenInterfaceImplementedDivinerParams,\n> extends AbstractDiviner<TParams, EvmContract, EvmTokenInterfaceImplemented> {\n /**\n * The list of supported token interfaces\n */\n static readonly SupportedTokenInterfaces: Readonly<Record<TokenInterface, readonly JsonFragment[]>> = {\n ERC1155: ERC1155__factory.abi,\n ERC1155Metadata_URI: IERC1155MetadataURI__factory.abi,\n ERC1155TokenReceiver: IERC1155Receiver__factory.abi,\n ERC20: ERC20__factory.abi,\n ERC721: ERC721__factory.abi,\n ERC721Enumerable: IERC721Enumerable__factory.abi,\n ERC721Metadata: IERC721Metadata__factory.abi,\n ERC721TokenReceiver: IERC721Receiver__factory.abi,\n }\n static override readonly configSchemas: Schema[] = [...super.configSchemas, EvmTokenInterfaceImplementedDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = EvmTokenInterfaceImplementedDivinerConfigSchema\n\n private _tokenInterfaces?: TokenInterfaceDictionary\n\n /**\n * The list of token interfaces to check against the contract\n */\n get tokenInterfaces() {\n if (!this._tokenInterfaces) {\n this._tokenInterfaces =\n this.config?.tokenInterfaces ?\n (Object.fromEntries(\n this.config?.tokenInterfaces.map((tokenInterface) => {\n return [tokenInterface, EvmTokenInterfaceImplementedDiviner.SupportedTokenInterfaces[tokenInterface]] as const\n }),\n ) as TokenInterfaceDictionary) ?? {}\n : EvmTokenInterfaceImplementedDiviner.SupportedTokenInterfaces\n }\n return this._tokenInterfaces\n }\n\n protected override async divineHandler(inPayloads: EvmContract[] = []): Promise<EvmTokenInterfaceImplemented[]> {\n await this.started('throw')\n try {\n const allResults = await Promise.all(\n // Iterate over each contract passed in\n inPayloads.filter(isEvmContract).map(({ address, code, chainId }) => {\n // Ensure we have the contract code\n const byteCode = assertEx(code, () => 'Missing code')\n const results: EvmTokenInterfaceImplemented[] = []\n // Iterate over each token interface\n for (const [tokenInterface, abi] of Object.entries(this.tokenInterfaces)) {\n // Check if the contract implements the interface abi\n const contractInterface = new Interface(abi)\n const implementations: boolean[] = []\n contractInterface.forEachFunction(({ selector }) => {\n implementations.push(byteCode.includes(BigInt(selector).toString(16)))\n })\n const implemented = implementations.every(Boolean)\n const result: EvmTokenInterfaceImplemented = {\n address,\n chainId,\n implemented,\n schema: EvmTokenInterfaceImplementedSchema,\n tokenInterface: tokenInterface as TokenInterface,\n }\n results.push(result)\n }\n\n return results\n }),\n )\n return allResults.flat()\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","import { isPayloadOfSchemaType, Payload } from '@xyo-network/payload-model'\n\n/**\n * ERC20 Token Interfaces\n */\nexport type ERC20TokenInterfaces = 'ERC20'\n\n/**\n * ERC721 Token Interfaces\n */\nexport type ERC721TokenInterfaces = 'ERC721' | 'ERC721TokenReceiver' | 'ERC721Metadata' | 'ERC721Enumerable'\n\n/**\n * ERC1155 Token Interfaces\n */\nexport type ERC1155TokenInterfaces = 'ERC1155' | 'ERC1155TokenReceiver' | 'ERC1155Metadata_URI'\n\n/**\n * All Token Interfaces\n */\nexport type TokenInterface = ERC20TokenInterfaces | ERC721TokenInterfaces | ERC1155TokenInterfaces\n\n/**\n * The schema for the EVM Token Interface Implemented payload\n */\nexport const EvmTokenInterfaceImplementedSchema = 'network.xyo.evm.token.interface.implemented'\n/**\n * The schema for the EVM Token Interface Implemented payload\n */\nexport type EvmTokenInterfaceImplementedSchema = typeof EvmTokenInterfaceImplementedSchema\n\n/**\n * The EVM Token Interface Implemented payload\n */\nexport type EvmTokenInterfaceImplemented = Payload<\n {\n /**\n * The contract address\n */\n address: string\n /**\n * The chain id\n */\n chainId: number\n /**\n * True if the contract implements the interface\n */\n implemented: boolean\n /**\n * The specific token interface\n */\n tokenInterface: TokenInterface\n },\n EvmTokenInterfaceImplementedSchema\n>\n\n/**\n * Identity function for EvmTokenInterfaceImplemented payload\n */\nexport const isEvmTokenInterfaceImplemented = isPayloadOfSchemaType<EvmTokenInterfaceImplemented>(EvmTokenInterfaceImplementedSchema)\n"],"mappings":"AAAA,OAAS,YAAAA,MAAgB,iBACzB,OAAS,mBAAAC,MAAuB,gCAEhC,OAAsB,iBAAAC,MAAqB,oCAE3C,OACE,kBAAAC,EACA,mBAAAC,EACA,oBAAAC,EACA,8BAAAC,EACA,4BAAAC,EACA,4BAAAC,EACA,gCAAAC,EACA,6BAAAC,MACK,uCAEP,OAAS,aAAAC,MAA+B,SChBxC,OAAS,yBAAAC,MAAsC,6BAyBxC,IAAMC,EAAqC,8CAkCrCC,EAAiCF,EAAoDC,CAAkC,EDvC7H,IAAME,EAAkD,GAAGC,CAAkC,kBAgBvFC,EAAN,MAAMC,UAEHC,CAAoE,CAI5E,OAAgB,yBAAsF,CACpG,QAASC,EAAiB,IAC1B,oBAAqBC,EAA6B,IAClD,qBAAsBC,EAA0B,IAChD,MAAOC,EAAe,IACtB,OAAQC,EAAgB,IACxB,iBAAkBC,EAA2B,IAC7C,eAAgBC,EAAyB,IACzC,oBAAqBC,EAAyB,GAChD,EACA,OAAyB,cAA0B,CAAC,GAAG,MAAM,cAAeZ,CAA+C,EAC3H,OAAyB,oBAA8BA,EAE/C,iBAKR,IAAI,iBAAkB,CACpB,OAAK,KAAK,mBACR,KAAK,iBACH,KAAK,QAAQ,gBACV,OAAO,YACN,KAAK,QAAQ,gBAAgB,IAAKa,GACzB,CAACA,EAAgBV,EAAoC,yBAAyBU,CAAc,CAAC,CACrG,CACH,GAAkC,CAAC,EACnCV,EAAoC,0BAEnC,KAAK,gBACd,CAEA,MAAyB,cAAcW,EAA4B,CAAC,EAA4C,CAC9G,MAAM,KAAK,QAAQ,OAAO,EAC1B,GAAI,CA6BF,OA5BmB,MAAM,QAAQ,IAE/BA,EAAW,OAAOC,CAAa,EAAE,IAAI,CAAC,CAAE,QAAAC,EAAS,KAAAC,EAAM,QAAAC,CAAQ,IAAM,CAEnE,IAAMC,EAAWC,EAASH,EAAM,IAAM,cAAc,EAC9CI,EAA0C,CAAC,EAEjD,OAAW,CAACR,EAAgBS,CAAG,IAAK,OAAO,QAAQ,KAAK,eAAe,EAAG,CAExE,IAAMC,EAAoB,IAAIC,EAAUF,CAAG,EACrCG,EAA6B,CAAC,EACpCF,EAAkB,gBAAgB,CAAC,CAAE,SAAAG,CAAS,IAAM,CAClDD,EAAgB,KAAKN,EAAS,SAAS,OAAOO,CAAQ,EAAE,SAAS,EAAE,CAAC,CAAC,CACvE,CAAC,EACD,IAAMC,EAAcF,EAAgB,MAAM,OAAO,EAC3CG,EAAuC,CAC3C,QAAAZ,EACA,QAAAE,EACA,YAAAS,EACA,OAAQ1B,EACR,eAAgBY,CAClB,EACAQ,EAAQ,KAAKO,CAAM,CACrB,CAEA,OAAOP,CACT,CAAC,CACH,GACkB,KAAK,CACzB,OAASQ,EAAI,CACX,IAAMC,EAAQD,EACd,cAAQ,IAAI,UAAU,KAAK,OAAO,IAAI,MAAMC,EAAM,OAAO,EAAE,EACrDA,CACR,CACF,CACF","names":["assertEx","AbstractDiviner","isEvmContract","ERC20__factory","ERC721__factory","ERC1155__factory","IERC721Enumerable__factory","IERC721Metadata__factory","IERC721Receiver__factory","IERC1155MetadataURI__factory","IERC1155Receiver__factory","Interface","isPayloadOfSchemaType","EvmTokenInterfaceImplementedSchema","isEvmTokenInterfaceImplemented","EvmTokenInterfaceImplementedDivinerConfigSchema","EvmTokenInterfaceImplementedSchema","EvmTokenInterfaceImplementedDiviner","_EvmTokenInterfaceImplementedDiviner","AbstractDiviner","ERC1155__factory","IERC1155MetadataURI__factory","IERC1155Receiver__factory","ERC20__factory","ERC721__factory","IERC721Enumerable__factory","IERC721Metadata__factory","IERC721Receiver__factory","tokenInterface","inPayloads","isEvmContract","address","code","chainId","byteCode","assertEx","results","abi","contractInterface","Interface","implementations","selector","implemented","result","ex","error"]}
|
|
@@ -16,20 +16,11 @@ type DistributiveMappedType<T> = T extends string ? {
|
|
|
16
16
|
[K in T]: readonly JsonFragment[];
|
|
17
17
|
} : never;
|
|
18
18
|
type TokenInterfaceDictionary = DistributiveMappedType<TokenInterface>;
|
|
19
|
-
/**
|
|
20
|
-
* A diviner that checks if a contract implements a token interface
|
|
21
|
-
*/
|
|
22
19
|
export declare class EvmTokenInterfaceImplementedDiviner<TParams extends EvmTokenInterfaceImplementedDivinerParams = EvmTokenInterfaceImplementedDivinerParams> extends AbstractDiviner<TParams, EvmContract, EvmTokenInterfaceImplemented> {
|
|
23
|
-
/**
|
|
24
|
-
* The list of supported token interfaces
|
|
25
|
-
*/
|
|
26
20
|
static readonly SupportedTokenInterfaces: Readonly<Record<TokenInterface, readonly JsonFragment[]>>;
|
|
27
21
|
static readonly configSchemas: Schema[];
|
|
28
22
|
static readonly defaultConfigSchema: Schema;
|
|
29
23
|
private _tokenInterfaces?;
|
|
30
|
-
/**
|
|
31
|
-
* The list of token interfaces to check against the contract
|
|
32
|
-
*/
|
|
33
24
|
get tokenInterfaces(): TokenInterfaceDictionary;
|
|
34
25
|
protected divineHandler(inPayloads?: EvmContract[]): Promise<EvmTokenInterfaceImplemented[]>;
|
|
35
26
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Diviner.d.ts","sourceRoot":"","sources":["../../src/Diviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AACzE,OAAO,EAAE,WAAW,EAAiB,MAAM,mCAAmC,CAAA;AAC9E,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAW3D,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AACnD,OAAO,EAAa,YAAY,EAAE,MAAM,QAAQ,CAAA;AAEhD,OAAO,EAAE,4BAA4B,EAAsC,cAAc,EAAE,MAAM,WAAW,CAAA;AAE5G,eAAO,MAAM,+CAA+C,+DAAyD,CAAA;AACrH,MAAM,MAAM,+CAA+C,GAAG,OAAO,+CAA+C,CAAA;AAEpH,MAAM,MAAM,yCAAyC,GAAG,aAAa,CAAC;IACpE,MAAM,EAAE,+CAA+C,CAAA;IACvD,eAAe,CAAC,EAAE,cAAc,EAAE,CAAA;CACnC,CAAC,CAAA;AAEF,MAAM,MAAM,yCAAyC,GAAG,aAAa,CAAC,eAAe,CAAC,yCAAyC,CAAC,CAAC,CAAA;AAEjI,KAAK,sBAAsB,CAAC,CAAC,IAAI,CAAC,SAAS,MAAM,GAAG;KAAG,CAAC,IAAI,CAAC,GAAG,SAAS,YAAY,EAAE;CAAE,GAAG,KAAK,CAAA;AACjG,KAAK,wBAAwB,GAAG,sBAAsB,CAAC,cAAc,CAAC,CAAA;
|
|
1
|
+
{"version":3,"file":"Diviner.d.ts","sourceRoot":"","sources":["../../src/Diviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AACzE,OAAO,EAAE,WAAW,EAAiB,MAAM,mCAAmC,CAAA;AAC9E,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAW3D,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AACnD,OAAO,EAAa,YAAY,EAAE,MAAM,QAAQ,CAAA;AAEhD,OAAO,EAAE,4BAA4B,EAAsC,cAAc,EAAE,MAAM,WAAW,CAAA;AAE5G,eAAO,MAAM,+CAA+C,+DAAyD,CAAA;AACrH,MAAM,MAAM,+CAA+C,GAAG,OAAO,+CAA+C,CAAA;AAEpH,MAAM,MAAM,yCAAyC,GAAG,aAAa,CAAC;IACpE,MAAM,EAAE,+CAA+C,CAAA;IACvD,eAAe,CAAC,EAAE,cAAc,EAAE,CAAA;CACnC,CAAC,CAAA;AAEF,MAAM,MAAM,yCAAyC,GAAG,aAAa,CAAC,eAAe,CAAC,yCAAyC,CAAC,CAAC,CAAA;AAEjI,KAAK,sBAAsB,CAAC,CAAC,IAAI,CAAC,SAAS,MAAM,GAAG;KAAG,CAAC,IAAI,CAAC,GAAG,SAAS,YAAY,EAAE;CAAE,GAAG,KAAK,CAAA;AACjG,KAAK,wBAAwB,GAAG,sBAAsB,CAAC,cAAc,CAAC,CAAA;AAKtE,qBAAa,mCAAmC,CAC9C,OAAO,SAAS,yCAAyC,GAAG,yCAAyC,CACrG,SAAQ,eAAe,CAAC,OAAO,EAAE,WAAW,EAAE,4BAA4B,CAAC;IAI3E,MAAM,CAAC,QAAQ,CAAC,wBAAwB,EAAE,QAAQ,CAAC,MAAM,CAAC,cAAc,EAAE,SAAS,YAAY,EAAE,CAAC,CAAC,CASlG;IACD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAA4E;IAC5H,gBAAyB,mBAAmB,EAAE,MAAM,CAAkD;IAEtG,OAAO,CAAC,gBAAgB,CAAC,CAA0B;IAKnD,IAAI,eAAe,6BAYlB;cAEwB,aAAa,CAAC,UAAU,GAAE,WAAW,EAAO,GAAG,OAAO,CAAC,4BAA4B,EAAE,CAAC;CAsChH"}
|
|
@@ -16,20 +16,11 @@ type DistributiveMappedType<T> = T extends string ? {
|
|
|
16
16
|
[K in T]: readonly JsonFragment[];
|
|
17
17
|
} : never;
|
|
18
18
|
type TokenInterfaceDictionary = DistributiveMappedType<TokenInterface>;
|
|
19
|
-
/**
|
|
20
|
-
* A diviner that checks if a contract implements a token interface
|
|
21
|
-
*/
|
|
22
19
|
export declare class EvmTokenInterfaceImplementedDiviner<TParams extends EvmTokenInterfaceImplementedDivinerParams = EvmTokenInterfaceImplementedDivinerParams> extends AbstractDiviner<TParams, EvmContract, EvmTokenInterfaceImplemented> {
|
|
23
|
-
/**
|
|
24
|
-
* The list of supported token interfaces
|
|
25
|
-
*/
|
|
26
20
|
static readonly SupportedTokenInterfaces: Readonly<Record<TokenInterface, readonly JsonFragment[]>>;
|
|
27
21
|
static readonly configSchemas: Schema[];
|
|
28
22
|
static readonly defaultConfigSchema: Schema;
|
|
29
23
|
private _tokenInterfaces?;
|
|
30
|
-
/**
|
|
31
|
-
* The list of token interfaces to check against the contract
|
|
32
|
-
*/
|
|
33
24
|
get tokenInterfaces(): TokenInterfaceDictionary;
|
|
34
25
|
protected divineHandler(inPayloads?: EvmContract[]): Promise<EvmTokenInterfaceImplemented[]>;
|
|
35
26
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Diviner.d.ts","sourceRoot":"","sources":["../../src/Diviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AACzE,OAAO,EAAE,WAAW,EAAiB,MAAM,mCAAmC,CAAA;AAC9E,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAW3D,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AACnD,OAAO,EAAa,YAAY,EAAE,MAAM,QAAQ,CAAA;AAEhD,OAAO,EAAE,4BAA4B,EAAsC,cAAc,EAAE,MAAM,WAAW,CAAA;AAE5G,eAAO,MAAM,+CAA+C,+DAAyD,CAAA;AACrH,MAAM,MAAM,+CAA+C,GAAG,OAAO,+CAA+C,CAAA;AAEpH,MAAM,MAAM,yCAAyC,GAAG,aAAa,CAAC;IACpE,MAAM,EAAE,+CAA+C,CAAA;IACvD,eAAe,CAAC,EAAE,cAAc,EAAE,CAAA;CACnC,CAAC,CAAA;AAEF,MAAM,MAAM,yCAAyC,GAAG,aAAa,CAAC,eAAe,CAAC,yCAAyC,CAAC,CAAC,CAAA;AAEjI,KAAK,sBAAsB,CAAC,CAAC,IAAI,CAAC,SAAS,MAAM,GAAG;KAAG,CAAC,IAAI,CAAC,GAAG,SAAS,YAAY,EAAE;CAAE,GAAG,KAAK,CAAA;AACjG,KAAK,wBAAwB,GAAG,sBAAsB,CAAC,cAAc,CAAC,CAAA;
|
|
1
|
+
{"version":3,"file":"Diviner.d.ts","sourceRoot":"","sources":["../../src/Diviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AACzE,OAAO,EAAE,WAAW,EAAiB,MAAM,mCAAmC,CAAA;AAC9E,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAW3D,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AACnD,OAAO,EAAa,YAAY,EAAE,MAAM,QAAQ,CAAA;AAEhD,OAAO,EAAE,4BAA4B,EAAsC,cAAc,EAAE,MAAM,WAAW,CAAA;AAE5G,eAAO,MAAM,+CAA+C,+DAAyD,CAAA;AACrH,MAAM,MAAM,+CAA+C,GAAG,OAAO,+CAA+C,CAAA;AAEpH,MAAM,MAAM,yCAAyC,GAAG,aAAa,CAAC;IACpE,MAAM,EAAE,+CAA+C,CAAA;IACvD,eAAe,CAAC,EAAE,cAAc,EAAE,CAAA;CACnC,CAAC,CAAA;AAEF,MAAM,MAAM,yCAAyC,GAAG,aAAa,CAAC,eAAe,CAAC,yCAAyC,CAAC,CAAC,CAAA;AAEjI,KAAK,sBAAsB,CAAC,CAAC,IAAI,CAAC,SAAS,MAAM,GAAG;KAAG,CAAC,IAAI,CAAC,GAAG,SAAS,YAAY,EAAE;CAAE,GAAG,KAAK,CAAA;AACjG,KAAK,wBAAwB,GAAG,sBAAsB,CAAC,cAAc,CAAC,CAAA;AAKtE,qBAAa,mCAAmC,CAC9C,OAAO,SAAS,yCAAyC,GAAG,yCAAyC,CACrG,SAAQ,eAAe,CAAC,OAAO,EAAE,WAAW,EAAE,4BAA4B,CAAC;IAI3E,MAAM,CAAC,QAAQ,CAAC,wBAAwB,EAAE,QAAQ,CAAC,MAAM,CAAC,cAAc,EAAE,SAAS,YAAY,EAAE,CAAC,CAAC,CASlG;IACD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAA4E;IAC5H,gBAAyB,mBAAmB,EAAE,MAAM,CAAkD;IAEtG,OAAO,CAAC,gBAAgB,CAAC,CAA0B;IAKnD,IAAI,eAAe,6BAYlB;cAEwB,aAAa,CAAC,UAAU,GAAE,WAAW,EAAO,GAAG,OAAO,CAAC,4BAA4B,EAAE,CAAC;CAsChH"}
|
|
@@ -16,20 +16,11 @@ type DistributiveMappedType<T> = T extends string ? {
|
|
|
16
16
|
[K in T]: readonly JsonFragment[];
|
|
17
17
|
} : never;
|
|
18
18
|
type TokenInterfaceDictionary = DistributiveMappedType<TokenInterface>;
|
|
19
|
-
/**
|
|
20
|
-
* A diviner that checks if a contract implements a token interface
|
|
21
|
-
*/
|
|
22
19
|
export declare class EvmTokenInterfaceImplementedDiviner<TParams extends EvmTokenInterfaceImplementedDivinerParams = EvmTokenInterfaceImplementedDivinerParams> extends AbstractDiviner<TParams, EvmContract, EvmTokenInterfaceImplemented> {
|
|
23
|
-
/**
|
|
24
|
-
* The list of supported token interfaces
|
|
25
|
-
*/
|
|
26
20
|
static readonly SupportedTokenInterfaces: Readonly<Record<TokenInterface, readonly JsonFragment[]>>;
|
|
27
21
|
static readonly configSchemas: Schema[];
|
|
28
22
|
static readonly defaultConfigSchema: Schema;
|
|
29
23
|
private _tokenInterfaces?;
|
|
30
|
-
/**
|
|
31
|
-
* The list of token interfaces to check against the contract
|
|
32
|
-
*/
|
|
33
24
|
get tokenInterfaces(): TokenInterfaceDictionary;
|
|
34
25
|
protected divineHandler(inPayloads?: EvmContract[]): Promise<EvmTokenInterfaceImplemented[]>;
|
|
35
26
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Diviner.d.ts","sourceRoot":"","sources":["../../src/Diviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AACzE,OAAO,EAAE,WAAW,EAAiB,MAAM,mCAAmC,CAAA;AAC9E,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAW3D,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AACnD,OAAO,EAAa,YAAY,EAAE,MAAM,QAAQ,CAAA;AAEhD,OAAO,EAAE,4BAA4B,EAAsC,cAAc,EAAE,MAAM,WAAW,CAAA;AAE5G,eAAO,MAAM,+CAA+C,+DAAyD,CAAA;AACrH,MAAM,MAAM,+CAA+C,GAAG,OAAO,+CAA+C,CAAA;AAEpH,MAAM,MAAM,yCAAyC,GAAG,aAAa,CAAC;IACpE,MAAM,EAAE,+CAA+C,CAAA;IACvD,eAAe,CAAC,EAAE,cAAc,EAAE,CAAA;CACnC,CAAC,CAAA;AAEF,MAAM,MAAM,yCAAyC,GAAG,aAAa,CAAC,eAAe,CAAC,yCAAyC,CAAC,CAAC,CAAA;AAEjI,KAAK,sBAAsB,CAAC,CAAC,IAAI,CAAC,SAAS,MAAM,GAAG;KAAG,CAAC,IAAI,CAAC,GAAG,SAAS,YAAY,EAAE;CAAE,GAAG,KAAK,CAAA;AACjG,KAAK,wBAAwB,GAAG,sBAAsB,CAAC,cAAc,CAAC,CAAA;
|
|
1
|
+
{"version":3,"file":"Diviner.d.ts","sourceRoot":"","sources":["../../src/Diviner.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AACzE,OAAO,EAAE,WAAW,EAAiB,MAAM,mCAAmC,CAAA;AAC9E,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAW3D,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AACnD,OAAO,EAAa,YAAY,EAAE,MAAM,QAAQ,CAAA;AAEhD,OAAO,EAAE,4BAA4B,EAAsC,cAAc,EAAE,MAAM,WAAW,CAAA;AAE5G,eAAO,MAAM,+CAA+C,+DAAyD,CAAA;AACrH,MAAM,MAAM,+CAA+C,GAAG,OAAO,+CAA+C,CAAA;AAEpH,MAAM,MAAM,yCAAyC,GAAG,aAAa,CAAC;IACpE,MAAM,EAAE,+CAA+C,CAAA;IACvD,eAAe,CAAC,EAAE,cAAc,EAAE,CAAA;CACnC,CAAC,CAAA;AAEF,MAAM,MAAM,yCAAyC,GAAG,aAAa,CAAC,eAAe,CAAC,yCAAyC,CAAC,CAAC,CAAA;AAEjI,KAAK,sBAAsB,CAAC,CAAC,IAAI,CAAC,SAAS,MAAM,GAAG;KAAG,CAAC,IAAI,CAAC,GAAG,SAAS,YAAY,EAAE;CAAE,GAAG,KAAK,CAAA;AACjG,KAAK,wBAAwB,GAAG,sBAAsB,CAAC,cAAc,CAAC,CAAA;AAKtE,qBAAa,mCAAmC,CAC9C,OAAO,SAAS,yCAAyC,GAAG,yCAAyC,CACrG,SAAQ,eAAe,CAAC,OAAO,EAAE,WAAW,EAAE,4BAA4B,CAAC;IAI3E,MAAM,CAAC,QAAQ,CAAC,wBAAwB,EAAE,QAAQ,CAAC,MAAM,CAAC,cAAc,EAAE,SAAS,YAAY,EAAE,CAAC,CAAC,CASlG;IACD,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAA4E;IAC5H,gBAAyB,mBAAmB,EAAE,MAAM,CAAkD;IAEtG,OAAO,CAAC,gBAAgB,CAAC,CAA0B;IAKnD,IAAI,eAAe,6BAYlB;cAEwB,aAAa,CAAC,UAAU,GAAE,WAAW,EAAO,GAAG,OAAO,CAAC,4BAA4B,EAAE,CAAC;CAsChH"}
|
|
@@ -1,68 +1,20 @@
|
|
|
1
1
|
import { Payload } from '@xyo-network/payload-model';
|
|
2
|
-
/**
|
|
3
|
-
* ERC20 Token Interfaces
|
|
4
|
-
*/
|
|
5
2
|
export type ERC20TokenInterfaces = 'ERC20';
|
|
6
|
-
/**
|
|
7
|
-
* ERC721 Token Interfaces
|
|
8
|
-
*/
|
|
9
3
|
export type ERC721TokenInterfaces = 'ERC721' | 'ERC721TokenReceiver' | 'ERC721Metadata' | 'ERC721Enumerable';
|
|
10
|
-
/**
|
|
11
|
-
* ERC1155 Token Interfaces
|
|
12
|
-
*/
|
|
13
4
|
export type ERC1155TokenInterfaces = 'ERC1155' | 'ERC1155TokenReceiver' | 'ERC1155Metadata_URI';
|
|
14
|
-
/**
|
|
15
|
-
* All Token Interfaces
|
|
16
|
-
*/
|
|
17
5
|
export type TokenInterface = ERC20TokenInterfaces | ERC721TokenInterfaces | ERC1155TokenInterfaces;
|
|
18
|
-
/**
|
|
19
|
-
* The schema for the EVM Token Interface Implemented payload
|
|
20
|
-
*/
|
|
21
6
|
export declare const EvmTokenInterfaceImplementedSchema = "network.xyo.evm.token.interface.implemented";
|
|
22
|
-
/**
|
|
23
|
-
* The schema for the EVM Token Interface Implemented payload
|
|
24
|
-
*/
|
|
25
7
|
export type EvmTokenInterfaceImplementedSchema = typeof EvmTokenInterfaceImplementedSchema;
|
|
26
|
-
/**
|
|
27
|
-
* The EVM Token Interface Implemented payload
|
|
28
|
-
*/
|
|
29
8
|
export type EvmTokenInterfaceImplemented = Payload<{
|
|
30
|
-
/**
|
|
31
|
-
* The contract address
|
|
32
|
-
*/
|
|
33
9
|
address: string;
|
|
34
|
-
/**
|
|
35
|
-
* The chain id
|
|
36
|
-
*/
|
|
37
10
|
chainId: number;
|
|
38
|
-
/**
|
|
39
|
-
* True if the contract implements the interface
|
|
40
|
-
*/
|
|
41
11
|
implemented: boolean;
|
|
42
|
-
/**
|
|
43
|
-
* The specific token interface
|
|
44
|
-
*/
|
|
45
12
|
tokenInterface: TokenInterface;
|
|
46
13
|
}, EvmTokenInterfaceImplementedSchema>;
|
|
47
|
-
|
|
48
|
-
* Identity function for EvmTokenInterfaceImplemented payload
|
|
49
|
-
*/
|
|
50
|
-
export declare const isEvmTokenInterfaceImplemented: (x?: unknown) => x is import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
51
|
-
/**
|
|
52
|
-
* The contract address
|
|
53
|
-
*/
|
|
14
|
+
export declare const isEvmTokenInterfaceImplemented: (x?: unknown | null) => x is import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
54
15
|
address: string;
|
|
55
|
-
/**
|
|
56
|
-
* The chain id
|
|
57
|
-
*/
|
|
58
16
|
chainId: number;
|
|
59
|
-
/**
|
|
60
|
-
* True if the contract implements the interface
|
|
61
|
-
*/
|
|
62
17
|
implemented: boolean;
|
|
63
|
-
/**
|
|
64
|
-
* The specific token interface
|
|
65
|
-
*/
|
|
66
18
|
tokenInterface: TokenInterface;
|
|
67
19
|
} & {
|
|
68
20
|
schema: "network.xyo.evm.token.interface.implemented";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Payload.d.ts","sourceRoot":"","sources":["../../src/Payload.ts"],"names":[],"mappings":"AAAA,OAAO,EAAyB,OAAO,EAAE,MAAM,4BAA4B,CAAA;
|
|
1
|
+
{"version":3,"file":"Payload.d.ts","sourceRoot":"","sources":["../../src/Payload.ts"],"names":[],"mappings":"AAAA,OAAO,EAAyB,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAK3E,MAAM,MAAM,oBAAoB,GAAG,OAAO,CAAA;AAK1C,MAAM,MAAM,qBAAqB,GAAG,QAAQ,GAAG,qBAAqB,GAAG,gBAAgB,GAAG,kBAAkB,CAAA;AAK5G,MAAM,MAAM,sBAAsB,GAAG,SAAS,GAAG,sBAAsB,GAAG,qBAAqB,CAAA;AAK/F,MAAM,MAAM,cAAc,GAAG,oBAAoB,GAAG,qBAAqB,GAAG,sBAAsB,CAAA;AAKlG,eAAO,MAAM,kCAAkC,gDAAgD,CAAA;AAI/F,MAAM,MAAM,kCAAkC,GAAG,OAAO,kCAAkC,CAAA;AAK1F,MAAM,MAAM,4BAA4B,GAAG,OAAO,CAChD;IAIE,OAAO,EAAE,MAAM,CAAA;IAIf,OAAO,EAAE,MAAM,CAAA;IAIf,WAAW,EAAE,OAAO,CAAA;IAIpB,cAAc,EAAE,cAAc,CAAA;CAC/B,EACD,kCAAkC,CACnC,CAAA;AAKD,eAAO,MAAM,8BAA8B;aApB9B,MAAM;aAIN,MAAM;iBAIF,OAAO;oBAIJ,cAAc;;;CAQmG,CAAA"}
|
|
@@ -1,68 +1,20 @@
|
|
|
1
1
|
import { Payload } from '@xyo-network/payload-model';
|
|
2
|
-
/**
|
|
3
|
-
* ERC20 Token Interfaces
|
|
4
|
-
*/
|
|
5
2
|
export type ERC20TokenInterfaces = 'ERC20';
|
|
6
|
-
/**
|
|
7
|
-
* ERC721 Token Interfaces
|
|
8
|
-
*/
|
|
9
3
|
export type ERC721TokenInterfaces = 'ERC721' | 'ERC721TokenReceiver' | 'ERC721Metadata' | 'ERC721Enumerable';
|
|
10
|
-
/**
|
|
11
|
-
* ERC1155 Token Interfaces
|
|
12
|
-
*/
|
|
13
4
|
export type ERC1155TokenInterfaces = 'ERC1155' | 'ERC1155TokenReceiver' | 'ERC1155Metadata_URI';
|
|
14
|
-
/**
|
|
15
|
-
* All Token Interfaces
|
|
16
|
-
*/
|
|
17
5
|
export type TokenInterface = ERC20TokenInterfaces | ERC721TokenInterfaces | ERC1155TokenInterfaces;
|
|
18
|
-
/**
|
|
19
|
-
* The schema for the EVM Token Interface Implemented payload
|
|
20
|
-
*/
|
|
21
6
|
export declare const EvmTokenInterfaceImplementedSchema = "network.xyo.evm.token.interface.implemented";
|
|
22
|
-
/**
|
|
23
|
-
* The schema for the EVM Token Interface Implemented payload
|
|
24
|
-
*/
|
|
25
7
|
export type EvmTokenInterfaceImplementedSchema = typeof EvmTokenInterfaceImplementedSchema;
|
|
26
|
-
/**
|
|
27
|
-
* The EVM Token Interface Implemented payload
|
|
28
|
-
*/
|
|
29
8
|
export type EvmTokenInterfaceImplemented = Payload<{
|
|
30
|
-
/**
|
|
31
|
-
* The contract address
|
|
32
|
-
*/
|
|
33
9
|
address: string;
|
|
34
|
-
/**
|
|
35
|
-
* The chain id
|
|
36
|
-
*/
|
|
37
10
|
chainId: number;
|
|
38
|
-
/**
|
|
39
|
-
* True if the contract implements the interface
|
|
40
|
-
*/
|
|
41
11
|
implemented: boolean;
|
|
42
|
-
/**
|
|
43
|
-
* The specific token interface
|
|
44
|
-
*/
|
|
45
12
|
tokenInterface: TokenInterface;
|
|
46
13
|
}, EvmTokenInterfaceImplementedSchema>;
|
|
47
|
-
|
|
48
|
-
* Identity function for EvmTokenInterfaceImplemented payload
|
|
49
|
-
*/
|
|
50
|
-
export declare const isEvmTokenInterfaceImplemented: (x?: unknown) => x is import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
51
|
-
/**
|
|
52
|
-
* The contract address
|
|
53
|
-
*/
|
|
14
|
+
export declare const isEvmTokenInterfaceImplemented: (x?: unknown | null) => x is import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
54
15
|
address: string;
|
|
55
|
-
/**
|
|
56
|
-
* The chain id
|
|
57
|
-
*/
|
|
58
16
|
chainId: number;
|
|
59
|
-
/**
|
|
60
|
-
* True if the contract implements the interface
|
|
61
|
-
*/
|
|
62
17
|
implemented: boolean;
|
|
63
|
-
/**
|
|
64
|
-
* The specific token interface
|
|
65
|
-
*/
|
|
66
18
|
tokenInterface: TokenInterface;
|
|
67
19
|
} & {
|
|
68
20
|
schema: "network.xyo.evm.token.interface.implemented";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Payload.d.ts","sourceRoot":"","sources":["../../src/Payload.ts"],"names":[],"mappings":"AAAA,OAAO,EAAyB,OAAO,EAAE,MAAM,4BAA4B,CAAA;
|
|
1
|
+
{"version":3,"file":"Payload.d.ts","sourceRoot":"","sources":["../../src/Payload.ts"],"names":[],"mappings":"AAAA,OAAO,EAAyB,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAK3E,MAAM,MAAM,oBAAoB,GAAG,OAAO,CAAA;AAK1C,MAAM,MAAM,qBAAqB,GAAG,QAAQ,GAAG,qBAAqB,GAAG,gBAAgB,GAAG,kBAAkB,CAAA;AAK5G,MAAM,MAAM,sBAAsB,GAAG,SAAS,GAAG,sBAAsB,GAAG,qBAAqB,CAAA;AAK/F,MAAM,MAAM,cAAc,GAAG,oBAAoB,GAAG,qBAAqB,GAAG,sBAAsB,CAAA;AAKlG,eAAO,MAAM,kCAAkC,gDAAgD,CAAA;AAI/F,MAAM,MAAM,kCAAkC,GAAG,OAAO,kCAAkC,CAAA;AAK1F,MAAM,MAAM,4BAA4B,GAAG,OAAO,CAChD;IAIE,OAAO,EAAE,MAAM,CAAA;IAIf,OAAO,EAAE,MAAM,CAAA;IAIf,WAAW,EAAE,OAAO,CAAA;IAIpB,cAAc,EAAE,cAAc,CAAA;CAC/B,EACD,kCAAkC,CACnC,CAAA;AAKD,eAAO,MAAM,8BAA8B;aApB9B,MAAM;aAIN,MAAM;iBAIF,OAAO;oBAIJ,cAAc;;;CAQmG,CAAA"}
|
|
@@ -1,68 +1,20 @@
|
|
|
1
1
|
import { Payload } from '@xyo-network/payload-model';
|
|
2
|
-
/**
|
|
3
|
-
* ERC20 Token Interfaces
|
|
4
|
-
*/
|
|
5
2
|
export type ERC20TokenInterfaces = 'ERC20';
|
|
6
|
-
/**
|
|
7
|
-
* ERC721 Token Interfaces
|
|
8
|
-
*/
|
|
9
3
|
export type ERC721TokenInterfaces = 'ERC721' | 'ERC721TokenReceiver' | 'ERC721Metadata' | 'ERC721Enumerable';
|
|
10
|
-
/**
|
|
11
|
-
* ERC1155 Token Interfaces
|
|
12
|
-
*/
|
|
13
4
|
export type ERC1155TokenInterfaces = 'ERC1155' | 'ERC1155TokenReceiver' | 'ERC1155Metadata_URI';
|
|
14
|
-
/**
|
|
15
|
-
* All Token Interfaces
|
|
16
|
-
*/
|
|
17
5
|
export type TokenInterface = ERC20TokenInterfaces | ERC721TokenInterfaces | ERC1155TokenInterfaces;
|
|
18
|
-
/**
|
|
19
|
-
* The schema for the EVM Token Interface Implemented payload
|
|
20
|
-
*/
|
|
21
6
|
export declare const EvmTokenInterfaceImplementedSchema = "network.xyo.evm.token.interface.implemented";
|
|
22
|
-
/**
|
|
23
|
-
* The schema for the EVM Token Interface Implemented payload
|
|
24
|
-
*/
|
|
25
7
|
export type EvmTokenInterfaceImplementedSchema = typeof EvmTokenInterfaceImplementedSchema;
|
|
26
|
-
/**
|
|
27
|
-
* The EVM Token Interface Implemented payload
|
|
28
|
-
*/
|
|
29
8
|
export type EvmTokenInterfaceImplemented = Payload<{
|
|
30
|
-
/**
|
|
31
|
-
* The contract address
|
|
32
|
-
*/
|
|
33
9
|
address: string;
|
|
34
|
-
/**
|
|
35
|
-
* The chain id
|
|
36
|
-
*/
|
|
37
10
|
chainId: number;
|
|
38
|
-
/**
|
|
39
|
-
* True if the contract implements the interface
|
|
40
|
-
*/
|
|
41
11
|
implemented: boolean;
|
|
42
|
-
/**
|
|
43
|
-
* The specific token interface
|
|
44
|
-
*/
|
|
45
12
|
tokenInterface: TokenInterface;
|
|
46
13
|
}, EvmTokenInterfaceImplementedSchema>;
|
|
47
|
-
|
|
48
|
-
* Identity function for EvmTokenInterfaceImplemented payload
|
|
49
|
-
*/
|
|
50
|
-
export declare const isEvmTokenInterfaceImplemented: (x?: unknown) => x is import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
51
|
-
/**
|
|
52
|
-
* The contract address
|
|
53
|
-
*/
|
|
14
|
+
export declare const isEvmTokenInterfaceImplemented: (x?: unknown | null) => x is import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & {
|
|
54
15
|
address: string;
|
|
55
|
-
/**
|
|
56
|
-
* The chain id
|
|
57
|
-
*/
|
|
58
16
|
chainId: number;
|
|
59
|
-
/**
|
|
60
|
-
* True if the contract implements the interface
|
|
61
|
-
*/
|
|
62
17
|
implemented: boolean;
|
|
63
|
-
/**
|
|
64
|
-
* The specific token interface
|
|
65
|
-
*/
|
|
66
18
|
tokenInterface: TokenInterface;
|
|
67
19
|
} & {
|
|
68
20
|
schema: "network.xyo.evm.token.interface.implemented";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Payload.d.ts","sourceRoot":"","sources":["../../src/Payload.ts"],"names":[],"mappings":"AAAA,OAAO,EAAyB,OAAO,EAAE,MAAM,4BAA4B,CAAA;
|
|
1
|
+
{"version":3,"file":"Payload.d.ts","sourceRoot":"","sources":["../../src/Payload.ts"],"names":[],"mappings":"AAAA,OAAO,EAAyB,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAK3E,MAAM,MAAM,oBAAoB,GAAG,OAAO,CAAA;AAK1C,MAAM,MAAM,qBAAqB,GAAG,QAAQ,GAAG,qBAAqB,GAAG,gBAAgB,GAAG,kBAAkB,CAAA;AAK5G,MAAM,MAAM,sBAAsB,GAAG,SAAS,GAAG,sBAAsB,GAAG,qBAAqB,CAAA;AAK/F,MAAM,MAAM,cAAc,GAAG,oBAAoB,GAAG,qBAAqB,GAAG,sBAAsB,CAAA;AAKlG,eAAO,MAAM,kCAAkC,gDAAgD,CAAA;AAI/F,MAAM,MAAM,kCAAkC,GAAG,OAAO,kCAAkC,CAAA;AAK1F,MAAM,MAAM,4BAA4B,GAAG,OAAO,CAChD;IAIE,OAAO,EAAE,MAAM,CAAA;IAIf,OAAO,EAAE,MAAM,CAAA;IAIf,WAAW,EAAE,OAAO,CAAA;IAIpB,cAAc,EAAE,cAAc,CAAA;CAC/B,EACD,kCAAkC,CACnC,CAAA;AAKD,eAAO,MAAM,8BAA8B;aApB9B,MAAM;aAIN,MAAM;iBAIF,OAAO;oBAIJ,cAAc;;;CAQmG,CAAA"}
|
package/dist/neutral/index.cjs
CHANGED
|
@@ -1,109 +1,2 @@
|
|
|
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
|
-
EvmTokenInterfaceImplementedDiviner: () => EvmTokenInterfaceImplementedDiviner,
|
|
24
|
-
EvmTokenInterfaceImplementedDivinerConfigSchema: () => EvmTokenInterfaceImplementedDivinerConfigSchema,
|
|
25
|
-
EvmTokenInterfaceImplementedSchema: () => EvmTokenInterfaceImplementedSchema,
|
|
26
|
-
isEvmTokenInterfaceImplemented: () => isEvmTokenInterfaceImplemented
|
|
27
|
-
});
|
|
28
|
-
module.exports = __toCommonJS(src_exports);
|
|
29
|
-
|
|
30
|
-
// src/Diviner.ts
|
|
31
|
-
var import_assert = require("@xylabs/assert");
|
|
32
|
-
var import_diviner_abstract = require("@xyo-network/diviner-abstract");
|
|
33
|
-
var import_evm_contract_witness = require("@xyo-network/evm-contract-witness");
|
|
34
|
-
var import_open_zeppelin_typechain = require("@xyo-network/open-zeppelin-typechain");
|
|
35
|
-
var import_ethers = require("ethers");
|
|
36
|
-
|
|
37
|
-
// src/Payload.ts
|
|
38
|
-
var import_payload_model = require("@xyo-network/payload-model");
|
|
39
|
-
var EvmTokenInterfaceImplementedSchema = "network.xyo.evm.token.interface.implemented";
|
|
40
|
-
var isEvmTokenInterfaceImplemented = (0, import_payload_model.isPayloadOfSchemaType)(EvmTokenInterfaceImplementedSchema);
|
|
41
|
-
|
|
42
|
-
// src/Diviner.ts
|
|
43
|
-
var EvmTokenInterfaceImplementedDivinerConfigSchema = `${EvmTokenInterfaceImplementedSchema}.diviner.config`;
|
|
44
|
-
var EvmTokenInterfaceImplementedDiviner = class _EvmTokenInterfaceImplementedDiviner extends import_diviner_abstract.AbstractDiviner {
|
|
45
|
-
/**
|
|
46
|
-
* The list of supported token interfaces
|
|
47
|
-
*/
|
|
48
|
-
static SupportedTokenInterfaces = {
|
|
49
|
-
ERC1155: import_open_zeppelin_typechain.ERC1155__factory.abi,
|
|
50
|
-
ERC1155Metadata_URI: import_open_zeppelin_typechain.IERC1155MetadataURI__factory.abi,
|
|
51
|
-
ERC1155TokenReceiver: import_open_zeppelin_typechain.IERC1155Receiver__factory.abi,
|
|
52
|
-
ERC20: import_open_zeppelin_typechain.ERC20__factory.abi,
|
|
53
|
-
ERC721: import_open_zeppelin_typechain.ERC721__factory.abi,
|
|
54
|
-
ERC721Enumerable: import_open_zeppelin_typechain.IERC721Enumerable__factory.abi,
|
|
55
|
-
ERC721Metadata: import_open_zeppelin_typechain.IERC721Metadata__factory.abi,
|
|
56
|
-
ERC721TokenReceiver: import_open_zeppelin_typechain.IERC721Receiver__factory.abi
|
|
57
|
-
};
|
|
58
|
-
static configSchemas = [...super.configSchemas, EvmTokenInterfaceImplementedDivinerConfigSchema];
|
|
59
|
-
static defaultConfigSchema = EvmTokenInterfaceImplementedDivinerConfigSchema;
|
|
60
|
-
_tokenInterfaces;
|
|
61
|
-
/**
|
|
62
|
-
* The list of token interfaces to check against the contract
|
|
63
|
-
*/
|
|
64
|
-
get tokenInterfaces() {
|
|
65
|
-
if (!this._tokenInterfaces) {
|
|
66
|
-
this._tokenInterfaces = this.config?.tokenInterfaces ? Object.fromEntries(
|
|
67
|
-
this.config?.tokenInterfaces.map((tokenInterface) => {
|
|
68
|
-
return [tokenInterface, _EvmTokenInterfaceImplementedDiviner.SupportedTokenInterfaces[tokenInterface]];
|
|
69
|
-
})
|
|
70
|
-
) ?? {} : _EvmTokenInterfaceImplementedDiviner.SupportedTokenInterfaces;
|
|
71
|
-
}
|
|
72
|
-
return this._tokenInterfaces;
|
|
73
|
-
}
|
|
74
|
-
async divineHandler(inPayloads = []) {
|
|
75
|
-
await this.started("throw");
|
|
76
|
-
try {
|
|
77
|
-
const allResults = await Promise.all(
|
|
78
|
-
// Iterate over each contract passed in
|
|
79
|
-
inPayloads.filter(import_evm_contract_witness.isEvmContract).map(({ address, code, chainId }) => {
|
|
80
|
-
const byteCode = (0, import_assert.assertEx)(code, () => "Missing code");
|
|
81
|
-
const results = [];
|
|
82
|
-
for (const [tokenInterface, abi] of Object.entries(this.tokenInterfaces)) {
|
|
83
|
-
const contractInterface = new import_ethers.Interface(abi);
|
|
84
|
-
const implementations = [];
|
|
85
|
-
contractInterface.forEachFunction(({ selector }) => {
|
|
86
|
-
implementations.push(byteCode.includes(BigInt(selector).toString(16)));
|
|
87
|
-
});
|
|
88
|
-
const implemented = implementations.every(Boolean);
|
|
89
|
-
const result = {
|
|
90
|
-
address,
|
|
91
|
-
chainId,
|
|
92
|
-
implemented,
|
|
93
|
-
schema: EvmTokenInterfaceImplementedSchema,
|
|
94
|
-
tokenInterface
|
|
95
|
-
};
|
|
96
|
-
results.push(result);
|
|
97
|
-
}
|
|
98
|
-
return results;
|
|
99
|
-
})
|
|
100
|
-
);
|
|
101
|
-
return allResults.flat();
|
|
102
|
-
} catch (ex) {
|
|
103
|
-
const error = ex;
|
|
104
|
-
console.log(`Error [${this.config.name}]: ${error.message}`);
|
|
105
|
-
throw error;
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
};
|
|
1
|
+
"use strict";var c=Object.defineProperty;var S=Object.getOwnPropertyDescriptor;var b=Object.getOwnPropertyNames;var x=Object.prototype.hasOwnProperty;var _=(n,t)=>{for(var r in t)c(n,r,{get:t[r],enumerable:!0})},D=(n,t,r,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of b(t))!x.call(n,a)&&a!==r&&c(n,a,{get:()=>t[a],enumerable:!(o=S(t,a))||o.enumerable});return n};var P=n=>D(c({},"__esModule",{value:!0}),n);var w={};_(w,{EvmTokenInterfaceImplementedDiviner:()=>f,EvmTokenInterfaceImplementedDivinerConfigSchema:()=>i,EvmTokenInterfaceImplementedSchema:()=>m,isEvmTokenInterfaceImplemented:()=>M});module.exports=P(w);var d=require("@xylabs/assert"),E=require("@xyo-network/diviner-abstract"),l=require("@xyo-network/evm-contract-witness"),e=require("@xyo-network/open-zeppelin-typechain"),k=require("ethers");var p=require("@xyo-network/payload-model"),m="network.xyo.evm.token.interface.implemented",M=(0,p.isPayloadOfSchemaType)(m);var i=`${m}.diviner.config`,f=class n extends E.AbstractDiviner{static SupportedTokenInterfaces={ERC1155:e.ERC1155__factory.abi,ERC1155Metadata_URI:e.IERC1155MetadataURI__factory.abi,ERC1155TokenReceiver:e.IERC1155Receiver__factory.abi,ERC20:e.ERC20__factory.abi,ERC721:e.ERC721__factory.abi,ERC721Enumerable:e.IERC721Enumerable__factory.abi,ERC721Metadata:e.IERC721Metadata__factory.abi,ERC721TokenReceiver:e.IERC721Receiver__factory.abi};static configSchemas=[...super.configSchemas,i];static defaultConfigSchema=i;_tokenInterfaces;get tokenInterfaces(){return this._tokenInterfaces||(this._tokenInterfaces=this.config?.tokenInterfaces?Object.fromEntries(this.config?.tokenInterfaces.map(t=>[t,n.SupportedTokenInterfaces[t]]))??{}:n.SupportedTokenInterfaces),this._tokenInterfaces}async divineHandler(t=[]){await this.started("throw");try{return(await Promise.all(t.filter(l.isEvmContract).map(({address:o,code:a,chainId:v})=>{let T=(0,d.assertEx)(a,()=>"Missing code"),s=[];for(let[C,y]of Object.entries(this.tokenInterfaces)){let R=new k.Interface(y),I=[];R.forEachFunction(({selector:u})=>{I.push(T.includes(BigInt(u).toString(16)))});let h=I.every(Boolean),g={address:o,chainId:v,implemented:h,schema:m,tokenInterface:C};s.push(g)}return s}))).flat()}catch(r){let o=r;throw console.log(`Error [${this.config.name}]: ${o.message}`),o}}};
|
|
109
2
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/Diviner.ts","../../src/Payload.ts"],"sourcesContent":["export * from './Diviner'\nexport * from './Payload'\n","import { assertEx } from '@xylabs/assert'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { DivinerConfig, DivinerParams } from '@xyo-network/diviner-model'\nimport { EvmContract, isEvmContract } from '@xyo-network/evm-contract-witness'\nimport { AnyConfigSchema } from '@xyo-network/module-model'\nimport {\n ERC20__factory,\n ERC721__factory,\n ERC1155__factory,\n IERC721Enumerable__factory,\n IERC721Metadata__factory,\n IERC721Receiver__factory,\n IERC1155MetadataURI__factory,\n IERC1155Receiver__factory,\n} from '@xyo-network/open-zeppelin-typechain'\nimport { Schema } from '@xyo-network/payload-model'\nimport { Interface, JsonFragment } from 'ethers'\n\nimport { EvmTokenInterfaceImplemented, EvmTokenInterfaceImplementedSchema, TokenInterface } from './Payload'\n\nexport const EvmTokenInterfaceImplementedDivinerConfigSchema = `${EvmTokenInterfaceImplementedSchema}.diviner.config`\nexport type EvmTokenInterfaceImplementedDivinerConfigSchema = typeof EvmTokenInterfaceImplementedDivinerConfigSchema\n\nexport type EvmTokenInterfaceImplementedDivinerConfig = DivinerConfig<{\n schema: EvmTokenInterfaceImplementedDivinerConfigSchema\n tokenInterfaces?: TokenInterface[]\n}>\n\nexport type EvmTokenInterfaceImplementedDivinerParams = DivinerParams<AnyConfigSchema<EvmTokenInterfaceImplementedDivinerConfig>>\n\ntype DistributiveMappedType<T> = T extends string ? { [K in T]: readonly JsonFragment[] } : never\ntype TokenInterfaceDictionary = DistributiveMappedType<TokenInterface>\n\n/**\n * A diviner that checks if a contract implements a token interface\n */\nexport class EvmTokenInterfaceImplementedDiviner<\n TParams extends EvmTokenInterfaceImplementedDivinerParams = EvmTokenInterfaceImplementedDivinerParams,\n> extends AbstractDiviner<TParams, EvmContract, EvmTokenInterfaceImplemented> {\n /**\n * The list of supported token interfaces\n */\n static readonly SupportedTokenInterfaces: Readonly<Record<TokenInterface, readonly JsonFragment[]>> = {\n ERC1155: ERC1155__factory.abi,\n ERC1155Metadata_URI: IERC1155MetadataURI__factory.abi,\n ERC1155TokenReceiver: IERC1155Receiver__factory.abi,\n ERC20: ERC20__factory.abi,\n ERC721: ERC721__factory.abi,\n ERC721Enumerable: IERC721Enumerable__factory.abi,\n ERC721Metadata: IERC721Metadata__factory.abi,\n ERC721TokenReceiver: IERC721Receiver__factory.abi,\n }\n static override readonly configSchemas: Schema[] = [...super.configSchemas, EvmTokenInterfaceImplementedDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = EvmTokenInterfaceImplementedDivinerConfigSchema\n\n private _tokenInterfaces?: TokenInterfaceDictionary\n\n /**\n * The list of token interfaces to check against the contract\n */\n get tokenInterfaces() {\n if (!this._tokenInterfaces) {\n this._tokenInterfaces =\n this.config?.tokenInterfaces ?\n (Object.fromEntries(\n this.config?.tokenInterfaces.map((tokenInterface) => {\n return [tokenInterface, EvmTokenInterfaceImplementedDiviner.SupportedTokenInterfaces[tokenInterface]] as const\n }),\n ) as TokenInterfaceDictionary) ?? {}\n : EvmTokenInterfaceImplementedDiviner.SupportedTokenInterfaces\n }\n return this._tokenInterfaces\n }\n\n protected override async divineHandler(inPayloads: EvmContract[] = []): Promise<EvmTokenInterfaceImplemented[]> {\n await this.started('throw')\n try {\n const allResults = await Promise.all(\n // Iterate over each contract passed in\n inPayloads.filter(isEvmContract).map(({ address, code, chainId }) => {\n // Ensure we have the contract code\n const byteCode = assertEx(code, () => 'Missing code')\n const results: EvmTokenInterfaceImplemented[] = []\n // Iterate over each token interface\n for (const [tokenInterface, abi] of Object.entries(this.tokenInterfaces)) {\n // Check if the contract implements the interface abi\n const contractInterface = new Interface(abi)\n const implementations: boolean[] = []\n contractInterface.forEachFunction(({ selector }) => {\n implementations.push(byteCode.includes(BigInt(selector).toString(16)))\n })\n const implemented = implementations.every(Boolean)\n const result: EvmTokenInterfaceImplemented = {\n address,\n chainId,\n implemented,\n schema: EvmTokenInterfaceImplementedSchema,\n tokenInterface: tokenInterface as TokenInterface,\n }\n results.push(result)\n }\n\n return results\n }),\n )\n return allResults.flat()\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","import { isPayloadOfSchemaType, Payload } from '@xyo-network/payload-model'\n\n/**\n * ERC20 Token Interfaces\n */\nexport type ERC20TokenInterfaces = 'ERC20'\n\n/**\n * ERC721 Token Interfaces\n */\nexport type ERC721TokenInterfaces = 'ERC721' | 'ERC721TokenReceiver' | 'ERC721Metadata' | 'ERC721Enumerable'\n\n/**\n * ERC1155 Token Interfaces\n */\nexport type ERC1155TokenInterfaces = 'ERC1155' | 'ERC1155TokenReceiver' | 'ERC1155Metadata_URI'\n\n/**\n * All Token Interfaces\n */\nexport type TokenInterface = ERC20TokenInterfaces | ERC721TokenInterfaces | ERC1155TokenInterfaces\n\n/**\n * The schema for the EVM Token Interface Implemented payload\n */\nexport const EvmTokenInterfaceImplementedSchema = 'network.xyo.evm.token.interface.implemented'\n/**\n * The schema for the EVM Token Interface Implemented payload\n */\nexport type EvmTokenInterfaceImplementedSchema = typeof EvmTokenInterfaceImplementedSchema\n\n/**\n * The EVM Token Interface Implemented payload\n */\nexport type EvmTokenInterfaceImplemented = Payload<\n {\n /**\n * The contract address\n */\n address: string\n /**\n * The chain id\n */\n chainId: number\n /**\n * True if the contract implements the interface\n */\n implemented: boolean\n /**\n * The specific token interface\n */\n tokenInterface: TokenInterface\n },\n EvmTokenInterfaceImplementedSchema\n>\n\n/**\n * Identity function for EvmTokenInterfaceImplemented payload\n */\nexport const isEvmTokenInterfaceImplemented = isPayloadOfSchemaType<EvmTokenInterfaceImplemented>(EvmTokenInterfaceImplementedSchema)\n"],"mappings":"
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/Diviner.ts","../../src/Payload.ts"],"sourcesContent":["export * from './Diviner'\nexport * from './Payload'\n","import { assertEx } from '@xylabs/assert'\nimport { AbstractDiviner } from '@xyo-network/diviner-abstract'\nimport { DivinerConfig, DivinerParams } from '@xyo-network/diviner-model'\nimport { EvmContract, isEvmContract } from '@xyo-network/evm-contract-witness'\nimport { AnyConfigSchema } from '@xyo-network/module-model'\nimport {\n ERC20__factory,\n ERC721__factory,\n ERC1155__factory,\n IERC721Enumerable__factory,\n IERC721Metadata__factory,\n IERC721Receiver__factory,\n IERC1155MetadataURI__factory,\n IERC1155Receiver__factory,\n} from '@xyo-network/open-zeppelin-typechain'\nimport { Schema } from '@xyo-network/payload-model'\nimport { Interface, JsonFragment } from 'ethers'\n\nimport { EvmTokenInterfaceImplemented, EvmTokenInterfaceImplementedSchema, TokenInterface } from './Payload'\n\nexport const EvmTokenInterfaceImplementedDivinerConfigSchema = `${EvmTokenInterfaceImplementedSchema}.diviner.config`\nexport type EvmTokenInterfaceImplementedDivinerConfigSchema = typeof EvmTokenInterfaceImplementedDivinerConfigSchema\n\nexport type EvmTokenInterfaceImplementedDivinerConfig = DivinerConfig<{\n schema: EvmTokenInterfaceImplementedDivinerConfigSchema\n tokenInterfaces?: TokenInterface[]\n}>\n\nexport type EvmTokenInterfaceImplementedDivinerParams = DivinerParams<AnyConfigSchema<EvmTokenInterfaceImplementedDivinerConfig>>\n\ntype DistributiveMappedType<T> = T extends string ? { [K in T]: readonly JsonFragment[] } : never\ntype TokenInterfaceDictionary = DistributiveMappedType<TokenInterface>\n\n/**\n * A diviner that checks if a contract implements a token interface\n */\nexport class EvmTokenInterfaceImplementedDiviner<\n TParams extends EvmTokenInterfaceImplementedDivinerParams = EvmTokenInterfaceImplementedDivinerParams,\n> extends AbstractDiviner<TParams, EvmContract, EvmTokenInterfaceImplemented> {\n /**\n * The list of supported token interfaces\n */\n static readonly SupportedTokenInterfaces: Readonly<Record<TokenInterface, readonly JsonFragment[]>> = {\n ERC1155: ERC1155__factory.abi,\n ERC1155Metadata_URI: IERC1155MetadataURI__factory.abi,\n ERC1155TokenReceiver: IERC1155Receiver__factory.abi,\n ERC20: ERC20__factory.abi,\n ERC721: ERC721__factory.abi,\n ERC721Enumerable: IERC721Enumerable__factory.abi,\n ERC721Metadata: IERC721Metadata__factory.abi,\n ERC721TokenReceiver: IERC721Receiver__factory.abi,\n }\n static override readonly configSchemas: Schema[] = [...super.configSchemas, EvmTokenInterfaceImplementedDivinerConfigSchema]\n static override readonly defaultConfigSchema: Schema = EvmTokenInterfaceImplementedDivinerConfigSchema\n\n private _tokenInterfaces?: TokenInterfaceDictionary\n\n /**\n * The list of token interfaces to check against the contract\n */\n get tokenInterfaces() {\n if (!this._tokenInterfaces) {\n this._tokenInterfaces =\n this.config?.tokenInterfaces ?\n (Object.fromEntries(\n this.config?.tokenInterfaces.map((tokenInterface) => {\n return [tokenInterface, EvmTokenInterfaceImplementedDiviner.SupportedTokenInterfaces[tokenInterface]] as const\n }),\n ) as TokenInterfaceDictionary) ?? {}\n : EvmTokenInterfaceImplementedDiviner.SupportedTokenInterfaces\n }\n return this._tokenInterfaces\n }\n\n protected override async divineHandler(inPayloads: EvmContract[] = []): Promise<EvmTokenInterfaceImplemented[]> {\n await this.started('throw')\n try {\n const allResults = await Promise.all(\n // Iterate over each contract passed in\n inPayloads.filter(isEvmContract).map(({ address, code, chainId }) => {\n // Ensure we have the contract code\n const byteCode = assertEx(code, () => 'Missing code')\n const results: EvmTokenInterfaceImplemented[] = []\n // Iterate over each token interface\n for (const [tokenInterface, abi] of Object.entries(this.tokenInterfaces)) {\n // Check if the contract implements the interface abi\n const contractInterface = new Interface(abi)\n const implementations: boolean[] = []\n contractInterface.forEachFunction(({ selector }) => {\n implementations.push(byteCode.includes(BigInt(selector).toString(16)))\n })\n const implemented = implementations.every(Boolean)\n const result: EvmTokenInterfaceImplemented = {\n address,\n chainId,\n implemented,\n schema: EvmTokenInterfaceImplementedSchema,\n tokenInterface: tokenInterface as TokenInterface,\n }\n results.push(result)\n }\n\n return results\n }),\n )\n return allResults.flat()\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","import { isPayloadOfSchemaType, Payload } from '@xyo-network/payload-model'\n\n/**\n * ERC20 Token Interfaces\n */\nexport type ERC20TokenInterfaces = 'ERC20'\n\n/**\n * ERC721 Token Interfaces\n */\nexport type ERC721TokenInterfaces = 'ERC721' | 'ERC721TokenReceiver' | 'ERC721Metadata' | 'ERC721Enumerable'\n\n/**\n * ERC1155 Token Interfaces\n */\nexport type ERC1155TokenInterfaces = 'ERC1155' | 'ERC1155TokenReceiver' | 'ERC1155Metadata_URI'\n\n/**\n * All Token Interfaces\n */\nexport type TokenInterface = ERC20TokenInterfaces | ERC721TokenInterfaces | ERC1155TokenInterfaces\n\n/**\n * The schema for the EVM Token Interface Implemented payload\n */\nexport const EvmTokenInterfaceImplementedSchema = 'network.xyo.evm.token.interface.implemented'\n/**\n * The schema for the EVM Token Interface Implemented payload\n */\nexport type EvmTokenInterfaceImplementedSchema = typeof EvmTokenInterfaceImplementedSchema\n\n/**\n * The EVM Token Interface Implemented payload\n */\nexport type EvmTokenInterfaceImplemented = Payload<\n {\n /**\n * The contract address\n */\n address: string\n /**\n * The chain id\n */\n chainId: number\n /**\n * True if the contract implements the interface\n */\n implemented: boolean\n /**\n * The specific token interface\n */\n tokenInterface: TokenInterface\n },\n EvmTokenInterfaceImplementedSchema\n>\n\n/**\n * Identity function for EvmTokenInterfaceImplemented payload\n */\nexport const isEvmTokenInterfaceImplemented = isPayloadOfSchemaType<EvmTokenInterfaceImplemented>(EvmTokenInterfaceImplementedSchema)\n"],"mappings":"yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,yCAAAE,EAAA,oDAAAC,EAAA,uCAAAC,EAAA,mCAAAC,IAAA,eAAAC,EAAAN,GCAA,IAAAO,EAAyB,0BACzBC,EAAgC,yCAEhCC,EAA2C,6CAE3CC,EASO,gDAEPC,EAAwC,kBChBxC,IAAAC,EAA+C,sCAyBlCC,EAAqC,8CAkCrCC,KAAiC,yBAAoDD,CAAkC,EDvC7H,IAAME,EAAkD,GAAGC,CAAkC,kBAgBvFC,EAAN,MAAMC,UAEH,iBAAoE,CAI5E,OAAgB,yBAAsF,CACpG,QAAS,mBAAiB,IAC1B,oBAAqB,+BAA6B,IAClD,qBAAsB,4BAA0B,IAChD,MAAO,iBAAe,IACtB,OAAQ,kBAAgB,IACxB,iBAAkB,6BAA2B,IAC7C,eAAgB,2BAAyB,IACzC,oBAAqB,2BAAyB,GAChD,EACA,OAAyB,cAA0B,CAAC,GAAG,MAAM,cAAeH,CAA+C,EAC3H,OAAyB,oBAA8BA,EAE/C,iBAKR,IAAI,iBAAkB,CACpB,OAAK,KAAK,mBACR,KAAK,iBACH,KAAK,QAAQ,gBACV,OAAO,YACN,KAAK,QAAQ,gBAAgB,IAAKI,GACzB,CAACA,EAAgBD,EAAoC,yBAAyBC,CAAc,CAAC,CACrG,CACH,GAAkC,CAAC,EACnCD,EAAoC,0BAEnC,KAAK,gBACd,CAEA,MAAyB,cAAcE,EAA4B,CAAC,EAA4C,CAC9G,MAAM,KAAK,QAAQ,OAAO,EAC1B,GAAI,CA6BF,OA5BmB,MAAM,QAAQ,IAE/BA,EAAW,OAAO,eAAa,EAAE,IAAI,CAAC,CAAE,QAAAC,EAAS,KAAAC,EAAM,QAAAC,CAAQ,IAAM,CAEnE,IAAMC,KAAW,YAASF,EAAM,IAAM,cAAc,EAC9CG,EAA0C,CAAC,EAEjD,OAAW,CAACN,EAAgBO,CAAG,IAAK,OAAO,QAAQ,KAAK,eAAe,EAAG,CAExE,IAAMC,EAAoB,IAAI,YAAUD,CAAG,EACrCE,EAA6B,CAAC,EACpCD,EAAkB,gBAAgB,CAAC,CAAE,SAAAE,CAAS,IAAM,CAClDD,EAAgB,KAAKJ,EAAS,SAAS,OAAOK,CAAQ,EAAE,SAAS,EAAE,CAAC,CAAC,CACvE,CAAC,EACD,IAAMC,EAAcF,EAAgB,MAAM,OAAO,EAC3CG,EAAuC,CAC3C,QAAAV,EACA,QAAAE,EACA,YAAAO,EACA,OAAQd,EACR,eAAgBG,CAClB,EACAM,EAAQ,KAAKM,CAAM,CACrB,CAEA,OAAON,CACT,CAAC,CACH,GACkB,KAAK,CACzB,OAASO,EAAI,CACX,IAAMC,EAAQD,EACd,cAAQ,IAAI,UAAU,KAAK,OAAO,IAAI,MAAMC,EAAM,OAAO,EAAE,EACrDA,CACR,CACF,CACF","names":["src_exports","__export","EvmTokenInterfaceImplementedDiviner","EvmTokenInterfaceImplementedDivinerConfigSchema","EvmTokenInterfaceImplementedSchema","isEvmTokenInterfaceImplemented","__toCommonJS","import_assert","import_diviner_abstract","import_evm_contract_witness","import_open_zeppelin_typechain","import_ethers","import_payload_model","EvmTokenInterfaceImplementedSchema","isEvmTokenInterfaceImplemented","EvmTokenInterfaceImplementedDivinerConfigSchema","EvmTokenInterfaceImplementedSchema","EvmTokenInterfaceImplementedDiviner","_EvmTokenInterfaceImplementedDiviner","tokenInterface","inPayloads","address","code","chainId","byteCode","results","abi","contractInterface","implementations","selector","implemented","result","ex","error"]}
|