EEE:三步实现自己的第一笔闪电贷合约_QueenDex Coin

闪电贷是DeFi中一个独特的产品,在传统金融活动中没有与之对应的事物。会编写和使用闪电贷也是一项很重要的技能。

概念

闪电贷是一种无抵押、借贷金额无上限的贷款。它要求借贷人快借快还,快到还款和借款在同一个交易内。

闪电贷要求每笔借款在归还时,除了归还本金,还要支付一定利息。该利息由系统动态计算。

实现?

很多人对理解闪电贷有一定的难度。因为这需要了解智能合约执行原理和以太坊状态变化的机制。我们通过自己编写一个闪电贷合约,来理解其背后的运行原理。

以使用Aave提供的闪电贷为例,编写一个你自己的合约非常简单,你只需要实现一个叫?executeOperation的方法。

1.executeOperation

executeOperation方法参数中_reserve?是所借代币的合约地址,如果是ETH则是一个特殊的地址,_amount是借款的金额,_fee是本次借款要偿还的利息。_params暂时可忽略。

数据:当前DEX24小时总交易量为28.3亿美元:据DeBank数据显示,目前DEX 24小时总交易量28.3亿美元。其中总交易排名前五的DEX分别为Uniswap V3(4.40亿美元)、Mdex(4.34亿美元)、PancakeSwap(3.38亿美元)、Curve(2.50亿美元)、1inch(2.47亿美元)。[2021/7/13 0:48:24]

functionexecuteOperation(

??address_reserve,

???uint256_amount,

???uint256_fee,

??bytescalldata_params

??)

??external

{

??require(_amount<=getBalanceInternal(address(this),_reserve),"借款失败");

火币生态链新一代标准算力协议DHM登录MDEX 24H涨幅突破250%:据官方消息,火币生态链Heco上标准算力协议DHM上线去中心化交易所Mdex。日内最高涨幅突破25U,涨幅达2.5倍。DHM锚定48W的矿机,永续挖矿。

DHM(Decentralized Hash Mining)是专为区块链技术的加密数字代币挖矿设计的分布式永续标准算力?具,目前已在火币生态链Heco首发。DHM引入算力代币质押&流动性LP挖矿,释放算力代币流动性;治理代币DHT流动性挖矿、分红等诸多玩法助力用户获得多重收益。

质押DHM仅能获得每日BTC产出收益,而提供DHM-USDT-LP除了可以获得每日BTC产出以外,还可以获得治理代币DHT产出。DHM开启流动性挖矿24H单池TVL:1852574U;流动性矿池TVL:1435379U.

治理代币DHT可以参与DHT流动性挖矿、每日BTC产出分红、DAO投票决策等,DHT的持有人可以看做是DHM协议的合伙人,拥有平台决策权力和分红池参与权力。[2021/2/13 19:40:52]

??//

观点:DEX交易量下降表明DeFi投资者正转向比特币:Cointelegraph发文称,随着比特币持续攀升至2020年的新高,围绕去中心化金融(DeFi)项目的炒作继续减弱。数据显示,去中心化交易所(DEX)的交易量正在迅速下降,这进一步表明DeFi行业的下滑。DEX每周交易量已从9月第一周的80亿美元下降至10月19日至25日期间的30亿美元,其中Uniswap仍以56%的市场份额领先。[2020/10/30]

??//用借来的?ETH去赚取更多的ETH

??//

??//还款

??uinttotalDebt=_amount.add(_fee);

??transferFundsBackToPoolInternal(_reserve,totalDebt);

}

当代码执行到executeOperation时,你已经拿到了借来的钱,你主要是写如何利用这些钱赚取更多钱的逻辑。例如你发现同一个交易对A/ETH在DEX1和DEX2的价格差较大,那么你的赚钱逻辑为:

Paydex开通社群节点:据官方消息,paydex已开通社群节点,此举意在实现社群共建并以节点串联的方式,打通信息与数据传输。[2020/3/18]

已借得100ETH;

在价格低的DEX1中买入A;

在价格高的DEX2中卖出A;

卖得110ETH。

2.开始借款

executeOperation是借款成功后要执行的逻辑。而开始借款的逻辑需要用户自己触发,或者直接写在合约的构造函数里。例如:

functionflashloan()publiconlyOwner{

??bytesmemorydata="";

??uintamount=100ether;

??addressasset=address(0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE);//借ETH

??ILendingPoollendingPool=ILendingPool(addressesProvider.getLendingPool());

??lendingPool.flashLoan(address(this),asset,amount,data);

}

flashLoan()是真正的借款函数,例子中是借入100ETH。闪电贷由此方法触发,也由此方法结束。要完全理解它,我们需要看看flashLoan()的内部逻辑。我们摘取最重要的部分。

3.?flashLoan()内部逻辑

flashLoan()中首先进行各项数据验证,然后便借款给你,紧接着调用你的?executeOperation?的赚钱逻辑,最后验证你是否归还了本金加利息。主要逻辑如下所示:

????????//各种数据验证,池中是否还有足够的钱可以贷出?计算手续费等等

??????//将借款转给你

????core.transferToUser(_reserve,userPayable,_amount);

????//执行你的合约的赚钱逻辑

????receiver.executeOperation(_reserve,_amount,amountFee,_params);

????//检查目前池中余额

????uint256availableLiquidityAfter=_reserve==EthAddressLib.ethAddress()

???????address(core).balance

??????:IERC20(_reserve).balanceOf(address(core));

????????//通过池中余额变化来确认你是否已经归还了借款利息

????require(

??????availableLiquidityAfter==availableLiquidityBefore.add(amountFee),

??????"Theactualbalanceoftheprotocolisinconsistent"

????);

如果?require()验证失败,它将revert整个交易,让借款无效,从而保证借出方总是安全的。

结语

以上解释了实现第一笔闪电贷最基本的方法和原理。编译源码,以及部署到线上,大家可以参考Aave相关官方文档,这里就不一一介绍了。

编写闪电贷合约总体并不复杂。使用闪电贷风险也比较小。如果赚钱逻辑失败,变成了亏钱逻辑,不能完成还款,那么也不用担心借来的巨款无力偿还。整个交易将会执行失败,就如同借款从来没有发生过一样。

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

大币网

[0:0ms0-3:208ms