স্মার্ট কন্ট্রাক্ট নিরাপত্তা
স্মার্ট কন্ট্রাক্টগুলি অত্যন্ত নমনীয় এবং ব্লকচেইনে ডিপ্লয় করা কোডের উপর ভিত্তি করে অপরিবর্তনীয় লজিক চালানোর পাশাপাশি প্রচুর পরিমাণে মূল্য এবং ডেটা নিয়ন্ত্রণ করতে সক্ষম। এটি আস্থা-নিরপেক্ষ এবং বিকেন্দ্রীকৃত অ্যাপ্লিকেশনগুলির একটি প্রাণবন্ত ইকোসিস্টেম তৈরি করেছে যা লিগ্যাসি সিস্টেমগুলির তুলনায় অনেক সুবিধা প্রদান করে। এগুলি স্মার্ট কন্ট্রাক্টের দুর্বলতাগুলিকে কাজে লাগিয়ে লাভবান হতে চাওয়া আক্রমণকারীদের জন্য সুযোগও তৈরি করে।
পাবলিক ব্লকচেইন, যেমন ইথেরিয়াম, স্মার্ট কন্ট্রাক্ট সুরক্ষিত করার বিষয়টিকে আরও জটিল করে তোলে। ডিপ্লয় করা কন্ট্রাক্ট কোড সাধারণত নিরাপত্তার ত্রুটিগুলি ঠিক করার জন্য পরিবর্তন করা যায় না, অন্যদিকে স্মার্ট কন্ট্রাক্ট থেকে চুরি হওয়া সম্পদগুলি ট্র্যাক করা অত্যন্ত কঠিন এবং অপরিবর্তনযোগ্যতার কারণে বেশিরভাগ ক্ষেত্রেই পুনরুদ্ধার করা অসম্ভব।
যদিও পরিসংখ্যান ভিন্ন হতে পারে, তবে অনুমান করা হয় যে স্মার্ট কন্ট্রাক্টের নিরাপত্তা ত্রুটির কারণে চুরি হওয়া বা হারিয়ে যাওয়া মূল্যের মোট পরিমাণ সহজেই $1 বিলিয়নের বেশি। এর মধ্যে রয়েছে হাই-প্রোফাইল ঘটনা, যেমন DAO হ্যাক (opens in a new tab) (3.6M ETH চুরি হয়েছে, যার বর্তমান মূল্য $1B-এর বেশি), Parity মাল্টিসিগ ওয়ালেট হ্যাক (opens in a new tab) (হ্যাকারদের কাছে $30M হারানো), এবং Parity ফ্রোজেন ওয়ালেট সমস্যা (opens in a new tab) ($300M-এর বেশি মূল্যের ETH চিরতরে লক হয়ে যাওয়া)।
উপরে উল্লিখিত সমস্যাগুলি ডেভেলপারদের জন্য নিরাপদ, শক্তিশালী এবং স্থিতিস্থাপক স্মার্ট কন্ট্রাক্ট তৈরিতে প্রচেষ্টা বিনিয়োগ করা অপরিহার্য করে তোলে। স্মার্ট কন্ট্রাক্ট নিরাপত্তা একটি অত্যন্ত গুরুত্বপূর্ণ বিষয়, এবং এটি এমন একটি বিষয় যা প্রতিটি ডেভেলপারের ভালোভাবে শেখা উচিত। এই নির্দেশিকাটি ইথেরিয়াম ডেভেলপারদের জন্য নিরাপত্তার বিবেচ্য বিষয়গুলি কভার করবে এবং স্মার্ট কন্ট্রাক্ট নিরাপত্তা উন্নত করার রিসোর্সগুলি অন্বেষণ করবে।
পূর্বশর্ত
নিরাপত্তা নিয়ে কাজ করার আগে নিশ্চিত করুন যে আপনি স্মার্ট কন্ট্রাক্ট ডেভেলপমেন্টের মৌলিক বিষয়গুলোর সাথে পরিচিত।
নিরাপদ ইথেরিয়াম স্মার্ট কন্ট্রাক্ট তৈরির নির্দেশিকা
1. সঠিক অ্যাক্সেস কন্ট্রোল ডিজাইন করুন
স্মার্ট কন্ট্রাক্টে, public বা external হিসেবে চিহ্নিত ফাংশনগুলোকে যেকোনো এক্সটার্নালি ওনড অ্যাকাউন্ট (EOA) বা কন্ট্রাক্ট অ্যাকাউন্ট কল করতে পারে। আপনি যদি চান যে অন্যরা আপনার কন্ট্রাক্টের সাথে ইন্টারঅ্যাক্ট করুক, তবে ফাংশনগুলোর জন্য পাবলিক ভিজিবিলিটি নির্দিষ্ট করা প্রয়োজন। তবে private হিসেবে চিহ্নিত ফাংশনগুলোকে শুধুমাত্র স্মার্ট কন্ট্রাক্টের ভেতরের ফাংশনগুলোই কল করতে পারে, কোনো এক্সটার্নাল অ্যাকাউন্ট নয়। নেটওয়ার্কের প্রতিটি অংশগ্রহণকারীকে কন্ট্রাক্ট ফাংশনে অ্যাক্সেস দেওয়া সমস্যার কারণ হতে পারে, বিশেষ করে যদি এর মানে হয় যে যেকেউ সংবেদনশীল কাজগুলো (যেমন, নতুন টোকেন মিন্টিং) করতে পারে।
স্মার্ট কন্ট্রাক্ট ফাংশনগুলোর অননুমোদিত ব্যবহার রোধ করতে, নিরাপদ অ্যাক্সেস কন্ট্রোল প্রয়োগ করা প্রয়োজন। অ্যাক্সেস কন্ট্রোল মেকানিজম স্মার্ট কন্ট্রাক্টের নির্দিষ্ট কিছু ফাংশন ব্যবহারের ক্ষমতাকে শুধুমাত্র অনুমোদিত সত্তাগুলোর মধ্যে সীমাবদ্ধ করে, যেমন কন্ট্রাক্ট পরিচালনার জন্য দায়ী অ্যাকাউন্টগুলো। Ownable প্যাটার্ন এবং রোল-ভিত্তিক কন্ট্রোল হলো স্মার্ট কন্ট্রাক্টে অ্যাক্সেস কন্ট্রোল প্রয়োগের জন্য দুটি কার্যকরী প্যাটার্ন:
Ownable প্যাটার্ন
Ownable প্যাটার্নে, কন্ট্রাক্ট তৈরির প্রক্রিয়ার সময় একটি ঠিকানাকে কন্ট্রাক্টের “মালিক” (owner) হিসেবে সেট করা হয়। সুরক্ষিত ফাংশনগুলোতে একটি OnlyOwner মডিফায়ার যুক্ত করা হয়, যা নিশ্চিত করে যে ফাংশনটি কার্যকর করার আগে কন্ট্রাক্টটি কলকারী ঠিকানার পরিচয় যাচাই করে। কন্ট্রাক্টের মালিক ছাড়া অন্য কোনো ঠিকানা থেকে সুরক্ষিত ফাংশনগুলোতে কল করা হলে তা সর্বদা রিভার্ট হয়, যা অবাঞ্ছিত অ্যাক্সেস প্রতিরোধ করে।
রোল-ভিত্তিক অ্যাক্সেস কন্ট্রোল
স্মার্ট কন্ট্রাক্টে একটিমাত্র ঠিকানাকে Owner হিসেবে নিবন্ধিত করা কেন্দ্রীকরণের ঝুঁকি তৈরি করে এবং এটি একটি সিঙ্গেল পয়েন্ট-অফ-ফেইলিওর (single point-of-failure) হিসেবে কাজ করে। যদি মালিকের অ্যাকাউন্টের কী (key) আপস করা হয়, তবে আক্রমণকারীরা মালিকানাধীন কন্ট্রাক্টে আক্রমণ করতে পারে। এ কারণেই একাধিক অ্যাডমিনিস্ট্রেটিভ অ্যাকাউন্টসহ একটি রোল-ভিত্তিক অ্যাক্সেস কন্ট্রোল প্যাটার্ন ব্যবহার করা আরও ভালো বিকল্প হতে পারে।
রোল-ভিত্তিক অ্যাক্সেস কন্ট্রোলে, সংবেদনশীল ফাংশনগুলোর অ্যাক্সেস বিশ্বস্ত অংশগ্রহণকারীদের একটি সেটের মধ্যে বিতরণ করা হয়। উদাহরণস্বরূপ, একটি অ্যাকাউন্ট টোকেন মিন্টিং এর জন্য দায়ী থাকতে পারে, যেখানে অন্য একটি অ্যাকাউন্ট আপগ্রেড করে বা কন্ট্রাক্টটি পজ (pause) করে। এভাবে অ্যাক্সেস কন্ট্রোল বিকেন্দ্রীকৃত করার ফলে সিঙ্গেল পয়েন্ট অফ ফেইলিওর দূর হয় এবং ব্যবহারকারীদের জন্য আস্থার অনুমান হ্রাস পায়।
মাল্টি-সিগনেচার ওয়ালেট ব্যবহার করা
নিরাপদ অ্যাক্সেস কন্ট্রোল প্রয়োগের আরেকটি পদ্ধতি হলো কন্ট্রাক্ট পরিচালনা করার জন্য একটি মাল্টি-সিগনেচার অ্যাকাউন্ট ব্যবহার করা। একটি সাধারণ EOA-এর বিপরীতে, মাল্টি-সিগনেচার অ্যাকাউন্টগুলোর মালিকানায় একাধিক সত্তা থাকে এবং ট্রানজ্যাকশন কার্যকর করার জন্য ন্যূনতম সংখ্যক অ্যাকাউন্টের (যেমন 5 টির মধ্যে 3 টি) স্বাক্ষরের প্রয়োজন হয়।
অ্যাক্সেস কন্ট্রোলের জন্য একটি মাল্টিসিগ ব্যবহার করা নিরাপত্তার একটি অতিরিক্ত স্তর যুক্ত করে, কারণ টার্গেট কন্ট্রাক্টে কোনো কাজ করার জন্য একাধিক পক্ষের সম্মতির প্রয়োজন হয়। এটি বিশেষভাবে কার্যকর যদি Ownable প্যাটার্ন ব্যবহার করা প্রয়োজনীয় হয়, কারণ এটি কোনো আক্রমণকারী বা ক্ষতিকারক ইনসাইডারের পক্ষে দূষিত উদ্দেশ্যে সংবেদনশীল কন্ট্রাক্ট ফাংশনগুলোকে ম্যানিপুলেট করা আরও কঠিন করে তোলে।
2. কন্ট্রাক্ট অপারেশনগুলো সুরক্ষিত রাখতে require(), assert() এবং revert() স্টেটমেন্ট ব্যবহার করুন
যেমনটি উল্লেখ করা হয়েছে, আপনার স্মার্ট কন্ট্রাক্ট একবার ব্লকচেইনে ডিপ্লয়মেন্ট হয়ে গেলে যেকেউ এর পাবলিক ফাংশনগুলো কল করতে পারে। যেহেতু আপনি আগে থেকে জানতে পারবেন না যে এক্সটার্নাল অ্যাকাউন্টগুলো কীভাবে একটি কন্ট্রাক্টের সাথে ইন্টারঅ্যাক্ট করবে, তাই ডিপ্লয়মেন্টের আগে সমস্যাযুক্ত অপারেশনগুলোর বিরুদ্ধে অভ্যন্তরীণ সুরক্ষাব্যবস্থা প্রয়োগ করা আদর্শ। আপনি require(), assert() এবং revert() স্টেটমেন্ট ব্যবহার করে স্মার্ট কন্ট্রাক্টে সঠিক আচরণ নিশ্চিত করতে পারেন, যা নির্দিষ্ট প্রয়োজনীয়তা পূরণে ব্যর্থ হলে এক্সেপশন ট্রিগার করে এবং স্টেট পরিবর্তনগুলো রিভার্ট করে।
require(): require ফাংশনের শুরুতে সংজ্ঞায়িত করা হয় এবং এটি নিশ্চিত করে যে কল করা ফাংশনটি কার্যকর হওয়ার আগে পূর্বনির্ধারিত শর্তগুলো পূরণ হয়েছে। একটি require স্টেটমেন্ট ব্যবহার করে ব্যবহারকারীর ইনপুট যাচাই করা, স্টেট ভেরিয়েবল চেক করা বা ফাংশনের কাজ এগিয়ে নেওয়ার আগে কলকারী অ্যাকাউন্টের পরিচয় প্রমাণ করা যেতে পারে।
assert(): assert() ব্যবহার করা হয় অভ্যন্তরীণ ত্রুটি শনাক্ত করতে এবং আপনার কোডে “ইনভ্যারিয়েন্ট” (invariants) লঙ্ঘনের বিষয়টি পরীক্ষা করতে। ইনভ্যারিয়েন্ট হলো একটি কন্ট্রাক্টের স্টেট সম্পর্কে একটি যৌক্তিক দাবি, যা সমস্ত ফাংশন এক্সিকিউশনের জন্য সত্য হওয়া উচিত। ইনভ্যারিয়েন্টের একটি উদাহরণ হলো একটি টোকেন কন্ট্রাক্টের সর্বোচ্চ মোট সরবরাহ বা ব্যালেন্স। assert() ব্যবহার করা নিশ্চিত করে যে আপনার কন্ট্রাক্ট কখনোই কোনো ঝুঁকিপূর্ণ স্টেটে পৌঁছাবে না, এবং যদি পৌঁছায়ও, তবে স্টেট ভেরিয়েবলের সমস্ত পরিবর্তন রোল ব্যাক করা হয়।
revert(): revert() একটি if-else স্টেটমেন্টে ব্যবহার করা যেতে পারে, যা প্রয়োজনীয় শর্ত পূরণ না হলে একটি এক্সেপশন ট্রিগার করে। নিচের নমুনা কন্ট্রাক্টটি ফাংশনগুলোর এক্সিকিউশন সুরক্ষিত রাখতে revert() ব্যবহার করে:
pragma solidity ^0.8.4;
contract VendingMachine {
address owner;
error Unauthorized();
function buy(uint amount) public payable {
if (amount > msg.value / 2 ether)
revert("Not enough Ether provided.");
// কেনাকাটা সম্পন্ন করুন।
}
function withdraw() public {
if (msg.sender != owner)
revert Unauthorized();
payable(msg.sender).transfer(address(this).balance);
}
}
3. স্মার্ট কন্ট্রাক্ট পরীক্ষা করুন এবং কোডের সঠিকতা যাচাই করুন
ইথেরিয়াম ভার্চুয়াল মেশিন-এ চলা কোডের অপরিবর্তনযোগ্যতা মানে হলো, ডেভেলপমেন্ট পর্যায়ে স্মার্ট কন্ট্রাক্টগুলোর জন্য উচ্চতর স্তরের গুণমান মূল্যায়নের প্রয়োজন। আপনার কন্ট্রাক্টটি ব্যাপকভাবে পরীক্ষা করা এবং কোনো অপ্রত্যাশিত ফলাফলের জন্য এটি পর্যবেক্ষণ করা নিরাপত্তাকে অনেকাংশে উন্নত করবে এবং দীর্ঘমেয়াদে আপনার ব্যবহারকারীদের রক্ষা করবে।
সাধারণ পদ্ধতি হলো মক ডেটা ব্যবহার করে ছোট ছোট ইউনিট টেস্ট লেখা, যা কন্ট্রাক্টটি ব্যবহারকারীদের কাছ থেকে পাবে বলে আশা করা হয়। নির্দিষ্ট ফাংশনগুলোর কার্যকারিতা পরীক্ষা করতে এবং একটি স্মার্ট কন্ট্রাক্ট প্রত্যাশা অনুযায়ী কাজ করছে কিনা তা নিশ্চিত করতে ইউনিট টেস্টিং বেশ ভালো।
দুর্ভাগ্যবশত, যখন বিচ্ছিন্নভাবে ব্যবহার করা হয়, তখন স্মার্ট কন্ট্রাক্টের নিরাপত্তা উন্নত করার ক্ষেত্রে ইউনিট টেস্টিং খুব সামান্যই কার্যকর। একটি ইউনিট টেস্ট প্রমাণ করতে পারে যে একটি ফাংশন মক ডেটার জন্য সঠিকভাবে কাজ করে, তবে ইউনিট টেস্টগুলো কেবল ততটাই কার্যকর যতটা ভালোভাবে টেস্টগুলো লেখা হয়। এটি মিস হয়ে যাওয়া এজ কেস (edge cases) এবং দুর্বলতাগুলো শনাক্ত করা কঠিন করে তোলে, যা আপনার স্মার্ট কন্ট্রাক্টের নিরাপত্তাকে ভেঙে দিতে পারে।
একটি ভালো পদ্ধতি হলো ইউনিট টেস্টিংয়ের সাথে স্ট্যাটিক এবং ডায়নামিক অ্যানালাইসিস ব্যবহার করে প্রপার্টি-ভিত্তিক টেস্টিং যুক্ত করা। স্ট্যাটিক অ্যানালাইসিস পৌঁছানো যায় এমন প্রোগ্রাম স্টেট এবং এক্সিকিউশন পাথগুলো বিশ্লেষণ করতে লো-লেভেল রিপ্রেজেন্টেশনের ওপর নির্ভর করে, যেমন কন্ট্রোল ফ্লো গ্রাফ (opens in a new tab) এবং অ্যাবস্ট্রাক্ট সিনট্যাক্স ট্রি (opens in a new tab)। অন্যদিকে, ডায়নামিক অ্যানালাইসিস কৌশলগুলো, যেমন স্মার্ট কন্ট্রাক্ট ফাজিং (opens in a new tab), নিরাপত্তা বৈশিষ্ট্য লঙ্ঘন করে এমন অপারেশনগুলো শনাক্ত করতে র্যান্ডম ইনপুট ভ্যালু দিয়ে কন্ট্রাক্ট কোড এক্সিকিউট করে।
স্মার্ট কন্ট্রাক্টে নিরাপত্তা বৈশিষ্ট্য যাচাই করার আরেকটি কৌশল হলো বিধিবদ্ধ যাচাইকরণ। নিয়মিত টেস্টিংয়ের বিপরীতে, বিধিবদ্ধ যাচাইকরণ একটি স্মার্ট কন্ট্রাক্টে ত্রুটির অনুপস্থিতি চূড়ান্তভাবে প্রমাণ করতে পারে। এটি একটি বিধিবদ্ধ স্পেসিফিকেশন তৈরি করে অর্জন করা হয় যা কাঙ্ক্ষিত নিরাপত্তা বৈশিষ্ট্যগুলো ধারণ করে এবং প্রমাণ করে যে কন্ট্রাক্টগুলোর একটি বিধিবদ্ধ মডেল এই স্পেসিফিকেশন মেনে চলে।
4. আপনার কোডের একটি স্বাধীন পর্যালোচনার জন্য অনুরোধ করুন
আপনার কন্ট্রাক্ট পরীক্ষা করার পর, কোনো নিরাপত্তা সমস্যার জন্য সোর্স কোডটি চেক করতে অন্যদের বলা ভালো। টেস্টিং একটি স্মার্ট কন্ট্রাক্টের প্রতিটি ত্রুটি উন্মোচন করবে না, তবে একটি স্বাধীন পর্যালোচনা পেলে দুর্বলতাগুলো শনাক্ত করার সম্ভাবনা বেড়ে যায়।
অডিট
একটি স্মার্ট কন্ট্রাক্ট অডিট করানো হলো স্বাধীন কোড পর্যালোচনা পরিচালনার একটি উপায়। স্মার্ট কন্ট্রাক্টগুলো নিরাপদ এবং গুণগত ত্রুটি ও ডিজাইনের ভুল থেকে মুক্ত কিনা তা নিশ্চিত করতে অডিটররা গুরুত্বপূর্ণ ভূমিকা পালন করে।
তা সত্ত্বেও, আপনার অডিটকে সব সমস্যার সমাধান (silver bullet) হিসেবে বিবেচনা করা এড়ানো উচিত। স্মার্ট কন্ট্রাক্ট অডিট প্রতিটি বাগ ধরতে পারে না এবং এগুলো মূলত পর্যালোচনার একটি অতিরিক্ত রাউন্ড প্রদান করার জন্য ডিজাইন করা হয়েছে, যা প্রাথমিক ডেভেলপমেন্ট এবং টেস্টিংয়ের সময় ডেভেলপারদের মিস করা সমস্যাগুলো শনাক্ত করতে সাহায্য করতে পারে। স্মার্ট কন্ট্রাক্ট অডিটের সুবিধা সর্বাধিক করতে আপনার অডিটরদের সাথে কাজ করার সর্বোত্তম অনুশীলনগুলোও অনুসরণ করা উচিত, যেমন কোড সঠিকভাবে ডকুমেন্ট করা এবং ইনলাইন কমেন্ট যোগ করা।
- স্মার্ট কন্ট্রাক্ট অডিটিংয়ের টিপস এবং ট্রিকস (opens in a new tab) - @tinchoabbate
- আপনার অডিটের সর্বোচ্চ ব্যবহার করুন (opens in a new tab) - Inference
বাগ বাউন্টি
একটি বাগ বাউন্টি প্রোগ্রাম সেট আপ করা হলো এক্সটার্নাল কোড পর্যালোচনা প্রয়োগের আরেকটি পদ্ধতি। বাগ বাউন্টি হলো একটি আর্থিক পুরস্কার যা এমন ব্যক্তিদের (সাধারণত হোয়াইটহ্যাট হ্যাকারদের) দেওয়া হয় যারা কোনো অ্যাপ্লিকেশনে দুর্বলতা আবিষ্কার করে।
সঠিকভাবে ব্যবহার করা হলে, বাগ বাউন্টি হ্যাকার কমিউনিটির সদস্যদের আপনার কোডে গুরুতর ত্রুটিগুলো পরীক্ষা করার জন্য উৎসাহিত করে। এর একটি বাস্তব উদাহরণ হলো “ইনফিনিট মানি বাগ” (infinite money bug), যা কোনো আক্রমণকারীকে ইথেরিয়ামে চলা একটি লেয়ার ২ (l2) প্রোটোকল অপটিমিজম (opens in a new tab)-এ সীমাহীন পরিমাণ ইথার তৈরি করতে দিত। সৌভাগ্যবশত, একজন হোয়াইটহ্যাট হ্যাকার ত্রুটিটি আবিষ্কার করেন (opens in a new tab) এবং টিমকে জানান, যার ফলে তিনি একটি বড় অঙ্কের অর্থ উপার্জন করেন (opens in a new tab)।
একটি কার্যকরী কৌশল হলো ঝুঁকিতে থাকা ফান্ডের পরিমাণের অনুপাতে বাগ বাউন্টি প্রোগ্রামের পেআউট নির্ধারণ করা। “স্কেলিং বাগ বাউন্টি (opens in a new tab)” হিসেবে পরিচিত এই পদ্ধতিটি ব্যক্তিদের দুর্বলতাগুলো কাজে লাগানোর পরিবর্তে দায়িত্বশীলভাবে প্রকাশ করার জন্য আর্থিক প্রণোদনা প্রদান করে।
5. স্মার্ট কন্ট্রাক্ট ডেভেলপমেন্টের সময় সর্বোত্তম অনুশীলনগুলো অনুসরণ করুন
অডিট এবং বাগ বাউন্টির অস্তিত্ব আপনাকে উচ্চ-মানের কোড লেখার দায়িত্ব থেকে অব্যাহতি দেয় না। ভালো স্মার্ট কন্ট্রাক্ট নিরাপত্তা শুরু হয় সঠিক ডিজাইন এবং ডেভেলপমেন্ট প্রক্রিয়া অনুসরণ করার মাধ্যমে:
-
সমস্ত কোড একটি ভার্সন কন্ট্রোল সিস্টেমে সংরক্ষণ করুন, যেমন git
-
পুল রিকোয়েস্টের মাধ্যমে কোডের সমস্ত পরিবর্তন করুন
-
নিশ্চিত করুন যে পুল রিকোয়েস্টগুলোতে অন্তত একজন স্বাধীন পর্যালোচক আছেন—যদি আপনি কোনো প্রজেক্টে একাকী কাজ করেন, তবে অন্য ডেভেলপারদের খুঁজে বের করার এবং কোড পর্যালোচনার বিনিময় করার কথা বিবেচনা করুন
-
স্মার্ট কন্ট্রাক্টগুলো টেস্টিং, কম্পাইল করা এবং ডিপ্লয়মেন্টের জন্য একটি ডেভেলপমেন্ট এনভায়রনমেন্ট ব্যবহার করুন
-
আপনার কোডটি বেসিক কোড অ্যানালাইসিস টুলগুলোর মাধ্যমে রান করুন, যেমন Cyfrin Aderyn (opens in a new tab), Mythril এবং স্লিদার। আদর্শভাবে, প্রতিটি পুল রিকোয়েস্ট মার্জ করার আগে আপনার এটি করা উচিত এবং আউটপুটের পার্থক্যগুলো তুলনা করা উচিত
-
নিশ্চিত করুন যে আপনার কোড কোনো ত্রুটি ছাড়াই কম্পাইল হয় এবং Solidity কম্পাইলার কোনো সতর্কতা দেখায় না
-
আপনার কোডটি সঠিকভাবে ডকুমেন্ট করুন (NatSpec (opens in a new tab) ব্যবহার করে) এবং সহজে বোঝা যায় এমন ভাষায় কন্ট্রাক্ট আর্কিটেকচার সম্পর্কে বিস্তারিত বর্ণনা করুন। এটি অন্যদের জন্য আপনার কোড অডিট এবং পর্যালোচনা করা সহজ করে তুলবে।
6. শক্তিশালী দুর্যোগ পুনরুদ্ধার পরিকল্পনা বাস্তবায়ন করুন
নিরাপদ অ্যাক্সেস কন্ট্রোল ডিজাইন করা, ফাংশন মডিফায়ার প্রয়োগ করা এবং অন্যান্য পরামর্শগুলো স্মার্ট কন্ট্রাক্টের নিরাপত্তা উন্নত করতে পারে, তবে এগুলো ক্ষতিকারক এক্সপ্লয়েটের সম্ভাবনাকে উড়িয়ে দিতে পারে না। নিরাপদ স্মার্ট কন্ট্রাক্ট তৈরির জন্য “ব্যর্থতার জন্য প্রস্তুতি” এবং আক্রমণের কার্যকর প্রতিক্রিয়া জানানোর জন্য একটি ফলব্যাক প্ল্যান থাকা প্রয়োজন। একটি সঠিক দুর্যোগ পুনরুদ্ধার পরিকল্পনায় নিচের কিছু বা সমস্ত উপাদান অন্তর্ভুক্ত থাকবে:
কন্ট্রাক্ট আপগ্রেড
যদিও ইথেরিয়াম স্মার্ট কন্ট্রাক্টগুলো ডিফল্টভাবে অপরিবর্তনীয়, তবে আপগ্রেড প্যাটার্ন ব্যবহার করে কিছুটা পরিবর্তনযোগ্যতা অর্জন করা সম্ভব। এমন ক্ষেত্রে কন্ট্রাক্ট আপগ্রেড করা প্রয়োজন যেখানে একটি গুরুতর ত্রুটি আপনার পুরোনো কন্ট্রাক্টটিকে অকেজো করে দেয় এবং নতুন লজিক ডিপ্লয়মেন্ট করা সবচেয়ে কার্যকর বিকল্প হয়।
কন্ট্রাক্ট আপগ্রেড মেকানিজমগুলো ভিন্নভাবে কাজ করে, তবে স্মার্ট কন্ট্রাক্ট আপগ্রেড করার জন্য “প্রক্সি প্যাটার্ন” হলো অন্যতম জনপ্রিয় পদ্ধতি। প্রক্সি প্যাটার্ন (opens in a new tab) একটি অ্যাপ্লিকেশনের স্টেট এবং লজিককে দুটি কন্ট্রাক্টের মধ্যে বিভক্ত করে। প্রথম কন্ট্রাক্টটি (যাকে ‘প্রক্সি চুক্তি’ বলা হয়) স্টেট ভেরিয়েবলগুলো (যেমন, ব্যবহারকারীর ব্যালেন্স) সংরক্ষণ করে, যেখানে দ্বিতীয় কন্ট্রাক্টটি (যাকে ‘লজিক কন্ট্রাক্ট’ বলা হয়) কন্ট্রাক্ট ফাংশনগুলো কার্যকর করার কোড ধারণ করে।
অ্যাকাউন্টগুলো প্রক্সি চুক্তির সাথে ইন্টারঅ্যাক্ট করে, যা delegatecall() (opens in a new tab) লো-লেভেল কল ব্যবহার করে সমস্ত ফাংশন কলকে লজিক কন্ট্রাক্টে পাঠায়। একটি সাধারণ মেসেজ কলের বিপরীতে, delegatecall() নিশ্চিত করে যে লজিক কন্ট্রাক্টের ঠিকানায় চলা কোডটি কলিং কন্ট্রাক্টের প্রেক্ষাপটে কার্যকর হয়। এর মানে হলো লজিক কন্ট্রাক্ট সর্বদা প্রক্সির স্টোরেজে (নিজের স্টোরেজের পরিবর্তে) লিখবে এবং msg.sender ও msg.value এর মূল মানগুলো সংরক্ষিত থাকবে।
লজিক কন্ট্রাক্টে কলগুলো অর্পণ করার জন্য প্রক্সি চুক্তির স্টোরেজে এর ঠিকানা সংরক্ষণ করা প্রয়োজন। অতএব, কন্ট্রাক্টের লজিক আপগ্রেড করা মানে হলো কেবল আরেকটি লজিক কন্ট্রাক্ট ডিপ্লয়মেন্ট করা এবং প্রক্সি চুক্তিতে নতুন ঠিকানাটি সংরক্ষণ করা। যেহেতু প্রক্সি চুক্তিতে পরবর্তী কলগুলো স্বয়ংক্রিয়ভাবে নতুন লজিক কন্ট্রাক্টে রাউট করা হয়, তাই আপনি আসলে কোড পরিবর্তন না করেই কন্ট্রাক্টটি “আপগ্রেড” করে ফেলবেন।
কন্ট্রাক্ট আপগ্রেড করা সম্পর্কে আরও জানুন।
ইমার্জেন্সি স্টপ
যেমনটি উল্লেখ করা হয়েছে, ব্যাপক অডিটিং এবং টেস্টিং একটি স্মার্ট কন্ট্রাক্টের সমস্ত বাগ আবিষ্কার করতে পারে না। ডিপ্লয়মেন্টের পরে যদি আপনার কোডে কোনো দুর্বলতা দেখা দেয়, তবে এটি প্যাচ করা অসম্ভব কারণ আপনি কন্ট্রাক্টের ঠিকানায় চলা কোডটি পরিবর্তন করতে পারবেন না। এছাড়াও, আপগ্রেড মেকানিজমগুলো (যেমন, প্রক্সি প্যাটার্ন) প্রয়োগ করতে সময় লাগতে পারে (এগুলোর জন্য প্রায়ই বিভিন্ন পক্ষের অনুমোদনের প্রয়োজন হয়), যা আক্রমণকারীদের আরও ক্ষতি করার জন্য কেবল আরও বেশি সময় দেয়।
চূড়ান্ত বিকল্প হলো একটি “ইমার্জেন্সি স্টপ” (emergency stop) ফাংশন প্রয়োগ করা যা কোনো কন্ট্রাক্টের দুর্বল ফাংশনগুলোতে কল করা ব্লক করে। ইমার্জেন্সি স্টপগুলোতে সাধারণত নিচের উপাদানগুলো থাকে:
-
একটি গ্লোবাল বুলিয়ান ভেরিয়েবল যা নির্দেশ করে যে স্মার্ট কন্ট্রাক্টটি বন্ধ স্টেটে আছে কি না। কন্ট্রাক্ট সেট আপ করার সময় এই ভেরিয়েবলটি
falseএ সেট করা হয়, তবে কন্ট্রাক্টটি বন্ধ হয়ে গেলে এটিtrueএ রিভার্ট হবে। -
এমন ফাংশন যা তাদের এক্সিকিউশনে বুলিয়ান ভেরিয়েবলকে রেফারেন্স করে। স্মার্ট কন্ট্রাক্ট বন্ধ না থাকলে এই ধরনের ফাংশনগুলো অ্যাক্সেসযোগ্য থাকে এবং ইমার্জেন্সি স্টপ ফিচারটি ট্রিগার হলে এগুলো অ্যাক্সেসযোগ্য থাকে না।
-
এমন একটি সত্তা যার ইমার্জেন্সি স্টপ ফাংশনে অ্যাক্সেস আছে, যা বুলিয়ান ভেরিয়েবলটিকে
trueএ সেট করে। ক্ষতিকারক কাজগুলো প্রতিরোধ করতে, এই ফাংশনে কলগুলো একটি বিশ্বস্ত ঠিকানায় (যেমন, কন্ট্রাক্টের মালিক) সীমাবদ্ধ করা যেতে পারে।
একবার কন্ট্রাক্টটি ইমার্জেন্সি স্টপ সক্রিয় করলে, নির্দিষ্ট কিছু ফাংশন কল করা যাবে না। এটি গ্লোবাল ভেরিয়েবলকে রেফারেন্স করে এমন একটি মডিফায়ারে নির্বাচিত ফাংশনগুলোকে র্যাপ (wrap) করে অর্জন করা হয়। নিচে কন্ট্রাক্টগুলোতে এই প্যাটার্নের একটি বাস্তবায়ন বর্ণনা করে এমন একটি উদাহরণ (opens in a new tab) দেওয়া হলো:
// এই কোডটি পেশাদারভাবে অডিট করা হয়নি এবং এর নিরাপত্তা বা সঠিকতা সম্পর্কে কোনো প্রতিশ্রুতি দেয় না। নিজ ঝুঁকিতে ব্যবহার করুন।
contract EmergencyStop {
bool isStopped = false;
modifier stoppedInEmergency {
require(!isStopped);
_;
}
modifier onlyWhenStopped {
require(isStopped);
_;
}
modifier onlyAuthorized {
// এখানে msg.sender-এর অনুমোদন চেক করুন
_;
}
function stopContract() public onlyAuthorized {
isStopped = true;
}
function resumeContract() public onlyAuthorized {
isStopped = false;
}
function deposit() public payable stoppedInEmergency {
// ডিপোজিট লজিক এখানে ঘটছে
}
function emergencyWithdraw() public onlyWhenStopped {
// জরুরি উইথড্র এখানে ঘটছে
}
}
এই উদাহরণটি ইমার্জেন্সি স্টপের মৌলিক বৈশিষ্ট্যগুলো দেখায়:
-
isStoppedহলো একটি বুলিয়ান যা শুরুতেfalseএবং কন্ট্রাক্টটি ইমার্জেন্সি মোডে প্রবেশ করলেtrueমূল্যায়ন করে। -
ফাংশন মডিফায়ার
onlyWhenStoppedএবংstoppedInEmergencyisStoppedভেরিয়েবলটি চেক করে।stoppedInEmergencyব্যবহার করা হয় এমন ফাংশনগুলো নিয়ন্ত্রণ করতে যা কন্ট্রাক্টটি ঝুঁকিপূর্ণ হলে অ্যাক্সেসযোগ্য হওয়া উচিত নয় (যেমন,deposit())। এই ফাংশনগুলোতে কলগুলো কেবল রিভার্ট হবে।
onlyWhenStopped এমন ফাংশনগুলোর জন্য ব্যবহার করা হয় যা ইমার্জেন্সির সময় কল করা উচিত (যেমন, emergencyWithdraw())। এই ধরনের ফাংশনগুলো পরিস্থিতি সমাধানে সাহায্য করতে পারে, তাই এগুলোকে “সীমাবদ্ধ ফাংশন” (restricted functions) তালিকা থেকে বাদ দেওয়া হয়েছে।
একটি ইমার্জেন্সি স্টপ কার্যকারিতা ব্যবহার করা আপনার স্মার্ট কন্ট্রাক্টের গুরুতর দুর্বলতাগুলো মোকাবিলা করার জন্য একটি কার্যকর সাময়িক সমাধান প্রদান করে। তবে, এটি ব্যবহারকারীদের ডেভেলপারদের ওপর আস্থা রাখার প্রয়োজনীয়তা বাড়িয়ে দেয় যাতে তারা নিজেদের স্বার্থে এটি সক্রিয় না করে। এই লক্ষ্যে, ইমার্জেন্সি স্টপের নিয়ন্ত্রণকে একটি অনচেইন ভোটিং মেকানিজম, টাইমক্লক বা একটি মাল্টিসিগ ওয়ালেটের অনুমোদনের অধীন করে বিকেন্দ্রীকৃত করা সম্ভাব্য সমাধান হতে পারে।
ইভেন্ট মনিটরিং
ইভেন্ট (opens in a new tab) আপনাকে স্মার্ট কন্ট্রাক্ট ফাংশনগুলোতে কল ট্র্যাক করতে এবং স্টেট ভেরিয়েবলের পরিবর্তনগুলো পর্যবেক্ষণ করতে দেয়। যখনই কোনো পক্ষ নিরাপত্তা-সংবেদনশীল কাজ (যেমন, ফান্ড উত্তোলন) করে, তখনই একটি ইভেন্ট এমিট (emit) করার জন্য আপনার স্মার্ট কন্ট্রাক্ট প্রোগ্রাম করা আদর্শ।
ইভেন্টগুলো লগ করা এবং সেগুলোকে অফচেইন পর্যবেক্ষণ করা কন্ট্রাক্ট অপারেশনগুলোর ওপর অন্তর্দৃষ্টি প্রদান করে এবং ক্ষতিকারক কাজগুলো দ্রুত আবিষ্কার করতে সহায়তা করে। এর মানে হলো আপনার টিম হ্যাকের ক্ষেত্রে দ্রুত প্রতিক্রিয়া জানাতে পারে এবং ব্যবহারকারীদের ওপর প্রভাব কমানোর জন্য পদক্ষেপ নিতে পারে, যেমন ফাংশনগুলো পজ করা বা আপগ্রেড করা।
আপনি একটি অফ-দ্য-শেল্ফ (off-the-shelf) মনিটরিং টুলও বেছে নিতে পারেন যা কেউ আপনার কন্ট্রাক্টগুলোর সাথে ইন্টারঅ্যাক্ট করলেই স্বয়ংক্রিয়ভাবে অ্যালার্ট পাঠায়। এই টুলগুলো আপনাকে বিভিন্ন ট্রিগারের ওপর ভিত্তি করে কাস্টম অ্যালার্ট তৈরি করতে দেবে, যেমন ট্রানজ্যাকশন ভলিউম, ফাংশন কলের ফ্রিকোয়েন্সি বা জড়িত নির্দিষ্ট ফাংশনগুলো। উদাহরণস্বরূপ, আপনি এমন একটি অ্যালার্ট প্রোগ্রাম করতে পারেন যা একটি একক ট্রানজ্যাকশনে উত্তোলিত পরিমাণ একটি নির্দিষ্ট থ্রেশহোল্ড অতিক্রম করলে আসে।
7. নিরাপদ গভর্ন্যান্স সিস্টেম ডিজাইন করুন
আপনি মূল স্মার্ট কন্ট্রাক্টগুলোর নিয়ন্ত্রণ কমিউনিটি সদস্যদের হাতে তুলে দিয়ে আপনার অ্যাপ্লিকেশনটিকে বিকেন্দ্রীকৃত করতে চাইতে পারেন। এক্ষেত্রে, স্মার্ট কন্ট্রাক্ট সিস্টেমে একটি গভর্ন্যান্স মডিউল অন্তর্ভুক্ত থাকবে—এমন একটি মেকানিজম যা কমিউনিটি সদস্যদের একটি অনচেইন গভর্ন্যান্স সিস্টেমের মাধ্যমে অ্যাডমিনিস্ট্রেটিভ কাজগুলো অনুমোদন করতে দেয়। উদাহরণস্বরূপ, একটি প্রক্সি চুক্তিকে নতুন ইমপ্লিমেন্টেশনে আপগ্রেড করার একটি প্রস্তাব টোকেন-হোল্ডারদের দ্বারা ভোট দেওয়া হতে পারে।
বিকেন্দ্রীকৃত গভর্ন্যান্স উপকারী হতে পারে, বিশেষ করে কারণ এটি ডেভেলপার এবং শেষ-ব্যবহারকারীদের স্বার্থকে একীভূত করে। তা সত্ত্বেও, স্মার্ট কন্ট্রাক্ট গভর্ন্যান্স মেকানিজমগুলো ভুলভাবে প্রয়োগ করা হলে নতুন ঝুঁকি তৈরি করতে পারে। একটি সম্ভাব্য পরিস্থিতি হলো যদি কোনো আক্রমণকারী একটি ফ্ল্যাশ লোন নিয়ে বিপুল ভোটিং ক্ষমতা (ধারণ করা টোকেনের সংখ্যায় পরিমাপ করা) অর্জন করে এবং একটি ক্ষতিকারক প্রস্তাব পাস করিয়ে নেয়।
অনচেইন গভর্ন্যান্স সম্পর্কিত সমস্যাগুলো প্রতিরোধের একটি উপায় হলো টাইমলক ব্যবহার করা (opens in a new tab)। একটি টাইমলক একটি নির্দিষ্ট সময় পার না হওয়া পর্যন্ত স্মার্ট কন্ট্রাক্টকে নির্দিষ্ট কাজগুলো সম্পাদন করতে বাধা দেয়। অন্যান্য কৌশলগুলোর মধ্যে রয়েছে প্রতিটি টোকেন কতক্ষণ ধরে লক করা আছে তার ওপর ভিত্তি করে একটি “ভোটিং ওয়েট” (voting weight) নির্ধারণ করা, অথবা বর্তমান ব্লকের পরিবর্তে একটি ঐতিহাসিক সময়ের (উদাহরণস্বরূপ, অতীতের 2-3 ব্লক) ঠিকানার ভোটিং ক্ষমতা পরিমাপ করা। উভয় পদ্ধতিই অনচেইন ভোটগুলোকে প্রভাবিত করার জন্য দ্রুত ভোটিং ক্ষমতা সংগ্রহ করার সম্ভাবনা হ্রাস করে।
শেয়ার করা লিঙ্কগুলোতে নিরাপদ গভর্ন্যান্স সিস্টেম ডিজাইন করা (opens in a new tab), DAO-তে বিভিন্ন ভোটিং মেকানিজম (opens in a new tab) এবং DeFi ব্যবহার করে সাধারণ DAO অ্যাটাক ভেক্টরগুলো (opens in a new tab) সম্পর্কে আরও জানুন।
8. কোডের জটিলতা সর্বনিম্নে কমিয়ে আনুন
ঐতিহ্যবাহী সফটওয়্যার ডেভেলপাররা KISS (“keep it simple, stupid”) নীতির সাথে পরিচিত, যা সফটওয়্যার ডিজাইনে অপ্রয়োজনীয় জটিলতা যুক্ত করার বিরুদ্ধে পরামর্শ দেয়। এটি দীর্ঘদিনের চিন্তাধারা অনুসরণ করে যে “জটিল সিস্টেমগুলো জটিল উপায়ে ব্যর্থ হয়” এবং এগুলো ব্যয়বহুল ত্রুটির প্রতি বেশি সংবেদনশীল।
স্মার্ট কন্ট্রাক্ট লেখার সময় বিষয়গুলোকে সহজ রাখা বিশেষভাবে গুরুত্বপূর্ণ, কারণ স্মার্ট কন্ট্রাক্টগুলো সম্ভাব্যভাবে বিপুল পরিমাণ মূল্য নিয়ন্ত্রণ করে। স্মার্ট কন্ট্রাক্ট লেখার সময় সরলতা অর্জনের একটি টিপ হলো যেখানে সম্ভব বিদ্যমান লাইব্রেরিগুলো, যেমন ওপেনজেপেলিন কন্ট্রাক্টস (opens in a new tab) পুনরায় ব্যবহার করা। যেহেতু এই লাইব্রেরিগুলো ডেভেলপারদের দ্বারা ব্যাপকভাবে অডিট এবং পরীক্ষা করা হয়েছে, তাই এগুলো ব্যবহার করলে স্ক্র্যাচ থেকে নতুন কার্যকারিতা লিখে বাগ তৈরি করার সম্ভাবনা কমে যায়।
আরেকটি সাধারণ পরামর্শ হলো ছোট ফাংশন লেখা এবং একাধিক কন্ট্রাক্ট জুড়ে বিজনেস লজিক বিভক্ত করে কন্ট্রাক্টগুলোকে মডুলার রাখা। সহজ কোড লেখা কেবল স্মার্ট কন্ট্রাক্টে আক্রমণের ক্ষেত্রই কমায় না, এটি সামগ্রিক সিস্টেমের সঠিকতা সম্পর্কে যুক্তি দেওয়া এবং সম্ভাব্য ডিজাইনের ত্রুটিগুলো আগে থেকেই শনাক্ত করা সহজ করে তোলে।
9. সাধারণ স্মার্ট কন্ট্রাক্ট দুর্বলতাগুলোর বিরুদ্ধে রক্ষা করুন
রিএন্ট্রান্সি
EVM কনকারেন্সি (concurrency) অনুমোদন করে না, যার মানে হলো একটি মেসেজ কলে জড়িত দুটি কন্ট্রাক্ট একই সাথে চলতে পারে না। একটি এক্সটার্নাল কল কলিং কন্ট্রাক্টের এক্সিকিউশন এবং মেমরিকে কলটি ফিরে না আসা পর্যন্ত পজ করে রাখে, এরপর এক্সিকিউশন স্বাভাবিকভাবে এগিয়ে যায়। এই প্রক্রিয়াটিকে আনুষ্ঠানিকভাবে অন্য একটি কন্ট্রাক্টে কন্ট্রোল ফ্লো (opens in a new tab) স্থানান্তর হিসেবে বর্ণনা করা যেতে পারে।
যদিও এটি বেশিরভাগ ক্ষেত্রেই ক্ষতিকারক নয়, তবে অবিশ্বস্ত কন্ট্রাক্টগুলোতে কন্ট্রোল ফ্লো স্থানান্তর করা রিএন্ট্রান্সির মতো সমস্যার কারণ হতে পারে। একটি রিএন্ট্রান্সি আক্রমণ তখন ঘটে যখন একটি ক্ষতিকারক কন্ট্রাক্ট মূল ফাংশন ইনভোকেশন (invocation) সম্পূর্ণ হওয়ার আগেই একটি দুর্বল কন্ট্রাক্টে কল ব্যাক করে। এই ধরনের আক্রমণ একটি উদাহরণের সাহায্যে সবচেয়ে ভালোভাবে ব্যাখ্যা করা যায়।
ধরা যাক একটি সাধারণ স্মার্ট কন্ট্রাক্ট (‘Victim’) যা যেকাউকে ইথার জমা এবং উত্তোলন করতে দেয়:
// এই কন্ট্রাক্টটি ঝুঁকিপূর্ণ। প্রোডাকশনে ব্যবহার করবেন না
contract Victim {
mapping (address => uint256) public balances;
function deposit() external payable {
balances[msg.sender] += msg.value;
}
function withdraw() external {
uint256 amount = balances[msg.sender];
(bool success, ) = msg.sender.call.value(amount)("");
require(success);
balances[msg.sender] = 0;
}
}
এই কন্ট্রাক্টটি ব্যবহারকারীদের কন্ট্রাক্টে আগে জমা করা ETH উত্তোলন করার অনুমতি দেওয়ার জন্য একটি withdraw() ফাংশন প্রকাশ করে। একটি উত্তোলন প্রক্রিয়া করার সময়, কন্ট্রাক্টটি নিচের কাজগুলো সম্পাদন করে:
- ব্যবহারকারীর ETH ব্যালেন্স চেক করে
- কলিং ঠিকানায় ফান্ড পাঠায়
- তাদের ব্যালেন্স 0 এ রিসেট করে, ব্যবহারকারীর কাছ থেকে অতিরিক্ত উত্তোলন প্রতিরোধ করে
Victim কন্ট্রাক্টের withdraw() ফাংশনটি একটি “চেকস-ইন্টারঅ্যাকশনস-ইফেক্টস” (checks-interactions-effects) প্যাটার্ন অনুসরণ করে। এটি চেক করে যে এক্সিকিউশনের জন্য প্রয়োজনীয় শর্তগুলো পূরণ হয়েছে কি না (অর্থাৎ, ব্যবহারকারীর একটি পজিটিভ ETH ব্যালেন্স আছে) এবং ট্রানজ্যাকশনের ইফেক্টগুলো প্রয়োগ করার আগে (অর্থাৎ, ব্যবহারকারীর ব্যালেন্স কমানো) কলারের ঠিকানায় ETH পাঠিয়ে ইন্টারঅ্যাকশন সম্পাদন করে।
যদি withdraw() একটি এক্সটার্নালি ওনড অ্যাকাউন্ট (EOA) থেকে কল করা হয়, তবে ফাংশনটি প্রত্যাশা অনুযায়ী কাজ করে: msg.sender.call.value() কলারকে ETH পাঠায়। তবে, যদি msg.sender একটি স্মার্ট কন্ট্রাক্ট অ্যাকাউন্ট হয় যা withdraw() কল করে, তবে msg.sender.call.value() ব্যবহার করে ফান্ড পাঠানো হলে সেই ঠিকানায় সংরক্ষিত কোডটিও রান করার জন্য ট্রিগার হবে।
কল্পনা করুন এটি কন্ট্রাক্টের ঠিকানায় ডিপ্লয়মেন্ট করা কোড:
contract Attacker {
function beginAttack() external payable {
Victim(victim_address).deposit.value(1 ether)();
Victim(victim_address).withdraw();
}
function() external payable {
if (gasleft() > 40000) {
Victim(victim_address).withdraw();
}
}
}
এই কন্ট্রাক্টটি তিনটি কাজ করার জন্য ডিজাইন করা হয়েছে:
- অন্য একটি অ্যাকাউন্ট থেকে জমা গ্রহণ করা (সম্ভবত আক্রমণকারীর EOA)
- Victim কন্ট্রাক্টে 1 ETH জমা করা
- স্মার্ট কন্ট্রাক্টে সংরক্ষিত 1 ETH উত্তোলন করা
এখানে কোনো ভুল নেই, তবে Attacker এর আরেকটি ফাংশন আছে যা ইনকামিং msg.sender.call.value থেকে অবশিষ্ট গ্যাস 40,000 এর বেশি হলে Victim এর withdraw() কে আবার কল করে। এটি Attacker কে Victim এ পুনরায় প্রবেশ করার এবং withdraw এর প্রথম ইনভোকেশন সম্পূর্ণ হওয়ার আগেই আরও ফান্ড উত্তোলন করার ক্ষমতা দেয়। চক্রটি দেখতে এরকম:
- Attacker's EOA calls `Attacker.beginAttack()` with 1 ETH
- `Attacker.beginAttack()` deposits 1 ETH into `Victim`
- `Attacker` calls `withdraw() in `Victim`
- `Victim` checks `Attacker`’s balance (1 ETH)
- `Victim` sends 1 ETH to `Attacker` (which triggers the default function)
- `Attacker` calls `Victim.withdraw()` again (note that `Victim` hasn’t reduced `Attacker`’s balance from the first withdrawal)
- `Victim` checks `Attacker`’s balance (which is still 1 ETH because it hasn’t applied the effects of the first call)
- `Victim` sends 1 ETH to `Attacker` (which triggers the default function and allows `Attacker` to reenter the `withdraw` function)
- The process repeats until `Attacker` runs out of gas, at which point `msg.sender.call.value` returns without triggering additional withdrawals
- `Victim` finally applies the results of the first transaction (and subsequent ones) to its state, so `Attacker`’s balance is set to 0
সারসংক্ষেপ হলো, যেহেতু ফাংশন এক্সিকিউশন সম্পূর্ণ না হওয়া পর্যন্ত কলারের ব্যালেন্স 0 এ সেট করা হয় না, তাই পরবর্তী ইনভোকেশনগুলো সফল হবে এবং কলারকে একাধিকবার তাদের ব্যালেন্স উত্তোলন করার অনুমতি দেবে। এই ধরনের আক্রমণ একটি স্মার্ট কন্ট্রাক্টের ফান্ড খালি করতে ব্যবহার করা যেতে পারে, যেমনটি 2016 সালের DAO হ্যাক (opens in a new tab)-এ ঘটেছিল। রিএন্ট্রান্সি আক্রমণগুলো আজও স্মার্ট কন্ট্রাক্টগুলোর জন্য একটি গুরুতর সমস্যা, যেমনটি রিএন্ট্রান্সি এক্সপ্লয়েটগুলোর পাবলিক তালিকা (opens in a new tab) দেখায়।
কীভাবে রিএন্ট্রান্সি আক্রমণ প্রতিরোধ করবেন
রিএন্ট্রান্সি মোকাবিলার একটি পদ্ধতি হলো চেকস-ইফেক্টস-ইন্টারঅ্যাকশনস প্যাটার্ন (opens in a new tab) অনুসরণ করা। এই প্যাটার্নটি ফাংশনগুলোর এক্সিকিউশনকে এমনভাবে সাজায় যাতে এক্সিকিউশন এগিয়ে নেওয়ার আগে প্রয়োজনীয় চেকগুলো সম্পাদনকারী কোড প্রথমে আসে, এরপর কন্ট্রাক্ট স্টেট ম্যানিপুলেটকারী কোড আসে এবং অন্যান্য কন্ট্রাক্ট বা EOA-এর সাথে ইন্টারঅ্যাক্টকারী কোড সবার শেষে আসে।
নিচে দেখানো Victim কন্ট্রাক্টের একটি সংশোধিত সংস্করণে চেকস-ইফেক্টস-ইন্টারঅ্যাকশনস প্যাটার্ন ব্যবহার করা হয়েছে:
contract NoLongerAVictim {
function withdraw() external {
uint256 amount = balances[msg.sender];
balances[msg.sender] = 0;
(bool success, ) = msg.sender.call.value(amount)("");
require(success);
}
}
এই কন্ট্রাক্টটি ব্যবহারকারীর ব্যালেন্সের ওপর একটি চেক সম্পাদন করে, withdraw() ফাংশনের ইফেক্টগুলো প্রয়োগ করে (ব্যবহারকারীর ব্যালেন্স 0 এ রিসেট করে) এবং ইন্টারঅ্যাকশন সম্পাদন করতে এগিয়ে যায় (ব্যবহারকারীর ঠিকানায় ETH পাঠানো)। এটি নিশ্চিত করে যে কন্ট্রাক্টটি এক্সটার্নাল কলের আগে তার স্টোরেজ আপডেট করে, যা প্রথম আক্রমণটিকে সক্ষম করা রি-এন্ট্রান্সি শর্তটি দূর করে। Attacker কন্ট্রাক্টটি এখনও NoLongerAVictim এ কল ব্যাক করতে পারে, তবে যেহেতু balances[msg.sender] 0 এ সেট করা হয়েছে, তাই অতিরিক্ত উত্তোলনগুলো একটি ত্রুটি দেখাবে।
আরেকটি বিকল্প হলো একটি মিউচুয়াল এক্সক্লুশন লক (সাধারণত "মিউটেক্স" হিসেবে পরিচিত) ব্যবহার করা যা একটি ফাংশন ইনভোকেশন সম্পূর্ণ না হওয়া পর্যন্ত কন্ট্রাক্টের স্টেটের একটি অংশ লক করে রাখে। এটি একটি বুলিয়ান ভেরিয়েবল ব্যবহার করে প্রয়োগ করা হয় যা ফাংশনটি কার্যকর হওয়ার আগে true এ সেট করা হয় এবং ইনভোকেশন সম্পন্ন হওয়ার পরে false এ রিভার্ট হয়। নিচের উদাহরণে যেমন দেখা যাচ্ছে, একটি মিউটেক্স ব্যবহার করা একটি ফাংশনকে রিকার্সিভ কলের বিরুদ্ধে রক্ষা করে যখন মূল ইনভোকেশনটি এখনও প্রক্রিয়াধীন থাকে, যা কার্যকরভাবে রিএন্ট্রান্সি বন্ধ করে।
pragma solidity ^0.7.0;
contract MutexPattern {
bool locked = false;
mapping(address => uint256) public balances;
modifier noReentrancy() {
require(!locked, "Blocked from reentrancy.");
locked = true;
_;
locked = false;
}
// এই ফাংশনটি একটি মিউটেক্স দ্বারা সুরক্ষিত, তাই `msg.sender.call`-এর ভেতর থেকে রিএন্ট্রান্ট কলগুলি আবার `withdraw` কল করতে পারবে না।
// `return` স্টেটমেন্টটি `true` হিসেবে মূল্যায়িত হয় কিন্তু তবুও মডিফায়ারে `locked = false` স্টেটমেন্টটি মূল্যায়ন করে
function withdraw(uint _amount) public payable noReentrancy returns(bool) {
require(balances[msg.sender] >= _amount, "No balance to withdraw.");
balances[msg.sender] -= _amount;
(bool success, ) = msg.sender.call{value: _amount}("");
require(success);
return true;
}
}
আপনি একটি পুল পেমেন্টস (opens in a new tab) (pull payments) সিস্টেমও ব্যবহার করতে পারেন যার জন্য ব্যবহারকারীদের স্মার্ট কন্ট্রাক্টগুলো থেকে ফান্ড উত্তোলন করতে হয়, একটি "পুশ পেমেন্টস" (push payments) সিস্টেমের পরিবর্তে যা অ্যাকাউন্টগুলোতে ফান্ড পাঠায়। এটি অজানা ঠিকানাগুলোতে অসাবধানতাবশত কোড ট্রিগার করার সম্ভাবনা দূর করে (এবং নির্দিষ্ট ডিনায়াল-অফ-সার্ভিস আক্রমণগুলোও প্রতিরোধ করতে পারে)।
ইন্টিজার আন্ডারফ্লো এবং ওভারফ্লো
একটি ইন্টিজার ওভারফ্লো তখন ঘটে যখন একটি গাণিতিক অপারেশনের ফলাফল গ্রহণযোগ্য মানের সীমার বাইরে চলে যায়, যার ফলে এটি সর্বনিম্ন উপস্থাপনযোগ্য মানে "রোল ওভার" (roll over) করে। উদাহরণস্বরূপ, একটি uint8 শুধুমাত্র 2^8-1=255 পর্যন্ত মান সংরক্ষণ করতে পারে। গাণিতিক অপারেশনগুলোর ফলাফল 255 এর চেয়ে বেশি হলে তা ওভারফ্লো হবে এবং uint কে 0 এ রিসেট করবে, ঠিক যেমন একটি গাড়ির ওডোমিটার সর্বোচ্চ মাইলেজে (999999) পৌঁছানোর পর 0 এ রিসেট হয়।
ইন্টিজার আন্ডারফ্লো একই কারণে ঘটে: একটি গাণিতিক অপারেশনের ফলাফল গ্রহণযোগ্য সীমার নিচে নেমে যায়। ধরা যাক আপনি একটি uint8 এ 0 কমানোর চেষ্টা করেছেন, ফলাফলটি কেবল সর্বোচ্চ উপস্থাপনযোগ্য মানে (255) রোল ওভার করবে।
ইন্টিজার ওভারফ্লো এবং আন্ডারফ্লো উভয়ই একটি কন্ট্রাক্টের স্টেট ভেরিয়েবলগুলোতে অপ্রত্যাশিত পরিবর্তন আনতে পারে এবং অপরিকল্পিত এক্সিকিউশনের কারণ হতে পারে। নিচে একটি উদাহরণ দেওয়া হলো যা দেখায় কীভাবে একজন আক্রমণকারী একটি অবৈধ অপারেশন সম্পাদন করতে স্মার্ট কন্ট্রাক্টে গাণিতিক ওভারফ্লোকে কাজে লাগাতে পারে:
pragma solidity ^0.7.6;
// এই কন্ট্রাক্টটি একটি টাইম ভল্ট হিসেবে কাজ করার জন্য ডিজাইন করা হয়েছে।
// ব্যবহারকারী এই কন্ট্রাক্টে জমা করতে পারেন তবে অন্তত এক সপ্তাহের জন্য উত্তোলন করতে পারবেন না।
// ব্যবহারকারী 1 সপ্তাহের অপেক্ষার সময়কালের বাইরেও অপেক্ষার সময় বাড়াতে পারেন।
/*
1. TimeLock ডিপ্লয়মেন্ট করুন
2. TimeLock এর ঠিকানা দিয়ে Attack ডিপ্লয়মেন্ট করুন
3. 1 ইথার পাঠিয়ে Attack.attack কল করুন। আপনি অবিলম্বে আপনার ইথার উত্তোলন করতে পারবেন।
কী ঘটল?
Attack TimeLock.lockTime কে ওভারফ্লো করেছে এবং 1 সপ্তাহের অপেক্ষার সময়কালের আগেই উত্তোলন করতে সক্ষম হয়েছে।
*/
contract TimeLock {
mapping(address => uint) public balances;
mapping(address => uint) public lockTime;
function deposit() external payable {
balances[msg.sender] += msg.value;
lockTime[msg.sender] = block.timestamp + 1 weeks;
}
function increaseLockTime(uint _secondsToIncrease) public {
lockTime[msg.sender] += _secondsToIncrease;
}
function withdraw() public {
require(balances[msg.sender] > 0, "Insufficient funds");
require(block.timestamp > lockTime[msg.sender], "Lock time not expired");
uint amount = balances[msg.sender];
balances[msg.sender] = 0;
(bool sent, ) = msg.sender.call{value: amount}("");
require(sent, "Failed to send Ether");
}
}
contract Attack {
TimeLock timeLock;
constructor(TimeLock _timeLock) {
timeLock = TimeLock(_timeLock);
}
fallback() external payable {}
function attack() public payable {
timeLock.deposit{value: msg.value}();
/*
যদি t = বর্তমান লক টাইম হয় তবে আমাদের এমন x খুঁজে বের করতে হবে যাতে
x + t = 2**256 = 0
তাই x = -t
2**256 = type(uint).max + 1
তাই x = type(uint).max + 1 - t
*/
timeLock.increaseLockTime(
type(uint).max + 1 - timeLock.lockTime(address(this))
);
timeLock.withdraw();
}
}
কীভাবে ইন্টিজার আন্ডারফ্লো এবং ওভারফ্লো প্রতিরোধ করবেন
0.8.0 সংস্করণ থেকে, Solidity কম্পাইলার এমন কোড প্রত্যাখ্যান করে যার ফলে ইন্টিজার আন্ডারফ্লো এবং ওভারফ্লো হয়। তবে, নিম্ন কম্পাইলার সংস্করণ দিয়ে কম্পাইল করা কন্ট্রাক্টগুলোর গাণিতিক অপারেশন জড়িত ফাংশনগুলোতে চেক করা উচিত অথবা এমন একটি লাইব্রেরি (যেমন, SafeMath (opens in a new tab)) ব্যবহার করা উচিত যা আন্ডারফ্লো/ওভারফ্লো চেক করে।
ওরাকল ম্যানিপুলেশন
ওরাকল অফচেইন তথ্যের উৎস হিসেবে কাজ করে এবং স্মার্ট কন্ট্রাক্টগুলোর ব্যবহারের জন্য এটি অনচেইনে পাঠায়। ওরাকলের সাহায্যে, আপনি এমন স্মার্ট কন্ট্রাক্ট ডিজাইন করতে পারেন যা অফচেইন সিস্টেমগুলোর সাথে ইন্টারঅপারেট করে, যেমন ক্যাপিটাল মার্কেট, যা এদের প্রয়োগকে ব্যাপকভাবে প্রসারিত করে।
তবে যদি ওরাকলটি দূষিত হয় এবং অনচেইনে ভুল তথ্য পাঠায়, তবে স্মার্ট কন্ট্রাক্টগুলো ভুল ইনপুটের ওপর ভিত্তি করে কার্যকর হবে, যা সমস্যার কারণ হতে পারে। এটি হলো “ওরাকল সমস্যা”-এর ভিত্তি, যা একটি ব্লকচেইন ওরাকল থেকে আসা তথ্য সঠিক, আপ-টু-ডেট এবং সময়োপযোগী কিনা তা নিশ্চিত করার কাজের সাথে সম্পর্কিত।
একটি সম্পর্কিত নিরাপত্তা উদ্বেগ হলো কোনো সম্পদের স্পট প্রাইস (spot price) পেতে একটি অনচেইন ওরাকল ব্যবহার করা, যেমন একটি বিকেন্দ্রীকৃত এক্সচেঞ্জ। বিকেন্দ্রীভূত অর্থব্যবস্থা (DeFi) ইন্ডাস্ট্রির ঋণ প্রদান প্ল্যাটফর্মগুলো প্রায়ই ব্যবহারকারীর জামানতের মূল্য নির্ধারণ করতে এটি করে থাকে, যাতে তারা কত টাকা ধার করতে পারে তা নির্ধারণ করা যায়।
DEX এর দামগুলো প্রায়ই সঠিক হয়, মূলত আরবিট্রেজারদের (arbitrageurs) বাজারে সমতা ফিরিয়ে আনার কারণে। তবে, এগুলো ম্যানিপুলেশনের জন্য উন্মুক্ত, বিশেষ করে যদি অনচেইন ওরাকল ঐতিহাসিক ট্রেডিং প্যাটার্নের ওপর ভিত্তি করে সম্পদের দাম গণনা করে (যেমনটি সাধারণত হয়)।
উদাহরণস্বরূপ, একজন আক্রমণকারী আপনার ঋণ প্রদান কন্ট্রাক্টের সাথে ইন্টারঅ্যাক্ট করার ঠিক আগে একটি ফ্ল্যাশ লোন নিয়ে কৃত্রিমভাবে কোনো সম্পদের স্পট প্রাইস বাড়িয়ে দিতে পারে। সম্পদের দামের জন্য DEX-এ কোয়েরি করলে স্বাভাবিকের চেয়ে বেশি মান পাওয়া যাবে (আক্রমণকারীর বড় “বাই অর্ডার” সম্পদের চাহিদাকে বিকৃত করার কারণে), যা তাদের উচিতের চেয়ে বেশি ধার করার অনুমতি দেয়। এই ধরনের "ফ্ল্যাশ লোন আক্রমণ" DeFi অ্যাপ্লিকেশনগুলোর মধ্যে প্রাইস ওরাকলের ওপর নির্ভরতাকে কাজে লাগাতে ব্যবহার করা হয়েছে, যার ফলে প্রোটোকলগুলোর লক্ষ লক্ষ টাকার ফান্ড নষ্ট হয়েছে।
কীভাবে ওরাকল ম্যানিপুলেশন প্রতিরোধ করবেন
ওরাকল ম্যানিপুলেশন এড়ানোর (opens in a new tab) ন্যূনতম প্রয়োজনীয়তা হলো একটি বিকেন্দ্রীকৃত ওরাকল নেটওয়ার্ক ব্যবহার করা যা সিঙ্গেল পয়েন্ট অফ ফেইলিওর এড়াতে একাধিক উৎস থেকে তথ্য কোয়েরি করে। বেশিরভাগ ক্ষেত্রে, বিকেন্দ্রীকৃত ওরাকলগুলোতে ওরাকল নোডগুলোকে সঠিক তথ্য রিপোর্ট করতে উৎসাহিত করার জন্য বিল্ট-ইন ক্রিপ্টোইকোনমিক প্রণোদনা থাকে, যা এগুলোকে কেন্দ্রীভূত ওরাকলগুলোর চেয়ে বেশি নিরাপদ করে তোলে।
আপনি যদি সম্পদের দামের জন্য একটি অনচেইন ওরাকলে কোয়েরি করার পরিকল্পনা করেন, তবে এমন একটি ব্যবহার করার কথা বিবেচনা করুন যা একটি টাইম-ওয়েটেড অ্যাভারেজ প্রাইস (TWAP) মেকানিজম প্রয়োগ করে। একটি TWAP ওরাকল (opens in a new tab) দুটি ভিন্ন সময়ে (যা আপনি পরিবর্তন করতে পারেন) একটি সম্পদের দাম কোয়েরি করে এবং প্রাপ্ত গড়ের ওপর ভিত্তি করে স্পট প্রাইস গণনা করে। দীর্ঘ সময়কাল বেছে নেওয়া আপনার প্রোটোকলকে প্রাইস ম্যানিপুলেশনের বিরুদ্ধে রক্ষা করে কারণ সম্প্রতি কার্যকর হওয়া বড় অর্ডারগুলো সম্পদের দামকে প্রভাবিত করতে পারে না।
ডেভেলপারদের জন্য স্মার্ট কন্ট্রাক্ট সিকিউরিটি রিসোর্স
স্মার্ট কন্ট্রাক্ট বিশ্লেষণ এবং কোডের সঠিকতা যাচাই করার টুল
-
টেস্টিং টুল এবং লাইব্রেরি - স্মার্ট কন্ট্রাক্টে ইউনিট টেস্ট, স্ট্যাটিক অ্যানালাইসিস এবং ডায়নামিক অ্যানালাইসিস করার জন্য ইন্ডাস্ট্রি-স্ট্যান্ডার্ড টুল এবং লাইব্রেরির সংগ্রহ।
-
বিধিবদ্ধ যাচাইকরণ টুল - স্মার্ট কন্ট্রাক্টের কার্যকারিতার সঠিকতা যাচাই এবং ইনভ্যারিয়েন্ট চেক করার টুল।
-
স্মার্ট কন্ট্রাক্ট অডিটিং পরিষেবা - ইথেরিয়াম ডেভেলপমেন্ট প্রজেক্টের জন্য স্মার্ট কন্ট্রাক্ট অডিটিং পরিষেবা প্রদানকারী সংস্থাগুলোর তালিকা।
-
বাগ বাউন্টি প্ল্যাটফর্ম - বাগ বাউন্টি সমন্বয় এবং স্মার্ট কন্ট্রাক্টের জটিল দুর্বলতাগুলো দায়িত্বশীলভাবে প্রকাশ করার জন্য পুরস্কৃত করার প্ল্যাটফর্ম।
-
Fork Checker (opens in a new tab) - ফর্ক করা কন্ট্রাক্ট সম্পর্কিত সমস্ত উপলব্ধ তথ্য চেক করার জন্য একটি বিনামূল্যের অনলাইন টুল।
-
ABI Encoder (opens in a new tab) - আপনার Solidity কন্ট্রাক্ট ফাংশন এবং কনস্ট্রাক্টর আর্গুমেন্ট এনকোড করার জন্য একটি বিনামূল্যের অনলাইন পরিষেবা।
-
Aderyn (opens in a new tab) - Solidity স্ট্যাটিক অ্যানালাইজার, যা সন্দেহভাজন দুর্বলতাগুলো চিহ্নিত করতে অ্যাবস্ট্রাক্ট সিনট্যাক্স ট্রি (AST) ট্রাভার্স করে এবং সহজে ব্যবহারযোগ্য মার্কডাউন ফর্ম্যাটে সমস্যাগুলো প্রিন্ট করে।
স্মার্ট কন্ট্রাক্ট মনিটর করার টুল
- Tenderly রিয়েল-টাইম অ্যালার্টিং (opens in a new tab) - আপনার স্মার্ট কন্ট্রাক্ট বা ওয়ালেটে অস্বাভাবিক বা অপ্রত্যাশিত ইভেন্ট ঘটলে রিয়েল-টাইম নোটিফিকেশন পাওয়ার একটি টুল।
স্মার্ট কন্ট্রাক্টের নিরাপদ পরিচালনার টুল
-
Safe (opens in a new tab) - ইথেরিয়ামে চলা স্মার্ট কন্ট্রাক্ট ওয়ালেট, যেখানে কোনো ট্রানজ্যাকশন সম্পন্ন হওয়ার আগে ন্যূনতম সংখ্যক মানুষের অনুমোদন প্রয়োজন হয় (M-of-N)।
-
ওপেনজেপেলিন কন্ট্রাক্টস (opens in a new tab) - কন্ট্রাক্টের মালিকানা, আপগ্রেড, অ্যাক্সেস কন্ট্রোল, গভর্ন্যান্স, পজ করার ক্ষমতাসহ অন্যান্য প্রশাসনিক বৈশিষ্ট্য বাস্তবায়নের জন্য কন্ট্রাক্ট লাইব্রেরি।
স্মার্ট কন্ট্রাক্ট অডিটিং পরিষেবা
-
ConsenSys Diligence (opens in a new tab) - স্মার্ট কন্ট্রাক্ট অডিটিং পরিষেবা, যা ব্লকচেইন ইকোসিস্টেমের প্রজেক্টগুলোকে তাদের প্রোটোকল লঞ্চের জন্য প্রস্তুত করতে এবং ব্যবহারকারীদের সুরক্ষার জন্য তৈরি করা হয়েছে তা নিশ্চিত করতে সাহায্য করে।
-
CertiK (opens in a new tab) - ব্লকচেইন সিকিউরিটি ফার্ম, যা স্মার্ট কন্ট্রাক্ট এবং ব্লকচেইন নেটওয়ার্কে অত্যাধুনিক বিধিবদ্ধ যাচাইকরণ প্রযুক্তির ব্যবহারে অগ্রণী ভূমিকা পালন করছে।
-
Trail of Bits (opens in a new tab) - সাইবার সিকিউরিটি কোম্পানি, যা ঝুঁকি কমাতে এবং কোডকে শক্তিশালী করতে আক্রমণকারীর মানসিকতার সাথে সিকিউরিটি গবেষণার সমন্বয় করে।
-
PeckShield (opens in a new tab) - ব্লকচেইন সিকিউরিটি কোম্পানি, যা সম্পূর্ণ ব্লকচেইন ইকোসিস্টেমের নিরাপত্তা, গোপনীয়তা এবং ব্যবহারযোগ্যতার জন্য পণ্য ও পরিষেবা প্রদান করে।
-
QuantStamp (opens in a new tab) - অডিটিং পরিষেবা, যা নিরাপত্তা এবং ঝুঁকি মূল্যায়ন পরিষেবার মাধ্যমে ব্লকচেইন প্রযুক্তির মূলধারায় গ্রহণকে সহজতর করে।
-
ওপেনজেপেলিন (opens in a new tab) - স্মার্ট কন্ট্রাক্ট সিকিউরিটি কোম্পানি, যা ডিস্ট্রিবিউটেড সিস্টেমের জন্য সিকিউরিটি অডিট প্রদান করে।
-
Runtime Verification (opens in a new tab) - সিকিউরিটি কোম্পানি, যা স্মার্ট কন্ট্রাক্টের ফর্মাল মডেলিং এবং যাচাইকরণে বিশেষজ্ঞ।
-
Hacken (opens in a new tab) - Web3 সাইবার সিকিউরিটি অডিটর, যা ব্লকচেইন নিরাপত্তায় 360-ডিগ্রি পদ্ধতি নিয়ে আসে।
-
নেদারমাইন্ড (opens in a new tab) - Solidity এবং Cairo অডিটিং পরিষেবা, যা ইথেরিয়াম এবং Starknet জুড়ে স্মার্ট কন্ট্রাক্টের অখণ্ডতা এবং ব্যবহারকারীদের নিরাপত্তা নিশ্চিত করে।
-
HashEx (opens in a new tab) - HashEx ক্রিপ্টোকারেন্সির নিরাপত্তা নিশ্চিত করতে ব্লকচেইন এবং স্মার্ট কন্ট্রাক্ট অডিটিংয়ের ওপর ফোকাস করে, যা স্মার্ট কন্ট্রাক্ট ডেভেলপমেন্ট, পেনিট্রেশন টেস্টিং, ব্লকচেইন কনসাল্টিংয়ের মতো পরিষেবা প্রদান করে।
-
Code4rena (opens in a new tab) - প্রতিযোগিতামূলক অডিট প্ল্যাটফর্ম, যা স্মার্ট কন্ট্রাক্ট সিকিউরিটি বিশেষজ্ঞদের দুর্বলতা খুঁজে বের করতে এবং Web3-কে আরও সুরক্ষিত করতে সাহায্য করার জন্য উৎসাহিত করে।
-
CodeHawks (opens in a new tab) - প্রতিযোগিতামূলক অডিট প্ল্যাটফর্ম, যা সিকিউরিটি গবেষকদের জন্য স্মার্ট কন্ট্রাক্ট অডিটিং প্রতিযোগিতার আয়োজন করে।
-
Cyfrin (opens in a new tab) - Web3 সিকিউরিটি পাওয়ারহাউস, যা বিভিন্ন পণ্য এবং স্মার্ট কন্ট্রাক্ট অডিটিং পরিষেবার মাধ্যমে ক্রিপ্টো সিকিউরিটিকে ইনকিউবেট করে।
-
ImmuneBytes (opens in a new tab) - Web3 সিকিউরিটি ফার্ম, যা অভিজ্ঞ অডিটরদের একটি দল এবং সেরা টুলগুলোর মাধ্যমে ব্লকচেইন সিস্টেমের জন্য সিকিউরিটি অডিট অফার করে।
-
Oxorio (opens in a new tab) - ক্রিপ্টো ফার্ম এবং বিকেন্দ্রীভূত অর্থব্যবস্থা (DeFi) প্রজেক্টের জন্য EVM, Solidity, ZK, ক্রস-চেইন প্রযুক্তিতে দক্ষতাসম্পন্ন স্মার্ট কন্ট্রাক্ট অডিট এবং ব্লকচেইন সিকিউরিটি পরিষেবা।
-
Inference (opens in a new tab) - সিকিউরিটি অডিটিং কোম্পানি, যা EVM-ভিত্তিক ব্লকচেইনগুলোর স্মার্ট কন্ট্রাক্ট অডিটিংয়ে বিশেষজ্ঞ। এর বিশেষজ্ঞ অডিটরদের কারণে তারা সম্ভাব্য সমস্যাগুলো চিহ্নিত করে এবং ডিপ্লয়মেন্টের আগে সেগুলো সমাধানের জন্য কার্যকর পরামর্শ দেয়।
বাগ বাউন্টি প্ল্যাটফর্ম
-
Immunefi (opens in a new tab) - স্মার্ট কন্ট্রাক্ট এবং বিকেন্দ্রীভূত অর্থব্যবস্থা (DeFi) প্রজেক্টের জন্য বাগ বাউন্টি প্ল্যাটফর্ম, যেখানে সিকিউরিটি গবেষকরা কোড পর্যালোচনা করেন, দুর্বলতা প্রকাশ করেন, অর্থ পান এবং ক্রিপ্টোকে আরও নিরাপদ করেন।
-
HackerOne (opens in a new tab) - দুর্বলতা সমন্বয় এবং বাগ বাউন্টি প্ল্যাটফর্ম, যা পেনিট্রেশন টেস্টার এবং সাইবার সিকিউরিটি গবেষকদের সাথে ব্যবসাগুলোকে সংযুক্ত করে।
-
HackenProof (opens in a new tab) - ক্রিপ্টো প্রজেক্টের (DeFi, স্মার্ট কন্ট্রাক্ট, ওয়ালেট, CEX এবং আরও অনেক কিছু) জন্য বিশেষজ্ঞ বাগ বাউন্টি প্ল্যাটফর্ম, যেখানে সিকিউরিটি পেশাদাররা ট্রায়াজ পরিষেবা প্রদান করেন এবং গবেষকরা প্রাসঙ্গিক, যাচাইকৃত বাগ রিপোর্টের জন্য অর্থ পান।
-
Sherlock (opens in a new tab) - স্মার্ট কন্ট্রাক্ট সিকিউরিটির জন্য Web3-তে আন্ডাররাইটার, যেখানে প্রাসঙ্গিক বাগগুলোর জন্য ন্যায্য অর্থ প্রদান নিশ্চিত করতে স্মার্ট কন্ট্রাক্টের মাধ্যমে অডিটরদের পেআউট পরিচালনা করা হয়।
-
CodeHawks (opens in a new tab) - প্রতিযোগিতামূলক বাগ বাউন্টি প্ল্যাটফর্ম, যেখানে অডিটররা সিকিউরিটি প্রতিযোগিতা এবং চ্যালেঞ্জে অংশ নেন এবং (শীঘ্রই) তাদের নিজস্ব প্রাইভেট অডিটেও অংশ নেবেন।
পরিচিত স্মার্ট কন্ট্রাক্ট দুর্বলতা এবং এক্সপ্লয়েটের প্রকাশনা
-
ConsenSys: স্মার্ট কন্ট্রাক্টের পরিচিত আক্রমণ (opens in a new tab) - সবচেয়ে উল্লেখযোগ্য কন্ট্রাক্ট দুর্বলতাগুলোর শিক্ষানবিস-বান্ধব ব্যাখ্যা, যেখানে বেশিরভাগ ক্ষেত্রেই নমুনা কোড দেওয়া আছে।
-
SWC রেজিস্ট্রি (opens in a new tab) - কমন উইকনেস এনিউমারেশন (CWE) আইটেমগুলোর কিউরেট করা তালিকা, যা ইথেরিয়াম স্মার্ট কন্ট্রাক্টের ক্ষেত্রে প্রযোজ্য।
-
Rekt (opens in a new tab) - হাই-প্রোফাইল ক্রিপ্টো হ্যাক এবং এক্সপ্লয়েটগুলোর নিয়মিত আপডেট করা প্রকাশনা, সাথে বিস্তারিত পোস্ট-মর্টেম রিপোর্ট।
স্মার্ট কন্ট্রাক্ট সিকিউরিটি শেখার চ্যালেঞ্জ
-
Awesome BlockSec CTF (opens in a new tab) - ব্লকচেইন সিকিউরিটি ওয়ারগেম, চ্যালেঞ্জ এবং ক্যাপচার দ্য ফ্ল্যাগ (opens in a new tab) প্রতিযোগিতা ও সমাধানের রাইটআপের কিউরেট করা তালিকা।
-
Damn Vulnerable DeFi (opens in a new tab) - বিকেন্দ্রীভূত অর্থব্যবস্থা (DeFi) স্মার্ট কন্ট্রাক্টের অফেন্সিভ সিকিউরিটি শিখতে এবং বাগ-হান্টিং ও সিকিউরিটি অডিটিংয়ে দক্ষতা তৈরি করার ওয়ারগেম।
-
Ethernaut (opens in a new tab) - Web3/Solidity-ভিত্তিক ওয়ারগেম, যেখানে প্রতিটি লেভেল হলো একটি স্মার্ট কন্ট্রাক্ট যাকে 'হ্যাক' করতে হয়।
-
HackenProof x HackTheBox (opens in a new tab) - ফ্যান্টাসি অ্যাডভেঞ্চারের ওপর ভিত্তি করে তৈরি স্মার্ট কন্ট্রাক্ট হ্যাকিং চ্যালেঞ্জ। চ্যালেঞ্জটি সফলভাবে সম্পন্ন করলে একটি প্রাইভেট বাগ বাউন্টি প্রোগ্রামেও অ্যাক্সেস পাওয়া যায়।
স্মার্ট কন্ট্রাক্ট সুরক্ষিত করার সর্বোত্তম অনুশীলন
-
ConsenSys: ইথেরিয়াম স্মার্ট কন্ট্রাক্ট সিকিউরিটির সর্বোত্তম অনুশীলন (opens in a new tab) - ইথেরিয়াম স্মার্ট কন্ট্রাক্ট সুরক্ষিত করার জন্য নির্দেশিকাগুলোর একটি বিস্তৃত তালিকা।
-
Nascent: সিম্পল সিকিউরিটি টুলকিট (opens in a new tab) - স্মার্ট কন্ট্রাক্ট ডেভেলপমেন্টের জন্য ব্যবহারিক সিকিউরিটি-কেন্দ্রিক গাইড এবং চেকলিস্টের সংগ্রহ।
-
Solidity প্যাটার্নস (opens in a new tab) - স্মার্ট কন্ট্রাক্ট প্রোগ্রামিং ভাষা Solidity-এর জন্য সুরক্ষিত প্যাটার্ন এবং সর্বোত্তম অনুশীলনের দরকারী সংকলন।
-
Solidity ডক্স: সিকিউরিটি বিবেচনা (opens in a new tab) - Solidity দিয়ে সুরক্ষিত স্মার্ট কন্ট্রাক্ট লেখার নির্দেশিকা।
-
স্মার্ট কন্ট্রাক্ট সিকিউরিটি ভেরিফিকেশন স্ট্যান্ডার্ড (opens in a new tab) - ডেভেলপার, আর্কিটেক্ট, সিকিউরিটি রিভিউয়ার এবং ভেন্ডরদের জন্য স্মার্ট কন্ট্রাক্টের সিকিউরিটিকে মানসম্মত করতে তৈরি করা চৌদ্দ-অংশের চেকলিস্ট।
-
স্মার্ট কন্ট্রাক্ট সিকিউরিটি এবং অডিটিং শিখুন (opens in a new tab) - চূড়ান্ত স্মার্ট কন্ট্রাক্ট সিকিউরিটি এবং অডিটিং কোর্স, যা সেইসব স্মার্ট কন্ট্রাক্ট ডেভেলপারদের জন্য তৈরি করা হয়েছে যারা তাদের সিকিউরিটির সর্বোত্তম অনুশীলনগুলোকে উন্নত করতে এবং সিকিউরিটি গবেষক হতে চান।