Stratis platform is a blockchain platform for software developers and architects who want to build new blockchain applications or want to integrate Stratis blockchain in their existing applications.
Stratis blockchain is open source and supports templates for Visual Studio to build blockchain solutions using C# and .NET. Stratis provides different products like Full Node, Smart Contract, Sidechains, Identity, etc. If you want to learn more about Stratis blockchain head over to Introduction to Stratis Platform.
In this article, you'll learn how to configure the required tools to start the development with Stratis blockchain, write a simple smart contract in C#, and deploy and execute your first Smart Contract over the Stratis blockchain.
To complete this article, you must have a basic understanding of C# and .NET. If you are new to C# programming, please learn C# here - Programming C# for Beginners. You should also have basic knowledge of Blockchain and how it works. If you do not have a basic understanding of Blockchain, please read this What is Blockchain.
Prerequisites
Here are the prerequisites to complete this tutorial:
- Visual Studio 2019 Community or later version
- Stratis Smart Contract Template
- Sct tool
- Stratis FullNode
- Postman
- Swagger
Download and install Visual Studio 2019
We are going to use Visual Studio 2019 in this tutorial. Visual Studio Community 2019 edition is free to download. You may use any other editions of Visual Studio 2019 or later.
If you wish to install Visual Studio 2019, download, and install it from here.
Install Stratis Smart Contract Template
Stratis Smart Contract template is a Visual Studio project template that creates a sample Stratis smart contract project in Visual Studio. You can install the template using the below command in your Visual Studio command terminal.
dotnet new --install Stratis.SmartContracts.Templates.CLI
Once the above command is successful, it will install the Stratis Smart Contracts Visual Studio project template.
Once it's installed successfully, it should appear in the list of available templates.
You can find this template in the Visual Studio available templates too. This template will be available to you when you create a new project in Visual Studio. To find it, you can simply type “Stratis” in the search box. We will see how to create a Visual Studio smart contracts project using this template later in this tutorial.
Quick Fix
If you cannot find the template in the list, enable the option from Tools > Options and look for the “Show all .NET Core templates in the New Project dialog” checkbox and check it.
Click the OK button.
After enabling, you need to restart the Visual Studio instance. Then try to create a new project, you should see the Stratis Smart Contract Template in the list. As I said earlier, we will use this for Smart Contract development later in this article.
Sct tool
When we create Stratis smart contracts, we must validate that the smart contract is correct. The Smart Contract validation process is completed using the sct tool provided by Stratis.
Download that sct project from here and keep it in the directory where you can easily access it. We will see more about the validation process later in this article.
Stratis Full Node (Private Blockchain)
Now, here comes the most important part. We need to install Stratis Blockchain on the local development machine, Stratis Blockchain is Stratis Full Node. If you want to learn more about Stratis Full Node, check out here.
Please note
For development, it is preferable to use a local blockchain network to deploy and test the smart contracts. Once you deploy and tested and have a clear understanding of smart contracts and Stratis, then you can go ahead and deploy your smart contracts on Live Stratis public blockchain. Stratis public blockchain has two live chains, “testnet” and “mainnet”. The “testnet” is used to deploy your smart contracts for testing purposes and the “mainnet” is the live public blockchain that’s where you will deploy your real working product smart contracts. However, to deploy on mainnet blockchain, there is going to be a small fee in form of $STRAX. We will discuss these two chains later in this series.
A local blockchain network is a clone of the actual blockchain (aka mainnet) but it uses a different consensus mechanism. To make the development and learning easier, it provides the flexibility of simple execution and testing of smart contracts on the development machine without any outside miners or validators required.
To run the blockchain on a local machine for development, download the Stratis full node master branch from here.
And run the Stratis.CirrusMinerD project with the -devmode parameter as shown below,
cd StratisFullNode\src\Stratis.CirrusMinerD
dotnet run -devmode=miner
This runs a single block-producing node utilizing the PoA (Proof-of-Authority) consensus algorithm. Open http://localhost:38223/swagger in your machine and the list of APIs should be visible. Using these API endpoints, we can interact with the blockchain.
All chain logs would appear in the terminal. You can find account and balance information there.
As you can see from the above screen, initially your Stratis wallet has a balance of 100,000 tokens.
Postman
Postman is a popular API client that is used to call API endpoints.
Download and install Postman from here.
To use Postman, you need to create an account. We will use Postman to deploy our contract and execute contract methods.
To get all available methods on the Swagger page to the Postman, go to http://localhost:38223/swagger/v1/swagger.json save it as a JSON file, and import it to the Postman.
This will create a new collection “Stratis Node API” in your workspace.
Change base URL variable value to http://localhost:38223
We have configured all required tools, now let’s create our first smart contract.
Step 1 - Development
Open a Visual Studio, select Stratis Smart Contract Template and create a project.
Click Create button.
Once a project is created, you will land upon the page below. The MyContract is a simple contract. You can customize it to your needs.
A smart contract stores the information in key-value pair. Using PersistentState we can store the information in a smart contract.
For our simple contract, we will create a smart contract that will modify the default contract to store the contract owner's information. Then after deployment, we’ll retrieve that smart contract owner information.
Here is the modified version of the MyContract.
The above contract has two methods, SetOwner and GetOwner to set and get the owner of the contract.
Things to notice,
- The sender is the address currently interacting with the contract.
- The owner property will set when the contract will be deployed.
- The constructor will be called only once when the smart contract will be deployed.
- PersistentState stores data in key-value format permanently to the state database.
Step 2 - Validating a smart contract
The validation process is a must to check the valid constraints used in a smart contract. The process ensures that a smart contract is free from the non-deterministic elements and additional constraints around the format of the contract are met.
We have already downloaded sct tool previously. Open a terminal and step into the sct project, and run the below commands.
cd src/Stratis.SmartContracts.Tools.Sct
dotnet run -- validate [Contract_PATH]
Example
dotnet run -- validate "D:\Project Repository\StratisSmartContract\MyContract.cs".
If there any issue with a contract, it will appear in the response. Modify the contract base on errors and try to validate it again. If all looks fine, we are ready to go to the next step.
Step 3 - Compiling a contract
Once a smart contract is validated, the next step is to compile a smart contract and generate a byte code. The smart contract byte code is the code that is deployed on a chain.
A contract can be compiled using the sct tool using the command below,
dotnet run -- validate [CONTRACT_PATH_HERE] -sb
If the compilation is successful, the output will be the compiled bytecode that looks like the following,
Step 4 - Contract Deployment
Now, we are going to deploy our smart contract on the chain.
Contract deployment can be done using API endpoints. To deploy your contract, open the Postman collection and follow the API execution.
Load the wallet
The wallet is required for everything we do in blockchain, whether it is sending cryptocurrency to someone or deploy a contract. Stratis provides a predefine wallet for development. We will use that wallet to deploy our contract, but first, we need to load that wallet.
Go to wallet load API, provide the wallet name and password.
If you receive an error in response, wait for a while and try again. The API should return a 200 status code.
Get Sender wallet address
An address is required to interact with a blockchain. One account can have multiple addresses. This private chain has some pre-configured wallet addresses with balance which we can use for creating transactions.
To get addresses with balance in the wallet, use the wallet addresses API. Provide the wallet name and account name.
Here address “PEpYnf7Zv5u4pTDGmvYPT2vktpop2VeCqj” has some balance. We’ll use this address to send transactions whenever it will be required in our case.
Smart Contract Deployment
A contract can be deployed using this endpoint. Here we have to pass bytecodes generated using the sct tool previously.
Go to SmartContract Wallet > select the endpoint /api/SmartContractWallet/create. Provide required information as below,
Parameter | Value | Description |
amount | 0 | STRAX amount sent to the contract. |
contractCode | Byte code generated using sct tool | |
password | password | Wallet password |
sender | PEpYnf7Zv5u4pTDGmvYPT2vktpop2VeCqj | Sender wallet address |
walletName | cirrusdev | Wallet name |
accountName | account 0 | Account name |
outpoints | null | |
feeAmount | 0.001 | Fee amount |
gasPrice | 100 | Gas price |
gasLimit | 100000 | Gas Limit |
parameters | null | Parameters to pass to the contract method. Our contract method doesn’t have any, hence passing null. |
It will return a transaction hash in the response as below:
"89e7092c75e866566b6a9ff25bd63360d77c7e3bc0fb460a2ad2389c75e59e05"
Get Transaction Receipt
Using transaction hash, you can get transaction receipt which includes Gas Used in the transaction, From and To Addresses, Return Values, Logs, etc.
Find receipt API from the Smart Contracts folder in the collection. Provide transaction hash in the query parameter.
Sample Response
{
"transactionHash": "89e7092c75e866566b6a9ff25bd63360d77c7e3bc0fb460a2ad2389c75e59e05",
"blockHash": "46409439dea5b9f30a80401e34432c90de07ee621c1df90d4a2bcb72be720141",
"postState": "49a66770d7702c31d57c9c3c46e20e104b1f682d64dd4fab1f9e6cd7535157e4",
"gasUsed": 12540,
"from": "PEpYnf7Zv5u4pTDGmvYPT2vktpop2VeCqj",
"to": null,
"newContractAddress": "PFHuKUFBYRYjoAfQ5aamqpzuETrd9hNAuE",
"success": true,
"returnValue": null,
"bloom": "000000000000000000000000000000000000000000000000000000000000000000000000
00000000000000000000000000000000000000000000000000000000000000000000000000000000000000
00000000000000000000000000000000000000000000000000000000000000000000000000000000000000
00000000000000000000000000000000000000000000000000000000000000000000000000000000000000
00000000000000000000000000000000000000000000000000000000000000000000000000000000000000
00000000000000000000000000000000000000000000000000000000000000000000000000000000000000
0000000000",
"error": null,
"logs": []
}
Please note down this contract address, it will use it while interacting with the smart contract deployed.
Step 5 - Interacting with smart contract
There are two ways to interact with a contract.
- Interacting with a contract through a transaction - a contract call
- Interacting with a contract without a transaction - a local call
From Stratis documentation,
“A contract call uses a regular transaction that is broadcast to the network. The call parameters are encapsulated in the transaction and handled by the network in the same way as any other transaction. Every node in the network will execute a contract call. If a contract call modifies the state database, the global state is changed.
A local call does not require a transaction. Instead, it passes the call data directly to the local node and executes it on the local machine only. A local call runs against a copy of the state database. If the local call makes changes to the state, these changes are discarded after execution.
Local calls can be used to read the contract state without expending gas (to query the value of a property for example). A local call can also aid in estimating gas costs without needing to broadcast transactions to the main network.”
In our contract, we have already set the Owner value when deployed. Now, we will use a local call to read the value of the Owner.
Parameters | Value | Description |
contractAddress | PFHuKUFBYRYjoAfQ5aamqpzuETrd9hNAuE | Address received in response of receipt API |
methodName | GetOwner | Contract method name |
amount | 0 | STRAX amount send to the contract. |
gasPrice | 100 | Gas price |
gasLimit | 100000 | Gas Limit |
sender | PEpYnf7Zv5u4pTDGmvYPT2vktpop2VeCqj | Sender address |
parameters | null | Method parameters |
The Response should contain the return value of the owner's address.
{
"internalTransfers": [],
"gasConsumed": {
"value": 10040
},
"revert": false,
"errorMessage": null,
"return": "PEpYnf7Zv5u4pTDGmvYPT2vktpop2VeCqj",
"logs": []
}
That’s all.
Congratulations! You’ve just completed the first step towards creating and deploying your smart contracts over Stratis blockchain.
Authors:
Thank you, Divyang Desai and Rohit Gupta for creating and testing the initial document.
No comments:
Post a Comment