热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

合约钱包集成Dapp

合约钱包集成Dapp-常规的以太坊账户(EOA)有一个不幸的局限。来自EOA的每笔交易只能直接与单个地址或合同进行交互。在dapp交互中经常出现这种情况,例如“您必须先解锁X才能

常规的以太坊账户(EOA)有一个不幸的局限。来自 EOA 的每笔交易只能直接与单个地址或合同进行交互。在dapp交互中经常出现这种情况,例如“您必须先解锁X才能获得Y”之类的消息。

基于合约的账户(合约钱包)不受此限制,可以将交易分批处理到多个合约中,以提供更顺畅的用户体验。在用户眼中,“approve”步骤可以完全抽象掉,可以简单地执行他们想要的动作。

1. defi 的产品分类

我们可以构建的DeFi协议的数量每天都在增长,但主要分为以下几类:

  1. 交换 — Uniswap,dYdX,Kyber网络,0x
  2. 借贷 — compound,dYdX,Aave
  3. 综合资产 — Maker,Synthetix,FutureSwap
  4. 保险 — Nexus Mutual 和 Opyn

2. 合约钱包集成 dapp 思路

基于 sendTransactionBatch 实现一键交互

例如:我需要抵押 ETH 获得 DAI,授权 DAI 给 cDAI 的合约,然后拿 DAI 去铸币产生 cDAI,只有 cDAI 即可 生息。

传统的 EOA 钱包,只能一笔一笔交易,而且需要当前交易上链后,才能继续执行第二笔交易。操作的复杂度和交易手续费都大大增加了。

合约钱包,可以把三部操作,封装到一次调用里面,用户只需要一次交互即可完成。app 提供身份认证和签名,由 web 实现页面交互。

await provider.sendTransactionBatch([
  deposit_ETH_and_get_DAI,
  approveDai_to_cDAI,
  mintCDaiTransaction
])

优势

  1. 体验更好:用户一键即可完成复杂的交互;UI 定制,和 app 风格统一
  2. 安全性:不需要部署新合约;解决 approve 的问题
  3. 功能更丰富:可随意组合多种 defi,想象空间更大

3. approve 问题

以使用 StarCoin 购买咖啡为例,

  1. 买一杯咖啡,用户需要 先 approve(BuyCoffee, fee),然后 buy(fee)。
  2. approve 后,dapp 合约有权操作钱包资产,可操作数量 <= fee
  3. 实际的场景中,很多 dapp 为了体验方便, 设置 fee 的值非常大 或者不受限制。可能由于合约升级,或者有漏洞时,作恶者接管钱包,用户的资金洗劫一空

解决办法:approveAndCall

  1. 需要使用多少,则授权多少金额
  2. 授权后,由于有每日限额,即使损失,金额也是可控
  3. 随时可以撤销授权,或者随时调整授权的金额
    /**
     * 设置帐户允许支付的最大金额
     *
     * 一般在智能合约的时候,避免支付过多,造成风险,加入时间参数,可以在 tokenRecipient 中做其他操作
     *
     * @param _spender 帐户地址
     * @param _value 金额
     * @param _extraData 操作的时间
     */
    function approveAndCall(address _spender, uint256 _value, bytes _extraData) public returns (bool success) {
        tokenRecipient spender = tokenRecipient(_spender);
        if (approve(_spender, _value)) {
            spender.receiveApproval(msg.sender, _value, this, _extraData);
            return true;
        }
    }

demo

  1. approve:https://github.com/argentlabs...
  2. sendTransactionBatch: https://github.com/authereum/...

参考资料

  1. https://www.argent.xyz/blog/a...
  2. https://medium.com/argenthq/f...
  3. approve 介绍文章:https://segmentfault.com/a/11...
  4. batchTransaction 介绍:https://medium.com/authereum/...
  5. sendTransactionBatch 的实现:https://docs.authereum.com/we...

推荐阅读
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • Fixes/redwoodjs/redwood/#55Thegooglesaidtodothis:https://webpack.js.org/co ... [详细]
  • 系列目录Guava1:概览Guava2:Basicutilities基本工具Guava3:集合CollectionsGuava4:GuavacacheGuava6:Concurre ... [详细]
  • Forexperiencedcryptoinvestors,thereareseveralsectorsthatseemedpromisingbutdidn’tlive ... [详细]
  • NFT 玩家分析 | NFTGo 年报(四)
    NFT玩家画像以年轻男性为主,一人多钱包成常态。推荐阅读:《NFT ... [详细]
  • Java多线程_Future设计模式
       Future模式的核心:去除了主函数的等待时间,并使得原本需要等待的时间段可以用于处理其他业务逻辑。  Future模式有点类似于商品订单。在网上购物时,提交订单后,在收货的 ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • java多线程获取线程返回结果
    我们在使用java多线程编写相关业务代码时,往往有这样一种情况,某个线程依赖于其他线程执行结果。也就是说,我们需要在一个线程中获取另一个线程的信息。可以分为两种情况,一种是轮询,一 ... [详细]
author-avatar
Gbom2402851125
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有