There are various ways of deploying a smart contract to Klaytn. This document provides a step-by-step guide to deploy a sample contract using various tools. We assume that you have a Klaytn account with enough KLAY to pay the transaction fee. To create an account, please refer to Klaytn Wallet.
Copy and paste the following code (or any code you want to deploy).
pragma solidity 0.5.6;
contract Mortal {
/* Define variable owner of the type address */
address payable owner;
/* This function is executed at initialization and sets the owner of the contract */
constructor () public { owner = msg.sender; }
/* Function to recover the funds on the contract */
function kill() public payable { if (msg.sender == owner) selfdestruct(owner); }
}
contract KlaytnGreeter is Mortal {
/* Define variable greeting of the type string */
string greeting;
/* This runs when the contract is executed */
constructor (string memory _greeting) public {
greeting = _greeting;
}
/* Main function */
function greet() public view returns (string memory) {
return greeting;
}
}
Set compiler version. Currently, you can choose between 0.4.24 and 0.5.6. (Default is 0.5.6.)
Click Run tab. At Environment dropdown, you can choose a target network to deploy the contract. (Baobab is test network and Cypress is main network.)
After choosing a network, import account by clicking on the plus button next to Account. Make sure to import account that has enough KLAY to deploy the contract on the network.
Set Gas limit and Value to send.
You may need to set higher Gas limit if you are deploying a more complicated contract. In this example, you can leave it as it is.
Set Value to 0 unless you want to send KLAY to the contract at the time of deployment.
Enter "Hello World!" as an argument for constructor function and click on Deploy button. If everything goes successful, deployed contract's instance will show up below.
You can interact with the contract by clicking on the function buttons. Dark blue buttons are send functions which can change state on blockchain and consumes gas. Light blue buttons are call functions which do not change state and do not require gas fee.
Create KlaytnGreeter.sol under /contracts directory and copy the following code.
pragma solidity 0.5.6;
contract Mortal {
/* Define variable owner of the type address */
address payable owner;
/* This function is executed at initialization and sets the owner of the contract */
constructor () public { owner = msg.sender; }
/* Function to recover the funds on the contract */
function kill() public payable { if (msg.sender == owner) selfdestruct(owner); }
}
contract KlaytnGreeter is Mortal {
/* Define variable greeting of the type string */
string greeting;
/* This runs when the contract is executed */
constructor (string memory _greeting) public {
greeting = _greeting;
}
/* Main function */
function greet() public view returns (string memory) {
return greeting;
}
}
Modify /migrations/1_initial_migration.js as in the following.
vvisp is an easy-to-use CLI tool/framework for developing smart contracts, provided by HEACHI LABS. You can easily set environment, deploy and execute Klaytn smart contracts with a single command. Refer to the following link for more details.
Another way to deploy contracts is manually compiling contracts with solc and deploying them with caver-js.
Create KlaytnGreeter.sol and write the following code.
pragma solidity 0.5.6;
contract Mortal {
/* Define variable owner of the type address */
address payable owner;
/* This function is executed at initialization and sets the owner of the contract */
constructor () public { owner = msg.sender; }
/* Function to recover the funds on the contract */
function kill() public payable { if (msg.sender == owner) selfdestruct(owner); }
}
contract KlaytnGreeter is Mortal {
/* Define variable greeting of the type string */
string greeting;
/* This runs when the contract is executed */
constructor (string memory _greeting) public {
greeting = _greeting;
}
/* Main function */
function greet() public view returns (string memory) {
return greeting;
}
}
Install solc 0.5.6.
$ sudo npm install -g solc@0.5.6
Compile the contract.
$ solcjs KlaytnGreeter.sol --bin
Install caver-js.
$ npm install caver-js.
Create deploy.js in the same directory with the following code.