From ed2f00b61c679eac483e36b2bf56cd6f15edc3b3 Mon Sep 17 00:00:00 2001 From: AnilChinchawale Date: Wed, 16 Jan 2019 04:37:33 +0530 Subject: [PATCH] Changes added in Smart-Contract --- contracts/validator/contract/XDCValidator.sol | 137 +-- .../validator/contract/libs/SafeMath.sol | 12 +- contracts/validator/contract/validator.go | 1089 +++++++---------- 3 files changed, 459 insertions(+), 779 deletions(-) diff --git a/contracts/validator/contract/XDCValidator.sol b/contracts/validator/contract/XDCValidator.sol index e35159507a..34d8b4e51b 100644 --- a/contracts/validator/contract/XDCValidator.sol +++ b/contracts/validator/contract/XDCValidator.sol @@ -1,52 +1,6 @@ pragma solidity ^0.4.21; -// This contract is under development. -// Refer to readme for further details. - - -library SafeMath { - - /** - * @dev Multiplies two numbers, throws on overflow. - */ - function mul(uint256 a, uint256 b) internal pure returns (uint256) { - if (a == 0) { - return 0; - } - uint256 c = a * b; - assert(c / a == b); - return c; - } - - /** - * @dev Integer division of two numbers, truncating the quotient. - */ - function div(uint256 a, uint256 b) internal pure returns (uint256) { - // assert(b > 0); // Solidity automatically throws when dividing by 0 - // uint256 c = a / b; - // assert(a == b * c + a % b); // There is no case in which this doesn't hold - return a / b; - } - - /** - * @dev Subtracts two numbers, throws on overflow (i.e. if subtrahend is greater than minuend). - */ - function sub(uint256 a, uint256 b) internal pure returns (uint256) { - assert(b <= a); - return a - b; - } - - /** - * @dev Adds two numbers, throws on overflow. - */ - function add(uint256 a, uint256 b) internal pure returns (uint256) { - uint256 c = a + b; - assert(c >= a); - return c; - } -} - - +import "./libs/SafeMath.sol"; contract XDCValidator { using SafeMath for uint256; @@ -73,14 +27,6 @@ contract XDCValidator { mapping(address => ValidatorState) validatorsState; mapping(address => address[]) voters; - - // Mapping structures added for KYC feature. - mapping(address => string) public KYCString; - mapping(address => uint) public invalidKYCCount; - mapping(address => mapping(address => bool)) public hasVotedInvalid; - mapping(address => address[]) public ownerToCandidate; - address[] public owners; - address[] public candidates; uint256 public candidateCount = 0; @@ -97,20 +43,10 @@ contract XDCValidator { } modifier onlyValidVoterCap { - require(msg.value >= minVoterCap); _; } - modifier onlyKYCWhitelisted { - if(bytes(KYCString[msg.sender]).length != 0) - {_;} - else{ - if (ownerToCandidate[msg.sender].length > 0) - {_;} - } - } - modifier onlyOwner(address _candidate) { require(validatorsState[_candidate].owner == msg.sender); _; @@ -163,7 +99,7 @@ contract XDCValidator { candidateWithdrawDelay = _candidateWithdrawDelay; voterWithdrawDelay = _voterWithdrawDelay; candidateCount = _candidates.length; - owners.push(_firstOwner); + for (uint256 i = 0; i < _candidates.length; i++) { candidates.push(_candidates[i]); validatorsState[_candidates[i]] = ValidatorState({ @@ -172,20 +108,11 @@ contract XDCValidator { cap: _caps[i] }); voters[_candidates[i]].push(_firstOwner); - ownerToCandidate[_firstOwner].push(_candidates[i]); validatorsState[_candidates[i]].voters[_firstOwner] = minCandidateCap; } } - - // uploadKYC : anyone can upload a KYC; its not equivalent to becoming an owner. - function uploadKYC(string kychash) external { - require(bytes(KYCString[msg.sender]).length==0); - KYCString[msg.sender]=kychash; - } - - // propose : any non-candidate who has uploaded its KYC can become an owner by proposing a candidate. - function propose(address _candidate) external payable onlyValidCandidateCap onlyKYCWhitelisted onlyNotCandidate(_candidate) { + function propose(address _candidate) external payable onlyValidCandidateCap onlyNotCandidate(_candidate) { uint256 cap = validatorsState[_candidate].cap.add(msg.value); candidates.push(_candidate); validatorsState[_candidate] = ValidatorState({ @@ -195,11 +122,6 @@ contract XDCValidator { }); validatorsState[_candidate].voters[msg.sender] = validatorsState[_candidate].voters[msg.sender].add(msg.value); candidateCount = candidateCount.add(1); - if (ownerToCandidate[msg.sender].length ==0){ - owners.push(msg.sender); - - } - ownerToCandidate[msg.sender].push(_candidate); voters[_candidate].push(msg.sender); emit Propose(msg.sender, _candidate, msg.value); } @@ -276,59 +198,6 @@ contract XDCValidator { emit Resign(msg.sender, _candidate); } - // voteInvalidKYC : any candidate can vote for invalid KYC i.e. a particular candidate's owner has uploaded a bad KYC. - // On securing 75% votes against an owner ( not candidate ), owner & all its candidates will lose their funds. - function voteInvalidKYC(address _invalidCandidate) onlyValidCandidate(msg.sender) onlyValidCandidate(_invalidCandidate) public { - address candidateOwner = getCandidateOwner(msg.sender); - address _invalidMasternode = getCandidateOwner(_invalidCandidate); - require(!hasVotedInvalid[candidateOwner][_invalidMasternode]); - hasVotedInvalid[candidateOwner][_invalidMasternode] = true; - invalidKYCCount[_invalidMasternode] += 1; - if( invalidKYCCount[_invalidMasternode]*100/getOwnerCount() >= 75 ){ - // 75% owners say that the KYC is invalid - for (uint i=0;i= a); return c; } -} \ No newline at end of file +} diff --git a/contracts/validator/contract/validator.go b/contracts/validator/contract/validator.go index 04923e7c8c..503154caef 100644 --- a/contracts/validator/contract/validator.go +++ b/contracts/validator/contract/validator.go @@ -2,6 +2,7 @@ // This file is a generated binding and any manual changes will be lost. package contract + import ( "math/big" "strings" @@ -14,123 +15,119 @@ import ( "github.com/ethereum/go-ethereum/event" ) -// SafeMathABI is the input ABI used to generate the binding from. -const SafeMathABI = "[]" +// Reference imports to suppress errors if they are not otherwise used. +var ( + _ = big.NewInt + _ = strings.NewReader + _ = ethereum.NotFound + _ = abi.U256 + _ = bind.Bind + _ = common.Big1 + _ = types.BloomLookup + _ = event.NewSubscription +) -// SafeMathBin is the compiled bytecode used for deploying new contracts. -const SafeMathBin = `0x604c602c600b82828239805160001a60731460008114601c57601e565bfe5b5030600052607381538281f30073000000000000000000000000000000000000000030146060604052600080fd00a165627a7a72305820b9407d48ebc7efee5c9f08b3b3a957df2939281f5913225e8c1291f069b900490029` +// KycABI is the input ABI used to generate the binding from. +const KycABI = "[{\"constant\":false,\"inputs\":[{\"name\":\"_candidate\",\"type\":\"address\"}],\"name\":\"propose\",\"outputs\":[],\"payable\":true,\"stateMutability\":\"payable\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"owners\",\"outputs\":[{\"name\":\"\",\"type\":\"address\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_candidate\",\"type\":\"address\"},{\"name\":\"_cap\",\"type\":\"uint256\"}],\"name\":\"unvote\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"getCandidates\",\"outputs\":[{\"name\":\"\",\"type\":\"address[]\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"\",\"type\":\"address\"},{\"name\":\"\",\"type\":\"address\"}],\"name\":\"hasVotedInvalid\",\"outputs\":[{\"name\":\"\",\"type\":\"bool\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_blockNumber\",\"type\":\"uint256\"}],\"name\":\"getWithdrawCap\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"\",\"type\":\"address\"},{\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"ownerToCandidate\",\"outputs\":[{\"name\":\"\",\"type\":\"address\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_candidate\",\"type\":\"address\"}],\"name\":\"getVoters\",\"outputs\":[{\"name\":\"\",\"type\":\"address[]\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"getWithdrawBlockNumbers\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256[]\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_candidate\",\"type\":\"address\"},{\"name\":\"_voter\",\"type\":\"address\"}],\"name\":\"getVoterCap\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"candidates\",\"outputs\":[{\"name\":\"\",\"type\":\"address\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_blockNumber\",\"type\":\"uint256\"},{\"name\":\"_index\",\"type\":\"uint256\"}],\"name\":\"withdraw\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_candidate\",\"type\":\"address\"}],\"name\":\"getCandidateCap\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_candidate\",\"type\":\"address\"}],\"name\":\"vote\",\"outputs\":[],\"payable\":true,\"stateMutability\":\"payable\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"\",\"type\":\"address\"}],\"name\":\"invalidKYCCount\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_invalidMasternode\",\"type\":\"address\"}],\"name\":\"InvalidPercent\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_invalidMasternode\",\"type\":\"address\"}],\"name\":\"VoteInvalidKYC\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"candidateCount\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"voterWithdrawDelay\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_candidate\",\"type\":\"address\"}],\"name\":\"resign\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_candidate\",\"type\":\"address\"}],\"name\":\"getCandidateOwner\",\"outputs\":[{\"name\":\"\",\"type\":\"address\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"maxValidatorNumber\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"candidateWithdrawDelay\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_candidate\",\"type\":\"address\"}],\"name\":\"isCandidate\",\"outputs\":[{\"name\":\"\",\"type\":\"bool\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"minCandidateCap\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_kycdata\",\"type\":\"bytes32\"}],\"name\":\"uploadKYC\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"getOwnerCount\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"minVoterCap\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_masternode\",\"type\":\"address\"}],\"name\":\"getOwner\",\"outputs\":[{\"name\":\"\",\"type\":\"address\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"inputs\":[{\"name\":\"_candidates\",\"type\":\"address[]\"},{\"name\":\"_caps\",\"type\":\"uint256[]\"},{\"name\":\"_firstOwner\",\"type\":\"address\"},{\"name\":\"_minCandidateCap\",\"type\":\"uint256\"},{\"name\":\"_minVoterCap\",\"type\":\"uint256\"},{\"name\":\"_maxValidatorNumber\",\"type\":\"uint256\"},{\"name\":\"_candidateWithdrawDelay\",\"type\":\"uint256\"},{\"name\":\"_voterWithdrawDelay\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"name\":\"_voter\",\"type\":\"address\"},{\"indexed\":false,\"name\":\"_candidate\",\"type\":\"address\"},{\"indexed\":false,\"name\":\"_cap\",\"type\":\"uint256\"}],\"name\":\"Vote\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"name\":\"_voter\",\"type\":\"address\"},{\"indexed\":false,\"name\":\"_candidate\",\"type\":\"address\"},{\"indexed\":false,\"name\":\"_cap\",\"type\":\"uint256\"}],\"name\":\"Unvote\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"name\":\"_owner\",\"type\":\"address\"},{\"indexed\":false,\"name\":\"_candidate\",\"type\":\"address\"},{\"indexed\":false,\"name\":\"_cap\",\"type\":\"uint256\"}],\"name\":\"Propose\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"name\":\"_owner\",\"type\":\"address\"},{\"indexed\":false,\"name\":\"_candidate\",\"type\":\"address\"}],\"name\":\"Resign\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"name\":\"_owner\",\"type\":\"address\"},{\"indexed\":false,\"name\":\"_blockNumber\",\"type\":\"uint256\"},{\"indexed\":false,\"name\":\"_cap\",\"type\":\"uint256\"}],\"name\":\"Withdraw\",\"type\":\"event\"}]" -// DeploySafeMath deploys a new Ethereum contract, binding an instance of SafeMath to it. -func DeploySafeMath(auth *bind.TransactOpts, backend bind.ContractBackend) (common.Address, *types.Transaction, *SafeMath, error) { - parsed, err := abi.JSON(strings.NewReader(SafeMathABI)) - if err != nil { - return common.Address{}, nil, nil, err - } - address, tx, contract, err := bind.DeployContract(auth, parsed, common.FromHex(SafeMathBin), backend) - if err != nil { - return common.Address{}, nil, nil, err - } - return address, tx, &SafeMath{SafeMathCaller: SafeMathCaller{contract: contract}, SafeMathTransactor: SafeMathTransactor{contract: contract}, SafeMathFilterer: SafeMathFilterer{contract: contract}}, nil +// Kyc is an auto generated Go binding around an Ethereum contract. +type Kyc struct { + KycCaller // Read-only binding to the contract + KycTransactor // Write-only binding to the contract + KycFilterer // Log filterer for contract events } -// SafeMath is an auto generated Go binding around an Ethereum contract. -type SafeMath struct { - SafeMathCaller // Read-only binding to the contract - SafeMathTransactor // Write-only binding to the contract - SafeMathFilterer // Log filterer for contract events -} - -// SafeMathCaller is an auto generated read-only Go binding around an Ethereum contract. -type SafeMathCaller struct { +// KycCaller is an auto generated read-only Go binding around an Ethereum contract. +type KycCaller struct { contract *bind.BoundContract // Generic contract wrapper for the low level calls } -// SafeMathTransactor is an auto generated write-only Go binding around an Ethereum contract. -type SafeMathTransactor struct { +// KycTransactor is an auto generated write-only Go binding around an Ethereum contract. +type KycTransactor struct { contract *bind.BoundContract // Generic contract wrapper for the low level calls } -// SafeMathFilterer is an auto generated log filtering Go binding around an Ethereum contract events. -type SafeMathFilterer struct { +// KycFilterer is an auto generated log filtering Go binding around an Ethereum contract events. +type KycFilterer struct { contract *bind.BoundContract // Generic contract wrapper for the low level calls } -// SafeMathSession is an auto generated Go binding around an Ethereum contract, +// KycSession is an auto generated Go binding around an Ethereum contract, // with pre-set call and transact options. -type SafeMathSession struct { - Contract *SafeMath // Generic contract binding to set the session for +type KycSession struct { + Contract *Kyc // 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 } -// SafeMathCallerSession is an auto generated read-only Go binding around an Ethereum contract, +// KycCallerSession is an auto generated read-only Go binding around an Ethereum contract, // with pre-set call options. -type SafeMathCallerSession struct { - Contract *SafeMathCaller // Generic contract caller binding to set the session for - CallOpts bind.CallOpts // Call options to use throughout this session +type KycCallerSession struct { + Contract *KycCaller // Generic contract caller binding to set the session for + CallOpts bind.CallOpts // Call options to use throughout this session } -// SafeMathTransactorSession is an auto generated write-only Go binding around an Ethereum contract, +// KycTransactorSession is an auto generated write-only Go binding around an Ethereum contract, // with pre-set transact options. -type SafeMathTransactorSession struct { - Contract *SafeMathTransactor // Generic contract transactor binding to set the session for - TransactOpts bind.TransactOpts // Transaction auth options to use throughout this session +type KycTransactorSession struct { + Contract *KycTransactor // Generic contract transactor binding to set the session for + TransactOpts bind.TransactOpts // Transaction auth options to use throughout this session } -// SafeMathRaw is an auto generated low-level Go binding around an Ethereum contract. -type SafeMathRaw struct { - Contract *SafeMath // Generic contract binding to access the raw methods on +// KycRaw is an auto generated low-level Go binding around an Ethereum contract. +type KycRaw struct { + Contract *Kyc // Generic contract binding to access the raw methods on } -// SafeMathCallerRaw is an auto generated low-level read-only Go binding around an Ethereum contract. -type SafeMathCallerRaw struct { - Contract *SafeMathCaller // Generic read-only contract binding to access the raw methods on +// KycCallerRaw is an auto generated low-level read-only Go binding around an Ethereum contract. +type KycCallerRaw struct { + Contract *KycCaller // Generic read-only contract binding to access the raw methods on } -// SafeMathTransactorRaw is an auto generated low-level write-only Go binding around an Ethereum contract. -type SafeMathTransactorRaw struct { - Contract *SafeMathTransactor // Generic write-only contract binding to access the raw methods on +// KycTransactorRaw is an auto generated low-level write-only Go binding around an Ethereum contract. +type KycTransactorRaw struct { + Contract *KycTransactor // Generic write-only contract binding to access the raw methods on } -// NewSafeMath creates a new instance of SafeMath, bound to a specific deployed contract. -func NewSafeMath(address common.Address, backend bind.ContractBackend) (*SafeMath, error) { - contract, err := bindSafeMath(address, backend, backend, backend) +// NewKyc creates a new instance of Kyc, bound to a specific deployed contract. +func NewKyc(address common.Address, backend bind.ContractBackend) (*Kyc, error) { + contract, err := bindKyc(address, backend, backend, backend) if err != nil { return nil, err } - return &SafeMath{SafeMathCaller: SafeMathCaller{contract: contract}, SafeMathTransactor: SafeMathTransactor{contract: contract}, SafeMathFilterer: SafeMathFilterer{contract: contract}}, nil + return &Kyc{KycCaller: KycCaller{contract: contract}, KycTransactor: KycTransactor{contract: contract}, KycFilterer: KycFilterer{contract: contract}}, nil } -// NewSafeMathCaller creates a new read-only instance of SafeMath, bound to a specific deployed contract. -func NewSafeMathCaller(address common.Address, caller bind.ContractCaller) (*SafeMathCaller, error) { - contract, err := bindSafeMath(address, caller, nil, nil) +// NewKycCaller creates a new read-only instance of Kyc, bound to a specific deployed contract. +func NewKycCaller(address common.Address, caller bind.ContractCaller) (*KycCaller, error) { + contract, err := bindKyc(address, caller, nil, nil) if err != nil { return nil, err } - return &SafeMathCaller{contract: contract}, nil + return &KycCaller{contract: contract}, nil } -// NewSafeMathTransactor creates a new write-only instance of SafeMath, bound to a specific deployed contract. -func NewSafeMathTransactor(address common.Address, transactor bind.ContractTransactor) (*SafeMathTransactor, error) { - contract, err := bindSafeMath(address, nil, transactor, nil) +// NewKycTransactor creates a new write-only instance of Kyc, bound to a specific deployed contract. +func NewKycTransactor(address common.Address, transactor bind.ContractTransactor) (*KycTransactor, error) { + contract, err := bindKyc(address, nil, transactor, nil) if err != nil { return nil, err } - return &SafeMathTransactor{contract: contract}, nil + return &KycTransactor{contract: contract}, nil } -// NewSafeMathFilterer creates a new log filterer instance of SafeMath, bound to a specific deployed contract. -func NewSafeMathFilterer(address common.Address, filterer bind.ContractFilterer) (*SafeMathFilterer, error) { - contract, err := bindSafeMath(address, nil, nil, filterer) +// NewKycFilterer creates a new log filterer instance of Kyc, bound to a specific deployed contract. +func NewKycFilterer(address common.Address, filterer bind.ContractFilterer) (*KycFilterer, error) { + contract, err := bindKyc(address, nil, nil, filterer) if err != nil { return nil, err } - return &SafeMathFilterer{contract: contract}, nil + return &KycFilterer{contract: contract}, nil } -// bindSafeMath binds a generic wrapper to an already deployed contract. -func bindSafeMath(address common.Address, caller bind.ContractCaller, transactor bind.ContractTransactor, filterer bind.ContractFilterer) (*bind.BoundContract, error) { - parsed, err := abi.JSON(strings.NewReader(SafeMathABI)) +// bindKyc binds a generic wrapper to an already deployed contract. +func bindKyc(address common.Address, caller bind.ContractCaller, transactor bind.ContractTransactor, filterer bind.ContractFilterer) (*bind.BoundContract, error) { + parsed, err := abi.JSON(strings.NewReader(KycABI)) if err != nil { return nil, err } @@ -141,948 +138,762 @@ func bindSafeMath(address common.Address, caller bind.ContractCaller, transactor // 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 (_SafeMath *SafeMathRaw) Call(opts *bind.CallOpts, result interface{}, method string, params ...interface{}) error { - return _SafeMath.Contract.SafeMathCaller.contract.Call(opts, result, method, params...) +func (_Kyc *KycRaw) Call(opts *bind.CallOpts, result interface{}, method string, params ...interface{}) error { + return _Kyc.Contract.KycCaller.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 (_SafeMath *SafeMathRaw) Transfer(opts *bind.TransactOpts) (*types.Transaction, error) { - return _SafeMath.Contract.SafeMathTransactor.contract.Transfer(opts) +func (_Kyc *KycRaw) Transfer(opts *bind.TransactOpts) (*types.Transaction, error) { + return _Kyc.Contract.KycTransactor.contract.Transfer(opts) } // Transact invokes the (paid) contract method with params as input values. -func (_SafeMath *SafeMathRaw) Transact(opts *bind.TransactOpts, method string, params ...interface{}) (*types.Transaction, error) { - return _SafeMath.Contract.SafeMathTransactor.contract.Transact(opts, method, params...) +func (_Kyc *KycRaw) Transact(opts *bind.TransactOpts, method string, params ...interface{}) (*types.Transaction, error) { + return _Kyc.Contract.KycTransactor.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 (_SafeMath *SafeMathCallerRaw) Call(opts *bind.CallOpts, result interface{}, method string, params ...interface{}) error { - return _SafeMath.Contract.contract.Call(opts, result, method, params...) +func (_Kyc *KycCallerRaw) Call(opts *bind.CallOpts, result interface{}, method string, params ...interface{}) error { + return _Kyc.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 (_SafeMath *SafeMathTransactorRaw) Transfer(opts *bind.TransactOpts) (*types.Transaction, error) { - return _SafeMath.Contract.contract.Transfer(opts) +func (_Kyc *KycTransactorRaw) Transfer(opts *bind.TransactOpts) (*types.Transaction, error) { + return _Kyc.Contract.contract.Transfer(opts) } // Transact invokes the (paid) contract method with params as input values. -func (_SafeMath *SafeMathTransactorRaw) Transact(opts *bind.TransactOpts, method string, params ...interface{}) (*types.Transaction, error) { - return _SafeMath.Contract.contract.Transact(opts, method, params...) -} -// XDCValidatorABI is the input ABI used to generate the binding from. -const XDCValidatorABI = "[{\"constant\":false,\"inputs\":[{\"name\":\"_candidate\",\"type\":\"address\"}],\"name\":\"propose\",\"outputs\":[],\"payable\":true,\"stateMutability\":\"payable\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_candidate\",\"type\":\"address\"}],\"name\":\"resign\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_candidate\",\"type\":\"address\"},{\"name\":\"_cap\",\"type\":\"uint256\"}],\"name\":\"unvote\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"kychash\",\"type\":\"string\"}],\"name\":\"uploadKYC\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_candidate\",\"type\":\"address\"}],\"name\":\"vote\",\"outputs\":[],\"payable\":true,\"stateMutability\":\"payable\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_invalidCandidate\",\"type\":\"address\"}],\"name\":\"voteInvalidKYC\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"constant\":false,\"inputs\":[{\"name\":\"_blockNumber\",\"type\":\"uint256\"},{\"name\":\"_index\",\"type\":\"uint256\"}],\"name\":\"withdraw\",\"outputs\":[],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"function\"},{\"inputs\":[{\"name\":\"_candidates\",\"type\":\"address[]\"},{\"name\":\"_caps\",\"type\":\"uint256[]\"},{\"name\":\"_firstOwner\",\"type\":\"address\"},{\"name\":\"_minCandidateCap\",\"type\":\"uint256\"},{\"name\":\"_minVoterCap\",\"type\":\"uint256\"},{\"name\":\"_maxValidatorNumber\",\"type\":\"uint256\"},{\"name\":\"_candidateWithdrawDelay\",\"type\":\"uint256\"},{\"name\":\"_voterWithdrawDelay\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"nonpayable\",\"type\":\"constructor\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"name\":\"_voter\",\"type\":\"address\"},{\"indexed\":false,\"name\":\"_candidate\",\"type\":\"address\"},{\"indexed\":false,\"name\":\"_cap\",\"type\":\"uint256\"}],\"name\":\"Vote\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"name\":\"_voter\",\"type\":\"address\"},{\"indexed\":false,\"name\":\"_candidate\",\"type\":\"address\"},{\"indexed\":false,\"name\":\"_cap\",\"type\":\"uint256\"}],\"name\":\"Unvote\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"name\":\"_owner\",\"type\":\"address\"},{\"indexed\":false,\"name\":\"_candidate\",\"type\":\"address\"},{\"indexed\":false,\"name\":\"_cap\",\"type\":\"uint256\"}],\"name\":\"Propose\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"name\":\"_owner\",\"type\":\"address\"},{\"indexed\":false,\"name\":\"_candidate\",\"type\":\"address\"}],\"name\":\"Resign\",\"type\":\"event\"},{\"anonymous\":false,\"inputs\":[{\"indexed\":false,\"name\":\"_owner\",\"type\":\"address\"},{\"indexed\":false,\"name\":\"_blockNumber\",\"type\":\"uint256\"},{\"indexed\":false,\"name\":\"_cap\",\"type\":\"uint256\"}],\"name\":\"Withdraw\",\"type\":\"event\"},{\"constant\":true,\"inputs\":[],\"name\":\"candidateCount\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"candidates\",\"outputs\":[{\"name\":\"\",\"type\":\"address\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"candidateWithdrawDelay\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_candidate\",\"type\":\"address\"}],\"name\":\"getCandidateCap\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_candidate\",\"type\":\"address\"}],\"name\":\"getCandidateOwner\",\"outputs\":[{\"name\":\"\",\"type\":\"address\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"getCandidates\",\"outputs\":[{\"name\":\"\",\"type\":\"address[]\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_address\",\"type\":\"address\"}],\"name\":\"getKYC\",\"outputs\":[{\"name\":\"\",\"type\":\"string\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"getOwnerCount\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_candidate\",\"type\":\"address\"},{\"name\":\"_voter\",\"type\":\"address\"}],\"name\":\"getVoterCap\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_candidate\",\"type\":\"address\"}],\"name\":\"getVoters\",\"outputs\":[{\"name\":\"\",\"type\":\"address[]\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"getWithdrawBlockNumbers\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256[]\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_blockNumber\",\"type\":\"uint256\"}],\"name\":\"getWithdrawCap\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"\",\"type\":\"address\"},{\"name\":\"\",\"type\":\"address\"}],\"name\":\"hasVotedInvalid\",\"outputs\":[{\"name\":\"\",\"type\":\"bool\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"\",\"type\":\"address\"}],\"name\":\"invalidKYCCount\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_invalidCandidate\",\"type\":\"address\"}],\"name\":\"invalidPercent\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"_candidate\",\"type\":\"address\"}],\"name\":\"isCandidate\",\"outputs\":[{\"name\":\"\",\"type\":\"bool\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"\",\"type\":\"address\"}],\"name\":\"KYCString\",\"outputs\":[{\"name\":\"\",\"type\":\"string\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"maxValidatorNumber\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"minCandidateCap\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"minVoterCap\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"owners\",\"outputs\":[{\"name\":\"\",\"type\":\"address\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[{\"name\":\"\",\"type\":\"address\"},{\"name\":\"\",\"type\":\"uint256\"}],\"name\":\"ownerToCandidate\",\"outputs\":[{\"name\":\"\",\"type\":\"address\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"},{\"constant\":true,\"inputs\":[],\"name\":\"voterWithdrawDelay\",\"outputs\":[{\"name\":\"\",\"type\":\"uint256\"}],\"payable\":false,\"stateMutability\":\"view\",\"type\":\"function\"}]" - -// XDCValidatorBin is the compiled bytecode used for deploying new contracts. -const XDCValidatorBin = `6060604052600060095534156200001557600080fd5b60405162003faf38038062003faf83398101604052808051820191906020018051820191906020018051906020019091908051906020019091908051906020019091908051906020019091908051906020019091908051906020019091905050600085600a8190555084600b8190555083600c8190555082600d8190555081600e81905550885160098190555060078054806001018281620000b89190620004da565b9160005260206000209001600089909190916101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050600090505b8851811015620004cb57600880548060010182816200012c9190620004da565b916000526020600020900160008b848151811015156200014857fe5b90602001906020020151909190916101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550506060604051908101604052808873ffffffffffffffffffffffffffffffffffffffff1681526020016001151581526020018983815181101515620001d357fe5b90602001906020020151815250600160008b84815181101515620001f357fe5b9060200190602002015173ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008201518160000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060208201518160000160146101000a81548160ff02191690831515021790555060408201518160010155905050600260008a83815181101515620002be57fe5b9060200190602002015173ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208054806001018281620003169190620004da565b9160005260206000209001600089909190916101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050600660008873ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208054806001018281620003b89190620004da565b916000526020600020900160008b84815181101515620003d457fe5b90602001906020020151909190916101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050600a54600160008b848151811015156200043557fe5b9060200190602002015173ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060020160008973ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208190555080806001019150506200010c565b50505050505050505062000531565b815481835581811511620005045781836000526020600020918201910162000503919062000509565b5b505050565b6200052e91905b808211156200052a57600081600090555060010162000510565b5090565b90565b613a6e80620005416000396000f300606060405260043610610180576000357c0100000000000000000000000000000000000000000000000000000000900463ffffffff1680630126795114610185578063025e7c27146101b357806302aa9be21461021657806306a49fce146102585780630e3e4fb8146102c257806315febd68146103325780632a3640b1146103695780632d15cc04146103eb5780632f9c4bba14610479578063302b6872146104e35780633477ee2e1461054f578063441a3e70146105b25780634d1a687d146105de5780634ff78d561461069057806358e7525f146107425780635b860d271461078f5780636dd7d8ea146107dc57806372e44a381461080a578063a9a981a314610857578063a9ff959e14610880578063ae6e43f5146108a9578063b642facd146108e2578063d09f1ab41461095b578063d161c76714610984578063d51b9e93146109ad578063d55b7dff146109fe578063ef18374a14610a27578063f2ee3c7d14610a50578063f5c9512514610a89578063f8ac9dd514610ab7575b600080fd5b6101b1600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091905050610ae0565b005b34156101be57600080fd5b6101d46004808035906020019091905050611724565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b341561022157600080fd5b610256600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091908035906020019091905050611763565b005b341561026357600080fd5b61026b611cbe565b6040518080602001828103825283818151815260200191508051906020019060200280838360005b838110156102ae578082015181840152602081019050610293565b505050509050019250505060405180910390f35b34156102cd57600080fd5b610318600480803573ffffffffffffffffffffffffffffffffffffffff1690602001909190803573ffffffffffffffffffffffffffffffffffffffff16906020019091905050611d52565b604051808215151515815260200191505060405180910390f35b341561033d57600080fd5b6103536004808035906020019091905050611d81565b6040518082815260200191505060405180910390f35b341561037457600080fd5b6103a9600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091908035906020019091905050611ddd565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b34156103f657600080fd5b610422600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091905050611e2b565b6040518080602001828103825283818151815260200191508051906020019060200280838360005b8381101561046557808201518184015260208101905061044a565b505050509050019250505060405180910390f35b341561048457600080fd5b61048c611efe565b6040518080602001828103825283818151815260200191508051906020019060200280838360005b838110156104cf5780820151818401526020810190506104b4565b505050509050019250505060405180910390f35b34156104ee57600080fd5b610539600480803573ffffffffffffffffffffffffffffffffffffffff1690602001909190803573ffffffffffffffffffffffffffffffffffffffff16906020019091905050611f9b565b6040518082815260200191505060405180910390f35b341561055a57600080fd5b6105706004808035906020019091905050612025565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b34156105bd57600080fd5b6105dc6004808035906020019091908035906020019091905050612064565b005b34156105e957600080fd5b610615600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091905050612310565b6040518080602001828103825283818151815260200191508051906020019080838360005b8381101561065557808201518184015260208101905061063a565b50505050905090810190601f1680156106825780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b341561069b57600080fd5b6106c7600480803573ffffffffffffffffffffffffffffffffffffffff169060200190919050506124ed565b6040518080602001828103825283818151815260200191508051906020019080838360005b838110156107075780820151818401526020810190506106ec565b50505050905090810190601f1680156107345780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b341561074d57600080fd5b610779600480803573ffffffffffffffffffffffffffffffffffffffff1690602001909190505061259d565b6040518082815260200191505060405180910390f35b341561079a57600080fd5b6107c6600480803573ffffffffffffffffffffffffffffffffffffffff169060200190919050506125e9565b6040518082815260200191505060405180910390f35b610808600480803573ffffffffffffffffffffffffffffffffffffffff169060200190919050506126b1565b005b341561081557600080fd5b610841600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091905050612a9a565b6040518082815260200191505060405180910390f35b341561086257600080fd5b61086a612ab2565b6040518082815260200191505060405180910390f35b341561088b57600080fd5b610893612ab8565b6040518082815260200191505060405180910390f35b34156108b457600080fd5b6108e0600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091905050612abe565b005b34156108ed57600080fd5b610919600480803573ffffffffffffffffffffffffffffffffffffffff1690602001909190505061307d565b604051808273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200191505060405180910390f35b341561096657600080fd5b61096e6130e9565b6040518082815260200191505060405180910390f35b341561098f57600080fd5b6109976130ef565b6040518082815260200191505060405180910390f35b34156109b857600080fd5b6109e4600480803573ffffffffffffffffffffffffffffffffffffffff169060200190919050506130f5565b604051808215151515815260200191505060405180910390f35b3415610a0957600080fd5b610a1161314e565b6040518082815260200191505060405180910390f35b3415610a3257600080fd5b610a3a613154565b6040518082815260200191505060405180910390f35b3415610a5b57600080fd5b610a87600480803573ffffffffffffffffffffffffffffffffffffffff16906020019091905050613161565b005b3415610a9457600080fd5b610ab560048080359060200190820180359060200191909192905050613782565b005b3415610ac257600080fd5b610aca613837565b6040518082815260200191505060405180910390f35b6000600a543410151515610af357600080fd5b6000600360003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208054600181600116156101000203166002900490501415156111145781600160008273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160149054906101000a900460ff16151515610bad57600080fd5b610c0234600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206001015461383d90919063ffffffff16565b915060088054806001018281610c189190613874565b9160005260206000209001600085909190916101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550506060604051908101604052803373ffffffffffffffffffffffffffffffffffffffff16815260200160011515815260200183815250600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008201518160000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060208201518160000160146101000a81548160ff02191690831515021790555060408201518160010155905050610de134600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060020160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205461383d90919063ffffffff16565b600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060020160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550610e7a600160095461383d90919063ffffffff16565b6009819055506000600660003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020805490501415610f2f5760078054806001018281610edf9190613874565b9160005260206000209001600033909190916101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550505b600660003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208054806001018281610f809190613874565b9160005260206000209001600085909190916101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050600260008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002080548060010182816110209190613874565b9160005260206000209001600033909190916101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550507f7635f1d87b47fba9f2b09e56eb4be75cca030e0cb179c1602ac9261d39a8f5c1338434604051808473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020018373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001828152602001935050505060405180910390a150611720565b6000600660003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002080549050111561171f5781600160008273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160149054906101000a900460ff161515156111bc57600080fd5b61121134600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206001015461383d90919063ffffffff16565b9150600880548060010182816112279190613874565b9160005260206000209001600085909190916101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550506060604051908101604052803373ffffffffffffffffffffffffffffffffffffffff16815260200160011515815260200183815250600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008201518160000160006101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555060208201518160000160146101000a81548160ff021916908315150217905550604082015181600101559050506113f034600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060020160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205461383d90919063ffffffff16565b600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060020160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550611489600160095461383d90919063ffffffff16565b6009819055506000600660003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002080549050141561153e57600780548060010182816114ee9190613874565b9160005260206000209001600033909190916101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550505b600660003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020805480600101828161158f9190613874565b9160005260206000209001600085909190916101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff16021790555050600260008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020805480600101828161162f9190613874565b9160005260206000209001600033909190916101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550507f7635f1d87b47fba9f2b09e56eb4be75cca030e0cb179c1602ac9261d39a8f5c1338434604051808473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020018373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001828152602001935050505060405180910390a1505b5b5050565b60078181548110151561173357fe5b90600052602060002090016000915054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b6000828280600160008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060020160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054101515156117f557600080fd5b3373ffffffffffffffffffffffffffffffffffffffff16600160008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16141561192e57600a5461192082600160008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060020160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205461385b90919063ffffffff16565b1015151561192d57600080fd5b5b61198384600160008873ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206001015461385b90919063ffffffff16565b600160008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060010181905550611a5b84600160008873ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060020160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205461385b90919063ffffffff16565b600160008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060020160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550611af343600e5461383d90919063ffffffff16565b9250611b5a846000803373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160008681526020019081526020016000205461383d90919063ffffffff16565b6000803373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206000016000858152602001908152602001600020819055506000803373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206001018054806001018281611c0391906138a0565b9160005260206000209001600085909190915055507faa0e554f781c3c3b2be110a0557f260f11af9a8aa2c64bc1e7a31dbb21e32fa2338686604051808473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020018373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001828152602001935050505060405180910390a15050505050565b611cc66138cc565b6008805480602002602001604051908101604052809291908181526020018280548015611d4857602002820191906000526020600020905b8160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019060010190808311611cfe575b5050505050905090565b60056020528160005260406000206020528060005260406000206000915091509054906101000a900460ff1681565b60008060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206000016000838152602001908152602001600020549050919050565b600660205281600052604060002081815481101515611df857fe5b90600052602060002090016000915091509054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b611e336138cc565b600260008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020805480602002602001604051908101604052809291908181526020018280548015611ef257602002820191906000526020600020905b8160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019060010190808311611ea8575b50505050509050919050565b611f066138e0565b6000803373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600101805480602002602001604051908101604052809291908181526020018280548015611f9157602002820191906000526020600020905b815481526020019060010190808311611f7d575b5050505050905090565b6000600160008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060020160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054905092915050565b60088181548110151561203457fe5b90600052602060002090016000915054906101000a900473ffffffffffffffffffffffffffffffffffffffff1681565b6000828260008211151561207757600080fd5b81431015151561208657600080fd5b60008060003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206000016000848152602001908152602001600020541115156120e757600080fd5b816000803373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206001018281548110151561213657fe5b90600052602060002090015414151561214e57600080fd5b6000803373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160008681526020019081526020016000205492506000803373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206000016000868152602001908152602001600020600090556000803373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206001018481548110151561224757fe5b9060005260206000209001600090553373ffffffffffffffffffffffffffffffffffffffff166108fc849081150290604051600060405180830381858888f19350505050151561229657600080fd5b7ff279e6a1f5e320cca91135676d9cb6e44ca8a08c0b88342bcdb1144f6511b568338685604051808473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001838152602001828152602001935050505060405180910390a15050505050565b6123186138f4565b612321826130f5565b1561240d57600360006123338461307d565b73ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208054600181600116156101000203166002900480601f0160208091040260200160405190810160405280929190818152602001828054600181600116156101000203166002900480156124015780601f106123d657610100808354040283529160200191612401565b820191906000526020600020905b8154815290600101906020018083116123e457829003601f168201915b505050505090506124e8565b600360008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208054600181600116156101000203166002900480601f0160208091040260200160405190810160405280929190818152602001828054600181600116156101000203166002900480156124e05780601f106124b5576101008083540402835291602001916124e0565b820191906000526020600020905b8154815290600101906020018083116124c357829003601f168201915b505050505090505b919050565b60036020528060005260406000206000915090508054600181600116156101000203166002900480601f0160208091040260200160405190810160405280929190818152602001828054600181600116156101000203166002900480156125955780601f1061256a57610100808354040283529160200191612595565b820191906000526020600020905b81548152906001019060200180831161257857829003601f168201915b505050505081565b6000600160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600101549050919050565b60008082600160008273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160149054906101000a900460ff16151561264857600080fd5b6126518461307d565b915061265b613154565b6064600460008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002054028115156126a757fe5b0492505050919050565b600b5434101515156126c257600080fd5b80600160008273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160149054906101000a900460ff16151561271e57600080fd5b61277334600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206001015461383d90919063ffffffff16565b600160008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600101819055506000600160008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060020160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205414156128e257600260008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002080548060010182816128929190613874565b9160005260206000209001600033909190916101000a81548173ffffffffffffffffffffffffffffffffffffffff021916908373ffffffffffffffffffffffffffffffffffffffff160217905550505b61297434600160008573ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060020160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000205461383d90919063ffffffff16565b600160008473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060020160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020819055507f66a9138482c99e9baf08860110ef332cc0c23b4a199a53593d8db0fc8f96fbfc338334604051808473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020018373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001828152602001935050505060405180910390a15050565b60046020528060005260406000206000915090505481565b60095481565b600e5481565b6000806000833373ffffffffffffffffffffffffffffffffffffffff16600160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16141515612b6057600080fd5b84600160008273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160149054906101000a900460ff161515612bbc57600080fd5b6000600160008873ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160146101000a81548160ff021916908315150217905550612c2d600160095461385b90919063ffffffff16565b600981905550600094505b600880549050851015612d02578573ffffffffffffffffffffffffffffffffffffffff16600886815481101515612c6b57fe5b906000526020600020900160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff161415612cf557600885815481101515612cc257fe5b906000526020600020900160006101000a81549073ffffffffffffffffffffffffffffffffffffffff0219169055612d02565b8480600101955050612c38565b600160008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060020160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020549350612dd984600160008973ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206001015461385b90919063ffffffff16565b600160008873ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600101819055506000600160008873ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060020160003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002081905550612eb943600d5461383d90919063ffffffff16565b9250612f20846000803373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160008681526020019081526020016000205461383d90919063ffffffff16565b6000803373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206000016000858152602001908152602001600020819055506000803373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000206001018054806001018281612fc991906138a0565b9160005260206000209001600085909190915055507f4edf3e325d0063213a39f9085522994a1c44bea5f39e7d63ef61260a1e58c6d33387604051808373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020018273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019250505060405180910390a1505050505050565b6000600160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff169050919050565b600c5481565b600d5481565b6000600160008373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160149054906101000a900460ff169050919050565b600a5481565b6000600780549050905090565b60008060008033600160008273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160149054906101000a900460ff1615156131c357600080fd5b85600160008273ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060000160149054906101000a900460ff16151561321f57600080fd5b6132283361307d565b95506132338761307d565b9450600560008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009054906101000a900460ff161515156132cb57600080fd5b6001600560008873ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006101000a81548160ff0219169083151502179055506001600460008773ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060008282540192505081905550604b6133b8613154565b6064600460008973ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020540281151561340457fe5b0410151561377957600093505b600880549050841015613778578473ffffffffffffffffffffffffffffffffffffffff1661347860088681548110151561344757fe5b906000526020600020900160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1661307d565b73ffffffffffffffffffffffffffffffffffffffff16141561376b576134aa600160095461385b90919063ffffffff16565b6009819055506008848154811015156134bf57fe5b906000526020600020900160006101000a81549073ffffffffffffffffffffffffffffffffffffffff02191690556001600060088681548110151561350057fe5b906000526020600020900160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020600080820160006101000a81549073ffffffffffffffffffffffffffffffffffffffff02191690556000820160146101000a81549060ff021916905560018201600090555050600360008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006135f79190613908565b600660008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060006136429190613950565b600460008673ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16815260200190815260200160002060009055600092505b60078054905083101561376a578473ffffffffffffffffffffffffffffffffffffffff166007848154811015156136bd57fe5b906000526020600020900160009054906101000a900473ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff16141561375d5760078381548110151561371457fe5b906000526020600020900160006101000a81549073ffffffffffffffffffffffffffffffffffffffff021916905560078054809190600190036137579190613971565b5061376a565b828060010193505061368a565b5b8380600101945050613411565b5b50505050505050565b6000600360003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff1681526020019081526020016000208054600181600116156101000203166002900490501415156137e457600080fd5b8181600360003373ffffffffffffffffffffffffffffffffffffffff1673ffffffffffffffffffffffffffffffffffffffff168152602001908152602001600020919061383292919061399d565b505050565b600b5481565b600080828401905083811015151561385157fe5b8091505092915050565b600082821115151561386957fe5b818303905092915050565b81548183558181151161389b5781836000526020600020918201910161389a9190613a1d565b5b505050565b8154818355818115116138c7578183600052602060002091820191016138c69190613a1d565b5b505050565b602060405190810160405280600081525090565b602060405190810160405280600081525090565b602060405190810160405280600081525090565b50805460018160011615610100020316600290046000825580601f1061392e575061394d565b601f01602090049060005260206000209081019061394c9190613a1d565b5b50565b508054600082559060005260206000209081019061396e9190613a1d565b50565b815481835581811511613998578183600052602060002091820191016139979190613a1d565b5b505050565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f106139de57803560ff1916838001178555613a0c565b82800160010185558215613a0c579182015b82811115613a0b5782358255916020019190600101906139f0565b5b509050613a199190613a1d565b5090565b613a3f91905b80821115613a3b576000816000905550600101613a23565b5090565b905600a165627a7a72305820a3d30674c84b59fda761ae8645ee6607b3ddb68bd16d65427495d94bd5b2ffa70029` - -// DeployXDCValidator deploys a new Ethereum contract, binding an instance of XDCValidator to it. -func DeployXDCValidator(auth *bind.TransactOpts, backend bind.ContractBackend, _candidates []common.Address, _caps []*big.Int, _firstOwner common.Address, _minCandidateCap *big.Int, _minVoterCap *big.Int, _maxValidatorNumber *big.Int, _candidateWithdrawDelay *big.Int, _voterWithdrawDelay *big.Int) (common.Address, *types.Transaction, *XDCValidator, error) { - parsed, err := abi.JSON(strings.NewReader(XDCValidatorABI)) - if err != nil { - return common.Address{}, nil, nil, err - } - address, tx, contract, err := bind.DeployContract(auth, parsed, common.FromHex(XDCValidatorBin), backend, _candidates, _caps, _firstOwner, _minCandidateCap, _minVoterCap, _maxValidatorNumber, _candidateWithdrawDelay, _voterWithdrawDelay) - if err != nil { - return common.Address{}, nil, nil, err - } - return address, tx, &XDCValidator{XDCValidatorCaller: XDCValidatorCaller{contract: contract}, XDCValidatorTransactor: XDCValidatorTransactor{contract: contract}, XDCValidatorFilterer: XDCValidatorFilterer{contract: contract}}, nil +func (_Kyc *KycTransactorRaw) Transact(opts *bind.TransactOpts, method string, params ...interface{}) (*types.Transaction, error) { + return _Kyc.Contract.contract.Transact(opts, method, params...) } -// XDCValidator is an auto generated Go binding around an Ethereum contract. -type XDCValidator struct { - XDCValidatorCaller // Read-only binding to the contract - XDCValidatorTransactor // Write-only binding to the contract - XDCValidatorFilterer // Log filterer for contract events -} - -// XDCValidatorCaller is an auto generated read-only Go binding around an Ethereum contract. -type XDCValidatorCaller struct { - contract *bind.BoundContract // Generic contract wrapper for the low level calls -} - -// XDCValidatorTransactor is an auto generated write-only Go binding around an Ethereum contract. -type XDCValidatorTransactor struct { - contract *bind.BoundContract // Generic contract wrapper for the low level calls -} - -// XDCValidatorFilterer is an auto generated log filtering Go binding around an Ethereum contract events. -type XDCValidatorFilterer struct { - contract *bind.BoundContract // Generic contract wrapper for the low level calls -} - -// XDCValidatorSession is an auto generated Go binding around an Ethereum contract, -// with pre-set call and transact options. -type XDCValidatorSession struct { - Contract *XDCValidator // 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 -} - -// XDCValidatorCallerSession is an auto generated read-only Go binding around an Ethereum contract, -// with pre-set call options. -type XDCValidatorCallerSession struct { - Contract *XDCValidatorCaller // Generic contract caller binding to set the session for - CallOpts bind.CallOpts // Call options to use throughout this session -} - -// XDCValidatorTransactorSession is an auto generated write-only Go binding around an Ethereum contract, -// with pre-set transact options. -type XDCValidatorTransactorSession struct { - Contract *XDCValidatorTransactor // Generic contract transactor binding to set the session for - TransactOpts bind.TransactOpts // Transaction auth options to use throughout this session -} - -// XDCValidatorRaw is an auto generated low-level Go binding around an Ethereum contract. -type XDCValidatorRaw struct { - Contract *XDCValidator // Generic contract binding to access the raw methods on -} - -// XDCValidatorCallerRaw is an auto generated low-level read-only Go binding around an Ethereum contract. -type XDCValidatorCallerRaw struct { - Contract *XDCValidatorCaller // Generic read-only contract binding to access the raw methods on -} - -// XDCValidatorTransactorRaw is an auto generated low-level write-only Go binding around an Ethereum contract. -type XDCValidatorTransactorRaw struct { - Contract *XDCValidatorTransactor // Generic write-only contract binding to access the raw methods on -} - -// NewXDCValidator creates a new instance of XDCValidator, bound to a specific deployed contract. -func NewXDCValidator(address common.Address, backend bind.ContractBackend) (*XDCValidator, error) { - contract, err := bindXDCValidator(address, backend, backend, backend) - if err != nil { - return nil, err - } - return &XDCValidator{XDCValidatorCaller: XDCValidatorCaller{contract: contract}, XDCValidatorTransactor: XDCValidatorTransactor{contract: contract}, XDCValidatorFilterer: XDCValidatorFilterer{contract: contract}}, nil -} - -// NewXDCValidatorCaller creates a new read-only instance of XDCValidator, bound to a specific deployed contract. -func NewXDCValidatorCaller(address common.Address, caller bind.ContractCaller) (*XDCValidatorCaller, error) { - contract, err := bindXDCValidator(address, caller, nil, nil) - if err != nil { - return nil, err - } - return &XDCValidatorCaller{contract: contract}, nil -} - -// NewXDCValidatorTransactor creates a new write-only instance of XDCValidator, bound to a specific deployed contract. -func NewXDCValidatorTransactor(address common.Address, transactor bind.ContractTransactor) (*XDCValidatorTransactor, error) { - contract, err := bindXDCValidator(address, nil, transactor, nil) - if err != nil { - return nil, err - } - return &XDCValidatorTransactor{contract: contract}, nil -} - -// NewXDCValidatorFilterer creates a new log filterer instance of XDCValidator, bound to a specific deployed contract. -func NewXDCValidatorFilterer(address common.Address, filterer bind.ContractFilterer) (*XDCValidatorFilterer, error) { - contract, err := bindXDCValidator(address, nil, nil, filterer) - if err != nil { - return nil, err - } - return &XDCValidatorFilterer{contract: contract}, nil -} - -// bindXDCValidator binds a generic wrapper to an already deployed contract. -func bindXDCValidator(address common.Address, caller bind.ContractCaller, transactor bind.ContractTransactor, filterer bind.ContractFilterer) (*bind.BoundContract, error) { - parsed, err := abi.JSON(strings.NewReader(XDCValidatorABI)) - 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 (_XDCValidator *XDCValidatorRaw) Call(opts *bind.CallOpts, result interface{}, method string, params ...interface{}) error { - return _XDCValidator.Contract.XDCValidatorCaller.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 (_XDCValidator *XDCValidatorRaw) Transfer(opts *bind.TransactOpts) (*types.Transaction, error) { - return _XDCValidator.Contract.XDCValidatorTransactor.contract.Transfer(opts) -} - -// Transact invokes the (paid) contract method with params as input values. -func (_XDCValidator *XDCValidatorRaw) Transact(opts *bind.TransactOpts, method string, params ...interface{}) (*types.Transaction, error) { - return _XDCValidator.Contract.XDCValidatorTransactor.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 (_XDCValidator *XDCValidatorCallerRaw) Call(opts *bind.CallOpts, result interface{}, method string, params ...interface{}) error { - return _XDCValidator.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 (_XDCValidator *XDCValidatorTransactorRaw) Transfer(opts *bind.TransactOpts) (*types.Transaction, error) { - return _XDCValidator.Contract.contract.Transfer(opts) -} - -// Transact invokes the (paid) contract method with params as input values. -func (_XDCValidator *XDCValidatorTransactorRaw) Transact(opts *bind.TransactOpts, method string, params ...interface{}) (*types.Transaction, error) { - return _XDCValidator.Contract.contract.Transact(opts, method, params...) -} - -// KYCString is a free data retrieval call binding the contract method 0x4ff78d56. +// InvalidPercent is a free data retrieval call binding the contract method 0x7ea80829. // -// Solidity: function KYCString( address) constant returns(string) -func (_XDCValidator *XDCValidatorCaller) KYCString(opts *bind.CallOpts, arg0 common.Address) (string, error) { - var ( - ret0 = new(string) - ) - out := ret0 - err := _XDCValidator.contract.Call(opts, out, "KYCString", arg0) - return *ret0, err -} - -// KYCString is a free data retrieval call binding the contract method 0x4ff78d56. -// -// Solidity: function KYCString( address) constant returns(string) -func (_XDCValidator *XDCValidatorSession) KYCString(arg0 common.Address) (string, error) { - return _XDCValidator.Contract.KYCString(&_XDCValidator.CallOpts, arg0) -} - -// KYCString is a free data retrieval call binding the contract method 0x4ff78d56. -// -// Solidity: function KYCString( address) constant returns(string) -func (_XDCValidator *XDCValidatorCallerSession) KYCString(arg0 common.Address) (string, error) { - return _XDCValidator.Contract.KYCString(&_XDCValidator.CallOpts, arg0) -} - -// CandidateCount is a free data retrieval call binding the contract method 0xa9a981a3. -// -// Solidity: function candidateCount() constant returns(uint256) -func (_XDCValidator *XDCValidatorCaller) CandidateCount(opts *bind.CallOpts) (*big.Int, error) { +// Solidity: function InvalidPercent(address _invalidMasternode) constant returns(uint256) +func (_Kyc *KycCaller) InvalidPercent(opts *bind.CallOpts, _invalidMasternode common.Address) (*big.Int, error) { var ( ret0 = new(*big.Int) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "candidateCount") + err := _Kyc.contract.Call(opts, out, "InvalidPercent", _invalidMasternode) return *ret0, err } -// CandidateCount is a free data retrieval call binding the contract method 0xa9a981a3. +// InvalidPercent is a free data retrieval call binding the contract method 0x7ea80829. // -// Solidity: function candidateCount() constant returns(uint256) -func (_XDCValidator *XDCValidatorSession) CandidateCount() (*big.Int, error) { - return _XDCValidator.Contract.CandidateCount(&_XDCValidator.CallOpts) +// Solidity: function InvalidPercent(address _invalidMasternode) constant returns(uint256) +func (_Kyc *KycSession) InvalidPercent(_invalidMasternode common.Address) (*big.Int, error) { + return _Kyc.Contract.InvalidPercent(&_Kyc.CallOpts, _invalidMasternode) +} + +// InvalidPercent is a free data retrieval call binding the contract method 0x7ea80829. +// +// Solidity: function InvalidPercent(address _invalidMasternode) constant returns(uint256) +func (_Kyc *KycCallerSession) InvalidPercent(_invalidMasternode common.Address) (*big.Int, error) { + return _Kyc.Contract.InvalidPercent(&_Kyc.CallOpts, _invalidMasternode) } // CandidateCount is a free data retrieval call binding the contract method 0xa9a981a3. // // Solidity: function candidateCount() constant returns(uint256) -func (_XDCValidator *XDCValidatorCallerSession) CandidateCount() (*big.Int, error) { - return _XDCValidator.Contract.CandidateCount(&_XDCValidator.CallOpts) -} - -// CandidateWithdrawDelay is a free data retrieval call binding the contract method 0xd161c767. -// -// Solidity: function candidateWithdrawDelay() constant returns(uint256) -func (_XDCValidator *XDCValidatorCaller) CandidateWithdrawDelay(opts *bind.CallOpts) (*big.Int, error) { +func (_Kyc *KycCaller) CandidateCount(opts *bind.CallOpts) (*big.Int, error) { var ( ret0 = new(*big.Int) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "candidateWithdrawDelay") + err := _Kyc.contract.Call(opts, out, "candidateCount") + return *ret0, err +} + +// CandidateCount is a free data retrieval call binding the contract method 0xa9a981a3. +// +// Solidity: function candidateCount() constant returns(uint256) +func (_Kyc *KycSession) CandidateCount() (*big.Int, error) { + return _Kyc.Contract.CandidateCount(&_Kyc.CallOpts) +} + +// CandidateCount is a free data retrieval call binding the contract method 0xa9a981a3. +// +// Solidity: function candidateCount() constant returns(uint256) +func (_Kyc *KycCallerSession) CandidateCount() (*big.Int, error) { + return _Kyc.Contract.CandidateCount(&_Kyc.CallOpts) +} + +// CandidateWithdrawDelay is a free data retrieval call binding the contract method 0xd161c767. +// +// Solidity: function candidateWithdrawDelay() constant returns(uint256) +func (_Kyc *KycCaller) CandidateWithdrawDelay(opts *bind.CallOpts) (*big.Int, error) { + var ( + ret0 = new(*big.Int) + ) + out := ret0 + err := _Kyc.contract.Call(opts, out, "candidateWithdrawDelay") return *ret0, err } // CandidateWithdrawDelay is a free data retrieval call binding the contract method 0xd161c767. // // Solidity: function candidateWithdrawDelay() constant returns(uint256) -func (_XDCValidator *XDCValidatorSession) CandidateWithdrawDelay() (*big.Int, error) { - return _XDCValidator.Contract.CandidateWithdrawDelay(&_XDCValidator.CallOpts) +func (_Kyc *KycSession) CandidateWithdrawDelay() (*big.Int, error) { + return _Kyc.Contract.CandidateWithdrawDelay(&_Kyc.CallOpts) } // CandidateWithdrawDelay is a free data retrieval call binding the contract method 0xd161c767. // // Solidity: function candidateWithdrawDelay() constant returns(uint256) -func (_XDCValidator *XDCValidatorCallerSession) CandidateWithdrawDelay() (*big.Int, error) { - return _XDCValidator.Contract.CandidateWithdrawDelay(&_XDCValidator.CallOpts) +func (_Kyc *KycCallerSession) CandidateWithdrawDelay() (*big.Int, error) { + return _Kyc.Contract.CandidateWithdrawDelay(&_Kyc.CallOpts) } // Candidates is a free data retrieval call binding the contract method 0x3477ee2e. // -// Solidity: function candidates( uint256) constant returns(address) -func (_XDCValidator *XDCValidatorCaller) Candidates(opts *bind.CallOpts, arg0 *big.Int) (common.Address, error) { +// Solidity: function candidates(uint256 ) constant returns(address) +func (_Kyc *KycCaller) Candidates(opts *bind.CallOpts, arg0 *big.Int) (common.Address, error) { var ( ret0 = new(common.Address) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "candidates", arg0) + err := _Kyc.contract.Call(opts, out, "candidates", arg0) return *ret0, err } // Candidates is a free data retrieval call binding the contract method 0x3477ee2e. // -// Solidity: function candidates( uint256) constant returns(address) -func (_XDCValidator *XDCValidatorSession) Candidates(arg0 *big.Int) (common.Address, error) { - return _XDCValidator.Contract.Candidates(&_XDCValidator.CallOpts, arg0) +// Solidity: function candidates(uint256 ) constant returns(address) +func (_Kyc *KycSession) Candidates(arg0 *big.Int) (common.Address, error) { + return _Kyc.Contract.Candidates(&_Kyc.CallOpts, arg0) } // Candidates is a free data retrieval call binding the contract method 0x3477ee2e. // -// Solidity: function candidates( uint256) constant returns(address) -func (_XDCValidator *XDCValidatorCallerSession) Candidates(arg0 *big.Int) (common.Address, error) { - return _XDCValidator.Contract.Candidates(&_XDCValidator.CallOpts, arg0) +// Solidity: function candidates(uint256 ) constant returns(address) +func (_Kyc *KycCallerSession) Candidates(arg0 *big.Int) (common.Address, error) { + return _Kyc.Contract.Candidates(&_Kyc.CallOpts, arg0) } // GetCandidateCap is a free data retrieval call binding the contract method 0x58e7525f. // -// Solidity: function getCandidateCap(_candidate address) constant returns(uint256) -func (_XDCValidator *XDCValidatorCaller) GetCandidateCap(opts *bind.CallOpts, _candidate common.Address) (*big.Int, error) { +// Solidity: function getCandidateCap(address _candidate) constant returns(uint256) +func (_Kyc *KycCaller) GetCandidateCap(opts *bind.CallOpts, _candidate common.Address) (*big.Int, error) { var ( ret0 = new(*big.Int) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "getCandidateCap", _candidate) + err := _Kyc.contract.Call(opts, out, "getCandidateCap", _candidate) return *ret0, err } // GetCandidateCap is a free data retrieval call binding the contract method 0x58e7525f. // -// Solidity: function getCandidateCap(_candidate address) constant returns(uint256) -func (_XDCValidator *XDCValidatorSession) GetCandidateCap(_candidate common.Address) (*big.Int, error) { - return _XDCValidator.Contract.GetCandidateCap(&_XDCValidator.CallOpts, _candidate) +// Solidity: function getCandidateCap(address _candidate) constant returns(uint256) +func (_Kyc *KycSession) GetCandidateCap(_candidate common.Address) (*big.Int, error) { + return _Kyc.Contract.GetCandidateCap(&_Kyc.CallOpts, _candidate) } // GetCandidateCap is a free data retrieval call binding the contract method 0x58e7525f. // -// Solidity: function getCandidateCap(_candidate address) constant returns(uint256) -func (_XDCValidator *XDCValidatorCallerSession) GetCandidateCap(_candidate common.Address) (*big.Int, error) { - return _XDCValidator.Contract.GetCandidateCap(&_XDCValidator.CallOpts, _candidate) +// Solidity: function getCandidateCap(address _candidate) constant returns(uint256) +func (_Kyc *KycCallerSession) GetCandidateCap(_candidate common.Address) (*big.Int, error) { + return _Kyc.Contract.GetCandidateCap(&_Kyc.CallOpts, _candidate) } // GetCandidateOwner is a free data retrieval call binding the contract method 0xb642facd. // -// Solidity: function getCandidateOwner(_candidate address) constant returns(address) -func (_XDCValidator *XDCValidatorCaller) GetCandidateOwner(opts *bind.CallOpts, _candidate common.Address) (common.Address, error) { +// Solidity: function getCandidateOwner(address _candidate) constant returns(address) +func (_Kyc *KycCaller) GetCandidateOwner(opts *bind.CallOpts, _candidate common.Address) (common.Address, error) { var ( ret0 = new(common.Address) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "getCandidateOwner", _candidate) + err := _Kyc.contract.Call(opts, out, "getCandidateOwner", _candidate) return *ret0, err } // GetCandidateOwner is a free data retrieval call binding the contract method 0xb642facd. // -// Solidity: function getCandidateOwner(_candidate address) constant returns(address) -func (_XDCValidator *XDCValidatorSession) GetCandidateOwner(_candidate common.Address) (common.Address, error) { - return _XDCValidator.Contract.GetCandidateOwner(&_XDCValidator.CallOpts, _candidate) +// Solidity: function getCandidateOwner(address _candidate) constant returns(address) +func (_Kyc *KycSession) GetCandidateOwner(_candidate common.Address) (common.Address, error) { + return _Kyc.Contract.GetCandidateOwner(&_Kyc.CallOpts, _candidate) } // GetCandidateOwner is a free data retrieval call binding the contract method 0xb642facd. // -// Solidity: function getCandidateOwner(_candidate address) constant returns(address) -func (_XDCValidator *XDCValidatorCallerSession) GetCandidateOwner(_candidate common.Address) (common.Address, error) { - return _XDCValidator.Contract.GetCandidateOwner(&_XDCValidator.CallOpts, _candidate) +// Solidity: function getCandidateOwner(address _candidate) constant returns(address) +func (_Kyc *KycCallerSession) GetCandidateOwner(_candidate common.Address) (common.Address, error) { + return _Kyc.Contract.GetCandidateOwner(&_Kyc.CallOpts, _candidate) } // GetCandidates is a free data retrieval call binding the contract method 0x06a49fce. // // Solidity: function getCandidates() constant returns(address[]) -func (_XDCValidator *XDCValidatorCaller) GetCandidates(opts *bind.CallOpts) ([]common.Address, error) { +func (_Kyc *KycCaller) GetCandidates(opts *bind.CallOpts) ([]common.Address, error) { var ( ret0 = new([]common.Address) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "getCandidates") + err := _Kyc.contract.Call(opts, out, "getCandidates") return *ret0, err } // GetCandidates is a free data retrieval call binding the contract method 0x06a49fce. // // Solidity: function getCandidates() constant returns(address[]) -func (_XDCValidator *XDCValidatorSession) GetCandidates() ([]common.Address, error) { - return _XDCValidator.Contract.GetCandidates(&_XDCValidator.CallOpts) +func (_Kyc *KycSession) GetCandidates() ([]common.Address, error) { + return _Kyc.Contract.GetCandidates(&_Kyc.CallOpts) } // GetCandidates is a free data retrieval call binding the contract method 0x06a49fce. // // Solidity: function getCandidates() constant returns(address[]) -func (_XDCValidator *XDCValidatorCallerSession) GetCandidates() ([]common.Address, error) { - return _XDCValidator.Contract.GetCandidates(&_XDCValidator.CallOpts) +func (_Kyc *KycCallerSession) GetCandidates() ([]common.Address, error) { + return _Kyc.Contract.GetCandidates(&_Kyc.CallOpts) } -// GetKYC is a free data retrieval call binding the contract method 0x4d1a687d. +// GetOwner is a free data retrieval call binding the contract method 0xfa544161. // -// Solidity: function getKYC(_address address) constant returns(string) -func (_XDCValidator *XDCValidatorCaller) GetKYC(opts *bind.CallOpts, _address common.Address) (string, error) { +// Solidity: function getOwner(address _masternode) constant returns(address) +func (_Kyc *KycCaller) GetOwner(opts *bind.CallOpts, _masternode common.Address) (common.Address, error) { var ( - ret0 = new(string) + ret0 = new(common.Address) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "getKYC", _address) + err := _Kyc.contract.Call(opts, out, "getOwner", _masternode) return *ret0, err } -// GetKYC is a free data retrieval call binding the contract method 0x4d1a687d. +// GetOwner is a free data retrieval call binding the contract method 0xfa544161. // -// Solidity: function getKYC(_address address) constant returns(string) -func (_XDCValidator *XDCValidatorSession) GetKYC(_address common.Address) (string, error) { - return _XDCValidator.Contract.GetKYC(&_XDCValidator.CallOpts, _address) +// Solidity: function getOwner(address _masternode) constant returns(address) +func (_Kyc *KycSession) GetOwner(_masternode common.Address) (common.Address, error) { + return _Kyc.Contract.GetOwner(&_Kyc.CallOpts, _masternode) } -// GetKYC is a free data retrieval call binding the contract method 0x4d1a687d. +// GetOwner is a free data retrieval call binding the contract method 0xfa544161. // -// Solidity: function getKYC(_address address) constant returns(string) -func (_XDCValidator *XDCValidatorCallerSession) GetKYC(_address common.Address) (string, error) { - return _XDCValidator.Contract.GetKYC(&_XDCValidator.CallOpts, _address) +// Solidity: function getOwner(address _masternode) constant returns(address) +func (_Kyc *KycCallerSession) GetOwner(_masternode common.Address) (common.Address, error) { + return _Kyc.Contract.GetOwner(&_Kyc.CallOpts, _masternode) } // GetOwnerCount is a free data retrieval call binding the contract method 0xef18374a. // // Solidity: function getOwnerCount() constant returns(uint256) -func (_XDCValidator *XDCValidatorCaller) GetOwnerCount(opts *bind.CallOpts) (*big.Int, error) { +func (_Kyc *KycCaller) GetOwnerCount(opts *bind.CallOpts) (*big.Int, error) { var ( ret0 = new(*big.Int) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "getOwnerCount") + err := _Kyc.contract.Call(opts, out, "getOwnerCount") return *ret0, err } // GetOwnerCount is a free data retrieval call binding the contract method 0xef18374a. // // Solidity: function getOwnerCount() constant returns(uint256) -func (_XDCValidator *XDCValidatorSession) GetOwnerCount() (*big.Int, error) { - return _XDCValidator.Contract.GetOwnerCount(&_XDCValidator.CallOpts) +func (_Kyc *KycSession) GetOwnerCount() (*big.Int, error) { + return _Kyc.Contract.GetOwnerCount(&_Kyc.CallOpts) } // GetOwnerCount is a free data retrieval call binding the contract method 0xef18374a. // // Solidity: function getOwnerCount() constant returns(uint256) -func (_XDCValidator *XDCValidatorCallerSession) GetOwnerCount() (*big.Int, error) { - return _XDCValidator.Contract.GetOwnerCount(&_XDCValidator.CallOpts) +func (_Kyc *KycCallerSession) GetOwnerCount() (*big.Int, error) { + return _Kyc.Contract.GetOwnerCount(&_Kyc.CallOpts) } // GetVoterCap is a free data retrieval call binding the contract method 0x302b6872. // -// Solidity: function getVoterCap(_candidate address, _voter address) constant returns(uint256) -func (_XDCValidator *XDCValidatorCaller) GetVoterCap(opts *bind.CallOpts, _candidate common.Address, _voter common.Address) (*big.Int, error) { +// Solidity: function getVoterCap(address _candidate, address _voter) constant returns(uint256) +func (_Kyc *KycCaller) GetVoterCap(opts *bind.CallOpts, _candidate common.Address, _voter common.Address) (*big.Int, error) { var ( ret0 = new(*big.Int) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "getVoterCap", _candidate, _voter) + err := _Kyc.contract.Call(opts, out, "getVoterCap", _candidate, _voter) return *ret0, err } // GetVoterCap is a free data retrieval call binding the contract method 0x302b6872. // -// Solidity: function getVoterCap(_candidate address, _voter address) constant returns(uint256) -func (_XDCValidator *XDCValidatorSession) GetVoterCap(_candidate common.Address, _voter common.Address) (*big.Int, error) { - return _XDCValidator.Contract.GetVoterCap(&_XDCValidator.CallOpts, _candidate, _voter) +// Solidity: function getVoterCap(address _candidate, address _voter) constant returns(uint256) +func (_Kyc *KycSession) GetVoterCap(_candidate common.Address, _voter common.Address) (*big.Int, error) { + return _Kyc.Contract.GetVoterCap(&_Kyc.CallOpts, _candidate, _voter) } // GetVoterCap is a free data retrieval call binding the contract method 0x302b6872. // -// Solidity: function getVoterCap(_candidate address, _voter address) constant returns(uint256) -func (_XDCValidator *XDCValidatorCallerSession) GetVoterCap(_candidate common.Address, _voter common.Address) (*big.Int, error) { - return _XDCValidator.Contract.GetVoterCap(&_XDCValidator.CallOpts, _candidate, _voter) +// Solidity: function getVoterCap(address _candidate, address _voter) constant returns(uint256) +func (_Kyc *KycCallerSession) GetVoterCap(_candidate common.Address, _voter common.Address) (*big.Int, error) { + return _Kyc.Contract.GetVoterCap(&_Kyc.CallOpts, _candidate, _voter) } // GetVoters is a free data retrieval call binding the contract method 0x2d15cc04. // -// Solidity: function getVoters(_candidate address) constant returns(address[]) -func (_XDCValidator *XDCValidatorCaller) GetVoters(opts *bind.CallOpts, _candidate common.Address) ([]common.Address, error) { +// Solidity: function getVoters(address _candidate) constant returns(address[]) +func (_Kyc *KycCaller) GetVoters(opts *bind.CallOpts, _candidate common.Address) ([]common.Address, error) { var ( ret0 = new([]common.Address) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "getVoters", _candidate) + err := _Kyc.contract.Call(opts, out, "getVoters", _candidate) return *ret0, err } // GetVoters is a free data retrieval call binding the contract method 0x2d15cc04. // -// Solidity: function getVoters(_candidate address) constant returns(address[]) -func (_XDCValidator *XDCValidatorSession) GetVoters(_candidate common.Address) ([]common.Address, error) { - return _XDCValidator.Contract.GetVoters(&_XDCValidator.CallOpts, _candidate) +// Solidity: function getVoters(address _candidate) constant returns(address[]) +func (_Kyc *KycSession) GetVoters(_candidate common.Address) ([]common.Address, error) { + return _Kyc.Contract.GetVoters(&_Kyc.CallOpts, _candidate) } // GetVoters is a free data retrieval call binding the contract method 0x2d15cc04. // -// Solidity: function getVoters(_candidate address) constant returns(address[]) -func (_XDCValidator *XDCValidatorCallerSession) GetVoters(_candidate common.Address) ([]common.Address, error) { - return _XDCValidator.Contract.GetVoters(&_XDCValidator.CallOpts, _candidate) +// Solidity: function getVoters(address _candidate) constant returns(address[]) +func (_Kyc *KycCallerSession) GetVoters(_candidate common.Address) ([]common.Address, error) { + return _Kyc.Contract.GetVoters(&_Kyc.CallOpts, _candidate) } // GetWithdrawBlockNumbers is a free data retrieval call binding the contract method 0x2f9c4bba. // // Solidity: function getWithdrawBlockNumbers() constant returns(uint256[]) -func (_XDCValidator *XDCValidatorCaller) GetWithdrawBlockNumbers(opts *bind.CallOpts) ([]*big.Int, error) { +func (_Kyc *KycCaller) GetWithdrawBlockNumbers(opts *bind.CallOpts) ([]*big.Int, error) { var ( ret0 = new([]*big.Int) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "getWithdrawBlockNumbers") + err := _Kyc.contract.Call(opts, out, "getWithdrawBlockNumbers") return *ret0, err } // GetWithdrawBlockNumbers is a free data retrieval call binding the contract method 0x2f9c4bba. // // Solidity: function getWithdrawBlockNumbers() constant returns(uint256[]) -func (_XDCValidator *XDCValidatorSession) GetWithdrawBlockNumbers() ([]*big.Int, error) { - return _XDCValidator.Contract.GetWithdrawBlockNumbers(&_XDCValidator.CallOpts) +func (_Kyc *KycSession) GetWithdrawBlockNumbers() ([]*big.Int, error) { + return _Kyc.Contract.GetWithdrawBlockNumbers(&_Kyc.CallOpts) } // GetWithdrawBlockNumbers is a free data retrieval call binding the contract method 0x2f9c4bba. // // Solidity: function getWithdrawBlockNumbers() constant returns(uint256[]) -func (_XDCValidator *XDCValidatorCallerSession) GetWithdrawBlockNumbers() ([]*big.Int, error) { - return _XDCValidator.Contract.GetWithdrawBlockNumbers(&_XDCValidator.CallOpts) +func (_Kyc *KycCallerSession) GetWithdrawBlockNumbers() ([]*big.Int, error) { + return _Kyc.Contract.GetWithdrawBlockNumbers(&_Kyc.CallOpts) } // GetWithdrawCap is a free data retrieval call binding the contract method 0x15febd68. // -// Solidity: function getWithdrawCap(_blockNumber uint256) constant returns(uint256) -func (_XDCValidator *XDCValidatorCaller) GetWithdrawCap(opts *bind.CallOpts, _blockNumber *big.Int) (*big.Int, error) { +// Solidity: function getWithdrawCap(uint256 _blockNumber) constant returns(uint256) +func (_Kyc *KycCaller) GetWithdrawCap(opts *bind.CallOpts, _blockNumber *big.Int) (*big.Int, error) { var ( ret0 = new(*big.Int) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "getWithdrawCap", _blockNumber) + err := _Kyc.contract.Call(opts, out, "getWithdrawCap", _blockNumber) return *ret0, err } // GetWithdrawCap is a free data retrieval call binding the contract method 0x15febd68. // -// Solidity: function getWithdrawCap(_blockNumber uint256) constant returns(uint256) -func (_XDCValidator *XDCValidatorSession) GetWithdrawCap(_blockNumber *big.Int) (*big.Int, error) { - return _XDCValidator.Contract.GetWithdrawCap(&_XDCValidator.CallOpts, _blockNumber) +// Solidity: function getWithdrawCap(uint256 _blockNumber) constant returns(uint256) +func (_Kyc *KycSession) GetWithdrawCap(_blockNumber *big.Int) (*big.Int, error) { + return _Kyc.Contract.GetWithdrawCap(&_Kyc.CallOpts, _blockNumber) } // GetWithdrawCap is a free data retrieval call binding the contract method 0x15febd68. // -// Solidity: function getWithdrawCap(_blockNumber uint256) constant returns(uint256) -func (_XDCValidator *XDCValidatorCallerSession) GetWithdrawCap(_blockNumber *big.Int) (*big.Int, error) { - return _XDCValidator.Contract.GetWithdrawCap(&_XDCValidator.CallOpts, _blockNumber) +// Solidity: function getWithdrawCap(uint256 _blockNumber) constant returns(uint256) +func (_Kyc *KycCallerSession) GetWithdrawCap(_blockNumber *big.Int) (*big.Int, error) { + return _Kyc.Contract.GetWithdrawCap(&_Kyc.CallOpts, _blockNumber) } // HasVotedInvalid is a free data retrieval call binding the contract method 0x0e3e4fb8. // -// Solidity: function hasVotedInvalid( address, address) constant returns(bool) -func (_XDCValidator *XDCValidatorCaller) HasVotedInvalid(opts *bind.CallOpts, arg0 common.Address, arg1 common.Address) (bool, error) { +// Solidity: function hasVotedInvalid(address , address ) constant returns(bool) +func (_Kyc *KycCaller) HasVotedInvalid(opts *bind.CallOpts, arg0 common.Address, arg1 common.Address) (bool, error) { var ( ret0 = new(bool) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "hasVotedInvalid", arg0, arg1) + err := _Kyc.contract.Call(opts, out, "hasVotedInvalid", arg0, arg1) return *ret0, err } // HasVotedInvalid is a free data retrieval call binding the contract method 0x0e3e4fb8. // -// Solidity: function hasVotedInvalid( address, address) constant returns(bool) -func (_XDCValidator *XDCValidatorSession) HasVotedInvalid(arg0 common.Address, arg1 common.Address) (bool, error) { - return _XDCValidator.Contract.HasVotedInvalid(&_XDCValidator.CallOpts, arg0, arg1) +// Solidity: function hasVotedInvalid(address , address ) constant returns(bool) +func (_Kyc *KycSession) HasVotedInvalid(arg0 common.Address, arg1 common.Address) (bool, error) { + return _Kyc.Contract.HasVotedInvalid(&_Kyc.CallOpts, arg0, arg1) } // HasVotedInvalid is a free data retrieval call binding the contract method 0x0e3e4fb8. // -// Solidity: function hasVotedInvalid( address, address) constant returns(bool) -func (_XDCValidator *XDCValidatorCallerSession) HasVotedInvalid(arg0 common.Address, arg1 common.Address) (bool, error) { - return _XDCValidator.Contract.HasVotedInvalid(&_XDCValidator.CallOpts, arg0, arg1) +// Solidity: function hasVotedInvalid(address , address ) constant returns(bool) +func (_Kyc *KycCallerSession) HasVotedInvalid(arg0 common.Address, arg1 common.Address) (bool, error) { + return _Kyc.Contract.HasVotedInvalid(&_Kyc.CallOpts, arg0, arg1) } // InvalidKYCCount is a free data retrieval call binding the contract method 0x72e44a38. // -// Solidity: function invalidKYCCount( address) constant returns(uint256) -func (_XDCValidator *XDCValidatorCaller) InvalidKYCCount(opts *bind.CallOpts, arg0 common.Address) (*big.Int, error) { +// Solidity: function invalidKYCCount(address ) constant returns(uint256) +func (_Kyc *KycCaller) InvalidKYCCount(opts *bind.CallOpts, arg0 common.Address) (*big.Int, error) { var ( ret0 = new(*big.Int) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "invalidKYCCount", arg0) + err := _Kyc.contract.Call(opts, out, "invalidKYCCount", arg0) return *ret0, err } // InvalidKYCCount is a free data retrieval call binding the contract method 0x72e44a38. // -// Solidity: function invalidKYCCount( address) constant returns(uint256) -func (_XDCValidator *XDCValidatorSession) InvalidKYCCount(arg0 common.Address) (*big.Int, error) { - return _XDCValidator.Contract.InvalidKYCCount(&_XDCValidator.CallOpts, arg0) +// Solidity: function invalidKYCCount(address ) constant returns(uint256) +func (_Kyc *KycSession) InvalidKYCCount(arg0 common.Address) (*big.Int, error) { + return _Kyc.Contract.InvalidKYCCount(&_Kyc.CallOpts, arg0) } // InvalidKYCCount is a free data retrieval call binding the contract method 0x72e44a38. // -// Solidity: function invalidKYCCount( address) constant returns(uint256) -func (_XDCValidator *XDCValidatorCallerSession) InvalidKYCCount(arg0 common.Address) (*big.Int, error) { - return _XDCValidator.Contract.InvalidKYCCount(&_XDCValidator.CallOpts, arg0) -} - -// InvalidPercent is a free data retrieval call binding the contract method 0x5b860d27. -// -// Solidity: function invalidPercent(_invalidCandidate address) constant returns(uint256) -func (_XDCValidator *XDCValidatorCaller) InvalidPercent(opts *bind.CallOpts, _invalidCandidate common.Address) (*big.Int, error) { - var ( - ret0 = new(*big.Int) - ) - out := ret0 - err := _XDCValidator.contract.Call(opts, out, "invalidPercent", _invalidCandidate) - return *ret0, err -} - -// InvalidPercent is a free data retrieval call binding the contract method 0x5b860d27. -// -// Solidity: function invalidPercent(_invalidCandidate address) constant returns(uint256) -func (_XDCValidator *XDCValidatorSession) InvalidPercent(_invalidCandidate common.Address) (*big.Int, error) { - return _XDCValidator.Contract.InvalidPercent(&_XDCValidator.CallOpts, _invalidCandidate) -} - -// InvalidPercent is a free data retrieval call binding the contract method 0x5b860d27. -// -// Solidity: function invalidPercent(_invalidCandidate address) constant returns(uint256) -func (_XDCValidator *XDCValidatorCallerSession) InvalidPercent(_invalidCandidate common.Address) (*big.Int, error) { - return _XDCValidator.Contract.InvalidPercent(&_XDCValidator.CallOpts, _invalidCandidate) +// Solidity: function invalidKYCCount(address ) constant returns(uint256) +func (_Kyc *KycCallerSession) InvalidKYCCount(arg0 common.Address) (*big.Int, error) { + return _Kyc.Contract.InvalidKYCCount(&_Kyc.CallOpts, arg0) } // IsCandidate is a free data retrieval call binding the contract method 0xd51b9e93. // -// Solidity: function isCandidate(_candidate address) constant returns(bool) -func (_XDCValidator *XDCValidatorCaller) IsCandidate(opts *bind.CallOpts, _candidate common.Address) (bool, error) { +// Solidity: function isCandidate(address _candidate) constant returns(bool) +func (_Kyc *KycCaller) IsCandidate(opts *bind.CallOpts, _candidate common.Address) (bool, error) { var ( ret0 = new(bool) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "isCandidate", _candidate) + err := _Kyc.contract.Call(opts, out, "isCandidate", _candidate) return *ret0, err } // IsCandidate is a free data retrieval call binding the contract method 0xd51b9e93. // -// Solidity: function isCandidate(_candidate address) constant returns(bool) -func (_XDCValidator *XDCValidatorSession) IsCandidate(_candidate common.Address) (bool, error) { - return _XDCValidator.Contract.IsCandidate(&_XDCValidator.CallOpts, _candidate) +// Solidity: function isCandidate(address _candidate) constant returns(bool) +func (_Kyc *KycSession) IsCandidate(_candidate common.Address) (bool, error) { + return _Kyc.Contract.IsCandidate(&_Kyc.CallOpts, _candidate) } // IsCandidate is a free data retrieval call binding the contract method 0xd51b9e93. // -// Solidity: function isCandidate(_candidate address) constant returns(bool) -func (_XDCValidator *XDCValidatorCallerSession) IsCandidate(_candidate common.Address) (bool, error) { - return _XDCValidator.Contract.IsCandidate(&_XDCValidator.CallOpts, _candidate) +// Solidity: function isCandidate(address _candidate) constant returns(bool) +func (_Kyc *KycCallerSession) IsCandidate(_candidate common.Address) (bool, error) { + return _Kyc.Contract.IsCandidate(&_Kyc.CallOpts, _candidate) } // MaxValidatorNumber is a free data retrieval call binding the contract method 0xd09f1ab4. // // Solidity: function maxValidatorNumber() constant returns(uint256) -func (_XDCValidator *XDCValidatorCaller) MaxValidatorNumber(opts *bind.CallOpts) (*big.Int, error) { +func (_Kyc *KycCaller) MaxValidatorNumber(opts *bind.CallOpts) (*big.Int, error) { var ( ret0 = new(*big.Int) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "maxValidatorNumber") + err := _Kyc.contract.Call(opts, out, "maxValidatorNumber") return *ret0, err } // MaxValidatorNumber is a free data retrieval call binding the contract method 0xd09f1ab4. // // Solidity: function maxValidatorNumber() constant returns(uint256) -func (_XDCValidator *XDCValidatorSession) MaxValidatorNumber() (*big.Int, error) { - return _XDCValidator.Contract.MaxValidatorNumber(&_XDCValidator.CallOpts) +func (_Kyc *KycSession) MaxValidatorNumber() (*big.Int, error) { + return _Kyc.Contract.MaxValidatorNumber(&_Kyc.CallOpts) } // MaxValidatorNumber is a free data retrieval call binding the contract method 0xd09f1ab4. // // Solidity: function maxValidatorNumber() constant returns(uint256) -func (_XDCValidator *XDCValidatorCallerSession) MaxValidatorNumber() (*big.Int, error) { - return _XDCValidator.Contract.MaxValidatorNumber(&_XDCValidator.CallOpts) +func (_Kyc *KycCallerSession) MaxValidatorNumber() (*big.Int, error) { + return _Kyc.Contract.MaxValidatorNumber(&_Kyc.CallOpts) } // MinCandidateCap is a free data retrieval call binding the contract method 0xd55b7dff. // // Solidity: function minCandidateCap() constant returns(uint256) -func (_XDCValidator *XDCValidatorCaller) MinCandidateCap(opts *bind.CallOpts) (*big.Int, error) { +func (_Kyc *KycCaller) MinCandidateCap(opts *bind.CallOpts) (*big.Int, error) { var ( ret0 = new(*big.Int) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "minCandidateCap") + err := _Kyc.contract.Call(opts, out, "minCandidateCap") return *ret0, err } // MinCandidateCap is a free data retrieval call binding the contract method 0xd55b7dff. // // Solidity: function minCandidateCap() constant returns(uint256) -func (_XDCValidator *XDCValidatorSession) MinCandidateCap() (*big.Int, error) { - return _XDCValidator.Contract.MinCandidateCap(&_XDCValidator.CallOpts) +func (_Kyc *KycSession) MinCandidateCap() (*big.Int, error) { + return _Kyc.Contract.MinCandidateCap(&_Kyc.CallOpts) } // MinCandidateCap is a free data retrieval call binding the contract method 0xd55b7dff. // // Solidity: function minCandidateCap() constant returns(uint256) -func (_XDCValidator *XDCValidatorCallerSession) MinCandidateCap() (*big.Int, error) { - return _XDCValidator.Contract.MinCandidateCap(&_XDCValidator.CallOpts) +func (_Kyc *KycCallerSession) MinCandidateCap() (*big.Int, error) { + return _Kyc.Contract.MinCandidateCap(&_Kyc.CallOpts) } // MinVoterCap is a free data retrieval call binding the contract method 0xf8ac9dd5. // // Solidity: function minVoterCap() constant returns(uint256) -func (_XDCValidator *XDCValidatorCaller) MinVoterCap(opts *bind.CallOpts) (*big.Int, error) { +func (_Kyc *KycCaller) MinVoterCap(opts *bind.CallOpts) (*big.Int, error) { var ( ret0 = new(*big.Int) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "minVoterCap") + err := _Kyc.contract.Call(opts, out, "minVoterCap") return *ret0, err } // MinVoterCap is a free data retrieval call binding the contract method 0xf8ac9dd5. // // Solidity: function minVoterCap() constant returns(uint256) -func (_XDCValidator *XDCValidatorSession) MinVoterCap() (*big.Int, error) { - return _XDCValidator.Contract.MinVoterCap(&_XDCValidator.CallOpts) +func (_Kyc *KycSession) MinVoterCap() (*big.Int, error) { + return _Kyc.Contract.MinVoterCap(&_Kyc.CallOpts) } // MinVoterCap is a free data retrieval call binding the contract method 0xf8ac9dd5. // // Solidity: function minVoterCap() constant returns(uint256) -func (_XDCValidator *XDCValidatorCallerSession) MinVoterCap() (*big.Int, error) { - return _XDCValidator.Contract.MinVoterCap(&_XDCValidator.CallOpts) +func (_Kyc *KycCallerSession) MinVoterCap() (*big.Int, error) { + return _Kyc.Contract.MinVoterCap(&_Kyc.CallOpts) } // OwnerToCandidate is a free data retrieval call binding the contract method 0x2a3640b1. // -// Solidity: function ownerToCandidate( address, uint256) constant returns(address) -func (_XDCValidator *XDCValidatorCaller) OwnerToCandidate(opts *bind.CallOpts, arg0 common.Address, arg1 *big.Int) (common.Address, error) { +// Solidity: function ownerToCandidate(address , uint256 ) constant returns(address) +func (_Kyc *KycCaller) OwnerToCandidate(opts *bind.CallOpts, arg0 common.Address, arg1 *big.Int) (common.Address, error) { var ( ret0 = new(common.Address) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "ownerToCandidate", arg0, arg1) + err := _Kyc.contract.Call(opts, out, "ownerToCandidate", arg0, arg1) return *ret0, err } // OwnerToCandidate is a free data retrieval call binding the contract method 0x2a3640b1. // -// Solidity: function ownerToCandidate( address, uint256) constant returns(address) -func (_XDCValidator *XDCValidatorSession) OwnerToCandidate(arg0 common.Address, arg1 *big.Int) (common.Address, error) { - return _XDCValidator.Contract.OwnerToCandidate(&_XDCValidator.CallOpts, arg0, arg1) +// Solidity: function ownerToCandidate(address , uint256 ) constant returns(address) +func (_Kyc *KycSession) OwnerToCandidate(arg0 common.Address, arg1 *big.Int) (common.Address, error) { + return _Kyc.Contract.OwnerToCandidate(&_Kyc.CallOpts, arg0, arg1) } // OwnerToCandidate is a free data retrieval call binding the contract method 0x2a3640b1. // -// Solidity: function ownerToCandidate( address, uint256) constant returns(address) -func (_XDCValidator *XDCValidatorCallerSession) OwnerToCandidate(arg0 common.Address, arg1 *big.Int) (common.Address, error) { - return _XDCValidator.Contract.OwnerToCandidate(&_XDCValidator.CallOpts, arg0, arg1) +// Solidity: function ownerToCandidate(address , uint256 ) constant returns(address) +func (_Kyc *KycCallerSession) OwnerToCandidate(arg0 common.Address, arg1 *big.Int) (common.Address, error) { + return _Kyc.Contract.OwnerToCandidate(&_Kyc.CallOpts, arg0, arg1) } // Owners is a free data retrieval call binding the contract method 0x025e7c27. // -// Solidity: function owners( uint256) constant returns(address) -func (_XDCValidator *XDCValidatorCaller) Owners(opts *bind.CallOpts, arg0 *big.Int) (common.Address, error) { +// Solidity: function owners(uint256 ) constant returns(address) +func (_Kyc *KycCaller) Owners(opts *bind.CallOpts, arg0 *big.Int) (common.Address, error) { var ( ret0 = new(common.Address) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "owners", arg0) + err := _Kyc.contract.Call(opts, out, "owners", arg0) return *ret0, err } // Owners is a free data retrieval call binding the contract method 0x025e7c27. // -// Solidity: function owners( uint256) constant returns(address) -func (_XDCValidator *XDCValidatorSession) Owners(arg0 *big.Int) (common.Address, error) { - return _XDCValidator.Contract.Owners(&_XDCValidator.CallOpts, arg0) +// Solidity: function owners(uint256 ) constant returns(address) +func (_Kyc *KycSession) Owners(arg0 *big.Int) (common.Address, error) { + return _Kyc.Contract.Owners(&_Kyc.CallOpts, arg0) } // Owners is a free data retrieval call binding the contract method 0x025e7c27. // -// Solidity: function owners( uint256) constant returns(address) -func (_XDCValidator *XDCValidatorCallerSession) Owners(arg0 *big.Int) (common.Address, error) { - return _XDCValidator.Contract.Owners(&_XDCValidator.CallOpts, arg0) +// Solidity: function owners(uint256 ) constant returns(address) +func (_Kyc *KycCallerSession) Owners(arg0 *big.Int) (common.Address, error) { + return _Kyc.Contract.Owners(&_Kyc.CallOpts, arg0) } // VoterWithdrawDelay is a free data retrieval call binding the contract method 0xa9ff959e. // // Solidity: function voterWithdrawDelay() constant returns(uint256) -func (_XDCValidator *XDCValidatorCaller) VoterWithdrawDelay(opts *bind.CallOpts) (*big.Int, error) { +func (_Kyc *KycCaller) VoterWithdrawDelay(opts *bind.CallOpts) (*big.Int, error) { var ( ret0 = new(*big.Int) ) out := ret0 - err := _XDCValidator.contract.Call(opts, out, "voterWithdrawDelay") + err := _Kyc.contract.Call(opts, out, "voterWithdrawDelay") return *ret0, err } // VoterWithdrawDelay is a free data retrieval call binding the contract method 0xa9ff959e. // // Solidity: function voterWithdrawDelay() constant returns(uint256) -func (_XDCValidator *XDCValidatorSession) VoterWithdrawDelay() (*big.Int, error) { - return _XDCValidator.Contract.VoterWithdrawDelay(&_XDCValidator.CallOpts) +func (_Kyc *KycSession) VoterWithdrawDelay() (*big.Int, error) { + return _Kyc.Contract.VoterWithdrawDelay(&_Kyc.CallOpts) } // VoterWithdrawDelay is a free data retrieval call binding the contract method 0xa9ff959e. // // Solidity: function voterWithdrawDelay() constant returns(uint256) -func (_XDCValidator *XDCValidatorCallerSession) VoterWithdrawDelay() (*big.Int, error) { - return _XDCValidator.Contract.VoterWithdrawDelay(&_XDCValidator.CallOpts) +func (_Kyc *KycCallerSession) VoterWithdrawDelay() (*big.Int, error) { + return _Kyc.Contract.VoterWithdrawDelay(&_Kyc.CallOpts) +} + +// VoteInvalidKYC is a paid mutator transaction binding the contract method 0xa0f56aa1. +// +// Solidity: function VoteInvalidKYC(address _invalidMasternode) returns() +func (_Kyc *KycTransactor) VoteInvalidKYC(opts *bind.TransactOpts, _invalidMasternode common.Address) (*types.Transaction, error) { + return _Kyc.contract.Transact(opts, "VoteInvalidKYC", _invalidMasternode) +} + +// VoteInvalidKYC is a paid mutator transaction binding the contract method 0xa0f56aa1. +// +// Solidity: function VoteInvalidKYC(address _invalidMasternode) returns() +func (_Kyc *KycSession) VoteInvalidKYC(_invalidMasternode common.Address) (*types.Transaction, error) { + return _Kyc.Contract.VoteInvalidKYC(&_Kyc.TransactOpts, _invalidMasternode) +} + +// VoteInvalidKYC is a paid mutator transaction binding the contract method 0xa0f56aa1. +// +// Solidity: function VoteInvalidKYC(address _invalidMasternode) returns() +func (_Kyc *KycTransactorSession) VoteInvalidKYC(_invalidMasternode common.Address) (*types.Transaction, error) { + return _Kyc.Contract.VoteInvalidKYC(&_Kyc.TransactOpts, _invalidMasternode) } // Propose is a paid mutator transaction binding the contract method 0x01267951. // -// Solidity: function propose(_candidate address) returns() -func (_XDCValidator *XDCValidatorTransactor) Propose(opts *bind.TransactOpts, _candidate common.Address) (*types.Transaction, error) { - return _XDCValidator.contract.Transact(opts, "propose", _candidate) +// Solidity: function propose(address _candidate) returns() +func (_Kyc *KycTransactor) Propose(opts *bind.TransactOpts, _candidate common.Address) (*types.Transaction, error) { + return _Kyc.contract.Transact(opts, "propose", _candidate) } // Propose is a paid mutator transaction binding the contract method 0x01267951. // -// Solidity: function propose(_candidate address) returns() -func (_XDCValidator *XDCValidatorSession) Propose(_candidate common.Address) (*types.Transaction, error) { - return _XDCValidator.Contract.Propose(&_XDCValidator.TransactOpts, _candidate) +// Solidity: function propose(address _candidate) returns() +func (_Kyc *KycSession) Propose(_candidate common.Address) (*types.Transaction, error) { + return _Kyc.Contract.Propose(&_Kyc.TransactOpts, _candidate) } // Propose is a paid mutator transaction binding the contract method 0x01267951. // -// Solidity: function propose(_candidate address) returns() -func (_XDCValidator *XDCValidatorTransactorSession) Propose(_candidate common.Address) (*types.Transaction, error) { - return _XDCValidator.Contract.Propose(&_XDCValidator.TransactOpts, _candidate) +// Solidity: function propose(address _candidate) returns() +func (_Kyc *KycTransactorSession) Propose(_candidate common.Address) (*types.Transaction, error) { + return _Kyc.Contract.Propose(&_Kyc.TransactOpts, _candidate) } // Resign is a paid mutator transaction binding the contract method 0xae6e43f5. // -// Solidity: function resign(_candidate address) returns() -func (_XDCValidator *XDCValidatorTransactor) Resign(opts *bind.TransactOpts, _candidate common.Address) (*types.Transaction, error) { - return _XDCValidator.contract.Transact(opts, "resign", _candidate) +// Solidity: function resign(address _candidate) returns() +func (_Kyc *KycTransactor) Resign(opts *bind.TransactOpts, _candidate common.Address) (*types.Transaction, error) { + return _Kyc.contract.Transact(opts, "resign", _candidate) } // Resign is a paid mutator transaction binding the contract method 0xae6e43f5. // -// Solidity: function resign(_candidate address) returns() -func (_XDCValidator *XDCValidatorSession) Resign(_candidate common.Address) (*types.Transaction, error) { - return _XDCValidator.Contract.Resign(&_XDCValidator.TransactOpts, _candidate) +// Solidity: function resign(address _candidate) returns() +func (_Kyc *KycSession) Resign(_candidate common.Address) (*types.Transaction, error) { + return _Kyc.Contract.Resign(&_Kyc.TransactOpts, _candidate) } // Resign is a paid mutator transaction binding the contract method 0xae6e43f5. // -// Solidity: function resign(_candidate address) returns() -func (_XDCValidator *XDCValidatorTransactorSession) Resign(_candidate common.Address) (*types.Transaction, error) { - return _XDCValidator.Contract.Resign(&_XDCValidator.TransactOpts, _candidate) +// Solidity: function resign(address _candidate) returns() +func (_Kyc *KycTransactorSession) Resign(_candidate common.Address) (*types.Transaction, error) { + return _Kyc.Contract.Resign(&_Kyc.TransactOpts, _candidate) } // Unvote is a paid mutator transaction binding the contract method 0x02aa9be2. // -// Solidity: function unvote(_candidate address, _cap uint256) returns() -func (_XDCValidator *XDCValidatorTransactor) Unvote(opts *bind.TransactOpts, _candidate common.Address, _cap *big.Int) (*types.Transaction, error) { - return _XDCValidator.contract.Transact(opts, "unvote", _candidate, _cap) +// Solidity: function unvote(address _candidate, uint256 _cap) returns() +func (_Kyc *KycTransactor) Unvote(opts *bind.TransactOpts, _candidate common.Address, _cap *big.Int) (*types.Transaction, error) { + return _Kyc.contract.Transact(opts, "unvote", _candidate, _cap) } // Unvote is a paid mutator transaction binding the contract method 0x02aa9be2. // -// Solidity: function unvote(_candidate address, _cap uint256) returns() -func (_XDCValidator *XDCValidatorSession) Unvote(_candidate common.Address, _cap *big.Int) (*types.Transaction, error) { - return _XDCValidator.Contract.Unvote(&_XDCValidator.TransactOpts, _candidate, _cap) +// Solidity: function unvote(address _candidate, uint256 _cap) returns() +func (_Kyc *KycSession) Unvote(_candidate common.Address, _cap *big.Int) (*types.Transaction, error) { + return _Kyc.Contract.Unvote(&_Kyc.TransactOpts, _candidate, _cap) } // Unvote is a paid mutator transaction binding the contract method 0x02aa9be2. // -// Solidity: function unvote(_candidate address, _cap uint256) returns() -func (_XDCValidator *XDCValidatorTransactorSession) Unvote(_candidate common.Address, _cap *big.Int) (*types.Transaction, error) { - return _XDCValidator.Contract.Unvote(&_XDCValidator.TransactOpts, _candidate, _cap) +// Solidity: function unvote(address _candidate, uint256 _cap) returns() +func (_Kyc *KycTransactorSession) Unvote(_candidate common.Address, _cap *big.Int) (*types.Transaction, error) { + return _Kyc.Contract.Unvote(&_Kyc.TransactOpts, _candidate, _cap) } -// UploadKYC is a paid mutator transaction binding the contract method 0xf5c95125. +// UploadKYC is a paid mutator transaction binding the contract method 0xe8fd6927. // -// Solidity: function uploadKYC(kychash string) returns() -func (_XDCValidator *XDCValidatorTransactor) UploadKYC(opts *bind.TransactOpts, kychash string) (*types.Transaction, error) { - return _XDCValidator.contract.Transact(opts, "uploadKYC", kychash) +// Solidity: function uploadKYC(bytes32 _kycdata) returns() +func (_Kyc *KycTransactor) UploadKYC(opts *bind.TransactOpts, _kycdata [32]byte) (*types.Transaction, error) { + return _Kyc.contract.Transact(opts, "uploadKYC", _kycdata) } -// UploadKYC is a paid mutator transaction binding the contract method 0xf5c95125. +// UploadKYC is a paid mutator transaction binding the contract method 0xe8fd6927. // -// Solidity: function uploadKYC(kychash string) returns() -func (_XDCValidator *XDCValidatorSession) UploadKYC(kychash string) (*types.Transaction, error) { - return _XDCValidator.Contract.UploadKYC(&_XDCValidator.TransactOpts, kychash) +// Solidity: function uploadKYC(bytes32 _kycdata) returns() +func (_Kyc *KycSession) UploadKYC(_kycdata [32]byte) (*types.Transaction, error) { + return _Kyc.Contract.UploadKYC(&_Kyc.TransactOpts, _kycdata) } -// UploadKYC is a paid mutator transaction binding the contract method 0xf5c95125. +// UploadKYC is a paid mutator transaction binding the contract method 0xe8fd6927. // -// Solidity: function uploadKYC(kychash string) returns() -func (_XDCValidator *XDCValidatorTransactorSession) UploadKYC(kychash string) (*types.Transaction, error) { - return _XDCValidator.Contract.UploadKYC(&_XDCValidator.TransactOpts, kychash) +// Solidity: function uploadKYC(bytes32 _kycdata) returns() +func (_Kyc *KycTransactorSession) UploadKYC(_kycdata [32]byte) (*types.Transaction, error) { + return _Kyc.Contract.UploadKYC(&_Kyc.TransactOpts, _kycdata) } // Vote is a paid mutator transaction binding the contract method 0x6dd7d8ea. // -// Solidity: function vote(_candidate address) returns() -func (_XDCValidator *XDCValidatorTransactor) Vote(opts *bind.TransactOpts, _candidate common.Address) (*types.Transaction, error) { - return _XDCValidator.contract.Transact(opts, "vote", _candidate) +// Solidity: function vote(address _candidate) returns() +func (_Kyc *KycTransactor) Vote(opts *bind.TransactOpts, _candidate common.Address) (*types.Transaction, error) { + return _Kyc.contract.Transact(opts, "vote", _candidate) } // Vote is a paid mutator transaction binding the contract method 0x6dd7d8ea. // -// Solidity: function vote(_candidate address) returns() -func (_XDCValidator *XDCValidatorSession) Vote(_candidate common.Address) (*types.Transaction, error) { - return _XDCValidator.Contract.Vote(&_XDCValidator.TransactOpts, _candidate) +// Solidity: function vote(address _candidate) returns() +func (_Kyc *KycSession) Vote(_candidate common.Address) (*types.Transaction, error) { + return _Kyc.Contract.Vote(&_Kyc.TransactOpts, _candidate) } // Vote is a paid mutator transaction binding the contract method 0x6dd7d8ea. // -// Solidity: function vote(_candidate address) returns() -func (_XDCValidator *XDCValidatorTransactorSession) Vote(_candidate common.Address) (*types.Transaction, error) { - return _XDCValidator.Contract.Vote(&_XDCValidator.TransactOpts, _candidate) -} - -// VoteInvalidKYC is a paid mutator transaction binding the contract method 0xf2ee3c7d. -// -// Solidity: function voteInvalidKYC(_invalidCandidate address) returns() -func (_XDCValidator *XDCValidatorTransactor) VoteInvalidKYC(opts *bind.TransactOpts, _invalidCandidate common.Address) (*types.Transaction, error) { - return _XDCValidator.contract.Transact(opts, "voteInvalidKYC", _invalidCandidate) -} - -// VoteInvalidKYC is a paid mutator transaction binding the contract method 0xf2ee3c7d. -// -// Solidity: function voteInvalidKYC(_invalidCandidate address) returns() -func (_XDCValidator *XDCValidatorSession) VoteInvalidKYC(_invalidCandidate common.Address) (*types.Transaction, error) { - return _XDCValidator.Contract.VoteInvalidKYC(&_XDCValidator.TransactOpts, _invalidCandidate) -} - -// VoteInvalidKYC is a paid mutator transaction binding the contract method 0xf2ee3c7d. -// -// Solidity: function voteInvalidKYC(_invalidCandidate address) returns() -func (_XDCValidator *XDCValidatorTransactorSession) VoteInvalidKYC(_invalidCandidate common.Address) (*types.Transaction, error) { - return _XDCValidator.Contract.VoteInvalidKYC(&_XDCValidator.TransactOpts, _invalidCandidate) +// Solidity: function vote(address _candidate) returns() +func (_Kyc *KycTransactorSession) Vote(_candidate common.Address) (*types.Transaction, error) { + return _Kyc.Contract.Vote(&_Kyc.TransactOpts, _candidate) } // Withdraw is a paid mutator transaction binding the contract method 0x441a3e70. // -// Solidity: function withdraw(_blockNumber uint256, _index uint256) returns() -func (_XDCValidator *XDCValidatorTransactor) Withdraw(opts *bind.TransactOpts, _blockNumber *big.Int, _index *big.Int) (*types.Transaction, error) { - return _XDCValidator.contract.Transact(opts, "withdraw", _blockNumber, _index) +// Solidity: function withdraw(uint256 _blockNumber, uint256 _index) returns() +func (_Kyc *KycTransactor) Withdraw(opts *bind.TransactOpts, _blockNumber *big.Int, _index *big.Int) (*types.Transaction, error) { + return _Kyc.contract.Transact(opts, "withdraw", _blockNumber, _index) } // Withdraw is a paid mutator transaction binding the contract method 0x441a3e70. // -// Solidity: function withdraw(_blockNumber uint256, _index uint256) returns() -func (_XDCValidator *XDCValidatorSession) Withdraw(_blockNumber *big.Int, _index *big.Int) (*types.Transaction, error) { - return _XDCValidator.Contract.Withdraw(&_XDCValidator.TransactOpts, _blockNumber, _index) +// Solidity: function withdraw(uint256 _blockNumber, uint256 _index) returns() +func (_Kyc *KycSession) Withdraw(_blockNumber *big.Int, _index *big.Int) (*types.Transaction, error) { + return _Kyc.Contract.Withdraw(&_Kyc.TransactOpts, _blockNumber, _index) } // Withdraw is a paid mutator transaction binding the contract method 0x441a3e70. // -// Solidity: function withdraw(_blockNumber uint256, _index uint256) returns() -func (_XDCValidator *XDCValidatorTransactorSession) Withdraw(_blockNumber *big.Int, _index *big.Int) (*types.Transaction, error) { - return _XDCValidator.Contract.Withdraw(&_XDCValidator.TransactOpts, _blockNumber, _index) +// Solidity: function withdraw(uint256 _blockNumber, uint256 _index) returns() +func (_Kyc *KycTransactorSession) Withdraw(_blockNumber *big.Int, _index *big.Int) (*types.Transaction, error) { + return _Kyc.Contract.Withdraw(&_Kyc.TransactOpts, _blockNumber, _index) } -// XDCValidatorProposeIterator is returned from FilterPropose and is used to iterate over the raw logs and unpacked data for Propose events raised by the XDCValidator contract. -type XDCValidatorProposeIterator struct { - Event *XDCValidatorPropose // Event containing the contract specifics and raw log +// KycProposeIterator is returned from FilterPropose and is used to iterate over the raw logs and unpacked data for Propose events raised by the Kyc contract. +type KycProposeIterator struct { + Event *KycPropose // 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 @@ -1096,7 +907,7 @@ type XDCValidatorProposeIterator struct { // 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 *XDCValidatorProposeIterator) Next() bool { +func (it *KycProposeIterator) Next() bool { // If the iterator failed, stop iterating if it.fail != nil { return false @@ -1105,7 +916,7 @@ func (it *XDCValidatorProposeIterator) Next() bool { if it.done { select { case log := <-it.logs: - it.Event = new(XDCValidatorPropose) + it.Event = new(KycPropose) if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil { it.fail = err return false @@ -1120,7 +931,7 @@ func (it *XDCValidatorProposeIterator) Next() bool { // Iterator still in progress, wait for either a data or an error event select { case log := <-it.logs: - it.Event = new(XDCValidatorPropose) + it.Event = new(KycPropose) if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil { it.fail = err return false @@ -1136,19 +947,19 @@ func (it *XDCValidatorProposeIterator) Next() bool { } // Error returns any retrieval or parsing error occurred during filtering. -func (it *XDCValidatorProposeIterator) Error() error { +func (it *KycProposeIterator) Error() error { return it.fail } // Close terminates the iteration process, releasing any pending underlying // resources. -func (it *XDCValidatorProposeIterator) Close() error { +func (it *KycProposeIterator) Close() error { it.sub.Unsubscribe() return nil } -// XDCValidatorPropose represents a Propose event raised by the XDCValidator contract. -type XDCValidatorPropose struct { +// KycPropose represents a Propose event raised by the Kyc contract. +type KycPropose struct { Owner common.Address Candidate common.Address Cap *big.Int @@ -1157,22 +968,22 @@ type XDCValidatorPropose struct { // FilterPropose is a free log retrieval operation binding the contract event 0x7635f1d87b47fba9f2b09e56eb4be75cca030e0cb179c1602ac9261d39a8f5c1. // -// Solidity: event Propose(_owner address, _candidate address, _cap uint256) -func (_XDCValidator *XDCValidatorFilterer) FilterPropose(opts *bind.FilterOpts) (*XDCValidatorProposeIterator, error) { +// Solidity: event Propose(address _owner, address _candidate, uint256 _cap) +func (_Kyc *KycFilterer) FilterPropose(opts *bind.FilterOpts) (*KycProposeIterator, error) { - logs, sub, err := _XDCValidator.contract.FilterLogs(opts, "Propose") + logs, sub, err := _Kyc.contract.FilterLogs(opts, "Propose") if err != nil { return nil, err } - return &XDCValidatorProposeIterator{contract: _XDCValidator.contract, event: "Propose", logs: logs, sub: sub}, nil + return &KycProposeIterator{contract: _Kyc.contract, event: "Propose", logs: logs, sub: sub}, nil } // WatchPropose is a free log subscription operation binding the contract event 0x7635f1d87b47fba9f2b09e56eb4be75cca030e0cb179c1602ac9261d39a8f5c1. // -// Solidity: event Propose(_owner address, _candidate address, _cap uint256) -func (_XDCValidator *XDCValidatorFilterer) WatchPropose(opts *bind.WatchOpts, sink chan<- *XDCValidatorPropose) (event.Subscription, error) { +// Solidity: event Propose(address _owner, address _candidate, uint256 _cap) +func (_Kyc *KycFilterer) WatchPropose(opts *bind.WatchOpts, sink chan<- *KycPropose) (event.Subscription, error) { - logs, sub, err := _XDCValidator.contract.WatchLogs(opts, "Propose") + logs, sub, err := _Kyc.contract.WatchLogs(opts, "Propose") if err != nil { return nil, err } @@ -1182,8 +993,8 @@ func (_XDCValidator *XDCValidatorFilterer) WatchPropose(opts *bind.WatchOpts, si select { case log := <-logs: // New log arrived, parse the event and forward to the user - event := new(XDCValidatorPropose) - if err := _XDCValidator.contract.UnpackLog(event, "Propose", log); err != nil { + event := new(KycPropose) + if err := _Kyc.contract.UnpackLog(event, "Propose", log); err != nil { return err } event.Raw = log @@ -1204,9 +1015,9 @@ func (_XDCValidator *XDCValidatorFilterer) WatchPropose(opts *bind.WatchOpts, si }), nil } -// XDCValidatorResignIterator is returned from FilterResign and is used to iterate over the raw logs and unpacked data for Resign events raised by the XDCValidator contract. -type XDCValidatorResignIterator struct { - Event *XDCValidatorResign // Event containing the contract specifics and raw log +// KycResignIterator is returned from FilterResign and is used to iterate over the raw logs and unpacked data for Resign events raised by the Kyc contract. +type KycResignIterator struct { + Event *KycResign // 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 @@ -1220,7 +1031,7 @@ type XDCValidatorResignIterator struct { // 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 *XDCValidatorResignIterator) Next() bool { +func (it *KycResignIterator) Next() bool { // If the iterator failed, stop iterating if it.fail != nil { return false @@ -1229,7 +1040,7 @@ func (it *XDCValidatorResignIterator) Next() bool { if it.done { select { case log := <-it.logs: - it.Event = new(XDCValidatorResign) + it.Event = new(KycResign) if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil { it.fail = err return false @@ -1244,7 +1055,7 @@ func (it *XDCValidatorResignIterator) Next() bool { // Iterator still in progress, wait for either a data or an error event select { case log := <-it.logs: - it.Event = new(XDCValidatorResign) + it.Event = new(KycResign) if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil { it.fail = err return false @@ -1260,19 +1071,19 @@ func (it *XDCValidatorResignIterator) Next() bool { } // Error returns any retrieval or parsing error occurred during filtering. -func (it *XDCValidatorResignIterator) Error() error { +func (it *KycResignIterator) Error() error { return it.fail } // Close terminates the iteration process, releasing any pending underlying // resources. -func (it *XDCValidatorResignIterator) Close() error { +func (it *KycResignIterator) Close() error { it.sub.Unsubscribe() return nil } -// XDCValidatorResign represents a Resign event raised by the XDCValidator contract. -type XDCValidatorResign struct { +// KycResign represents a Resign event raised by the Kyc contract. +type KycResign struct { Owner common.Address Candidate common.Address Raw types.Log // Blockchain specific contextual infos @@ -1280,22 +1091,22 @@ type XDCValidatorResign struct { // FilterResign is a free log retrieval operation binding the contract event 0x4edf3e325d0063213a39f9085522994a1c44bea5f39e7d63ef61260a1e58c6d3. // -// Solidity: event Resign(_owner address, _candidate address) -func (_XDCValidator *XDCValidatorFilterer) FilterResign(opts *bind.FilterOpts) (*XDCValidatorResignIterator, error) { +// Solidity: event Resign(address _owner, address _candidate) +func (_Kyc *KycFilterer) FilterResign(opts *bind.FilterOpts) (*KycResignIterator, error) { - logs, sub, err := _XDCValidator.contract.FilterLogs(opts, "Resign") + logs, sub, err := _Kyc.contract.FilterLogs(opts, "Resign") if err != nil { return nil, err } - return &XDCValidatorResignIterator{contract: _XDCValidator.contract, event: "Resign", logs: logs, sub: sub}, nil + return &KycResignIterator{contract: _Kyc.contract, event: "Resign", logs: logs, sub: sub}, nil } // WatchResign is a free log subscription operation binding the contract event 0x4edf3e325d0063213a39f9085522994a1c44bea5f39e7d63ef61260a1e58c6d3. // -// Solidity: event Resign(_owner address, _candidate address) -func (_XDCValidator *XDCValidatorFilterer) WatchResign(opts *bind.WatchOpts, sink chan<- *XDCValidatorResign) (event.Subscription, error) { +// Solidity: event Resign(address _owner, address _candidate) +func (_Kyc *KycFilterer) WatchResign(opts *bind.WatchOpts, sink chan<- *KycResign) (event.Subscription, error) { - logs, sub, err := _XDCValidator.contract.WatchLogs(opts, "Resign") + logs, sub, err := _Kyc.contract.WatchLogs(opts, "Resign") if err != nil { return nil, err } @@ -1305,8 +1116,8 @@ func (_XDCValidator *XDCValidatorFilterer) WatchResign(opts *bind.WatchOpts, sin select { case log := <-logs: // New log arrived, parse the event and forward to the user - event := new(XDCValidatorResign) - if err := _XDCValidator.contract.UnpackLog(event, "Resign", log); err != nil { + event := new(KycResign) + if err := _Kyc.contract.UnpackLog(event, "Resign", log); err != nil { return err } event.Raw = log @@ -1327,9 +1138,9 @@ func (_XDCValidator *XDCValidatorFilterer) WatchResign(opts *bind.WatchOpts, sin }), nil } -// XDCValidatorUnvoteIterator is returned from FilterUnvote and is used to iterate over the raw logs and unpacked data for Unvote events raised by the XDCValidator contract. -type XDCValidatorUnvoteIterator struct { - Event *XDCValidatorUnvote // Event containing the contract specifics and raw log +// KycUnvoteIterator is returned from FilterUnvote and is used to iterate over the raw logs and unpacked data for Unvote events raised by the Kyc contract. +type KycUnvoteIterator struct { + Event *KycUnvote // 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 @@ -1343,7 +1154,7 @@ type XDCValidatorUnvoteIterator struct { // 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 *XDCValidatorUnvoteIterator) Next() bool { +func (it *KycUnvoteIterator) Next() bool { // If the iterator failed, stop iterating if it.fail != nil { return false @@ -1352,7 +1163,7 @@ func (it *XDCValidatorUnvoteIterator) Next() bool { if it.done { select { case log := <-it.logs: - it.Event = new(XDCValidatorUnvote) + it.Event = new(KycUnvote) if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil { it.fail = err return false @@ -1367,7 +1178,7 @@ func (it *XDCValidatorUnvoteIterator) Next() bool { // Iterator still in progress, wait for either a data or an error event select { case log := <-it.logs: - it.Event = new(XDCValidatorUnvote) + it.Event = new(KycUnvote) if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil { it.fail = err return false @@ -1383,19 +1194,19 @@ func (it *XDCValidatorUnvoteIterator) Next() bool { } // Error returns any retrieval or parsing error occurred during filtering. -func (it *XDCValidatorUnvoteIterator) Error() error { +func (it *KycUnvoteIterator) Error() error { return it.fail } // Close terminates the iteration process, releasing any pending underlying // resources. -func (it *XDCValidatorUnvoteIterator) Close() error { +func (it *KycUnvoteIterator) Close() error { it.sub.Unsubscribe() return nil } -// XDCValidatorUnvote represents a Unvote event raised by the XDCValidator contract. -type XDCValidatorUnvote struct { +// KycUnvote represents a Unvote event raised by the Kyc contract. +type KycUnvote struct { Voter common.Address Candidate common.Address Cap *big.Int @@ -1404,22 +1215,22 @@ type XDCValidatorUnvote struct { // FilterUnvote is a free log retrieval operation binding the contract event 0xaa0e554f781c3c3b2be110a0557f260f11af9a8aa2c64bc1e7a31dbb21e32fa2. // -// Solidity: event Unvote(_voter address, _candidate address, _cap uint256) -func (_XDCValidator *XDCValidatorFilterer) FilterUnvote(opts *bind.FilterOpts) (*XDCValidatorUnvoteIterator, error) { +// Solidity: event Unvote(address _voter, address _candidate, uint256 _cap) +func (_Kyc *KycFilterer) FilterUnvote(opts *bind.FilterOpts) (*KycUnvoteIterator, error) { - logs, sub, err := _XDCValidator.contract.FilterLogs(opts, "Unvote") + logs, sub, err := _Kyc.contract.FilterLogs(opts, "Unvote") if err != nil { return nil, err } - return &XDCValidatorUnvoteIterator{contract: _XDCValidator.contract, event: "Unvote", logs: logs, sub: sub}, nil + return &KycUnvoteIterator{contract: _Kyc.contract, event: "Unvote", logs: logs, sub: sub}, nil } // WatchUnvote is a free log subscription operation binding the contract event 0xaa0e554f781c3c3b2be110a0557f260f11af9a8aa2c64bc1e7a31dbb21e32fa2. // -// Solidity: event Unvote(_voter address, _candidate address, _cap uint256) -func (_XDCValidator *XDCValidatorFilterer) WatchUnvote(opts *bind.WatchOpts, sink chan<- *XDCValidatorUnvote) (event.Subscription, error) { +// Solidity: event Unvote(address _voter, address _candidate, uint256 _cap) +func (_Kyc *KycFilterer) WatchUnvote(opts *bind.WatchOpts, sink chan<- *KycUnvote) (event.Subscription, error) { - logs, sub, err := _XDCValidator.contract.WatchLogs(opts, "Unvote") + logs, sub, err := _Kyc.contract.WatchLogs(opts, "Unvote") if err != nil { return nil, err } @@ -1429,8 +1240,8 @@ func (_XDCValidator *XDCValidatorFilterer) WatchUnvote(opts *bind.WatchOpts, sin select { case log := <-logs: // New log arrived, parse the event and forward to the user - event := new(XDCValidatorUnvote) - if err := _XDCValidator.contract.UnpackLog(event, "Unvote", log); err != nil { + event := new(KycUnvote) + if err := _Kyc.contract.UnpackLog(event, "Unvote", log); err != nil { return err } event.Raw = log @@ -1451,9 +1262,9 @@ func (_XDCValidator *XDCValidatorFilterer) WatchUnvote(opts *bind.WatchOpts, sin }), nil } -// XDCValidatorVoteIterator is returned from FilterVote and is used to iterate over the raw logs and unpacked data for Vote events raised by the XDCValidator contract. -type XDCValidatorVoteIterator struct { - Event *XDCValidatorVote // Event containing the contract specifics and raw log +// KycVoteIterator is returned from FilterVote and is used to iterate over the raw logs and unpacked data for Vote events raised by the Kyc contract. +type KycVoteIterator struct { + Event *KycVote // 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 @@ -1467,7 +1278,7 @@ type XDCValidatorVoteIterator struct { // 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 *XDCValidatorVoteIterator) Next() bool { +func (it *KycVoteIterator) Next() bool { // If the iterator failed, stop iterating if it.fail != nil { return false @@ -1476,7 +1287,7 @@ func (it *XDCValidatorVoteIterator) Next() bool { if it.done { select { case log := <-it.logs: - it.Event = new(XDCValidatorVote) + it.Event = new(KycVote) if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil { it.fail = err return false @@ -1491,7 +1302,7 @@ func (it *XDCValidatorVoteIterator) Next() bool { // Iterator still in progress, wait for either a data or an error event select { case log := <-it.logs: - it.Event = new(XDCValidatorVote) + it.Event = new(KycVote) if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil { it.fail = err return false @@ -1507,19 +1318,19 @@ func (it *XDCValidatorVoteIterator) Next() bool { } // Error returns any retrieval or parsing error occurred during filtering. -func (it *XDCValidatorVoteIterator) Error() error { +func (it *KycVoteIterator) Error() error { return it.fail } // Close terminates the iteration process, releasing any pending underlying // resources. -func (it *XDCValidatorVoteIterator) Close() error { +func (it *KycVoteIterator) Close() error { it.sub.Unsubscribe() return nil } -// XDCValidatorVote represents a Vote event raised by the XDCValidator contract. -type XDCValidatorVote struct { +// KycVote represents a Vote event raised by the Kyc contract. +type KycVote struct { Voter common.Address Candidate common.Address Cap *big.Int @@ -1528,22 +1339,22 @@ type XDCValidatorVote struct { // FilterVote is a free log retrieval operation binding the contract event 0x66a9138482c99e9baf08860110ef332cc0c23b4a199a53593d8db0fc8f96fbfc. // -// Solidity: event Vote(_voter address, _candidate address, _cap uint256) -func (_XDCValidator *XDCValidatorFilterer) FilterVote(opts *bind.FilterOpts) (*XDCValidatorVoteIterator, error) { +// Solidity: event Vote(address _voter, address _candidate, uint256 _cap) +func (_Kyc *KycFilterer) FilterVote(opts *bind.FilterOpts) (*KycVoteIterator, error) { - logs, sub, err := _XDCValidator.contract.FilterLogs(opts, "Vote") + logs, sub, err := _Kyc.contract.FilterLogs(opts, "Vote") if err != nil { return nil, err } - return &XDCValidatorVoteIterator{contract: _XDCValidator.contract, event: "Vote", logs: logs, sub: sub}, nil + return &KycVoteIterator{contract: _Kyc.contract, event: "Vote", logs: logs, sub: sub}, nil } // WatchVote is a free log subscription operation binding the contract event 0x66a9138482c99e9baf08860110ef332cc0c23b4a199a53593d8db0fc8f96fbfc. // -// Solidity: event Vote(_voter address, _candidate address, _cap uint256) -func (_XDCValidator *XDCValidatorFilterer) WatchVote(opts *bind.WatchOpts, sink chan<- *XDCValidatorVote) (event.Subscription, error) { +// Solidity: event Vote(address _voter, address _candidate, uint256 _cap) +func (_Kyc *KycFilterer) WatchVote(opts *bind.WatchOpts, sink chan<- *KycVote) (event.Subscription, error) { - logs, sub, err := _XDCValidator.contract.WatchLogs(opts, "Vote") + logs, sub, err := _Kyc.contract.WatchLogs(opts, "Vote") if err != nil { return nil, err } @@ -1553,8 +1364,8 @@ func (_XDCValidator *XDCValidatorFilterer) WatchVote(opts *bind.WatchOpts, sink select { case log := <-logs: // New log arrived, parse the event and forward to the user - event := new(XDCValidatorVote) - if err := _XDCValidator.contract.UnpackLog(event, "Vote", log); err != nil { + event := new(KycVote) + if err := _Kyc.contract.UnpackLog(event, "Vote", log); err != nil { return err } event.Raw = log @@ -1575,9 +1386,9 @@ func (_XDCValidator *XDCValidatorFilterer) WatchVote(opts *bind.WatchOpts, sink }), nil } -// XDCValidatorWithdrawIterator is returned from FilterWithdraw and is used to iterate over the raw logs and unpacked data for Withdraw events raised by the XDCValidator contract. -type XDCValidatorWithdrawIterator struct { - Event *XDCValidatorWithdraw // Event containing the contract specifics and raw log +// KycWithdrawIterator is returned from FilterWithdraw and is used to iterate over the raw logs and unpacked data for Withdraw events raised by the Kyc contract. +type KycWithdrawIterator struct { + Event *KycWithdraw // 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 @@ -1591,7 +1402,7 @@ type XDCValidatorWithdrawIterator struct { // 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 *XDCValidatorWithdrawIterator) Next() bool { +func (it *KycWithdrawIterator) Next() bool { // If the iterator failed, stop iterating if it.fail != nil { return false @@ -1600,7 +1411,7 @@ func (it *XDCValidatorWithdrawIterator) Next() bool { if it.done { select { case log := <-it.logs: - it.Event = new(XDCValidatorWithdraw) + it.Event = new(KycWithdraw) if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil { it.fail = err return false @@ -1615,7 +1426,7 @@ func (it *XDCValidatorWithdrawIterator) Next() bool { // Iterator still in progress, wait for either a data or an error event select { case log := <-it.logs: - it.Event = new(XDCValidatorWithdraw) + it.Event = new(KycWithdraw) if err := it.contract.UnpackLog(it.Event, it.event, log); err != nil { it.fail = err return false @@ -1631,19 +1442,19 @@ func (it *XDCValidatorWithdrawIterator) Next() bool { } // Error returns any retrieval or parsing error occurred during filtering. -func (it *XDCValidatorWithdrawIterator) Error() error { +func (it *KycWithdrawIterator) Error() error { return it.fail } // Close terminates the iteration process, releasing any pending underlying // resources. -func (it *XDCValidatorWithdrawIterator) Close() error { +func (it *KycWithdrawIterator) Close() error { it.sub.Unsubscribe() return nil } -// XDCValidatorWithdraw represents a Withdraw event raised by the XDCValidator contract. -type XDCValidatorWithdraw struct { +// KycWithdraw represents a Withdraw event raised by the Kyc contract. +type KycWithdraw struct { Owner common.Address BlockNumber *big.Int Cap *big.Int @@ -1652,22 +1463,22 @@ type XDCValidatorWithdraw struct { // FilterWithdraw is a free log retrieval operation binding the contract event 0xf279e6a1f5e320cca91135676d9cb6e44ca8a08c0b88342bcdb1144f6511b568. // -// Solidity: event Withdraw(_owner address, _blockNumber uint256, _cap uint256) -func (_XDCValidator *XDCValidatorFilterer) FilterWithdraw(opts *bind.FilterOpts) (*XDCValidatorWithdrawIterator, error) { +// Solidity: event Withdraw(address _owner, uint256 _blockNumber, uint256 _cap) +func (_Kyc *KycFilterer) FilterWithdraw(opts *bind.FilterOpts) (*KycWithdrawIterator, error) { - logs, sub, err := _XDCValidator.contract.FilterLogs(opts, "Withdraw") + logs, sub, err := _Kyc.contract.FilterLogs(opts, "Withdraw") if err != nil { return nil, err } - return &XDCValidatorWithdrawIterator{contract: _XDCValidator.contract, event: "Withdraw", logs: logs, sub: sub}, nil + return &KycWithdrawIterator{contract: _Kyc.contract, event: "Withdraw", logs: logs, sub: sub}, nil } // WatchWithdraw is a free log subscription operation binding the contract event 0xf279e6a1f5e320cca91135676d9cb6e44ca8a08c0b88342bcdb1144f6511b568. // -// Solidity: event Withdraw(_owner address, _blockNumber uint256, _cap uint256) -func (_XDCValidator *XDCValidatorFilterer) WatchWithdraw(opts *bind.WatchOpts, sink chan<- *XDCValidatorWithdraw) (event.Subscription, error) { +// Solidity: event Withdraw(address _owner, uint256 _blockNumber, uint256 _cap) +func (_Kyc *KycFilterer) WatchWithdraw(opts *bind.WatchOpts, sink chan<- *KycWithdraw) (event.Subscription, error) { - logs, sub, err := _XDCValidator.contract.WatchLogs(opts, "Withdraw") + logs, sub, err := _Kyc.contract.WatchLogs(opts, "Withdraw") if err != nil { return nil, err } @@ -1677,8 +1488,8 @@ func (_XDCValidator *XDCValidatorFilterer) WatchWithdraw(opts *bind.WatchOpts, s select { case log := <-logs: // New log arrived, parse the event and forward to the user - event := new(XDCValidatorWithdraw) - if err := _XDCValidator.contract.UnpackLog(event, "Withdraw", log); err != nil { + event := new(KycWithdraw) + if err := _Kyc.contract.UnpackLog(event, "Withdraw", log); err != nil { return err } event.Raw = log