区块见闻 区块见闻
Ctrl+D收藏区块见闻

MENT:一文学习如何创建自己的ERC20代币支付拆分器_POOL

作者:

时间:

在加密货币的几乎每个领域,支付都是一个反复出现的话题,特别是向多个质押者提供支付。例如,DAO希望为多个计划提供资金,DEX希望合并向某些参与者分配交易费用,或者团队希望将代币作为月薪分发给团队成员。智能合约使我们能够自动化这些类型的支付功能,这就限制了人工管理支付所导致的潜在错误,并允许我们将宝贵的时间花在其他生产性任务上。今天,我们将学习如何创建自己的ERC20代币支付拆分器,它可以合并到任何项目中!先决条件和设置

下面的内容要求你对Solidity有点熟悉,不过任何人都可以学习。项目架构

我们将创建两个合约。第一个将是ERC20代币支付拆分智能合约,第二个将是模拟池智能合约。ERC20代币支付拆分器智能合约将是抽象的,并持有用于管理收付方及其各自支付部分的逻辑和数据。模拟池将继承ERC20代币支付拆分器,以便我们可以自动将支付分发给多个质押者。在两个合约中拆分支付功能的原因有两个:展示在真实世界的用例中代币支付拆分合约的使用确保代币支付拆分合约足够灵活,任何人都可以选择并集成到自己的项目中OpenZeppelin已有一个名为PaymentSplitter

SafeERC20

paymentToken是我们用于支付的ERC20代币的地址。_totalShares提供来自所有收款人的份额相加。_totalTokenReleased是已支付给所有收款人的支付代币总额。_payees提供了当前所有收款人地址的数组。_shares是收款人地址与分配给他们的份额数量的映射。_tokenReleased是收款人地址到支付代币数量的映射。现在放置一个接受三个参数的构造函数。第一个参数是我们希望在合约部署中初始化的收款人的数组。第二个参数是每个收款人的份额数组。第三个是将用于支付的ERC20代币的地址。pragmasolidity0

paymentToken=_paymentToken;}构造函数包含一个require语句,以确保两个数组具有相同的长度,以便每个收款人都有分配给他们的份额。还有另一个require语句,以确保合约初始化与至少有一个收款人。还有一个for循环,它将每个收款人及其份额分配我们上面创建的变量。这是通过一个名为_addPayee的函数完成的,我们将很快创建这个函数。构造函数就绪后,再添加几个函数来调用和获取合约变量。pragmasolidity0

加密基金DBA Crypto将目标募资额从5亿美元降至1.5亿美元:6月17日消息,根据6月份提交给美国SEC的文件以及两名知情人士的消息,加密货币基金DBA Crypto仍在努力启动。

这家以机构为导向的投资初创公司此前试图募集至少5亿美元的外部资金,其目标是在2022年底或2023年初推出。其中三名核心员工已跳槽到其他加密企业。 当时的消息人士表示,DBA正在与潜在的锚定投资者进行高级对话,但其计划没有成功。

最新SEC文件显示,DBA Crypto将其基金的目标募资总额从5亿美元削减至1.5亿美元,其旗舰DBA Crypto Fund 1在岸和离岸版本的目标募资额均为7500万美元。[2023/6/17 21:43:57]

functionshares(addressaccount)publicviewreturns(uint256){return_shares;}functionpayee(uint256index)publicviewreturns(address){return_payees;}现在我们将创建用于添加收款人的函数。pragmasolidity0

_addPayee是我们在构造函数中调用的用于设置收款人数组的函数。这个函数有两个参数,收款人的帐户和与其相关的份额数量。然后它会检查账户是否为零地址,份额是否大于零,以及该账户是否已经注册为收款人。如果所有检查都通过,那么我们将数据添加到各自的变量中。现在让我们添加一个函数来支持将代币分发给收款人。pragmasolidity0

Release是一个任何人都可以调用的函数,它接受一个现有收款人帐户的参数。来分析一下这个函数中发生了什么。首先,它检查帐户是否有分配给它的份额。然后,它创建一个名为tokenTotalReceived的变量,该变量将合约的当前代币余额与之前释放的代币总数相加。创建另一个称为payment的变量,该变量确定收到的代币总额中有多少是欠账户的,然后减去多少已经释放到账户。然后,一个require语句检查当前支付金额是否大于零(即,当前是否欠下了更多代币)。如果该检查通过,则更新账户的tokenReleased,并更新totalTokenReleased。最后,支付给账户的代币金额被转账。现在函数已经就位了!但是这个合约还有一件事要做....事件!我们将在合约中添加两个事件,将事件添加到合约顶部是一个良好的实践。pragmasolidity0

美联储会议纪要:每月将资产负债表缩减950亿美元,或从5月份开始:金色财经报道,美联储会议纪要显示,美联储官员在3月份的会议上讨论了如何减少数万亿美元的债券持有量,共识规模约为950亿美元。官员们“普遍同意”,允许在三个月内逐步减少600亿美元的美国国债和350亿美元的抵押贷款支持证券,虽然官员们没有进行任何正式投票,但会议记录显示,成员们同意该过程可以在5月份开始。

“我不认为美联储缩减资产负债表必然对加密货币不利的观点,”宏观分析师兼Blockworks Forward Guidance播客主持人Jack Farley说。“美联储最近一次量化紧缩始于2017年10月,比特币从那时起上涨了340%,直到2017年12月达到顶峰。”(blockworks)[2022/4/7 14:10:37]

functionrelease(addressaccount)publicvirtual{///existingFunctionCodeemitPaymentReleased(account,payment);}现在代币支付拆分合约已经建立!为了理解这在真实场景中是如何工作的,让我们创建一个模拟池合约,它将导入代币支付拆分器。创建模拟池合约

这个合约不会很复杂,因为我们只是想演示如何集成代币支付拆分器。这个合约定期收到我们想分发给收款人列表的特定ERC20代币。这个ERC20代币可以通过不同的场景到达,比如用户存款或来自另一个智能合约的重定向费用。在现实生活中,根据不同的项目,可能会有一个更复杂的合约,包含更多的功能来满足用户的用例。在合约文件夹中,创建一个名为MockPool

}在这份合约中,导入三样东西。首先是OpenZeppelin的Ownable实用程序,它在某些函数上使用唯一的onlyOwner修饰符。第二个是SafeERC20,它允许安全的ERC20代币转账,正如将在合约中看到。第三个是我们的TokenPaymentSplitter合约。在MockPool构造函数中,我们需要TokenPaymentSplitter提供相同的三个参数,我们只是将它们传递给我们继承的合约。在这个合约中添加了另一个函数,drainTo。它实际上与TokenPaymentSplitter合约没有任何关系。它只是在另一个没有设置为支付代币的ERC20代币被发送到池时的一种安全机制,然后有一种方法让合约所有者释放该代币。测试合约

欧佩克+:将从5月开始逐步增产:欧佩克+就逐步增产达成协议,将从5月开始逐步增产。(界面新闻)[2021/4/2 19:38:26]

测试智能合约与创建它们同样重要。这些合约处理的资产通常是属于其他人的,所以作为开发人员,我们有责任确保这些资产按照他们应该的方式工作,并且我们的测试可以覆盖几乎所有的边缘情况。将在这里进行的测试是一些示例,以显示TokenPaymentSplitter智能合约按照我们的预期工作。在处理自己的项目时,可能希望创建专门适合自己的用例的测试。为了支持我们的测试,我们希望包含一个ERC20代币,为此,我们将创建一个新的solididity文件,该文件导入OpenZepplinERC20模板以供我们的测试使用。在合约文件夹中,创建一个名为Imports.sol的新文件,并包括以下代码: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()=>{}}在这些部分就位后,让我们进入这些测试的核心部分!支付代币平均分配给多个收款人

Cream Finance:FTT的Collateral Factor从50%降低至25%:Cream Finance发推表示,提案已通过,FTT的Collateral Factor从50%降低至25%,意味着供应100美元的FTT,最多可借入25美元的其它代币。[2020/11/6 11:50:45]

在我们的第一个测试中,我们想看看当我们部署一个包含平均分配份额的收款人列表的合约时会发生什么。下面是测试代码。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。)在这个测试中,我们将合约分配给4个收款人,每个人都有10个相同的份额。然后我们向合约发送100000单位的testPaymentToken,并向每个收款人发放付款。在测试中可以注意到,每个收款人都在调用函数来向自己释放代币。支付代币不均匀地分配给多个收款人

本体将gas费从500上调至2500:本体(ONT)在电报群表示,根据最新发布经济模型,从7月7日(UTC)起,本体链上gas费将从500调整为2500,gaslimit保持不变。所有本体Triones节点将在此时间之前进行此项调整。如果上述调整未能及时进行,则链上用户可能无法正常进行ONT或ONG交易。节点申请的500ONG质押合约费用保持不变。[2020/7/3]

在第二个测试中,我们希望确保即使每个收款人的份额分配不均,数学计算仍然有效。it('paymenttokenisdistributedunevenlytomultiplepayees',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)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。)看起来收款人还能拿到钱,但注意到什么了吗?合约中还剩下一个单位的支付代币!由于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本文来自去中心化金融社区,星球日报经授权转载。

标签:TOKENMENTDREPOOLCryowar TokenDecentralized Community Investment ProtocolDrEE ProjectAuctpool

狗狗币价格热门资讯
COI:星球日报 | Coinbase计划进军加密衍生品领域,申请注册为期货佣金商;OpenSea回应内幕交易事件:将禁止员工利用内幕信息来买卖NFT(9月16日)_OIN

头条 Coinbase计划进军加密衍生品领域,申请注册为期货佣金商加密货币交易所Coinbase周三向美国全国期货协会提交申请以注册为期货佣金商.

OIN:探讨 Loot 与 Rarity 爆火后的生态发展现状:Rarity 已有至少6种 UI 界面,Loot 生态一度停滞_Coinzix Token

作者|RichardLee8月27日,Loot项目横空出世,行业人士以其充分的想象空间和可扩展性,将其誉为「NFT的范式转变」.

NFT:从5个角度全面说透Loot的价值所在_loot币最新价格

不是我不明白,而是这世界变化太快。前几天还潮的不行的JPG型号NFT,上周瞬间被一张黑底白字的TXT型号NFT打成了“古典NFT”.

TOKE:玩转“烤仔宇宙” | 当Thinker遇上Artist_PAY

9月28日,Conflux联合Odaily星球日报举办活动《当Thinker遇上Artist》,希望以此活动连接艺术家市场和主流市场,共同探寻艺术与创新的结合.

FLUX:NFT 市场繁荣背景下,DeFi 生态系统快速扩张_conflux币怎么挖

文:ANIRUDHTIWARI编译:Zion责编:karen随着九月的结束,加密货币市场从所谓的“九月魔咒”中恢复过来,市值达到2.32万亿美元。去中心化金融市场一直是这种增长不可分割的一部分.

DAP:Dapper Labs收购Brud,成立专注于DAO的新部门「Dapper Collectives」_Kong Defi

Odaily星球日报译者|念银思唐 摘要: -DapperLabs成立了一个新的业务部门,专注于为DAO构建工具。-该公司已经收购了虚拟网红LilMiquela背后的初创公司Brud.