以太坊價格 以太坊價格
Ctrl+D 以太坊價格
ads

KEN:一文學習如何創建自己的ERC20代幣支付拆分器

Author:

Time:1900/1/1 0:00:00

在加密貨幣的幾乎每個領域,支付都是一個反復出現的話題,特別是向多個質押者提供支付。例如,DAO希望為多個計劃提供資金,DEX希望合并向某些參與者分配交易費用,或者團隊希望將代幣作為月薪分發給團隊成員。

智能合約使我們能夠自動化這些類型的支付功能,這就限制了人工管理支付所導致的潛在錯誤,并允許我們將寶貴的時間花在其他生產性任務上。

今天,我們將學習如何創建自己的ERC20代幣支付拆分器,它可以合并到任何項目中!

項目架構

我們將創建兩個合約。第一個將是ERC20代幣支付拆分智能合約,第二個將是模擬池智能合約。ERC20代幣支付拆分器智能合約將是抽象的,并持有用于管理收付方及其各自支付部分的邏輯和數據。模擬池將繼承ERC20代幣支付拆分器,以便我們可以自動將支付分發給多個質押者。在兩個合約中拆分支付功能的原因有兩個:

展示在真實世界的用例中代幣支付拆分合約的使用

確保代幣支付拆分合約足夠靈活,任何人都可以選擇并集成到自己的項目中

OpenZeppelin已有一個名為PaymentSplitter

functionshares(addressaccount)publicviewreturns(uint256){??return_shares;}functionpayee(uint256index)publicviewreturns(address){??return_payees;

}

現在我們將創建用于添加收款人的函數。

pragmasolidity0

Release是一個任何人都可以調用的函數,它接受一個現有收款人帳戶的參數。來分析一下這個函數中發生了什么。首先,它檢查帳戶是否有分配給它的份額。然后,它創建一個名為tokenTotalReceived的變量,該變量將合約的當前代幣余額與之前釋放的代幣總數相加。創建另一個稱為payment的變量,該變量確定收到的代幣總額中有多少是欠賬戶的,然后減去多少已經釋放到賬戶。然后,一個require語句檢查當前支付金額是否大于零(即,當前是否欠下了更多代幣)。如果該檢查通過,則更新賬戶的tokenReleased,并更新totalTokenReleased。最后,支付給賬戶的代幣金額被轉賬。

數據:比特瀏覽器被盜資金總額的87%已轉移到eXch平臺:金色財經報道,MistTrack發布比特瀏覽器黑客更新:9月4日上午9點左右,來自多個地址的資金被轉移到0x950a...a5f3。接下來,71.21枚ETH從地址0x950a...a5f3轉出到0xd488...d822,然后轉入eXch。到目前為止,已有307.48枚ETH(約合 502,403 美元)轉移到eXch平臺,占被盜資金總額的87%。[2023/9/4 13:17:16]

現在函數已經就位了!但是這個合約還有一件事要做....事件!

我們將在合約中添加兩個事件,將事件添加到合約頂部是一個良好的實踐。

pragmasolidity0

functionrelease(addressaccount)publicvirtual{??///existingFunctionCode??emitPaymentReleased(account,payment);

}

現在代幣支付拆分合約已經建立!為了理解這在真實場景中是如何工作的,讓我們創建一個模擬池合約,它將導入代幣支付拆分器。

創建模擬池合約

這個合約不會很復雜,因為我們只是想演示如何集成代幣支付拆分器。這個合約定期收到我們想分發給收款人列表的特定ERC20代幣。這個ERC20代幣可以通過不同的場景到達,比如用戶存款或來自另一個智能合約的重定向費用。在現實生活中,根據不同的項目,可能會有一個更復雜的合約,包含更多的功能來滿足用戶的用例。

在合約文件夾中,創建一個名為MockPool.sol的新文件。然后添加以下代碼。

pragmasolidity^0.8.0;import"????functiondrainTo(address_transferTo,address_token)publiconlyOwner{????require(????_token!=paymentToken,????"MockPool:TokentodrainisPaymentToken"????);????uint256balance=IERC20(_token).balanceOf(address(this));????require(balance>0,"MockPool:Tokentodrainbalanceis0");????IERC20(_token).safeTransfer(_transferTo,balance);??}

Curve發布禁用crvUSD價格預言機Chainlink限制提案:金色財經報道,Curve發布禁用crvUSD價格預言機Chainlink限制提案。提案稱,目前,crvUSD中的所有價格預言機都具有Chainlink +/- 1.5% 的“安全限制”。這意味著,如果 Chainlink 價格與內部預言機價格 (EMA) 偏差太大(1.5%),它將使用 Chainlink 的來源。看來,當市場波動很大時,Chainlink價格會造成不必要的損失。如果波動足夠高,使用 chainlink 限制的價格預言機仍然可能會出現偏差。

因此,我建議在所有市場的價格預言機合約中禁用Chainlink限制,除了舊的frxeth市場除外(很快就會被新的市場取代)。具體做法是通過set_use_chainlink(False)從控制器所有者(Ownership DAO)調用所有價格預言機合約來完成。[2023/8/20 18:11:02]

}

在這份合約中,導入三樣東西。首先是OpenZeppelin的Ownable實用程序,它在某些函數上使用唯一的onlyOwner修飾符。第二個是SafeERC20,它允許安全的ERC20代幣轉賬,正如將在合約中看到。第三個是我們的TokenPaymentSplitter合約。

在MockPool構造函數中,我們需要TokenPaymentSplitter提供相同的三個參數,我們只是將它們傳遞給我們繼承的合約。

在這個合約中添加了另一個函數,drainTo。它實際上與TokenPaymentSplitter合約沒有任何關系。它只是在另一個沒有設置為支付代幣的ERC20代幣被發送到池時的一種安全機制,然后有一種方法讓合約所有者釋放該代幣。

測試合約

測試智能合約與創建它們同樣重要。這些合約處理的資產通常是屬于其他人的,所以作為開發人員,我們有責任確保這些資產按照他們應該的方式工作,并且我們的測試可以覆蓋幾乎所有的邊緣情況。

將在這里進行的測試是一些示例,以顯示TokenPaymentSplitter智能合約按照我們的預期工作。在處理自己的項目時,可能希望創建專門適合自己的用例的測試。

為了支持我們的測試,我們希望包含一個ERC20代幣,為此,我們將創建一個新的solididity文件,該文件導入OpenZepplinERC20模板以供我們的測試使用。在合約文件夾中,創建一個名為Imports.sol的新文件,并包括以下代碼:

OpenAI創始人:OpenAI“計劃遵守”歐盟的監管規定:金色財經報道,OpenAI創始人Sam Altman:OpenAI“計劃遵守”歐盟的監管規定。公司將“慎重考慮”開設新辦事處。[2023/5/26 9:44:53]

pragmasolidity^0.8.0;import"

現在,在test文件夾中創建一個名為test.js的文件。在這個文件的頂部,我們將導入支持我們的測試的包。

const{expect}=require('chai')

const{ethers}=require('hardhat')

現在,為了設置測試,我們將首先創建必要的變量,創建beforeEach函數,該函數在每次測試之前調用,并創建一個空的describe函數,該函數將很快包含我們的測試。

describe('TokenPaymentSplitterTests',()=>{letdeployerletaccount1letaccount2letaccount3letaccount4lettestPaymentTokenletmockPoolbeforeEach(async()=>{??=awaitethers.getSigners()??constTestPaymentToken=awaitethers.getContractFactory('ERC20PresetMinterPauser')??testPaymentToken=awaitTestPaymentToken.deploy('TestPaymentToken','TPT')??awaittestPaymentToken.deployed(。)?describe('Addpayeeswithvaryingamountsanddistributepayments',async()=>{}

}

在這些部分就位后,讓我們進入這些測試的核心部分!

支付代幣平均分配給多個收款人

在我們的第一個測試中,我們想看看當我們部署一個包含平均分配份額的收款人列表的合約時會發生什么。下面是測試代碼。

it('paymenttokenisdistributedevenlytomultiplepayees',async()=>{??payeeAddressArray=??payeeShareArray=??constMockPool=awaitethers.getContractFactory('MockPool')??mockPool=awaitMockPool.deploy(????payeeAddressArray,????payeeShareArray,????testPaymentToken.address??)??awaitmockPool.deployed()??awaittestPaymentToken.mint(mockPool.address,100000)??awaitmockPool????.connect(account1)????.release(account1.address)??awaitmockPool????.connect(account2)????.release(account2.address)??awaitmockPool????.connect(account3)????.release(account3.address)??awaitmockPool????.connect(account4)????.release(account4.address)??constaccount1TokenBalance=awaittestPaymentToken.balanceOf(account1.address)??constaccount2TokenBalance=awaittestPaymentToken.balanceOf(account2.address)??constaccount3TokenBalance=awaittestPaymentToken.balanceOf(account3.address)??constaccount4TokenBalance=awaittestPaymentToken.balanceOf(account4.address)??expect(account1TokenBalance).to.equal(25000)??expect(account2TokenBalance).to.equal(25000)??expect(account3TokenBalance).to.equal(25000)??expect(account4TokenBalance).to.equal(25000)

Messari完成3500萬美元B輪融資:9月21日消息,加密分析平臺Messari宣布完成3500萬美元B輪融資, Brevan Howard Digital領投,Morgan Creek Digital、FTX Ventures、Point72 Ventures、Kraken Ventures、Uncork Capital、Underscore VC、Galaxy和Coinbase Ventures等參投。

此前8月9日消息,加密數據分析平臺Messari正在以3億美元的估值籌集資金,并已吸引了潛在投資者。其中一位消息人士稱,該公司正在尋求籌集3500萬美元。 上周,Messari曾收購加密融資數據庫Dove Metrics。[2022/9/21 7:11:44]

})

在這個測試中,我們將合約分配給4個收款人,每個人都有10個相同的份額。然后我們向合約發送100000單位的testPaymentToken,并向每個收款人發放付款。在測試中可以注意到,每個收款人都在調用函數來向自己釋放代幣。

{??payeeAddressArray=??payeeShareArray=??constMockPool=awaitethers.getContractFactory('MockPool')??mockPool=awaitMockPool.deploy(????payeeAddressArray,????payeeShareArray,????testPaymentToken.address??)??awaitmockPool.deployed()??awaittestPaymentToken.mint(mockPool.address,100000)??awaitmockPool????.connect(account1)????.release(account1.address)??awaitmockPool????.connect(account2)????.release(account2.address)??awaitmockPool????.connect(account3)????.release(account3.address)??awaitmockPool????.connect(account4)????.release(account4.address)??constmockPoolTestPaymentTokenBalance=awaittestPaymentToken.balanceOf(????mockPool.address??)??constaccount1TokenBalance=awaittestPaymentToken.balanceOf(account1.address)??constaccount2TokenBalance=awaittestPaymentToken.balanceOf(account2.address)??constaccount3TokenBalance=awaittestPaymentToken.balanceOf(account3.address)??constaccount4TokenBalance=awaittestPaymentToken.balanceOf(account4.address)??expect(mockPoolTestPaymentTokenBalance).to.equal(1)??expect(account1TokenBalance).to.equal(30303)??expect(account2TokenBalance).to.equal(15151)??expect(account3TokenBalance).to.equal(33333)??expect(account4TokenBalance).to.equal(21212)

迪拜擬建立數字經濟工作組:元宇宙是優先工作之一:金色財經報道,據arabnews消息,作為迪拜政府基金Dubai Future Foundation戰略合作伙伴,迪拜區塊鏈中心(Dubai Blockchain Center)將為迪拜政府建立一個數字經濟工作組,負責制定和監督該地區的數字經濟政策,其中元宇宙是該工作組的優先工作之一。據迪拜區塊鏈中心首席執行官 Marwan Al-Zarouni 透露,該機構計劃創建一個虛擬平臺,其中將進行與監督數字經濟技術發展相關工作組即將舉行的所有活動。[2022/6/29 1:38:03]

})

看起來收款人還能拿到錢,但注意到什么了嗎?合約中還剩下一個單位的支付代幣!由于Solidity沒有小數,當它達到最低單位時,它通常會四舍五入,這可能會導致合約塵埃飛揚,就像我們在這里看到的。不過不用擔心,因為我們預計未來會有支付代幣流入合約,所以它將繼續分發。

支付代幣不均勻地分配給多個收款人,并將額外的支付代幣發送到池中

這與之前的測試類似,不過在資金被釋放給收款人之間增加了更多支付代幣發送到池中。這表明,隨著支付代幣不斷流入模擬池合約,數學仍然可以確保收款人收到正確的金額。

it('paymenttokenisdistributedunevenlytomultiplepayeeswithadditionalpaymenttokensenttopool',async()=>{??payeeAddressArray=??payeeShareArray=??constMockPool=awaitethers.getContractFactory('MockPool')??mockPool=awaitMockPool.deploy(????payeeAddressArray,????payeeShareArray,????testPaymentToken.address??)??awaitmockPool.deployed()??awaittestPaymentToken.mint(mockPool.address,100000)??awaitmockPool????.connect(account1)????.release(account1.address)??awaitmockPool????.connect(account2)????.release(account2.address)??awaittestPaymentToken.mint(mockPool.address,100000)??awaitmockPool????.connect(account3)????.release(account3.address)??awaitmockPool????.connect(account4)????.release(account4.address)??awaitmockPool????.connect(account1)????.release(account1.address)??awaitmockPool????.connect(account2)????.release(account2.address)??constmockPoolTestPaymentTokenBalance=awaittestPaymentToken.balanceOf(????mockPool.address??????)??constaccount1TokenBalance=awaittestPaymentToken.balanceOf(account1.address)??constaccount2TokenBalance=awaittestPaymentToken.balanceOf(account2.address)??constaccount3TokenBalance=awaittestPaymentToken.balanceOf(account3.address)??constaccount4TokenBalance=awaittestPaymentToken.balanceOf(account4.address)??expect(mockPoolTestPaymentTokenBalance).to.equal(1)??expect(account1TokenBalance).to.equal(60606)??expect(account2TokenBalance).to.equal(30303)??expect(account3TokenBalance).to.equal(66666)??expect(account4TokenBalance).to.equal(42424)

})

現在所有的測試都就緒了,是時候運行它們了,看看它們是否工作!在項目根文件夾中,使用npxhardhattest啟動測試。如果一切都是正確的,那么你應該看到如下圖所示的所有綠色格子。

如上所述,我們需要做更多的測試,以確保整個項目/協議按照預期工作,支付拆分器是它的集成部分。這將意味著更多的單元測試來覆蓋所有可用的功能,以及更復雜的集成測試,這取決于具體用例。

總結

支付是許多加密協議的一個常見方面,有幾種方法可以解決它們。今天我們學習了一種管理支付的方法,盡管用戶甚至可以在此合約的基礎上構建以滿足您的特定需求,如跨多個代幣啟用支付,添加額外的收款人或移除收款人,或在一個函數調用中同時分發所有支付。

Source:https://medium.com/coinmonks/create-an-erc20-token-payment-splitting-smart-contract-c79436470ccc

本文來自去中心化金融社區,星球日報經授權轉載。

Tags:KENTOKETOKENTOKVanity TokenWorld Mobile TokenPenny TokenAEP Token

狗狗幣價格
ETH:區塊鏈開發者入門指南

譯文出自:登鏈翻譯計劃 譯者:aisiji 校對:Tiny熊 一份幫你入門的資源清單 特別感謝RNG主持了產生本文的談話.

1900/1/1 0:00:00
加密貨幣:關于上線SHIB(Shiba Inu)及其交易的公告

尊敬的EXX用戶:? ???您好!根據市場的情況及用戶的建議,EXX將于香港時間2021年5月10日15:00上線開放SHIB/USDT、SHIB/ETH交易市場,用戶可提前準備.

1900/1/1 0:00:00
TPS:關于開啟LFD充幣的公告

尊敬的用戶: WBF現已開啟LFD的充值,給您帶來的不便,敬請諒解。掃碼加入WBF官方QQ群 WBF風險提示: 關于SushiSwap集成基于Layer Zero的跨鏈橋Stargate的提案已.

1900/1/1 0:00:00
BOO:Diem負責人想讓用戶信任Facebook,他能做到嗎?

“FacebookCoin”負責人DavidMarcus向大家展示了即將到來的Novi錢包,并指出用戶不需要擔心安全或隱私問題.

1900/1/1 0:00:00
CHIV:比特幣成為薩爾瓦多法幣的第十天,反對派燒了比特幣ATM

作者|秦曉峰 編輯|郝方舟 出品|Odaily星球日報9月7日,比特幣合法化法案在拉美國家薩爾瓦多正式生效,比特幣終成法定貨幣.

1900/1/1 0:00:00
GOAT:Bibox即將支持AQUAGOAT項目智能合約升級

尊敬的Bibox用戶: 為支持AQUAGOAT(mAQUAGOAT)項目智能合約升級,Bibox將于2021年9月16日14:00(UTC8)暫停原AQUAGOAT代幣交易.

1900/1/1 0:00:00
ads