Use Hardhat
Developing for Besu using Hardhat is the same as developing for public Ethereum networks using Hardhat. Hardhat supports Besu with the only difference being Besu does not support private key management.
You can therefore use a wallet provider, or specify your private key in the code.
Private key management
Use an HD wallet
To add the wallet provider, update the hardhat.config.ts
file in the project directory. Replace:
<JSON-RPC-http-endpoint>
with the JSON-RPC endpoint (IP address and port) of a Besu node.<MY-ACCOUNT-MNEMONIC>
with the list of words that make up your account's mnemonic.<MY-PASSWORD
> with your password if used.<MY-ACCOUNT-PRIVATE-KEY>
with your account's private key.
module.exports = {
// See <https://hardhat.org/hardhat-runner/docs/config#hd-wallet-config>
// for more about customizing your Hardhat configuration!
networks: {
besuWallet: {
url: "<JSON-RPC-http-endpoint>",
accounts: {
mnemonic: "<ACCOUNT-MNEMONIC>",
path: "m/44'/60'/0'/0",
initialIndex: 0,
count: 1,
passphrase: "",
},
},
},
};
Specify your private key in code
danger
Ensure you do not commit private keys to source control like Github, always inject your keys at runtime as environment variables, or use a vault or similar.
const provider = new ethers.JsonRpcApiProvider(<JSON-RPC-http-endpoint>);
const wallet = new ethers.Wallet(<MY-ACCOUNT-PRIVATE-KEY>);
// connect the wallet to the provider
const signer = wallet.connect(provider);
Start a Besu node
Start a Besu node with JSON-RPC enabled on the endpoint specified in the Hardhat configuration file.
Deploy a contract
To deploy a contract onto the Besu network:
npx hardhat scripts run ./scripts/deploy_my_contract.ts --network besuWallet