使用Python的開發框架Brownie部署以太坊智能合約

介紹

我希望可以在任何開發場景都盡量用Python。在區塊鏈開發中,常用的是以太坊虛擬機智能合約語言Solidity,它具有許多不錯的功能,並且仍然可以使用 Python 進行部署。剛開始使用Solidity時,我使用瞭Remix(https://remix.ethereum.org/),這是一個強大的Web IDE,可讓您進行智能合約可視化。Remix很棒,我現在仍然使用它,但是在單個IDE之外可以實現很多其他功能。後來我開始學習Truffle(https://www.trufflesuite.com/)和HardHat(https://hardhat.org/guides/mainnet-forking.html),它們是用於部署智能合約的Node.js框架。
這些是到目前為止我所見過的主要框架,這些框架都不錯,但是我更喜歡Python。所以當我發現Brownie 和web3.py:一個用於部署智能合約的Python框架和一個用於區塊鏈開發的開源協議之後非常興奮。我們將在本文中同時介紹Brownie和Web3.py。

為什麼選擇Python?

有這麼多數據科學傢、學者和金融科技機構使用Python是有原因的。它用途廣泛,具有輕松的開發體驗,並且與各種第三方庫緊密結合在一起。頂級 defi 項目開始意識到這一點,諸如yearn.finance之類的項目使用python來部署其所有生產代碼。Yearn.finance由一群非常有才華的金融科技工程師經營,他們轉向瞭區塊鏈,帶著他們熟悉和喜愛的Python工具。

Brownie是什麼?

Brownie是由Ben Hauser創建的Python智能合約開源框架,又名“iamdefinitelyahuman”(中文意思“非絕對人類”),是一件藝術品。這就是yearn.finance團隊用來部署和維護智能合約的工具。您可以使用簡單的命令啟動項目,然後立即開始使用代碼。

用Python部署您的第一個智能合約

1. 安裝 Brownie 和 bake

Brownie具有“baking”功能,可讓您使用一些基礎代碼啟動存儲庫,因為大多數項目都需要很多相同的部分,類似於create-eth-app。要開始使用,和其他所有Python軟件包的安裝方式一樣。

pip install eth-brownie

我們還需要安裝ganache-cli一個用於部署本地區塊鏈的軟件包。為此,您需要安裝npm和nodejs。

npm install -g ganache-cli

準備開始!我們將使用chainlink-mix入門,因為許多頂級defi項目都使用Chainlink來獲取其資產數據。

brownie bake chainlink-mix
cd chainlink

通過ls命令將向我們展示項目的結構佈局
Brownie項目佈局

build : This is where the project keeps track of your deployed smart contracts and compiled contracts
contracts : The source code of your contracts, typically written in solidity or vyper
interfaces : A layout of interfaces you'll need to work with deployed contracts. Every interaction with a contract needs an ABI and an address. Interfaces are great ways to get a contract's ABI
scripts : Scripts we create to automate processes of working with our contracts
tests : Tests
brownie-config.yaml : This is where we have all the information for brownie to understand how to work with our smart contract. What blockchain do we want to deploy to? Are there any special parameters we want to set? All these are set in the config file.

requirements.txt,README.md,LICENSE和.gitignore可以忽略,您將在後面瞭解它們的用途。

2.設置環境變量

如果您熟悉區塊鏈開發,就會知道本地區塊鏈,測試網區塊鏈和主網區塊鏈都是不同的東西。我們將部署到測試網,以便我們可以與真實的實時區塊鏈網絡進行交互。您需要一個WEB3_INFURA_PROJECT_ID,可以通過創建Infura帳戶來檢索該WEB3_INFURA_PROJECT_ID。這就是我們用來連接到測試網絡的東西。我們還將獲得一個metamask或其他web3以太坊錢包,並用一些ETH進行註資。對於這個demo,我們要使用Kovan測試網絡。
您可以跳過有關LINK資金的部分,我們隻需要testnet ETH。我們也不會使用Ropsten,而是使用Kovan。如果您已經有瞭錢包,請從https://gitter.im/kovan-testnet/faucet獲取一些Kovan Ether。

安裝,配置和Metamask

一旦有瞭Metamask錢包,就可以將私鑰導出到PRIVATE_KEY環境變量。在此處(https://www.twilio.com/blog/2017/01/how-to-set-environment-variables.html)閱讀有關設置環境變量的信息。如果這仍然使您感到困惑,並且這隻是一個測試錢包,請隨意將代碼中的PRIVATE_KEY替換為您的私鑰和WEB3_INFURA_PROJECT_ID。

3.部署您的智能合約

在我們的腳本文件夾中,我們有一個名為deploy_price_consumer_v3.py的腳本,該腳本將部署我們的智能合約,該合約讀取以太坊的美元價格。如果您想更輕松地瞭解該合約的功能以及如何部署它,請隨時查看有關部署價格訂閱合同的Chainlink教程(https://docs.chain.link/docs/beginners-tutorial/)。brownie run是我們可以用來運行腳本的命令。如果僅運行brownie,則可以看到所有命令的列表。

brownie run scripts/price_feed_scripts/deploy_price_consumer_v3.py --network kovan

–network kovan允許我們設置要使用的網絡。我們正在使用kovan testnet進行此演示。您將需要Kovan ETH來做到這一點!您將獲得很多輸出內容,但最終會得到類似以下結果:

Running 'scripts/price_feed_scripts/deploy_price_consumer_v3.py::main'...
Transaction sent: 0x23d1dfa3937e0cfbab58f8d5ecabe2bfffc28bbe2349527dabe9289e747bac56
Gas price: 20.0 gwei   Gas limit: 145600   Nonce: 1339
PriceFeed.constructor confirmed - Block: 22721813   Gas used: 132364 (90.91%)
PriceFeed deployed at: 0x6B2305935DbC77662811ff817cF3Aa54fc585816

如果此方法正常運行,我們可以轉到kovan etherscan並找到我們部署的合約。上面的鏈接顯示瞭此示例中部署的合約。

4.讀取您的智能合約

現在我們已經部署瞭智能合約,我們可以從剛剛部署的合約中讀取以太坊的價格。我們將運行另一個腳本:

brownie run scripts/price_feed_scripts/read_price_feed.py --network kovan

得到類似以下的輸出:

Brownie v1.12.2 - Python development framework for Ethereum
ChainlinkProject is the active project.
Running 'scripts/price_feed_scripts/read_price_feed.py::main'...
Reading data from 0x6B2305935DbC77662811ff817cF3Aa54fc585816
62322000000
Where 62322000000 is the current price of ETH in USD! Solidity doesn't understand decimals, and we know that this example has 8 decimals, so the price is $623.22 .

您剛剛使用Python和Brownie部署瞭您的第一個智能合約!
使用web3.py
Brownie使用名為web3.py的工具讓您的開發更輕松,但是如果機智點,則我們始終可以直接在沒有框架的情況下使用合約。Web3.py是一個原始程序包,我們可以使用它來更直接地處理合同。為此,我們隻需要上面的Kovan infura項目ID。請記住,要與任何智能合約進行交互,您需要做兩件事:

  • 智能合約ABI
  • 智能合約地址

Brownie 會在後臺處理很多此類工作,但我們也可以手動進行。這是通過web3.py從鏈上合同中讀取的內容。首先,我們需要安裝web3.py。

pip install web3

然後,我們可以在文件中運行以下內容。

web3 = Web3(Web3.HTTPProvider('https://kovan.infura.io/v3/<infura_project_id>')) 
abi = '[{"inputs":[],"name":"decimals","outputs":[{"internalType":"uint8","name":"","type":"uint8"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"description","outputs":[{"internalType":"string","name":"","type":"string"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint80","name":"_roundId","type":"uint80"}],"name":"getRoundData","outputs":[{"internalType":"uint80","name":"roundId","type":"uint80"},{"internalType":"int256","name":"answer","type":"int256"},{"internalType":"uint256","name":"startedAt","type":"uint256"},{"internalType":"uint256","name":"updatedAt","type":"uint256"},{"internalType":"uint80","name":"answeredInRound","type":"uint80"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"latestRoundData","outputs":[{"internalType":"uint80","name":"roundId","type":"uint80"},{"internalType":"int256","name":"answer","type":"int256"},{"internalType":"uint256","name":"startedAt","type":"uint256"},{"internalType":"uint256","name":"updatedAt","type":"uint256"},{"internalType":"uint80","name":"answeredInRound","type":"uint80"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"version","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"}]' 
addr = '0x9326BFA02ADD2366b30bacB125260Af641031331' 
contract = web3.eth.contract(address=addr, abi=abi) 
latestData = contract.functions.latestRoundData().call() print(latestData)

運行上述操作後將在我們的控制臺中打印以美元為單位的ETH的最新價格。請查看Chainlink文檔以確定是否有問題。

結論

您可以從他們的文檔中瞭解有關Web3.py和Brown的更多信息。這兩個項目都是開源的,任何人都可以做出貢獻!
https://github.com/eth-brownie/brownie
https://github.com/ethereum/web3.py

以上就是使用Python的開發框架Brownie部署以太坊智能合約的詳細內容,更多關於Python部署智能合約的資料請關註WalkonNet其它相關文章!

推薦閱讀: