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.