程序员秘籍丨如果使用611193为DeFi协议Compound供应资产?_CETH:CETH币

前言:本文适用于对JavaScript,Web3和以太坊智能合约有基本了解的开发者。

DeFi已成为以太坊生态系统非常流行的用例。在撰写本文时,DeFi协议已锁定价值超过10亿美元。迄今为止,使用开放的,去中心化的替代选择替代现有金融产品的前景已经非常受欢迎。

这些DeFi平台之所以如此出色,原因之一就是因为它们易于开发人员使用。由于它们的开源特性,开发者可以更好地了解,任何愿意学习如何使用它们的人都可以使用它们。

DeFi领域目前最大的公司之一是CompoundFinance,目前其生态中锁定的价值约为1.15亿美元。所有人都可以为其协议提供资产并从中获取利息,但是这个过程如何做到的?

程序员创建标准化代理合约以解决以太坊合约规模的限制:7月19日消息,当有太多函数和代码时,以太坊合约可能会达到最大合约大小24KB的限制,程序员Nick Mudge在他7月10日的博客中透露,尽管V神坚持使用“代理合约”可能是解决这些限制的潜在方法,但他创建的标准化代理合约“钻石标准”可能为其锦上添花。代理合约是指通过借用其他合同的功能来保持较小规模的合约。Mudge指出,ERC1400安全代币标准需要很多函数和事件,实现标准契约很容易就会受到限制。而“钻石标准”可以将程序员如何从任意数量的合同中创建小合约借用功能。(Cointelegraph)[2020/7/20]

Compound怎么玩的?

Compound目前支持9种代币:BAT,DAI,ETH,REP,SAI,USDC,USDT,WBTC,ZRX。这些是您可以赚取利息的数字资产。

让我们以DAI为例。当你向协议提供DAI后,DAI将被锁定,直到您决定取回它为止。当DAI被锁定时,您需要同意协议可以借出这些价值,从而赢得整个流动性池的利息。你可以把它想象为一种储蓄帐户。

自称一星期攻破币安程序员,集资后清空微博疑似跑路:3月15日,微博网友“程序员的快乐”在微博挑衅币安创始人赵长鹏,称可以打在一个星期内攻破币安,赢了需要币安奖励1000个比特币。随后几日,该网友在其微博放出以太坊地址,声称需要赞助,赞助人可根据转账资金截图入群获取内部消息。今日该网友微博已清空,疑似跑路。根据查询其以太坊地址得知,该地址目前已将筹集的11.8个ETH转出。[2018/3/21]

存入其中后,您可以随时查看池中总共锁定了多少DAI,当前利率是多少,借用其他资产等。

技术实现

从技术角度来看,这种资产供应过程是什么样的?

该协议使用了ERC20兼容合约用于每个受支持的市场。它们称为cToken。它们每个都有一个外部函数:mint,这是供应的价值的发送目的地。此函数用于接收供应的价值,根据交易所汇率计算等值的cToken数量,并将它们交换为供应的价值。

币安何一发微博疑似回应程序员一周攻破币安言论:币安联合创始人何一于今日发微博表示,“网友建议我碰瓷川普,如果川普回应了我就一夜成名,如果川普不回应肯定是心虚;无论怎么样都可以单方面宣布胜利。什么都准备好了,就差碰瓷的钱了,你们要不要赞助一下时代广场的碰瓷广告费?我留个BNB地址好不好?在线等挺急的。”疑回应昨日微博上腾讯程序员称一星期可攻破币安的挑战。[2018/3/17]

例如,如果汇率为1:1,则供应1个ETH,发送方将收到一个cETH。

mint的反向函数为redeem函数。当用户想要提取其锁定的价值时,根据当前汇率,使用所需数量的cETH代币进行赎回,返还等价的ETH。

注意:还有一个redeemUnderlying函数,使用基础资产单位而不是cToken单位作为输入。

编写代码

前提条件:本演练假定读者对JavaScript,Web3和以太坊智能合约有基本的了解。

再次用比特币购买披萨的程序员:闪电支付还有技术问题要解决:前日再次出手购买披萨的Hanyecz受访Coindesk时称:因为披萨店尚无法建立闪电支付渠道,这次的支付渠道中需要一个朋友外送披萨来促成交易。还有一些棘手的技术障碍需要解决,比如为披萨预付的款项,中间交易证明,尚没有任何发票可以提供。Hanyecz称:“希望不使用预付款,这样有拿不到披萨的风险。”据悉Hanyecz因10年5月22日用10000个比特币(当时41美元)购买两个Papa John的披萨而出名,为此在加密货币领域有了“批萨节”。就此再次购买披萨的举动,Reddit上社群用户评论“这个家伙有钢铁侠神经,应该去做第一批火星殖民者。”[2018/2/27]

我们将按照以下步骤为CompoundFinance提供和兑换ETH:

加载cETH合约。

通过调用mint,锁定ETH并接收cETH代币来提供ETH。

读取我们的cETH余额。

读取我们锁定的ETH余额。

通过提供cETH从协议中赎回我们的ETH。

步骤1:加载cETH合约

每个代币合约在每个网络上都有一个不同的地址。cToken合约的ABI可从https://compound.finance/docs/abi/<network>/<cToken>公开获得。

在我们的场景中,使用cETH和Kovan测试网,我们的URL是https://compound.finance/docs/abi/kovan/cETH。

在Compound的官方文档中可以找到每个网络上每个合约的地址。

使用web3,我们像这样初始化合约实例:

constcEthInstance=newweb3.eth.Contract(cEthABI,addr);

步骤2:提供ETH

图1显示了使用web3的send函数创建cToken的容易程度:

图1:铸造cToken

在此阶段,我们的ETH将开始根据当前利率赚取利息。

步骤3:读取我们的cETH余额

由于cToken合约兼容ERC20,因此它们提供了一个称为balanceOf的函数。我们可以通过调用并向其传递我们的帐户地址来检查我们的cETH余额:

letb=awaitcEthInstance.methods.balanceOf(account).call();

步骤4:读取锁定的ETH余额

cToken合约还提供了一个称为balanceOfUnderlying的函数,该函数使用其拥有的cToken和当前汇率返还帐户的基础资产价值:

letu=await

cEthInstance.methods.balanceOfUnderlying(account).call();

步骤5:从协议中赎回我们的ETH

将步骤4中的值u用作图2中的redeemAmount,我们可以调用redeemUnderlying来赎回我们的ETH:

图2:赎回过程

或者,我们可以使用

redeem代替

redeemUnderlying并将第3步中的值

b作为

redeemAmount。

结论

随着DeFi变得越来越容易使用并被许多人采用,在任何开发人员的工具箱中,学习如何与这些协议进行交互都是一种宝贵的工具。

如果您对区块链开发感兴趣,我会撰写有关入门和构建产品组合的教程,演练,提示和技巧。查看以下的区块链开发资源:https://medium.com/blockcentric/blockchain-development-resources-b44b752f3248

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

金智博客

[0:15ms0-4:978ms