NFT-ஐ எவ்வாறு எழுதுவது மற்றும் Deploy செய்வது (NFT Tutorial தொடரின் பகுதி 1/3)
NFT-கள் பிளாக்செயினை பொதுமக்களின் கவனத்திற்கு கொண்டு வருவதால், Ethereum பிளாக்செயினில் உங்கள் சொந்த NFT contract (ERC-721 டோக்கன்)-ஐ வெளியிடுவதன் மூலம் இந்த பிரபலத்தை நீங்களே புரிந்துகொள்ள இது ஒரு சிறந்த வாய்ப்பாகும்!
Makersplace (சமீபத்தில் Christie's இல் $69 மில்லியனுக்கு டிஜிட்டல் கலைப்படைப்பை சாதனை விலையில் விற்றது), Dapper Labs (NBA Top Shot & Crypto Kitties உருவாக்கியவர்கள்), OpenSea (உலகின் மிகப்பெரிய NFT சந்தை), Zora, Super Rare, NFTfi, Foundation, Enjin, Origin Protocol, Immutable மற்றும் பலவற்றை உள்ளடக்கிய NFT துறையில் மிகப்பெரிய பெயர்களுக்கு ஆற்றல் அளிப்பதில் Alchemy மிகவும் பெருமை கொள்கிறது.
இந்த tutorial-இல், MetaMaskopens in a new tab, Solidityopens in a new tab, Hardhatopens in a new tab, Pinataopens in a new tab மற்றும் Alchemyopens in a new tab ஆகியவற்றைப் பயன்படுத்தி Sepolia test network-இல் ஒரு ERC-721 smart contract-ஐ உருவாக்கி மற்றும் deploy செய்வதை நாம் காண்போம் (இவற்றின் அர்த்தம் உங்களுக்கு இன்னும் புரியவில்லை என்றால் கவலைப்பட வேண்டாம் — நாங்கள் அதை விளக்குவோம்!).
இந்த tutorial-இன் பகுதி 2 இல், NFT-ஐ mint செய்ய நமது smart contract-ஐ எவ்வாறு பயன்படுத்தலாம் என்பதைப் பார்ப்போம், மேலும் பகுதி 3 இல், MetaMask-இல் உங்கள் NFT-ஐ எவ்வாறு பார்ப்பது என்பதை விளக்குவோம்.
நிச்சயமாக, உங்களுக்கு எந்த நேரத்திலும் கேள்விகள் இருந்தால், Alchemy Discordopens in a new tab-இல் கேட்கத் தயங்காதீர்கள் அல்லது Alchemy's NFT API ஆவணங்களைopens in a new tab-ஐப் பார்வையிடுங்கள்!
படி 1: Ethereum நெட்வொர்க்குடன் இணையுங்கள்
Ethereum பிளாக்செயினுக்கு கோரிக்கைகளைச் செய்ய பல வழிகள் உள்ளன, ஆனால் விஷயங்களை எளிதாக்க, Alchemyopens in a new tab இல் ஒரு இலவச கணக்கைப் பயன்படுத்துவோம். இது ஒரு பிளாக்செயின் டெவலப்பர் தளம் மற்றும் API ஆகும். இது நமது சொந்த நோட்களை இயக்காமல் Ethereum சங்கிலியுடன் தொடர்பு கொள்ள அனுமதிக்கிறது.
இந்த tutorial-இல், நமது smart contract deployment-இல் என்ன நடக்கிறது என்பதைப் புரிந்துகொள்ள, கண்காணிப்பு மற்றும் பகுப்பாய்விற்கான Alchemy-இன் டெவலப்பர் கருவிகளையும் நாங்கள் பயன்படுத்திக் கொள்வோம். உங்களிடம் ஏற்கனவே Alchemy கணக்கு இல்லை என்றால், நீங்கள் இங்கேopens in a new tab இலவசமாக பதிவு செய்யலாம்.
படி 2: உங்கள் பயன்பாட்டை (மற்றும் API கீயை) உருவாக்கவும்
நீங்கள் ஒரு Alchemy கணக்கை உருவாக்கியதும், ஒரு பயன்பாட்டை உருவாக்குவதன் மூலம் API கீயை உருவாக்கலாம். இது Sepolia test நெட்வொர்க்கிற்கு கோரிக்கைகளைச் செய்ய எங்களை அனுமதிக்கும். டெஸ்ட் நெட்வொர்க்குகள் பற்றி மேலும் அறிய ஆர்வமாக இருந்தால், இந்த வழிகாட்டியைப்opens in a new tab பாருங்கள்.
- nav bar-இல் உள்ள “Apps” மீது ஹோவர் செய்து “Create App” என்பதைக் கிளிக் செய்வதன் மூலம் உங்கள் Alchemy டாஷ்போர்டில் உள்ள “Create App” பக்கத்திற்குச் செல்லவும்.
- உங்கள் பயன்பாட்டிற்குப் பெயரிடுங்கள் (நாங்கள் “My First NFT!” என்பதைத் தேர்ந்தெடுத்தோம்), ஒரு சிறு விளக்கத்தை வழங்கவும், Chain-க்கு “Ethereum” என்பதைத் தேர்ந்தெடுக்கவும், மற்றும் உங்கள் நெட்வொர்க்கிற்கு “Sepolia”-வைத் தேர்ந்தெடுக்கவும். தி மெர்ஜிற்குப் பிறகு மற்ற டெஸ்ட்நெட்கள் வழக்கற்றுப் போய்விட்டன.
- “Create app” என்பதைக் கிளிக் செய்யவும், அவ்வளவுதான்! உங்கள் ஆப் கீழே உள்ள அட்டவணையில் தோன்றும்.
படி 3: ஒரு Ethereum கணக்கை (முகவரி) உருவாக்கவும்
பரிவர்த்தனைகளை அனுப்பவும் பெறவும் நமக்கு ஒரு Ethereum கணக்கு தேவை. இந்த tutorial-க்கு, உங்கள் Ethereum கணக்கு முகவரியை நிர்வகிக்கப் பயன்படும் உலாவியில் உள்ள ஒரு மெய்நிகர் பணப்பையான MetaMask-ஐப் பயன்படுத்துவோம். Ethereum-இல் பரிவர்த்தனைகள் எவ்வாறு செயல்படுகின்றன என்பதைப் பற்றி மேலும் புரிந்துகொள்ள விரும்பினால், Ethereum ஃபவுண்டேஷனில் இருந்து இந்தப் பக்கத்தைப் பார்க்கவும்.
நீங்கள் இங்கேopens in a new tab இலவசமாக MetaMask கணக்கை பதிவிறக்கம் செய்து உருவாக்கலாம். நீங்கள் ஒரு கணக்கை உருவாக்கும்போது, அல்லது உங்களிடம் ஏற்கனவே ஒரு கணக்கு இருந்தால், மேல் வலதுபுறத்தில் உள்ள “Sepolia Test Network”க்கு மாறுவதை உறுதிசெய்யவும் (அதனால் நாங்கள் உண்மையான பணத்தைக் கையாளவில்லை).
படி 4: ஒரு Faucet-இலிருந்து ஈதரைச் சேர்க்கவும்
நமது smart contract-ஐ test நெட்வொர்க்கிற்கு deploy செய்ய, நமக்கு சில போலி ETH தேவைப்படும். ETH-ஐப் பெற, நீங்கள் Alchemy வழங்கும் Sepolia Faucetopens in a new tab-க்குச் சென்று, உள்நுழைந்து உங்கள் கணக்கு முகவரியை உள்ளிட்டு, “Send Me ETH” என்பதைக் கிளிக் செய்யவும். சிறிது நேரத்தில் உங்கள் MetaMask கணக்கில் ETH-ஐப் பார்க்க வேண்டும்!
படி 5: உங்கள் இருப்பைச் சரிபார்க்கவும்
நமது இருப்பு உள்ளதா என்பதை இருமுறை சரிபார்க்க, Alchemy’s composer toolopens in a new tab-ஐப் பயன்படுத்தி eth_getBalanceopens in a new tab கோரிக்கையைச் செய்வோம். இது நமது பணப்பையில் உள்ள ETH-இன் அளவை வழங்கும். உங்கள் MetaMask கணக்கு முகவரியை உள்ளிட்டு “Send Request” என்பதைக் கிளிக் செய்த பிறகு, இதுபோன்ற பதிலை நீங்கள் பார்க்க வேண்டும்:
1`{"jsonrpc": "2.0", "id": 0, "result": "0xde0b6b3a7640000"}`குறிப்பு இந்த முடிவு ETH-இல் அல்ல, wei-இல் உள்ளது. Wei ஈதரின் மிகச்சிறிய அலகாக பயன்படுத்தப்படுகிறது. wei-இலிருந்து ETH-க்கு மாற்றுவது 1 eth = 1018 wei. எனவே நாம் 0xde0b6b3a7640000-ஐ தசமமாக மாற்றினால், நமக்கு 1*1018 wei கிடைக்கும், இது 1 ETH-க்கு சமம்.
அப்பாடா! நமது போலிப் பணம் அனைத்தும் அங்கே உள்ளது.
படி 6: நமது திட்டத்தைத் தொடங்கவும்
முதலில், நமது திட்டத்திற்காக ஒரு கோப்புறையை உருவாக்க வேண்டும். உங்கள் command line-க்குச் சென்று தட்டச்சு செய்யவும்:
1mkdir my-nft2cd my-nftஇப்போது நாம் நமது திட்டக் கோப்புறைக்குள் இருக்கிறோம், திட்டத்தைத் தொடங்க npm init-ஐப் பயன்படுத்துவோம். நீங்கள் ஏற்கனவே npm-ஐ நிறுவவில்லை என்றால், இந்த வழிமுறைகளைப்opens in a new tab பின்பற்றவும் (நமக்கு Node.jsopens in a new tab-ம் தேவைப்படும், எனவே அதையும் பதிவிறக்கவும்!).
1npm initநிறுவல் கேள்விகளுக்கு நீங்கள் எவ்வாறு பதிலளிக்கிறீர்கள் என்பது முக்கியமல்ல; குறிப்புக்காக நாங்கள் அதை எப்படி செய்தோம் என்பது இங்கே:
1 தொகுப்பு பெயர்: (my-nft)2 பதிப்பு: (1.0.0)3 விளக்கம்: எனது முதல் NFT!4 நுழைவு புள்ளி: (index.js)5 சோதனை கட்டளை:6 git களஞ்சியம்:7 குறிச்சொற்கள்:8 ஆசிரியர்:9 உரிமம்: (ISC)10 /Users/thesuperb1/Desktop/my-nft/package.json-க்கு எழுதப் போகிறது:1112 {13 "name": "my-nft",14 "version": "1.0.0",15 "description": "எனது முதல் NFT!",16 "main": "index.js",17 "scripts": {18 "test": "echo \"Error: no test specified\" && exit 1"19 },20 "author": "",21 "license": "ISC"22 }அனைத்தையும் காட்டுpackage.json-ஐ அங்கீகரிக்கவும், நாம் தொடரலாம்!
படி 7: Hardhatopens in a new tab-ஐ நிறுவவும்
Hardhat என்பது உங்கள் Ethereum மென்பொருளைத் தொகுக்க, deploy செய்ய, சோதிக்க மற்றும் பிழைத்திருத்தம் செய்வதற்கான ஒரு மேம்பாட்டுச் சூழலாகும். நேரடி சங்கிலிக்கு deploy செய்வதற்கு முன்பு, smart contract-கள் மற்றும் dapps-களை உள்ளூரில் உருவாக்கும்போது இது டெவலப்பர்களுக்கு உதவுகிறது.
நமது my-nft திட்டத்தில் இயக்கவும்:
1npm install --save-dev hardhatநிறுவல் வழிமுறைகள்opens in a new tab குறித்த கூடுதல் விவரங்களுக்கு இந்தப் பக்கத்தைப் பார்க்கவும்.
படி 8: Hardhat திட்டத்தை உருவாக்கவும்
நமது திட்டக் கோப்புறைக்குள் இயக்கவும்:
1npx hardhatநீங்கள் ஒரு வரவேற்பு செய்தியையும், நீங்கள் என்ன செய்ய விரும்புகிறீர்கள் என்பதைத் தேர்ந்தெடுக்கும் விருப்பத்தையும் காண்பீர்கள். “create an empty hardhat.config.js”-ஐத் தேர்ந்தெடுக்கவும்:
1888 888 888 888 8882888 888 888 888 8883888 888 888 888 88848888888888 8888b. 888d888 .d88888 88888b. 8888b. 8888885888 888 "88b 888P" d88" 888 888 "88b "88b 8886888 888 .d888888 888 888 888 888 888 .d888888 8887888 888 888 888 888 Y88b 888 888 888 888 888 Y88b.8888 888 "Y888888 888 "Y88888 888 888 "Y888888 "Y8889👷 Hardhat v2.0.11-க்கு வரவேற்கிறோம் 👷10? நீங்கள் என்ன செய்ய விரும்புகிறீர்கள்? …11ஒரு மாதிரித் திட்டத்தை உருவாக்குங்கள்12❯ ஒரு வெற்று hardhat.config.js ஐ உருவாக்கவும்13வெளியேறுஅனைத்தையும் காட்டுஇது நமக்காக ஒரு hardhat.config.js கோப்பை உருவாக்கும், அங்குதான் நமது திட்டத்திற்கான அனைத்து அமைப்புகளையும் குறிப்பிடுவோம் (படி 13 இல்).
படி 9: திட்டக் கோப்புறைகளைச் சேர்க்கவும்
நமது திட்டத்தை ஒழுங்கமைக்க, இரண்டு புதிய கோப்புறைகளை உருவாக்குவோம். உங்கள் திட்டத்தின் மூல கோப்பகத்திற்கு உங்கள் command line-இல் சென்று தட்டச்சு செய்யவும்:
1mkdir contracts2mkdir scripts-
contracts/ என்பது நமது NFT smart contract குறியீட்டை வைக்கும் இடமாகும்.
-
scripts/ என்பது நமது smart contract-ஐ deploy செய்யவும், அதனுடன் தொடர்பு கொள்ளவும் ஸ்கிரிப்ட்களை வைக்கும் இடமாகும்.
படி 10: நமது contract-ஐ எழுதுங்கள்
இப்போது நமது சூழல் அமைக்கப்பட்டுள்ளது, மேலும் உற்சாகமான விஷயங்களுக்குச் செல்வோம்: நமது smart contract குறியீட்டை எழுதுவது!
உங்களுக்குப் பிடித்த எடிட்டரில் (நாங்கள் VSCodeopens in a new tab-ஐ விரும்புகிறோம்) my-nft திட்டத்தைத் திறக்கவும். Smart contract-கள் Solidity எனப்படும் மொழியில் எழுதப்பட்டுள்ளன, அதைத்தான் நமது MyNFT.sol smart contract-ஐ எழுதப் பயன்படுத்துவோம்.
-
contractsகோப்புறைக்குச் சென்று MyNFT.sol என்ற புதிய கோப்பை உருவாக்கவும். -
கீழே உள்ளது நமது NFT smart contract குறியீடு, இது OpenZeppelinopens in a new tab library-இன் ERC-721 செயலாக்கத்தை அடிப்படையாகக் கொண்டது. கீழே உள்ள உள்ளடக்கங்களை உங்கள் MyNFT.sol கோப்பில் நகலெடுத்து ஒட்டவும்.
1//Contract [https://docs.openzeppelin.com/contracts/3.x/erc721](https://docs.openzeppelin.com/contracts/3.x/erc721)-ஐ அடிப்படையாகக் கொண்டது2// SPDX-உரிம-அடையாளங்காட்டி: MIT3pragma solidity ^0.8.0;45import "@openzeppelin/contracts/token/ERC721/ERC721.sol";6import "@openzeppelin/contracts/utils/Counters.sol";7import "@openzeppelin/contracts/access/Ownable.sol";8import "@openzeppelin/contracts/token/ERC721/extensions/ERC721URIStorage.sol";910contract MyNFT is ERC721URIStorage, Ownable {11 using Counters for Counters.Counter;12 Counters.Counter private _tokenIds;1314 constructor() ERC721("MyNFT", "NFT") {}1516 function mintNFT(address recipient, string memory tokenURI)17 public onlyOwner18 returns (uint256)19 {20 _tokenIds.increment();2122 uint256 newItemId = _tokenIds.current();23 _mint(recipient, newItemId);24 _setTokenURI(newItemId, tokenURI);2526 return newItemId;27 }28}அனைத்தையும் காட்டு -
நாங்கள் OpenZeppelin contracts library-இலிருந்து வகுப்புகளைப் பெறுவதால், உங்கள் command line-இல்
npm install @openzeppelin/contracts^4.0.0என்பதை இயக்கி, library-ஐ நமது கோப்புறையில் நிறுவவும்.
சரி, இந்த குறியீடு சரியாக என்ன செய்கிறது? அதை வரி வரியாகப் பார்ப்போம்.
நமது smart contract-இன் மேலே, மூன்று OpenZeppelinopens in a new tab smart contract வகுப்புகளை இறக்குமதி செய்கிறோம்:
-
@openzeppelin/contracts/token/ERC721/ERC721.sol என்பது ERC-721 தரநிலையின் செயலாக்கத்தைக் கொண்டுள்ளது, அதை நமது NFT smart contract மரபுரிமையாகப் பெறும். (செல்லுபடியாகும் NFT ஆக இருக்க, உங்கள் smart contract ERC-721 தரநிலையின் அனைத்து முறைகளையும் செயல்படுத்த வேண்டும்.) மரபுரிமையாகப் பெற்ற ERC-721 செயல்பாடுகளைப் பற்றி மேலும் அறிய, இங்கேopens in a new tab இடைமுக வரையறையைப் பார்க்கவும்.
-
@openzeppelin/contracts/utils/Counters.sol ஒன்றால் மட்டுமே அதிகரிக்க அல்லது குறைக்கக்கூடிய கவுண்டர்களை வழங்குகிறது. நமது smart contract, mint செய்யப்பட்ட NFT-களின் மொத்த எண்ணிக்கையைக் கண்காணிக்கவும், நமது புதிய NFT-இல் தனிப்பட்ட ஐடியை அமைக்கவும் ஒரு கவுண்டரைப் பயன்படுத்துகிறது. (ஒரு smart contract-ஐப் பயன்படுத்தி mint செய்யப்படும் ஒவ்வொரு NFT-க்கும் ஒரு தனிப்பட்ட ஐடி ஒதுக்கப்பட வேண்டும் — இங்கே நமது தனிப்பட்ட ஐடி தற்போதுள்ள NFT-களின் மொத்த எண்ணிக்கையால் தீர்மானிக்கப்படுகிறது. எடுத்துக்காட்டாக, நமது smart contract மூலம் நாம் mint செய்யும் முதல் NFT-இன் ஐடி "1," நமது இரண்டாவது NFT-இன் ஐடி "2," மற்றும் பல.)
-
@openzeppelin/contracts/access/Ownable.sol நமது smart contract-இல் அணுகல் கட்டுப்பாட்டைopens in a new tab அமைக்கிறது, எனவே smart contract-இன் உரிமையாளர் (நீங்கள்) மட்டுமே NFT-களை mint செய்ய முடியும். (குறிப்பு, அணுகல் கட்டுப்பாட்டைச் சேர்ப்பது முற்றிலும் ஒரு விருப்பத்தேர்வாகும். உங்கள் smart contract-ஐப் பயன்படுத்தி யார் வேண்டுமானாலும் NFT-ஐ mint செய்ய விரும்பினால், வரி 10-இல் உள்ள Ownable என்ற வார்த்தையையும், வரி 17-இல் உள்ள onlyOwner-ஐயும் அகற்றவும்.)
நமது இறக்குமதி அறிக்கைகளுக்குப் பிறகு, நமது தனிப்பயன் NFT smart contract உள்ளது, இது ஆச்சரியப்படத்தக்க வகையில் குறுகியது — இது ஒரு கவுண்டர், ஒரு கன்ஸ்ட்ரக்டர் மற்றும் ஒற்றைச் செயல்பாட்டை மட்டுமே கொண்டுள்ளது! இது நமது மரபுரிமையாகப் பெற்ற OpenZeppelin contract-களுக்கு நன்றி, NFT-ஐ உருவாக்குவதற்குத் தேவையான பெரும்பாலான முறைகளை இது செயல்படுத்துகிறது. எடுத்துக்காட்டாக, ownerOf NFT-இன் உரிமையாளரை வழங்குகிறது, மற்றும் transferFrom NFT-இன் உரிமையை ஒரு கணக்கிலிருந்து மற்றொரு கணக்கிற்கு மாற்றுகிறது.
நமது ERC-721 கன்ஸ்ட்ரக்டரில், நாங்கள் 2 சரங்களை, “MyNFT” மற்றும் “NFT”ஐ அனுப்புவதை நீங்கள் கவனிப்பீர்கள். முதல் மாறி smart contract-இன் பெயர், மற்றும் இரண்டாவது அதன் சின்னம். இந்த மாறிகள் ஒவ்வொன்றிற்கும் நீங்கள் விரும்பிய பெயரை இடலாம்!
இறுதியாக, நம்மிடம் mintNFT(address recipient, string memory tokenURI) என்ற செயல்பாடு உள்ளது, இது ஒரு NFT-ஐ mint செய்ய அனுமதிக்கிறது! இந்தச் செயல்பாடு இரண்டு மாறிகளை உள்ளீடாக எடுப்பதை நீங்கள் கவனிப்பீர்கள்:
-
address recipientஉங்கள் புதிதாக mint செய்யப்பட்ட NFT-ஐப் பெறும் முகவரியைக் குறிப்பிடுகிறது. -
string memory tokenURIஎன்பது ஒரு சரம், இது NFT-இன் மெட்டாடேட்டாவை விவரிக்கும் ஒரு JSON ஆவணத்திற்குத் தீர்வு காண வேண்டும். ஒரு NFT-இன் மெட்டாடேட்டா தான் உண்மையில் அதை உயிர்ப்பிக்கிறது, இது பெயர், விளக்கம், படம் மற்றும் பிற பண்புக்கூறுகள் போன்ற உள்ளமைக்கக்கூடிய பண்புகளைக் கொண்டிருக்க அனுமதிக்கிறது. இந்த tutorial-இன் பகுதி 2-இல், இந்த மெட்டாடேட்டாவை எவ்வாறு உள்ளமைப்பது என்பதை விவரிப்போம்.
mintNFT மரபுரிமையாகப் பெற்ற ERC-721 library-இலிருந்து சில முறைகளை அழைக்கிறது, மேலும் இறுதியில் புதிதாக mint செய்யப்பட்ட NFT-இன் ஐடியைக் குறிக்கும் ஒரு எண்ணைத் திருப்புகிறது.
படி 11: MetaMask & Alchemy-ஐ உங்கள் திட்டத்துடன் இணைக்கவும்
இப்போது நாம் ஒரு MetaMask wallet, Alchemy கணக்கு மற்றும் நமது smart contract-ஐ எழுதியுள்ளோம், மூன்றையும் இணைக்க வேண்டிய நேரம் இது.
உங்கள் மெய்நிகர் பணப்பையிலிருந்து அனுப்பப்படும் ஒவ்வொரு பரிவர்த்தனைக்கும் உங்கள் தனிப்பட்ட private key-ஐப் பயன்படுத்தி ஒரு கையொப்பம் தேவை. நமது நிரலுக்கு இந்த அனுமதியை வழங்க, நமது private key (மற்றும் Alchemy API key) ஆகியவற்றை ஒரு சூழல் கோப்பில் பாதுகாப்பாக சேமிக்கலாம்.
பரிவர்த்தனைகளை அனுப்புவது பற்றி மேலும் அறிய, web3-ஐப் பயன்படுத்தி பரிவர்த்தனைகளை அனுப்புவது குறித்த இந்த tutorial-ஐப் பார்க்கவும்.
முதலில், உங்கள் திட்ட கோப்பகத்தில் dotenv தொகுப்பை நிறுவவும்:
1npm install dotenv --saveபின்னர், நமது திட்டத்தின் மூல கோப்பகத்தில் .env கோப்பை உருவாக்கி, அதில் உங்கள் MetaMask private key மற்றும் HTTP Alchemy API URL-ஐச் சேர்க்கவும்.
-
MetaMask-இலிருந்து உங்கள் private key-ஐ ஏற்றுமதி செய்ய இந்த வழிமுறைகளைopens in a new tab பின்பற்றவும்
-
HTTP Alchemy API URL-ஐப் பெற கீழே பார்க்கவும் மற்றும் அதை உங்கள் கிளிப்போர்டுக்கு நகலெடுக்கவும்
உங்கள் .env இப்போது இப்படி இருக்க வேண்டும்:
1API_URL="https://eth-sepolia.g.alchemy.com/v2/உங்கள்-api-கீ"2PRIVATE_KEY="உங்கள்-மெட்டமாஸ்க்-தனியார்-கீ"இவற்றை உண்மையில் நமது குறியீட்டுடன் இணைக்க, படி 13-இல் நமது hardhat.config.js கோப்பில் இந்த மாறிகளை நாம் குறிப்பிடுவோம்.
.env ஐ கமிட் செய்யாதீர்கள்! உங்கள் .env கோப்பை யாருடனும் பகிரவோ அல்லது வெளிப்படுத்தவோ வேண்டாம் என்பதைத் தயவுசெய்து உறுதிப்படுத்திக் கொள்ளுங்கள், ஏனெனில் அவ்வாறு செய்வதன் மூலம் உங்கள் இரகசியங்களை நீங்கள் சமரசம் செய்கிறீர்கள். நீங்கள் பதிப்புக் கட்டுப்பாட்டைப் பயன்படுத்தினால், உங்கள் .env-ஐ ஒரு gitignoreopens in a new tab கோப்பில் சேர்க்கவும்.படி 12: Ethers.js-ஐ நிறுவவும்
Ethers.js என்பது ஒரு library ஆகும், இது standard JSON-RPC முறைகளை அதிக பயனர் நட்பு முறைகளுடன் இணைப்பதன் மூலம் Ethereum உடன் தொடர்புகொள்வதையும் கோரிக்கைகளைச் செய்வதையும் எளிதாக்குகிறது.
கூடுதல் கருவி மற்றும் நீட்டிக்கப்பட்ட செயல்பாட்டிற்காக Pluginsopens in a new tab-ஐ ஒருங்கிணைப்பதை Hardhat மிகவும் எளிதாக்குகிறது. ஒப்பந்தத்தைப் பயன்படுத்த நாம் Ethers செருகுநிரலைப்opens in a new tab பயன்படுத்திக் கொள்வோம் (Ethers.jsopens in a new tab-இல் சில மிகத் தெளிவான ஒப்பந்தப் பயன்பாட்டு முறைகள் உள்ளன).
உங்கள் திட்ட கோப்பகத்தில் தட்டச்சு செய்யவும்:
1npm install --save-dev @nomiclabs/hardhat-ethers ethers@^5.0.0அடுத்த படியில் நமது hardhat.config.js-இல் ethers-ஐயும் கோருவோம்.
படி 13: hardhat.config.js-ஐப் புதுப்பிக்கவும்
இதுவரை பல சார்புகள் மற்றும் செருகுநிரல்களைச் சேர்த்துள்ளோம், இப்போது hardhat.config.js-ஐப் புதுப்பிக்க வேண்டும், இதனால் நமது திட்டம் அவை அனைத்தையும் பற்றி அறியும்.
உங்கள் hardhat.config.js-ஐப் இதுபோலப் புதுப்பிக்கவும்:
1 /**2 * @type import('hardhat/config').HardhatUserConfig3 */4 require('dotenv').config();5 require("@nomiclabs/hardhat-ethers");6 const { API_URL, PRIVATE_KEY } = process.env;7 module.exports = {8 solidity: "0.8.1",9 defaultNetwork: "sepolia",10 networks: {11 hardhat: {},12 sepolia: {13 url: API_URL,14 accounts: [`0x${PRIVATE_KEY}`]15 }16 },17 }அனைத்தையும் காட்டுபடி 14: நமது contract-ஐத் தொகுக்கவும்
இதுவரை எல்லாம் செயல்படுகிறதா என்பதை உறுதிப்படுத்த, நமது contract-ஐத் தொகுப்போம். தொகுக்கும் பணி, உள்ளமைக்கப்பட்ட hardhat பணிகளில் ஒன்றாகும்.
command line-இலிருந்து இயக்கவும்:
1npx hardhat compileமூலக் கோப்பில் SPDX உரிம அடையாளங்காட்டி வழங்கப்படவில்லை என்பது பற்றிய எச்சரிக்கையைப் பெறலாம், ஆனால் அதைப் பற்றி கவலைப்படத் தேவையில்லை — மற்ற அனைத்தும் நன்றாக இருக்கும் என்று நம்புகிறோம்! இல்லையெனில், நீங்கள் எப்போதும் Alchemy discordopens in a new tab-இல் செய்தி அனுப்பலாம்.
படி 15: நமது deploy ஸ்கிரிப்டை எழுதவும்
இப்போது நமது contract எழுதப்பட்டு, நமது உள்ளமைவுக் கோப்பு தயாராக உள்ளது, நமது contract deploy ஸ்கிரிப்டை எழுத வேண்டிய நேரம் இது.
scripts/ கோப்புறைக்குச் சென்று deploy.js என்ற புதிய கோப்பை உருவாக்கி, அதில் பின்வரும் உள்ளடக்கங்களைச் சேர்க்கவும்:
1async function main() {2 const MyNFT = await ethers.getContractFactory("MyNFT")34 // பயன்படுத்தலைத் தொடங்கவும், ஒரு ஒப்பந்தப் பொருளுக்குத் தீர்க்கும் ஒரு வாக்குறுதியைத் திருப்பி அளிக்கவும்5 const myNFT = await MyNFT.deploy()6 await myNFT.deployed()7 console.log("Contract இந்த முகவரிக்கு deploy செய்யப்பட்டது:", myNFT.address)8}910main()11 .then(() => process.exit(0))12 .catch((error) => {13 console.error(error)14 process.exit(1)15 })அனைத்தையும் காட்டுஇந்த ஒவ்வொரு குறியீட்டு வரிகளும் என்ன செய்கின்றன என்பதை Hardhat அவர்களின் Contracts tutorialopens in a new tab-இல் அற்புதமாக விளக்குகிறது, நாங்கள் அவர்களின் விளக்கங்களை இங்கே எடுத்துள்ளோம்.
1const MyNFT = await ethers.getContractFactory("MyNFT");ethers.js-இல் உள்ள ஒரு ContractFactory என்பது புதிய smart contract-களை deploy செய்யப் பயன்படும் ஒரு சுருக்கமாகும், எனவே இங்குள்ள MyNFT என்பது நமது NFT contract-இன் நிகழ்வுகளுக்கான ஒரு factory ஆகும். hardhat-ethers செருகுநிரலைப் பயன்படுத்தும் போது, ContractFactory மற்றும் Contract நிகழ்வுகள் இயல்பாக முதல் கையொப்பமிடுபவருடன் இணைக்கப்பட்டுள்ளன.
1const myNFT = await MyNFT.deploy();ஒரு ContractFactory-இல் deploy()-ஐ அழைப்பது, பயன்படுத்தலைத் தொடங்கும், மற்றும் ஒரு Contract-க்குத் தீர்க்கும் ஒரு Promise-ஐத் திருப்பும். இது நமது ஒவ்வொரு smart contract செயல்பாடுகளுக்கும் ஒரு முறையைக் கொண்ட பொருளாகும்.
படி 16: நமது contract-ஐ deploy செய்யவும்
இறுதியாக நமது smart contract-ஐ deploy செய்யத் தயாராகிவிட்டோம்! உங்கள் திட்ட கோப்பகத்தின் மூலத்திற்குத் திரும்பிச் சென்று, command line-இல் இயக்கவும்:
1npx hardhat --network sepolia run scripts/deploy.jsநீங்கள் இது போன்ற ஒன்றைக் காண்பீர்கள்:
1Contract இந்த முகவரிக்கு deploy செய்யப்பட்டது: 0x4C5266cCc4b3F426965d2f51b6D910325a0E7650Sepolia etherscanopens in a new tab-க்குச் சென்று நமது contract முகவரியைத் தேடினால், அது வெற்றிகரமாக deploy செய்யப்பட்டிருப்பதைக் காண முடியும். உங்களால் உடனடியாக அதைப் பார்க்க முடியாவிட்டால், சிறிது நேரம் காத்திருக்கவும், ஏனெனில் இதற்கு சிறிது நேரம் ஆகலாம். பரிவர்த்தனை இதுபோல இருக்கும்:
From முகவரி உங்கள் MetaMask கணக்கு முகவரியுடன் பொருந்த வேண்டும் மற்றும் To முகவரியில் “Contract Creation” என்று இருக்கும். பரிவர்த்தனைக்குள் கிளிக் செய்தால், To புலத்தில் நமது contract முகவரியைக் காண்போம்:
ஆஹா! உங்கள் NFT smart contract-ஐ Ethereum (testnet) சங்கிலிக்கு நீங்கள் இப்போது deploy செய்துவிட்டீர்கள்!
திரைக்குப் பின்னால் என்ன நடக்கிறது என்பதைப் புரிந்துகொள்ள, நமது Alchemy dashboardopens in a new tab-இல் உள்ள Explorer தாவலுக்குச் செல்வோம். உங்களிடம் பல Alchemy ஆப்-கள் இருந்தால், ஆப் மூலம் வடிகட்டி “MyNFT”-ஐத் தேர்ந்தெடுப்பதை உறுதிசெய்யவும்.
நாம் .deploy() செயல்பாட்டை அழைத்தபோது Hardhat/Ethers நமக்காகத் திரைக்குப் பின்னால் செய்த சில JSON-RPC அழைப்புகளை இங்கே காண்பீர்கள். இங்கே குறிப்பிட வேண்டிய இரண்டு முக்கியமானவை eth_sendRawTransaction, இது நமது smart contract-ஐ Sepolia சங்கிலியில் எழுதுவதற்கான கோரிக்கையாகும், மற்றும் eth_getTransactionByHash இது hash-ஐக் கொண்டு நமது பரிவர்த்தனை பற்றிய தகவலைப் படிக்கும் கோரிக்கையாகும் (பரிவர்த்தனைகளை அனுப்பும்போது ஒரு பொதுவான முறை). பரிவர்த்தனைகளை அனுப்புவது பற்றி மேலும் அறிய, Web3-ஐப் பயன்படுத்தி பரிவர்த்தனைகளை அனுப்புவது பற்றிய இந்த tutorial-ஐப் பார்க்கவும்.
இந்த tutorial-இன் பகுதி 1 இத்துடன் முடிவடைகிறது. பகுதி 2-இல், ஒரு NFT-ஐ mint செய்வதன் மூலம் நமது smart contract-உடன் உண்மையில் தொடர்புகொள்வோம், மற்றும் பகுதி 3-இல் உங்கள் Ethereum wallet-இல் உங்கள் NFT-ஐ எவ்வாறு பார்ப்பது என்பதைக் காண்பிப்போம்!
பக்கத்தின் கடைசி புதுப்பிப்பு: 5 டிசம்பர், 2025






