技术分享|Flow USDC合约分析与链上链下多签实现分享

互联网 阅读 613 2022-03-26 10:00:00

本文作者:Jing,Flow中文社区技术大使。转载请备注来源。

Circle部署在Flow上的FiatToken.cdc合约写的较为复杂,因为该USDC合约不仅仅为了支持Flow Fungible Token标准,还尝试在Flow上兼容ERC20与CENTRE TOKEN的相关标准,比如黑名单、交易冻结、allowance等。

参考文档:https://github.com/flow-usdc/flow-usdc

为此,Circle描述了一个FiatTokenInterface.cdc接口,但在主网实际部署USDC合约时,因为某种原因,并没有继承该interface,只实现了一些角色管理和基础FT接口。

https://flow-view-source.com/mainnet/account/0xb19436aae4d94622/contract/FiatToken

allowance/approve其实在FiatTokenInterface.cdcTRANSACTIONS.md中是有实现的,不过withdraw_allowance.cdc中存在一定漏洞(没有对tx发起人做检验)。

FiatTokenInterface.cdc:https://github.com/flow-usdc/flow-usdc/blob/main/contracts/FiatTokenInterface.cdc

TRANSACTIONS.md: https://github.com/flow-usdc/flow-usdc/blob/main/doc/TRANSACTIONS.md

FiatToken的角色管理

FiatToken.cdc一个长达1300多行的FT合约,绝大部分都是在做角色管理:admin,owner,masterMinter,minter,pauser,blacklister 。

下面是Docs里的图:

Flow的代码结构偏组件化编程,不太方便阅读,换一种示意以有助于理解角色关系:

  1. Minter负责mint和burn,MinterController负责设置allowance值,且Minter与Mintercontroller是一一对应的,需要绑定通过MasterMinter认证。

  2. 各种Executor资源都是唯一创建并存储在合约部署地址下的。

  3. 可以有多个Admin资源拥有者,通过AdminExecutor进行ExecutorCapability签发。

  4. Pause、MasterMinter、Blocklist的ExecutorCapability获取则需要通过Owner来控制。

  5. 对权限的管理都是通过资源uuid完成的,Minter可以恶意转移或是暴露cap。

Circle链上多签协议OnChainMultiSig.cdc

链接:https://flow-view-source.com/mainnet/account/0x220c1b4155f86f2f/contract/OnChainMultiSig

Circle实现了一套链上的多签协议,允许多个签名在链上来授权一笔tx,而绕过链下多次签名的流程限制。如果有相同的多签需求或是投票治理等场景可以有些借鉴。

用FiatToken.cdc中Admin resource的多签使用举例:

值得注意的是:

  1. 待多签的tx的代码实现需要被封装在合约里,并在Payload里进行描述,比如tx序列id、method 名字,参数等,需要签名的部分也是这个Playload描述。

  2. 每个签名者都可以单独对这笔tx上传签名认证。

  3. 当完成签名的钥匙权重合>1000后,可以调用readyForExecution执行相关tx代码;否则继续等待签名。

  4. 多种不同的等待签名的tx都会在OnChainMultiSig.Manager中进行管理。

  5. 这个多签体系有个地方需要讨论:假设一笔tx,当前有5个人可签名,但增加第6个签名者的操作只需要5个人中的任意1人即可发起。

补充正常多签流程

Flow文档描述:https://docs.onflow.org/concepts/transaction-signing/

包含4种: 单地址单key单地址多key多地址单key多地址多key

■ 使用Cli完成多签流程:

链接:https://docs.onflow.org/flow-cli/complex-transactions/

一次tx的签名管线如下:

  • Build: encode the source code using rlp or the "Recursive Length Prefix" encoding.

  • Sign: cryptographically sign the encoded source code.

  • Send: deliver the encoded source code with the signatures to a Flow Access Node.

举例:

transaction() {    prepare(signerA: AuthAccount, signerB: AuthAccount) {

一次tx可以被拆解成多步,由中间签名字串传递。

Step 1:

flow transactions build ./helloworld_tx.cdc \  --proposer testnet-A \  --payer testnet-A \  --authorizer testnet-A \  --authorizer testnet-B \  --filter payload \  --save transaction.build.rlp

Step 2:

flow transactions sign ./transaction.build.rlp \  --signer testnet-B \  --filter payload \  --save transaction.signed.B.rlp \  -yflow transactions sign ./transaction.signed.B.rlp \  --signer testnet-A \  --filter payload \  --save transaction.signed.rlp \  -y

Step 3:

flow transactions send-signed ./transaction.signed.rlp -y

Tips:

  1. 注意签名顺序,payer需要最后签

  2. 当同地址多个key时,在accounts里可以这么配置:

"key1": {    "address": "0x4",    "key": "444...444"},"key2": {    "address": "0x4",    "key": "555...555"}

FCL链下多签

可以参考:https://github.com/onflow/flow-multisig

  1. 与Cli的分步签名接口类似,Fcl中有类似的接口。

  2. 该工程里使用supabase做了baas服务,发起的签名请求payload和生成的rlp中间编码字串都会在云数据库里存储。待签名的人可以fcl前端登录,然后查询数据库获取需要签名的rlp字串进行签名。

 END 

什么是Flow福洛链?

Flow福洛链是一个快速,去中心化,且对开发者友好的区块链,旨在为新一代游戏、娱乐应用程序提供动力的数字资产的基础。Flow是唯一一个由始至终为消费者提供出色体验的Layer-1区块链团队。其团队创造的dApp包括:CryptoKittiesDapper WalletsNBA Top shot

CrytoKitties于2017年推出时便快速成为加密市场最受欢迎的dApp,因其成功而导致以太坊堵塞。在Flow上运营的NBA Top shot也已成为增长最快的dApp,在公开发布后的6个月创造了7亿美金销量。正因为Flow公链的可扩展性和消费者友好的体验,让这一切成为可能。目前有300多个项目正在Flow链上筹备中,我们期待看到一个伟大的生态系统蓬勃发展。

关于Dapper Labs

Dapper Labs是一家位于加拿大的全球顶尖区块链服务商,在2017 年年底通过CryptoKitties收藏游戏成功进入⽤户视野,并且因为加密猫的爆⽕导致以太坊拥堵,从而推出Flow公链以及全新的开发语言—— Cadence,旨在吸引更多的开发者在Flow 上开发应⽤。 

Flow的合作伙伴们:

我们欢迎越来越多的小伙伴加入Flow星球,为星球增添色彩!

Flow 官网:https://zh.onflow.org/

Flow 论坛: https://forum.onflow.org/

Flow Discord:

https://discord.com/invite/flow

Flow CN Telegram: https://t.me/flow_zh

Flow B站:https://space.bilibili.com/1002168058

Flow 微博: 

https://weibo.com/7610419699

Flow CSDN:

https://blog.csdn.net/weixin_57551966?spm=1010.2135.3001.5343

扫码添加Flow官方账号微信号,加入Flow生态群

微信号 : FlowChainOfficial

免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
上一篇:Flow Ecosystem| 加入Meta Panda Club,共建篮球社区 下一篇:MilkySwap测试操作教程

您可能感兴趣

  • 解读CKB版 “闪电网络” Fiber Network:比特币可编程性扩展的另一种思路
    解读CKB版 “闪电网络” Fiber Network:比特币可编程性扩展的另一种思路

    作者:NingNing行业周期与宏观金融周期共振,加密行业正处在与 2019 年相似的整体性迷茫之中,现阶段不仅流动性枯竭,叙事貌似也在枯竭。市场不但对 VC 叙事兴趣阙如,对反 VC 的 Meme 叙事也已经疲倦。就像每次哲学危机,人们都会回归柏拉图寻找出路,当加密行业危机时,我们也需要回归比特币、回归中本聪。正如 CKB 生态 RGB++ 协议创始人 Cipher 在最新 Blog 里所阐述的,加密行业需要对以太坊 “链上计算” 的路径依赖进行反思,回归P2P经济学,让计算归于链下,让验证归于链上。因

    每日资讯 2024-09-02 12:06 1283
  • 面对NFL球员工会起诉,“退圈”的DraftKings竟主动承认NFT是证券?
    面对NFL球员工会起诉,“退圈”的DraftKings竟主动承认NFT是证券?

    作者:Zen,PANews近日,美国国家橄榄球联盟球员协会 (NFLPA) 指控数字体育娱乐和游戏公司DraftKings 逃避了其 NFT 球员许可协议的付款义务。在放弃NFT业务后,涉嫌出售未注册证券而遭到集体诉讼的DraftKings又背上了一起官司。而有趣的是,在与NFLPA的纠纷中,DraftKings的立场似乎已从反驳转变为积极承认“NFT就是证券”。放弃NFT业务:驳回集体诉讼的动议遭到否决今年7月底,Draftkings在给用户的电子邮件中表示:“经过慎重考虑,DraftKings 决定终

    每日资讯 2024-09-02 12:06 1393
  • 简析两种最新比特币智能合约实现方案:OP_NET与Arch有何区别?
    简析两种最新比特币智能合约实现方案:OP_NET与Arch有何区别?

    作者:Cookie过去半个月,OP_NET 与 Arch 这两个比特币主网上的智能合约实现方案引发了较多的讨论。有意思的事情是,OP_NET 这个名字与大家熟悉的 OP_CAT 很像,都以「OP_」开头,具有很强的、让大家认为这哥俩差不多的迷惑性。所以,在开篇要和大家先提一嘴 OP_CAT。首先,OP_CAT 是比特币操作码,从去年开始有以「量子猫」Quantum Cats,也就是「大巫师」Taproot Wizards 的创始人 Udi Wertheimer 为首的社区力量一直在呼喊要「复活」OP_CA

    每日资讯 2024-09-02 12:06 1295
  • 争议不断,以太坊正在失去“万链之王”的权威
    争议不断,以太坊正在失去“万链之王”的权威

    作者:Climber,金色财经近期围绕以太坊的话题和争议越来越多,不仅 Vitalik 本人需要下场解释观点,就连以太坊基金会也要发布公告来平息社区的质疑声。在本轮牛市周期中,以太坊的表现可谓平平。而美国以太坊现货 ETF 的通过也并未让 ETH 走势如投资者期待般爆发,相反却在币价方面越走越低。这就不免让有着「万链之王」美誉的以太坊逐渐失去投资者和社区的尊重,进而质疑起有关以太坊的方方面面。争议不断,以太坊亟需重塑权威最近一段时间以来社区成员对 Vitalik 言论观点、以太坊基金会乃至以太坊生态系统的

    每日资讯 2024-09-02 12:06 992
  • 从《黑神话:悟空》谈起,GameFi何时能取得真经?
    从《黑神话:悟空》谈起,GameFi何时能取得真经?

    作者:YBB Capital Researcher Zeke前言本文是市场垃圾时间中的一些闲聊,需要对传统游戏市场有一定程度了解。大家可以把这篇文章当作日记或者随想观看,这些只是我在游玩《黑神话:悟空》之后对GameFi的一些粗浅思考,以及对这个赛道未来的看法。一、游戏科学的九九八十一难三天全网销量破千万、Steam玩家同时在线峰值破235万、多家品牌联名周边销售爆火、国家级媒体多次采访、多个游戏取景地可凭游戏通关记录终身免费进入、86版《西游记》YouTube观看量超400万。以上,是《黑神话:悟空》上

    每日资讯 2024-09-02 12:06 684
  • Gavin Wood:如何防止女巫攻击进行有效空投?
    Gavin Wood:如何防止女巫攻击进行有效空投?

    演讲:Gavin WoodGavin 近期一直在关注的女巫攻击(civil resistance)的问题,PolkaWorld 回顾了 Gavin Wood 博士在 Polkadot Decoded 2024 上的主题演讲,想要探究 Gavin 在如何防止女巫攻击上的一些见解。什么是女巫攻击?你们可能知道,我一直在研究一些项目,我在编写灰皮书,专注于 JAM 项目,也在这个方向上做了一些代码的工作。实际上,在过去的两年时间里,我一直在思考一个非常关键的问题,这个问题在这个领域中非常重要,那就是如何防止女巫

    每日资讯 2024-09-02 12:06 1238
  • 市场热议,链抽象将成加密新叙事?
    市场热议,链抽象将成加密新叙事?

    2024年,加密货币领域的技术创新持续加速,链抽象(Chain Abstraction)逐渐成为行业内的焦点。链抽象技术的核心在于通过隐藏底层技术的复杂性,让用户能够更加便捷地在多个区块链之间进行操作。传统的区块链技术通常要求用户掌握不同链的操作流程,并需要应对跨链操作中的技术难题,这极大地吸引了新用户的进入。而链抽象的出现,则为这些问题提供了有效的解决方案,成为Web3建设不可忽视的重要一环。01、什么是链抽象及其作用链抽象能够将不同的区块链之间的差异整合在一个统一的操作界面中,使得用户只需一个账户即可

    每日资讯 2024-09-02 12:05 533
  • 今日日报|马斯克和特斯拉赢得“被指控操纵狗狗币”的诉讼;稳定币支付平台Bridge完成5800万美元融资
    今日日报|马斯克和特斯拉赢得“被指控操纵狗狗币”的诉讼;稳定币支付平台Bridge完成5800万美元融资

    今日要闻提示:马斯克和特斯拉赢得驳回指控他们操纵狗狗币的诉讼OpenAI和Anthropic已同意将其主要新AI模型在发布前共享给美国政府OKX将上线Hamster Kombat(HMSTR)现货交易X平台纽约总部将于9月13日关闭,预计将迁往得州萨尔瓦多总统布克尔成为《时代》杂志最新一期封面人物稳定币支付公司Bridge完成5800万美元融资数据:MATIC、SHIB、UNI代币头部地址持仓均超50%网龙今年上半年通过出售2.9亿元的加密货币,获利5100万元人民币监管消息美国众议院计划在9月举行多场加

    每日资讯 2024-09-02 12:05 1034