Skip to main content

Build on Shibarium

Welcome aboard! Simply switch to the Shibarium RPC and kickstart your journey. All the familiar tools used on Ethereum are fully supported on Shibarium. Whether you're using Truffle, Remix, or Web3js, Shibarium offers the same user experience as Ethereum.

Connect your wallet and deploy any decentralized application to either the mainnet Shibarium or testnet Puppynet. Puppynet is connected to Ethereum Sepolia Testnet, which serves as its ParentChain, a testnet layer 1 (L1).

To illustrate how you can create, deploy and verify smart contracts on Shibarium, we have added two tutorials:

  • Deploy a smart contract with Remix
  • Deploy and verify a smart contract with Hardhat

Overview

Shibarium functions as a layer 2 (L2) network to Ethereum, employing a proof-of-stake (PoS) consensus mechanism, consisting of the following two layers;

  • Heimdall layer, a consensus layer that communicates with staking contracts deployed on the Ethereum mainnet and commits the Shibarium Network checkpoints to the Ethereum mainnet.
  • Bor layer, a Geth-based execution layer composed of a set of block-producing Bor nodes shuffled by Heimdall nodes.

Wallets

To interact with the Shibarium Network, you need an Ethereum-based wallet because Shibarium operates on the Ethereum Virtual Machine (EVM). Set up a Metamask or Arkane Wallet to get started.

Smart contracts

Shibarium supports various services for testing, compiling, debugging, and deploying decentralized applications onto the Shibarium Network. These include deployment using thirdweb, Remix, Truffle, Hardhat, and Replit.

Deploy a smart contract on Shibarium using Remix

Now that you know what Shibarium is, let's deploy a contract.

You will need some BONE tokens to deploy and interact with the smart contract, which you can acquire from the Shibarium faucet. Copy your Metamask address,paste it into the address field of the faucet, and click on submit. The faucet will send you 10 test BONE.

Writing the contract

Make a new solidity file using REMIX Ethereum, for example. Your new Solidity script should contain the following code:

// SPDX-License-Identifier: MIT
pragma solidity >=0.4.0 <0.7.0;
contract SimpleStorage {
uint storedData;
function set(uint x) public {
storedData = x;
}
function get() public view returns (uint) {
return storedData;
}
}
  • Line 1: Specifying SPDX license type, which is an addition after Solidity ^0.6.8. Whenever the source code of a smart contract is made available to the public, these licenses can help resolve/avoid copyright issues. If you do not wish to specify any license type, you can use a special license UNLICENSED or simply skip the whole comment (it won’t result in an error, just a warning).
  • Line 2: On the second line, we are declaring which Solidity compiler we want to use. For instance, we are targeting any version between 0.4.0 and 0.7.0.
  • Line 3: You declare your contract here and name it as SimpleStorage.
  • Line 4: Declaring a uint (Unsigned Integer) variable named storedData. This variable will be used to store data.
  • Line 5-7: Next, you will add a set function, used to change the value of the storeData variable. The set function accepts a parameter x whose value you are placing into storeData. In addition, the function is marked as public which means that the function can be called outside the scope of this function and by other contracts.
  • Line 8-10: You will add a get function to retrieve the value of storeData variable. This function is marked as view, which tells the Solidity compiler that this is a read-only function. Other than that, the get function also has returns (uint), which means that the function will return a uint value.

Deploying the contract

Click on the Solidity logo from the left menu and click on Compile. After successful compilation, a green tick will appear on the Solidity logo.

Now, click on the option from the left menu to deploy the complied contract and select Injected Web3 as the environment. Below the environment field, the name and Chain ID of your network will appear. Make sure you have the correct contract name selected under the contract option. Once you have checked everything, click on Deploy and accept the transaction from the MetaMask pop-up window.

Once the contract deployment transaction is approved, the deployed contract will appear under the Deployed Contracts section.

Expand the deployed contract and click on get. It will return the value of storedData, which is currently zero since you have not input any number yet.

To input a value, enter a number in the field near the set button, click on set and approve the transaction from the MetaMask pop-up. Once the transaction is approved, the value of storedData will be the input number. To verify this, click on get, and the previously input value will be printed.

This is how contracts are deployed on Shibarium with Remix!

Deploy and verify a smart contract with Hardhat

Prerequisites

  • Node.js: Make sure you have Node.js installed. You can download it from here.
  • Hardhat: Install Hardhat globally using npm:

npm install -g hardhat

  • Metamask Wallet: Set up a Metamask wallet if you don't have one. Add Shibarium's network to Metamask.

Set Up Hardhat Project

  1. Create a new directory for your project and navigate into it:

mkdir shibarium-smart-contract
cd shibarium-smart-contract

  1. Initialize a new Hardhat project:

npx hardhat

Follow the prompts to create a basic sample project.

  1. Install the necessary dependencies:

npm install --save-dev @nomiclabs/hardhat-ethers ethers

Write Your Smart Contract

  1. Create a new file in the contracts directory named SimpleStorage.sol:

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;

contract SimpleStorage {
uint256 private storedData;

function set(uint256 x) public {
storedData = x;
}

function get() public view returns (uint256) {
return storedData;
}
}

Configure Hardhat for Shibarium

  1. Open hardhat.config.js and add the following network configuration for Shibarium:

require("@nomiclabs/hardhat-ethers");

module.exports = {
solidity: "0.8.0",
networks: {
shibarium: {
url: "https://www.shibrpc.com", // Replace with Shibarium's RPC URL
accounts: [process.env.PRIVATE_KEY] // Use an environment variable to securely store your private key
}
}
};

  1. Create a .env file in the root of your project and add your private key:

PRIVATE_KEY=your_private_key_here

Write the Deployment Script

  1. Create a new file in the scripts directory named deploy.js:

async function main() {
const [deployer] = await ethers.getSigners();
console.log("Deploying contracts with the account:", deployer.address);

const SimpleStorage = await ethers.getContractFactory("SimpleStorage");
const simpleStorage = await SimpleStorage.deploy();

console.log("SimpleStorage deployed to:", simpleStorage.address);
}

main()
.then(() => process.exit(0))
.catch(error => {
console.error(error);
process.exit(1);
});

Deploy the Contract

  1. Run the deployment script:

npx hardhat run scripts/deploy.js --network shibarium

Verify the Contract on Shibarium

  1. Install the verification plugin:

npm install --save-dev @nomiclabs/hardhat-etherscan

  1. Update hardhat.config.js to include the Etherscan plugin and Shibarium's API key:

require("@nomiclabs/hardhat-ethers");
require("@nomiclabs/hardhat-etherscan");

module.exports = {
solidity: "0.8.0",
networks: {
shibarium: {
url: "https://www.shibrpc.com",
accounts: [process.env.PRIVATE_KEY]
}
},
etherscan: {
apiKey: {
shibarium: "shib",
},
customChains: [
{
network: "shibarium",
chainId: 109,
urls: {
apiURL: "https://www.shibariumscan.io/api/",
browserURL: "https://www.shibariumscan.io/"
}
},
]
},
};

  1. Verify your contract:

npx hardhat verify --network shibarium <DEPLOYED_CONTRACT_ADDRESS>

You have successfully deployed and verified a simple smart contract on Shibarium using Hardhat.