মূল কন্টেন্টে যান

কীভাবে একটি NFT লিখবেন এবং ডিপ্লয় করবেন (NFT টিউটোরিয়াল সিরিজের পর্ব 1/3)

ERC-721
Alchemy
Solidity
স্মার্ট কন্ট্রাক্ট
শিক্ষানবিস
সুমি মুদগিল
22 এপ্রিল, 2021
13 মিনিট পড়ার সময়

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) দেখতে পারেন।

  1. ন্যাভ বারে “Apps”-এর ওপর হোভার করে এবং “Create App”-এ ক্লিক করে আপনার Alchemy ড্যাশবোর্ডের “Create App” পেজে যান

Create your app

  1. আপনার অ্যাপের নাম দিন (আমরা “My First NFT!” বেছে নিয়েছি), একটি সংক্ষিপ্ত বিবরণ দিন, চেইন-এর জন্য “Ethereum” নির্বাচন করুন এবং আপনার নেটওয়ার্ক-এর জন্য “Sepolia” বেছে নিন। দ্য মার্জ-এর পর থেকে অন্যান্য টেস্টনেট-গুলো বাতিল করা হয়েছে।

Configure and publish your app

  1. “Create app”-এ ক্লিক করুন এবং কাজ শেষ! আপনার অ্যাপটি নিচের টেবিলে দেখা উচিত।

ধাপ 3: একটি ইথেরিয়াম অ্যাকাউন্ট (ঠিকানা) তৈরি করুন

ট্রানজ্যাকশন পাঠানো এবং গ্রহণ করার জন্য আমাদের একটি ইথেরিয়াম অ্যাকাউন্ট প্রয়োজন। এই টিউটোরিয়ালের জন্য, আমরা মেটামাস্ক ব্যবহার করব, যা ব্রাউজারে থাকা একটি ভার্চুয়াল ওয়ালেট এবং এটি আপনার ইথেরিয়াম অ্যাকাউন্ট ঠিকানা পরিচালনা করতে ব্যবহৃত হয়। ইথেরিয়াম-এ ট্রানজ্যাকশন কীভাবে কাজ করে সে সম্পর্কে আপনি যদি আরও বুঝতে চান, তবে ইথেরিয়াম ফাউন্ডেশন-এর এই পেজটি দেখুন।

আপনি বিনামূল্যে এখানে (opens in a new tab) একটি মেটামাস্ক অ্যাকাউন্ট ডাউনলোড এবং তৈরি করতে পারেন। যখন আপনি একটি অ্যাকাউন্ট তৈরি করছেন, বা যদি আপনার আগে থেকেই একটি অ্যাকাউন্ট থাকে, তবে নিশ্চিত করুন যে আপনি ওপরের ডানদিকে “Sepolia Test Network”-এ স্যুইচ করেছেন (যাতে আমরা আসল টাকা নিয়ে কাজ না করি)।

Set Sepolia as your 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.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 স্মার্ট কন্ট্রাক্ট লিখতে ব্যবহার করব।‌

  1. contracts ফোল্ডারে যান এবং MyNFT.sol নামে একটি নতুন ফাইল তৈরি করুন

  2. নিচে আমাদের NFT স্মার্ট কন্ট্রাক্ট কোড দেওয়া হলো, যা আমরা ওপেনজেপেলিন (opens in a new tab) লাইব্রেরি-এর ERC-721 ইমপ্লিমেন্টেশনের ওপর ভিত্তি করে তৈরি করেছি। নিচের বিষয়বস্তু কপি করে আপনার MyNFT.sol ফাইলে পেস্ট করুন।

  3. যেহেতু আমরা ওপেনজেপেলিন কন্ট্রাক্ট লাইব্রেরি থেকে ক্লাস ইনহেরিট করছি, তাই আমাদের ফোল্ডারে লাইব্রেরিটি ইনস্টল করতে আপনার কমান্ড লাইনে 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 পেতে নিচে দেখুন এবং এটি আপনার ক্লিপবোর্ডে কপি করুন

Copy your 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 আপডেট করে এরকম করুন:

ধাপ 14: আমাদের কন্ট্রাক্ট কম্পাইল করুন

এ পর্যন্ত সবকিছু ঠিকঠাক কাজ করছে কিনা তা নিশ্চিত করতে, চলুন আমাদের কন্ট্রাক্ট কম্পাইল করি। কম্পাইল টাস্কটি হলো বিল্ট-ইন Hardhat টাস্কগুলোর মধ্যে একটি।

কমান্ড লাইন থেকে রান করুন:

npx hardhat compile

আপনি সোর্স ফাইলে SPDX লাইসেন্স আইডেন্টিফায়ার প্রদান না করা সম্পর্কে একটি ওয়ার্নিং পেতে পারেন, তবে এটি নিয়ে চিন্তা করার দরকার নেই — আশা করি অন্য সবকিছু ঠিক আছে! যদি তা না হয়, তবে আপনি সবসময় Alchemy ডিসকর্ড (opens in a new tab)-এ মেসেজ করতে পারেন।

ধাপ 15: আমাদের ডিপ্লয় স্ক্রিপ্ট লিখুন

এখন যেহেতু আমাদের কন্ট্রাক্ট লেখা হয়েছে এবং আমাদের কনফিগারেশন ফাইল প্রস্তুত, এখন আমাদের কন্ট্রাক্ট ডিপ্লয় স্ক্রিপ্ট লেখার সময়।

scripts/ ফোল্ডারে যান এবং deploy.js নামে একটি নতুন ফাইল তৈরি করুন, এতে নিচের বিষয়বস্তু যোগ করুন:

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)-এ যাই এবং আমাদের কন্ট্রাক্ট ঠিকানা সার্চ করি তবে আমরা দেখতে পাব যে এটি সফলভাবে ডিপ্লয় হয়েছে। যদি আপনি এটি সাথে সাথে দেখতে না পান, তবে অনুগ্রহ করে কিছুক্ষণ অপেক্ষা করুন কারণ এতে কিছুটা সময় লাগতে পারে। ট্রানজ্যাকশন-টি দেখতে এরকম হবে:

View your transaction address on Etherscan

From ঠিকানাটি আপনার মেটামাস্ক অ্যাকাউন্ট ঠিকানার সাথে মিলতে হবে এবং To ঠিকানায় “Contract Creation” লেখা থাকবে। যদি আমরা ট্রানজ্যাকশন-টিতে ক্লিক করি, তবে আমরা To ফিল্ডে আমাদের কন্ট্রাক্ট ঠিকানা দেখতে পাব:

View your contract address on Etherscan

দারুণ! আপনি এইমাত্র ইথেরিয়াম (টেস্টনেট) চেইন-এ আপনার NFT স্মার্ট কন্ট্রাক্ট ডিপ্লয় করেছেন!

ভেতরে কীভাবে কাজ হচ্ছে তা বুঝতে, চলুন আমাদের Alchemy ড্যাশবোর্ডের (opens in a new tab) এক্সপ্লোরার ট্যাবে যাই। যদি আপনার একাধিক Alchemy অ্যাপ থাকে তবে অ্যাপ অনুযায়ী ফিল্টার করতে ভুলবেন না এবং “MyNFT” নির্বাচন করুন।

View calls made “under the hood” with Alchemy’s Explorer Dashboard

এখানে আপনি বেশ কয়েকটি জেসন-আরপিসি কল দেখতে পাবেন যা Hardhat/Ethers আমাদের জন্য ভেতরে ভেতরে তৈরি করেছে যখন আমরা .deploy() ফাংশনটি কল করেছি। এখানে উল্লেখ করার মতো দুটি গুরুত্বপূর্ণ কল হলো eth_sendRawTransaction, যা আসলে Sepolia চেইন-এ আমাদের স্মার্ট কন্ট্রাক্ট লেখার রিকোয়েস্ট, এবং eth_getTransactionByHash যা হ্যাশ দেওয়া থাকলে আমাদের ট্রানজ্যাকশন সম্পর্কে তথ্য পড়ার একটি রিকোয়েস্ট (ট্রানজ্যাকশন পাঠানোর সময় একটি সাধারণ প্যাটার্ন)। ট্রানজ্যাকশন পাঠানো সম্পর্কে আরও জানতে, Web3 ব্যবহার করে ট্রানজ্যাকশন পাঠানোর ওপর এই টিউটোরিয়ালটি দেখুন।

এই টিউটোরিয়ালের পর্ব 1-এর জন্য এটুকুই। পর্ব 2-এ, আমরা একটি NFT মিন্ট করে আমাদের স্মার্ট কন্ট্রাক্ট-এর সাথে ইন্টারঅ্যাক্ট করব, এবং পর্ব 3-এ আমরা আপনাকে দেখাব কীভাবে আপনার ইথেরিয়াম ওয়ালেট-এ আপনার NFT দেখতে হয়!