U2U Network Documentations
  • Introduction
    • Our Vision
    • Litepaper
      • Overview
        • U2U Network Diagram
        • U2U Network with DEPIN and Web3 Eco System
      • Consensus
  • Services
    • RPC
      • RPC Endpoints
      • Ethereum API Methods
        • eth_blockNumber
        • eth_call
        • eth_chainId
        • eth_estimateGas
        • eth_feeHistory
        • eth_gasPrice
        • eth_getBalance
        • eth_getBlockByHash
        • eth_getBlockByNumber
        • eth_getBlockTransactionCountByHash
        • eth_getBlockTransactionCountByNumber
        • eth_getCode
        • eth_getLogs
        • eth_getProof
        • eth_getStorageAt
        • eth_getTransactionByBlockHashAndIndex
        • eth_getTransactionByBlockNumberAndIndex
        • eth_getTransactionByHash
        • eth_getTransactionCount
        • eth_getTransactionReceipt
        • eth_getUncleByBlockHashAndIndex
        • eth_getUncleByBlockNumberAndIndex
        • eth_getUncleCountByBlockHash
        • eth_getUncleCountByBlockNumber
        • eth_maxPriorityFeePerGas
        • eth_sendRawTransaction
        • eth_subscribe
        • eth_unsubscribe
        • net_version
        • net_listening
        • net_peerCount
        • web3_clientVersion
        • web3_sha3
        • debug_traceTransaction
      • DAG API Methods
        • dag_getEvent
        • dag_getEventPayload
        • dag_getHeads
        • eth_currentEpoch
      • Trace API Methods
        • trace_block
        • trace_get
        • trace_transaction
        • trace_filter
    • Explorer
      • Explorer URLs
      • Explorer API
        • Account
        • Block
        • Contract
        • Logs
        • Stats
        • Token
        • Transaction
      • GraphQL
      • Explorer RPC API
      • Smart Contract Verification
        • Via explorer
        • Via hardhat plugin
      • Testnet Faucet
    • Wallets
      • Metamask
      • Wallet Connect
      • Coinbase Wallet
      • U2U Super App
        • Policy
    • Staking
      • How To Stake?
      • FAQ
    • The Graph
      • Deploy a Graph Node
      • Deploy a Subgraph
    • Bridge
      • Smart Contracts & EOA
    • Oracle
      • Smart Contracts & EOA
  • Network
    • Node Types
    • Requirements
    • Build Dependencies
    • Run Normal Node
      • Mainnet Normal Node
      • Testnet Normal Node
      • Run via Docker
    • Run Validator Node
      • Mainnet Validator Node
      • Testnet Validator Node
    • Run A Local Test Network
    • Troubleshooting
  • SUBNET
    • Overview
    • Subnet Node Type
    • Requirements
    • NFT Digital License
    • Subnet Node Setup
      • Master Node
      • Verifier Node
      • Edge Node CLI
  • For Developers
    • SDK
    • Smart Contract Development
      • What are smart contracts?
      • What is gas?
      • Structure of a smart contract
      • Your first smart contract
      • Test your smart contract
      • Deploy your smart contract
      • Submit your contract to explorer
      • Interact With Your Smart Contract
      • Integrate Your Smart Contract With a Frontend
      • Additional Resources
    • Smart Contract Deployment
      • Deploy with Remix
      • Deploy with Hardhat
Powered by GitBook
On this page
  • With blockchain explorer
  • Read contract
  • Write contract
  • With Hardhat
  • With a frontend and web3.js
  1. For Developers
  2. Smart Contract Development

Interact With Your Smart Contract

PreviousSubmit your contract to explorerNextIntegrate Your Smart Contract With a Frontend

Last updated 11 months ago

With blockchain explorer

With verified contracts on blockchain explorer, we can easily interact with them via blockchain explorer UI.

Read contract

Public fields of the contract:

uint public unlockTime;
address payable public owner;

They are displayed on the explorer, at Read contract tab:

Public fields and view functions are displayed on the explorer.

Write contract

Contract have a function:

function withdraw() public {}

Since it is publicly set, user can interact with this function via explorer's UI:

To interact with contract, you have to connect your wallet to the explorer.

With Hardhat

The same as above method, we will call withdraw() on Lock contract.

Back to your sample project, at scripts folder, add following withdraw.ts file:

import { ethers } from "hardhat";
import { Lock } from "../typechain-types";

async function main() {
    const [owner] = await ethers.getSigners();

    const lockAddr = "0x8D51395C76C34d0e11178c1F7EE3219B4b958e30"
    const Lock = await ethers.getContractFactory("Lock")
    const lock = await Lock.attach(lockAddr) as Lock

    const tx = await lock.withdraw()
    console.log("Withdrawal has completed. Transaction hash: " + tx.hash)
}

main().catch((error) => {
    console.error(error);
    process.exitCode = 1;
});

Then run it by:

npx hardhat run scripts/withdraw.ts --network nebulas

And the result:

Withdrawal has completed. Transaction hash: 0x0481a1abccb0e3dc336ec970628c033d11af6696da5536838ac76cad5f0494d7

With a frontend and web3.js

Please head to next section .

Integrate Your Smart Contract With a Frontend
https://testnet.u2uscan.xyz/address/0x8D51395C76C34d0e11178c1F7EE3219B4b958e30/read-contract#address-tabs