前言:本文适用于对JavaScript,Web3和以太坊智能合约有基本了解的开发者。
DeFi已成为以太坊生态系统非常流行的用例。在撰写本文时,DeFi协议已锁定价值超过10亿美元。迄今为止,使用开放的,去中心化的替代选择替代现有金融产品的前景已经非常受欢迎。
这些DeFi平台之所以如此出色,原因之一就是因为它们易于开发人员使用。由于它们的开源特性,开发者可以更好地了解,任何愿意学习如何使用它们的人都可以使用它们。
动态 | 德国程序员TobiasFr?mel反黑Muhstik勒索软件:德国程序员TobiasFr?mel(又名battleck)反黑Muhstik勒索软件,因Muhstik勒索软件制造者之前曾对其进行勒索,要求其支付0.09 BTC来恢复对其文件的访问。Fr?mel透露他已经入侵了攻击者的数据库,与其他受害者共享了近3000个解密密钥和一个免费解密器。(Cointelegraph)[2019/10/9]
DeFi领域目前最大的公司之一是CompoundFinance,目前其生态中锁定的价值约为1.15亿美元。所有人都可以为其协议提供资产并从中获取利息,但是这个过程如何做到的?
Compound怎么玩的?
Compound目前支持9种代币:BAT,DAI,ETH,REP,SAI,USDC,USDT,WBTC,ZRX。这些是您可以赚取利息的数字资产。
动态 | 澳大利亚程序员警告用户闪电网络的漏洞:澳大利亚软件程序员和比特币闪电网络程序员Rusty Russell警告用户,“各种基于闪电网络都存在安全问题,可能导致资金损失。”拉塞尔发布推文敦促闪电节点运营商尽快更新他们的软件。根据消息,他的警告涉及0.7.1之前的所有C-Lightning版本、0.7之前的LND版本和0.3之前的ECLAir版本。Russell表示完整的细节将在4周内发布,请在此之前进行升级。”[2019/9/1]
让我们以DAI为例。当你向协议提供DAI后,DAI将被锁定,直到您决定取回它为止。当DAI被锁定时,您需要同意协议可以借出这些价值,从而赢得整个流动性池的利息。你可以把它想象为一种储蓄帐户。
存入其中后,您可以随时查看池中总共锁定了多少DAI,当前利率是多少,借用其他资产等。
技术实现
动态 | 程序员Phil Wilson宣称中本聪并非一个人 但遭到CSW否认:据Bitcoinnews.com消息,新西兰程序员Phil Wilson宣称自己是中本聪成员,并创建了比特币项目。他强调中本聪并非一个人,而是 CSW和Dave Kleinman当时开发电子货币,但未成功,后加入自己创建的比特币项目中。这就是后来人们所谓的中本聪。Phil Wilson声称,为避免政府起诉,他删除了所有能够证明自己说法真实的证据。但CSW否认Phil Wilson的说法,称其为子。并称,其装有比特币开发资料的硬盘曾在2015年丢失,Phil Wilson曾获得该硬盘。为防止被盗,该硬盘中存有错误信息,该错误信息正是能够证明Phil Wilson说法有误的关键证据。[2018/9/4]
从技术角度来看,这种资产供应过程是什么样的?
该协议使用了ERC20兼容合约用于每个受支持的市场。它们称为cToken。它们每个都有一个外部函数:mint,这是供应的价值的发送目的地。此函数用于接收供应的价值,根据交易所汇率计算等值的cToken数量,并将它们交换为供应的价值。
以太坊社区程序员:否定V神的以太币固定供应提案:据btcmanager最新报道,V神愚人节提出的针对以太币的固定供应建议(固定供应EIP 960)引发了一场讨论,争议点在于以太币应该是有限供应还是无限供应。日前,社区知名程序员Vlad Zamfir发表了一篇评论文章,批评V神试图推动社区同意有限的以太币供应,认为它只符合投机者的利益,即商品的稀缺性将成为未来令牌的价值,并表示无限供应应该被认真考虑,这关乎以太坊平台的最终功能。V神在第二天回应Zamfir称自己根本没有表示他不愿意拥有无限的供应。[2018/4/22]
例如,如果汇率为1:1,则供应1个ETH,发送方将收到一个cETH。
mint的反向函数为redeem函数。当用户想要提取其锁定的价值时,根据当前汇率,使用所需数量的cETH代币进行赎回,返还等价的ETH。
注意:还有一个redeemUnderlying函数,使用基础资产单位而不是cToken单位作为输入。
再次用比特币购买披萨的程序员:闪电支付还有技术问题要解决:前日再次出手购买披萨的Hanyecz受访Coindesk时称:因为披萨店尚无法建立闪电支付渠道,这次的支付渠道中需要一个朋友外送披萨来促成交易。还有一些棘手的技术障碍需要解决,比如为披萨预付的款项,中间交易证明,尚没有任何发票可以提供。Hanyecz称:“希望不使用预付款,这样有拿不到披萨的风险。”据悉Hanyecz因10年5月22日用10000个比特币(当时41美元)购买两个Papa John的披萨而出名,为此在加密货币领域有了“批萨节”。就此再次购买披萨的举动,Reddit上社群用户评论“这个家伙有钢铁侠神经,应该去做第一批火星殖民者。”[2018/2/27]
编写代码
前提条件:本演练假定读者对JavaScript,Web3和以太坊智能合约有基本的了解。
我们将按照以下步骤为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
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。