Skip to main content
Version: v0.50

Demo of Mitigating Front-Running with Vote Extensions

The purpose of this demo is to test the implementation of the VoteExtensionHandler and PrepareProposalHandler that we have just added to the codebase. These handlers are designed to mitigate front-running by ensuring that all validators have a consistent view of the mempool when preparing proposals.

In this demo, we are using a 3 validator network. The Beacon validator is special because it has a custom transaction provider enabled. This means that it can potentially manipulate the order of transactions in a proposal to its advantage (i.e., front-running).

  1. Bootstrap the validator network: This sets up a network with 3 validators. The script `./scripts/configure.sh is used to configure the network and the validators.
cd scripts
configure.sh

If this doesnt work please ensure you have run make build in the tutorials/nameservice/base directory.

  1. Have alice attempt to reserve bob.cosmos: This is a normal transaction that alice wants to execute. The script `./scripts/reserve.sh "bob.cosmos" is used to send this transaction.
bash reserve.sh "bob.cosmos"
  1. Query to verify the name has been reserved: This is to check the result of the transaction. The script ./scripts/whois.sh "bob.cosmos" is used to query the state of the blockchain.
bash whois.sh "bob.cosmos"

It should return:

  "name":  {
"name": "bob.cosmos",
"owner": "cosmos1nq9wuvuju4jdmpmzvxmg8zhhu2ma2y2l2pnu6w",
"resolve_address": "cosmos1h6zy2kn9efxtw5z22rc5k9qu7twl70z24kr3ht",
"amount": [
{
"denom": "uatom",
"amount": "1000"
}
]
}
}

To detect front-running attempts by the beacon, scrutinise the logs during the ProcessProposal stage. Open the logs for each validator, including the beacon, val1, and val2, to observe the following behavior. Open the log file of the validator node. The location of this file can vary depending on your setup, but it's typically located in a directory like $HOME/cosmos/nodes/#{validator}/logs. The directory in this case will be under the validator so, beacon val1 or val2. Run the following to tail the logs of the validator or beacon:

tail -f $HOME/cosmos/nodes/#{validator}/logs
2:47PM ERR ❌️:: Detected invalid proposal bid :: name:"bob.cosmos" resolveAddress:"cosmos1wmuwv38pdur63zw04t0c78r2a8dyt08hf9tpvd" owner:"cosmos1wmuwv38pdur63zw04t0c78r2a8dyt08hf9tpvd" amount:<denom:"uatom" amount:"2000" >  module=server
2:47PM ERR ❌️:: Unable to validate bids in Process Proposal :: <nil> module=server
2:47PM ERR prevote step: state machine rejected a proposed block; this should not happen:the proposer may be misbehaving; prevoting nil err=null height=142 module=consensus round=0
  1. List the Beacon's keys: This is to verify the addresses of the validators. The script ./scripts/list-beacon-keys.sh is used to list the keys.
bash list-beacon-keys.sh

We should receive something similar to the following:

[
{
"name": "alice",
"type": "local",
"address": "cosmos1h6zy2kn9efxtw5z22rc5k9qu7twl70z24kr3ht",
"pubkey": "{\"@type\":\"/cosmos.crypto.secp256k1.PubKey\",\"key\":\"A32cvBUkNJz+h2vld4A5BxvU5Rd+HyqpR3aGtvEhlm4C\"}"
},
{
"name": "barbara",
"type": "local",
"address": "cosmos1nq9wuvuju4jdmpmzvxmg8zhhu2ma2y2l2pnu6w",
"pubkey": "{\"@type\":\"/cosmos.crypto.secp256k1.PubKey\",\"key\":\"Ag9PFsNyTQPoJdbyCWia5rZH9CrvSrjMsk7Oz4L3rXQ5\"}"
},
{
"name": "beacon-key",
"type": "local",
"address": "cosmos1ez9a6x7lz4gvn27zr368muw8jeyas7sv84lfup",
"pubkey": "{\"@type\":\"/cosmos.crypto.secp256k1.PubKey\",\"key\":\"AlzJZMWyN7lass710TnAhyuFKAFIaANJyw5ad5P2kpcH\"}"
},
{
"name": "cindy",
"type": "local",
"address": "cosmos1m5j6za9w4qc2c5ljzxmm2v7a63mhjeag34pa3g",
"pubkey": "{\"@type\":\"/cosmos.crypto.secp256k1.PubKey\",\"key\":\"A6F1/3yot5OpyXoSkBbkyl+3rqBkxzRVSJfvSpm/AvW5\"}"
}
]

This allows us to match up the addresses and see that the bid was not front run by the beacon due as the resolve address is Alice's address and not the beacons address.

By running this demo, we can verify that the VoteExtensionHandler and PrepareProposalHandler are working as expected and that they are able to prevent front-running.

Conclusion

In this tutorial, we've tackled front-running and MEV, focusing on nameservice auctions' vulnerability to these issues. We've explored vote extensions, a key feature of ABCI 2.0, and integrated them into a Cosmos SDK application.

Through practical exercises, you've implemented vote extensions, and tested their effectiveness in creating a fair auction system. You've gained practical insights by configuring a validator network and analysing blockchain logs.

Keep experimenting with these concepts, engage with the community, and stay updated on new advancements. The knowledge you've acquired here is crucial for developing secure and fair blockchain applications.