How SmartContract interacts with app(front-end) & Backend(Blockchain).
In this article I am planning to talk about the interaction between SC, APP and BC.
As you might know SmartContract is self-executing code when specific conditions are met & that will always run the way it is programmed. Smart Contract, blockchains provide developers with a way to decentralize where the code runs. In this way, code can truly become a public resource. This means code can run without any direct ownership, making it censorship resistant and transparently verifiable. When you take smart contract code, compile it and deploy it to a decentralized blockchain, the code becomes publicly available on the blockchain and the nodes in the network will enforce the logic of the code through the financial incentives of the blockchain protocol.
When you write a smart contract using Solidity, you need to compile it in order to convert it into bytecode that can be executed on the blockchain. The Solidity compiler is used to compile the smart contract code into bytecode that can be executed by the Ethereum Virtual Machine (EVM).
Please note that Solidity is a programming language used for writing smart contracts on the Ethereum blockchain. It is not a multi-threaded programming language, and therefore it does not have synchronization resources such as mutexes, semaphores, or threads.
Solidity is designed to be a single-threaded programming language, which means that all code executed by a smart contract is executed on a single thread of execution. This is because smart contracts are intended to be deterministic, and multi-threading can introduce non-deterministic behavior that could lead to inconsistent results.
Please note that smart contracts can be created using other languages also, one of the famous was is to create using the Ink language which is based on populer Rust lang and can be deployed in any blockchain which are built using the substrate framework.
I can see Smart Contracts are similar to Class in objects-oriented programming languages like C++ or Java. Please see below analysis.
Smart contracts written in Rust using the Ink language have some similarities to classes in C++, but there are also significant differences. Here are some points to consider:
Let me list some of the frequently used or very important terms used in block chain especially in Etherium.
Interaction between different players :
User Interfac
|
Web3 Provider (e.g. MetaMask)
|
Wallet
|
+--------------+--------------+
| |
Blockchain Network Sidechains
(e.g. Ethereum) (e.g. Polygon)
| |
+-----------------+----------------+ +-----+-----+
| | | | |
Smart Contracts Consensus Oracles | |
Mechanism | |
| |
Interoperability Protocols
(e.g. Polkadot)
|
+-------------+------------+
| |
Data Provider Storage System
(e.g. Infura) (e.g. IPFS, Swarm)
| |
Identity and Access Management Systems
(e.g. Litentry)
e
Coming back to smart contract on Ethereum, When you compile a smart contract, the Solidity compiler generates a number of output artifacts. These artifacts include:
Simplified representation of the Ethereum blockchain ecosystem and the specific components and their interactions may vary depending on the specific use case and implementation.
Smart Contract Developer
|
Solidity Programming
|
+-----------------------------+
| |
Smart Contract Code ABI (Application Binary Interface)
| |
+----------------+ +-------------+
| | | |
Bytecode Deployed Smart Contract Interface
Contract Instance |
| |
+------------------+ |
| Ethereum Virtual | |
| Machine | |
| | |
| Execution of | |
| Smart Contract | |
| | |
+------------------+ |
| |
Blockchain Mempool
| |
+------------------+ +---------------------+
| Block Producer | | Transaction |
| (e.g. Miner) | | Pool (Pending) |
+------------------+ +---------------------+
| |
+------------------+ +---------------------+
| Block | | Transaction Pool |
| | | (Mempool Snapshot) |
+------------------+ +---------------------+
| |
+------------------+ +---------------------+
| Block | | Transaction |
| Content | | Processing |
+------------------+ +---------------------+
| |
+------------------+ +---------------------+
| Block Data | | Transaction Receipt |
| Validation | | Storage |
+------------------+ +---------------------+
| |
Finalized Block Transaction Finality
| |
Block Chain Head |
| |
Block Chain History |
|
External Integration
|
DApps, Wallets, etc.
Below are details of some important components :
6. Gas Limit: It is Maximum gas that the transaction can consume and gas limit is set by the sender.
7. MetaMask : MetaMask is a popular cryptocurrency wallet that allows users to store, manage and interact with their cryptocurrencies and decentralized applications (DApps) on the Ethereum blockchain. It is a browser extension wallet that integrates with popular web browsers such as Google Chrome, Firefox, and Brave, making it easy to use and accessible to a wide range of users.
With MetaMask, users can securely store their private keys, send and receive Ether and ERC-20 tokens, interact with decentralized applications, and sign and verify digital signatures. MetaMask also provides a user-friendly interface for managing Ethereum accounts, tracking transaction history, and monitoring cryptocurrency prices.
In addition to being a wallet, MetaMask also serves as a gateway to the decentralized web, allowing users to seamlessly interact with DApps built on the Ethereum blockchain. With MetaMask, users can connect to DApps with just a few clicks, without the need to manually enter their private keys or seed phrases. This makes it easy for anyone to participate in the decentralized economy and take advantage of the benefits offered by blockchain technology.
Ethereum Virtual Machine (EVM) :
The Ethereum Virtual Machine (EVM) is a key component of the Ethereum blockchain. It is a virtual machine that executes smart contracts on the Ethereum blockchain. Here is an example of how the EVM executes a simple smart contract that stores and retrieves a string:
Recommended by LinkedIn
This is a simplified example, but it gives you an idea of how the EVM works. The EVM is a complex system that is designed to be secure and deterministic, which means that every node on the Ethereum network will execute smart contracts in exactly the same way.
Here is an example of how to compile a Solidity smart contract using the solc command-line compiler:
solc --abi --bin -o build/contracts/ MyContract.sol
This command will compile the MyContract.sol file and output the ABI and bytecode artifacts to the build/contracts/ directory.
Once you have compiled your smart contract, you can use the ABI and bytecode artifacts to deploy and interact with the smart contract on the blockchain.
"contractName": "MyContract", {
"abi": [
{
"constant": false,
"inputs": [
{
"name": "param1",
"type": "uint256"
}
],
"name": "myFunction",
"outputs": [],
"payable": false,
"stateMutability": "nonpayable",
"type": "function"
}
],
"bytecode": "0x608060405234801561001057600080fd5b506101a98061001f6000396000f3fe608060405260043610610045576000357c01... ",
"deployedBytecode": "0x608060405260043610610045576000357c01...",
"networks": {
"1": {
"events": {},
"links": {},
"address": "0x1234567890123456789012345678901234567890",
"transactionHash": "0x0123456789abcdef0123456789abcdef0123456789abcdef0123456789abcdef",
"updatedAt": "2022-02-12T11:01:45.001Z"
}
},
"sourceMap": "46:54:0:-;;;;;;;;;;;;;;;;",
"deployedSourceMap": "46:54:0:-;;;;;;"
}
This example JSON artifact contains the contract name ("MyContract"), the ABI (which describes the functions and variables of the smart contract), the bytecode of the smart contract (which can be deployed to the blockchain), and the deployed bytecode (which is the actual bytecode that was deployed to the network).
It also contains a "networks" object, which maps network IDs to deployment data, such as the contract address and transaction hash. Finally, it contains source maps that map the compiled bytecode back to the original source code for debugging purposes.
How to dApps can interact with smartContract or how is the connection between the front-end and backend of the application with a local or remote Solidity using HTTP to WebSocket. :
Front-end and backend are the two main components of any application, and web 3.0 app is not an exception.
To interact with the ABI of a smart contract using Web3.js, the following steps can be followed:
import Web3 from 'web3';
import configuration from '../build/contracts/smartContract**.json';
import 'bootstrap/dist/css/bootstrap.css';
// Import the web3 library
const Web3 = require('web3');
// Set up the web3 provider (in this case, we're using a local Ganache instance)
const web3 = new Web3('http://localhost:8545');
// Define the contract ABI (Application Binary Interface)
//
const abi = [
{
"constant": false,
"inputs": [
{
"name": "_greeting",
"type": "string"
}
],
"name": "setGreeting",
"outputs": [],
"payable": false,
"stateMutability": "nonpayable",
"type": "function"
},
{
"constant": true,
"inputs": [],
"name": "getGreeting",
"outputs": [
{
"name": "",
"type": "string"
}
],
"payable": false,
"stateMutability": "view",
"type": "function"
}
];
// Define the contract address (in this case, we'll deploy a new instance of the contract later)
let contractAddress;
// Define the contract instance
const contract = new web3.eth.Contract(abi, contractAddress);
// Define the default account to use for transactions
web3.eth.defaultAccount = '0x...'; // replace with an actual Ethereum account address
// Deploy a new instance of the contract ,
/*
below deplyoment is not required in most of the cases
deployment of the smart contract should be done before running
the JavaScript code using the contract. Typically,
the deployment is done using the Truffle framework,
which will generate an artifact with the contract's ABI
and bytecode. This artifact can be imported into the JavaScript
code and used to interact with the contract. so commentin below deloyment code*/
/*
const deployment = contract.deploy({
data: '0x...',
arguments: ['Hello Smart contract world !']
});
deployment.send({
from: web3.eth.defaultAccount,
gas: 1500000,
gasPrice: '30000000000000'
}).then((newContractInstance) => {
console.log(`Contract deployed at address ${newContractInstance.options.address}`);
contractAddress = newContractInstance.options.address;
}).catch((error) => {
console.error(`Error deploying contract: ${error}`);
});
*/
// Call a contract function
contract.methods.getGreeting().call().then((result) => {
console.log(`Current greeting: ${result}`);
}).catch((error) => {
console.error(`Error calling contract function: ${error}`);
});
// Send a transaction to a contract function
contract.methods.setGreeting('Jai, Shree Ram!').send({
from: web3.eth.defaultAccount,
gas: 1500000,
gasPrice: '30000000000000'
}).then((receipt) => {
console.log(`Transaction sent: ${receipt.transactionHash}`);
}).catch((error) => {
console.error(`Error sending transaction: ${error}`);
});
In the above example, we instantiate a new Web3 object using the provider from MetaMask, and define the ABI and address of a simple smart contract. We create a new instance of the contract object, and use its methods to interact with the contract.
// Deploy a new instance of the contract ,
/*
below deplyoment is not required in most of the cases
deployment of the smart contract should be done before running
the JavaScript code using the contract. Typically,
the deployment is done using the Truffle framework,
which will generate an artifact with the contract's ABI
and bytecode. This artifact can be imported into the JavaScript
code and used to interact with the contract. so commentin below deloyment code*/
/*
const deployment = contract.deploy({
data: '0x...',
arguments: ['Hello Smart contract world !']
});
deployment.send({
from: web3.eth.defaultAccount,
gas: 1500000,
gasPrice: '30000000000000'
}).then((newContractInstance) => {
console.log(`Contract deployed at address ${newContractInstance.options.address}`);
contractAddress = newContractInstance.options.address;
}).catch((error) => {
console.error(`Error deploying contract: ${error}`);
});
*/
Note : Deployment of the smart contract should be done before running the JavaScript code using the contract. Typically, the deployment is done using the Truffle framework, which will generate an artifact with the contract's ABI and bytecode. This artifact can be imported into the JavaScript code and used to interact with the contract.
In the above code, the contract object represents an instance of the contract that has already been deployed. However, if the code attempts to deploy a new instance of the contract using the deploy method of the contract object. This is unnecessary and will result in an error if the contract has already been deployed to the network.
However, there may be scenarios where you want to deploy a smart contract directly from your JavaScript code. In such cases, you can use a library like Web3 to interact with the blockchain and deploy the contract. The deployment code in JavaScript would typically involve creating a new instance of the contract using the deploy() method, specifying the necessary deployment parameters, and then sending the deployment transaction to the blockchain network using the send() method.
So, when you write a smart contract, you can compile it using a tool like Truffle or Remix. The compiled code will generate a binary version of the contract that can be deployed to the blockchain. Once you have the compiled code. Then deployment code is necessary in JavaScript if you want to deploy a new instance of a smart contract from your JavaScript application.
Practical example of webapp interacting with smart contract:
One example of a web application that interacts with a smart contract on the blockchain is Uniswap, a decentralized exchange built on the Ethereum blockchain. Uniswap allows users to swap ERC-20 tokens directly from their Ethereum wallets, without the need for a centralized exchange.
When a user wants to make a trade on Uniswap, they connect their Ethereum wallet to the Uniswap interface through a web app. The web app then communicates with the smart contract on the Ethereum blockchain that powers the Uniswap exchange. The smart contract executes the trade by swapping the user's tokens with tokens from the Uniswap liquidity pool, which is a collection of tokens provided by liquidity providers.
Once the trade is executed on the blockchain, the web app updates the user's wallet balance and displays the transaction details. This seamless integration of the web app with the smart contract on the blockchain allows users to interact with the Uniswap exchange in a user-friendly way, without having to manually interact with the smart contract themselves.
Other examples of web applications that interact with smart contracts on the blockchain include decentralized finance (DeFi) platforms, decentralized prediction markets, and decentralized social networks.
Thanks for reading till end, If you have any questions or suggestions, please leave a comment.