@ensdomains/ensjs 4.1.2 → 5.0.0-alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/actions/dns/getDnsImportData.d.ts +38 -0
- package/dist/actions/dns/getDnsImportData.d.ts.map +1 -0
- package/dist/actions/dns/getDnsImportData.js +60 -0
- package/dist/actions/dns/getDnsImportData.js.map +1 -0
- package/dist/actions/dns/getDnsOffchainData.d.ts +40 -0
- package/dist/actions/dns/getDnsOffchainData.d.ts.map +1 -0
- package/dist/actions/dns/getDnsOffchainData.js +104 -0
- package/dist/actions/dns/getDnsOffchainData.js.map +1 -0
- package/dist/actions/dns/getDnsOwner.d.ts +27 -0
- package/dist/actions/dns/getDnsOwner.d.ts.map +1 -0
- package/dist/actions/dns/getDnsOwner.js +53 -0
- package/dist/actions/dns/getDnsOwner.js.map +1 -0
- package/dist/actions/dns/importDnsName.d.ts +64 -0
- package/dist/actions/dns/importDnsName.d.ts.map +1 -0
- package/dist/actions/dns/importDnsName.js +85 -0
- package/dist/actions/dns/importDnsName.js.map +1 -0
- package/dist/actions/dns/types.d.ts +2 -0
- package/dist/actions/dns/types.d.ts.map +1 -0
- package/dist/actions/dns/types.js.map +1 -0
- package/dist/actions/public/findResolver.d.ts +7 -0
- package/dist/actions/public/findResolver.d.ts.map +1 -0
- package/dist/actions/public/findResolver.js +5 -0
- package/dist/actions/public/findResolver.js.map +1 -0
- package/dist/actions/public/getAbiRecord.d.ts +32 -0
- package/dist/actions/public/getAbiRecord.d.ts.map +1 -0
- package/dist/actions/public/getAbiRecord.js +35 -0
- package/dist/actions/public/getAbiRecord.js.map +1 -0
- package/dist/actions/public/getAddressRecord.d.ts +32 -0
- package/dist/actions/public/getAddressRecord.d.ts.map +1 -0
- package/dist/actions/public/getAddressRecord.js +35 -0
- package/dist/actions/public/getAddressRecord.js.map +1 -0
- package/dist/actions/public/getAvailable.d.ts +31 -0
- package/dist/actions/public/getAvailable.d.ts.map +1 -0
- package/dist/actions/public/getAvailable.js +49 -0
- package/dist/actions/public/getAvailable.js.map +1 -0
- package/dist/actions/public/getContentHashRecord.d.ts +32 -0
- package/dist/actions/public/getContentHashRecord.d.ts.map +1 -0
- package/dist/actions/public/getContentHashRecord.js +35 -0
- package/dist/actions/public/getContentHashRecord.js.map +1 -0
- package/dist/actions/public/getCredentials.d.ts +32 -0
- package/dist/actions/public/getCredentials.d.ts.map +1 -0
- package/dist/actions/public/getCredentials.js +41 -0
- package/dist/actions/public/getCredentials.js.map +1 -0
- package/dist/actions/public/getExpiry.d.ts +45 -0
- package/dist/actions/public/getExpiry.d.ts.map +1 -0
- package/dist/actions/public/getExpiry.js +156 -0
- package/dist/actions/public/getExpiry.js.map +1 -0
- package/dist/actions/public/getName.d.ts +62 -0
- package/dist/actions/public/getName.d.ts.map +1 -0
- package/dist/actions/public/getName.js +90 -0
- package/dist/actions/public/getName.js.map +1 -0
- package/dist/actions/public/getOwner.d.ts +61 -0
- package/dist/actions/public/getOwner.d.ts.map +1 -0
- package/dist/actions/public/getOwner.js +163 -0
- package/dist/actions/public/getOwner.js.map +1 -0
- package/dist/actions/public/getPrice.d.ts +37 -0
- package/dist/actions/public/getPrice.d.ts.map +1 -0
- package/dist/actions/public/getPrice.js +61 -0
- package/dist/actions/public/getPrice.js.map +1 -0
- package/dist/actions/public/getRecords.d.ts +79 -0
- package/dist/actions/public/getRecords.d.ts.map +1 -0
- package/dist/actions/public/getRecords.js +160 -0
- package/dist/actions/public/getRecords.js.map +1 -0
- package/dist/actions/public/getResolver.d.ts +30 -0
- package/dist/actions/public/getResolver.d.ts.map +1 -0
- package/dist/actions/public/getResolver.js +43 -0
- package/dist/actions/public/getResolver.js.map +1 -0
- package/dist/actions/public/getResolverName.d.ts +30 -0
- package/dist/actions/public/getResolverName.d.ts.map +1 -0
- package/dist/actions/public/getResolverName.js +35 -0
- package/dist/actions/public/getResolverName.js.map +1 -0
- package/dist/actions/public/getSupportedInterfaces.d.ts +34 -0
- package/dist/actions/public/getSupportedInterfaces.d.ts.map +1 -0
- package/dist/actions/public/getSupportedInterfaces.js +40 -0
- package/dist/actions/public/getSupportedInterfaces.js.map +1 -0
- package/dist/actions/public/getTextRecord.d.ts +32 -0
- package/dist/actions/public/getTextRecord.d.ts.map +1 -0
- package/dist/actions/public/getTextRecord.js +37 -0
- package/dist/actions/public/getTextRecord.js.map +1 -0
- package/dist/actions/public/getWrapperData.d.ts +39 -0
- package/dist/actions/public/getWrapperData.d.ts.map +1 -0
- package/dist/actions/public/getWrapperData.js +50 -0
- package/dist/actions/public/getWrapperData.js.map +1 -0
- package/dist/actions/public/getWrapperName.d.ts +30 -0
- package/dist/actions/public/getWrapperName.d.ts.map +1 -0
- package/dist/actions/public/getWrapperName.js +43 -0
- package/dist/actions/public/getWrapperName.js.map +1 -0
- package/dist/actions/public/resolveNameData.d.ts +30 -0
- package/dist/actions/public/resolveNameData.d.ts.map +1 -0
- package/dist/actions/public/resolveNameData.js +91 -0
- package/dist/actions/public/resolveNameData.js.map +1 -0
- package/dist/actions/public/v2/getResolverName.d.ts +29 -0
- package/dist/actions/public/v2/getResolverName.d.ts.map +1 -0
- package/dist/actions/public/v2/getResolverName.js +35 -0
- package/dist/actions/public/v2/getResolverName.js.map +1 -0
- package/dist/actions/public/v2/getUnderlyingResolver.d.ts +30 -0
- package/dist/actions/public/v2/getUnderlyingResolver.d.ts.map +1 -0
- package/dist/actions/public/v2/getUnderlyingResolver.js +35 -0
- package/dist/actions/public/v2/getUnderlyingResolver.js.map +1 -0
- package/dist/actions/subgraph/client.d.ts +9 -0
- package/dist/actions/subgraph/client.d.ts.map +1 -0
- package/dist/actions/subgraph/client.js +88 -0
- package/dist/actions/subgraph/client.js.map +1 -0
- package/dist/actions/subgraph/events.d.ts +140 -0
- package/dist/actions/subgraph/events.d.ts.map +1 -0
- package/dist/actions/subgraph/events.js.map +1 -0
- package/dist/actions/subgraph/filters.d.ts +702 -0
- package/dist/actions/subgraph/filters.d.ts.map +1 -0
- package/dist/actions/subgraph/filters.js +108 -0
- package/dist/actions/subgraph/filters.js.map +1 -0
- package/dist/actions/subgraph/fragments.d.ts +41 -0
- package/dist/actions/subgraph/fragments.d.ts.map +1 -0
- package/dist/actions/subgraph/fragments.js.map +1 -0
- package/dist/actions/subgraph/getDecodedName.d.ts +33 -0
- package/dist/actions/subgraph/getDecodedName.d.ts.map +1 -0
- package/dist/actions/subgraph/getDecodedName.js +84 -0
- package/dist/actions/subgraph/getDecodedName.js.map +1 -0
- package/dist/actions/subgraph/getNameHistory.d.ts +61 -0
- package/dist/actions/subgraph/getNameHistory.d.ts.map +1 -0
- package/dist/actions/subgraph/getNameHistory.js +202 -0
- package/dist/actions/subgraph/getNameHistory.js.map +1 -0
- package/dist/actions/subgraph/getNamesForAddress.d.ts +69 -0
- package/dist/actions/subgraph/getNamesForAddress.d.ts.map +1 -0
- package/dist/actions/subgraph/getNamesForAddress.js +214 -0
- package/dist/actions/subgraph/getNamesForAddress.js.map +1 -0
- package/dist/actions/subgraph/getRecordHistory.d.ts +13 -0
- package/dist/actions/subgraph/getRecordHistory.d.ts.map +1 -0
- package/dist/actions/subgraph/getRecordHistory.js +76 -0
- package/dist/actions/subgraph/getRecordHistory.js.map +1 -0
- package/dist/actions/subgraph/getResolvedNamesForAddress.d.ts +26 -0
- package/dist/actions/subgraph/getResolvedNamesForAddress.d.ts.map +1 -0
- package/dist/actions/subgraph/getResolvedNamesForAddress.js +29 -0
- package/dist/actions/subgraph/getResolvedNamesForAddress.js.map +1 -0
- package/dist/actions/subgraph/getSubgraphRecords.d.ts +49 -0
- package/dist/actions/subgraph/getSubgraphRecords.d.ts.map +1 -0
- package/dist/actions/subgraph/getSubgraphRecords.js +103 -0
- package/dist/actions/subgraph/getSubgraphRecords.js.map +1 -0
- package/dist/actions/subgraph/getSubgraphRegistrant.d.ts +33 -0
- package/dist/actions/subgraph/getSubgraphRegistrant.d.ts.map +1 -0
- package/dist/actions/subgraph/getSubgraphRegistrant.js +52 -0
- package/dist/actions/subgraph/getSubgraphRegistrant.js.map +1 -0
- package/dist/actions/subgraph/getSubnames.d.ts +47 -0
- package/dist/actions/subgraph/getSubnames.d.ts.map +1 -0
- package/dist/actions/subgraph/getSubnames.js +159 -0
- package/dist/actions/subgraph/getSubnames.js.map +1 -0
- package/dist/actions/subgraph/types.d.ts +13 -0
- package/dist/actions/subgraph/types.d.ts.map +1 -0
- package/dist/actions/subgraph/types.js.map +1 -0
- package/dist/actions/subgraph/utils.d.ts +42 -0
- package/dist/actions/subgraph/utils.d.ts.map +1 -0
- package/dist/actions/subgraph/utils.js +119 -0
- package/dist/actions/subgraph/utils.js.map +1 -0
- package/dist/actions/wallet/clearRecords.d.ts +70 -0
- package/dist/actions/wallet/clearRecords.d.ts.map +1 -0
- package/dist/actions/wallet/clearRecords.js +55 -0
- package/dist/actions/wallet/clearRecords.js.map +1 -0
- package/dist/actions/wallet/commitName.d.ts +171 -0
- package/dist/actions/wallet/commitName.d.ts.map +1 -0
- package/dist/actions/wallet/commitName.js +76 -0
- package/dist/actions/wallet/commitName.js.map +1 -0
- package/dist/actions/wallet/createSubname.d.ts +83 -0
- package/dist/actions/wallet/createSubname.d.ts.map +1 -0
- package/dist/actions/wallet/createSubname.js +173 -0
- package/dist/actions/wallet/createSubname.js.map +1 -0
- package/dist/actions/wallet/deleteSubname.d.ts +481 -0
- package/dist/actions/wallet/deleteSubname.d.ts.map +1 -0
- package/dist/actions/wallet/deleteSubname.js +120 -0
- package/dist/actions/wallet/deleteSubname.js.map +1 -0
- package/dist/actions/wallet/registerName.d.ts +207 -0
- package/dist/actions/wallet/registerName.d.ts.map +1 -0
- package/dist/actions/wallet/registerName.js +94 -0
- package/dist/actions/wallet/registerName.js.map +1 -0
- package/dist/actions/wallet/renewNames.d.ts +131 -0
- package/dist/actions/wallet/renewNames.d.ts.map +1 -0
- package/dist/actions/wallet/renewNames.js +79 -0
- package/dist/actions/wallet/renewNames.js.map +1 -0
- package/dist/actions/wallet/setAbiRecord.d.ts +78 -0
- package/dist/actions/wallet/setAbiRecord.d.ts.map +1 -0
- package/dist/actions/wallet/setAbiRecord.js +58 -0
- package/dist/actions/wallet/setAbiRecord.js.map +1 -0
- package/dist/actions/wallet/setAddressRecord.d.ts +90 -0
- package/dist/actions/wallet/setAddressRecord.d.ts.map +1 -0
- package/dist/actions/wallet/setAddressRecord.js +57 -0
- package/dist/actions/wallet/setAddressRecord.js.map +1 -0
- package/dist/actions/wallet/setChildFuses.d.ts +183 -0
- package/dist/actions/wallet/setChildFuses.d.ts.map +1 -0
- package/dist/actions/wallet/setChildFuses.js +63 -0
- package/dist/actions/wallet/setChildFuses.js.map +1 -0
- package/dist/actions/wallet/setContentHashRecord.d.ts +78 -0
- package/dist/actions/wallet/setContentHashRecord.d.ts.map +1 -0
- package/dist/actions/wallet/setContentHashRecord.js +50 -0
- package/dist/actions/wallet/setContentHashRecord.js.map +1 -0
- package/dist/actions/wallet/setFuses.d.ts +175 -0
- package/dist/actions/wallet/setFuses.d.ts.map +1 -0
- package/dist/actions/wallet/setFuses.js +59 -0
- package/dist/actions/wallet/setFuses.js.map +1 -0
- package/dist/actions/wallet/setPrimaryName.d.ts +197 -0
- package/dist/actions/wallet/setPrimaryName.d.ts.map +1 -0
- package/dist/actions/wallet/setPrimaryName.js +69 -0
- package/dist/actions/wallet/setPrimaryName.js.map +1 -0
- package/dist/actions/wallet/setRecords.d.ts +225 -0
- package/dist/actions/wallet/setRecords.d.ts.map +1 -0
- package/dist/actions/wallet/setRecords.js +81 -0
- package/dist/actions/wallet/setRecords.js.map +1 -0
- package/dist/actions/wallet/setResolver.d.ts +244 -0
- package/dist/actions/wallet/setResolver.d.ts.map +1 -0
- package/dist/actions/wallet/setResolver.js +75 -0
- package/dist/actions/wallet/setResolver.js.map +1 -0
- package/dist/actions/wallet/setTextRecord.d.ts +88 -0
- package/dist/actions/wallet/setTextRecord.d.ts.map +1 -0
- package/dist/actions/wallet/setTextRecord.js +53 -0
- package/dist/actions/wallet/setTextRecord.js.map +1 -0
- package/dist/actions/wallet/transferName.d.ts +622 -0
- package/dist/actions/wallet/transferName.d.ts.map +1 -0
- package/dist/actions/wallet/transferName.js +161 -0
- package/dist/actions/wallet/transferName.js.map +1 -0
- package/dist/actions/wallet/unwrapName.d.ts +313 -0
- package/dist/actions/wallet/unwrapName.d.ts.map +1 -0
- package/dist/actions/wallet/unwrapName.js +84 -0
- package/dist/actions/wallet/unwrapName.js.map +1 -0
- package/dist/actions/wallet/wrapName.d.ts +257 -0
- package/dist/actions/wallet/wrapName.d.ts.map +1 -0
- package/dist/actions/wallet/wrapName.js +101 -0
- package/dist/actions/wallet/wrapName.js.map +1 -0
- package/dist/clients/chain.d.ts +287 -0
- package/dist/clients/chain.d.ts.map +1 -0
- package/dist/clients/chain.js +232 -0
- package/dist/clients/chain.js.map +1 -0
- package/dist/clients/decorators/public.d.ts +38 -40
- package/dist/clients/decorators/public.d.ts.map +1 -0
- package/dist/clients/decorators/public.js +33 -30
- package/dist/clients/decorators/public.js.map +1 -1
- package/dist/clients/decorators/subgraph.d.ts +8 -7
- package/dist/clients/decorators/subgraph.d.ts.map +1 -0
- package/dist/clients/decorators/subgraph.js +6 -6
- package/dist/clients/decorators/subgraph.js.map +1 -1
- package/dist/clients/decorators/wallet.d.ts +45 -41
- package/dist/clients/decorators/wallet.d.ts.map +1 -0
- package/dist/clients/decorators/wallet.js +41 -38
- package/dist/clients/decorators/wallet.js.map +1 -1
- package/dist/contracts/addEnsContracts.d.ts +3 -3
- package/dist/contracts/addEnsContracts.d.ts.map +1 -0
- package/dist/contracts/addEnsContracts.js +5 -5
- package/dist/contracts/addEnsContracts.js.map +1 -1
- package/dist/contracts/baseRegistrar.d.ts +1 -0
- package/dist/contracts/baseRegistrar.d.ts.map +1 -0
- package/dist/contracts/bulkRenewal.d.ts +1 -0
- package/dist/contracts/bulkRenewal.d.ts.map +1 -0
- package/dist/contracts/compositeResolver.d.ts +17 -0
- package/dist/contracts/compositeResolver.d.ts.map +1 -0
- package/dist/contracts/compositeResolver.js +24 -0
- package/dist/contracts/compositeResolver.js.map +1 -0
- package/dist/contracts/consts.d.ts +17 -40
- package/dist/contracts/consts.d.ts.map +1 -0
- package/dist/contracts/consts.js +19 -41
- package/dist/contracts/consts.js.map +1 -1
- package/dist/contracts/dedicatedResolver.d.ts +55 -0
- package/dist/contracts/dedicatedResolver.d.ts.map +1 -0
- package/dist/contracts/dedicatedResolver.js +75 -0
- package/dist/contracts/dedicatedResolver.js.map +1 -0
- package/dist/contracts/dnsRegistrar.d.ts +1 -0
- package/dist/contracts/dnsRegistrar.d.ts.map +1 -0
- package/dist/contracts/dnssecImpl.d.ts +1 -0
- package/dist/contracts/dnssecImpl.d.ts.map +1 -0
- package/dist/contracts/erc1155.d.ts +1 -0
- package/dist/contracts/erc1155.d.ts.map +1 -0
- package/dist/contracts/erc165.d.ts +1 -0
- package/dist/contracts/erc165.d.ts.map +1 -0
- package/dist/contracts/erc721.d.ts +1 -0
- package/dist/contracts/erc721.d.ts.map +1 -0
- package/dist/contracts/ethRegistrarController.d.ts +1 -31
- package/dist/contracts/ethRegistrarController.d.ts.map +1 -0
- package/dist/contracts/ethRegistrarController.js +0 -40
- package/dist/contracts/ethRegistrarController.js.map +1 -1
- package/dist/contracts/getChainContractAddress.d.ts +16 -15
- package/dist/contracts/getChainContractAddress.d.ts.map +1 -0
- package/dist/contracts/getChainContractAddress.js +3 -2
- package/dist/contracts/getChainContractAddress.js.map +1 -1
- package/dist/contracts/index.d.ts +3 -4
- package/dist/contracts/index.d.ts.map +1 -0
- package/dist/contracts/index.js +2 -4
- package/dist/contracts/index.js.map +1 -1
- package/dist/contracts/l2EthRegistrar.d.ts +599 -0
- package/dist/contracts/l2EthRegistrar.d.ts.map +1 -0
- package/dist/contracts/l2EthRegistrar.js +296 -0
- package/dist/contracts/l2EthRegistrar.js.map +1 -0
- package/dist/contracts/multicall.d.ts +11 -10
- package/dist/contracts/multicall.d.ts.map +1 -0
- package/dist/contracts/multicall.js +14 -14
- package/dist/contracts/multicall.js.map +1 -1
- package/dist/contracts/nameWrapper.d.ts +1 -0
- package/dist/contracts/nameWrapper.d.ts.map +1 -0
- package/dist/contracts/publicResolver.d.ts +8 -3
- package/dist/contracts/publicResolver.d.ts.map +1 -0
- package/dist/contracts/publicResolver.js +9 -3
- package/dist/contracts/publicResolver.js.map +1 -1
- package/dist/contracts/registry.d.ts +1 -0
- package/dist/contracts/registry.d.ts.map +1 -0
- package/dist/contracts/reverseRegistrar.d.ts +1 -0
- package/dist/contracts/reverseRegistrar.d.ts.map +1 -0
- package/dist/contracts/universalResolver.d.ts +1 -0
- package/dist/contracts/universalResolver.d.ts.map +1 -0
- package/dist/dns.d.ts +6 -5
- package/dist/dns.d.ts.map +1 -0
- package/dist/dns.js +4 -4
- package/dist/dns.js.map +1 -1
- package/dist/errors/base.d.ts +1 -0
- package/dist/errors/base.d.ts.map +1 -0
- package/dist/errors/base.js +36 -6
- package/dist/errors/base.js.map +1 -1
- package/dist/errors/contracts.d.ts +1 -0
- package/dist/errors/contracts.d.ts.map +1 -0
- package/dist/errors/contracts.js +24 -4
- package/dist/errors/contracts.js.map +1 -1
- package/dist/errors/dns.d.ts +1 -0
- package/dist/errors/dns.d.ts.map +1 -0
- package/dist/errors/dns.js +90 -15
- package/dist/errors/dns.js.map +1 -1
- package/dist/errors/error-utils.d.ts +1 -0
- package/dist/errors/error-utils.d.ts.map +1 -0
- package/dist/errors/general.d.ts +2 -1
- package/dist/errors/general.d.ts.map +1 -0
- package/dist/errors/general.js +66 -11
- package/dist/errors/general.js.map +1 -1
- package/dist/errors/public.d.ts +1 -0
- package/dist/errors/public.d.ts.map +1 -0
- package/dist/errors/public.js +30 -5
- package/dist/errors/public.js.map +1 -1
- package/dist/errors/subgraph.d.ts +1 -0
- package/dist/errors/subgraph.d.ts.map +1 -0
- package/dist/errors/subgraph.js +48 -8
- package/dist/errors/subgraph.js.map +1 -1
- package/dist/errors/utils.d.ts +4 -0
- package/dist/errors/utils.d.ts.map +1 -0
- package/dist/errors/utils.js +96 -16
- package/dist/errors/utils.js.map +1 -1
- package/dist/errors/version.d.ts +2 -1
- package/dist/errors/version.d.ts.map +1 -0
- package/dist/errors/version.js +1 -1
- package/dist/errors/version.js.map +1 -1
- package/dist/errors/wallet.d.ts +1 -0
- package/dist/errors/wallet.d.ts.map +1 -0
- package/dist/exports/chain.d.ts +2 -0
- package/dist/exports/chain.d.ts.map +1 -0
- package/dist/exports/chain.js +2 -0
- package/dist/exports/chain.js.map +1 -0
- package/dist/exports/internal.d.ts +2 -0
- package/dist/exports/internal.d.ts.map +1 -0
- package/dist/exports/internal.js +2 -0
- package/dist/exports/internal.js.map +1 -0
- package/dist/exports/public/v2.d.ts +3 -0
- package/dist/exports/public/v2.d.ts.map +1 -0
- package/dist/exports/public/v2.js +3 -0
- package/dist/exports/public/v2.js.map +1 -0
- package/dist/exports/public.d.ts +17 -0
- package/dist/exports/public.d.ts.map +1 -0
- package/dist/exports/public.js +17 -0
- package/dist/exports/public.js.map +1 -0
- package/dist/exports/wallet.d.ts +19 -0
- package/dist/exports/wallet.d.ts.map +1 -0
- package/dist/exports/wallet.js +19 -0
- package/dist/exports/wallet.js.map +1 -0
- package/dist/index.d.ts +1 -6
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +0 -6
- package/dist/index.js.map +1 -1
- package/dist/subgraph.d.ts +12 -9
- package/dist/subgraph.d.ts.map +1 -0
- package/dist/subgraph.js +10 -8
- package/dist/subgraph.js.map +1 -1
- package/dist/test/addTestContracts.d.ts +87 -0
- package/dist/test/addTestContracts.d.ts.map +1 -0
- package/dist/test/addTestContracts.js +89 -0
- package/dist/test/addTestContracts.js.map +1 -0
- package/dist/test/createHttpServer.d.ts +6 -0
- package/dist/test/createHttpServer.d.ts.map +1 -0
- package/dist/test/createHttpServer.js +25 -0
- package/dist/test/createHttpServer.js.map +1 -0
- package/dist/test/dns.d.ts +6 -0
- package/dist/test/dns.d.ts.map +1 -0
- package/dist/test/dns.js +8 -0
- package/dist/test/dns.js.map +1 -0
- package/dist/test/setup.d.ts +2 -0
- package/dist/test/setup.d.ts.map +1 -0
- package/dist/test/setup.js +7 -0
- package/dist/test/setup.js.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -0
- package/dist/types/index.d.ts +60 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +2 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/internal.d.ts +25 -0
- package/dist/types/internal.d.ts.map +1 -0
- package/dist/types/internal.js +18 -0
- package/dist/types/internal.js.map +1 -0
- package/dist/utils/ccipBatchRequest.d.ts +3 -0
- package/dist/utils/ccipBatchRequest.d.ts.map +1 -0
- package/dist/utils/ccipBatchRequest.js +4 -1
- package/dist/utils/ccipBatchRequest.js.map +1 -1
- package/dist/utils/ccipRequest.d.ts +4 -1
- package/dist/utils/ccipRequest.d.ts.map +1 -0
- package/dist/utils/ccipRequest.js +4 -3
- package/dist/utils/ccipRequest.js.map +1 -1
- package/dist/utils/clientWithOverrides.d.ts +8 -0
- package/dist/utils/clientWithOverrides.d.ts.map +1 -0
- package/dist/utils/clientWithOverrides.js +9 -0
- package/dist/utils/clientWithOverrides.js.map +1 -0
- package/dist/utils/coders/clearRecords.d.ts +29 -0
- package/dist/utils/coders/clearRecords.d.ts.map +1 -0
- package/dist/utils/coders/clearRecords.js +12 -0
- package/dist/utils/coders/clearRecords.js.map +1 -0
- package/dist/utils/coders/encodeAbi.d.ts +39 -0
- package/dist/utils/coders/encodeAbi.d.ts.map +1 -0
- package/dist/utils/coders/encodeAbi.js +75 -0
- package/dist/utils/coders/encodeAbi.js.map +1 -0
- package/dist/utils/coders/getAbi.d.ts +65 -0
- package/dist/utils/coders/getAbi.d.ts.map +1 -0
- package/dist/utils/coders/getAbi.js +102 -0
- package/dist/utils/coders/getAbi.js.map +1 -0
- package/dist/utils/coders/getAddress.d.ts +118 -0
- package/dist/utils/coders/getAddress.d.ts.map +1 -0
- package/dist/utils/coders/getAddress.js +99 -0
- package/dist/utils/coders/getAddress.js.map +1 -0
- package/dist/utils/coders/getContentHash.d.ts +35 -0
- package/dist/utils/coders/getContentHash.d.ts.map +1 -0
- package/dist/utils/coders/getContentHash.js +31 -0
- package/dist/utils/coders/getContentHash.js.map +1 -0
- package/dist/utils/coders/getText.d.ts +60 -0
- package/dist/utils/coders/getText.d.ts.map +1 -0
- package/dist/utils/coders/getText.js +32 -0
- package/dist/utils/coders/getText.js.map +1 -0
- package/dist/utils/coders/resolverMulticallParameters.d.ts +27 -0
- package/dist/utils/coders/resolverMulticallParameters.d.ts.map +1 -0
- package/dist/utils/coders/resolverMulticallParameters.js +34 -0
- package/dist/utils/coders/resolverMulticallParameters.js.map +1 -0
- package/dist/utils/coders/setAbi.d.ts +31 -0
- package/dist/utils/coders/setAbi.d.ts.map +1 -0
- package/dist/utils/coders/setAbi.js +14 -0
- package/dist/utils/coders/setAbi.js.map +1 -0
- package/dist/utils/coders/setAddr.d.ts +49 -0
- package/dist/utils/coders/setAddr.d.ts.map +1 -0
- package/dist/utils/coders/setAddr.js +27 -0
- package/dist/utils/coders/setAddr.js.map +1 -0
- package/dist/utils/coders/setContentHash.d.ts +40 -0
- package/dist/utils/coders/setContentHash.d.ts.map +1 -0
- package/dist/utils/coders/setContentHash.js +19 -0
- package/dist/utils/coders/setContentHash.js.map +1 -0
- package/dist/utils/coders/setText.d.ts +45 -0
- package/dist/utils/coders/setText.d.ts.map +1 -0
- package/dist/utils/coders/setText.js +17 -0
- package/dist/utils/coders/setText.js.map +1 -0
- package/dist/utils/consts.d.ts +1 -0
- package/dist/utils/consts.d.ts.map +1 -0
- package/dist/utils/contentHash.d.ts +8 -0
- package/dist/utils/contentHash.d.ts.map +1 -0
- package/dist/utils/contentHash.js +1 -0
- package/dist/utils/contentHash.js.map +1 -1
- package/dist/utils/dns/getDnsTxtRecords.d.ts +4 -1
- package/dist/utils/dns/getDnsTxtRecords.d.ts.map +1 -0
- package/dist/utils/dns/getDnsTxtRecords.js.map +1 -1
- package/dist/utils/dns/misc.d.ts +1 -0
- package/dist/utils/dns/misc.d.ts.map +1 -0
- package/dist/utils/errors/isNullRegistrarOwnerOfError.d.ts +6 -0
- package/dist/utils/errors/isNullRegistrarOwnerOfError.d.ts.map +1 -0
- package/dist/utils/errors/isNullRegistrarOwnerOfError.js +14 -0
- package/dist/utils/errors/isNullRegistrarOwnerOfError.js.map +1 -0
- package/dist/utils/errors/isNullUniversalResolverError.d.ts +6 -0
- package/dist/utils/errors/isNullUniversalResolverError.d.ts.map +1 -0
- package/dist/utils/errors/isNullUniversalResolverError.js +24 -0
- package/dist/utils/errors/isNullUniversalResolverError.js.map +1 -0
- package/dist/utils/errors/isReverseAddressMismatch.d.ts +6 -0
- package/dist/utils/errors/isReverseAddressMismatch.d.ts.map +1 -0
- package/dist/utils/errors/isReverseAddressMismatch.js +16 -0
- package/dist/utils/errors/isReverseAddressMismatch.js.map +1 -0
- package/dist/utils/errors/parseReverseAddressMismatchError.d.ts +5 -0
- package/dist/utils/errors/parseReverseAddressMismatchError.d.ts.map +1 -0
- package/dist/utils/errors/parseReverseAddressMismatchError.js +15 -0
- package/dist/utils/errors/parseReverseAddressMismatchError.js.map +1 -0
- package/dist/utils/format.d.ts +1 -0
- package/dist/utils/format.d.ts.map +1 -0
- package/dist/utils/fuses.d.ts +6 -1
- package/dist/utils/fuses.d.ts.map +1 -0
- package/dist/utils/fuses.js.map +1 -1
- package/dist/utils/generateSupportedContentTypes.d.ts +2 -1
- package/dist/utils/generateSupportedContentTypes.d.ts.map +1 -0
- package/dist/utils/index.d.ts +37 -23
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +36 -23
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/l2RegisterHelpers.d.ts +37 -0
- package/dist/utils/l2RegisterHelpers.d.ts.map +1 -0
- package/dist/utils/l2RegisterHelpers.js +48 -0
- package/dist/utils/l2RegisterHelpers.js.map +1 -0
- package/dist/utils/name/getNameType.d.ts +3 -0
- package/dist/utils/name/getNameType.d.ts.map +1 -0
- package/dist/utils/name/getNameType.js.map +1 -0
- package/dist/utils/name/getNameWithSizedLabels.d.ts +8 -0
- package/dist/utils/name/getNameWithSizedLabels.d.ts.map +1 -0
- package/dist/utils/name/getNameWithSizedLabels.js +18 -0
- package/dist/utils/name/getNameWithSizedLabels.js.map +1 -0
- package/dist/utils/name/hexEncodedName.d.ts +7 -0
- package/dist/utils/name/hexEncodedName.d.ts.map +1 -0
- package/dist/utils/name/hexEncodedName.js +20 -0
- package/dist/utils/name/hexEncodedName.js.map +1 -0
- package/dist/utils/name/labels.d.ts +55 -0
- package/dist/utils/name/labels.d.ts.map +1 -0
- package/dist/utils/name/labels.js +123 -0
- package/dist/utils/name/labels.js.map +1 -0
- package/dist/utils/name/makeLabelNodeAndParent.d.ts +14 -0
- package/dist/utils/name/makeLabelNodeAndParent.d.ts.map +1 -0
- package/dist/utils/name/makeLabelNodeAndParent.js +18 -0
- package/dist/utils/name/makeLabelNodeAndParent.js.map +1 -0
- package/dist/utils/name/normalize.d.ts +25 -0
- package/dist/utils/name/normalize.d.ts.map +1 -0
- package/dist/utils/name/normalize.js +27 -0
- package/dist/utils/name/normalize.js.map +1 -0
- package/dist/utils/name/validation.d.ts +20 -0
- package/dist/utils/name/validation.d.ts.map +1 -0
- package/dist/utils/name/validation.js +70 -0
- package/dist/utils/name/validation.js.map +1 -0
- package/dist/utils/normalizeCoinId.d.ts +15 -0
- package/dist/utils/normalizeCoinId.d.ts.map +1 -0
- package/dist/utils/normalizeCoinId.js +32 -0
- package/dist/utils/normalizeCoinId.js.map +1 -0
- package/dist/utils/nullableAddress.d.ts +3 -0
- package/dist/utils/nullableAddress.d.ts.map +1 -0
- package/dist/utils/nullableAddress.js +3 -0
- package/dist/utils/nullableAddress.js.map +1 -0
- package/dist/utils/ownerFromContract.d.ts +187 -8
- package/dist/utils/ownerFromContract.d.ts.map +1 -0
- package/dist/utils/ownerFromContract.js +20 -22
- package/dist/utils/ownerFromContract.js.map +1 -1
- package/dist/utils/registerHelpers.d.ts +14 -6
- package/dist/utils/registerHelpers.d.ts.map +1 -0
- package/dist/utils/registerHelpers.js +13 -12
- package/dist/utils/registerHelpers.js.map +1 -1
- package/dist/utils/wrapper.d.ts +7 -1
- package/dist/utils/wrapper.d.ts.map +1 -0
- package/dist/utils/wrapper.js +4 -1
- package/dist/utils/wrapper.js.map +1 -1
- package/package.json +29 -14
- package/src/actions/dns/getDnsImportData.ts +109 -0
- package/src/actions/dns/getDnsOffchainData.ts +169 -0
- package/src/actions/dns/getDnsOwner.ts +96 -0
- package/src/actions/dns/importDnsName.ts +175 -0
- package/src/actions/public/getAbiRecord.ts +72 -0
- package/src/actions/public/getAddressRecord.ts +87 -0
- package/src/actions/public/getAvailable.ts +76 -0
- package/src/actions/public/getContentHashRecord.ts +70 -0
- package/src/actions/public/getCredentials.ts +65 -0
- package/src/actions/public/getExpiry.ts +220 -0
- package/src/actions/public/getName.ts +164 -0
- package/src/actions/public/getOwner.ts +278 -0
- package/src/actions/public/getPrice.ts +100 -0
- package/src/actions/public/getRecords.ts +398 -0
- package/src/actions/public/getResolver.ts +71 -0
- package/src/actions/public/getSupportedInterfaces.ts +68 -0
- package/src/actions/public/getTextRecord.ts +74 -0
- package/src/actions/public/getWrapperData.ts +88 -0
- package/src/actions/public/getWrapperName.ts +76 -0
- package/src/actions/public/resolveNameData.ts +143 -0
- package/src/actions/public/v2/getResolverName.ts +50 -0
- package/src/actions/public/v2/getUnderlyingResolver.ts +53 -0
- package/src/actions/subgraph/client.ts +105 -0
- package/src/actions/subgraph/filters.ts +848 -0
- package/src/actions/subgraph/getDecodedName.ts +123 -0
- package/src/actions/subgraph/getNameHistory.ts +286 -0
- package/src/actions/subgraph/getNamesForAddress.ts +353 -0
- package/src/actions/subgraph/getRecordHistory.ts +126 -0
- package/src/actions/subgraph/getResolvedNamesForAddress.ts +60 -0
- package/src/actions/subgraph/getSubgraphRecords.ts +185 -0
- package/src/actions/subgraph/getSubgraphRegistrant.ts +78 -0
- package/src/actions/subgraph/getSubnames.ts +238 -0
- package/src/actions/subgraph/utils.ts +164 -0
- package/src/actions/wallet/clearRecords.ts +135 -0
- package/src/actions/wallet/commitName.ts +191 -0
- package/src/actions/wallet/createSubname.ts +354 -0
- package/src/actions/wallet/deleteSubname.ts +241 -0
- package/src/actions/wallet/registerName.ts +190 -0
- package/src/actions/wallet/renewNames.ts +167 -0
- package/src/actions/wallet/setAbiRecord.ts +176 -0
- package/src/actions/wallet/setAddressRecord.ts +174 -0
- package/src/actions/wallet/setChildFuses.ts +152 -0
- package/src/actions/wallet/setContentHashRecord.ts +134 -0
- package/src/actions/wallet/setFuses.ts +127 -0
- package/src/actions/wallet/setPrimaryName.ts +189 -0
- package/src/actions/wallet/setRecords.ts +174 -0
- package/src/actions/wallet/setResolver.ts +173 -0
- package/src/actions/wallet/setTextRecord.ts +137 -0
- package/src/actions/wallet/transferName.ts +314 -0
- package/src/actions/wallet/unwrapName.ts +194 -0
- package/src/actions/wallet/wrapName.ts +235 -0
- package/src/clients/chain.ts +426 -0
- package/src/contracts/addEnsContracts.ts +14 -12
- package/src/contracts/compositeResolver.ts +23 -0
- package/src/contracts/dedicatedResolver.ts +77 -0
- package/src/contracts/ethRegistrarController.ts +0 -41
- package/src/contracts/getChainContractAddress.ts +25 -18
- package/src/contracts/index.ts +4 -28
- package/src/contracts/l2EthRegistrar.ts +303 -0
- package/src/contracts/multicall.ts +15 -15
- package/src/contracts/publicResolver.ts +10 -3
- package/src/dns.ts +13 -9
- package/src/errors/base.ts +1 -1
- package/src/errors/general.ts +1 -1
- package/src/errors/utils.ts +2 -0
- package/src/errors/version.ts +1 -1
- package/src/exports/chain.ts +1 -0
- package/src/exports/internal.ts +1 -0
- package/src/exports/public/v2.ts +2 -0
- package/src/exports/public.ts +16 -0
- package/src/exports/wallet.ts +18 -0
- package/src/index.ts +0 -28
- package/src/subgraph.ts +28 -9
- package/src/types/index.ts +137 -0
- package/src/types/internal.ts +62 -0
- package/src/utils/ccipBatchRequest.ts +14 -2
- package/src/utils/ccipRequest.ts +24 -3
- package/src/utils/clientWithOverrides.ts +27 -0
- package/src/utils/coders/clearRecords.ts +33 -0
- package/src/utils/coders/encodeAbi.ts +144 -0
- package/src/utils/coders/getAbi.ts +211 -0
- package/src/utils/coders/getAddress.ts +254 -0
- package/src/utils/coders/getContentHash.ts +81 -0
- package/src/utils/coders/getText.ts +104 -0
- package/src/utils/coders/resolverMulticallParameters.ts +109 -0
- package/src/utils/coders/setAbi.ts +44 -0
- package/src/utils/coders/setAddr.ts +64 -0
- package/src/utils/coders/setContentHash.ts +45 -0
- package/src/utils/coders/setText.ts +40 -0
- package/src/utils/contentHash.ts +39 -2
- package/src/utils/dns/getDnsTxtRecords.ts +4 -1
- package/src/utils/errors/isNullRegistrarOwnerOfError.ts +12 -0
- package/src/utils/errors/isNullUniversalResolverError.ts +19 -0
- package/src/utils/errors/parseReverseAddressMismatchError.ts +14 -0
- package/src/utils/fuses.ts +30 -1
- package/src/utils/generateSupportedContentTypes.ts +1 -1
- package/src/utils/index.ts +36 -164
- package/src/utils/l2RegisterHelpers.ts +147 -0
- package/src/utils/name/getNameType.ts +18 -0
- package/src/utils/name/getNameWithSizedLabels.ts +28 -0
- package/src/utils/name/hexEncodedName.ts +33 -0
- package/src/utils/name/labels.ts +178 -0
- package/src/utils/name/makeLabelNodeAndParent.ts +27 -0
- package/src/utils/name/normalize.ts +70 -0
- package/src/utils/name/validation.ts +119 -0
- package/src/utils/normalizeCoinId.ts +65 -0
- package/src/utils/nullableAddress.ts +4 -0
- package/src/utils/ownerFromContract.ts +49 -34
- package/src/utils/registerHelpers.ts +76 -17
- package/src/utils/wrapper.ts +27 -4
- package/dist/clients/public.d.ts +0 -26
- package/dist/clients/public.js +0 -34
- package/dist/clients/public.js.map +0 -1
- package/dist/clients/subgraph.d.ts +0 -25
- package/dist/clients/subgraph.js +0 -31
- package/dist/clients/subgraph.js.map +0 -1
- package/dist/clients/wallet.d.ts +0 -25
- package/dist/clients/wallet.js +0 -30
- package/dist/clients/wallet.js.map +0 -1
- package/dist/contracts/legacyEthRegistrarController.d.ts +0 -262
- package/dist/contracts/legacyEthRegistrarController.js +0 -184
- package/dist/contracts/legacyEthRegistrarController.js.map +0 -1
- package/dist/errors/register.d.ts +0 -9
- package/dist/errors/register.js +0 -14
- package/dist/errors/register.js.map +0 -1
- package/dist/functions/dns/getDnsImportData.d.ts +0 -36
- package/dist/functions/dns/getDnsImportData.js +0 -60
- package/dist/functions/dns/getDnsImportData.js.map +0 -1
- package/dist/functions/dns/getDnsOffchainData.d.ts +0 -27
- package/dist/functions/dns/getDnsOffchainData.js +0 -95
- package/dist/functions/dns/getDnsOffchainData.js.map +0 -1
- package/dist/functions/dns/getDnsOwner.d.ts +0 -24
- package/dist/functions/dns/getDnsOwner.js +0 -54
- package/dist/functions/dns/getDnsOwner.js.map +0 -1
- package/dist/functions/dns/importDnsName.d.ts +0 -61
- package/dist/functions/dns/importDnsName.js +0 -84
- package/dist/functions/dns/importDnsName.js.map +0 -1
- package/dist/functions/dns/types.d.ts +0 -1
- package/dist/functions/dns/types.js.map +0 -1
- package/dist/functions/public/_getAbi.d.ts +0 -19
- package/dist/functions/public/_getAbi.js +0 -82
- package/dist/functions/public/_getAbi.js.map +0 -1
- package/dist/functions/public/_getAddr.d.ts +0 -16
- package/dist/functions/public/_getAddr.js +0 -78
- package/dist/functions/public/_getAddr.js.map +0 -1
- package/dist/functions/public/_getContentHash.d.ts +0 -13
- package/dist/functions/public/_getContentHash.js +0 -36
- package/dist/functions/public/_getContentHash.js.map +0 -1
- package/dist/functions/public/_getText.d.ts +0 -14
- package/dist/functions/public/_getText.js +0 -37
- package/dist/functions/public/_getText.js.map +0 -1
- package/dist/functions/public/batch.d.ts +0 -39
- package/dist/functions/public/batch.js +0 -54
- package/dist/functions/public/batch.js.map +0 -1
- package/dist/functions/public/getAbiRecord.d.ts +0 -34
- package/dist/functions/public/getAbiRecord.js +0 -42
- package/dist/functions/public/getAbiRecord.js.map +0 -1
- package/dist/functions/public/getAddressRecord.d.ts +0 -34
- package/dist/functions/public/getAddressRecord.js +0 -42
- package/dist/functions/public/getAddressRecord.js.map +0 -1
- package/dist/functions/public/getAvailable.d.ts +0 -33
- package/dist/functions/public/getAvailable.js +0 -59
- package/dist/functions/public/getAvailable.js.map +0 -1
- package/dist/functions/public/getContentHashRecord.d.ts +0 -34
- package/dist/functions/public/getContentHashRecord.js +0 -42
- package/dist/functions/public/getContentHashRecord.js.map +0 -1
- package/dist/functions/public/getExpiry.d.ts +0 -44
- package/dist/functions/public/getExpiry.js +0 -137
- package/dist/functions/public/getExpiry.js.map +0 -1
- package/dist/functions/public/getName.d.ts +0 -60
- package/dist/functions/public/getName.js +0 -122
- package/dist/functions/public/getName.js.map +0 -1
- package/dist/functions/public/getOwner.d.ts +0 -73
- package/dist/functions/public/getOwner.js +0 -156
- package/dist/functions/public/getOwner.js.map +0 -1
- package/dist/functions/public/getPrice.d.ts +0 -40
- package/dist/functions/public/getPrice.js +0 -105
- package/dist/functions/public/getPrice.js.map +0 -1
- package/dist/functions/public/getRecords.d.ts +0 -107
- package/dist/functions/public/getRecords.js +0 -252
- package/dist/functions/public/getRecords.js.map +0 -1
- package/dist/functions/public/getResolver.d.ts +0 -33
- package/dist/functions/public/getResolver.js +0 -61
- package/dist/functions/public/getResolver.js.map +0 -1
- package/dist/functions/public/getSupportedInterfaces.d.ts +0 -47
- package/dist/functions/public/getSupportedInterfaces.js +0 -53
- package/dist/functions/public/getSupportedInterfaces.js.map +0 -1
- package/dist/functions/public/getTextRecord.d.ts +0 -34
- package/dist/functions/public/getTextRecord.js +0 -42
- package/dist/functions/public/getTextRecord.js.map +0 -1
- package/dist/functions/public/getWrapperData.d.ts +0 -42
- package/dist/functions/public/getWrapperData.js +0 -77
- package/dist/functions/public/getWrapperData.js.map +0 -1
- package/dist/functions/public/getWrapperName.d.ts +0 -33
- package/dist/functions/public/getWrapperName.js +0 -61
- package/dist/functions/public/getWrapperName.js.map +0 -1
- package/dist/functions/public/multicallWrapper.d.ts +0 -13
- package/dist/functions/public/multicallWrapper.js +0 -55
- package/dist/functions/public/multicallWrapper.js.map +0 -1
- package/dist/functions/public/universalWrapper.d.ts +0 -15
- package/dist/functions/public/universalWrapper.js +0 -79
- package/dist/functions/public/universalWrapper.js.map +0 -1
- package/dist/functions/subgraph/client.d.ts +0 -8
- package/dist/functions/subgraph/client.js +0 -88
- package/dist/functions/subgraph/client.js.map +0 -1
- package/dist/functions/subgraph/events.d.ts +0 -139
- package/dist/functions/subgraph/events.js.map +0 -1
- package/dist/functions/subgraph/filters.d.ts +0 -701
- package/dist/functions/subgraph/filters.js +0 -108
- package/dist/functions/subgraph/filters.js.map +0 -1
- package/dist/functions/subgraph/fragments.d.ts +0 -40
- package/dist/functions/subgraph/fragments.js.map +0 -1
- package/dist/functions/subgraph/getDecodedName.d.ts +0 -29
- package/dist/functions/subgraph/getDecodedName.js +0 -84
- package/dist/functions/subgraph/getDecodedName.js.map +0 -1
- package/dist/functions/subgraph/getNameHistory.d.ts +0 -53
- package/dist/functions/subgraph/getNameHistory.js +0 -248
- package/dist/functions/subgraph/getNameHistory.js.map +0 -1
- package/dist/functions/subgraph/getNamesForAddress.d.ts +0 -64
- package/dist/functions/subgraph/getNamesForAddress.js +0 -214
- package/dist/functions/subgraph/getNamesForAddress.js.map +0 -1
- package/dist/functions/subgraph/getSubgraphRecords.d.ts +0 -45
- package/dist/functions/subgraph/getSubgraphRecords.js +0 -103
- package/dist/functions/subgraph/getSubgraphRecords.js.map +0 -1
- package/dist/functions/subgraph/getSubgraphRegistrant.d.ts +0 -28
- package/dist/functions/subgraph/getSubgraphRegistrant.js +0 -52
- package/dist/functions/subgraph/getSubgraphRegistrant.js.map +0 -1
- package/dist/functions/subgraph/getSubnames.d.ts +0 -42
- package/dist/functions/subgraph/getSubnames.js +0 -159
- package/dist/functions/subgraph/getSubnames.js.map +0 -1
- package/dist/functions/subgraph/types.d.ts +0 -12
- package/dist/functions/subgraph/types.js.map +0 -1
- package/dist/functions/subgraph/utils.d.ts +0 -38
- package/dist/functions/subgraph/utils.js +0 -53
- package/dist/functions/subgraph/utils.js.map +0 -1
- package/dist/functions/wallet/clearRecords.d.ts +0 -40
- package/dist/functions/wallet/clearRecords.js +0 -45
- package/dist/functions/wallet/clearRecords.js.map +0 -1
- package/dist/functions/wallet/commitName.d.ts +0 -40
- package/dist/functions/wallet/commitName.js +0 -76
- package/dist/functions/wallet/commitName.js.map +0 -1
- package/dist/functions/wallet/createSubname.d.ts +0 -61
- package/dist/functions/wallet/createSubname.js +0 -148
- package/dist/functions/wallet/createSubname.js.map +0 -1
- package/dist/functions/wallet/deleteSubname.d.ts +0 -42
- package/dist/functions/wallet/deleteSubname.js +0 -125
- package/dist/functions/wallet/deleteSubname.js.map +0 -1
- package/dist/functions/wallet/legacyCommitName.d.ts +0 -40
- package/dist/functions/wallet/legacyCommitName.js +0 -72
- package/dist/functions/wallet/legacyCommitName.js.map +0 -1
- package/dist/functions/wallet/legacyRegisterName.d.ts +0 -59
- package/dist/functions/wallet/legacyRegisterName.js +0 -93
- package/dist/functions/wallet/legacyRegisterName.js.map +0 -1
- package/dist/functions/wallet/registerName.d.ts +0 -59
- package/dist/functions/wallet/registerName.js +0 -92
- package/dist/functions/wallet/registerName.js.map +0 -1
- package/dist/functions/wallet/renewNames.d.ts +0 -58
- package/dist/functions/wallet/renewNames.js +0 -94
- package/dist/functions/wallet/renewNames.js.map +0 -1
- package/dist/functions/wallet/setAbiRecord.d.ts +0 -48
- package/dist/functions/wallet/setAbiRecord.js +0 -54
- package/dist/functions/wallet/setAbiRecord.js.map +0 -1
- package/dist/functions/wallet/setAddressRecord.d.ts +0 -46
- package/dist/functions/wallet/setAddressRecord.js +0 -49
- package/dist/functions/wallet/setAddressRecord.js.map +0 -1
- package/dist/functions/wallet/setChildFuses.d.ts +0 -47
- package/dist/functions/wallet/setChildFuses.js +0 -57
- package/dist/functions/wallet/setChildFuses.js.map +0 -1
- package/dist/functions/wallet/setContentHashRecord.d.ts +0 -43
- package/dist/functions/wallet/setContentHashRecord.js +0 -47
- package/dist/functions/wallet/setContentHashRecord.js.map +0 -1
- package/dist/functions/wallet/setFuses.d.ts +0 -43
- package/dist/functions/wallet/setFuses.js +0 -52
- package/dist/functions/wallet/setFuses.js.map +0 -1
- package/dist/functions/wallet/setPrimaryName.d.ts +0 -50
- package/dist/functions/wallet/setPrimaryName.js +0 -76
- package/dist/functions/wallet/setPrimaryName.js.map +0 -1
- package/dist/functions/wallet/setRecords.d.ts +0 -48
- package/dist/functions/wallet/setRecords.js +0 -75
- package/dist/functions/wallet/setRecords.js.map +0 -1
- package/dist/functions/wallet/setResolver.d.ts +0 -43
- package/dist/functions/wallet/setResolver.js +0 -67
- package/dist/functions/wallet/setResolver.js.map +0 -1
- package/dist/functions/wallet/setTextRecord.d.ts +0 -46
- package/dist/functions/wallet/setTextRecord.js +0 -49
- package/dist/functions/wallet/setTextRecord.js.map +0 -1
- package/dist/functions/wallet/transferName.d.ts +0 -57
- package/dist/functions/wallet/transferName.js +0 -159
- package/dist/functions/wallet/transferName.js.map +0 -1
- package/dist/functions/wallet/unwrapName.d.ts +0 -52
- package/dist/functions/wallet/unwrapName.js +0 -82
- package/dist/functions/wallet/unwrapName.js.map +0 -1
- package/dist/functions/wallet/wrapName.d.ts +0 -45
- package/dist/functions/wallet/wrapName.js +0 -97
- package/dist/functions/wallet/wrapName.js.map +0 -1
- package/dist/public.d.ts +0 -20
- package/dist/public.js +0 -21
- package/dist/public.js.map +0 -1
- package/dist/types.d.ts +0 -66
- package/dist/types.js +0 -2
- package/dist/types.js.map +0 -1
- package/dist/utils/checkSafeUniversalResolverData.d.ts +0 -13
- package/dist/utils/checkSafeUniversalResolverData.js +0 -39
- package/dist/utils/checkSafeUniversalResolverData.js.map +0 -1
- package/dist/utils/encoders/encodeAbi.d.ts +0 -28
- package/dist/utils/encoders/encodeAbi.js +0 -64
- package/dist/utils/encoders/encodeAbi.js.map +0 -1
- package/dist/utils/encoders/encodeClearRecords.d.ts +0 -2
- package/dist/utils/encoders/encodeClearRecords.js +0 -8
- package/dist/utils/encoders/encodeClearRecords.js.map +0 -1
- package/dist/utils/encoders/encodeSetAbi.d.ts +0 -7
- package/dist/utils/encoders/encodeSetAbi.js +0 -10
- package/dist/utils/encoders/encodeSetAbi.js.map +0 -1
- package/dist/utils/encoders/encodeSetAddr.d.ts +0 -8
- package/dist/utils/encoders/encodeSetAddr.js +0 -19
- package/dist/utils/encoders/encodeSetAddr.js.map +0 -1
- package/dist/utils/encoders/encodeSetContentHash.d.ts +0 -7
- package/dist/utils/encoders/encodeSetContentHash.js +0 -15
- package/dist/utils/encoders/encodeSetContentHash.js.map +0 -1
- package/dist/utils/encoders/encodeSetText.d.ts +0 -8
- package/dist/utils/encoders/encodeSetText.js +0 -10
- package/dist/utils/encoders/encodeSetText.js.map +0 -1
- package/dist/utils/generateFunction.d.ts +0 -22
- package/dist/utils/generateFunction.js +0 -26
- package/dist/utils/generateFunction.js.map +0 -1
- package/dist/utils/generateRecordCallArray.d.ts +0 -20
- package/dist/utils/generateRecordCallArray.js +0 -36
- package/dist/utils/generateRecordCallArray.js.map +0 -1
- package/dist/utils/getNameType.d.ts +0 -2
- package/dist/utils/getNameType.js.map +0 -1
- package/dist/utils/getRevertErrorData.d.ts +0 -1
- package/dist/utils/getRevertErrorData.js +0 -11
- package/dist/utils/getRevertErrorData.js.map +0 -1
- package/dist/utils/hexEncodedName.d.ts +0 -3
- package/dist/utils/hexEncodedName.js +0 -43
- package/dist/utils/hexEncodedName.js.map +0 -1
- package/dist/utils/labels.d.ts +0 -9
- package/dist/utils/labels.js +0 -76
- package/dist/utils/labels.js.map +0 -1
- package/dist/utils/legacyRegisterHelpers.d.ts +0 -48
- package/dist/utils/legacyRegisterHelpers.js +0 -45
- package/dist/utils/legacyRegisterHelpers.js.map +0 -1
- package/dist/utils/makeLabelNodeAndParent.d.ts +0 -5
- package/dist/utils/makeLabelNodeAndParent.js +0 -13
- package/dist/utils/makeLabelNodeAndParent.js.map +0 -1
- package/dist/utils/makeSafeSecondsDate.d.ts +0 -1
- package/dist/utils/makeSafeSecondsDate.js +0 -8
- package/dist/utils/makeSafeSecondsDate.js.map +0 -1
- package/dist/utils/normalise.d.ts +0 -11
- package/dist/utils/normalise.js +0 -33
- package/dist/utils/normalise.js.map +0 -1
- package/dist/utils/normaliseCoinId.d.ts +0 -9
- package/dist/utils/normaliseCoinId.js +0 -30
- package/dist/utils/normaliseCoinId.js.map +0 -1
- package/dist/utils/validation.d.ts +0 -13
- package/dist/utils/validation.js +0 -60
- package/dist/utils/validation.js.map +0 -1
- package/dist/wallet.d.ts +0 -20
- package/dist/wallet.js +0 -21
- package/dist/wallet.js.map +0 -1
- package/src/clients/decorators/public.ts +0 -420
- package/src/clients/decorators/subgraph.ts +0 -195
- package/src/clients/decorators/wallet.ts +0 -746
- package/src/clients/public.ts +0 -84
- package/src/clients/subgraph.ts +0 -75
- package/src/clients/wallet.ts +0 -96
- package/src/contracts/consts.ts +0 -236
- package/src/contracts/legacyEthRegistrarController.ts +0 -194
- package/src/errors/register.ts +0 -22
- package/src/functions/dns/getDnsImportData.ts +0 -102
- package/src/functions/dns/getDnsOffchainData.ts +0 -152
- package/src/functions/dns/getDnsOwner.ts +0 -89
- package/src/functions/dns/importDnsName.ts +0 -171
- package/src/functions/public/_getAbi.ts +0 -126
- package/src/functions/public/_getAddr.ts +0 -121
- package/src/functions/public/_getContentHash.ts +0 -60
- package/src/functions/public/_getText.ts +0 -59
- package/src/functions/public/batch.ts +0 -101
- package/src/functions/public/getAbiRecord.ts +0 -87
- package/src/functions/public/getAddressRecord.ts +0 -88
- package/src/functions/public/getAvailable.ts +0 -92
- package/src/functions/public/getContentHashRecord.ts +0 -84
- package/src/functions/public/getExpiry.ts +0 -200
- package/src/functions/public/getName.ts +0 -197
- package/src/functions/public/getOwner.ts +0 -277
- package/src/functions/public/getPrice.ts +0 -148
- package/src/functions/public/getRecords.ts +0 -505
- package/src/functions/public/getResolver.ts +0 -101
- package/src/functions/public/getSupportedInterfaces.ts +0 -114
- package/src/functions/public/getTextRecord.ts +0 -83
- package/src/functions/public/getWrapperData.ts +0 -129
- package/src/functions/public/getWrapperName.ts +0 -98
- package/src/functions/public/multicallWrapper.ts +0 -88
- package/src/functions/public/universalWrapper.ts +0 -122
- package/src/functions/subgraph/client.ts +0 -103
- package/src/functions/subgraph/filters.ts +0 -848
- package/src/functions/subgraph/getDecodedName.ts +0 -121
- package/src/functions/subgraph/getNameHistory.ts +0 -328
- package/src/functions/subgraph/getNamesForAddress.ts +0 -347
- package/src/functions/subgraph/getSubgraphRecords.ts +0 -183
- package/src/functions/subgraph/getSubgraphRegistrant.ts +0 -76
- package/src/functions/subgraph/getSubnames.ts +0 -236
- package/src/functions/subgraph/utils.ts +0 -92
- package/src/functions/wallet/clearRecords.ts +0 -98
- package/src/functions/wallet/commitName.ts +0 -132
- package/src/functions/wallet/createSubname.ts +0 -276
- package/src/functions/wallet/deleteSubname.ts +0 -192
- package/src/functions/wallet/legacyCommitName.ts +0 -127
- package/src/functions/wallet/legacyRegisterName.ts +0 -159
- package/src/functions/wallet/registerName.ts +0 -156
- package/src/functions/wallet/renewNames.ts +0 -153
- package/src/functions/wallet/setAbiRecord.ts +0 -114
- package/src/functions/wallet/setAddressRecord.ts +0 -108
- package/src/functions/wallet/setChildFuses.ts +0 -113
- package/src/functions/wallet/setContentHashRecord.ts +0 -103
- package/src/functions/wallet/setFuses.ts +0 -107
- package/src/functions/wallet/setPrimaryName.ts +0 -156
- package/src/functions/wallet/setRecords.ts +0 -135
- package/src/functions/wallet/setResolver.ts +0 -127
- package/src/functions/wallet/setTextRecord.ts +0 -108
- package/src/functions/wallet/transferName.ts +0 -264
- package/src/functions/wallet/unwrapName.ts +0 -173
- package/src/functions/wallet/wrapName.ts +0 -189
- package/src/public.ts +0 -100
- package/src/types.ts +0 -131
- package/src/utils/checkSafeUniversalResolverData.ts +0 -62
- package/src/utils/encoders/encodeAbi.ts +0 -104
- package/src/utils/encoders/encodeClearRecords.ts +0 -9
- package/src/utils/encoders/encodeSetAbi.ts +0 -21
- package/src/utils/encoders/encodeSetAddr.ts +0 -32
- package/src/utils/encoders/encodeSetContentHash.ts +0 -25
- package/src/utils/encoders/encodeSetText.ts +0 -22
- package/src/utils/generateFunction.ts +0 -83
- package/src/utils/generateRecordCallArray.ts +0 -74
- package/src/utils/getNameType.ts +0 -18
- package/src/utils/getRevertErrorData.ts +0 -9
- package/src/utils/hexEncodedName.ts +0 -49
- package/src/utils/labels.ts +0 -96
- package/src/utils/legacyRegisterHelpers.ts +0 -147
- package/src/utils/makeLabelNodeAndParent.ts +0 -13
- package/src/utils/makeSafeSecondsDate.ts +0 -7
- package/src/utils/normalise.ts +0 -75
- package/src/utils/normaliseCoinId.ts +0 -36
- package/src/utils/validation.ts +0 -79
- package/src/wallet.ts +0 -140
- /package/dist/{functions → actions}/dns/types.js +0 -0
- /package/dist/{functions → actions}/subgraph/events.js +0 -0
- /package/dist/{functions → actions}/subgraph/fragments.js +0 -0
- /package/dist/{functions → actions}/subgraph/types.js +0 -0
- /package/dist/utils/{getNameType.js → name/getNameType.js} +0 -0
- /package/src/{functions → actions}/dns/types.ts +0 -0
- /package/src/{functions → actions}/subgraph/events.ts +0 -0
- /package/src/{functions → actions}/subgraph/fragments.ts +0 -0
- /package/src/{functions → actions}/subgraph/types.ts +0 -0
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { type Chain, type Hex } from 'viem';
|
|
2
|
+
import type { RequireClientContracts } from '../../clients/chain.js';
|
|
3
|
+
import { DnsNewerRecordTypeAvailableError } from '../../errors/dns.js';
|
|
4
|
+
import type { Endpoint } from './types.js';
|
|
5
|
+
export type GetDnsImportDataParameters = {
|
|
6
|
+
/** Name to prepare for DNS import */
|
|
7
|
+
name: string;
|
|
8
|
+
/** An RFC-1035 compatible DNS endpoint to use (default: `https://cloudflare-dns.com/dns-query`) */
|
|
9
|
+
endpoint?: Endpoint;
|
|
10
|
+
};
|
|
11
|
+
export type GetDnsImportDataReturnType = RrSetWithSig[];
|
|
12
|
+
export type GetDnsImportDataErrorType = DnsNewerRecordTypeAvailableError | Error;
|
|
13
|
+
export type RrSetWithSig = {
|
|
14
|
+
rrset: Hex;
|
|
15
|
+
sig: Hex;
|
|
16
|
+
};
|
|
17
|
+
/**
|
|
18
|
+
* Gets DNS import data, used for `importDnsName()`
|
|
19
|
+
* @param client - {@link Client}
|
|
20
|
+
* @param parameters - {@link GetDnsImportDataParameters}
|
|
21
|
+
* @returns DNS import data object, used for proving the value of the `_ens` TXT record
|
|
22
|
+
*
|
|
23
|
+
* @example
|
|
24
|
+
* import { createPublicClient, http } from 'viem'
|
|
25
|
+
* import { mainnet } from 'viem/chains'
|
|
26
|
+
* import { addEnsContracts } from '@ensdomains/ensjs'
|
|
27
|
+
* import { getDnsImportData } from '@ensdomains/ensjs/dns'
|
|
28
|
+
*
|
|
29
|
+
* const client = createPublicClient({
|
|
30
|
+
* chain: addEnsContracts(mainnet),
|
|
31
|
+
* transport: http(),
|
|
32
|
+
* })
|
|
33
|
+
* const data = await getDnsImportData(client, {
|
|
34
|
+
* name: 'example.eth',
|
|
35
|
+
* })
|
|
36
|
+
*/
|
|
37
|
+
export declare function getDnsImportData<_chain extends Chain>(client: RequireClientContracts<_chain, 'ensDnssecImpl'>, { name, endpoint, }: GetDnsImportDataParameters): Promise<GetDnsImportDataReturnType>;
|
|
38
|
+
//# sourceMappingURL=getDnsImportData.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getDnsImportData.d.ts","sourceRoot":"","sources":["../../../src/actions/dns/getDnsImportData.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,KAAK,KAAK,EAGV,KAAK,GAAG,EAET,MAAM,MAAM,CAAA;AAEb,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,wBAAwB,CAAA;AAEpE,OAAO,EAAE,gCAAgC,EAAE,MAAM,qBAAqB,CAAA;AAEtE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAE1C,MAAM,MAAM,0BAA0B,GAAG;IACvC,qCAAqC;IACrC,IAAI,EAAE,MAAM,CAAA;IACZ,mGAAmG;IACnG,QAAQ,CAAC,EAAE,QAAQ,CAAA;CACpB,CAAA;AAED,MAAM,MAAM,0BAA0B,GAAG,YAAY,EAAE,CAAA;AAEvD,MAAM,MAAM,yBAAyB,GAAG,gCAAgC,GAAG,KAAK,CAAA;AAEhF,MAAM,MAAM,YAAY,GAAG;IACzB,KAAK,EAAE,GAAG,CAAA;IACV,GAAG,EAAE,GAAG,CAAA;CACT,CAAA;AAcD;;;;;;;;;;;;;;;;;;;GAmBG;AACH,wBAAsB,gBAAgB,CAAC,MAAM,SAAS,KAAK,EACzD,MAAM,EAAE,sBAAsB,CAAC,MAAM,EAAE,eAAe,CAAC,EACvD,EACE,IAAI,EACJ,QAAiD,GAClD,EAAE,0BAA0B,GAC5B,OAAO,CAAC,0BAA0B,CAAC,CAsCrC"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { getChainContractAddress, toHex, } from 'viem';
|
|
2
|
+
import { readContract } from 'viem/actions';
|
|
3
|
+
import { dnssecImplVerifyRrSetSnippet } from '../../contracts/dnssecImpl.js';
|
|
4
|
+
import { DnsNewerRecordTypeAvailableError } from '../../errors/dns.js';
|
|
5
|
+
import { ASSERT_NO_TYPE_ERROR } from '../../types/internal.js';
|
|
6
|
+
// Compares two serial numbers using RFC1982 serial number math.
|
|
7
|
+
const serialNumberGt = (i1, i2) => (i1 < i2 && i2 - i1 > 0x7fffffff) || (i1 > i2 && i1 - i2 < 0x7fffffff);
|
|
8
|
+
const encodeProofs = (proofs) => proofs.map((proof) => ({
|
|
9
|
+
rrset: toHex(proof.toWire(true)),
|
|
10
|
+
sig: toHex(proof.signature.data.signature),
|
|
11
|
+
}));
|
|
12
|
+
/**
|
|
13
|
+
* Gets DNS import data, used for `importDnsName()`
|
|
14
|
+
* @param client - {@link Client}
|
|
15
|
+
* @param parameters - {@link GetDnsImportDataParameters}
|
|
16
|
+
* @returns DNS import data object, used for proving the value of the `_ens` TXT record
|
|
17
|
+
*
|
|
18
|
+
* @example
|
|
19
|
+
* import { createPublicClient, http } from 'viem'
|
|
20
|
+
* import { mainnet } from 'viem/chains'
|
|
21
|
+
* import { addEnsContracts } from '@ensdomains/ensjs'
|
|
22
|
+
* import { getDnsImportData } from '@ensdomains/ensjs/dns'
|
|
23
|
+
*
|
|
24
|
+
* const client = createPublicClient({
|
|
25
|
+
* chain: addEnsContracts(mainnet),
|
|
26
|
+
* transport: http(),
|
|
27
|
+
* })
|
|
28
|
+
* const data = await getDnsImportData(client, {
|
|
29
|
+
* name: 'example.eth',
|
|
30
|
+
* })
|
|
31
|
+
*/
|
|
32
|
+
export async function getDnsImportData(client, { name, endpoint = 'https://cloudflare-dns.com/dns-query', }) {
|
|
33
|
+
ASSERT_NO_TYPE_ERROR(client);
|
|
34
|
+
const { DNSProver } = await import('@ensdomains/dnsprovejs');
|
|
35
|
+
const prover = DNSProver.create(endpoint);
|
|
36
|
+
const result = (await prover.queryWithProof('TXT', `_ens.${name}`));
|
|
37
|
+
const allProofs = result.proofs.concat([result.answer]);
|
|
38
|
+
const rrsets = encodeProofs(allProofs);
|
|
39
|
+
const [onchainRrData, inception] = await readContract(client, {
|
|
40
|
+
abi: dnssecImplVerifyRrSetSnippet,
|
|
41
|
+
address: getChainContractAddress({
|
|
42
|
+
chain: client.chain,
|
|
43
|
+
contract: 'ensDnssecImpl',
|
|
44
|
+
}),
|
|
45
|
+
functionName: 'verifyRRSet',
|
|
46
|
+
args: [rrsets],
|
|
47
|
+
});
|
|
48
|
+
const lastProof = allProofs[allProofs.length - 1];
|
|
49
|
+
if (serialNumberGt(inception, lastProof.signature.data.inception))
|
|
50
|
+
throw new DnsNewerRecordTypeAvailableError({
|
|
51
|
+
typeCovered: lastProof.signature.data.typeCovered,
|
|
52
|
+
signatureName: lastProof.signature.name,
|
|
53
|
+
onchainInception: inception,
|
|
54
|
+
dnsInception: lastProof.signature.data.inception,
|
|
55
|
+
});
|
|
56
|
+
if (toHex(lastProof.toWire(false)) !== onchainRrData)
|
|
57
|
+
throw new Error('Mismatched proof data');
|
|
58
|
+
return rrsets;
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=getDnsImportData.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getDnsImportData.js","sourceRoot":"","sources":["../../../src/actions/dns/getDnsImportData.ts"],"names":[],"mappings":"AAEA,OAAO,EAGL,uBAAuB,EAEvB,KAAK,GACN,MAAM,MAAM,CAAA;AACb,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAA;AAE3C,OAAO,EAAE,4BAA4B,EAAE,MAAM,+BAA+B,CAAA;AAC5E,OAAO,EAAE,gCAAgC,EAAE,MAAM,qBAAqB,CAAA;AACtE,OAAO,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAA;AAmB9D,gEAAgE;AAChE,MAAM,cAAc,GAAG,CAAC,EAAU,EAAE,EAAU,EAAW,EAAE,CACzD,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,UAAU,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,UAAU,CAAC,CAAA;AAExE,MAAM,YAAY,GAAG,CACnB,MAA4D,EAC5C,EAAE,CAClB,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;IACrB,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAChC,GAAG,EAAE,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC;CAC3C,CAAC,CAAC,CAAA;AAEL;;;;;;;;;;;;;;;;;;;GAmBG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB,CACpC,MAAuD,EACvD,EACE,IAAI,EACJ,QAAQ,GAAG,sCAAsC,GACtB;IAE7B,oBAAoB,CAAC,MAAM,CAAC,CAAA;IAC5B,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,MAAM,CAAC,wBAAwB,CAAC,CAAA;IAC5D,MAAM,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAA;IACzC,MAAM,MAAM,GAAG,CAAC,MAAM,MAAM,CAAC,cAAc,CACzC,KAAK,EACL,QAAQ,IAAI,EAAE,CACf,CAAgC,CAAA;IAEjC,MAAM,SAAS,GACb,MAAM,CAAC,MACR,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAA;IAEzB,MAAM,MAAM,GAAG,YAAY,CAAC,SAAS,CAAC,CAAA;IAEtC,MAAM,CAAC,aAAa,EAAE,SAAS,CAAC,GAAG,MAAM,YAAY,CAAC,MAAM,EAAE;QAC5D,GAAG,EAAE,4BAA4B;QACjC,OAAO,EAAE,uBAAuB,CAAC;YAC/B,KAAK,EAAE,MAAM,CAAC,KAAK;YACnB,QAAQ,EAAE,eAAe;SAC1B,CAAC;QACF,YAAY,EAAE,aAAa;QAC3B,IAAI,EAAE,CAAC,MAAM,CAAC;KACf,CAAC,CAAA;IAEF,MAAM,SAAS,GAAG,SAAS,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;IACjD,IAAI,cAAc,CAAC,SAAS,EAAE,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC;QAC/D,MAAM,IAAI,gCAAgC,CAAC;YACzC,WAAW,EAAE,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW;YACjD,aAAa,EAAE,SAAS,CAAC,SAAS,CAAC,IAAI;YACvC,gBAAgB,EAAE,SAAS;YAC3B,YAAY,EAAE,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS;SACjD,CAAC,CAAA;IAEJ,IAAI,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,KAAK,aAAa;QAClD,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAA;IAE1C,OAAO,MAAM,CAAA;AACf,CAAC"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { type Address, type Chain } from 'viem';
|
|
2
|
+
import type { RequireClientContracts } from '../../clients/chain.js';
|
|
3
|
+
import { DnsDnssecVerificationFailedError, DnsDnssecWildcardExpansionError, DnsInvalidTxtRecordError, DnsNoTxtRecordError, DnsResponseStatusError } from '../../errors/dns.js';
|
|
4
|
+
import { UnsupportedNameTypeError } from '../../errors/general.js';
|
|
5
|
+
import type { Endpoint } from './types.js';
|
|
6
|
+
export type GetDnsOffchainDataParameters = {
|
|
7
|
+
/** Name to get the offchain data for */
|
|
8
|
+
name: string;
|
|
9
|
+
/** An RFC-1035 compatible DNS endpoint to use (default: `https://cloudflare-dns.com/dns-query`) */
|
|
10
|
+
endpoint?: Endpoint;
|
|
11
|
+
/** Whether or not to throw errors */
|
|
12
|
+
strict?: boolean;
|
|
13
|
+
};
|
|
14
|
+
export type GetDnsOffchainDataReturnType = {
|
|
15
|
+
resolverAddress: Address;
|
|
16
|
+
extraData: string | null;
|
|
17
|
+
} | null;
|
|
18
|
+
export type GetDnsOffchainDataErrorType = DnsDnssecVerificationFailedError | DnsDnssecWildcardExpansionError | DnsInvalidTxtRecordError | DnsNoTxtRecordError | DnsResponseStatusError | UnsupportedNameTypeError | Error;
|
|
19
|
+
/**
|
|
20
|
+
* Gets the DNS offchain data for a name, via DNS record lookup
|
|
21
|
+
* @param client - {@link Client}
|
|
22
|
+
* @param parameters - {@link GetDnsOffchainDataParameters}
|
|
23
|
+
* @returns Resolver address and extra data, or null. {@link GetDnsOffchainDataReturnType}
|
|
24
|
+
*
|
|
25
|
+
* @example
|
|
26
|
+
* import { createPublicClient, http } from 'viem'
|
|
27
|
+
* import { mainnet } from 'viem/chains'
|
|
28
|
+
* import { addEnsContracts } from '@ensdomains/ensjs'
|
|
29
|
+
* import { getDnsOffchainData } from '@ensdomains/ensjs/dns'
|
|
30
|
+
*
|
|
31
|
+
* const client = createPublicClient({
|
|
32
|
+
* chain: addEnsContracts(mainnet),
|
|
33
|
+
* transport: http(),
|
|
34
|
+
* })
|
|
35
|
+
* const data = await getDnsOffchainData(client, {
|
|
36
|
+
* name: 'ethleaderboard.xyz',
|
|
37
|
+
* })
|
|
38
|
+
*/
|
|
39
|
+
export declare function getDnsOffchainData<chain extends Chain>(client: RequireClientContracts<chain, 'ensUniversalResolver'>, { name, endpoint, strict }: GetDnsOffchainDataParameters): Promise<GetDnsOffchainDataReturnType>;
|
|
40
|
+
//# sourceMappingURL=getDnsOffchainData.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getDnsOffchainData.d.ts","sourceRoot":"","sources":["../../../src/actions/dns/getDnsOffchainData.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,OAAO,EAAE,KAAK,KAAK,EAAa,MAAM,MAAM,CAAA;AAC1D,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,wBAAwB,CAAA;AACpE,OAAO,EACL,gCAAgC,EAChC,+BAA+B,EAC/B,wBAAwB,EACxB,mBAAmB,EACnB,sBAAsB,EACvB,MAAM,qBAAqB,CAAA;AAC5B,OAAO,EAAE,wBAAwB,EAAE,MAAM,yBAAyB,CAAA;AASlE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAE1C,MAAM,MAAM,4BAA4B,GAAG;IACzC,wCAAwC;IACxC,IAAI,EAAE,MAAM,CAAA;IACZ,mGAAmG;IACnG,QAAQ,CAAC,EAAE,QAAQ,CAAA;IACnB,qCAAqC;IACrC,MAAM,CAAC,EAAE,OAAO,CAAA;CACjB,CAAA;AAED,MAAM,MAAM,4BAA4B,GAAG;IACzC,eAAe,EAAE,OAAO,CAAA;IACxB,SAAS,EAAE,MAAM,GAAG,IAAI,CAAA;CACzB,GAAG,IAAI,CAAA;AAER,MAAM,MAAM,2BAA2B,GACnC,gCAAgC,GAChC,+BAA+B,GAC/B,wBAAwB,GACxB,mBAAmB,GACnB,sBAAsB,GACtB,wBAAwB,GACxB,KAAK,CAAA;AA8CT;;;;;;;;;;;;;;;;;;;GAmBG;AACH,wBAAsB,kBAAkB,CAAC,KAAK,SAAS,KAAK,EAC1D,MAAM,EAAE,sBAAsB,CAAC,KAAK,EAAE,sBAAsB,CAAC,EAC7D,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,4BAA4B,GACvD,OAAO,CAAC,4BAA4B,CAAC,CA0DvC"}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { isAddress } from 'viem';
|
|
2
|
+
import { DnsDnssecVerificationFailedError, DnsDnssecWildcardExpansionError, DnsInvalidTxtRecordError, DnsNoTxtRecordError, DnsResponseStatusError, } from '../../errors/dns.js';
|
|
3
|
+
import { UnsupportedNameTypeError } from '../../errors/general.js';
|
|
4
|
+
import { getDnsTxtRecords } from '../../utils/dns/getDnsTxtRecords.js';
|
|
5
|
+
import { DnsRecordType, DnsResponseStatus, } from '../../utils/dns/misc.js';
|
|
6
|
+
import { getNameType } from '../../utils/name/getNameType.js';
|
|
7
|
+
import { getAddressRecord } from '../public/getAddressRecord.js';
|
|
8
|
+
async function checkValidEnsTxtRecord(client, record) {
|
|
9
|
+
if (record.type !== DnsRecordType.TXT)
|
|
10
|
+
return null;
|
|
11
|
+
if (!record.data.startsWith('"ENS1 '))
|
|
12
|
+
return null;
|
|
13
|
+
const unwrappedRecordData = record.data.replace(/^"(.*)"$/g, '$1');
|
|
14
|
+
const resolverAndExtraData = unwrappedRecordData.slice(5);
|
|
15
|
+
const splitIndex = resolverAndExtraData.indexOf(' ');
|
|
16
|
+
const resolverNameOrAddress = splitIndex === -1
|
|
17
|
+
? resolverAndExtraData
|
|
18
|
+
: resolverAndExtraData.slice(0, splitIndex);
|
|
19
|
+
const extraData = splitIndex === -1 ? null : resolverAndExtraData.slice(splitIndex + 1);
|
|
20
|
+
if (isAddress(resolverNameOrAddress))
|
|
21
|
+
return { isValid: true, resolverAddress: resolverNameOrAddress, extraData };
|
|
22
|
+
const resolverAddress = await getAddressRecord(client, {
|
|
23
|
+
name: resolverNameOrAddress,
|
|
24
|
+
// force no ccip-read, since dnsregistrar doesn't allow resolvers with ccip-read addresses
|
|
25
|
+
gatewayUrls: [],
|
|
26
|
+
}).catch(() => null); // if ccip-read is attempted, an error will be thrown. we can just ignore it
|
|
27
|
+
if (resolverAddress)
|
|
28
|
+
return {
|
|
29
|
+
isValid: true,
|
|
30
|
+
resolverAddress: resolverAddress.value,
|
|
31
|
+
extraData,
|
|
32
|
+
};
|
|
33
|
+
return { isValid: false, recordData: unwrappedRecordData };
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Gets the DNS offchain data for a name, via DNS record lookup
|
|
37
|
+
* @param client - {@link Client}
|
|
38
|
+
* @param parameters - {@link GetDnsOffchainDataParameters}
|
|
39
|
+
* @returns Resolver address and extra data, or null. {@link GetDnsOffchainDataReturnType}
|
|
40
|
+
*
|
|
41
|
+
* @example
|
|
42
|
+
* import { createPublicClient, http } from 'viem'
|
|
43
|
+
* import { mainnet } from 'viem/chains'
|
|
44
|
+
* import { addEnsContracts } from '@ensdomains/ensjs'
|
|
45
|
+
* import { getDnsOffchainData } from '@ensdomains/ensjs/dns'
|
|
46
|
+
*
|
|
47
|
+
* const client = createPublicClient({
|
|
48
|
+
* chain: addEnsContracts(mainnet),
|
|
49
|
+
* transport: http(),
|
|
50
|
+
* })
|
|
51
|
+
* const data = await getDnsOffchainData(client, {
|
|
52
|
+
* name: 'ethleaderboard.xyz',
|
|
53
|
+
* })
|
|
54
|
+
*/
|
|
55
|
+
export async function getDnsOffchainData(client, { name, endpoint, strict }) {
|
|
56
|
+
const nameType = getNameType(name);
|
|
57
|
+
if (nameType !== 'other-2ld' && nameType !== 'other-subname')
|
|
58
|
+
throw new UnsupportedNameTypeError({
|
|
59
|
+
nameType,
|
|
60
|
+
supportedNameTypes: ['other-2ld', 'other-subname'],
|
|
61
|
+
});
|
|
62
|
+
try {
|
|
63
|
+
const response = await getDnsTxtRecords({ name, endpoint });
|
|
64
|
+
if (response.Status !== DnsResponseStatus.NOERROR)
|
|
65
|
+
throw new DnsResponseStatusError({
|
|
66
|
+
responseStatus: DnsResponseStatus[response.Status],
|
|
67
|
+
});
|
|
68
|
+
if (response.AD === false)
|
|
69
|
+
throw new DnsDnssecVerificationFailedError({ record: undefined });
|
|
70
|
+
if (!response.Answer?.length)
|
|
71
|
+
throw new DnsNoTxtRecordError();
|
|
72
|
+
const labels = name.split('.');
|
|
73
|
+
const rrsigRecord = response.Answer.find((record) => {
|
|
74
|
+
if (record.type !== DnsRecordType.RRSIG)
|
|
75
|
+
return false;
|
|
76
|
+
if (record.name !== name)
|
|
77
|
+
return false;
|
|
78
|
+
if (!record.data.startsWith('TXT'))
|
|
79
|
+
return false;
|
|
80
|
+
const [, , labelCount] = record.data.split(' ');
|
|
81
|
+
// mismatching label count implies wildcard expansion, which is not supported
|
|
82
|
+
return Number(labelCount) === labels.length;
|
|
83
|
+
});
|
|
84
|
+
if (!rrsigRecord)
|
|
85
|
+
throw new DnsDnssecWildcardExpansionError();
|
|
86
|
+
const ensTxtRecords = await Promise.all(response.Answer.map((record) => checkValidEnsTxtRecord(client, record)));
|
|
87
|
+
const validRecord = ensTxtRecords.find((record) => record?.isValid === true);
|
|
88
|
+
if (validRecord)
|
|
89
|
+
return {
|
|
90
|
+
resolverAddress: validRecord.resolverAddress,
|
|
91
|
+
extraData: validRecord.extraData,
|
|
92
|
+
};
|
|
93
|
+
const invalidRecord = ensTxtRecords.find((record) => record?.isValid === false);
|
|
94
|
+
if (invalidRecord)
|
|
95
|
+
throw new DnsInvalidTxtRecordError({ record: invalidRecord.recordData });
|
|
96
|
+
throw new DnsNoTxtRecordError();
|
|
97
|
+
}
|
|
98
|
+
catch (error) {
|
|
99
|
+
if (!strict)
|
|
100
|
+
return null;
|
|
101
|
+
throw error;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
//# sourceMappingURL=getDnsOffchainData.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getDnsOffchainData.js","sourceRoot":"","sources":["../../../src/actions/dns/getDnsOffchainData.ts"],"names":[],"mappings":"AAAA,OAAO,EAA4B,SAAS,EAAE,MAAM,MAAM,CAAA;AAE1D,OAAO,EACL,gCAAgC,EAChC,+BAA+B,EAC/B,wBAAwB,EACxB,mBAAmB,EACnB,sBAAsB,GACvB,MAAM,qBAAqB,CAAA;AAC5B,OAAO,EAAE,wBAAwB,EAAE,MAAM,yBAAyB,CAAA;AAClE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAA;AACtE,OAAO,EACL,aAAa,EAEb,iBAAiB,GAClB,MAAM,yBAAyB,CAAA;AAChC,OAAO,EAAE,WAAW,EAAE,MAAM,iCAAiC,CAAA;AAC7D,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAA;AAiChE,KAAK,UAAU,sBAAsB,CACnC,MAA6D,EAC7D,MAAuB;IAEvB,IAAI,MAAM,CAAC,IAAI,KAAK,aAAa,CAAC,GAAG;QAAE,OAAO,IAAI,CAAA;IAClD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC;QAAE,OAAO,IAAI,CAAA;IAElD,MAAM,mBAAmB,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,CAAC,CAAA;IAElE,MAAM,oBAAoB,GAAG,mBAAmB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;IACzD,MAAM,UAAU,GAAG,oBAAoB,CAAC,OAAO,CAAC,GAAG,CAAC,CAAA;IACpD,MAAM,qBAAqB,GACzB,UAAU,KAAK,CAAC,CAAC;QACf,CAAC,CAAC,oBAAoB;QACtB,CAAC,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC,EAAE,UAAU,CAAC,CAAA;IAC/C,MAAM,SAAS,GACb,UAAU,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,oBAAoB,CAAC,KAAK,CAAC,UAAU,GAAG,CAAC,CAAC,CAAA;IAEvE,IAAI,SAAS,CAAC,qBAAqB,CAAC;QAClC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,eAAe,EAAE,qBAAqB,EAAE,SAAS,EAAE,CAAA;IAE7E,MAAM,eAAe,GAAG,MAAM,gBAAgB,CAAC,MAAM,EAAE;QACrD,IAAI,EAAE,qBAAqB;QAC3B,0FAA0F;QAC1F,WAAW,EAAE,EAAE;KAChB,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAA,CAAC,4EAA4E;IAEjG,IAAI,eAAe;QACjB,OAAO;YACL,OAAO,EAAE,IAAI;YACb,eAAe,EAAE,eAAe,CAAC,KAAgB;YACjD,SAAS;SACV,CAAA;IAEH,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,mBAAmB,EAAE,CAAA;AAC5D,CAAC;AAED;;;;;;;;;;;;;;;;;;;GAmBG;AACH,MAAM,CAAC,KAAK,UAAU,kBAAkB,CACtC,MAA6D,EAC7D,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,EAAgC;IAExD,MAAM,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,CAAA;IAElC,IAAI,QAAQ,KAAK,WAAW,IAAI,QAAQ,KAAK,eAAe;QAC1D,MAAM,IAAI,wBAAwB,CAAC;YACjC,QAAQ;YACR,kBAAkB,EAAE,CAAC,WAAW,EAAE,eAAe,CAAC;SACnD,CAAC,CAAA;IAEJ,IAAI,CAAC;QACH,MAAM,QAAQ,GAAG,MAAM,gBAAgB,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAA;QAE3D,IAAI,QAAQ,CAAC,MAAM,KAAK,iBAAiB,CAAC,OAAO;YAC/C,MAAM,IAAI,sBAAsB,CAAC;gBAC/B,cAAc,EAAE,iBAAiB,CAAC,QAAQ,CAAC,MAAM,CAAC;aACnD,CAAC,CAAA;QAEJ,IAAI,QAAQ,CAAC,EAAE,KAAK,KAAK;YACvB,MAAM,IAAI,gCAAgC,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC,CAAA;QAEnE,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,MAAM;YAAE,MAAM,IAAI,mBAAmB,EAAE,CAAA;QAE7D,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;QAC9B,MAAM,WAAW,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE;YAClD,IAAI,MAAM,CAAC,IAAI,KAAK,aAAa,CAAC,KAAK;gBAAE,OAAO,KAAK,CAAA;YACrD,IAAI,MAAM,CAAC,IAAI,KAAK,IAAI;gBAAE,OAAO,KAAK,CAAA;YACtC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC;gBAAE,OAAO,KAAK,CAAA;YAChD,MAAM,CAAC,EAAE,AAAD,EAAG,UAAU,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;YAC/C,6EAA6E;YAC7E,OAAO,MAAM,CAAC,UAAU,CAAC,KAAK,MAAM,CAAC,MAAM,CAAA;QAC7C,CAAC,CAAC,CAAA;QAEF,IAAI,CAAC,WAAW;YAAE,MAAM,IAAI,+BAA+B,EAAE,CAAA;QAE7D,MAAM,aAAa,GAAG,MAAM,OAAO,CAAC,GAAG,CACrC,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,sBAAsB,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CACxE,CAAA;QAED,MAAM,WAAW,GAAG,aAAa,CAAC,IAAI,CACpC,CAAC,MAAM,EAA6B,EAAE,CAAC,MAAM,EAAE,OAAO,KAAK,IAAI,CAChE,CAAA;QACD,IAAI,WAAW;YACb,OAAO;gBACL,eAAe,EAAE,WAAW,CAAC,eAAe;gBAC5C,SAAS,EAAE,WAAW,CAAC,SAAS;aACjC,CAAA;QAEH,MAAM,aAAa,GAAG,aAAa,CAAC,IAAI,CACtC,CAAC,MAAM,EAA+B,EAAE,CAAC,MAAM,EAAE,OAAO,KAAK,KAAK,CACnE,CAAA;QACD,IAAI,aAAa;YACf,MAAM,IAAI,wBAAwB,CAAC,EAAE,MAAM,EAAE,aAAa,CAAC,UAAU,EAAE,CAAC,CAAA;QAE1E,MAAM,IAAI,mBAAmB,EAAE,CAAA;IACjC,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,IAAI,CAAC,MAAM;YAAE,OAAO,IAAI,CAAA;QACxB,MAAM,KAAK,CAAA;IACb,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { type Address } from 'viem';
|
|
2
|
+
import { DnsDnssecVerificationFailedError, DnsInvalidAddressChecksumError, DnsInvalidTxtRecordError, DnsNoTxtRecordError, DnsResponseStatusError } from '../../errors/dns.js';
|
|
3
|
+
import { UnsupportedNameTypeError } from '../../errors/general.js';
|
|
4
|
+
import type { Endpoint } from './types.js';
|
|
5
|
+
export type GetDnsOwnerParameters = {
|
|
6
|
+
/** Name to get the owner for */
|
|
7
|
+
name: string;
|
|
8
|
+
/** An RFC-1035 compatible DNS endpoint to use (default: `https://cloudflare-dns.com/dns-query`) */
|
|
9
|
+
endpoint?: Endpoint;
|
|
10
|
+
/** Whether or not to throw errors */
|
|
11
|
+
strict?: boolean;
|
|
12
|
+
};
|
|
13
|
+
export type GetDnsOwnerReturnType = Address | null;
|
|
14
|
+
export type GetDnsOwnerErrorType = DnsDnssecVerificationFailedError | DnsInvalidAddressChecksumError | DnsInvalidTxtRecordError | DnsNoTxtRecordError | DnsResponseStatusError | UnsupportedNameTypeError | Error;
|
|
15
|
+
/**
|
|
16
|
+
* Gets the DNS owner of a name, via DNS record lookup
|
|
17
|
+
* @param parameters - {@link GetDnsOwnerParameters}
|
|
18
|
+
* @returns Address of DNS owner. {@link GetDnsOwnerReturnType}
|
|
19
|
+
*
|
|
20
|
+
* @example
|
|
21
|
+
* import { getDnsOwner } from '@ensdomains/ensjs/dns'
|
|
22
|
+
*
|
|
23
|
+
* const owner = await getDnsOwner({ name: 'ens.domains' })
|
|
24
|
+
* // '0xb8c2C29ee19D8307cb7255e1Cd9CbDE883A267d5'
|
|
25
|
+
*/
|
|
26
|
+
export declare function getDnsOwner({ name, endpoint, strict, }: GetDnsOwnerParameters): Promise<GetDnsOwnerReturnType>;
|
|
27
|
+
//# sourceMappingURL=getDnsOwner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getDnsOwner.d.ts","sourceRoot":"","sources":["../../../src/actions/dns/getDnsOwner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,OAAO,EAAc,MAAM,MAAM,CAAA;AAC/C,OAAO,EACL,gCAAgC,EAChC,8BAA8B,EAC9B,wBAAwB,EACxB,mBAAmB,EACnB,sBAAsB,EACvB,MAAM,qBAAqB,CAAA;AAC5B,OAAO,EAAE,wBAAwB,EAAE,MAAM,yBAAyB,CAAA;AAIlE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAE1C,MAAM,MAAM,qBAAqB,GAAG;IAClC,gCAAgC;IAChC,IAAI,EAAE,MAAM,CAAA;IACZ,mGAAmG;IACnG,QAAQ,CAAC,EAAE,QAAQ,CAAA;IACnB,qCAAqC;IACrC,MAAM,CAAC,EAAE,OAAO,CAAA;CACjB,CAAA;AAED,MAAM,MAAM,qBAAqB,GAAG,OAAO,GAAG,IAAI,CAAA;AAElD,MAAM,MAAM,oBAAoB,GAC5B,gCAAgC,GAChC,8BAA8B,GAC9B,wBAAwB,GACxB,mBAAmB,GACnB,sBAAsB,GACtB,wBAAwB,GACxB,KAAK,CAAA;AAET;;;;;;;;;;GAUG;AACH,wBAAsB,WAAW,CAAC,EAChC,IAAI,EACJ,QAAQ,EACR,MAAM,GACP,EAAE,qBAAqB,GAAG,OAAO,CAAC,qBAAqB,CAAC,CA8CxD"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { getAddress } from 'viem';
|
|
2
|
+
import { DnsDnssecVerificationFailedError, DnsInvalidAddressChecksumError, DnsInvalidTxtRecordError, DnsNoTxtRecordError, DnsResponseStatusError, } from '../../errors/dns.js';
|
|
3
|
+
import { UnsupportedNameTypeError } from '../../errors/general.js';
|
|
4
|
+
import { getDnsTxtRecords } from '../../utils/dns/getDnsTxtRecords.js';
|
|
5
|
+
import { DnsRecordType, DnsResponseStatus } from '../../utils/dns/misc.js';
|
|
6
|
+
import { getNameType } from '../../utils/name/getNameType.js';
|
|
7
|
+
/**
|
|
8
|
+
* Gets the DNS owner of a name, via DNS record lookup
|
|
9
|
+
* @param parameters - {@link GetDnsOwnerParameters}
|
|
10
|
+
* @returns Address of DNS owner. {@link GetDnsOwnerReturnType}
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* import { getDnsOwner } from '@ensdomains/ensjs/dns'
|
|
14
|
+
*
|
|
15
|
+
* const owner = await getDnsOwner({ name: 'ens.domains' })
|
|
16
|
+
* // '0xb8c2C29ee19D8307cb7255e1Cd9CbDE883A267d5'
|
|
17
|
+
*/
|
|
18
|
+
export async function getDnsOwner({ name, endpoint, strict, }) {
|
|
19
|
+
const nameType = getNameType(name);
|
|
20
|
+
if (nameType !== 'other-2ld')
|
|
21
|
+
throw new UnsupportedNameTypeError({
|
|
22
|
+
nameType,
|
|
23
|
+
supportedNameTypes: ['other-2ld'],
|
|
24
|
+
});
|
|
25
|
+
try {
|
|
26
|
+
const response = await getDnsTxtRecords({ name: `_ens.${name}`, endpoint });
|
|
27
|
+
if (response.Status !== DnsResponseStatus.NOERROR)
|
|
28
|
+
throw new DnsResponseStatusError({
|
|
29
|
+
responseStatus: DnsResponseStatus[response.Status],
|
|
30
|
+
});
|
|
31
|
+
const addressRecord = response.Answer?.find((record) => record.type === DnsRecordType.TXT);
|
|
32
|
+
const unwrappedAddressRecord = addressRecord?.data?.replace(/^"(.*)"$/g, '$1');
|
|
33
|
+
if (response.AD === false)
|
|
34
|
+
throw new DnsDnssecVerificationFailedError({
|
|
35
|
+
record: unwrappedAddressRecord,
|
|
36
|
+
});
|
|
37
|
+
if (!addressRecord?.data)
|
|
38
|
+
throw new DnsNoTxtRecordError();
|
|
39
|
+
if (!unwrappedAddressRecord?.match(/^a=0x[a-fA-F0-9]{40}$/g))
|
|
40
|
+
throw new DnsInvalidTxtRecordError({ record: unwrappedAddressRecord });
|
|
41
|
+
const address = unwrappedAddressRecord?.slice(2);
|
|
42
|
+
const checksumAddress = getAddress(address);
|
|
43
|
+
if (address !== checksumAddress)
|
|
44
|
+
throw new DnsInvalidAddressChecksumError({ address });
|
|
45
|
+
return checksumAddress;
|
|
46
|
+
}
|
|
47
|
+
catch (error) {
|
|
48
|
+
if (!strict)
|
|
49
|
+
return null;
|
|
50
|
+
throw error;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
//# sourceMappingURL=getDnsOwner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getDnsOwner.js","sourceRoot":"","sources":["../../../src/actions/dns/getDnsOwner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,UAAU,EAAE,MAAM,MAAM,CAAA;AAC/C,OAAO,EACL,gCAAgC,EAChC,8BAA8B,EAC9B,wBAAwB,EACxB,mBAAmB,EACnB,sBAAsB,GACvB,MAAM,qBAAqB,CAAA;AAC5B,OAAO,EAAE,wBAAwB,EAAE,MAAM,yBAAyB,CAAA;AAClE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAA;AACtE,OAAO,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAA;AAC1E,OAAO,EAAE,WAAW,EAAE,MAAM,iCAAiC,CAAA;AAuB7D;;;;;;;;;;GAUG;AACH,MAAM,CAAC,KAAK,UAAU,WAAW,CAAC,EAChC,IAAI,EACJ,QAAQ,EACR,MAAM,GACgB;IACtB,MAAM,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,CAAA;IAElC,IAAI,QAAQ,KAAK,WAAW;QAC1B,MAAM,IAAI,wBAAwB,CAAC;YACjC,QAAQ;YACR,kBAAkB,EAAE,CAAC,WAAW,CAAC;SAClC,CAAC,CAAA;IAEJ,IAAI,CAAC;QACH,MAAM,QAAQ,GAAG,MAAM,gBAAgB,CAAC,EAAE,IAAI,EAAE,QAAQ,IAAI,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAA;QAE3E,IAAI,QAAQ,CAAC,MAAM,KAAK,iBAAiB,CAAC,OAAO;YAC/C,MAAM,IAAI,sBAAsB,CAAC;gBAC/B,cAAc,EAAE,iBAAiB,CAAC,QAAQ,CAAC,MAAM,CAAC;aACnD,CAAC,CAAA;QAEJ,MAAM,aAAa,GAAG,QAAQ,CAAC,MAAM,EAAE,IAAI,CACzC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,aAAa,CAAC,GAAG,CAC9C,CAAA;QACD,MAAM,sBAAsB,GAAG,aAAa,EAAE,IAAI,EAAE,OAAO,CACzD,WAAW,EACX,IAAI,CACL,CAAA;QAED,IAAI,QAAQ,CAAC,EAAE,KAAK,KAAK;YACvB,MAAM,IAAI,gCAAgC,CAAC;gBACzC,MAAM,EAAE,sBAAsB;aAC/B,CAAC,CAAA;QAEJ,IAAI,CAAC,aAAa,EAAE,IAAI;YAAE,MAAM,IAAI,mBAAmB,EAAE,CAAA;QAEzD,IAAI,CAAC,sBAAsB,EAAE,KAAK,CAAC,wBAAwB,CAAC;YAC1D,MAAM,IAAI,wBAAwB,CAAC,EAAE,MAAM,EAAE,sBAAuB,EAAE,CAAC,CAAA;QAEzE,MAAM,OAAO,GAAG,sBAAsB,EAAE,KAAK,CAAC,CAAC,CAAC,CAAA;QAChD,MAAM,eAAe,GAAG,UAAU,CAAC,OAAO,CAAC,CAAA;QAE3C,IAAI,OAAO,KAAK,eAAe;YAC7B,MAAM,IAAI,8BAA8B,CAAC,EAAE,OAAO,EAAE,CAAC,CAAA;QAEvD,OAAO,eAAe,CAAA;IACxB,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,IAAI,CAAC,MAAM;YAAE,OAAO,IAAI,CAAA;QACxB,MAAM,KAAK,CAAA;IACb,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { type Account, type Address, type Client, type Hash, type Transport } from 'viem';
|
|
2
|
+
import type { ChainWithEns } from '../../clients/chain.js';
|
|
3
|
+
import { AdditionalParameterSpecifiedError } from '../../errors/general.js';
|
|
4
|
+
import type { Prettify, SimpleTransactionRequest, WriteTransactionParameters } from '../../types/index.js';
|
|
5
|
+
import type { GetDnsImportDataReturnType } from './getDnsImportData.js';
|
|
6
|
+
type BaseImportDnsNameDataParameters = {
|
|
7
|
+
/** Name to import */
|
|
8
|
+
name: string;
|
|
9
|
+
/** Data returned from `getDnsImportData()` */
|
|
10
|
+
dnsImportData: GetDnsImportDataReturnType;
|
|
11
|
+
/** Address to claim the name for */
|
|
12
|
+
address?: Address;
|
|
13
|
+
/** Address of the resolver to use (default: `ensPublicResolver`) */
|
|
14
|
+
resolverAddress?: Address;
|
|
15
|
+
};
|
|
16
|
+
type NoResolverImportDnsNameDataParameters = {
|
|
17
|
+
address?: never;
|
|
18
|
+
resolverAddress?: never;
|
|
19
|
+
};
|
|
20
|
+
type ResolverImportDnsNameDataParameters = {
|
|
21
|
+
address: Address;
|
|
22
|
+
resolverAddress?: Address;
|
|
23
|
+
};
|
|
24
|
+
export type ImportDnsNameDataParameters = BaseImportDnsNameDataParameters & (NoResolverImportDnsNameDataParameters | ResolverImportDnsNameDataParameters);
|
|
25
|
+
export type ImportDnsNameDataReturnType = SimpleTransactionRequest;
|
|
26
|
+
export type ImportDnsNameParameters<TChain extends ChainWithEns, TAccount extends Account | undefined, TChainOverride extends ChainWithEns | undefined> = Prettify<ImportDnsNameDataParameters & WriteTransactionParameters<TChain, TAccount, TChainOverride>>;
|
|
27
|
+
export type ImportDnsNameReturnType = Hash;
|
|
28
|
+
export type ImportDnsNameErrorType = AdditionalParameterSpecifiedError | Error;
|
|
29
|
+
export declare const makeFunctionData: <TChain extends ChainWithEns, TAccount extends Account | undefined>(wallet: Client<Transport, TChain, TAccount>, { name, dnsImportData, address, resolverAddress, }: ImportDnsNameDataParameters) => ImportDnsNameDataReturnType;
|
|
30
|
+
/**
|
|
31
|
+
* Creates a transaction to import a DNS name to ENS.
|
|
32
|
+
* @param wallet - {@link ClientWithAccount}
|
|
33
|
+
* @param parameters - {@link ImportDnsNameParameters}
|
|
34
|
+
* @returns A transaction hash. {@link ImportDnsNameReturnType}
|
|
35
|
+
*
|
|
36
|
+
* @example
|
|
37
|
+
* import { createPublicClient, createWalletClient, http, custom } from 'viem'
|
|
38
|
+
* import { mainnet } from 'viem/chains'
|
|
39
|
+
* import { addEnsContracts } from '@ensdomains/ensjs'
|
|
40
|
+
* import { getDnsImportData, importDnsName } from '@ensdomains/ensjs/dns'
|
|
41
|
+
*
|
|
42
|
+
* const mainnetWithEns = addEnsContracts(mainnet)
|
|
43
|
+
* const client = createPublicClient({
|
|
44
|
+
* chain: mainnetWithEns,
|
|
45
|
+
* transport: http(),
|
|
46
|
+
* })
|
|
47
|
+
* const wallet = createWalletClient({
|
|
48
|
+
* chain: mainnetWithEns,
|
|
49
|
+
* transport: custom(window.ethereum),
|
|
50
|
+
* })
|
|
51
|
+
* const dnsImportData = await getDnsImportData(client, {
|
|
52
|
+
* name: 'example.com',
|
|
53
|
+
* })
|
|
54
|
+
* const hash = await importDnsName(wallet, {
|
|
55
|
+
* name: 'example.com',
|
|
56
|
+
* dnsImportData,
|
|
57
|
+
* })
|
|
58
|
+
*/
|
|
59
|
+
export declare function importDnsName<TChain extends ChainWithEns, TAccount extends Account | undefined, TChainOverride extends ChainWithEns | undefined = ChainWithEns>(wallet: Client<Transport, TChain, TAccount>, { name, address, dnsImportData, resolverAddress, ...txArgs }: ImportDnsNameParameters<TChain, TAccount, TChainOverride>): Promise<ImportDnsNameReturnType>;
|
|
60
|
+
export declare namespace importDnsName {
|
|
61
|
+
var makeFunctionData: <TChain extends ChainWithEns, TAccount extends Account | undefined>(wallet: Client<Transport, TChain, TAccount>, { name, dnsImportData, address, resolverAddress, }: ImportDnsNameDataParameters) => ImportDnsNameDataReturnType;
|
|
62
|
+
}
|
|
63
|
+
export {};
|
|
64
|
+
//# sourceMappingURL=importDnsName.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"importDnsName.d.ts","sourceRoot":"","sources":["../../../src/actions/dns/importDnsName.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,OAAO,EACZ,KAAK,OAAO,EACZ,KAAK,MAAM,EAGX,KAAK,IAAI,EAET,KAAK,SAAS,EAEf,MAAM,MAAM,CAAA;AAGb,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAA;AAK1D,OAAO,EAAE,iCAAiC,EAAE,MAAM,yBAAyB,CAAA;AAC3E,OAAO,KAAK,EACV,QAAQ,EACR,wBAAwB,EACxB,0BAA0B,EAC3B,MAAM,sBAAsB,CAAA;AAC7B,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,uBAAuB,CAAA;AAEvE,KAAK,+BAA+B,GAAG;IACrC,qBAAqB;IACrB,IAAI,EAAE,MAAM,CAAA;IACZ,8CAA8C;IAC9C,aAAa,EAAE,0BAA0B,CAAA;IACzC,oCAAoC;IACpC,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,oEAAoE;IACpE,eAAe,CAAC,EAAE,OAAO,CAAA;CAC1B,CAAA;AAED,KAAK,qCAAqC,GAAG;IAC3C,OAAO,CAAC,EAAE,KAAK,CAAA;IACf,eAAe,CAAC,EAAE,KAAK,CAAA;CACxB,CAAA;AAED,KAAK,mCAAmC,GAAG;IACzC,OAAO,EAAE,OAAO,CAAA;IAChB,eAAe,CAAC,EAAE,OAAO,CAAA;CAC1B,CAAA;AAED,MAAM,MAAM,2BAA2B,GAAG,+BAA+B,GACvE,CAAC,qCAAqC,GAAG,mCAAmC,CAAC,CAAA;AAE/E,MAAM,MAAM,2BAA2B,GAAG,wBAAwB,CAAA;AAElE,MAAM,MAAM,uBAAuB,CACjC,MAAM,SAAS,YAAY,EAC3B,QAAQ,SAAS,OAAO,GAAG,SAAS,EACpC,cAAc,SAAS,YAAY,GAAG,SAAS,IAC7C,QAAQ,CACV,2BAA2B,GACzB,0BAA0B,CAAC,MAAM,EAAE,QAAQ,EAAE,cAAc,CAAC,CAC/D,CAAA;AAED,MAAM,MAAM,uBAAuB,GAAG,IAAI,CAAA;AAE1C,MAAM,MAAM,sBAAsB,GAAG,iCAAiC,GAAG,KAAK,CAAA;AAE9E,eAAO,MAAM,gBAAgB,GAC3B,MAAM,SAAS,YAAY,EAC3B,QAAQ,SAAS,OAAO,GAAG,SAAS,EAEpC,QAAQ,MAAM,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,CAAC,EAC3C,oDAKG,2BAA2B,KAC7B,2BAwCF,CAAA;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BG;AACH,wBAAsB,aAAa,CACjC,MAAM,SAAS,YAAY,EAC3B,QAAQ,SAAS,OAAO,GAAG,SAAS,EACpC,cAAc,SAAS,YAAY,GAAG,SAAS,GAAG,YAAY,EAE9D,MAAM,EAAE,MAAM,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,CAAC,EAC3C,EACE,IAAI,EACJ,OAAO,EACP,aAAa,EACb,eAAe,EACf,GAAG,MAAM,EACV,EAAE,uBAAuB,CAAC,MAAM,EAAE,QAAQ,EAAE,cAAc,CAAC,GAC3D,OAAO,CAAC,uBAAuB,CAAC,CAYlC;yBAzBqB,aAAa;2BAjFjC,MAAM,SAAS,YAAY,EAC3B,QAAQ,SAAS,OAAO,GAAG,SAAS,UAE5B,MAAM,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,CAAC,sDAMxC,2BAA2B,KAC7B,2BAA2B"}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import { encodeFunctionData, getChainContractAddress, toHex, } from 'viem';
|
|
2
|
+
import { sendTransaction } from 'viem/actions';
|
|
3
|
+
import { packetToBytes } from 'viem/ens';
|
|
4
|
+
import { dnsRegistrarProveAndClaimSnippet, dnsRegistrarProveAndClaimWithResolverSnippet, } from '../../contracts/dnsRegistrar.js';
|
|
5
|
+
import { AdditionalParameterSpecifiedError } from '../../errors/general.js';
|
|
6
|
+
export const makeFunctionData = (wallet, { name, dnsImportData, address, resolverAddress, }) => {
|
|
7
|
+
const hexEncodedName = toHex(packetToBytes(name));
|
|
8
|
+
const dnsRegistrarAddress = getChainContractAddress({
|
|
9
|
+
chain: wallet.chain,
|
|
10
|
+
contract: 'ensDnsRegistrar',
|
|
11
|
+
});
|
|
12
|
+
if (!address) {
|
|
13
|
+
if (resolverAddress)
|
|
14
|
+
throw new AdditionalParameterSpecifiedError({
|
|
15
|
+
parameter: 'resolverAddress',
|
|
16
|
+
allowedParameters: ['name', 'dnsImportData'],
|
|
17
|
+
details: 'resolverAddress cannot be specified when claiming without an address',
|
|
18
|
+
});
|
|
19
|
+
return {
|
|
20
|
+
to: dnsRegistrarAddress,
|
|
21
|
+
data: encodeFunctionData({
|
|
22
|
+
abi: dnsRegistrarProveAndClaimSnippet,
|
|
23
|
+
functionName: 'proveAndClaim',
|
|
24
|
+
args: [hexEncodedName, dnsImportData],
|
|
25
|
+
}),
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
const resolverAddress_ = resolverAddress ||
|
|
29
|
+
getChainContractAddress({
|
|
30
|
+
chain: wallet.chain,
|
|
31
|
+
contract: 'ensPublicResolver',
|
|
32
|
+
});
|
|
33
|
+
return {
|
|
34
|
+
to: dnsRegistrarAddress,
|
|
35
|
+
data: encodeFunctionData({
|
|
36
|
+
abi: dnsRegistrarProveAndClaimWithResolverSnippet,
|
|
37
|
+
functionName: 'proveAndClaimWithResolver',
|
|
38
|
+
args: [hexEncodedName, dnsImportData, resolverAddress_, address],
|
|
39
|
+
}),
|
|
40
|
+
};
|
|
41
|
+
};
|
|
42
|
+
/**
|
|
43
|
+
* Creates a transaction to import a DNS name to ENS.
|
|
44
|
+
* @param wallet - {@link ClientWithAccount}
|
|
45
|
+
* @param parameters - {@link ImportDnsNameParameters}
|
|
46
|
+
* @returns A transaction hash. {@link ImportDnsNameReturnType}
|
|
47
|
+
*
|
|
48
|
+
* @example
|
|
49
|
+
* import { createPublicClient, createWalletClient, http, custom } from 'viem'
|
|
50
|
+
* import { mainnet } from 'viem/chains'
|
|
51
|
+
* import { addEnsContracts } from '@ensdomains/ensjs'
|
|
52
|
+
* import { getDnsImportData, importDnsName } from '@ensdomains/ensjs/dns'
|
|
53
|
+
*
|
|
54
|
+
* const mainnetWithEns = addEnsContracts(mainnet)
|
|
55
|
+
* const client = createPublicClient({
|
|
56
|
+
* chain: mainnetWithEns,
|
|
57
|
+
* transport: http(),
|
|
58
|
+
* })
|
|
59
|
+
* const wallet = createWalletClient({
|
|
60
|
+
* chain: mainnetWithEns,
|
|
61
|
+
* transport: custom(window.ethereum),
|
|
62
|
+
* })
|
|
63
|
+
* const dnsImportData = await getDnsImportData(client, {
|
|
64
|
+
* name: 'example.com',
|
|
65
|
+
* })
|
|
66
|
+
* const hash = await importDnsName(wallet, {
|
|
67
|
+
* name: 'example.com',
|
|
68
|
+
* dnsImportData,
|
|
69
|
+
* })
|
|
70
|
+
*/
|
|
71
|
+
export async function importDnsName(wallet, { name, address, dnsImportData, resolverAddress, ...txArgs }) {
|
|
72
|
+
const data = makeFunctionData(wallet, {
|
|
73
|
+
name,
|
|
74
|
+
address,
|
|
75
|
+
dnsImportData,
|
|
76
|
+
resolverAddress,
|
|
77
|
+
});
|
|
78
|
+
const writeArgs = {
|
|
79
|
+
...data,
|
|
80
|
+
...txArgs,
|
|
81
|
+
};
|
|
82
|
+
return sendTransaction(wallet, writeArgs);
|
|
83
|
+
}
|
|
84
|
+
importDnsName.makeFunctionData = makeFunctionData;
|
|
85
|
+
//# sourceMappingURL=importDnsName.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"importDnsName.js","sourceRoot":"","sources":["../../../src/actions/dns/importDnsName.ts"],"names":[],"mappings":"AAAA,OAAO,EAIL,kBAAkB,EAClB,uBAAuB,EAIvB,KAAK,GACN,MAAM,MAAM,CAAA;AACb,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAExC,OAAO,EACL,gCAAgC,EAChC,4CAA4C,GAC7C,MAAM,iCAAiC,CAAA;AACxC,OAAO,EAAE,iCAAiC,EAAE,MAAM,yBAAyB,CAAA;AA+C3E,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAI9B,MAA2C,EAC3C,EACE,IAAI,EACJ,aAAa,EACb,OAAO,EACP,eAAe,GACa,EACD,EAAE;IAC/B,MAAM,cAAc,GAAG,KAAK,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAA;IACjD,MAAM,mBAAmB,GAAG,uBAAuB,CAAC;QAClD,KAAK,EAAE,MAAM,CAAC,KAAK;QACnB,QAAQ,EAAE,iBAAiB;KAC5B,CAAC,CAAA;IAEF,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,IAAI,eAAe;YACjB,MAAM,IAAI,iCAAiC,CAAC;gBAC1C,SAAS,EAAE,iBAAiB;gBAC5B,iBAAiB,EAAE,CAAC,MAAM,EAAE,eAAe,CAAC;gBAC5C,OAAO,EACL,sEAAsE;aACzE,CAAC,CAAA;QACJ,OAAO;YACL,EAAE,EAAE,mBAAmB;YACvB,IAAI,EAAE,kBAAkB,CAAC;gBACvB,GAAG,EAAE,gCAAgC;gBACrC,YAAY,EAAE,eAAe;gBAC7B,IAAI,EAAE,CAAC,cAAc,EAAE,aAAa,CAAC;aACtC,CAAC;SACH,CAAA;IACH,CAAC;IAED,MAAM,gBAAgB,GACpB,eAAe;QACf,uBAAuB,CAAC;YACtB,KAAK,EAAE,MAAM,CAAC,KAAK;YACnB,QAAQ,EAAE,mBAAmB;SAC9B,CAAC,CAAA;IAEJ,OAAO;QACL,EAAE,EAAE,mBAAmB;QACvB,IAAI,EAAE,kBAAkB,CAAC;YACvB,GAAG,EAAE,4CAA4C;YACjD,YAAY,EAAE,2BAA2B;YACzC,IAAI,EAAE,CAAC,cAAc,EAAE,aAAa,EAAE,gBAAgB,EAAE,OAAO,CAAC;SACjE,CAAC;KACH,CAAA;AACH,CAAC,CAAA;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BG;AACH,MAAM,CAAC,KAAK,UAAU,aAAa,CAKjC,MAA2C,EAC3C,EACE,IAAI,EACJ,OAAO,EACP,aAAa,EACb,eAAe,EACf,GAAG,MAAM,EACiD;IAE5D,MAAM,IAAI,GAAG,gBAAgB,CAAC,MAAM,EAAE;QACpC,IAAI;QACJ,OAAO;QACP,aAAa;QACb,eAAe;KACe,CAAC,CAAA;IACjC,MAAM,SAAS,GAAG;QAChB,GAAG,IAAI;QACP,GAAG,MAAM;KACqD,CAAA;IAChE,OAAO,eAAe,CAAC,MAAM,EAAE,SAAS,CAAC,CAAA;AAC3C,CAAC;AAED,aAAa,CAAC,gBAAgB,GAAG,gBAAgB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/actions/dns/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,QAAQ,GAAG,WAAW,MAAM,EAAE,GAAG,UAAU,MAAM,EAAE,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/actions/dns/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { Chain } from "viem";
|
|
2
|
+
import type { RequireClientContracts } from "../../clients/chain.js";
|
|
3
|
+
export type FindResolverParameters = {
|
|
4
|
+
name: string;
|
|
5
|
+
};
|
|
6
|
+
export declare function findResolver<chain extends Chain>(client: RequireClientContracts<chain, 'ensUniversalResolver'>, { name }: FindResolverParameters): Promise<void>;
|
|
7
|
+
//# sourceMappingURL=findResolver.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"findResolver.d.ts","sourceRoot":"","sources":["../../../src/actions/public/findResolver.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,MAAM,CAAC;AAElC,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,wBAAwB,CAAC;AAErE,MAAM,MAAM,sBAAsB,GAAG;IACnC,IAAI,EAAE,MAAM,CAAA;CACb,CAAA;AAED,wBAAsB,YAAY,CAAC,KAAK,SAAS,KAAK,EACpD,MAAM,EAAE,sBAAsB,CAAC,KAAK,EAAE,sBAAsB,CAAC,EAC7D,EAAE,IAAI,EAAE,EAAE,sBAAsB,iBAGjC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"findResolver.js","sourceRoot":"","sources":["../../../src/actions/public/findResolver.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,SAAS,EAAE,MAAM,YAAY,CAAC;AAOtC,MAAM,CAAC,KAAK,UAAU,YAAY,CAChC,MAA6D,EAC7D,EAAE,IAAI,EAA0B;IAEhC,MAAM,kBAAkB,GAAG,SAAS,CAAA;AACtC,CAAC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import type { Chain, EncodeFunctionDataErrorType } from 'viem';
|
|
2
|
+
import type { RequireClientContracts } from '../../clients/chain.js';
|
|
3
|
+
import type { Prettify } from '../../types/index.js';
|
|
4
|
+
import { type DecodeAbiResultErrorType, type DecodeAbiResultParameters, type DecodeAbiResultReturnType, type GetAbiParametersErrorType, type GetAbiParametersParameters } from '../../utils/coders/getAbi.js';
|
|
5
|
+
import { type ResolveNameDataErrorType } from './resolveNameData.js';
|
|
6
|
+
export type GetAbiRecordParameters = Prettify<GetAbiParametersParameters & DecodeAbiResultParameters & {
|
|
7
|
+
/** Batch gateway URLs to use for resolving CCIP-read requests. */
|
|
8
|
+
gatewayUrls?: string[];
|
|
9
|
+
}>;
|
|
10
|
+
export type GetAbiRecordReturnType = DecodeAbiResultReturnType | null;
|
|
11
|
+
export type GetAbiRecordErrorType = ResolveNameDataErrorType | EncodeFunctionDataErrorType | GetAbiParametersErrorType | DecodeAbiResultErrorType;
|
|
12
|
+
/**
|
|
13
|
+
* Gets the ABI record for a name
|
|
14
|
+
* @param client - {@link Client}
|
|
15
|
+
* @param parameters - {@link GetAbiRecordParameters}
|
|
16
|
+
* @returns ABI record for the name, or `null` if not found. {@link GetAbiRecordReturnType}
|
|
17
|
+
*
|
|
18
|
+
* @example
|
|
19
|
+
* import { createPublicClient, http } from 'viem'
|
|
20
|
+
* import { mainnet } from 'viem/chains'
|
|
21
|
+
* import { addEnsContracts } from '@ensdomains/ensjs'
|
|
22
|
+
* import { getAbiRecord } from '@ensdomains/ensjs/public'
|
|
23
|
+
*
|
|
24
|
+
* const client = createPublicClient({
|
|
25
|
+
* chain: addEnsContracts(mainnet),
|
|
26
|
+
* transport: http(),
|
|
27
|
+
* })
|
|
28
|
+
* const result = await getAbiRecord(client, { name: 'ens.eth' })
|
|
29
|
+
* // TODO: real example
|
|
30
|
+
*/
|
|
31
|
+
export declare function getAbiRecord<chain extends Chain>(client: RequireClientContracts<chain, 'ensUniversalResolver'>, { gatewayUrls, name, supportedContentTypes, strict }: GetAbiRecordParameters): Promise<GetAbiRecordReturnType>;
|
|
32
|
+
//# sourceMappingURL=getAbiRecord.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getAbiRecord.d.ts","sourceRoot":"","sources":["../../../src/actions/public/getAbiRecord.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,2BAA2B,EAAE,MAAM,MAAM,CAAA;AAE9D,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,wBAAwB,CAAA;AACpE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAA;AAEpD,OAAO,EACL,KAAK,wBAAwB,EAC7B,KAAK,yBAAyB,EAC9B,KAAK,yBAAyB,EAE9B,KAAK,yBAAyB,EAC9B,KAAK,0BAA0B,EAEhC,MAAM,8BAA8B,CAAA;AACrC,OAAO,EACL,KAAK,wBAAwB,EAE9B,MAAM,sBAAsB,CAAA;AAE7B,MAAM,MAAM,sBAAsB,GAAG,QAAQ,CAC3C,0BAA0B,GACxB,yBAAyB,GAAG;IAC1B,kEAAkE;IAClE,WAAW,CAAC,EAAE,MAAM,EAAE,CAAA;CACvB,CACJ,CAAA;AAED,MAAM,MAAM,sBAAsB,GAAG,yBAAyB,GAAG,IAAI,CAAA;AAErE,MAAM,MAAM,qBAAqB,GAC7B,wBAAwB,GACxB,2BAA2B,GAC3B,yBAAyB,GACzB,wBAAwB,CAAA;AAE5B;;;;;;;;;;;;;;;;;;GAkBG;AACH,wBAAsB,YAAY,CAAC,KAAK,SAAS,KAAK,EACpD,MAAM,EAAE,sBAAsB,CAAC,KAAK,EAAE,sBAAsB,CAAC,EAC7D,EAAE,WAAW,EAAE,IAAI,EAAE,qBAAqB,EAAE,MAAM,EAAE,EAAE,sBAAsB,GAC3E,OAAO,CAAC,sBAAsB,CAAC,CAcjC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { encodeFunctionData, getAction } from 'viem/utils';
|
|
2
|
+
import { decodeAbiResult, getAbiParameters, } from '../../utils/coders/getAbi.js';
|
|
3
|
+
import { resolveNameData, } from './resolveNameData.js';
|
|
4
|
+
/**
|
|
5
|
+
* Gets the ABI record for a name
|
|
6
|
+
* @param client - {@link Client}
|
|
7
|
+
* @param parameters - {@link GetAbiRecordParameters}
|
|
8
|
+
* @returns ABI record for the name, or `null` if not found. {@link GetAbiRecordReturnType}
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* import { createPublicClient, http } from 'viem'
|
|
12
|
+
* import { mainnet } from 'viem/chains'
|
|
13
|
+
* import { addEnsContracts } from '@ensdomains/ensjs'
|
|
14
|
+
* import { getAbiRecord } from '@ensdomains/ensjs/public'
|
|
15
|
+
*
|
|
16
|
+
* const client = createPublicClient({
|
|
17
|
+
* chain: addEnsContracts(mainnet),
|
|
18
|
+
* transport: http(),
|
|
19
|
+
* })
|
|
20
|
+
* const result = await getAbiRecord(client, { name: 'ens.eth' })
|
|
21
|
+
* // TODO: real example
|
|
22
|
+
*/
|
|
23
|
+
export async function getAbiRecord(client, { gatewayUrls, name, supportedContentTypes, strict }) {
|
|
24
|
+
const resolveNameDataAction = getAction(client, resolveNameData, 'resolveNameData');
|
|
25
|
+
const result = await resolveNameDataAction({
|
|
26
|
+
name,
|
|
27
|
+
data: encodeFunctionData(getAbiParameters({ name, supportedContentTypes })),
|
|
28
|
+
gatewayUrls,
|
|
29
|
+
strict,
|
|
30
|
+
});
|
|
31
|
+
if (!result)
|
|
32
|
+
return null;
|
|
33
|
+
return decodeAbiResult(result.resolvedData, { strict });
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=getAbiRecord.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getAbiRecord.js","sourceRoot":"","sources":["../../../src/actions/public/getAbiRecord.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,SAAS,EAAE,MAAM,YAAY,CAAA;AAI1D,OAAO,EAIL,eAAe,EAGf,gBAAgB,GACjB,MAAM,8BAA8B,CAAA;AACrC,OAAO,EAEL,eAAe,GAChB,MAAM,sBAAsB,CAAA;AAkB7B;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAM,CAAC,KAAK,UAAU,YAAY,CAChC,MAA6D,EAC7D,EAAE,WAAW,EAAE,IAAI,EAAE,qBAAqB,EAAE,MAAM,EAA0B;IAE5E,MAAM,qBAAqB,GAAG,SAAS,CACrC,MAAkC,EAClC,eAAe,EACf,iBAAiB,CAClB,CAAA;IACD,MAAM,MAAM,GAAG,MAAM,qBAAqB,CAAC;QACzC,IAAI;QACJ,IAAI,EAAE,kBAAkB,CAAC,gBAAgB,CAAC,EAAE,IAAI,EAAE,qBAAqB,EAAE,CAAC,CAAC;QAC3E,WAAW;QACX,MAAM;KACP,CAAC,CAAA;IACF,IAAI,CAAC,MAAM;QAAE,OAAO,IAAI,CAAA;IACxB,OAAO,eAAe,CAAC,MAAM,CAAC,YAAY,EAAE,EAAE,MAAM,EAAE,CAAC,CAAA;AACzD,CAAC"}
|