Hey @dan-i
I am receiving the following error after sending 0.5 ETH transaction through my created Dapp…
inpage.js:1 MetaMask - RPC Error: Error: [ethjs-query] while formatting outputs from RPC '{"value":{"code":-32603,"data":{"message":"the tx doesn't have the correct nonce. account has nonce of: 14 tx has nonce of: 20","code":-32000,"data":{"stack":"Error: \n at validateNonce (/Volumes/Ganache 2.1.1/Ganache.app/Contents/Resources/app.asar/node_modules/ganache-core/lib/statemanager.js:964:11)\n at blockchain.getQueuedNonce (/Volumes/Ganache 2.1.1/Ganache.app/Contents/Resources/app.asar/node_modules/ganache-core/lib/statemanager.js:973:7)\n at /Volumes/Ganache 2.1.1/Ganache.app/Contents/Resources/app.asar/node_modules/ganache-core/lib/blockchain_double.js:436:5\n at /Volumes/Ganache 2.1.1/Ganache.app/Contents/Resources/app.asar/node_modules/ganache-core/node_modules/merkle-patricia-tree/baseTrie.js:77:5\n at /Volumes/Ganache 2.1.1/Ganache.app/Contents/Resources/app.asar/node_modules/ganache-core/node_modules/merkle-patricia-tree/baseTrie.js:461:14\n at Object.return (/Volumes/Ganache 2.1.1/Ganache.app/Contents/Resources/app.asar/node_modules/ganache-core/node_modules/merkle-patricia-tree/baseTrie.js:485:9)\n at processNode (/Volumes/Ganache 2.1.1/Ganache.app/Contents/Resources/app.asar/node_modules/ganache-core/node_modules/merkle-patricia-tree/baseTrie.js:285:30)\n at processNode (/Volumes/Ganache 2.1.1/Ganache.app/Contents/Resources/app.asar/node_modules/ganache-core/node_modules/merkle-patricia-tree/baseTrie.js:521:5)\n at /Volumes/Ganache 2.1.1/Ganache.app/Contents/Resources/app.asar/node_modules/ganache-core/node_modules/merkle-patricia-tree/baseTrie.js:516:13\n at /Volumes/Ganache 2.1.1/Ganache.app/Contents/Resources/app.asar/node_modules/ganache-core/node_modules/merkle-patricia-tree/baseTrie.js:180:7\n at _combinedTickCallback (internal/process/next_tick.js:131:7)\n at process._tickCallback (internal/process/next_tick.js:180:9)","name":"TXRejectedError"}}}}' {code: -32603, message: "Error: [ethjs-query] while formatting outputs from…ext_tick.js:180:9)","name":"TXRejectedError"}}}}'"}
(anonymous) @ inpage.js:1
(anonymous) @ inpage.js:1
_runReturnHandlers @ inpage.js:1
_processRequest @ inpage.js:1
async function (async)
_processRequest @ inpage.js:1
_handle @ inpage.js:1
handle @ inpage.js:1
_rpcRequest @ inpage.js:1
sendAsync @ inpage.js:1
s.send @ web3.min.js:1
n @ web3.min.js:1
(anonymous) @ web3.min.js:1
u @ web3.min.js:1
(anonymous) @ web3.min.js:1
(anonymous) @ inpage.js:1
Promise.finally (async)
_handle @ inpage.js:1
handle @ inpage.js:1
_rpcRequest @ inpage.js:1
sendAsync @ inpage.js:1
s.send @ web3.min.js:1
n @ web3.min.js:1
t @ web3.min.js:1
t @ web3.min.js:1
o._executeMethod @ web3.min.js:1
(anonymous) @ main.js:24
dispatch @ jquery-3.4.1.min.js:2
v.handle @ jquery-3.4.1.min.js:2
web3.min.js:1 Uncaught (in promise) {code: -32603, message: "Error: [ethjs-query] while formatting outputs from…ext_tick.js:180:9)","name":"TXRejectedError"}}}}'"}
(anonymous) @ web3.min.js:1
setTimeout (async)
_fireError @ web3.min.js:1
u @ web3.min.js:1
(anonymous) @ web3.min.js:1
(anonymous) @ inpage.js:1
Promise.finally (async)
_handle @ inpage.js:1
handle @ inpage.js:1
_rpcRequest @ inpage.js:1
sendAsync @ inpage.js:1
s.send @ web3.min.js:1
n @ web3.min.js:1
(anonymous) @ web3.min.js:1
u @ web3.min.js:1
(anonymous) @ web3.min.js:1
(anonymous) @ inpage.js:1
Promise.finally (async)
_handle @ inpage.js:1
handle @ inpage.js:1
_rpcRequest @ inpage.js:1
sendAsync @ inpage.js:1
s.send @ web3.min.js:1
n @ web3.min.js:1
t @ web3.min.js:1
t @ web3.min.js:1
o._executeMethod @ web3.min.js:1
(anonymous) @ main.js:24
dispatch @ jquery-3.4.1.min.js:2
v.handle @ jquery-3.4.1.min.js:2
This below is my Coinflip.sol code
ragma solidity 0.5.12;
contract Coinflip {
address public contractOwner;
constructor() public {
contractOwner = msg.sender;
}
modifier onlyOwner() {
require(msg.sender == contractOwner, "You are not the owner");
_;
}
uint public contractBalance;
address public contractAddress;
modifier costs(uint cost) {
require(msg.value >= cost, "Minimum amount >= 0.01 ether");
_;
}
event betPlaced(address user, uint bet, bool);
event contractFunded(address contractOwner, uint);
//Flip the Coin and check whether user won or lost;
function flipCoin() public payable costs(0.01 ether) returns(bool) {
require(address(this).balance >= msg.value, "The contract doesnt have enough balance to play right now. Come Back later");
bool success;
if (now % 2 == 0) {
contractBalance += msg.value;
success = false;
}
else if (now % 2 == 1){
contractBalance -= msg.value;
msg.sender.transfer(msg.value * 2);
success = true;
}
//event to be emitted
emit betPlaced(msg.sender, msg.value, success);
return success;
}
function getBalance() public view returns(address, uint, uint) {
return(address(this), address(this).balance, contractBalance);
}
// withdraw all funds possible only though contractOwner address;
function withdrawAll() public onlyOwner returns(uint){
msg.sender.transfer(address(this).balance);
assert(address(this).balance == 0);
return address(this).balance;
}
function fundContract() public payable onlyOwner returns(uint) {
require(msg.value != 0);
emit contractFunded(msg.sender, msg.value);
return msg.value;
}
}
and this below is my main.js.
var web3 = new Web3(Web3.givenProvider);
var contractInstance;
$(document).ready(function(){
window.ethereum.enable().then(function(accounts){
contractInstance = new web3.eth.Contract(abi, "0x340c4A19652675fFf90C25Ba3C711a5a499b86b3", {from : accounts[0]});
console.log(contractInstance);
});
var config1 = {
value : web3.utils.toWei("0.5", "ether")
}
var config2 = {
value : web3.utils.toWei("1", "ether")
}
var config3 = {
value : web3.utils.toWei("2", "ether")
}
$("#open-door1").click(function(){
contractInstance.methods.flipCoin().send(config1)
.on("transactionHash", function(hash){
console.log(hash);
})
.on("confirmation", function(confirmationNr){
console.log(confirmationNr);
})
.on("receipt", function(receipt){
console.log(receipt);
alert("Funds received!");
if(receipt.events.betPlaced.returnValues[2] === false){
alert("You lost " + " 0.5 Ether!");
}
else if(receipt.events.betPlaced.returnValues[2] === true){
alert("You won " + " 0.5 Ether!");
}
});
});
$("#open-door2").click(function(){
contractInstance.methods.flipCoin().send(config2)
.on("transactionHash", function(hash){
console.log(hash);
})
.on("confirmation", function(confirmationNr){
console.log(confirmationNr);
})
.on("receipt", function(receipt){
console.log(receipt);
alert("Funds received!");
if(receipt.events.betPlaced.returnValues[2] === false){
alert("You lost " + " 1 Ether!");
}
else if(receipt.events.betPlaced.returnValues[2] === true){
alert("You won " + " 1 Ether!");
}
})
});
$("#open-door3").click(function(){
contractInstance.methods.flipCoin().send(config3)
.on("transactionHash", function(hash){
console.log(hash);
})
.on("confirmation", function(confirmationNr){
console.log(confirmationNr);
})
.on("receipt", function(receipt){
console.log(receipt);
if(receipt.events.betPlaced.returnValues[2] === false){
alert("You lost " + " 2 Ether!");
}
else if(receipt.events.betPlaced.returnValues[2] === true){
alert("You won " + " 2 Ether!");
}
})
});
});
and here below is my index.html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<title>FlipCoin</title>
<script src="https://code.jquery.com/jquery-3.4.1.min.js"
integrity="sha256-CSXorXvZcTkaix6Yvo6HppcZGetbYMGWSFlBw8HfCJo="
crossorigin="anonymous"></script>
<script type="text/javascript" src="./web3.min.js"></script>
<script type="text/javascript" src="./abi.js"></script>
<script type="text/javascript" src="./main.js"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.4.1/js/bootstrap.min.js" integrity="sha384-wfSDF2E50Y2D1uUdj0O3uMBJnjuUD4Ih7YwaYd1iqfktj0Uod8GCExl3Og8ifwB6" crossorigin="anonymous"></script>
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.4.1/css/bootstrap.min.css" integrity="sha384-Vkoo8x4CGsO3+Hhxv8T/Q5PaXtkKtu6ug5TOeNV6gBiFeWPGFN9MuhOf23Q9Ifjh" crossorigin="anonymous">
</head>
<body>
<div class="jumbotron jumbotron-fluid">
<div class="container">
<h1 class="display-4">CoinFlip Dapp - </h1><h2> Web3's Most Happening
"Fully Decentralized" Betting App</h2>
<img src = "" alt = "Ether Image">
<p class="lead">Win Double of What You Bet! </p>
</div>
</div>
<div class="container">
<div>
<h2>Now time to Bet</h2>
<button type="button" id="open-door1" class="btn btn-primary">0.5 ETH</button>
<button type="button" id="open-door2" class="btn btn-primary">1 ETH</button>
<button type="button" id="open-door3" class="btn btn-primary">2 ETH</button>
</div>
</div>
<div class="jumbotron jumbotron-fluid">
<div class="container">
<img src ="https://media2.giphy.com/media/g7GDZf4NXsIpi/giphy.gif?cid=ecf05e477r1ngzmvq4si8tucvi9wizdx3acymzcielzg3sis&rid=giphy.gif , alt = "Money Door">
</body>
</html>
Please can you inspect and let me know where I am going wrong and why Metamask is showing this error?
https://github.com/Suveett/coinFlip-Dapp.git
This is the full set of files on github
Thanks and regards
Su.Kal Crypto