diff --git a/contracts/ens/README.md b/contracts/ens/README.md
deleted file mode 100644
index c09b47e39d81..000000000000
--- a/contracts/ens/README.md
+++ /dev/null
@@ -1,20 +0,0 @@
-# Swarm ENS interface
-
-## Usage
-
-Full documentation for the Ethereum Name Service [can be found as EIP 137](https://github.com/ethereum/EIPs/issues/137).
-This package offers a simple binding that streamlines the registration of arbitrary UTF8 domain names to swarm content hashes.
-
-## Development
-
-The SOL file in contract subdirectory implements the ENS root registry, a simple
-first-in, first-served registrar for the root namespace, and a simple resolver contract;
-they're used in tests, and can be used to deploy these contracts for your own purposes.
-
-The solidity source code can be found at [github.com/arachnid/ens/](https://github.com/arachnid/ens/).
-
-The go bindings for ENS contracts are generated using `abigen` via the go generator:
-
-```shell
-go generate ./contracts/ens
-```
diff --git a/contracts/ens/contract/AbstractENS.sol b/contracts/ens/contract/AbstractENS.sol
deleted file mode 100644
index b80a1b0e6b50..000000000000
--- a/contracts/ens/contract/AbstractENS.sol
+++ /dev/null
@@ -1,23 +0,0 @@
-pragma solidity ^0.4.0;
-
-contract AbstractENS {
- function owner(bytes32 node) constant returns(address);
- function resolver(bytes32 node) constant returns(address);
- function ttl(bytes32 node) constant returns(uint64);
- function setOwner(bytes32 node, address owner);
- function setSubnodeOwner(bytes32 node, bytes32 label, address owner);
- function setResolver(bytes32 node, address resolver);
- function setTTL(bytes32 node, uint64 ttl);
-
- // Logged when the owner of a node assigns a new owner to a subnode.
- event NewOwner(bytes32 indexed node, bytes32 indexed label, address owner);
-
- // Logged when the owner of a node transfers ownership to a new account.
- event Transfer(bytes32 indexed node, address owner);
-
- // Logged when the resolver for a node changes.
- event NewResolver(bytes32 indexed node, address resolver);
-
- // Logged when the TTL of a node changes
- event NewTTL(bytes32 indexed node, uint64 ttl);
-}
diff --git a/contracts/ens/contract/ENS.sol b/contracts/ens/contract/ENS.sol
deleted file mode 100644
index 47050c19dabb..000000000000
--- a/contracts/ens/contract/ENS.sol
+++ /dev/null
@@ -1,94 +0,0 @@
-pragma solidity ^0.4.0;
-
-import './AbstractENS.sol';
-
-/**
- * The ENS registry contract.
- */
-contract ENS is AbstractENS {
- struct Record {
- address owner;
- address resolver;
- uint64 ttl;
- }
-
- mapping(bytes32=>Record) records;
-
- // Permits modifications only by the owner of the specified node.
- modifier only_owner(bytes32 node) {
- if (records[node].owner != msg.sender) throw;
- _;
- }
-
- /**
- * Constructs a new ENS registrar.
- */
- function ENS() {
- records[0].owner = msg.sender;
- }
-
- /**
- * Returns the address that owns the specified node.
- */
- function owner(bytes32 node) constant returns (address) {
- return records[node].owner;
- }
-
- /**
- * Returns the address of the resolver for the specified node.
- */
- function resolver(bytes32 node) constant returns (address) {
- return records[node].resolver;
- }
-
- /**
- * Returns the TTL of a node, and any records associated with it.
- */
- function ttl(bytes32 node) constant returns (uint64) {
- return records[node].ttl;
- }
-
- /**
- * Transfers ownership of a node to a new address. May only be called by the current
- * owner of the node.
- * @param node The node to transfer ownership of.
- * @param owner The address of the new owner.
- */
- function setOwner(bytes32 node, address owner) only_owner(node) {
- Transfer(node, owner);
- records[node].owner = owner;
- }
-
- /**
- * Transfers ownership of a subnode sha3(node, label) to a new address. May only be
- * called by the owner of the parent node.
- * @param node The parent node.
- * @param label The hash of the label specifying the subnode.
- * @param owner The address of the new owner.
- */
- function setSubnodeOwner(bytes32 node, bytes32 label, address owner) only_owner(node) {
- var subnode = sha3(node, label);
- NewOwner(node, label, owner);
- records[subnode].owner = owner;
- }
-
- /**
- * Sets the resolver address for the specified node.
- * @param node The node to update.
- * @param resolver The address of the resolver.
- */
- function setResolver(bytes32 node, address resolver) only_owner(node) {
- NewResolver(node, resolver);
- records[node].resolver = resolver;
- }
-
- /**
- * Sets the TTL for the specified node.
- * @param node The node to update.
- * @param ttl The TTL in seconds.
- */
- function setTTL(bytes32 node, uint64 ttl) only_owner(node) {
- NewTTL(node, ttl);
- records[node].ttl = ttl;
- }
-}
diff --git a/contracts/ens/contract/FIFSRegistrar.sol b/contracts/ens/contract/FIFSRegistrar.sol
deleted file mode 100644
index 51629c2b65e0..000000000000
--- a/contracts/ens/contract/FIFSRegistrar.sol
+++ /dev/null
@@ -1,39 +0,0 @@
-pragma solidity ^0.4.0;
-
-import './AbstractENS.sol';
-
-/**
- * A registrar that allocates subdomains to the first person to claim them.
- */
-contract FIFSRegistrar {
- AbstractENS ens;
- bytes32 rootNode;
-
- modifier only_owner(bytes32 subnode) {
- var node = sha3(rootNode, subnode);
- var currentOwner = ens.owner(node);
-
- if (currentOwner != 0 && currentOwner != msg.sender) throw;
-
- _;
- }
-
- /**
- * Constructor.
- * @param ensAddr The address of the ENS registry.
- * @param node The node that this registrar administers.
- */
- function FIFSRegistrar(AbstractENS ensAddr, bytes32 node) {
- ens = ensAddr;
- rootNode = node;
- }
-
- /**
- * Register a name, or change the owner of an existing registration.
- * @param subnode The hash of the label to register.
- * @param owner The address of the new owner.
- */
- function register(bytes32 subnode, address owner) only_owner(subnode) {
- ens.setSubnodeOwner(rootNode, subnode, owner);
- }
-}
diff --git a/contracts/ens/contract/PublicResolver.sol b/contracts/ens/contract/PublicResolver.sol
deleted file mode 100644
index 9dcc95689ecc..000000000000
--- a/contracts/ens/contract/PublicResolver.sol
+++ /dev/null
@@ -1,212 +0,0 @@
-pragma solidity ^0.4.0;
-
-import './AbstractENS.sol';
-
-/**
- * A simple resolver anyone can use; only allows the owner of a node to set its
- * address.
- */
-contract PublicResolver {
- bytes4 constant INTERFACE_META_ID = 0x01ffc9a7;
- bytes4 constant ADDR_INTERFACE_ID = 0x3b3b57de;
- bytes4 constant CONTENT_INTERFACE_ID = 0xd8389dc5;
- bytes4 constant NAME_INTERFACE_ID = 0x691f3431;
- bytes4 constant ABI_INTERFACE_ID = 0x2203ab56;
- bytes4 constant PUBKEY_INTERFACE_ID = 0xc8690233;
- bytes4 constant TEXT_INTERFACE_ID = 0x59d1d43c;
-
- event AddrChanged(bytes32 indexed node, address a);
- event ContentChanged(bytes32 indexed node, bytes32 hash);
- event NameChanged(bytes32 indexed node, string name);
- event ABIChanged(bytes32 indexed node, uint256 indexed contentType);
- event PubkeyChanged(bytes32 indexed node, bytes32 x, bytes32 y);
- event TextChanged(bytes32 indexed node, string indexed indexedKey, string key);
-
- struct PublicKey {
- bytes32 x;
- bytes32 y;
- }
-
- struct Record {
- address addr;
- bytes32 content;
- string name;
- PublicKey pubkey;
- mapping(string=>string) text;
- mapping(uint256=>bytes) abis;
- }
-
- AbstractENS ens;
- mapping(bytes32=>Record) records;
-
- modifier only_owner(bytes32 node) {
- if (ens.owner(node) != msg.sender) throw;
- _;
- }
-
- /**
- * Constructor.
- * @param ensAddr The ENS registrar contract.
- */
- function PublicResolver(AbstractENS ensAddr) {
- ens = ensAddr;
- }
-
- /**
- * Returns true if the resolver implements the interface specified by the provided hash.
- * @param interfaceID The ID of the interface to check for.
- * @return True if the contract implements the requested interface.
- */
- function supportsInterface(bytes4 interfaceID) constant returns (bool) {
- return interfaceID == ADDR_INTERFACE_ID ||
- interfaceID == CONTENT_INTERFACE_ID ||
- interfaceID == NAME_INTERFACE_ID ||
- interfaceID == ABI_INTERFACE_ID ||
- interfaceID == PUBKEY_INTERFACE_ID ||
- interfaceID == TEXT_INTERFACE_ID ||
- interfaceID == INTERFACE_META_ID;
- }
-
- /**
- * Returns the address associated with an ENS node.
- * @param node The ENS node to query.
- * @return The associated address.
- */
- function addr(bytes32 node) constant returns (address ret) {
- ret = records[node].addr;
- }
-
- /**
- * Sets the address associated with an ENS node.
- * May only be called by the owner of that node in the ENS registry.
- * @param node The node to update.
- * @param addr The address to set.
- */
- function setAddr(bytes32 node, address addr) only_owner(node) {
- records[node].addr = addr;
- AddrChanged(node, addr);
- }
-
- /**
- * Returns the content hash associated with an ENS node.
- * Note that this resource type is not standardized, and will likely change
- * in future to a resource type based on multihash.
- * @param node The ENS node to query.
- * @return The associated content hash.
- */
- function content(bytes32 node) constant returns (bytes32 ret) {
- ret = records[node].content;
- }
-
- /**
- * Sets the content hash associated with an ENS node.
- * May only be called by the owner of that node in the ENS registry.
- * Note that this resource type is not standardized, and will likely change
- * in future to a resource type based on multihash.
- * @param node The node to update.
- * @param hash The content hash to set
- */
- function setContent(bytes32 node, bytes32 hash) only_owner(node) {
- records[node].content = hash;
- ContentChanged(node, hash);
- }
-
- /**
- * Returns the name associated with an ENS node, for reverse records.
- * Defined in EIP181.
- * @param node The ENS node to query.
- * @return The associated name.
- */
- function name(bytes32 node) constant returns (string ret) {
- ret = records[node].name;
- }
-
- /**
- * Sets the name associated with an ENS node, for reverse records.
- * May only be called by the owner of that node in the ENS registry.
- * @param node The node to update.
- * @param name The name to set.
- */
- function setName(bytes32 node, string name) only_owner(node) {
- records[node].name = name;
- NameChanged(node, name);
- }
-
- /**
- * Returns the ABI associated with an ENS node.
- * Defined in EIP205.
- * @param node The ENS node to query
- * @param contentTypes A bitwise OR of the ABI formats accepted by the caller.
- * @return contentType The content type of the return value
- * @return data The ABI data
- */
- function ABI(bytes32 node, uint256 contentTypes) constant returns (uint256 contentType, bytes data) {
- var record = records[node];
- for(contentType = 1; contentType <= contentTypes; contentType <<= 1) {
- if ((contentType & contentTypes) != 0 && record.abis[contentType].length > 0) {
- data = record.abis[contentType];
- return;
- }
- }
- contentType = 0;
- }
-
- /**
- * Sets the ABI associated with an ENS node.
- * Nodes may have one ABI of each content type. To remove an ABI, set it to
- * the empty string.
- * @param node The node to update.
- * @param contentType The content type of the ABI
- * @param data The ABI data.
- */
- function setABI(bytes32 node, uint256 contentType, bytes data) only_owner(node) {
- // Content types must be powers of 2
- if (((contentType - 1) & contentType) != 0) throw;
-
- records[node].abis[contentType] = data;
- ABIChanged(node, contentType);
- }
-
- /**
- * Returns the SECP256k1 public key associated with an ENS node.
- * Defined in EIP 619.
- * @param node The ENS node to query
- * @return x, y the X and Y coordinates of the curve point for the public key.
- */
- function pubkey(bytes32 node) constant returns (bytes32 x, bytes32 y) {
- return (records[node].pubkey.x, records[node].pubkey.y);
- }
-
- /**
- * Sets the SECP256k1 public key associated with an ENS node.
- * @param node The ENS node to query
- * @param x the X coordinate of the curve point for the public key.
- * @param y the Y coordinate of the curve point for the public key.
- */
- function setPubkey(bytes32 node, bytes32 x, bytes32 y) only_owner(node) {
- records[node].pubkey = PublicKey(x, y);
- PubkeyChanged(node, x, y);
- }
-
- /**
- * Returns the text data associated with an ENS node and key.
- * @param node The ENS node to query.
- * @param key The text data key to query.
- * @return The associated text data.
- */
- function text(bytes32 node, string key) constant returns (string ret) {
- ret = records[node].text[key];
- }
-
- /**
- * Sets the text data associated with an ENS node and key.
- * May only be called by the owner of that node in the ENS registry.
- * @param node The node to update.
- * @param key The key to set.
- * @param value The text data value to set.
- */
- function setText(bytes32 node, string key, string value) only_owner(node) {
- records[node].text[key] = value;
- TextChanged(node, key, key);
- }
-}
diff --git a/contracts/ens/contract/ens.go b/contracts/ens/contract/ens.go
deleted file mode 100644
index 68418c45a14f..000000000000
--- a/contracts/ens/contract/ens.go
+++ /dev/null
@@ -1,879 +0,0 @@
-// Code generated - DO NOT EDIT.
-// This file is a generated binding and any manual changes will be lost.
-
-package contract
-
-import (
- "strings"
-
- ethereum "github.com/XinFinOrg/XDPoSChain"
- "github.com/XinFinOrg/XDPoSChain/accounts/abi"
- "github.com/XinFinOrg/XDPoSChain/accounts/abi/bind"
- "github.com/XinFinOrg/XDPoSChain/common"
- "github.com/XinFinOrg/XDPoSChain/core/types"
- "github.com/XinFinOrg/XDPoSChain/event"
-)
-
-// ENSABI is the input ABI used to generate the binding from.
-const ENSABI = "[{\"constant\":true,\"inputs\":[{\"name\":\"node\",\"type\":\"bytes32\"}],\"name\":\"resolver\",\"outputs\":[{\"name\":\"\",\"type\":\"address\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"node\",\"type\":\"bytes32\"}],\"name\":\"owner\",\"outputs\":[{\"name\":\"\",\"type\":\"address\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"node\",\"type\":\"bytes32\"},{\"name\":\"label\",\"type\":\"bytes32\"},{\"name\":\"owner\",\"type\":\"address\"}],\"name\":\"setSubnodeOwner\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"node\",\"type\":\"bytes32\"},{\"name\":\"ttl\",\"type\":\"uint64\"}],\"name\":\"setTTL\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"node\",\"type\":\"bytes32\"}],\"name\":\"ttl\",\"outputs\":[{\"name\":\"\",\"type\":\"uint64\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"node\",\"type\":\"bytes32\"},{\"name\":\"resolver\",\"type\":\"address\"}],\"name\":\"setResolver\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"node\",\"type\":\"bytes32\"},{\"name\":\"owner\",\"type\":\"address\"}],\"name\":\"setOwner\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"name\":\"node\",\"type\":\"bytes32\"},{\"indexed\":true,\"name\":\"label\",\"type\":\"bytes32\"},{\"indexed\":false,\"name\":\"owner\",\"type\":\"address\"}],\"name\":\"NewOwner\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"name\":\"node\",\"type\":\"bytes32\"},{\"indexed\":false,\"name\":\"owner\",\"type\":\"address\"}],\"name\":\"Transfer\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"name\":\"node\",\"type\":\"bytes32\"},{\"indexed\":false,\"name\":\"resolver\",\"type\":\"address\"}],\"name\":\"NewResolver\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"name\":\"node\",\"type\":\"bytes32\"},{\"indexed\":false,\"name\":\"ttl\",\"type\":\"uint64\"}],\"name\":\"NewTTL\",\"type\":\"event\"}]"
-
-// ENSBin is the compiled bytecode used for deploying new contracts.
-const ENSBin = `0x6060604052341561000f57600080fd5b60008080526020527fad3228b676f7d3cd4284a5443f17f1962b36e491b30a40b2405849e597ba5fb58054600160a060020a033316600160a060020a0319909116179055610503806100626000396000f3006060604052600436106100825763ffffffff7c01000000000000000000000000000000000000000000000000000000006000350416630178b8bf811461008757806302571be3146100b957806306ab5923146100cf57806314ab9038146100f657806316a25cbd146101195780631896f70a1461014c5780635b0fc9c31461016e575b600080fd5b341561009257600080fd5b61009d600435610190565b604051600160a060020a03909116815260200160405180910390f35b34156100c457600080fd5b61009d6004356101ae565b34156100da57600080fd5b6100f4600435602435600160a060020a03604435166101c9565b005b341561010157600080fd5b6100f460043567ffffffffffffffff6024351661028b565b341561012457600080fd5b61012f600435610357565b60405167ffffffffffffffff909116815260200160405180910390f35b341561015757600080fd5b6100f4600435600160a060020a036024351661038e565b341561017957600080fd5b6100f4600435600160a060020a0360243516610434565b600090815260208190526040902060010154600160a060020a031690565b600090815260208190526040902054600160a060020a031690565b600083815260208190526040812054849033600160a060020a039081169116146101f257600080fd5b8484604051918252602082015260409081019051908190039020915083857fce0457fe73731f824cc272376169235128c118b49d344817417c6d108d155e8285604051600160a060020a03909116815260200160405180910390a3506000908152602081905260409020805473ffffffffffffffffffffffffffffffffffffffff1916600160a060020a03929092169190911790555050565b600082815260208190526040902054829033600160a060020a039081169116146102b457600080fd5b827f1d4f9bbfc9cab89d66e1a1562f2233ccbf1308cb4f63de2ead5787adddb8fa688360405167ffffffffffffffff909116815260200160405180910390a250600091825260208290526040909120600101805467ffffffffffffffff90921674010000000000000000000000000000000000000000027fffffffff0000000000000000ffffffffffffffffffffffffffffffffffffffff909216919091179055565b60009081526020819052604090206001015474010000000000000000000000000000000000000000900467ffffffffffffffff1690565b600082815260208190526040902054829033600160a060020a039081169116146103b757600080fd5b827f335721b01866dc23fbee8b6b2c7b1e14d6f05c28cd35a2c934239f94095602a083604051600160a060020a03909116815260200160405180910390a250600091825260208290526040909120600101805473ffffffffffffffffffffffffffffffffffffffff1916600160a060020a03909216919091179055565b600082815260208190526040902054829033600160a060020a0390811691161461045d57600080fd5b827fd4735d920b0f87494915f556dd9b54c8f309026070caea5c737245152564d26683604051600160a060020a03909116815260200160405180910390a250600091825260208290526040909120805473ffffffffffffffffffffffffffffffffffffffff1916600160a060020a039092169190911790555600a165627a7a72305820f4c798d4c84c9912f389f64631e85e8d16c3e6644f8c2e1579936015c7d5f6660029`
-
-// DeployENS deploys a new Ethereum contract, binding an instance of ENS to it.
-func DeployENS(auth *bind.TransactOpts, backend bind.ContractBackend) (common.Address, *types.Transaction, *ENS, error) {
- parsed, err := abi.JSON(strings.NewReader(ENSABI))
- if err != nil {
- return common.Address{}, nil, nil, err
- }
- address, tx, contract, err := bind.DeployContract(auth, parsed, common.FromHex(ENSBin), backend)
- if err != nil {
- return common.Address{}, nil, nil, err
- }
- return address, tx, &ENS{ENSCaller: ENSCaller{contract: contract}, ENSTransactor: ENSTransactor{contract: contract}, ENSFilterer: ENSFilterer{contract: contract}}, nil
-}
-
-// ENS is an auto generated Go binding around an Ethereum contract.
-type ENS struct {
- ENSCaller // Read-only binding to the contract
- ENSTransactor // Write-only binding to the contract
- ENSFilterer // Log filterer for contract events
-}
-
-// ENSCaller is an auto generated read-only Go binding around an Ethereum contract.
-type ENSCaller struct {
- contract *bind.BoundContract // Generic contract wrapper for the low level calls
-}
-
-// ENSTransactor is an auto generated write-only Go binding around an Ethereum contract.
-type ENSTransactor struct {
- contract *bind.BoundContract // Generic contract wrapper for the low level calls
-}
-
-// ENSFilterer is an auto generated log filtering Go binding around an Ethereum contract events.
-type ENSFilterer struct {
- contract *bind.BoundContract // Generic contract wrapper for the low level calls
-}
-
-// ENSSession is an auto generated Go binding around an Ethereum contract,
-// with pre-set call and transact options.
-type ENSSession struct {
- Contract *ENS // Generic contract binding to set the session for
- CallOpts bind.CallOpts // Call options to use throughout this session
- TransactOpts bind.TransactOpts // Transaction auth options to use throughout this session
-}
-
-// ENSCallerSession is an auto generated read-only Go binding around an Ethereum contract,
-// with pre-set call options.
-type ENSCallerSession struct {
- Contract *ENSCaller // Generic contract caller binding to set the session for
- CallOpts bind.CallOpts // Call options to use throughout this session
-}
-
-// ENSTransactorSession is an auto generated write-only Go binding around an Ethereum contract,
-// with pre-set transact options.
-type ENSTransactorSession struct {
- Contract *ENSTransactor // Generic contract transactor binding to set the session for
- TransactOpts bind.TransactOpts // Transaction auth options to use throughout this session
-}
-
-// ENSRaw is an auto generated low-level Go binding around an Ethereum contract.
-type ENSRaw struct {
- Contract *ENS // Generic contract binding to access the raw methods on
-}
-
-// ENSCallerRaw is an auto generated low-level read-only Go binding around an Ethereum contract.
-type ENSCallerRaw struct {
- Contract *ENSCaller // Generic read-only contract binding to access the raw methods on
-}
-
-// ENSTransactorRaw is an auto generated low-level write-only Go binding around an Ethereum contract.
-type ENSTransactorRaw struct {
- Contract *ENSTransactor // Generic write-only contract binding to access the raw methods on
-}
-
-// NewENS creates a new instance of ENS, bound to a specific deployed contract.
-func NewENS(address common.Address, backend bind.ContractBackend) (*ENS, error) {
- contract, err := bindENS(address, backend, backend, backend)
- if err != nil {
- return nil, err
- }
- return &ENS{ENSCaller: ENSCaller{contract: contract}, ENSTransactor: ENSTransactor{contract: contract}, ENSFilterer: ENSFilterer{contract: contract}}, nil
-}
-
-// NewENSCaller creates a new read-only instance of ENS, bound to a specific deployed contract.
-func NewENSCaller(address common.Address, caller bind.ContractCaller) (*ENSCaller, error) {
- contract, err := bindENS(address, caller, nil, nil)
- if err != nil {
- return nil, err
- }
- return &ENSCaller{contract: contract}, nil
-}
-
-// NewENSTransactor creates a new write-only instance of ENS, bound to a specific deployed contract.
-func NewENSTransactor(address common.Address, transactor bind.ContractTransactor) (*ENSTransactor, error) {
- contract, err := bindENS(address, nil, transactor, nil)
- if err != nil {
- return nil, err
- }
- return &ENSTransactor{contract: contract}, nil
-}
-
-// NewENSFilterer creates a new log filterer instance of ENS, bound to a specific deployed contract.
-func NewENSFilterer(address common.Address, filterer bind.ContractFilterer) (*ENSFilterer, error) {
- contract, err := bindENS(address, nil, nil, filterer)
- if err != nil {
- return nil, err
- }
- return &ENSFilterer{contract: contract}, nil
-}
-
-// bindENS binds a generic wrapper to an already deployed contract.
-func bindENS(address common.Address, caller bind.ContractCaller, transactor bind.ContractTransactor, filterer bind.ContractFilterer) (*bind.BoundContract, error) {
- parsed, err := abi.JSON(strings.NewReader(ENSABI))
- if err != nil {
- return nil, err
- }
- return bind.NewBoundContract(address, parsed, caller, transactor, filterer), nil
-}
-
-// Call invokes the (constant) contract method with params as input values and
-// sets the output to result. The result type might be a single field for simple
-// returns, a slice of interfaces for anonymous returns and a struct for named
-// returns.
-func (_ENS *ENSRaw) Call(opts *bind.CallOpts, result interface{}, method string, params ...interface{}) error {
- return _ENS.Contract.ENSCaller.contract.Call(opts, result, method, params...)
-}
-
-// Transfer initiates a plain transaction to move funds to the contract, calling
-// its default method if one is available.
-func (_ENS *ENSRaw) Transfer(opts *bind.TransactOpts) (*types.Transaction, error) {
- return _ENS.Contract.ENSTransactor.contract.Transfer(opts)
-}
-
-// Transact invokes the (paid) contract method with params as input values.
-func (_ENS *ENSRaw) Transact(opts *bind.TransactOpts, method string, params ...interface{}) (*types.Transaction, error) {
- return _ENS.Contract.ENSTransactor.contract.Transact(opts, method, params...)
-}
-
-// Call invokes the (constant) contract method with params as input values and
-// sets the output to result. The result type might be a single field for simple
-// returns, a slice of interfaces for anonymous returns and a struct for named
-// returns.
-func (_ENS *ENSCallerRaw) Call(opts *bind.CallOpts, result interface{}, method string, params ...interface{}) error {
- return _ENS.Contract.contract.Call(opts, result, method, params...)
-}
-
-// Transfer initiates a plain transaction to move funds to the contract, calling
-// its default method if one is available.
-func (_ENS *ENSTransactorRaw) Transfer(opts *bind.TransactOpts) (*types.Transaction, error) {
- return _ENS.Contract.contract.Transfer(opts)
-}
-
-// Transact invokes the (paid) contract method with params as input values.
-func (_ENS *ENSTransactorRaw) Transact(opts *bind.TransactOpts, method string, params ...interface{}) (*types.Transaction, error) {
- return _ENS.Contract.contract.Transact(opts, method, params...)
-}
-
-// Owner is a free data retrieval call binding the contract method 0x02571be3.
-//
-// Solidity: function owner(node bytes32) constant returns(address)
-func (_ENS *ENSCaller) Owner(opts *bind.CallOpts, node [32]byte) (common.Address, error) {
- var (
- ret0 = new(common.Address)
- )
- out := ret0
- err := _ENS.contract.Call(opts, out, "owner", node)
- return *ret0, err
-}
-
-// Owner is a free data retrieval call binding the contract method 0x02571be3.
-//
-// Solidity: function owner(node bytes32) constant returns(address)
-func (_ENS *ENSSession) Owner(node [32]byte) (common.Address, error) {
- return _ENS.Contract.Owner(&_ENS.CallOpts, node)
-}
-
-// Owner is a free data retrieval call binding the contract method 0x02571be3.
-//
-// Solidity: function owner(node bytes32) constant returns(address)
-func (_ENS *ENSCallerSession) Owner(node [32]byte) (common.Address, error) {
- return _ENS.Contract.Owner(&_ENS.CallOpts, node)
-}
-
-// Resolver is a free data retrieval call binding the contract method 0x0178b8bf.
-//
-// Solidity: function resolver(node bytes32) constant returns(address)
-func (_ENS *ENSCaller) Resolver(opts *bind.CallOpts, node [32]byte) (common.Address, error) {
- var (
- ret0 = new(common.Address)
- )
- out := ret0
- err := _ENS.contract.Call(opts, out, "resolver", node)
- return *ret0, err
-}
-
-// Resolver is a free data retrieval call binding the contract method 0x0178b8bf.
-//
-// Solidity: function resolver(node bytes32) constant returns(address)
-func (_ENS *ENSSession) Resolver(node [32]byte) (common.Address, error) {
- return _ENS.Contract.Resolver(&_ENS.CallOpts, node)
-}
-
-// Resolver is a free data retrieval call binding the contract method 0x0178b8bf.
-//
-// Solidity: function resolver(node bytes32) constant returns(address)
-func (_ENS *ENSCallerSession) Resolver(node [32]byte) (common.Address, error) {
- return _ENS.Contract.Resolver(&_ENS.CallOpts, node)
-}
-
-// Ttl is a free data retrieval call binding the contract method 0x16a25cbd.
-//
-// Solidity: function ttl(node bytes32) constant returns(uint64)
-func (_ENS *ENSCaller) Ttl(opts *bind.CallOpts, node [32]byte) (uint64, error) {
- var (
- ret0 = new(uint64)
- )
- out := ret0
- err := _ENS.contract.Call(opts, out, "ttl", node)
- return *ret0, err
-}
-
-// Ttl is a free data retrieval call binding the contract method 0x16a25cbd.
-//
-// Solidity: function ttl(node bytes32) constant returns(uint64)
-func (_ENS *ENSSession) Ttl(node [32]byte) (uint64, error) {
- return _ENS.Contract.Ttl(&_ENS.CallOpts, node)
-}
-
-// Ttl is a free data retrieval call binding the contract method 0x16a25cbd.
-//
-// Solidity: function ttl(node bytes32) constant returns(uint64)
-func (_ENS *ENSCallerSession) Ttl(node [32]byte) (uint64, error) {
- return _ENS.Contract.Ttl(&_ENS.CallOpts, node)
-}
-
-// SetOwner is a paid mutator transaction binding the contract method 0x5b0fc9c3.
-//
-// Solidity: function setOwner(node bytes32, owner address) returns()
-func (_ENS *ENSTransactor) SetOwner(opts *bind.TransactOpts, node [32]byte, owner common.Address) (*types.Transaction, error) {
- return _ENS.contract.Transact(opts, "setOwner", node, owner)
-}
-
-// SetOwner is a paid mutator transaction binding the contract method 0x5b0fc9c3.
-//
-// Solidity: function setOwner(node bytes32, owner address) returns()
-func (_ENS *ENSSession) SetOwner(node [32]byte, owner common.Address) (*types.Transaction, error) {
- return _ENS.Contract.SetOwner(&_ENS.TransactOpts, node, owner)
-}
-
-// SetOwner is a paid mutator transaction binding the contract method 0x5b0fc9c3.
-//
-// Solidity: function setOwner(node bytes32, owner address) returns()
-func (_ENS *ENSTransactorSession) SetOwner(node [32]byte, owner common.Address) (*types.Transaction, error) {
- return _ENS.Contract.SetOwner(&_ENS.TransactOpts, node, owner)
-}
-
-// SetResolver is a paid mutator transaction binding the contract method 0x1896f70a.
-//
-// Solidity: function setResolver(node bytes32, resolver address) returns()
-func (_ENS *ENSTransactor) SetResolver(opts *bind.TransactOpts, node [32]byte, resolver common.Address) (*types.Transaction, error) {
- return _ENS.contract.Transact(opts, "setResolver", node, resolver)
-}
-
-// SetResolver is a paid mutator transaction binding the contract method 0x1896f70a.
-//
-// Solidity: function setResolver(node bytes32, resolver address) returns()
-func (_ENS *ENSSession) SetResolver(node [32]byte, resolver common.Address) (*types.Transaction, error) {
- return _ENS.Contract.SetResolver(&_ENS.TransactOpts, node, resolver)
-}
-
-// SetResolver is a paid mutator transaction binding the contract method 0x1896f70a.
-//
-// Solidity: function setResolver(node bytes32, resolver address) returns()
-func (_ENS *ENSTransactorSession) SetResolver(node [32]byte, resolver common.Address) (*types.Transaction, error) {
- return _ENS.Contract.SetResolver(&_ENS.TransactOpts, node, resolver)
-}
-
-// SetSubnodeOwner is a paid mutator transaction binding the contract method 0x06ab5923.
-//
-// Solidity: function setSubnodeOwner(node bytes32, label bytes32, owner address) returns()
-func (_ENS *ENSTransactor) SetSubnodeOwner(opts *bind.TransactOpts, node [32]byte, label [32]byte, owner common.Address) (*types.Transaction, error) {
- return _ENS.contract.Transact(opts, "setSubnodeOwner", node, label, owner)
-}
-
-// SetSubnodeOwner is a paid mutator transaction binding the contract method 0x06ab5923.
-//
-// Solidity: function setSubnodeOwner(node bytes32, label bytes32, owner address) returns()
-func (_ENS *ENSSession) SetSubnodeOwner(node [32]byte, label [32]byte, owner common.Address) (*types.Transaction, error) {
- return _ENS.Contract.SetSubnodeOwner(&_ENS.TransactOpts, node, label, owner)
-}
-
-// SetSubnodeOwner is a paid mutator transaction binding the contract method 0x06ab5923.
-//
-// Solidity: function setSubnodeOwner(node bytes32, label bytes32, owner address) returns()
-func (_ENS *ENSTransactorSession) SetSubnodeOwner(node [32]byte, label [32]byte, owner common.Address) (*types.Transaction, error) {
- return _ENS.Contract.SetSubnodeOwner(&_ENS.TransactOpts, node, label, owner)
-}
-
-// SetTTL is a paid mutator transaction binding the contract method 0x14ab9038.
-//
-// Solidity: function setTTL(node bytes32, ttl uint64) returns()
-func (_ENS *ENSTransactor) SetTTL(opts *bind.TransactOpts, node [32]byte, ttl uint64) (*types.Transaction, error) {
- return _ENS.contract.Transact(opts, "setTTL", node, ttl)
-}
-
-// SetTTL is a paid mutator transaction binding the contract method 0x14ab9038.
-//
-// Solidity: function setTTL(node bytes32, ttl uint64) returns()
-func (_ENS *ENSSession) SetTTL(node [32]byte, ttl uint64) (*types.Transaction, error) {
- return _ENS.Contract.SetTTL(&_ENS.TransactOpts, node, ttl)
-}
-
-// SetTTL is a paid mutator transaction binding the contract method 0x14ab9038.
-//
-// Solidity: function setTTL(node bytes32, ttl uint64) returns()
-func (_ENS *ENSTransactorSession) SetTTL(node [32]byte, ttl uint64) (*types.Transaction, error) {
- return _ENS.Contract.SetTTL(&_ENS.TransactOpts, node, ttl)
-}
-
-// ENSNewOwnerIterator is returned from FilterNewOwner and is used to iterate over the raw logs and unpacked data for NewOwner events raised by the ENS contract.
-type ENSNewOwnerIterator struct {
- Event *ENSNewOwner // Event containing the contract specifics and raw log
-
- contract *bind.BoundContract // Generic contract to use for unpacking event data
- event string // Event name to use for unpacking event data
-
- logs chan types.Log // Log channel receiving the found contract events
- sub ethereum.Subscription // Subscription for errors, completion and termination
- done bool // Whether the subscription completed delivering logs
- fail error // Occurred error to stop iteration
-}
-
-// Next advances the iterator to the subsequent event, returning whether there
-// are any more events found. In case of a retrieval or parsing error, false is
-// returned and Error() can be queried for the exact failure.
-func (it *ENSNewOwnerIterator) Next() bool {
- // If the iterator failed, stop iterating
- if it.fail != nil {
- return false
- }
- // If the iterator completed, deliver directly whatever's available
- if it.done {
- select {
- case log := <-it.logs:
- it.Event = new(ENSNewOwner)
- if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil {
- it.fail = err
- return false
- }
- it.Event.Raw = log
- return true
-
- default:
- return false
- }
- }
- // Iterator still in progress, wait for either a data or an error event
- select {
- case log := <-it.logs:
- it.Event = new(ENSNewOwner)
- if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil {
- it.fail = err
- return false
- }
- it.Event.Raw = log
- return true
-
- case err := <-it.sub.Err():
- it.done = true
- it.fail = err
- return it.Next()
- }
-}
-
-// Error retruned any retrieval or parsing error occurred during filtering.
-func (it *ENSNewOwnerIterator) Error() error {
- return it.fail
-}
-
-// Close terminates the iteration process, releasing any pending underlying
-// resources.
-func (it *ENSNewOwnerIterator) Close() error {
- it.sub.Unsubscribe()
- return nil
-}
-
-// ENSNewOwner represents a NewOwner event raised by the ENS contract.
-type ENSNewOwner struct {
- Node [32]byte
- Label [32]byte
- Owner common.Address
- Raw types.Log // Blockchain specific contextual infos
-}
-
-// FilterNewOwner is a free log retrieval operation binding the contract event 0xce0457fe73731f824cc272376169235128c118b49d344817417c6d108d155e82.
-//
-// Solidity: event NewOwner(node indexed bytes32, label indexed bytes32, owner address)
-func (_ENS *ENSFilterer) FilterNewOwner(opts *bind.FilterOpts, node [][32]byte, label [][32]byte) (*ENSNewOwnerIterator, error) {
-
- var nodeRule []interface{}
- for _, nodeItem := range node {
- nodeRule = append(nodeRule, nodeItem)
- }
- var labelRule []interface{}
- for _, labelItem := range label {
- labelRule = append(labelRule, labelItem)
- }
-
- logs, sub, err := _ENS.contract.FilterLogs(opts, "NewOwner", nodeRule, labelRule)
- if err != nil {
- return nil, err
- }
- return &ENSNewOwnerIterator{contract: _ENS.contract, event: "NewOwner", logs: logs, sub: sub}, nil
-}
-
-// WatchNewOwner is a free log subscription operation binding the contract event 0xce0457fe73731f824cc272376169235128c118b49d344817417c6d108d155e82.
-//
-// Solidity: event NewOwner(node indexed bytes32, label indexed bytes32, owner address)
-func (_ENS *ENSFilterer) WatchNewOwner(opts *bind.WatchOpts, sink chan<- *ENSNewOwner, node [][32]byte, label [][32]byte) (event.Subscription, error) {
-
- var nodeRule []interface{}
- for _, nodeItem := range node {
- nodeRule = append(nodeRule, nodeItem)
- }
- var labelRule []interface{}
- for _, labelItem := range label {
- labelRule = append(labelRule, labelItem)
- }
-
- logs, sub, err := _ENS.contract.WatchLogs(opts, "NewOwner", nodeRule, labelRule)
- if err != nil {
- return nil, err
- }
- return event.NewSubscription(func(quit <-chan struct{}) error {
- defer sub.Unsubscribe()
- for {
- select {
- case log := <-logs:
- // New log arrived, parse the event and forward to the user
- event := new(ENSNewOwner)
- if err := _ENS.contract.UnpackLog(event, "NewOwner", log); err != nil {
- return err
- }
- event.Raw = log
-
- select {
- case sink <- event:
- case err := <-sub.Err():
- return err
- case <-quit:
- return nil
- }
- case err := <-sub.Err():
- return err
- case <-quit:
- return nil
- }
- }
- }), nil
-}
-
-// ENSNewResolverIterator is returned from FilterNewResolver and is used to iterate over the raw logs and unpacked data for NewResolver events raised by the ENS contract.
-type ENSNewResolverIterator struct {
- Event *ENSNewResolver // Event containing the contract specifics and raw log
-
- contract *bind.BoundContract // Generic contract to use for unpacking event data
- event string // Event name to use for unpacking event data
-
- logs chan types.Log // Log channel receiving the found contract events
- sub ethereum.Subscription // Subscription for errors, completion and termination
- done bool // Whether the subscription completed delivering logs
- fail error // Occurred error to stop iteration
-}
-
-// Next advances the iterator to the subsequent event, returning whether there
-// are any more events found. In case of a retrieval or parsing error, false is
-// returned and Error() can be queried for the exact failure.
-func (it *ENSNewResolverIterator) Next() bool {
- // If the iterator failed, stop iterating
- if it.fail != nil {
- return false
- }
- // If the iterator completed, deliver directly whatever's available
- if it.done {
- select {
- case log := <-it.logs:
- it.Event = new(ENSNewResolver)
- if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil {
- it.fail = err
- return false
- }
- it.Event.Raw = log
- return true
-
- default:
- return false
- }
- }
- // Iterator still in progress, wait for either a data or an error event
- select {
- case log := <-it.logs:
- it.Event = new(ENSNewResolver)
- if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil {
- it.fail = err
- return false
- }
- it.Event.Raw = log
- return true
-
- case err := <-it.sub.Err():
- it.done = true
- it.fail = err
- return it.Next()
- }
-}
-
-// Error retruned any retrieval or parsing error occurred during filtering.
-func (it *ENSNewResolverIterator) Error() error {
- return it.fail
-}
-
-// Close terminates the iteration process, releasing any pending underlying
-// resources.
-func (it *ENSNewResolverIterator) Close() error {
- it.sub.Unsubscribe()
- return nil
-}
-
-// ENSNewResolver represents a NewResolver event raised by the ENS contract.
-type ENSNewResolver struct {
- Node [32]byte
- Resolver common.Address
- Raw types.Log // Blockchain specific contextual infos
-}
-
-// FilterNewResolver is a free log retrieval operation binding the contract event 0x335721b01866dc23fbee8b6b2c7b1e14d6f05c28cd35a2c934239f94095602a0.
-//
-// Solidity: event NewResolver(node indexed bytes32, resolver address)
-func (_ENS *ENSFilterer) FilterNewResolver(opts *bind.FilterOpts, node [][32]byte) (*ENSNewResolverIterator, error) {
-
- var nodeRule []interface{}
- for _, nodeItem := range node {
- nodeRule = append(nodeRule, nodeItem)
- }
-
- logs, sub, err := _ENS.contract.FilterLogs(opts, "NewResolver", nodeRule)
- if err != nil {
- return nil, err
- }
- return &ENSNewResolverIterator{contract: _ENS.contract, event: "NewResolver", logs: logs, sub: sub}, nil
-}
-
-// WatchNewResolver is a free log subscription operation binding the contract event 0x335721b01866dc23fbee8b6b2c7b1e14d6f05c28cd35a2c934239f94095602a0.
-//
-// Solidity: event NewResolver(node indexed bytes32, resolver address)
-func (_ENS *ENSFilterer) WatchNewResolver(opts *bind.WatchOpts, sink chan<- *ENSNewResolver, node [][32]byte) (event.Subscription, error) {
-
- var nodeRule []interface{}
- for _, nodeItem := range node {
- nodeRule = append(nodeRule, nodeItem)
- }
-
- logs, sub, err := _ENS.contract.WatchLogs(opts, "NewResolver", nodeRule)
- if err != nil {
- return nil, err
- }
- return event.NewSubscription(func(quit <-chan struct{}) error {
- defer sub.Unsubscribe()
- for {
- select {
- case log := <-logs:
- // New log arrived, parse the event and forward to the user
- event := new(ENSNewResolver)
- if err := _ENS.contract.UnpackLog(event, "NewResolver", log); err != nil {
- return err
- }
- event.Raw = log
-
- select {
- case sink <- event:
- case err := <-sub.Err():
- return err
- case <-quit:
- return nil
- }
- case err := <-sub.Err():
- return err
- case <-quit:
- return nil
- }
- }
- }), nil
-}
-
-// ENSNewTTLIterator is returned from FilterNewTTL and is used to iterate over the raw logs and unpacked data for NewTTL events raised by the ENS contract.
-type ENSNewTTLIterator struct {
- Event *ENSNewTTL // Event containing the contract specifics and raw log
-
- contract *bind.BoundContract // Generic contract to use for unpacking event data
- event string // Event name to use for unpacking event data
-
- logs chan types.Log // Log channel receiving the found contract events
- sub ethereum.Subscription // Subscription for errors, completion and termination
- done bool // Whether the subscription completed delivering logs
- fail error // Occurred error to stop iteration
-}
-
-// Next advances the iterator to the subsequent event, returning whether there
-// are any more events found. In case of a retrieval or parsing error, false is
-// returned and Error() can be queried for the exact failure.
-func (it *ENSNewTTLIterator) Next() bool {
- // If the iterator failed, stop iterating
- if it.fail != nil {
- return false
- }
- // If the iterator completed, deliver directly whatever's available
- if it.done {
- select {
- case log := <-it.logs:
- it.Event = new(ENSNewTTL)
- if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil {
- it.fail = err
- return false
- }
- it.Event.Raw = log
- return true
-
- default:
- return false
- }
- }
- // Iterator still in progress, wait for either a data or an error event
- select {
- case log := <-it.logs:
- it.Event = new(ENSNewTTL)
- if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil {
- it.fail = err
- return false
- }
- it.Event.Raw = log
- return true
-
- case err := <-it.sub.Err():
- it.done = true
- it.fail = err
- return it.Next()
- }
-}
-
-// Error retruned any retrieval or parsing error occurred during filtering.
-func (it *ENSNewTTLIterator) Error() error {
- return it.fail
-}
-
-// Close terminates the iteration process, releasing any pending underlying
-// resources.
-func (it *ENSNewTTLIterator) Close() error {
- it.sub.Unsubscribe()
- return nil
-}
-
-// ENSNewTTL represents a NewTTL event raised by the ENS contract.
-type ENSNewTTL struct {
- Node [32]byte
- Ttl uint64
- Raw types.Log // Blockchain specific contextual infos
-}
-
-// FilterNewTTL is a free log retrieval operation binding the contract event 0x1d4f9bbfc9cab89d66e1a1562f2233ccbf1308cb4f63de2ead5787adddb8fa68.
-//
-// Solidity: event NewTTL(node indexed bytes32, ttl uint64)
-func (_ENS *ENSFilterer) FilterNewTTL(opts *bind.FilterOpts, node [][32]byte) (*ENSNewTTLIterator, error) {
-
- var nodeRule []interface{}
- for _, nodeItem := range node {
- nodeRule = append(nodeRule, nodeItem)
- }
-
- logs, sub, err := _ENS.contract.FilterLogs(opts, "NewTTL", nodeRule)
- if err != nil {
- return nil, err
- }
- return &ENSNewTTLIterator{contract: _ENS.contract, event: "NewTTL", logs: logs, sub: sub}, nil
-}
-
-// WatchNewTTL is a free log subscription operation binding the contract event 0x1d4f9bbfc9cab89d66e1a1562f2233ccbf1308cb4f63de2ead5787adddb8fa68.
-//
-// Solidity: event NewTTL(node indexed bytes32, ttl uint64)
-func (_ENS *ENSFilterer) WatchNewTTL(opts *bind.WatchOpts, sink chan<- *ENSNewTTL, node [][32]byte) (event.Subscription, error) {
-
- var nodeRule []interface{}
- for _, nodeItem := range node {
- nodeRule = append(nodeRule, nodeItem)
- }
-
- logs, sub, err := _ENS.contract.WatchLogs(opts, "NewTTL", nodeRule)
- if err != nil {
- return nil, err
- }
- return event.NewSubscription(func(quit <-chan struct{}) error {
- defer sub.Unsubscribe()
- for {
- select {
- case log := <-logs:
- // New log arrived, parse the event and forward to the user
- event := new(ENSNewTTL)
- if err := _ENS.contract.UnpackLog(event, "NewTTL", log); err != nil {
- return err
- }
- event.Raw = log
-
- select {
- case sink <- event:
- case err := <-sub.Err():
- return err
- case <-quit:
- return nil
- }
- case err := <-sub.Err():
- return err
- case <-quit:
- return nil
- }
- }
- }), nil
-}
-
-// ENSTransferIterator is returned from FilterTransfer and is used to iterate over the raw logs and unpacked data for Transfer events raised by the ENS contract.
-type ENSTransferIterator struct {
- Event *ENSTransfer // Event containing the contract specifics and raw log
-
- contract *bind.BoundContract // Generic contract to use for unpacking event data
- event string // Event name to use for unpacking event data
-
- logs chan types.Log // Log channel receiving the found contract events
- sub ethereum.Subscription // Subscription for errors, completion and termination
- done bool // Whether the subscription completed delivering logs
- fail error // Occurred error to stop iteration
-}
-
-// Next advances the iterator to the subsequent event, returning whether there
-// are any more events found. In case of a retrieval or parsing error, false is
-// returned and Error() can be queried for the exact failure.
-func (it *ENSTransferIterator) Next() bool {
- // If the iterator failed, stop iterating
- if it.fail != nil {
- return false
- }
- // If the iterator completed, deliver directly whatever's available
- if it.done {
- select {
- case log := <-it.logs:
- it.Event = new(ENSTransfer)
- if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil {
- it.fail = err
- return false
- }
- it.Event.Raw = log
- return true
-
- default:
- return false
- }
- }
- // Iterator still in progress, wait for either a data or an error event
- select {
- case log := <-it.logs:
- it.Event = new(ENSTransfer)
- if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil {
- it.fail = err
- return false
- }
- it.Event.Raw = log
- return true
-
- case err := <-it.sub.Err():
- it.done = true
- it.fail = err
- return it.Next()
- }
-}
-
-// Error retruned any retrieval or parsing error occurred during filtering.
-func (it *ENSTransferIterator) Error() error {
- return it.fail
-}
-
-// Close terminates the iteration process, releasing any pending underlying
-// resources.
-func (it *ENSTransferIterator) Close() error {
- it.sub.Unsubscribe()
- return nil
-}
-
-// ENSTransfer represents a Transfer event raised by the ENS contract.
-type ENSTransfer struct {
- Node [32]byte
- Owner common.Address
- Raw types.Log // Blockchain specific contextual infos
-}
-
-// FilterTransfer is a free log retrieval operation binding the contract event 0xd4735d920b0f87494915f556dd9b54c8f309026070caea5c737245152564d266.
-//
-// Solidity: event Transfer(node indexed bytes32, owner address)
-func (_ENS *ENSFilterer) FilterTransfer(opts *bind.FilterOpts, node [][32]byte) (*ENSTransferIterator, error) {
-
- var nodeRule []interface{}
- for _, nodeItem := range node {
- nodeRule = append(nodeRule, nodeItem)
- }
-
- logs, sub, err := _ENS.contract.FilterLogs(opts, "Transfer", nodeRule)
- if err != nil {
- return nil, err
- }
- return &ENSTransferIterator{contract: _ENS.contract, event: "Transfer", logs: logs, sub: sub}, nil
-}
-
-// WatchTransfer is a free log subscription operation binding the contract event 0xd4735d920b0f87494915f556dd9b54c8f309026070caea5c737245152564d266.
-//
-// Solidity: event Transfer(node indexed bytes32, owner address)
-func (_ENS *ENSFilterer) WatchTransfer(opts *bind.WatchOpts, sink chan<- *ENSTransfer, node [][32]byte) (event.Subscription, error) {
-
- var nodeRule []interface{}
- for _, nodeItem := range node {
- nodeRule = append(nodeRule, nodeItem)
- }
-
- logs, sub, err := _ENS.contract.WatchLogs(opts, "Transfer", nodeRule)
- if err != nil {
- return nil, err
- }
- return event.NewSubscription(func(quit <-chan struct{}) error {
- defer sub.Unsubscribe()
- for {
- select {
- case log := <-logs:
- // New log arrived, parse the event and forward to the user
- event := new(ENSTransfer)
- if err := _ENS.contract.UnpackLog(event, "Transfer", log); err != nil {
- return err
- }
- event.Raw = log
-
- select {
- case sink <- event:
- case err := <-sub.Err():
- return err
- case <-quit:
- return nil
- }
- case err := <-sub.Err():
- return err
- case <-quit:
- return nil
- }
- }
- }), nil
-}
diff --git a/contracts/ens/contract/fifsregistrar.go b/contracts/ens/contract/fifsregistrar.go
deleted file mode 100644
index ad431b467ea9..000000000000
--- a/contracts/ens/contract/fifsregistrar.go
+++ /dev/null
@@ -1,195 +0,0 @@
-// Code generated - DO NOT EDIT.
-// This file is a generated binding and any manual changes will be lost.
-
-package contract
-
-import (
- "strings"
-
- "github.com/XinFinOrg/XDPoSChain/accounts/abi"
- "github.com/XinFinOrg/XDPoSChain/accounts/abi/bind"
- "github.com/XinFinOrg/XDPoSChain/common"
- "github.com/XinFinOrg/XDPoSChain/core/types"
-)
-
-// FIFSRegistrarABI is the input ABI used to generate the binding from.
-const FIFSRegistrarABI = "[{\"constant\":false,\"inputs\":[{\"name\":\"subnode\",\"type\":\"bytes32\"},{\"name\":\"owner\",\"type\":\"address\"}],\"name\":\"register\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"name\":\"ensAddr\",\"type\":\"address\"},{\"name\":\"node\",\"type\":\"bytes32\"}],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"}]"
-
-// FIFSRegistrarBin is the compiled bytecode used for deploying new contracts.
-const FIFSRegistrarBin = `0x6060604052341561000f57600080fd5b604051604080610224833981016040528080519190602001805160008054600160a060020a03909516600160a060020a03199095169490941790935550506001556101c58061005f6000396000f3006060604052600436106100275763ffffffff60e060020a600035041663d22057a9811461002c575b600080fd5b341561003757600080fd5b61004e600435600160a060020a0360243516610050565b005b816000806001548360405191825260208201526040908101905190819003902060008054919350600160a060020a03909116906302571be39084906040516020015260405160e060020a63ffffffff84160281526004810191909152602401602060405180830381600087803b15156100c857600080fd5b6102c65a03f115156100d957600080fd5b5050506040518051915050600160a060020a0381161580159061010e575033600160a060020a031681600160a060020a031614155b1561011857600080fd5b600054600154600160a060020a03909116906306ab592390878760405160e060020a63ffffffff861602815260048101939093526024830191909152600160a060020a03166044820152606401600060405180830381600087803b151561017e57600080fd5b6102c65a03f1151561018f57600080fd5b50505050505050505600a165627a7a723058206fb963cb168d5e3a51af12cd6bb23e324dbd32dd4954f43653ba27e66b68ea650029`
-
-// DeployFIFSRegistrar deploys a new Ethereum contract, binding an instance of FIFSRegistrar to it.
-func DeployFIFSRegistrar(auth *bind.TransactOpts, backend bind.ContractBackend, ensAddr common.Address, node [32]byte) (common.Address, *types.Transaction, *FIFSRegistrar, error) {
- parsed, err := abi.JSON(strings.NewReader(FIFSRegistrarABI))
- if err != nil {
- return common.Address{}, nil, nil, err
- }
- address, tx, contract, err := bind.DeployContract(auth, parsed, common.FromHex(FIFSRegistrarBin), backend, ensAddr, node)
- if err != nil {
- return common.Address{}, nil, nil, err
- }
- return address, tx, &FIFSRegistrar{FIFSRegistrarCaller: FIFSRegistrarCaller{contract: contract}, FIFSRegistrarTransactor: FIFSRegistrarTransactor{contract: contract}, FIFSRegistrarFilterer: FIFSRegistrarFilterer{contract: contract}}, nil
-}
-
-// FIFSRegistrar is an auto generated Go binding around an Ethereum contract.
-type FIFSRegistrar struct {
- FIFSRegistrarCaller // Read-only binding to the contract
- FIFSRegistrarTransactor // Write-only binding to the contract
- FIFSRegistrarFilterer // Log filterer for contract events
-}
-
-// FIFSRegistrarCaller is an auto generated read-only Go binding around an Ethereum contract.
-type FIFSRegistrarCaller struct {
- contract *bind.BoundContract // Generic contract wrapper for the low level calls
-}
-
-// FIFSRegistrarTransactor is an auto generated write-only Go binding around an Ethereum contract.
-type FIFSRegistrarTransactor struct {
- contract *bind.BoundContract // Generic contract wrapper for the low level calls
-}
-
-// FIFSRegistrarFilterer is an auto generated log filtering Go binding around an Ethereum contract events.
-type FIFSRegistrarFilterer struct {
- contract *bind.BoundContract // Generic contract wrapper for the low level calls
-}
-
-// FIFSRegistrarSession is an auto generated Go binding around an Ethereum contract,
-// with pre-set call and transact options.
-type FIFSRegistrarSession struct {
- Contract *FIFSRegistrar // Generic contract binding to set the session for
- CallOpts bind.CallOpts // Call options to use throughout this session
- TransactOpts bind.TransactOpts // Transaction auth options to use throughout this session
-}
-
-// FIFSRegistrarCallerSession is an auto generated read-only Go binding around an Ethereum contract,
-// with pre-set call options.
-type FIFSRegistrarCallerSession struct {
- Contract *FIFSRegistrarCaller // Generic contract caller binding to set the session for
- CallOpts bind.CallOpts // Call options to use throughout this session
-}
-
-// FIFSRegistrarTransactorSession is an auto generated write-only Go binding around an Ethereum contract,
-// with pre-set transact options.
-type FIFSRegistrarTransactorSession struct {
- Contract *FIFSRegistrarTransactor // Generic contract transactor binding to set the session for
- TransactOpts bind.TransactOpts // Transaction auth options to use throughout this session
-}
-
-// FIFSRegistrarRaw is an auto generated low-level Go binding around an Ethereum contract.
-type FIFSRegistrarRaw struct {
- Contract *FIFSRegistrar // Generic contract binding to access the raw methods on
-}
-
-// FIFSRegistrarCallerRaw is an auto generated low-level read-only Go binding around an Ethereum contract.
-type FIFSRegistrarCallerRaw struct {
- Contract *FIFSRegistrarCaller // Generic read-only contract binding to access the raw methods on
-}
-
-// FIFSRegistrarTransactorRaw is an auto generated low-level write-only Go binding around an Ethereum contract.
-type FIFSRegistrarTransactorRaw struct {
- Contract *FIFSRegistrarTransactor // Generic write-only contract binding to access the raw methods on
-}
-
-// NewFIFSRegistrar creates a new instance of FIFSRegistrar, bound to a specific deployed contract.
-func NewFIFSRegistrar(address common.Address, backend bind.ContractBackend) (*FIFSRegistrar, error) {
- contract, err := bindFIFSRegistrar(address, backend, backend, backend)
- if err != nil {
- return nil, err
- }
- return &FIFSRegistrar{FIFSRegistrarCaller: FIFSRegistrarCaller{contract: contract}, FIFSRegistrarTransactor: FIFSRegistrarTransactor{contract: contract}, FIFSRegistrarFilterer: FIFSRegistrarFilterer{contract: contract}}, nil
-}
-
-// NewFIFSRegistrarCaller creates a new read-only instance of FIFSRegistrar, bound to a specific deployed contract.
-func NewFIFSRegistrarCaller(address common.Address, caller bind.ContractCaller) (*FIFSRegistrarCaller, error) {
- contract, err := bindFIFSRegistrar(address, caller, nil, nil)
- if err != nil {
- return nil, err
- }
- return &FIFSRegistrarCaller{contract: contract}, nil
-}
-
-// NewFIFSRegistrarTransactor creates a new write-only instance of FIFSRegistrar, bound to a specific deployed contract.
-func NewFIFSRegistrarTransactor(address common.Address, transactor bind.ContractTransactor) (*FIFSRegistrarTransactor, error) {
- contract, err := bindFIFSRegistrar(address, nil, transactor, nil)
- if err != nil {
- return nil, err
- }
- return &FIFSRegistrarTransactor{contract: contract}, nil
-}
-
-// NewFIFSRegistrarFilterer creates a new log filterer instance of FIFSRegistrar, bound to a specific deployed contract.
-func NewFIFSRegistrarFilterer(address common.Address, filterer bind.ContractFilterer) (*FIFSRegistrarFilterer, error) {
- contract, err := bindFIFSRegistrar(address, nil, nil, filterer)
- if err != nil {
- return nil, err
- }
- return &FIFSRegistrarFilterer{contract: contract}, nil
-}
-
-// bindFIFSRegistrar binds a generic wrapper to an already deployed contract.
-func bindFIFSRegistrar(address common.Address, caller bind.ContractCaller, transactor bind.ContractTransactor, filterer bind.ContractFilterer) (*bind.BoundContract, error) {
- parsed, err := abi.JSON(strings.NewReader(FIFSRegistrarABI))
- if err != nil {
- return nil, err
- }
- return bind.NewBoundContract(address, parsed, caller, transactor, filterer), nil
-}
-
-// Call invokes the (constant) contract method with params as input values and
-// sets the output to result. The result type might be a single field for simple
-// returns, a slice of interfaces for anonymous returns and a struct for named
-// returns.
-func (_FIFSRegistrar *FIFSRegistrarRaw) Call(opts *bind.CallOpts, result interface{}, method string, params ...interface{}) error {
- return _FIFSRegistrar.Contract.FIFSRegistrarCaller.contract.Call(opts, result, method, params...)
-}
-
-// Transfer initiates a plain transaction to move funds to the contract, calling
-// its default method if one is available.
-func (_FIFSRegistrar *FIFSRegistrarRaw) Transfer(opts *bind.TransactOpts) (*types.Transaction, error) {
- return _FIFSRegistrar.Contract.FIFSRegistrarTransactor.contract.Transfer(opts)
-}
-
-// Transact invokes the (paid) contract method with params as input values.
-func (_FIFSRegistrar *FIFSRegistrarRaw) Transact(opts *bind.TransactOpts, method string, params ...interface{}) (*types.Transaction, error) {
- return _FIFSRegistrar.Contract.FIFSRegistrarTransactor.contract.Transact(opts, method, params...)
-}
-
-// Call invokes the (constant) contract method with params as input values and
-// sets the output to result. The result type might be a single field for simple
-// returns, a slice of interfaces for anonymous returns and a struct for named
-// returns.
-func (_FIFSRegistrar *FIFSRegistrarCallerRaw) Call(opts *bind.CallOpts, result interface{}, method string, params ...interface{}) error {
- return _FIFSRegistrar.Contract.contract.Call(opts, result, method, params...)
-}
-
-// Transfer initiates a plain transaction to move funds to the contract, calling
-// its default method if one is available.
-func (_FIFSRegistrar *FIFSRegistrarTransactorRaw) Transfer(opts *bind.TransactOpts) (*types.Transaction, error) {
- return _FIFSRegistrar.Contract.contract.Transfer(opts)
-}
-
-// Transact invokes the (paid) contract method with params as input values.
-func (_FIFSRegistrar *FIFSRegistrarTransactorRaw) Transact(opts *bind.TransactOpts, method string, params ...interface{}) (*types.Transaction, error) {
- return _FIFSRegistrar.Contract.contract.Transact(opts, method, params...)
-}
-
-// Register is a paid mutator transaction binding the contract method 0xd22057a9.
-//
-// Solidity: function register(subnode bytes32, owner address) returns()
-func (_FIFSRegistrar *FIFSRegistrarTransactor) Register(opts *bind.TransactOpts, subnode [32]byte, owner common.Address) (*types.Transaction, error) {
- return _FIFSRegistrar.contract.Transact(opts, "register", subnode, owner)
-}
-
-// Register is a paid mutator transaction binding the contract method 0xd22057a9.
-//
-// Solidity: function register(subnode bytes32, owner address) returns()
-func (_FIFSRegistrar *FIFSRegistrarSession) Register(subnode [32]byte, owner common.Address) (*types.Transaction, error) {
- return _FIFSRegistrar.Contract.Register(&_FIFSRegistrar.TransactOpts, subnode, owner)
-}
-
-// Register is a paid mutator transaction binding the contract method 0xd22057a9.
-//
-// Solidity: function register(subnode bytes32, owner address) returns()
-func (_FIFSRegistrar *FIFSRegistrarTransactorSession) Register(subnode [32]byte, owner common.Address) (*types.Transaction, error) {
- return _FIFSRegistrar.Contract.Register(&_FIFSRegistrar.TransactOpts, subnode, owner)
-}
diff --git a/contracts/ens/contract/publicresolver.go b/contracts/ens/contract/publicresolver.go
deleted file mode 100644
index a7ac9ab0ef7b..000000000000
--- a/contracts/ens/contract/publicresolver.go
+++ /dev/null
@@ -1,1321 +0,0 @@
-// Code generated - DO NOT EDIT.
-// This file is a generated binding and any manual changes will be lost.
-
-package contract
-
-import (
- "math/big"
- "strings"
-
- ethereum "github.com/XinFinOrg/XDPoSChain"
- "github.com/XinFinOrg/XDPoSChain/accounts/abi"
- "github.com/XinFinOrg/XDPoSChain/accounts/abi/bind"
- "github.com/XinFinOrg/XDPoSChain/common"
- "github.com/XinFinOrg/XDPoSChain/core/types"
- "github.com/XinFinOrg/XDPoSChain/event"
-)
-
-// PublicResolverABI is the input ABI used to generate the binding from.
-const PublicResolverABI = "[{\"constant\":true,\"inputs\":[{\"name\":\"interfaceID\",\"type\":\"bytes4\"}],\"name\":\"supportsInterface\",\"outputs\":[{\"name\":\"\",\"type\":\"bool\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"node\",\"type\":\"bytes32\"},{\"name\":\"key\",\"type\":\"string\"},{\"name\":\"value\",\"type\":\"string\"}],\"name\":\"setText\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"node\",\"type\":\"bytes32\"},{\"name\":\"contentTypes\",\"type\":\"uint256\"}],\"name\":\"ABI\",\"outputs\":[{\"name\":\"contentType\",\"type\":\"uint256\"},{\"name\":\"data\",\"type\":\"bytes\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"node\",\"type\":\"bytes32\"},{\"name\":\"x\",\"type\":\"bytes32\"},{\"name\":\"y\",\"type\":\"bytes32\"}],\"name\":\"setPubkey\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"node\",\"type\":\"bytes32\"}],\"name\":\"content\",\"outputs\":[{\"name\":\"ret\",\"type\":\"bytes32\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"node\",\"type\":\"bytes32\"}],\"name\":\"addr\",\"outputs\":[{\"name\":\"ret\",\"type\":\"address\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"node\",\"type\":\"bytes32\"},{\"name\":\"key\",\"type\":\"string\"}],\"name\":\"text\",\"outputs\":[{\"name\":\"ret\",\"type\":\"string\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"node\",\"type\":\"bytes32\"},{\"name\":\"contentType\",\"type\":\"uint256\"},{\"name\":\"data\",\"type\":\"bytes\"}],\"name\":\"setABI\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"node\",\"type\":\"bytes32\"}],\"name\":\"name\",\"outputs\":[{\"name\":\"ret\",\"type\":\"string\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"node\",\"type\":\"bytes32\"},{\"name\":\"name\",\"type\":\"string\"}],\"name\":\"setName\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"node\",\"type\":\"bytes32\"},{\"name\":\"hash\",\"type\":\"bytes32\"}],\"name\":\"setContent\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"node\",\"type\":\"bytes32\"}],\"name\":\"pubkey\",\"outputs\":[{\"name\":\"x\",\"type\":\"bytes32\"},{\"name\":\"y\",\"type\":\"bytes32\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"node\",\"type\":\"bytes32\"},{\"name\":\"addr\",\"type\":\"address\"}],\"name\":\"setAddr\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"name\":\"ensAddr\",\"type\":\"address\"}],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"name\":\"node\",\"type\":\"bytes32\"},{\"indexed\":false,\"name\":\"a\",\"type\":\"address\"}],\"name\":\"AddrChanged\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"name\":\"node\",\"type\":\"bytes32\"},{\"indexed\":false,\"name\":\"hash\",\"type\":\"bytes32\"}],\"name\":\"ContentChanged\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"name\":\"node\",\"type\":\"bytes32\"},{\"indexed\":false,\"name\":\"name\",\"type\":\"string\"}],\"name\":\"NameChanged\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"name\":\"node\",\"type\":\"bytes32\"},{\"indexed\":true,\"name\":\"contentType\",\"type\":\"uint256\"}],\"name\":\"ABIChanged\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"name\":\"node\",\"type\":\"bytes32\"},{\"indexed\":false,\"name\":\"x\",\"type\":\"bytes32\"},{\"indexed\":false,\"name\":\"y\",\"type\":\"bytes32\"}],\"name\":\"PubkeyChanged\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":true,\"name\":\"node\",\"type\":\"bytes32\"},{\"indexed\":true,\"name\":\"indexedKey\",\"type\":\"string\"},{\"indexed\":false,\"name\":\"key\",\"type\":\"string\"}],\"name\":\"TextChanged\",\"type\":\"event\"}]"
-
-// PublicResolverBin is the compiled bytecode used for deploying new contracts.
-const PublicResolverBin = `0x6060604052341561000f57600080fd5b6040516020806111b28339810160405280805160008054600160a060020a03909216600160a060020a0319909216919091179055505061115e806100546000396000f3006060604052600436106100ab5763ffffffff60e060020a60003504166301ffc9a781146100b057806310f13a8c146100e45780632203ab561461017e57806329cd62ea146102155780632dff6941146102315780633b3b57de1461025957806359d1d43c1461028b578063623195b014610358578063691f3431146103b457806377372213146103ca578063c3d014d614610420578063c869023314610439578063d5fa2b0014610467575b600080fd5b34156100bb57600080fd5b6100d0600160e060020a031960043516610489565b604051901515815260200160405180910390f35b34156100ef57600080fd5b61017c600480359060446024803590810190830135806020601f8201819004810201604051908101604052818152929190602084018383808284378201915050505050509190803590602001908201803590602001908080601f0160208091040260200160405190810160405281815292919060208401838380828437509496506105f695505050505050565b005b341561018957600080fd5b610197600435602435610807565b60405182815260406020820181815290820183818151815260200191508051906020019080838360005b838110156101d95780820151838201526020016101c1565b50505050905090810190601f1680156102065780820380516001836020036101000a031916815260200191505b50935050505060405180910390f35b341561022057600080fd5b61017c600435602435604435610931565b341561023c57600080fd5b610247600435610a30565b60405190815260200160405180910390f35b341561026457600080fd5b61026f600435610a46565b604051600160a060020a03909116815260200160405180910390f35b341561029657600080fd5b6102e1600480359060446024803590810190830135806020601f82018190048102016040519081016040528181529291906020840183838082843750949650610a6195505050505050565b60405160208082528190810183818151815260200191508051906020019080838360005b8381101561031d578082015183820152602001610305565b50505050905090810190601f16801561034a5780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b341561036357600080fd5b61017c600480359060248035919060649060443590810190830135806020601f82018190048102016040519081016040528181529291906020840183838082843750949650610b8095505050505050565b34156103bf57600080fd5b6102e1600435610c7c565b34156103d557600080fd5b61017c600480359060446024803590810190830135806020601f82018190048102016040519081016040528181529291906020840183838082843750949650610d4295505050505050565b341561042b57600080fd5b61017c600435602435610e8c565b341561044457600080fd5b61044f600435610f65565b60405191825260208201526040908101905180910390f35b341561047257600080fd5b61017c600435600160a060020a0360243516610f82565b6000600160e060020a031982167f3b3b57de0000000000000000000000000000000000000000000000000000000014806104ec5750600160e060020a031982167fd8389dc500000000000000000000000000000000000000000000000000000000145b806105205750600160e060020a031982167f691f343100000000000000000000000000000000000000000000000000000000145b806105545750600160e060020a031982167f2203ab5600000000000000000000000000000000000000000000000000000000145b806105885750600160e060020a031982167fc869023300000000000000000000000000000000000000000000000000000000145b806105bc5750600160e060020a031982167f59d1d43c00000000000000000000000000000000000000000000000000000000145b806105f05750600160e060020a031982167f01ffc9a700000000000000000000000000000000000000000000000000000000145b92915050565b600080548491600160a060020a033381169216906302571be39084906040516020015260405160e060020a63ffffffff84160281526004810191909152602401602060405180830381600087803b151561064f57600080fd5b6102c65a03f1151561066057600080fd5b50505060405180519050600160a060020a031614151561067f57600080fd5b6000848152600160205260409081902083916005909101908590518082805190602001908083835b602083106106c65780518252601f1990920191602091820191016106a7565b6001836020036101000a038019825116818451168082178552505050505050905001915050908152602001604051809103902090805161070a929160200190611085565b50826040518082805190602001908083835b6020831061073b5780518252601f19909201916020918201910161071c565b6001836020036101000a0380198251168184511617909252505050919091019250604091505051908190039020847fd8c9334b1a9c2f9da342a0a2b32629c1a229b6445dad78947f674b44444a75508560405160208082528190810183818151815260200191508051906020019080838360005b838110156107c75780820151838201526020016107af565b50505050905090810190601f1680156107f45780820380516001836020036101000a031916815260200191505b509250505060405180910390a350505050565b6000610811611103565b60008481526001602081905260409091209092505b838311610924578284161580159061085f5750600083815260068201602052604081205460026000196101006001841615020190911604115b15610919578060060160008481526020019081526020016000208054600181600116156101000203166002900480601f01602080910402602001604051908101604052809291908181526020018280546001816001161561010002031660029004801561090d5780601f106108e25761010080835404028352916020019161090d565b820191906000526020600020905b8154815290600101906020018083116108f057829003601f168201915b50505050509150610929565b600290920291610826565b600092505b509250929050565b600080548491600160a060020a033381169216906302571be39084906040516020015260405160e060020a63ffffffff84160281526004810191909152602401602060405180830381600087803b151561098a57600080fd5b6102c65a03f1151561099b57600080fd5b50505060405180519050600160a060020a03161415156109ba57600080fd5b6040805190810160409081528482526020808301859052600087815260019091522060030181518155602082015160019091015550837f1d6f5e03d3f63eb58751986629a5439baee5079ff04f345becb66e23eb154e46848460405191825260208201526040908101905180910390a250505050565b6000908152600160208190526040909120015490565b600090815260016020526040902054600160a060020a031690565b610a69611103565b60008381526001602052604090819020600501908390518082805190602001908083835b60208310610aac5780518252601f199092019160209182019101610a8d565b6001836020036101000a03801982511681845116808217855250505050505090500191505090815260200160405180910390208054600181600116156101000203166002900480601f016020809104026020016040519081016040528092919081815260200182805460018160011615610100020316600290048015610b735780601f10610b4857610100808354040283529160200191610b73565b820191906000526020600020905b815481529060010190602001808311610b5657829003601f168201915b5050505050905092915050565b600080548491600160a060020a033381169216906302571be39084906040516020015260405160e060020a63ffffffff84160281526004810191909152602401602060405180830381600087803b1515610bd957600080fd5b6102c65a03f11515610bea57600080fd5b50505060405180519050600160a060020a0316141515610c0957600080fd5b6000198301831615610c1a57600080fd5b60008481526001602090815260408083208684526006019091529020828051610c47929160200190611085565b5082847faa121bbeef5f32f5961a2a28966e769023910fc9479059ee3495d4c1a696efe360405160405180910390a350505050565b610c84611103565b6001600083600019166000191681526020019081526020016000206002018054600181600116156101000203166002900480601f016020809104026020016040519081016040528092919081815260200182805460018160011615610100020316600290048015610d365780601f10610d0b57610100808354040283529160200191610d36565b820191906000526020600020905b815481529060010190602001808311610d1957829003601f168201915b50505050509050919050565b600080548391600160a060020a033381169216906302571be39084906040516020015260405160e060020a63ffffffff84160281526004810191909152602401602060405180830381600087803b1515610d9b57600080fd5b6102c65a03f11515610dac57600080fd5b50505060405180519050600160a060020a0316141515610dcb57600080fd5b6000838152600160205260409020600201828051610ded929160200190611085565b50827fb7d29e911041e8d9b843369e890bcb72c9388692ba48b65ac54e7214c4c348f78360405160208082528190810183818151815260200191508051906020019080838360005b83811015610e4d578082015183820152602001610e35565b50505050905090810190601f168015610e7a5780820380516001836020036101000a031916815260200191505b509250505060405180910390a2505050565b600080548391600160a060020a033381169216906302571be39084906040516020015260405160e060020a63ffffffff84160281526004810191909152602401602060405180830381600087803b1515610ee557600080fd5b6102c65a03f11515610ef657600080fd5b50505060405180519050600160a060020a0316141515610f1557600080fd5b6000838152600160208190526040918290200183905583907f0424b6fe0d9c3bdbece0e7879dc241bb0c22e900be8b6c168b4ee08bd9bf83bc9084905190815260200160405180910390a2505050565b600090815260016020526040902060038101546004909101549091565b600080548391600160a060020a033381169216906302571be39084906040516020015260405160e060020a63ffffffff84160281526004810191909152602401602060405180830381600087803b1515610fdb57600080fd5b6102c65a03f11515610fec57600080fd5b50505060405180519050600160a060020a031614151561100b57600080fd5b60008381526001602052604090819020805473ffffffffffffffffffffffffffffffffffffffff1916600160a060020a03851617905583907f52d7d861f09ab3d26239d492e8968629f95e9e318cf0b73bfddc441522a15fd290849051600160a060020a03909116815260200160405180910390a2505050565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f106110c657805160ff19168380011785556110f3565b828001600101855582156110f3579182015b828111156110f35782518255916020019190600101906110d8565b506110ff929150611115565b5090565b60206040519081016040526000815290565b61112f91905b808211156110ff576000815560010161111b565b905600a165627a7a723058201ecacbc445b9fbcd91b0ab164389f69d7283b856883bc7437eeed1008345a4920029`
-
-// DeployPublicResolver deploys a new Ethereum contract, binding an instance of PublicResolver to it.
-func DeployPublicResolver(auth *bind.TransactOpts, backend bind.ContractBackend, ensAddr common.Address) (common.Address, *types.Transaction, *PublicResolver, error) {
- parsed, err := abi.JSON(strings.NewReader(PublicResolverABI))
- if err != nil {
- return common.Address{}, nil, nil, err
- }
- address, tx, contract, err := bind.DeployContract(auth, parsed, common.FromHex(PublicResolverBin), backend, ensAddr)
- if err != nil {
- return common.Address{}, nil, nil, err
- }
- return address, tx, &PublicResolver{PublicResolverCaller: PublicResolverCaller{contract: contract}, PublicResolverTransactor: PublicResolverTransactor{contract: contract}, PublicResolverFilterer: PublicResolverFilterer{contract: contract}}, nil
-}
-
-// PublicResolver is an auto generated Go binding around an Ethereum contract.
-type PublicResolver struct {
- PublicResolverCaller // Read-only binding to the contract
- PublicResolverTransactor // Write-only binding to the contract
- PublicResolverFilterer // Log filterer for contract events
-}
-
-// PublicResolverCaller is an auto generated read-only Go binding around an Ethereum contract.
-type PublicResolverCaller struct {
- contract *bind.BoundContract // Generic contract wrapper for the low level calls
-}
-
-// PublicResolverTransactor is an auto generated write-only Go binding around an Ethereum contract.
-type PublicResolverTransactor struct {
- contract *bind.BoundContract // Generic contract wrapper for the low level calls
-}
-
-// PublicResolverFilterer is an auto generated log filtering Go binding around an Ethereum contract events.
-type PublicResolverFilterer struct {
- contract *bind.BoundContract // Generic contract wrapper for the low level calls
-}
-
-// PublicResolverSession is an auto generated Go binding around an Ethereum contract,
-// with pre-set call and transact options.
-type PublicResolverSession struct {
- Contract *PublicResolver // Generic contract binding to set the session for
- CallOpts bind.CallOpts // Call options to use throughout this session
- TransactOpts bind.TransactOpts // Transaction auth options to use throughout this session
-}
-
-// PublicResolverCallerSession is an auto generated read-only Go binding around an Ethereum contract,
-// with pre-set call options.
-type PublicResolverCallerSession struct {
- Contract *PublicResolverCaller // Generic contract caller binding to set the session for
- CallOpts bind.CallOpts // Call options to use throughout this session
-}
-
-// PublicResolverTransactorSession is an auto generated write-only Go binding around an Ethereum contract,
-// with pre-set transact options.
-type PublicResolverTransactorSession struct {
- Contract *PublicResolverTransactor // Generic contract transactor binding to set the session for
- TransactOpts bind.TransactOpts // Transaction auth options to use throughout this session
-}
-
-// PublicResolverRaw is an auto generated low-level Go binding around an Ethereum contract.
-type PublicResolverRaw struct {
- Contract *PublicResolver // Generic contract binding to access the raw methods on
-}
-
-// PublicResolverCallerRaw is an auto generated low-level read-only Go binding around an Ethereum contract.
-type PublicResolverCallerRaw struct {
- Contract *PublicResolverCaller // Generic read-only contract binding to access the raw methods on
-}
-
-// PublicResolverTransactorRaw is an auto generated low-level write-only Go binding around an Ethereum contract.
-type PublicResolverTransactorRaw struct {
- Contract *PublicResolverTransactor // Generic write-only contract binding to access the raw methods on
-}
-
-// NewPublicResolver creates a new instance of PublicResolver, bound to a specific deployed contract.
-func NewPublicResolver(address common.Address, backend bind.ContractBackend) (*PublicResolver, error) {
- contract, err := bindPublicResolver(address, backend, backend, backend)
- if err != nil {
- return nil, err
- }
- return &PublicResolver{PublicResolverCaller: PublicResolverCaller{contract: contract}, PublicResolverTransactor: PublicResolverTransactor{contract: contract}, PublicResolverFilterer: PublicResolverFilterer{contract: contract}}, nil
-}
-
-// NewPublicResolverCaller creates a new read-only instance of PublicResolver, bound to a specific deployed contract.
-func NewPublicResolverCaller(address common.Address, caller bind.ContractCaller) (*PublicResolverCaller, error) {
- contract, err := bindPublicResolver(address, caller, nil, nil)
- if err != nil {
- return nil, err
- }
- return &PublicResolverCaller{contract: contract}, nil
-}
-
-// NewPublicResolverTransactor creates a new write-only instance of PublicResolver, bound to a specific deployed contract.
-func NewPublicResolverTransactor(address common.Address, transactor bind.ContractTransactor) (*PublicResolverTransactor, error) {
- contract, err := bindPublicResolver(address, nil, transactor, nil)
- if err != nil {
- return nil, err
- }
- return &PublicResolverTransactor{contract: contract}, nil
-}
-
-// NewPublicResolverFilterer creates a new log filterer instance of PublicResolver, bound to a specific deployed contract.
-func NewPublicResolverFilterer(address common.Address, filterer bind.ContractFilterer) (*PublicResolverFilterer, error) {
- contract, err := bindPublicResolver(address, nil, nil, filterer)
- if err != nil {
- return nil, err
- }
- return &PublicResolverFilterer{contract: contract}, nil
-}
-
-// bindPublicResolver binds a generic wrapper to an already deployed contract.
-func bindPublicResolver(address common.Address, caller bind.ContractCaller, transactor bind.ContractTransactor, filterer bind.ContractFilterer) (*bind.BoundContract, error) {
- parsed, err := abi.JSON(strings.NewReader(PublicResolverABI))
- if err != nil {
- return nil, err
- }
- return bind.NewBoundContract(address, parsed, caller, transactor, filterer), nil
-}
-
-// Call invokes the (constant) contract method with params as input values and
-// sets the output to result. The result type might be a single field for simple
-// returns, a slice of interfaces for anonymous returns and a struct for named
-// returns.
-func (_PublicResolver *PublicResolverRaw) Call(opts *bind.CallOpts, result interface{}, method string, params ...interface{}) error {
- return _PublicResolver.Contract.PublicResolverCaller.contract.Call(opts, result, method, params...)
-}
-
-// Transfer initiates a plain transaction to move funds to the contract, calling
-// its default method if one is available.
-func (_PublicResolver *PublicResolverRaw) Transfer(opts *bind.TransactOpts) (*types.Transaction, error) {
- return _PublicResolver.Contract.PublicResolverTransactor.contract.Transfer(opts)
-}
-
-// Transact invokes the (paid) contract method with params as input values.
-func (_PublicResolver *PublicResolverRaw) Transact(opts *bind.TransactOpts, method string, params ...interface{}) (*types.Transaction, error) {
- return _PublicResolver.Contract.PublicResolverTransactor.contract.Transact(opts, method, params...)
-}
-
-// Call invokes the (constant) contract method with params as input values and
-// sets the output to result. The result type might be a single field for simple
-// returns, a slice of interfaces for anonymous returns and a struct for named
-// returns.
-func (_PublicResolver *PublicResolverCallerRaw) Call(opts *bind.CallOpts, result interface{}, method string, params ...interface{}) error {
- return _PublicResolver.Contract.contract.Call(opts, result, method, params...)
-}
-
-// Transfer initiates a plain transaction to move funds to the contract, calling
-// its default method if one is available.
-func (_PublicResolver *PublicResolverTransactorRaw) Transfer(opts *bind.TransactOpts) (*types.Transaction, error) {
- return _PublicResolver.Contract.contract.Transfer(opts)
-}
-
-// Transact invokes the (paid) contract method with params as input values.
-func (_PublicResolver *PublicResolverTransactorRaw) Transact(opts *bind.TransactOpts, method string, params ...interface{}) (*types.Transaction, error) {
- return _PublicResolver.Contract.contract.Transact(opts, method, params...)
-}
-
-// ABI is a free data retrieval call binding the contract method 0x2203ab56.
-//
-// Solidity: function ABI(node bytes32, contentTypes uint256) constant returns(contentType uint256, data bytes)
-func (_PublicResolver *PublicResolverCaller) ABI(opts *bind.CallOpts, node [32]byte, contentTypes *big.Int) (struct {
- ContentType *big.Int
- Data []byte
-}, error) {
- ret := new(struct {
- ContentType *big.Int
- Data []byte
- })
- out := ret
- err := _PublicResolver.contract.Call(opts, out, "ABI", node, contentTypes)
- return *ret, err
-}
-
-// ABI is a free data retrieval call binding the contract method 0x2203ab56.
-//
-// Solidity: function ABI(node bytes32, contentTypes uint256) constant returns(contentType uint256, data bytes)
-func (_PublicResolver *PublicResolverSession) ABI(node [32]byte, contentTypes *big.Int) (struct {
- ContentType *big.Int
- Data []byte
-}, error) {
- return _PublicResolver.Contract.ABI(&_PublicResolver.CallOpts, node, contentTypes)
-}
-
-// ABI is a free data retrieval call binding the contract method 0x2203ab56.
-//
-// Solidity: function ABI(node bytes32, contentTypes uint256) constant returns(contentType uint256, data bytes)
-func (_PublicResolver *PublicResolverCallerSession) ABI(node [32]byte, contentTypes *big.Int) (struct {
- ContentType *big.Int
- Data []byte
-}, error) {
- return _PublicResolver.Contract.ABI(&_PublicResolver.CallOpts, node, contentTypes)
-}
-
-// Addr is a free data retrieval call binding the contract method 0x3b3b57de.
-//
-// Solidity: function addr(node bytes32) constant returns(ret address)
-func (_PublicResolver *PublicResolverCaller) Addr(opts *bind.CallOpts, node [32]byte) (common.Address, error) {
- var (
- ret0 = new(common.Address)
- )
- out := ret0
- err := _PublicResolver.contract.Call(opts, out, "addr", node)
- return *ret0, err
-}
-
-// Addr is a free data retrieval call binding the contract method 0x3b3b57de.
-//
-// Solidity: function addr(node bytes32) constant returns(ret address)
-func (_PublicResolver *PublicResolverSession) Addr(node [32]byte) (common.Address, error) {
- return _PublicResolver.Contract.Addr(&_PublicResolver.CallOpts, node)
-}
-
-// Addr is a free data retrieval call binding the contract method 0x3b3b57de.
-//
-// Solidity: function addr(node bytes32) constant returns(ret address)
-func (_PublicResolver *PublicResolverCallerSession) Addr(node [32]byte) (common.Address, error) {
- return _PublicResolver.Contract.Addr(&_PublicResolver.CallOpts, node)
-}
-
-// Content is a free data retrieval call binding the contract method 0x2dff6941.
-//
-// Solidity: function content(node bytes32) constant returns(ret bytes32)
-func (_PublicResolver *PublicResolverCaller) Content(opts *bind.CallOpts, node [32]byte) ([32]byte, error) {
- var (
- ret0 = new([32]byte)
- )
- out := ret0
- err := _PublicResolver.contract.Call(opts, out, "content", node)
- return *ret0, err
-}
-
-// Content is a free data retrieval call binding the contract method 0x2dff6941.
-//
-// Solidity: function content(node bytes32) constant returns(ret bytes32)
-func (_PublicResolver *PublicResolverSession) Content(node [32]byte) ([32]byte, error) {
- return _PublicResolver.Contract.Content(&_PublicResolver.CallOpts, node)
-}
-
-// Content is a free data retrieval call binding the contract method 0x2dff6941.
-//
-// Solidity: function content(node bytes32) constant returns(ret bytes32)
-func (_PublicResolver *PublicResolverCallerSession) Content(node [32]byte) ([32]byte, error) {
- return _PublicResolver.Contract.Content(&_PublicResolver.CallOpts, node)
-}
-
-// Name is a free data retrieval call binding the contract method 0x691f3431.
-//
-// Solidity: function name(node bytes32) constant returns(ret string)
-func (_PublicResolver *PublicResolverCaller) Name(opts *bind.CallOpts, node [32]byte) (string, error) {
- var (
- ret0 = new(string)
- )
- out := ret0
- err := _PublicResolver.contract.Call(opts, out, "name", node)
- return *ret0, err
-}
-
-// Name is a free data retrieval call binding the contract method 0x691f3431.
-//
-// Solidity: function name(node bytes32) constant returns(ret string)
-func (_PublicResolver *PublicResolverSession) Name(node [32]byte) (string, error) {
- return _PublicResolver.Contract.Name(&_PublicResolver.CallOpts, node)
-}
-
-// Name is a free data retrieval call binding the contract method 0x691f3431.
-//
-// Solidity: function name(node bytes32) constant returns(ret string)
-func (_PublicResolver *PublicResolverCallerSession) Name(node [32]byte) (string, error) {
- return _PublicResolver.Contract.Name(&_PublicResolver.CallOpts, node)
-}
-
-// Pubkey is a free data retrieval call binding the contract method 0xc8690233.
-//
-// Solidity: function pubkey(node bytes32) constant returns(x bytes32, y bytes32)
-func (_PublicResolver *PublicResolverCaller) Pubkey(opts *bind.CallOpts, node [32]byte) (struct {
- X [32]byte
- Y [32]byte
-}, error) {
- ret := new(struct {
- X [32]byte
- Y [32]byte
- })
- out := ret
- err := _PublicResolver.contract.Call(opts, out, "pubkey", node)
- return *ret, err
-}
-
-// Pubkey is a free data retrieval call binding the contract method 0xc8690233.
-//
-// Solidity: function pubkey(node bytes32) constant returns(x bytes32, y bytes32)
-func (_PublicResolver *PublicResolverSession) Pubkey(node [32]byte) (struct {
- X [32]byte
- Y [32]byte
-}, error) {
- return _PublicResolver.Contract.Pubkey(&_PublicResolver.CallOpts, node)
-}
-
-// Pubkey is a free data retrieval call binding the contract method 0xc8690233.
-//
-// Solidity: function pubkey(node bytes32) constant returns(x bytes32, y bytes32)
-func (_PublicResolver *PublicResolverCallerSession) Pubkey(node [32]byte) (struct {
- X [32]byte
- Y [32]byte
-}, error) {
- return _PublicResolver.Contract.Pubkey(&_PublicResolver.CallOpts, node)
-}
-
-// SupportsInterface is a free data retrieval call binding the contract method 0x01ffc9a7.
-//
-// Solidity: function supportsInterface(interfaceID bytes4) constant returns(bool)
-func (_PublicResolver *PublicResolverCaller) SupportsInterface(opts *bind.CallOpts, interfaceID [4]byte) (bool, error) {
- var (
- ret0 = new(bool)
- )
- out := ret0
- err := _PublicResolver.contract.Call(opts, out, "supportsInterface", interfaceID)
- return *ret0, err
-}
-
-// SupportsInterface is a free data retrieval call binding the contract method 0x01ffc9a7.
-//
-// Solidity: function supportsInterface(interfaceID bytes4) constant returns(bool)
-func (_PublicResolver *PublicResolverSession) SupportsInterface(interfaceID [4]byte) (bool, error) {
- return _PublicResolver.Contract.SupportsInterface(&_PublicResolver.CallOpts, interfaceID)
-}
-
-// SupportsInterface is a free data retrieval call binding the contract method 0x01ffc9a7.
-//
-// Solidity: function supportsInterface(interfaceID bytes4) constant returns(bool)
-func (_PublicResolver *PublicResolverCallerSession) SupportsInterface(interfaceID [4]byte) (bool, error) {
- return _PublicResolver.Contract.SupportsInterface(&_PublicResolver.CallOpts, interfaceID)
-}
-
-// Text is a free data retrieval call binding the contract method 0x59d1d43c.
-//
-// Solidity: function text(node bytes32, key string) constant returns(ret string)
-func (_PublicResolver *PublicResolverCaller) Text(opts *bind.CallOpts, node [32]byte, key string) (string, error) {
- var (
- ret0 = new(string)
- )
- out := ret0
- err := _PublicResolver.contract.Call(opts, out, "text", node, key)
- return *ret0, err
-}
-
-// Text is a free data retrieval call binding the contract method 0x59d1d43c.
-//
-// Solidity: function text(node bytes32, key string) constant returns(ret string)
-func (_PublicResolver *PublicResolverSession) Text(node [32]byte, key string) (string, error) {
- return _PublicResolver.Contract.Text(&_PublicResolver.CallOpts, node, key)
-}
-
-// Text is a free data retrieval call binding the contract method 0x59d1d43c.
-//
-// Solidity: function text(node bytes32, key string) constant returns(ret string)
-func (_PublicResolver *PublicResolverCallerSession) Text(node [32]byte, key string) (string, error) {
- return _PublicResolver.Contract.Text(&_PublicResolver.CallOpts, node, key)
-}
-
-// SetABI is a paid mutator transaction binding the contract method 0x623195b0.
-//
-// Solidity: function setABI(node bytes32, contentType uint256, data bytes) returns()
-func (_PublicResolver *PublicResolverTransactor) SetABI(opts *bind.TransactOpts, node [32]byte, contentType *big.Int, data []byte) (*types.Transaction, error) {
- return _PublicResolver.contract.Transact(opts, "setABI", node, contentType, data)
-}
-
-// SetABI is a paid mutator transaction binding the contract method 0x623195b0.
-//
-// Solidity: function setABI(node bytes32, contentType uint256, data bytes) returns()
-func (_PublicResolver *PublicResolverSession) SetABI(node [32]byte, contentType *big.Int, data []byte) (*types.Transaction, error) {
- return _PublicResolver.Contract.SetABI(&_PublicResolver.TransactOpts, node, contentType, data)
-}
-
-// SetABI is a paid mutator transaction binding the contract method 0x623195b0.
-//
-// Solidity: function setABI(node bytes32, contentType uint256, data bytes) returns()
-func (_PublicResolver *PublicResolverTransactorSession) SetABI(node [32]byte, contentType *big.Int, data []byte) (*types.Transaction, error) {
- return _PublicResolver.Contract.SetABI(&_PublicResolver.TransactOpts, node, contentType, data)
-}
-
-// SetAddr is a paid mutator transaction binding the contract method 0xd5fa2b00.
-//
-// Solidity: function setAddr(node bytes32, addr address) returns()
-func (_PublicResolver *PublicResolverTransactor) SetAddr(opts *bind.TransactOpts, node [32]byte, addr common.Address) (*types.Transaction, error) {
- return _PublicResolver.contract.Transact(opts, "setAddr", node, addr)
-}
-
-// SetAddr is a paid mutator transaction binding the contract method 0xd5fa2b00.
-//
-// Solidity: function setAddr(node bytes32, addr address) returns()
-func (_PublicResolver *PublicResolverSession) SetAddr(node [32]byte, addr common.Address) (*types.Transaction, error) {
- return _PublicResolver.Contract.SetAddr(&_PublicResolver.TransactOpts, node, addr)
-}
-
-// SetAddr is a paid mutator transaction binding the contract method 0xd5fa2b00.
-//
-// Solidity: function setAddr(node bytes32, addr address) returns()
-func (_PublicResolver *PublicResolverTransactorSession) SetAddr(node [32]byte, addr common.Address) (*types.Transaction, error) {
- return _PublicResolver.Contract.SetAddr(&_PublicResolver.TransactOpts, node, addr)
-}
-
-// SetContent is a paid mutator transaction binding the contract method 0xc3d014d6.
-//
-// Solidity: function setContent(node bytes32, hash bytes32) returns()
-func (_PublicResolver *PublicResolverTransactor) SetContent(opts *bind.TransactOpts, node [32]byte, hash [32]byte) (*types.Transaction, error) {
- return _PublicResolver.contract.Transact(opts, "setContent", node, hash)
-}
-
-// SetContent is a paid mutator transaction binding the contract method 0xc3d014d6.
-//
-// Solidity: function setContent(node bytes32, hash bytes32) returns()
-func (_PublicResolver *PublicResolverSession) SetContent(node [32]byte, hash [32]byte) (*types.Transaction, error) {
- return _PublicResolver.Contract.SetContent(&_PublicResolver.TransactOpts, node, hash)
-}
-
-// SetContent is a paid mutator transaction binding the contract method 0xc3d014d6.
-//
-// Solidity: function setContent(node bytes32, hash bytes32) returns()
-func (_PublicResolver *PublicResolverTransactorSession) SetContent(node [32]byte, hash [32]byte) (*types.Transaction, error) {
- return _PublicResolver.Contract.SetContent(&_PublicResolver.TransactOpts, node, hash)
-}
-
-// SetName is a paid mutator transaction binding the contract method 0x77372213.
-//
-// Solidity: function setName(node bytes32, name string) returns()
-func (_PublicResolver *PublicResolverTransactor) SetName(opts *bind.TransactOpts, node [32]byte, name string) (*types.Transaction, error) {
- return _PublicResolver.contract.Transact(opts, "setName", node, name)
-}
-
-// SetName is a paid mutator transaction binding the contract method 0x77372213.
-//
-// Solidity: function setName(node bytes32, name string) returns()
-func (_PublicResolver *PublicResolverSession) SetName(node [32]byte, name string) (*types.Transaction, error) {
- return _PublicResolver.Contract.SetName(&_PublicResolver.TransactOpts, node, name)
-}
-
-// SetName is a paid mutator transaction binding the contract method 0x77372213.
-//
-// Solidity: function setName(node bytes32, name string) returns()
-func (_PublicResolver *PublicResolverTransactorSession) SetName(node [32]byte, name string) (*types.Transaction, error) {
- return _PublicResolver.Contract.SetName(&_PublicResolver.TransactOpts, node, name)
-}
-
-// SetPubkey is a paid mutator transaction binding the contract method 0x29cd62ea.
-//
-// Solidity: function setPubkey(node bytes32, x bytes32, y bytes32) returns()
-func (_PublicResolver *PublicResolverTransactor) SetPubkey(opts *bind.TransactOpts, node [32]byte, x [32]byte, y [32]byte) (*types.Transaction, error) {
- return _PublicResolver.contract.Transact(opts, "setPubkey", node, x, y)
-}
-
-// SetPubkey is a paid mutator transaction binding the contract method 0x29cd62ea.
-//
-// Solidity: function setPubkey(node bytes32, x bytes32, y bytes32) returns()
-func (_PublicResolver *PublicResolverSession) SetPubkey(node [32]byte, x [32]byte, y [32]byte) (*types.Transaction, error) {
- return _PublicResolver.Contract.SetPubkey(&_PublicResolver.TransactOpts, node, x, y)
-}
-
-// SetPubkey is a paid mutator transaction binding the contract method 0x29cd62ea.
-//
-// Solidity: function setPubkey(node bytes32, x bytes32, y bytes32) returns()
-func (_PublicResolver *PublicResolverTransactorSession) SetPubkey(node [32]byte, x [32]byte, y [32]byte) (*types.Transaction, error) {
- return _PublicResolver.Contract.SetPubkey(&_PublicResolver.TransactOpts, node, x, y)
-}
-
-// SetText is a paid mutator transaction binding the contract method 0x10f13a8c.
-//
-// Solidity: function setText(node bytes32, key string, value string) returns()
-func (_PublicResolver *PublicResolverTransactor) SetText(opts *bind.TransactOpts, node [32]byte, key string, value string) (*types.Transaction, error) {
- return _PublicResolver.contract.Transact(opts, "setText", node, key, value)
-}
-
-// SetText is a paid mutator transaction binding the contract method 0x10f13a8c.
-//
-// Solidity: function setText(node bytes32, key string, value string) returns()
-func (_PublicResolver *PublicResolverSession) SetText(node [32]byte, key string, value string) (*types.Transaction, error) {
- return _PublicResolver.Contract.SetText(&_PublicResolver.TransactOpts, node, key, value)
-}
-
-// SetText is a paid mutator transaction binding the contract method 0x10f13a8c.
-//
-// Solidity: function setText(node bytes32, key string, value string) returns()
-func (_PublicResolver *PublicResolverTransactorSession) SetText(node [32]byte, key string, value string) (*types.Transaction, error) {
- return _PublicResolver.Contract.SetText(&_PublicResolver.TransactOpts, node, key, value)
-}
-
-// PublicResolverABIChangedIterator is returned from FilterABIChanged and is used to iterate over the raw logs and unpacked data for ABIChanged events raised by the PublicResolver contract.
-type PublicResolverABIChangedIterator struct {
- Event *PublicResolverABIChanged // Event containing the contract specifics and raw log
-
- contract *bind.BoundContract // Generic contract to use for unpacking event data
- event string // Event name to use for unpacking event data
-
- logs chan types.Log // Log channel receiving the found contract events
- sub ethereum.Subscription // Subscription for errors, completion and termination
- done bool // Whether the subscription completed delivering logs
- fail error // Occurred error to stop iteration
-}
-
-// Next advances the iterator to the subsequent event, returning whether there
-// are any more events found. In case of a retrieval or parsing error, false is
-// returned and Error() can be queried for the exact failure.
-func (it *PublicResolverABIChangedIterator) Next() bool {
- // If the iterator failed, stop iterating
- if it.fail != nil {
- return false
- }
- // If the iterator completed, deliver directly whatever's available
- if it.done {
- select {
- case log := <-it.logs:
- it.Event = new(PublicResolverABIChanged)
- if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil {
- it.fail = err
- return false
- }
- it.Event.Raw = log
- return true
-
- default:
- return false
- }
- }
- // Iterator still in progress, wait for either a data or an error event
- select {
- case log := <-it.logs:
- it.Event = new(PublicResolverABIChanged)
- if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil {
- it.fail = err
- return false
- }
- it.Event.Raw = log
- return true
-
- case err := <-it.sub.Err():
- it.done = true
- it.fail = err
- return it.Next()
- }
-}
-
-// Error retruned any retrieval or parsing error occurred during filtering.
-func (it *PublicResolverABIChangedIterator) Error() error {
- return it.fail
-}
-
-// Close terminates the iteration process, releasing any pending underlying
-// resources.
-func (it *PublicResolverABIChangedIterator) Close() error {
- it.sub.Unsubscribe()
- return nil
-}
-
-// PublicResolverABIChanged represents a ABIChanged event raised by the PublicResolver contract.
-type PublicResolverABIChanged struct {
- Node [32]byte
- ContentType *big.Int
- Raw types.Log // Blockchain specific contextual infos
-}
-
-// FilterABIChanged is a free log retrieval operation binding the contract event 0xaa121bbeef5f32f5961a2a28966e769023910fc9479059ee3495d4c1a696efe3.
-//
-// Solidity: event ABIChanged(node indexed bytes32, contentType indexed uint256)
-func (_PublicResolver *PublicResolverFilterer) FilterABIChanged(opts *bind.FilterOpts, node [][32]byte, contentType []*big.Int) (*PublicResolverABIChangedIterator, error) {
-
- var nodeRule []interface{}
- for _, nodeItem := range node {
- nodeRule = append(nodeRule, nodeItem)
- }
- var contentTypeRule []interface{}
- for _, contentTypeItem := range contentType {
- contentTypeRule = append(contentTypeRule, contentTypeItem)
- }
-
- logs, sub, err := _PublicResolver.contract.FilterLogs(opts, "ABIChanged", nodeRule, contentTypeRule)
- if err != nil {
- return nil, err
- }
- return &PublicResolverABIChangedIterator{contract: _PublicResolver.contract, event: "ABIChanged", logs: logs, sub: sub}, nil
-}
-
-// WatchABIChanged is a free log subscription operation binding the contract event 0xaa121bbeef5f32f5961a2a28966e769023910fc9479059ee3495d4c1a696efe3.
-//
-// Solidity: event ABIChanged(node indexed bytes32, contentType indexed uint256)
-func (_PublicResolver *PublicResolverFilterer) WatchABIChanged(opts *bind.WatchOpts, sink chan<- *PublicResolverABIChanged, node [][32]byte, contentType []*big.Int) (event.Subscription, error) {
-
- var nodeRule []interface{}
- for _, nodeItem := range node {
- nodeRule = append(nodeRule, nodeItem)
- }
- var contentTypeRule []interface{}
- for _, contentTypeItem := range contentType {
- contentTypeRule = append(contentTypeRule, contentTypeItem)
- }
-
- logs, sub, err := _PublicResolver.contract.WatchLogs(opts, "ABIChanged", nodeRule, contentTypeRule)
- if err != nil {
- return nil, err
- }
- return event.NewSubscription(func(quit <-chan struct{}) error {
- defer sub.Unsubscribe()
- for {
- select {
- case log := <-logs:
- // New log arrived, parse the event and forward to the user
- event := new(PublicResolverABIChanged)
- if err := _PublicResolver.contract.UnpackLog(event, "ABIChanged", log); err != nil {
- return err
- }
- event.Raw = log
-
- select {
- case sink <- event:
- case err := <-sub.Err():
- return err
- case <-quit:
- return nil
- }
- case err := <-sub.Err():
- return err
- case <-quit:
- return nil
- }
- }
- }), nil
-}
-
-// PublicResolverAddrChangedIterator is returned from FilterAddrChanged and is used to iterate over the raw logs and unpacked data for AddrChanged events raised by the PublicResolver contract.
-type PublicResolverAddrChangedIterator struct {
- Event *PublicResolverAddrChanged // Event containing the contract specifics and raw log
-
- contract *bind.BoundContract // Generic contract to use for unpacking event data
- event string // Event name to use for unpacking event data
-
- logs chan types.Log // Log channel receiving the found contract events
- sub ethereum.Subscription // Subscription for errors, completion and termination
- done bool // Whether the subscription completed delivering logs
- fail error // Occurred error to stop iteration
-}
-
-// Next advances the iterator to the subsequent event, returning whether there
-// are any more events found. In case of a retrieval or parsing error, false is
-// returned and Error() can be queried for the exact failure.
-func (it *PublicResolverAddrChangedIterator) Next() bool {
- // If the iterator failed, stop iterating
- if it.fail != nil {
- return false
- }
- // If the iterator completed, deliver directly whatever's available
- if it.done {
- select {
- case log := <-it.logs:
- it.Event = new(PublicResolverAddrChanged)
- if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil {
- it.fail = err
- return false
- }
- it.Event.Raw = log
- return true
-
- default:
- return false
- }
- }
- // Iterator still in progress, wait for either a data or an error event
- select {
- case log := <-it.logs:
- it.Event = new(PublicResolverAddrChanged)
- if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil {
- it.fail = err
- return false
- }
- it.Event.Raw = log
- return true
-
- case err := <-it.sub.Err():
- it.done = true
- it.fail = err
- return it.Next()
- }
-}
-
-// Error retruned any retrieval or parsing error occurred during filtering.
-func (it *PublicResolverAddrChangedIterator) Error() error {
- return it.fail
-}
-
-// Close terminates the iteration process, releasing any pending underlying
-// resources.
-func (it *PublicResolverAddrChangedIterator) Close() error {
- it.sub.Unsubscribe()
- return nil
-}
-
-// PublicResolverAddrChanged represents a AddrChanged event raised by the PublicResolver contract.
-type PublicResolverAddrChanged struct {
- Node [32]byte
- A common.Address
- Raw types.Log // Blockchain specific contextual infos
-}
-
-// FilterAddrChanged is a free log retrieval operation binding the contract event 0x52d7d861f09ab3d26239d492e8968629f95e9e318cf0b73bfddc441522a15fd2.
-//
-// Solidity: event AddrChanged(node indexed bytes32, a address)
-func (_PublicResolver *PublicResolverFilterer) FilterAddrChanged(opts *bind.FilterOpts, node [][32]byte) (*PublicResolverAddrChangedIterator, error) {
-
- var nodeRule []interface{}
- for _, nodeItem := range node {
- nodeRule = append(nodeRule, nodeItem)
- }
-
- logs, sub, err := _PublicResolver.contract.FilterLogs(opts, "AddrChanged", nodeRule)
- if err != nil {
- return nil, err
- }
- return &PublicResolverAddrChangedIterator{contract: _PublicResolver.contract, event: "AddrChanged", logs: logs, sub: sub}, nil
-}
-
-// WatchAddrChanged is a free log subscription operation binding the contract event 0x52d7d861f09ab3d26239d492e8968629f95e9e318cf0b73bfddc441522a15fd2.
-//
-// Solidity: event AddrChanged(node indexed bytes32, a address)
-func (_PublicResolver *PublicResolverFilterer) WatchAddrChanged(opts *bind.WatchOpts, sink chan<- *PublicResolverAddrChanged, node [][32]byte) (event.Subscription, error) {
-
- var nodeRule []interface{}
- for _, nodeItem := range node {
- nodeRule = append(nodeRule, nodeItem)
- }
-
- logs, sub, err := _PublicResolver.contract.WatchLogs(opts, "AddrChanged", nodeRule)
- if err != nil {
- return nil, err
- }
- return event.NewSubscription(func(quit <-chan struct{}) error {
- defer sub.Unsubscribe()
- for {
- select {
- case log := <-logs:
- // New log arrived, parse the event and forward to the user
- event := new(PublicResolverAddrChanged)
- if err := _PublicResolver.contract.UnpackLog(event, "AddrChanged", log); err != nil {
- return err
- }
- event.Raw = log
-
- select {
- case sink <- event:
- case err := <-sub.Err():
- return err
- case <-quit:
- return nil
- }
- case err := <-sub.Err():
- return err
- case <-quit:
- return nil
- }
- }
- }), nil
-}
-
-// PublicResolverContentChangedIterator is returned from FilterContentChanged and is used to iterate over the raw logs and unpacked data for ContentChanged events raised by the PublicResolver contract.
-type PublicResolverContentChangedIterator struct {
- Event *PublicResolverContentChanged // Event containing the contract specifics and raw log
-
- contract *bind.BoundContract // Generic contract to use for unpacking event data
- event string // Event name to use for unpacking event data
-
- logs chan types.Log // Log channel receiving the found contract events
- sub ethereum.Subscription // Subscription for errors, completion and termination
- done bool // Whether the subscription completed delivering logs
- fail error // Occurred error to stop iteration
-}
-
-// Next advances the iterator to the subsequent event, returning whether there
-// are any more events found. In case of a retrieval or parsing error, false is
-// returned and Error() can be queried for the exact failure.
-func (it *PublicResolverContentChangedIterator) Next() bool {
- // If the iterator failed, stop iterating
- if it.fail != nil {
- return false
- }
- // If the iterator completed, deliver directly whatever's available
- if it.done {
- select {
- case log := <-it.logs:
- it.Event = new(PublicResolverContentChanged)
- if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil {
- it.fail = err
- return false
- }
- it.Event.Raw = log
- return true
-
- default:
- return false
- }
- }
- // Iterator still in progress, wait for either a data or an error event
- select {
- case log := <-it.logs:
- it.Event = new(PublicResolverContentChanged)
- if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil {
- it.fail = err
- return false
- }
- it.Event.Raw = log
- return true
-
- case err := <-it.sub.Err():
- it.done = true
- it.fail = err
- return it.Next()
- }
-}
-
-// Error retruned any retrieval or parsing error occurred during filtering.
-func (it *PublicResolverContentChangedIterator) Error() error {
- return it.fail
-}
-
-// Close terminates the iteration process, releasing any pending underlying
-// resources.
-func (it *PublicResolverContentChangedIterator) Close() error {
- it.sub.Unsubscribe()
- return nil
-}
-
-// PublicResolverContentChanged represents a ContentChanged event raised by the PublicResolver contract.
-type PublicResolverContentChanged struct {
- Node [32]byte
- Hash [32]byte
- Raw types.Log // Blockchain specific contextual infos
-}
-
-// FilterContentChanged is a free log retrieval operation binding the contract event 0x0424b6fe0d9c3bdbece0e7879dc241bb0c22e900be8b6c168b4ee08bd9bf83bc.
-//
-// Solidity: event ContentChanged(node indexed bytes32, hash bytes32)
-func (_PublicResolver *PublicResolverFilterer) FilterContentChanged(opts *bind.FilterOpts, node [][32]byte) (*PublicResolverContentChangedIterator, error) {
-
- var nodeRule []interface{}
- for _, nodeItem := range node {
- nodeRule = append(nodeRule, nodeItem)
- }
-
- logs, sub, err := _PublicResolver.contract.FilterLogs(opts, "ContentChanged", nodeRule)
- if err != nil {
- return nil, err
- }
- return &PublicResolverContentChangedIterator{contract: _PublicResolver.contract, event: "ContentChanged", logs: logs, sub: sub}, nil
-}
-
-// WatchContentChanged is a free log subscription operation binding the contract event 0x0424b6fe0d9c3bdbece0e7879dc241bb0c22e900be8b6c168b4ee08bd9bf83bc.
-//
-// Solidity: event ContentChanged(node indexed bytes32, hash bytes32)
-func (_PublicResolver *PublicResolverFilterer) WatchContentChanged(opts *bind.WatchOpts, sink chan<- *PublicResolverContentChanged, node [][32]byte) (event.Subscription, error) {
-
- var nodeRule []interface{}
- for _, nodeItem := range node {
- nodeRule = append(nodeRule, nodeItem)
- }
-
- logs, sub, err := _PublicResolver.contract.WatchLogs(opts, "ContentChanged", nodeRule)
- if err != nil {
- return nil, err
- }
- return event.NewSubscription(func(quit <-chan struct{}) error {
- defer sub.Unsubscribe()
- for {
- select {
- case log := <-logs:
- // New log arrived, parse the event and forward to the user
- event := new(PublicResolverContentChanged)
- if err := _PublicResolver.contract.UnpackLog(event, "ContentChanged", log); err != nil {
- return err
- }
- event.Raw = log
-
- select {
- case sink <- event:
- case err := <-sub.Err():
- return err
- case <-quit:
- return nil
- }
- case err := <-sub.Err():
- return err
- case <-quit:
- return nil
- }
- }
- }), nil
-}
-
-// PublicResolverNameChangedIterator is returned from FilterNameChanged and is used to iterate over the raw logs and unpacked data for NameChanged events raised by the PublicResolver contract.
-type PublicResolverNameChangedIterator struct {
- Event *PublicResolverNameChanged // Event containing the contract specifics and raw log
-
- contract *bind.BoundContract // Generic contract to use for unpacking event data
- event string // Event name to use for unpacking event data
-
- logs chan types.Log // Log channel receiving the found contract events
- sub ethereum.Subscription // Subscription for errors, completion and termination
- done bool // Whether the subscription completed delivering logs
- fail error // Occurred error to stop iteration
-}
-
-// Next advances the iterator to the subsequent event, returning whether there
-// are any more events found. In case of a retrieval or parsing error, false is
-// returned and Error() can be queried for the exact failure.
-func (it *PublicResolverNameChangedIterator) Next() bool {
- // If the iterator failed, stop iterating
- if it.fail != nil {
- return false
- }
- // If the iterator completed, deliver directly whatever's available
- if it.done {
- select {
- case log := <-it.logs:
- it.Event = new(PublicResolverNameChanged)
- if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil {
- it.fail = err
- return false
- }
- it.Event.Raw = log
- return true
-
- default:
- return false
- }
- }
- // Iterator still in progress, wait for either a data or an error event
- select {
- case log := <-it.logs:
- it.Event = new(PublicResolverNameChanged)
- if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil {
- it.fail = err
- return false
- }
- it.Event.Raw = log
- return true
-
- case err := <-it.sub.Err():
- it.done = true
- it.fail = err
- return it.Next()
- }
-}
-
-// Error retruned any retrieval or parsing error occurred during filtering.
-func (it *PublicResolverNameChangedIterator) Error() error {
- return it.fail
-}
-
-// Close terminates the iteration process, releasing any pending underlying
-// resources.
-func (it *PublicResolverNameChangedIterator) Close() error {
- it.sub.Unsubscribe()
- return nil
-}
-
-// PublicResolverNameChanged represents a NameChanged event raised by the PublicResolver contract.
-type PublicResolverNameChanged struct {
- Node [32]byte
- Name string
- Raw types.Log // Blockchain specific contextual infos
-}
-
-// FilterNameChanged is a free log retrieval operation binding the contract event 0xb7d29e911041e8d9b843369e890bcb72c9388692ba48b65ac54e7214c4c348f7.
-//
-// Solidity: event NameChanged(node indexed bytes32, name string)
-func (_PublicResolver *PublicResolverFilterer) FilterNameChanged(opts *bind.FilterOpts, node [][32]byte) (*PublicResolverNameChangedIterator, error) {
-
- var nodeRule []interface{}
- for _, nodeItem := range node {
- nodeRule = append(nodeRule, nodeItem)
- }
-
- logs, sub, err := _PublicResolver.contract.FilterLogs(opts, "NameChanged", nodeRule)
- if err != nil {
- return nil, err
- }
- return &PublicResolverNameChangedIterator{contract: _PublicResolver.contract, event: "NameChanged", logs: logs, sub: sub}, nil
-}
-
-// WatchNameChanged is a free log subscription operation binding the contract event 0xb7d29e911041e8d9b843369e890bcb72c9388692ba48b65ac54e7214c4c348f7.
-//
-// Solidity: event NameChanged(node indexed bytes32, name string)
-func (_PublicResolver *PublicResolverFilterer) WatchNameChanged(opts *bind.WatchOpts, sink chan<- *PublicResolverNameChanged, node [][32]byte) (event.Subscription, error) {
-
- var nodeRule []interface{}
- for _, nodeItem := range node {
- nodeRule = append(nodeRule, nodeItem)
- }
-
- logs, sub, err := _PublicResolver.contract.WatchLogs(opts, "NameChanged", nodeRule)
- if err != nil {
- return nil, err
- }
- return event.NewSubscription(func(quit <-chan struct{}) error {
- defer sub.Unsubscribe()
- for {
- select {
- case log := <-logs:
- // New log arrived, parse the event and forward to the user
- event := new(PublicResolverNameChanged)
- if err := _PublicResolver.contract.UnpackLog(event, "NameChanged", log); err != nil {
- return err
- }
- event.Raw = log
-
- select {
- case sink <- event:
- case err := <-sub.Err():
- return err
- case <-quit:
- return nil
- }
- case err := <-sub.Err():
- return err
- case <-quit:
- return nil
- }
- }
- }), nil
-}
-
-// PublicResolverPubkeyChangedIterator is returned from FilterPubkeyChanged and is used to iterate over the raw logs and unpacked data for PubkeyChanged events raised by the PublicResolver contract.
-type PublicResolverPubkeyChangedIterator struct {
- Event *PublicResolverPubkeyChanged // Event containing the contract specifics and raw log
-
- contract *bind.BoundContract // Generic contract to use for unpacking event data
- event string // Event name to use for unpacking event data
-
- logs chan types.Log // Log channel receiving the found contract events
- sub ethereum.Subscription // Subscription for errors, completion and termination
- done bool // Whether the subscription completed delivering logs
- fail error // Occurred error to stop iteration
-}
-
-// Next advances the iterator to the subsequent event, returning whether there
-// are any more events found. In case of a retrieval or parsing error, false is
-// returned and Error() can be queried for the exact failure.
-func (it *PublicResolverPubkeyChangedIterator) Next() bool {
- // If the iterator failed, stop iterating
- if it.fail != nil {
- return false
- }
- // If the iterator completed, deliver directly whatever's available
- if it.done {
- select {
- case log := <-it.logs:
- it.Event = new(PublicResolverPubkeyChanged)
- if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil {
- it.fail = err
- return false
- }
- it.Event.Raw = log
- return true
-
- default:
- return false
- }
- }
- // Iterator still in progress, wait for either a data or an error event
- select {
- case log := <-it.logs:
- it.Event = new(PublicResolverPubkeyChanged)
- if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil {
- it.fail = err
- return false
- }
- it.Event.Raw = log
- return true
-
- case err := <-it.sub.Err():
- it.done = true
- it.fail = err
- return it.Next()
- }
-}
-
-// Error retruned any retrieval or parsing error occurred during filtering.
-func (it *PublicResolverPubkeyChangedIterator) Error() error {
- return it.fail
-}
-
-// Close terminates the iteration process, releasing any pending underlying
-// resources.
-func (it *PublicResolverPubkeyChangedIterator) Close() error {
- it.sub.Unsubscribe()
- return nil
-}
-
-// PublicResolverPubkeyChanged represents a PubkeyChanged event raised by the PublicResolver contract.
-type PublicResolverPubkeyChanged struct {
- Node [32]byte
- X [32]byte
- Y [32]byte
- Raw types.Log // Blockchain specific contextual infos
-}
-
-// FilterPubkeyChanged is a free log retrieval operation binding the contract event 0x1d6f5e03d3f63eb58751986629a5439baee5079ff04f345becb66e23eb154e46.
-//
-// Solidity: event PubkeyChanged(node indexed bytes32, x bytes32, y bytes32)
-func (_PublicResolver *PublicResolverFilterer) FilterPubkeyChanged(opts *bind.FilterOpts, node [][32]byte) (*PublicResolverPubkeyChangedIterator, error) {
-
- var nodeRule []interface{}
- for _, nodeItem := range node {
- nodeRule = append(nodeRule, nodeItem)
- }
-
- logs, sub, err := _PublicResolver.contract.FilterLogs(opts, "PubkeyChanged", nodeRule)
- if err != nil {
- return nil, err
- }
- return &PublicResolverPubkeyChangedIterator{contract: _PublicResolver.contract, event: "PubkeyChanged", logs: logs, sub: sub}, nil
-}
-
-// WatchPubkeyChanged is a free log subscription operation binding the contract event 0x1d6f5e03d3f63eb58751986629a5439baee5079ff04f345becb66e23eb154e46.
-//
-// Solidity: event PubkeyChanged(node indexed bytes32, x bytes32, y bytes32)
-func (_PublicResolver *PublicResolverFilterer) WatchPubkeyChanged(opts *bind.WatchOpts, sink chan<- *PublicResolverPubkeyChanged, node [][32]byte) (event.Subscription, error) {
-
- var nodeRule []interface{}
- for _, nodeItem := range node {
- nodeRule = append(nodeRule, nodeItem)
- }
-
- logs, sub, err := _PublicResolver.contract.WatchLogs(opts, "PubkeyChanged", nodeRule)
- if err != nil {
- return nil, err
- }
- return event.NewSubscription(func(quit <-chan struct{}) error {
- defer sub.Unsubscribe()
- for {
- select {
- case log := <-logs:
- // New log arrived, parse the event and forward to the user
- event := new(PublicResolverPubkeyChanged)
- if err := _PublicResolver.contract.UnpackLog(event, "PubkeyChanged", log); err != nil {
- return err
- }
- event.Raw = log
-
- select {
- case sink <- event:
- case err := <-sub.Err():
- return err
- case <-quit:
- return nil
- }
- case err := <-sub.Err():
- return err
- case <-quit:
- return nil
- }
- }
- }), nil
-}
-
-// PublicResolverTextChangedIterator is returned from FilterTextChanged and is used to iterate over the raw logs and unpacked data for TextChanged events raised by the PublicResolver contract.
-type PublicResolverTextChangedIterator struct {
- Event *PublicResolverTextChanged // Event containing the contract specifics and raw log
-
- contract *bind.BoundContract // Generic contract to use for unpacking event data
- event string // Event name to use for unpacking event data
-
- logs chan types.Log // Log channel receiving the found contract events
- sub ethereum.Subscription // Subscription for errors, completion and termination
- done bool // Whether the subscription completed delivering logs
- fail error // Occurred error to stop iteration
-}
-
-// Next advances the iterator to the subsequent event, returning whether there
-// are any more events found. In case of a retrieval or parsing error, false is
-// returned and Error() can be queried for the exact failure.
-func (it *PublicResolverTextChangedIterator) Next() bool {
- // If the iterator failed, stop iterating
- if it.fail != nil {
- return false
- }
- // If the iterator completed, deliver directly whatever's available
- if it.done {
- select {
- case log := <-it.logs:
- it.Event = new(PublicResolverTextChanged)
- if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil {
- it.fail = err
- return false
- }
- it.Event.Raw = log
- return true
-
- default:
- return false
- }
- }
- // Iterator still in progress, wait for either a data or an error event
- select {
- case log := <-it.logs:
- it.Event = new(PublicResolverTextChanged)
- if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil {
- it.fail = err
- return false
- }
- it.Event.Raw = log
- return true
-
- case err := <-it.sub.Err():
- it.done = true
- it.fail = err
- return it.Next()
- }
-}
-
-// Error retruned any retrieval or parsing error occurred during filtering.
-func (it *PublicResolverTextChangedIterator) Error() error {
- return it.fail
-}
-
-// Close terminates the iteration process, releasing any pending underlying
-// resources.
-func (it *PublicResolverTextChangedIterator) Close() error {
- it.sub.Unsubscribe()
- return nil
-}
-
-// PublicResolverTextChanged represents a TextChanged event raised by the PublicResolver contract.
-type PublicResolverTextChanged struct {
- Node [32]byte
- IndexedKey common.Hash
- Key string
- Raw types.Log // Blockchain specific contextual infos
-}
-
-// FilterTextChanged is a free log retrieval operation binding the contract event 0xd8c9334b1a9c2f9da342a0a2b32629c1a229b6445dad78947f674b44444a7550.
-//
-// Solidity: event TextChanged(node indexed bytes32, indexedKey indexed string, key string)
-func (_PublicResolver *PublicResolverFilterer) FilterTextChanged(opts *bind.FilterOpts, node [][32]byte, indexedKey []string) (*PublicResolverTextChangedIterator, error) {
-
- var nodeRule []interface{}
- for _, nodeItem := range node {
- nodeRule = append(nodeRule, nodeItem)
- }
- var indexedKeyRule []interface{}
- for _, indexedKeyItem := range indexedKey {
- indexedKeyRule = append(indexedKeyRule, indexedKeyItem)
- }
-
- logs, sub, err := _PublicResolver.contract.FilterLogs(opts, "TextChanged", nodeRule, indexedKeyRule)
- if err != nil {
- return nil, err
- }
- return &PublicResolverTextChangedIterator{contract: _PublicResolver.contract, event: "TextChanged", logs: logs, sub: sub}, nil
-}
-
-// WatchTextChanged is a free log subscription operation binding the contract event 0xd8c9334b1a9c2f9da342a0a2b32629c1a229b6445dad78947f674b44444a7550.
-//
-// Solidity: event TextChanged(node indexed bytes32, indexedKey indexed string, key string)
-func (_PublicResolver *PublicResolverFilterer) WatchTextChanged(opts *bind.WatchOpts, sink chan<- *PublicResolverTextChanged, node [][32]byte, indexedKey []string) (event.Subscription, error) {
-
- var nodeRule []interface{}
- for _, nodeItem := range node {
- nodeRule = append(nodeRule, nodeItem)
- }
- var indexedKeyRule []interface{}
- for _, indexedKeyItem := range indexedKey {
- indexedKeyRule = append(indexedKeyRule, indexedKeyItem)
- }
-
- logs, sub, err := _PublicResolver.contract.WatchLogs(opts, "TextChanged", nodeRule, indexedKeyRule)
- if err != nil {
- return nil, err
- }
- return event.NewSubscription(func(quit <-chan struct{}) error {
- defer sub.Unsubscribe()
- for {
- select {
- case log := <-logs:
- // New log arrived, parse the event and forward to the user
- event := new(PublicResolverTextChanged)
- if err := _PublicResolver.contract.UnpackLog(event, "TextChanged", log); err != nil {
- return err
- }
- event.Raw = log
-
- select {
- case sink <- event:
- case err := <-sub.Err():
- return err
- case <-quit:
- return nil
- }
- case err := <-sub.Err():
- return err
- case <-quit:
- return nil
- }
- }
- }), nil
-}
diff --git a/contracts/ens/ens.go b/contracts/ens/ens.go
deleted file mode 100644
index 7c47865097b8..000000000000
--- a/contracts/ens/ens.go
+++ /dev/null
@@ -1,178 +0,0 @@
-// Copyright 2016 The go-ethereum Authors
-// This file is part of the go-ethereum library.
-//
-// The go-ethereum library is free software: you can redistribute it and/or modify
-// it under the terms of the GNU Lesser General Public License as published by
-// the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// The go-ethereum library is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU Lesser General Public License for more details.
-//
-// You should have received a copy of the GNU Lesser General Public License
-// along with the go-ethereum library. If not, see .
-
-package ens
-
-//go:generate abigen --sol contract/ENS.sol --exc contract/AbstractENS.sol:AbstractENS --pkg contract --out contract/ens.go
-//go:generate abigen --sol contract/FIFSRegistrar.sol --exc contract/AbstractENS.sol:AbstractENS --pkg contract --out contract/fifsregistrar.go
-//go:generate abigen --sol contract/PublicResolver.sol --exc contract/AbstractENS.sol:AbstractENS --pkg contract --out contract/publicresolver.go
-
-import (
- "strings"
-
- "github.com/XinFinOrg/XDPoSChain/accounts/abi/bind"
- "github.com/XinFinOrg/XDPoSChain/common"
- "github.com/XinFinOrg/XDPoSChain/contracts/ens/contract"
- "github.com/XinFinOrg/XDPoSChain/core/types"
- "github.com/XinFinOrg/XDPoSChain/crypto"
-)
-
-var (
- MainNetAddress = common.HexToAddress("0x314159265dD8dbb310642f98f50C066173C1259b")
- TestNetAddress = common.HexToAddress("0x112234455c3a32fd11230c42e7bccd4a84e02010")
-)
-
-// swarm domain name registry and resolver
-type ENS struct {
- *contract.ENSSession
- contractBackend bind.ContractBackend
-}
-
-// NewENS creates a struct exposing convenient high-level operations for interacting with
-// the Ethereum Name Service.
-func NewENS(transactOpts *bind.TransactOpts, contractAddr common.Address, contractBackend bind.ContractBackend) (*ENS, error) {
- ens, err := contract.NewENS(contractAddr, contractBackend)
- if err != nil {
- return nil, err
- }
-
- return &ENS{
- &contract.ENSSession{
- Contract: ens,
- TransactOpts: *transactOpts,
- },
- contractBackend,
- }, nil
-}
-
-// DeployENS deploys an instance of the ENS nameservice, with a 'first-in, first-served' root registrar.
-func DeployENS(transactOpts *bind.TransactOpts, contractBackend bind.ContractBackend) (common.Address, *ENS, error) {
- // Deploy the ENS registry.
- ensAddr, _, _, err := contract.DeployENS(transactOpts, contractBackend)
- if err != nil {
- return ensAddr, nil, err
- }
-
- ens, err := NewENS(transactOpts, ensAddr, contractBackend)
- if err != nil {
- return ensAddr, nil, err
- }
-
- // Deploy the registrar.
- regAddr, _, _, err := contract.DeployFIFSRegistrar(transactOpts, contractBackend, ensAddr, [32]byte{})
- if err != nil {
- return ensAddr, nil, err
- }
- // Set the registrar as owner of the ENS root.
- if _, err = ens.SetOwner([32]byte{}, regAddr); err != nil {
- return ensAddr, nil, err
- }
-
- return ensAddr, ens, nil
-}
-
-func ensParentNode(name string) (common.Hash, common.Hash) {
- parts := strings.SplitN(name, ".", 2)
- label := crypto.Keccak256Hash([]byte(parts[0]))
- if len(parts) == 1 {
- return [32]byte{}, label
- } else {
- parentNode, parentLabel := ensParentNode(parts[1])
- return crypto.Keccak256Hash(parentNode[:], parentLabel[:]), label
- }
-}
-
-func ensNode(name string) common.Hash {
- parentNode, parentLabel := ensParentNode(name)
- return crypto.Keccak256Hash(parentNode[:], parentLabel[:])
-}
-
-func (e *ENS) getResolver(node [32]byte) (*contract.PublicResolverSession, error) {
- resolverAddr, err := e.Resolver(node)
- if err != nil {
- return nil, err
- }
-
- resolver, err := contract.NewPublicResolver(resolverAddr, e.contractBackend)
- if err != nil {
- return nil, err
- }
-
- return &contract.PublicResolverSession{
- Contract: resolver,
- TransactOpts: e.TransactOpts,
- }, nil
-}
-
-func (e *ENS) getRegistrar(node [32]byte) (*contract.FIFSRegistrarSession, error) {
- registrarAddr, err := e.Owner(node)
- if err != nil {
- return nil, err
- }
-
- registrar, err := contract.NewFIFSRegistrar(registrarAddr, e.contractBackend)
- if err != nil {
- return nil, err
- }
-
- return &contract.FIFSRegistrarSession{
- Contract: registrar,
- TransactOpts: e.TransactOpts,
- }, nil
-}
-
-// Resolve is a non-transactional call that returns the content hash associated with a name.
-func (e *ENS) Resolve(name string) (common.Hash, error) {
- node := ensNode(name)
-
- resolver, err := e.getResolver(node)
- if err != nil {
- return common.Hash{}, err
- }
-
- ret, err := resolver.Content(node)
- if err != nil {
- return common.Hash{}, err
- }
-
- return common.BytesToHash(ret[:]), nil
-}
-
-// Register registers a new domain name for the caller, making them the owner of the new name.
-// Only works if the registrar for the parent domain implements the FIFS registrar protocol.
-func (e *ENS) Register(name string) (*types.Transaction, error) {
- parentNode, label := ensParentNode(name)
- registrar, err := e.getRegistrar(parentNode)
- if err != nil {
- return nil, err
- }
- return registrar.Contract.Register(&e.TransactOpts, label, e.TransactOpts.From)
-}
-
-// SetContentHash sets the content hash associated with a name. Only works if the caller
-// owns the name, and the associated resolver implements a `setContent` function.
-func (e *ENS) SetContentHash(name string, hash common.Hash) (*types.Transaction, error) {
- node := ensNode(name)
-
- resolver, err := e.getResolver(node)
- if err != nil {
- return nil, err
- }
-
- opts := e.TransactOpts
- opts.GasLimit = 200000
- return resolver.Contract.SetContent(&opts, node, hash)
-}
diff --git a/contracts/ens/ens_test.go b/contracts/ens/ens_test.go
deleted file mode 100644
index 410b5acdadf1..000000000000
--- a/contracts/ens/ens_test.go
+++ /dev/null
@@ -1,78 +0,0 @@
-// Copyright 2016 The go-ethereum Authors
-// This file is part of the go-ethereum library.
-//
-// The go-ethereum library is free software: you can redistribute it and/or modify
-// it under the terms of the GNU Lesser General Public License as published by
-// the Free Software Foundation, either version 3 of the License, or
-// (at your option) any later version.
-//
-// The go-ethereum library is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-// GNU Lesser General Public License for more details.
-//
-// You should have received a copy of the GNU Lesser General Public License
-// along with the go-ethereum library. If not, see .
-
-package ens
-
-import (
- "math/big"
- "testing"
-
- "github.com/XinFinOrg/XDPoSChain/accounts/abi/bind"
- "github.com/XinFinOrg/XDPoSChain/accounts/abi/bind/backends"
- "github.com/XinFinOrg/XDPoSChain/contracts/ens/contract"
- "github.com/XinFinOrg/XDPoSChain/core"
- "github.com/XinFinOrg/XDPoSChain/crypto"
- "github.com/XinFinOrg/XDPoSChain/params"
-)
-
-var (
- key, _ = crypto.HexToECDSA("b71c71a67e1177ad4e901695e1b4b9ee17ae16c6668d313eac2f96dbcda3f291")
- name = "my name on ENS"
- hash = crypto.Keccak256Hash([]byte("my content"))
- addr = crypto.PubkeyToAddress(key.PublicKey)
-)
-
-func TestENS(t *testing.T) {
- contractBackend := backends.NewXDCSimulatedBackend(core.GenesisAlloc{addr: {Balance: big.NewInt(1000000000)}}, 10000000, params.TestXDPoSMockChainConfig)
- transactOpts := bind.NewKeyedTransactor(key)
-
- ensAddr, ens, err := DeployENS(transactOpts, contractBackend)
- if err != nil {
- t.Fatalf("can't deploy root registry: %v", err)
- }
- contractBackend.Commit()
-
- // Set ourself as the owner of the name.
- if _, err := ens.Register(name); err != nil {
- t.Fatalf("can't register: %v", err)
- }
- contractBackend.Commit()
-
- // Deploy a resolver and make it responsible for the name.
- resolverAddr, _, _, err := contract.DeployPublicResolver(transactOpts, contractBackend, ensAddr)
- if err != nil {
- t.Fatalf("can't deploy resolver: %v", err)
- }
- if _, err := ens.SetResolver(ensNode(name), resolverAddr); err != nil {
- t.Fatalf("can't set resolver: %v", err)
- }
- contractBackend.Commit()
-
- // Set the content hash for the name.
- if _, err = ens.SetContentHash(name, hash); err != nil {
- t.Fatalf("can't set content hash: %v", err)
- }
- contractBackend.Commit()
-
- // Try to resolve the name.
- vhost, err := ens.Resolve(name)
- if err != nil {
- t.Fatalf("expected no error, got %v", err)
- }
- if vhost != hash {
- t.Fatalf("resolve error, expected %v, got %v", hash.Hex(), vhost.Hex())
- }
-}