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

JavaScript API লাইব্রেরি

একটি ওয়েব অ্যাপকে ইথেরিয়াম ব্লকচেইনের সাথে ইন্টারঅ্যাক্ট করতে (অর্থাৎ, ব্লকচেইন ডেটা পড়তে এবং/অথবা নেটওয়ার্কে ট্রানজ্যাকশন পাঠাতে) হলে, এটিকে অবশ্যই একটি ইথেরিয়াম নোডের সাথে কানেক্ট করতে হবে।

এই উদ্দেশ্যে, প্রতিটি ইথেরিয়াম ক্লায়েন্ট জেসন-আরপিসি স্পেসিফিকেশন প্রয়োগ করে, তাই অ্যাপ্লিকেশনগুলি নির্ভর করতে পারে এমন একটি অভিন্ন মেথড সেট রয়েছে।

আপনি যদি একটি ইথেরিয়াম নোডের সাথে কানেক্ট করতে JavaScript ব্যবহার করতে চান, তবে ভ্যানিলা JavaScript ব্যবহার করা সম্ভব, কিন্তু ইকোসিস্টেমের মধ্যে বেশ কয়েকটি সুবিধাজনক লাইব্রেরি রয়েছে যা এটিকে অনেক সহজ করে তোলে। এই লাইব্রেরিগুলির সাহায্যে, ডেভেলপাররা ইথেরিয়ামের সাথে ইন্টারঅ্যাক্ট করে এমন জেসন-আরপিসি রিকোয়েস্ট (অভ্যন্তরীণভাবে) ইনিশিয়ালাইজ করার জন্য সহজ, এক-লাইনের মেথড লিখতে পারেন।

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

পূর্বশর্ত

JavaScript বোঝার পাশাপাশি, ইথেরিয়াম স্ট্যাক এবং ইথেরিয়াম ক্লায়েন্ট সম্পর্কে বোঝাও সহায়ক হতে পারে।

কেন একটি লাইব্রেরি ব্যবহার করবেন?

এই লাইব্রেরিগুলি সরাসরি একটি ইথেরিয়াম নোডের সাথে ইন্টারঅ্যাক্ট করার বেশিরভাগ জটিলতা দূর করে। এগুলি ইউটিলিটি ফাংশনও প্রদান করে (যেমন, ETH-কে Gwei-তে রূপান্তর করা) যাতে একজন ডেভেলপার হিসেবে আপনি ইথেরিয়াম ক্লায়েন্টগুলির জটিলতাগুলি নিয়ে কম সময় ব্যয় করতে পারেন এবং আপনার অ্যাপ্লিকেশনের অনন্য কার্যকারিতার উপর বেশি সময় ফোকাস করতে পারেন।

লাইব্রেরির বৈশিষ্ট্য

ইথেরিয়াম নোডের সাথে কানেক্ট করা

প্রোভাইডার ব্যবহার করে, এই লাইব্রেরিগুলি আপনাকে ইথেরিয়ামের সাথে কানেক্ট করতে এবং এর ডেটা পড়তে দেয়, তা জেসন-আরপিসি, Infura, Etherscan, Alchemy বা মেটামাস্ক-এর মাধ্যমেই হোক না কেন।

সতর্কতা: Web3.js 4 মার্চ, 2025-এ আর্কাইভ করা হয়েছিল। ঘোষণাটি পড়ুন (opens in a new tab)। নতুন প্রজেক্টের জন্য ethers.js (opens in a new tab) বা viem (opens in a new tab)-এর মতো বিকল্প লাইব্রেরিগুলি ব্যবহার করার কথা বিবেচনা করুন।

Ethers-এর উদাহরণ

// একটি BrowserProvider একটি স্ট্যান্ডার্ড Web3 প্রোভাইডারকে র‍্যাপ করে, যা হলো
// মেটামাস্ক প্রতিটি পেজে window.ethereum হিসেবে যা ইনজেক্ট করে
const provider = new ethers.BrowserProvider(window.ethereum)

// মেটামাস্ক প্লাগইন ট্রানজ্যাকশন সাইন করারও অনুমতি দেয় যাতে
// ইথার পাঠানো যায় এবং ব্লকচেইন এর মধ্যে স্টেট পরিবর্তন করার জন্য পে করা যায়।
// এর জন্য, আমাদের অ্যাকাউন্ট সাইনার প্রয়োজন...
const signer = provider.getSigner()

Web3js-এর উদাহরণ

একবার সেট আপ হয়ে গেলে আপনি ব্লকচেইনে নিম্নলিখিত বিষয়গুলির জন্য কোয়েরি করতে পারবেন:

  • ব্লক নম্বর
  • গ্যাস এস্টিমেট
  • স্মার্ট কন্ট্রাক্ট ইভেন্ট
  • নেটওয়ার্ক আইডি
  • এবং আরও অনেক কিছু...

ওয়ালেট কার্যকারিতা

এই লাইব্রেরিগুলি আপনাকে ওয়ালেট তৈরি করতে, কী (key) পরিচালনা করতে এবং ট্রানজ্যাকশন সাইন করার কার্যকারিতা দেয়।

এখানে Ethers থেকে একটি উদাহরণ দেওয়া হলো

সম্পূর্ণ ডক্স পড়ুন (opens in a new tab)

একবার সেট আপ হয়ে গেলে আপনি যা করতে পারবেন:

  • অ্যাকাউন্ট তৈরি করা
  • ট্রানজ্যাকশন পাঠানো
  • ট্রানজ্যাকশন সাইন করা
  • এবং আরও অনেক কিছু...

স্মার্ট কন্ট্রাক্ট ফাংশনের সাথে ইন্টারঅ্যাক্ট করা

JavaScript ক্লায়েন্ট লাইব্রেরিগুলি আপনার অ্যাপ্লিকেশনকে একটি কম্পাইল করা কন্ট্রাক্টের অ্যাপ্লিকেশন বাইনারি ইন্টারফেস (ABI) পড়ে স্মার্ট কন্ট্রাক্ট ফাংশন কল করার অনুমতি দেয়।

ABI মূলত একটি JSON ফর্ম্যাটে কন্ট্রাক্টের ফাংশনগুলি ব্যাখ্যা করে এবং আপনাকে এটিকে একটি সাধারণ JavaScript অবজেক্টের মতো ব্যবহার করতে দেয়।

সুতরাং নিম্নলিখিত Solidity কন্ট্রাক্ট:

এর ফলে নিম্নলিখিত JSON তৈরি হবে:

এর মানে হলো আপনি করতে পারেন:

  • স্মার্ট কন্ট্রাক্টে একটি ট্রানজ্যাকশন পাঠাতে এবং এর মেথড এক্সিকিউট করতে
  • EVM-এ এক্সিকিউট করার সময় একটি মেথড এক্সিকিউশনে কত গ্যাস লাগবে তা অনুমান করার জন্য কল করতে
  • একটি কন্ট্রাক্ট ডিপ্লয় করতে
  • এবং আরও অনেক কিছু...

ইউটিলিটি ফাংশন

ইউটিলিটি ফাংশনগুলি আপনাকে সুবিধাজনক শর্টকাট দেয় যা ইথেরিয়ামের সাথে তৈরি করাকে কিছুটা সহজ করে তোলে।

ETH মানগুলি ডিফল্টরূপে Wei-তে থাকে। 1 ETH = 1,000,000,000,000,000,000 WEI – এর মানে হলো আপনি অনেক বড় সংখ্যার সাথে কাজ করছেন! web3.utils.toWei আপনার জন্য ইথারকে Wei-তে রূপান্তর করে।

এবং ethers-এ এটি দেখতে এইরকম:

// একটি অ্যাকাউন্টের ব্যালেন্স পান (অ্যাড্রেস বা ENS নাম দ্বারা)
balance = await provider.getBalance("ethers.eth")
// { BigNumber: "2337132817842795605" }

// প্রায়শই আপনাকে ব্যবহারকারীর জন্য আউটপুট ফরম্যাট করতে হবে
// যারা (Wei এর পরিবর্তে) ইথারে ভ্যালু দেখতে পছন্দ করে
ethers.utils.formatEther(balance)
// '2.337132817842795605'

উপলব্ধ লাইব্রেরি

Web3.js - ইথেরিয়াম JavaScript API.

Ethers.js - JavaScript এবং TypeScript-এ সম্পূর্ণ ইথেরিয়াম ওয়ালেট ইমপ্লিমেন্টেশন এবং ইউটিলিটি।

The Graph - ইথেরিয়াম এবং IPFS ডেটা ইনডেক্স করার এবং GraphQL ব্যবহার করে এটি কোয়েরি করার জন্য একটি প্রোটোকল।

Alchemy SDK - উন্নত API সহ Ethers.js-এর চারপাশে র‍্যাপার।

viem - ইথেরিয়ামের জন্য TypeScript ইন্টারফেস।

Codex - কয়েক ডজন চেইন জুড়ে রিয়েল-টাইম, সমৃদ্ধ ব্লকচেইন ডেটা API।

Drift - বিল্ট-ইন ক্যাশিং, হুক এবং টেস্ট মক সহ TypeScript মেটা-লাইব্রেরি।

আরও পড়ুন

আপনাকে সাহায্য করেছে এমন কোনো কমিউনিটি রিসোর্স সম্পর্কে জানেন? এই পেজটি এডিট করুন এবং এটি যোগ করুন!

টিউটোরিয়াল: ইথেরিয়ামে JavaScript API এবং WebSockets

  • WebSockets ব্যবহার করা – ইথেরিয়াম ইভেন্টগুলিতে সাবস্ক্রাইব করতে এবং রিয়েল-টাইম জেসন-আরপিসি রিকোয়েস্ট করতে Alchemy-এর সাথে কীভাবে WebSockets ব্যবহার করবেন।