কীভাবে একটি NFT লিখবেন এবং ডিপ্লয় করবেন (NFT টিউটোরিয়াল সিরিজের পর্ব 1/3)
NFT-গুলো ব্লকচেইনকে জনসমক্ষে নিয়ে আসার সাথে সাথে, ইথেরিয়াম ব্লকচেইনে আপনার নিজস্ব NFT কন্ট্রাক্ট (ERC-721 টোকেন) প্রকাশ করে এই উন্মাদনাটি নিজে বোঝার জন্য এটি একটি চমৎকার সুযোগ!
Alchemy NFT স্পেসের সবচেয়ে বড় নামগুলোকে শক্তি জোগাতে পেরে অত্যন্ত গর্বিত, যার মধ্যে রয়েছে Makersplace (সম্প্রতি Christie’s-এ 69 মিলিয়ন ডলারে ডিজিটাল আর্টওয়ার্ক বিক্রির রেকর্ড গড়েছে), Dapper Labs (NBA Top Shot এবং Crypto Kitties-এর নির্মাতা), ওপেনসি (বিশ্বের বৃহত্তম NFT মার্কেটপ্লেস), Zora, Super Rare, NFTfi, Foundation, Enjin, Origin Protocol, Immutable এবং আরও অনেক কিছু।
এই টিউটোরিয়ালে, আমরা মেটামাস্ক (opens in a new tab), Solidity (opens in a new tab), Hardhat (opens in a new tab), Pinata (opens in a new tab) এবং Alchemy (opens in a new tab) ব্যবহার করে Sepolia টেস্টনেট-এ একটি ERC-721 স্মার্ট কন্ট্রাক্ট তৈরি এবং ডিপ্লয় করার প্রক্রিয়া দেখব (যদি আপনি এখনও এগুলোর অর্থ বুঝতে না পারেন তবে চিন্তা করবেন না — আমরা এটি ব্যাখ্যা করব!)।
এই টিউটোরিয়ালের পর্ব 2-এ আমরা দেখব কীভাবে আমরা একটি NFT মিন্ট করতে আমাদের স্মার্ট কন্ট্রাক্ট ব্যবহার করতে পারি, এবং পর্ব 3-এ আমরা ব্যাখ্যা করব কীভাবে মেটামাস্ক-এ আপনার NFT দেখতে হয়।
এবং অবশ্যই, যদি কোনো পর্যায়ে আপনার প্রশ্ন থাকে, তবে Alchemy ডিসকর্ড (opens in a new tab)-এ যোগাযোগ করতে দ্বিধা করবেন না বা Alchemy-এর NFT API ডক্স (opens in a new tab) ভিজিট করুন!
ধাপ 1: ইথেরিয়াম নেটওয়ার্ক-এর সাথে কানেক্ট করুন
ইথেরিয়াম ব্লকচেইন-এ রিকোয়েস্ট করার অনেক উপায় আছে, কিন্তু কাজ সহজ করার জন্য, আমরা Alchemy (opens in a new tab)-তে একটি ফ্রি অ্যাকাউন্ট ব্যবহার করব, যা একটি ব্লকচেইন ডেভেলপার প্ল্যাটফর্ম এবং API যা আমাদের নিজস্ব নোড না চালিয়েই ইথেরিয়াম চেইন-এর সাথে যোগাযোগ করতে দেয়।
এই টিউটোরিয়ালে, আমরা আমাদের স্মার্ট কন্ট্রাক্ট ডিপ্লয়মেন্ট-এর ভেতরে কীভাবে কাজ হচ্ছে তা বোঝার জন্য মনিটরিং এবং অ্যানালিটিক্স-এর জন্য Alchemy-এর ডেভেলপার টুলগুলোর সুবিধাও নেব। যদি আপনার আগে থেকেই কোনো Alchemy অ্যাকাউন্ট না থাকে, তবে আপনি বিনামূল্যে এখানে (opens in a new tab) সাইন আপ করতে পারেন।
ধাপ 2: আপনার অ্যাপ (এবং API কী) তৈরি করুন
একবার আপনি একটি Alchemy অ্যাকাউন্ট তৈরি করলে, আপনি একটি অ্যাপ তৈরি করে একটি API কী জেনারেট করতে পারেন। এটি আমাদের Sepolia টেস্ট নেটওয়ার্ক-এ রিকোয়েস্ট করার অনুমতি দেবে। আপনি যদি টেস্ট নেটওয়ার্ক সম্পর্কে আরও জানতে আগ্রহী হন তবে এই গাইডটি (opens in a new tab) দেখতে পারেন।
- ন্যাভ বারে “Apps”-এর ওপর হোভার করে এবং “Create App”-এ ক্লিক করে আপনার Alchemy ড্যাশবোর্ডের “Create App” পেজে যান
- আপনার অ্যাপের নাম দিন (আমরা “My First NFT!” বেছে নিয়েছি), একটি সংক্ষিপ্ত বিবরণ দিন, চেইন-এর জন্য “Ethereum” নির্বাচন করুন এবং আপনার নেটওয়ার্ক-এর জন্য “Sepolia” বেছে নিন। দ্য মার্জ-এর পর থেকে অন্যান্য টেস্টনেট-গুলো বাতিল করা হয়েছে।
- “Create app”-এ ক্লিক করুন এবং কাজ শেষ! আপনার অ্যাপটি নিচের টেবিলে দেখা উচিত।
ধাপ 3: একটি ইথেরিয়াম অ্যাকাউন্ট (ঠিকানা) তৈরি করুন
ট্রানজ্যাকশন পাঠানো এবং গ্রহণ করার জন্য আমাদের একটি ইথেরিয়াম অ্যাকাউন্ট প্রয়োজন। এই টিউটোরিয়ালের জন্য, আমরা মেটামাস্ক ব্যবহার করব, যা ব্রাউজারে থাকা একটি ভার্চুয়াল ওয়ালেট এবং এটি আপনার ইথেরিয়াম অ্যাকাউন্ট ঠিকানা পরিচালনা করতে ব্যবহৃত হয়। ইথেরিয়াম-এ ট্রানজ্যাকশন কীভাবে কাজ করে সে সম্পর্কে আপনি যদি আরও বুঝতে চান, তবে ইথেরিয়াম ফাউন্ডেশন-এর এই পেজটি দেখুন।
আপনি বিনামূল্যে এখানে (opens in a new tab) একটি মেটামাস্ক অ্যাকাউন্ট ডাউনলোড এবং তৈরি করতে পারেন। যখন আপনি একটি অ্যাকাউন্ট তৈরি করছেন, বা যদি আপনার আগে থেকেই একটি অ্যাকাউন্ট থাকে, তবে নিশ্চিত করুন যে আপনি ওপরের ডানদিকে “Sepolia Test Network”-এ স্যুইচ করেছেন (যাতে আমরা আসল টাকা নিয়ে কাজ না করি)।
ধাপ 4: একটি ফসেট থেকে ইথার যোগ করুন
টেস্ট নেটওয়ার্ক-এ আমাদের স্মার্ট কন্ট্রাক্ট ডিপ্লয় করার জন্য, আমাদের কিছু নকল ETH প্রয়োজন হবে। ETH পেতে আপনি Alchemy দ্বারা হোস্ট করা Sepolia ফসেট (opens in a new tab)-এ যেতে পারেন, লগ ইন করে আপনার অ্যাকাউন্ট ঠিকানা লিখুন এবং “Send Me ETH”-এ ক্লিক করুন। এর কিছুক্ষণ পরেই আপনার মেটামাস্ক অ্যাকাউন্ট-এ ETH দেখতে পাবেন!
ধাপ 5: আপনার ব্যালেন্স চেক করুন
আমাদের ব্যালেন্স সেখানে আছে কিনা তা নিশ্চিত করতে, চলুন Alchemy-এর স্যান্ডবক্স টুল (opens in a new tab) ব্যবহার করে একটি eth_getBalance (opens in a new tab) রিকোয়েস্ট করি। এটি আমাদের ওয়ালেট-এ থাকা ETH-এর পরিমাণ রিটার্ন করবে। আপনার মেটামাস্ক অ্যাকাউন্ট ঠিকানা ইনপুট করার পর এবং “Send Request”-এ ক্লিক করার পর, আপনি এরকম একটি রেসপন্স দেখতে পাবেন:
{"jsonrpc": "2.0", "id": 0, "result": "0xde0b6b3a7640000"}
নোট এই ফলাফলটি Wei-তে, ETH-এ নয়। Wei-কে ইথার-এর সবচেয়ে ছোট একক হিসেবে ব্যবহার করা হয়। Wei থেকে ETH-এ রূপান্তর হলো 1 eth = 1018 Wei। তাই যদি আমরা 0xde0b6b3a7640000-কে ডেসিমালে রূপান্তর করি তবে আমরা 1*1018 Wei পাই, যা 1 ETH-এর সমান।
যাক! আমাদের সব নকল টাকা সেখানেই আছে।
ধাপ 6: আমাদের প্রজেক্ট ইনিশিয়ালাইজ করুন
প্রথমে, আমাদের প্রজেক্টের জন্য একটি ফোল্ডার তৈরি করতে হবে। আপনার কমান্ড লাইনে যান এবং টাইপ করুন:
mkdir my-nft cd my-nft
এখন যেহেতু আমরা আমাদের প্রজেক্ট ফোল্ডারের ভেতরে আছি, আমরা প্রজেক্টটি ইনিশিয়ালাইজ করতে npm init ব্যবহার করব। যদি আপনার আগে থেকেই npm ইনস্টল করা না থাকে, তবে Node.js ইনস্টলেশন নির্দেশিকা (opens in a new tab) অনুসরণ করুন (এই টিউটোরিয়ালের জন্য আমাদের Node.js এবং npm প্রয়োজন হবে)।
npm init
আপনি ইনস্টলেশনের প্রশ্নগুলোর উত্তর কীভাবে দিচ্ছেন তা খুব একটা গুরুত্বপূর্ণ নয়; রেফারেন্সের জন্য আমরা কীভাবে এটি করেছি তা নিচে দেওয়া হলো:
package name: (my-nft)
version: (1.0.0)
description: My first NFT!
entry point: (index.js)
test command:
git repository:
keywords:
author:
license: (ISC)
About to write to /Users/thesuperb1/Desktop/my-nft/package.json:
{
"name": "my-nft",
"version": "1.0.0",
"description": "My first NFT!",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "",
"license": "ISC"
}
package.json অনুমোদন করুন, এবং আমরা কাজ শুরু করার জন্য প্রস্তুত!
ধাপ 7: Hardhat (opens in a new tab) ইনস্টল করুন
Hardhat হলো আপনার ইথেরিয়াম সফটওয়্যার কম্পাইল, ডিপ্লয়, টেস্ট এবং ডিবাগ করার জন্য একটি ডেভেলপমেন্ট এনভায়রনমেন্ট। এটি লাইভ চেইন-এ ডিপ্লয় করার আগে স্থানীয়ভাবে স্মার্ট কন্ট্রাক্ট এবং বিকেন্দ্রীকৃত অ্যাপ্লিকেশন (dapp) তৈরি করার সময় ডেভেলপারদের সাহায্য করে।
আমাদের my-nft প্রজেক্টের ভেতরে রান করুন:
npm install --save-dev hardhat
ইনস্টলেশন নির্দেশিকা (opens in a new tab) সম্পর্কে আরও বিস্তারিত জানতে এই পেজটি দেখুন।
ধাপ 8: Hardhat প্রজেক্ট তৈরি করুন
আমাদের প্রজেক্ট ফোল্ডারের ভেতরে রান করুন:
npx hardhat
এরপর আপনি একটি ওয়েলকাম মেসেজ এবং আপনি কী করতে চান তা নির্বাচন করার অপশন দেখতে পাবেন। “create an empty hardhat.config.js” নির্বাচন করুন:
888 888 888 888 888 888 888 888 888 888 888 888 888 888 888 8888888888 8888b. 888d888 .d88888 88888b. 8888b. 888888 888 888 "88b 888P" d88" 888 888 "88b "88b 888 888 888 .d888888 888 888 888 888 888 .d888888 888 888 888 888 888 888 Y88b 888 888 888 888 888 Y88b. 888 888 "Y888888 888 "Y88888 888 888 "Y888888 "Y888 👷 Welcome to Hardhat v2.0.11 👷 ? What do you want to do? … Create a sample project ❯ Create an empty hardhat.config.js Quit
এটি আমাদের জন্য একটি hardhat.config.js ফাইল তৈরি করবে যেখানে আমরা আমাদের প্রজেক্টের সমস্ত সেটআপ নির্দিষ্ট করব (ধাপ 13-এ)।
ধাপ 9: প্রজেক্ট ফোল্ডার যোগ করুন
আমাদের প্রজেক্টটি গুছিয়ে রাখতে, আমরা দুটি নতুন ফোল্ডার তৈরি করব। আপনার কমান্ড লাইনে প্রজেক্টের রুট ডিরেক্টরিতে যান এবং টাইপ করুন:
mkdir contracts mkdir scripts
-
contracts/ হলো সেই জায়গা যেখানে আমরা আমাদের NFT স্মার্ট কন্ট্রাক্ট কোড রাখব
-
scripts/ হলো সেই জায়গা যেখানে আমরা আমাদের স্মার্ট কন্ট্রাক্ট ডিপ্লয় এবং এর সাথে ইন্টারঅ্যাক্ট করার স্ক্রিপ্টগুলো রাখব
ধাপ 10: আমাদের কন্ট্রাক্ট লিখুন
এখন যেহেতু আমাদের এনভায়রনমেন্ট সেট আপ করা হয়েছে, চলুন আরও রোমাঞ্চকর কাজের দিকে এগিয়ে যাই: আমাদের স্মার্ট কন্ট্রাক্ট কোড লেখা!
আপনার পছন্দের এডিটরে my-nft প্রজেক্টটি খুলুন (আমাদের পছন্দ VSCode (opens in a new tab))। স্মার্ট কন্ট্রাক্ট-গুলো Solidity নামক একটি ভাষায় লেখা হয়, যা আমরা আমাদের MyNFT.sol স্মার্ট কন্ট্রাক্ট লিখতে ব্যবহার করব।
-
contractsফোল্ডারে যান এবং MyNFT.sol নামে একটি নতুন ফাইল তৈরি করুন -
নিচে আমাদের NFT স্মার্ট কন্ট্রাক্ট কোড দেওয়া হলো, যা আমরা ওপেনজেপেলিন (opens in a new tab) লাইব্রেরি-এর ERC-721 ইমপ্লিমেন্টেশনের ওপর ভিত্তি করে তৈরি করেছি। নিচের বিষয়বস্তু কপি করে আপনার MyNFT.sol ফাইলে পেস্ট করুন।
//[https://docs.openzeppelin.com/contracts/3.x/erc721](https://docs.openzeppelin.com/contracts/3.x/erc721)-এর উপর ভিত্তি করে কন্ট্রাক্ট // SPDX-License-Identifier: MIT pragma solidity ^0.8.0; import "@openzeppelin/contracts/token/ERC721/ERC721.sol"; import "@openzeppelin/contracts/utils/Counters.sol"; import "@openzeppelin/contracts/access/Ownable.sol"; import "@openzeppelin/contracts/token/ERC721/extensions/ERC721URIStorage.sol"; contract MyNFT is ERC721URIStorage, Ownable { using Counters for Counters.Counter; Counters.Counter private _tokenIds; constructor() ERC721("MyNFT", "NFT") {} function mintNFT(address recipient, string memory tokenURI) public onlyOwner returns (uint256) { _tokenIds.increment(); uint256 newItemId = _tokenIds.current(); _mint(recipient, newItemId); _setTokenURI(newItemId, tokenURI); return newItemId; } } -
যেহেতু আমরা ওপেনজেপেলিন কন্ট্রাক্ট লাইব্রেরি থেকে ক্লাস ইনহেরিট করছি, তাই আমাদের ফোল্ডারে লাইব্রেরিটি ইনস্টল করতে আপনার কমান্ড লাইনে
npm install @openzeppelin/contracts^4.0.0রান করুন।
তাহলে, এই কোডটি আসলে কী করে? চলুন এটি লাইন-বাই-লাইন বিশ্লেষণ করি।
আমাদের স্মার্ট কন্ট্রাক্ট-এর একেবারে ওপরে, আমরা তিনটি ওপেনজেপেলিন (opens in a new tab) স্মার্ট কন্ট্রাক্ট ক্লাস ইমপোর্ট করি:
-
@openzeppelin/contracts/token/ERC721/ERC721.sol-এ ERC-721 স্ট্যান্ডার্ডের ইমপ্লিমেন্টেশন রয়েছে, যা আমাদের NFT স্মার্ট কন্ট্রাক্ট ইনহেরিট করবে। (একটি বৈধ NFT হতে হলে, আপনার স্মার্ট কন্ট্রাক্ট-কে অবশ্যই ERC-721 স্ট্যান্ডার্ডের সমস্ত মেথড ইমপ্লিমেন্ট করতে হবে।) ইনহেরিট করা ERC-721 ফাংশনগুলো সম্পর্কে আরও জানতে, এখানে (opens in a new tab) ইন্টারফেস ডেফিনিশন দেখুন।
-
@openzeppelin/contracts/utils/Counters.sol এমন কাউন্টার প্রদান করে যা শুধুমাত্র এক করে বাড়ানো বা কমানো যায়। আমাদের স্মার্ট কন্ট্রাক্ট মিন্ট করা মোট NFT-এর সংখ্যা ট্র্যাক করতে এবং আমাদের নতুন NFT-তে ইউনিক ID সেট করতে একটি কাউন্টার ব্যবহার করে। (স্মার্ট কন্ট্রাক্ট ব্যবহার করে মিন্ট করা প্রতিটি NFT-কে অবশ্যই একটি ইউনিক ID দিতে হবে—এখানে আমাদের ইউনিক ID শুধুমাত্র বিদ্যমান মোট NFT-এর সংখ্যা দ্বারা নির্ধারিত হয়। উদাহরণস্বরূপ, আমাদের স্মার্ট কন্ট্রাক্ট দিয়ে আমরা যে প্রথম NFT মিন্ট করি তার ID হলো "1," আমাদের দ্বিতীয় NFT-এর ID হলো "2," ইত্যাদি।)
-
@openzeppelin/contracts/access/Ownable.sol আমাদের স্মার্ট কন্ট্রাক্ট-এ অ্যাক্সেস কন্ট্রোল (opens in a new tab) সেট আপ করে, যাতে শুধুমাত্র স্মার্ট কন্ট্রাক্ট-এর মালিক (আপনি) NFT মিন্ট করতে পারেন। (নোট করুন, অ্যাক্সেস কন্ট্রোল অন্তর্ভুক্ত করা সম্পূর্ণ আপনার পছন্দের ওপর নির্ভর করে। আপনি যদি চান যে যে কেউ আপনার স্মার্ট কন্ট্রাক্ট ব্যবহার করে একটি NFT মিন্ট করতে পারুক, তবে 10 নম্বর লাইনে Ownable এবং 17 নম্বর লাইনে onlyOwner শব্দটি সরিয়ে দিন।)
আমাদের ইমপোর্ট স্টেটমেন্টগুলোর পরে, আমাদের কাস্টম NFT স্মার্ট কন্ট্রাক্ট রয়েছে, যা আশ্চর্যজনকভাবে ছোট — এতে শুধুমাত্র একটি কাউন্টার, একটি কনস্ট্রাক্টর এবং একটি মাত্র ফাংশন রয়েছে! এটি সম্ভব হয়েছে আমাদের ইনহেরিট করা ওপেনজেপেলিন কন্ট্রাক্ট-গুলোর কারণে, যা একটি NFT তৈরি করার জন্য আমাদের প্রয়োজনীয় বেশিরভাগ মেথড ইমপ্লিমেন্ট করে, যেমন ownerOf যা NFT-এর মালিককে রিটার্ন করে, এবং transferFrom, যা একটি অ্যাকাউন্ট থেকে অন্য অ্যাকাউন্টে NFT-এর মালিকানা ট্রান্সফার করে।
আমাদের ERC-721 কনস্ট্রাক্টর-এ, আপনি লক্ষ্য করবেন যে আমরা 2টি স্ট্রিং পাস করি, “MyNFT” এবং “NFT”। প্রথম ভেরিয়েবলটি হলো স্মার্ট কন্ট্রাক্ট-এর নাম, এবং দ্বিতীয়টি হলো এর প্রতীক। আপনি আপনার ইচ্ছামতো এই ভেরিয়েবলগুলোর নাম দিতে পারেন!
অবশেষে, আমাদের mintNFT(address recipient, string memory tokenURI) ফাংশনটি রয়েছে যা আমাদের একটি NFT মিন্ট করতে দেয়! আপনি লক্ষ্য করবেন যে এই ফাংশনটি দুটি ভেরিয়েবল নেয়:
-
address recipientসেই ঠিকানা নির্দিষ্ট করে যা আপনার নতুন মিন্ট করা NFT গ্রহণ করবে -
string memory tokenURIহলো একটি স্ট্রিং যা একটি JSON ডকুমেন্টে রিজলভ হওয়া উচিত যা NFT-এর মেটাডেটা বর্ণনা করে। একটি NFT-এর মেটাডেটা সত্যিই এটিকে জীবন্ত করে তোলে, এটিকে কনফিগারযোগ্য বৈশিষ্ট্য যেমন নাম, বিবরণ, ছবি এবং অন্যান্য অ্যাট্রিবিউট রাখার অনুমতি দেয়। এই টিউটোরিয়ালের পর্ব 2-এ, আমরা বর্ণনা করব কীভাবে এই মেটাডেটা কনফিগার করতে হয়।
mintNFT ইনহেরিট করা ERC-721 লাইব্রেরি থেকে কিছু মেথড কল করে, এবং শেষ পর্যন্ত একটি সংখ্যা রিটার্ন করে যা নতুন মিন্ট করা NFT-এর ID উপস্থাপন করে।
ধাপ 11: আপনার প্রজেক্টের সাথে মেটামাস্ক এবং Alchemy কানেক্ট করুন
এখন যেহেতু আমরা একটি মেটামাস্ক ওয়ালেট, Alchemy অ্যাকাউন্ট তৈরি করেছি এবং আমাদের স্মার্ট কন্ট্রাক্ট লিখেছি, এখন এই তিনটিকে কানেক্ট করার সময়।
আপনার ভার্চুয়াল ওয়ালেট থেকে পাঠানো প্রতিটি ট্রানজ্যাকশন-এর জন্য আপনার ইউনিক প্রাইভেট কী ব্যবহার করে একটি স্বাক্ষর প্রয়োজন। আমাদের প্রোগ্রামকে এই অনুমতি প্রদান করতে, আমরা নিরাপদে আমাদের প্রাইভেট কী (এবং Alchemy API কী) একটি এনভায়রনমেন্ট ফাইলে সংরক্ষণ করতে পারি।
ট্রানজ্যাকশন পাঠানো সম্পর্কে আরও জানতে, Web3 ব্যবহার করে ট্রানজ্যাকশন পাঠানোর ওপর এই টিউটোরিয়ালটি দেখুন।
প্রথমে, আপনার প্রজেক্ট ডিরেক্টরিতে dotenv প্যাকেজটি ইনস্টল করুন:
npm install dotenv --save
তারপর, আমাদের প্রজেক্টের রুট ডিরেক্টরিতে একটি .env ফাইল তৈরি করুন এবং এতে আপনার মেটামাস্ক প্রাইভেট কী এবং HTTP Alchemy API URL যোগ করুন।
-
মেটামাস্ক থেকে আপনার প্রাইভেট কী এক্সপোর্ট করতে এই নির্দেশিকাগুলো (opens in a new tab) অনুসরণ করুন
-
HTTP Alchemy API URL পেতে নিচে দেখুন এবং এটি আপনার ক্লিপবোর্ডে কপি করুন
আপনার .env এখন এরকম দেখতে হওয়া উচিত:
API_URL="https://eth-sepolia.g.alchemy.com/v2/your-api-key (opens in a new tab)" PRIVATE_KEY="your-metamask-private-key"
এগুলোকে আমাদের কোডের সাথে কানেক্ট করতে, আমরা ধাপ 13-এ আমাদের hardhat.config.js ফাইলে এই ভেরিয়েবলগুলোর রেফারেন্স দেব।
.env কমিট করবেন না! অনুগ্রহ করে নিশ্চিত করুন যে আপনি কখনই আপনার .env ফাইলটি কারও সাথে শেয়ার বা প্রকাশ করবেন না, কারণ এটি করার মাধ্যমে আপনি আপনার গোপনীয়তার সাথে আপস করছেন। আপনি যদি ভার্সন কন্ট্রোল ব্যবহার করেন, তবে আপনার .env ফাইলটি একটি gitignore (opens in a new tab) ফাইলে যোগ করুন।ধাপ 12: Ethers.js ইনস্টল করুন
Ethers.js হলো এমন একটি লাইব্রেরি যা স্ট্যান্ডার্ড জেসন-আরপিসি মেথডগুলোকে আরও ব্যবহারকারী-বান্ধব মেথড দিয়ে র্যাপ করে ইথেরিয়াম-এর সাথে ইন্টারঅ্যাক্ট করা এবং রিকোয়েস্ট করা সহজ করে তোলে।
অতিরিক্ত টুলিং এবং বর্ধিত কার্যকারিতার জন্য Hardhat প্লাগইন (opens in a new tab) ইন্টিগ্রেট করা খুব সহজ করে তোলে। আমরা কন্ট্রাক্ট ডিপ্লয়মেন্ট-এর জন্য Ethers প্লাগইন (opens in a new tab)-এর সুবিধা নেব (Ethers.js (opens in a new tab)-এ কিছু খুব পরিষ্কার কন্ট্রাক্ট ডিপ্লয়মেন্ট মেথড রয়েছে)।
আপনার প্রজেক্ট ডিরেক্টরিতে টাইপ করুন:
npm install --save-dev @nomiclabs/hardhat-ethers ethers@^5.0.0
পরবর্তী ধাপে আমাদের hardhat.config.js-এ ethers-এরও প্রয়োজন হবে।
ধাপ 13: hardhat.config.js আপডেট করুন
আমরা এ পর্যন্ত বেশ কয়েকটি ডিপেন্ডেন্সি এবং প্লাগইন যোগ করেছি, এখন আমাদের hardhat.config.js আপডেট করতে হবে যাতে আমাদের প্রজেক্ট সেগুলোর সব সম্পর্কে জানতে পারে।
আপনার hardhat.config.js আপডেট করে এরকম করুন:
/**
* @type import('hardhat/config').HardhatUserConfig
*/
require('dotenv').config();
require("@nomiclabs/hardhat-ethers");
const { API_URL, PRIVATE_KEY } = process.env;
module.exports = {
solidity: "0.8.1",
defaultNetwork: "sepolia",
networks: {
hardhat: {},
sepolia: {
url: API_URL,
accounts: [`0x${PRIVATE_KEY}`]
}
},
}
ধাপ 14: আমাদের কন্ট্রাক্ট কম্পাইল করুন
এ পর্যন্ত সবকিছু ঠিকঠাক কাজ করছে কিনা তা নিশ্চিত করতে, চলুন আমাদের কন্ট্রাক্ট কম্পাইল করি। কম্পাইল টাস্কটি হলো বিল্ট-ইন Hardhat টাস্কগুলোর মধ্যে একটি।
কমান্ড লাইন থেকে রান করুন:
npx hardhat compile
আপনি সোর্স ফাইলে SPDX লাইসেন্স আইডেন্টিফায়ার প্রদান না করা সম্পর্কে একটি ওয়ার্নিং পেতে পারেন, তবে এটি নিয়ে চিন্তা করার দরকার নেই — আশা করি অন্য সবকিছু ঠিক আছে! যদি তা না হয়, তবে আপনি সবসময় Alchemy ডিসকর্ড (opens in a new tab)-এ মেসেজ করতে পারেন।
ধাপ 15: আমাদের ডিপ্লয় স্ক্রিপ্ট লিখুন
এখন যেহেতু আমাদের কন্ট্রাক্ট লেখা হয়েছে এবং আমাদের কনফিগারেশন ফাইল প্রস্তুত, এখন আমাদের কন্ট্রাক্ট ডিপ্লয় স্ক্রিপ্ট লেখার সময়।
scripts/ ফোল্ডারে যান এবং deploy.js নামে একটি নতুন ফাইল তৈরি করুন, এতে নিচের বিষয়বস্তু যোগ করুন:
async function main() {
const MyNFT = await ethers.getContractFactory("MyNFT")
// ডিপ্লয়মেন্ট শুরু করুন, যা একটি প্রমিস রিটার্ন করে যা একটি কন্ট্রাক্ট অবজেক্টে রিজলভ হয়
const myNFT = await MyNFT.deploy()
await myNFT.deployed()
console.log("Contract deployed to address:", myNFT.address)
}
main()
.then(() => process.exit(0))
.catch((error) => {
console.error(error)
process.exit(1)
})
Hardhat তাদের কন্ট্রাক্ট টিউটোরিয়াল (opens in a new tab)-এ কোডের এই প্রতিটি লাইন কী করে তা ব্যাখ্যা করার ক্ষেত্রে চমৎকার কাজ করে, আমরা এখানে তাদের ব্যাখ্যাগুলো গ্রহণ করেছি।
const MyNFT = await ethers.getContractFactory("MyNFT");
Ethers.js-এ একটি ContractFactory হলো নতুন স্মার্ট কন্ট্রাক্ট ডিপ্লয় করতে ব্যবহৃত একটি অ্যাবস্ট্রাকশন, তাই এখানে MyNFT হলো আমাদের NFT কন্ট্রাক্ট-এর ইনস্ট্যান্সগুলোর জন্য একটি ফ্যাক্টরি। hardhat-ethers প্লাগইন ব্যবহার করার সময় ContractFactory এবং Contract ইনস্ট্যান্সগুলো ডিফল্টভাবে প্রথম সাইনারের সাথে কানেক্টেড থাকে।
const myNFT = await MyNFT.deploy();
একটি ContractFactory-তে deploy() কল করলে ডিপ্লয়মেন্ট শুরু হবে, এবং একটি Promise রিটার্ন করবে যা একটি Contract-এ রিজলভ হয়। এটি হলো সেই অবজেক্ট যার আমাদের প্রতিটি স্মার্ট কন্ট্রাক্ট ফাংশনের জন্য একটি মেথড রয়েছে।
ধাপ 16: আমাদের কন্ট্রাক্ট ডিপ্লয় করুন
আমরা অবশেষে আমাদের স্মার্ট কন্ট্রাক্ট ডিপ্লয় করতে প্রস্তুত! আপনার প্রজেক্ট ডিরেক্টরির রুটে ফিরে যান এবং কমান্ড লাইনে রান করুন:
npx hardhat --network sepolia run scripts/deploy.js
এরপর আপনি এরকম কিছু দেখতে পাবেন:
Contract deployed to address: 0x4C5266cCc4b3F426965d2f51b6D910325a0E7650
যদি আমরা Sepolia Etherscan (opens in a new tab)-এ যাই এবং আমাদের কন্ট্রাক্ট ঠিকানা সার্চ করি তবে আমরা দেখতে পাব যে এটি সফলভাবে ডিপ্লয় হয়েছে। যদি আপনি এটি সাথে সাথে দেখতে না পান, তবে অনুগ্রহ করে কিছুক্ষণ অপেক্ষা করুন কারণ এতে কিছুটা সময় লাগতে পারে। ট্রানজ্যাকশন-টি দেখতে এরকম হবে:
From ঠিকানাটি আপনার মেটামাস্ক অ্যাকাউন্ট ঠিকানার সাথে মিলতে হবে এবং To ঠিকানায় “Contract Creation” লেখা থাকবে। যদি আমরা ট্রানজ্যাকশন-টিতে ক্লিক করি, তবে আমরা To ফিল্ডে আমাদের কন্ট্রাক্ট ঠিকানা দেখতে পাব:
দারুণ! আপনি এইমাত্র ইথেরিয়াম (টেস্টনেট) চেইন-এ আপনার NFT স্মার্ট কন্ট্রাক্ট ডিপ্লয় করেছেন!
ভেতরে কীভাবে কাজ হচ্ছে তা বুঝতে, চলুন আমাদের Alchemy ড্যাশবোর্ডের (opens in a new tab) এক্সপ্লোরার ট্যাবে যাই। যদি আপনার একাধিক Alchemy অ্যাপ থাকে তবে অ্যাপ অনুযায়ী ফিল্টার করতে ভুলবেন না এবং “MyNFT” নির্বাচন করুন।
এখানে আপনি বেশ কয়েকটি জেসন-আরপিসি কল দেখতে পাবেন যা Hardhat/Ethers আমাদের জন্য ভেতরে ভেতরে তৈরি করেছে যখন আমরা .deploy() ফাংশনটি কল করেছি। এখানে উল্লেখ করার মতো দুটি গুরুত্বপূর্ণ কল হলো eth_sendRawTransaction, যা আসলে Sepolia চেইন-এ আমাদের স্মার্ট কন্ট্রাক্ট লেখার রিকোয়েস্ট, এবং eth_getTransactionByHash যা হ্যাশ দেওয়া থাকলে আমাদের ট্রানজ্যাকশন সম্পর্কে তথ্য পড়ার একটি রিকোয়েস্ট (ট্রানজ্যাকশন পাঠানোর সময় একটি সাধারণ প্যাটার্ন)। ট্রানজ্যাকশন পাঠানো সম্পর্কে আরও জানতে, Web3 ব্যবহার করে ট্রানজ্যাকশন পাঠানোর ওপর এই টিউটোরিয়ালটি দেখুন।
এই টিউটোরিয়ালের পর্ব 1-এর জন্য এটুকুই। পর্ব 2-এ, আমরা একটি NFT মিন্ট করে আমাদের স্মার্ট কন্ট্রাক্ট-এর সাথে ইন্টারঅ্যাক্ট করব, এবং পর্ব 3-এ আমরা আপনাকে দেখাব কীভাবে আপনার ইথেরিয়াম ওয়ালেট-এ আপনার NFT দেখতে হয়!






