简体   繁体   中英

Events handler in Ethers.js

I'm using https://github.com/ethers-io/ethers.js/ I have The following smart contract,

contract WhiteList {

   event logAddressChange(address indexed purchaser, uint256 value, uint256 amount);

   function changeContractAddress(address _purchaser, uint256 _whitelistCap)
        public
        returns (bool)
    {

        logAddressChange(_purchaser, _whitelistCap, _whitelistCap);
        return true;
    }

}

I'm trying to develop a node js listener for logAddressChange event. I want to listen to that event only.

my node server js

app.listen(port, function() {
    homeController.check_health();
});

My node js controller

var config = require('config');
var ethers = require('ethers');
var providers = require('ethers').providers;
var network = providers.networks.rinkeby;
var infuraProvider = new providers.InfuraProvider(network);
var etherscanProvider = new providers.EtherscanProvider(network);
var fallbackProvider = new providers.FallbackProvider([
    infuraProvider,
    etherscanProvider
]);
var provider = providers.getDefaultProvider(network)
var contract_provider = config.get('contract_provider');
var contract_address = config.get('contract_address');
var contract_abi = config.get('contract_abi');
var account_private_key = config.get('account_private_key');
var account_address = config.get('account_address');
var crm_url = config.get('crm_url');
var wallet = new ethers.Wallet(account_private_key, provider);
var contract = new ethers.Contract(contract_address, contract_abi, wallet);
var provider_contract = new ethers.Contract(contract_address, contract_abi, provider);
var overrideOptions = {
    gasLimit: 250000,
    nonce: 0,
    value: ethers.utils.parseEther('1.0')
};
exports.check_health = function(req, res) {
  console.log('started event');
  contract.events.onlogAddressChange = function(purchaser, value, amount) {
    console.log('started event1');
      console.log("purchaser:" + purchaser);
      console.log("value:" + value);
      console.log("amount:" + amount);
  };
}; 

I have waited for longer than an hour after triggering the event and still nothing.

I do not know what I'm doing wrong.

Can you please help?

So it turned out I missed something in the doc.

The event watcher has to be all lower case even if function is CamelCase:

Only change needed is instead of onlogAddressChange I should have onlogaddresschange

exports.check_health = function(req, res) {
  console.log('started event');
  contract.events.onlogaddresschange = function(purchaser, value, amount) {
    console.log('started event1');
      console.log("purchaser:" + purchaser);
      console.log("value:" + value);
      console.log("amount:" + amount);
  };
};

Thanks

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM