SBT:一种转移并在 OpenSea 上拍卖灵魂绑定代币的方法

原文标题:《一种转移并在Os拍卖不可转移灵魂绑定代币的方法》

撰文:十四君

5月初,以太坊创始人Vitalik的灵魂代币SBT论文发表之后,迅速成为整个Web3领域最热门的话题之一,不久前Vitalik发布新书时便使用了此SBT,任何人均可捐赠任意金额,并获得一个灵魂绑定的NFT,但是新的Token标准不仅是缺乏市场上对灵魂绑定的可靠应用,更是其灵魂代币本身还存在强制转移的漏洞。

对于合约技术的老手而言,只需合约钱包/A3S协议两个关键词即可理解核心内容但如果对实现细节有兴趣,且同本文一同探索吧。

1、灵魂绑定代币是什么

一直以来,自由主义都是Web3或者说区块链世界发展蓬勃发展的基石,但是蛮横的自由主义催生的是只有黑客才是web2向web3转型的最成功的群体。所以如果说真正有价值的Web3,需要怎样的意识形态呢?

Vitalik认为,Web3需要以负责任的自由主义作为新的信念基础。所以SBT其本质就是将信誉机制引入到了Web3当中,使得数字世界能够对账户的信誉进行评价和度量,在去中心化世界里建立声誉、责任和社会资本。

科幻作家陈楸帆:应当把元宇宙视为一种媒介形态:金色财经报道,著名科幻作家、中国科普作协副理事长陈楸帆指出,在元宇宙的内容和世界观的架构上,现在仍然需要科幻作家和未来学家贡献自己的力量,帮助科幻继续“出圈”,即让更多人看到科幻在创新内容、激发企业组织架构、动员社会文化肌体创造力与创新力上的潜力。应当把元宇宙视为一种媒介形态,科幻作家应当更多地参与进去,不光是想象未来、定义未来,也要更多地参与未来的建设。科幻界应积极运用这一话语场,借助初始、原生的元宇宙媒介,将更多作品以新的方式呈现。(国际在线)[2022/2/20 10:03:05]

而实现的方式,就是以钱包地址的目标之下,发行不可以转移的Token,并称之为Soulbond。

1.1、SBT的应用场景案例

SBT,SoulbondToken,顾名思义,就是绑定于用户账户或钱包的Token,一旦生成则不可交易。可用来代表承诺、资格、从属关系等,类似于履历表作为相应社会关系的一种证明。

在Vitalik的论文中,把绑定SBT的相关账户定义为Soul。

澳大利亚先买后付巨头Afterpay:相信很快就会出现一种流行的澳元稳定币:9月7日消息,澳大利亚先买后付巨头Afterpay告诉澳大利亚参议院金融技术委员会,它相信基于澳元(AUD)的稳定币很快就会出现。

Afterpay在提交的文件中表示,“目前没有一种澳元支持的稳定币被大量采用。然而,这种情况不太可能长期持续下去。澳元支持的稳定币将为澳大利亚加密货币用户和投资者提供与主流美元计价代币相比的一种替代价值存储方式,以及区块链技术相关的好处。这也可能有助于消除澳大利亚消费者和企业进入加密货币市场的一些障碍,因为将他们持有的澳元加密货币合理化,使其超过美元加密货币,可以为探索这一领域提供额外的便利。”(ZDNet)[2021/9/7 23:06:19]

举例来说,以太坊基金会所绑定的账户可以向参加其开发者大会的人发放相应的SBT,某大学所绑定的账户也可以向其毕业生发放代表学位证书的SBT,等等。

而本文的样例目标,就是由Vitalik发布新书时候,将会附带赠送给捐赠地址的SBT。

美国国会议员Tom Emmer:XRP不是一种证券:在参与加密货币市政厅会面时,美国国会议员Tom Emmer表示,XRP不是一种证券。他还表示,无需中介人是他喜欢XRP的原因之一。

据8月14日报道,美国国会议员Tom Emmer宣布他将领导首个加密货币市政厅会面。此次活动将邀请区块链行业的领导人参加,包括Circle首席执行官Jeremy Allaire、Ripple首席执行官Brad Garlinghouse、eToro董事总经理Guy Hirsch、BitPay首席执行官Stephan Pair以及Bloq联合创始人兼董事长Matthew Roszak。公告称,该小组将讨论“使美国保持在创新前沿的方法”。该会议时间是北京时间8月21日00:30,并对公众开放。(Zycrypto)[2020/8/21]

1.2、SBT的最小实现

其实无论ERC20还是ERC721都是通过合约标准中的transfer和SafeTransferFrom来执行转移功能,因此对SBT的最小实现,只需要删除掉transfer的代码,让其只有Mint时可以修改用户余额表_balances即可。

Morgan Creek创始人:比特币仍是一种不相关资产:Morgan Creek创始人Anthony Pompliano今日发推称,比特币目前基本持平,股市下跌两位数。今天,不要听到很多人称比特币具有相关性。事实是,相关性在短时间内并不重要。经过几个月甚至几年的时间,比特币仍然是一种不相关的资产。[2020/3/17]

对标准实现可拓展阅读:你买的NFT到底是什么?

2、转移SBT的漏洞是什么?

2.1、钱包分类概述

其实很简单,能够链上发起交易的是钱包,而钱包分单签和多签。

单签钱包,我们要往区块链上发送一笔转账交易,需要去用钱包去做一个签名,我们自己签好名把交易发送出去,交易执行成功转账就成功,这就是典型的单签钱包,也是我们平时使用最多的钱包。

而多签钱包,顾名思义,就是需要多个人去签名执行某个操作的钱包。使用多签钱包进行转账,往往需要>=1个人去签名发送交易之后,转账操作才真正完成。使用多签钱包时,我们可以指定m/n的签名模式,就是n个人里面有m个人签名即可完成操作。

现场 | 律师李振英:从资本市场法来看 加密货币很难被看作一种金融投资商品:金色财经现场报道,4月25日,韩国著名律师李振英(音)在由金色财经和cointime主办的金色沙龙韩国站第四期现场进行演讲时对最近比较火热的IEO进行了解读,并解释了其法律地位。他说,无论是ICO还是IEO,作为一种募资的手段,比较接近于金融市场,特别是资本市场领域。从资本市场法来看,加密货币很难被看作一种金融投资商品。加密货币交易所也不能适用资本市场法。但是有可能适用商业法,可以将其看作商业法中的委托买卖方或者与其相似的主体。[2019/4/25]

多签钱包,常常应用为需求强安全性的个人,以及管理公共资产的投资机构、交易所以及项目方。核心价值是资金安全与资金共同管理

2.2、多签钱包如何mintNFT?

在以太坊中,多签钱包往往是一个智能合约,而合约要实现多签管理,有两大种路径分别对应

Ownbit多签钱包使用持签授权法:用你的私钥对相应的花费进行签名,并给出签名结果

Gnosis多签钱包使用交易授权法:用你的私钥发送一笔以太坊交易,去调用某个特定接口,并给予特定参数;

咱们用Gnosis的早期版本实现V1版做例子

2.3、Gnosis多签执行任意交易的流程

整体分成4个阶段:初始化阶段→提案阶段→投票阶段→执行阶段

初始化阶段:定义若干管理员_owners,后续的交易仅这些地址可调用

提案阶段:任意管理员之一通过submitTransaction方法提交交易,得到一个交易号transactionId,提交的交易需要携带destination,value,data这三个参数

投票阶段:其余管理员通过提交ETH交易来投票,调用合约的confirmTransaction方法

执行阶段:当confirm的人数达到最低要求,executeTransaction的内部逻辑将被触发,

最终合约通过call远程调用执行任意操作

2.4、为何可以执行任意操作?

因为其中destination是目标地址,value是金额,data是交易附带的参数。

在一笔以太坊交易中,Data字段是交易的附带信息,有明确的规则控制,比如下图是最常规的ERC20转账交易,其在Etherscan解析后的展示逻辑如下,而其实交易解析前的原文是

0xa9059cbb0000000000000000000000003baf10686c60680d491f49ea3f720a1831c3391e00000000000000000000000000000000000000000000f92e1b81422bfc3a0000

其解析的原理是,依据前8位对应合约的ABI文件可以得知对应的函数名与参数列表,后续每64位按不同参数类型做不同转换做解析

所以,对于提案,只需要清晰的规定,目标地址、金额、交易附带参数,即可执行任意操作

2.5、小结-合约钱包模式优缺对比

这里概述了核心的GnosisV1版本实现逻辑,其实后来他已经逐步改版成类Ownbit的形式,采用持签验签的模式了,主要原因是

用发送交易代表提案和投票,有着简单易懂规避了复杂签名计算,且全程线上实现任何时候追溯都有据可查等优势,但是缺点也很显著

一次提案需要多人交易成本高昂

最后投票者gas费更高,即成本不平衡

再交易实际逻辑在data字段中,难以阅读理解

所以用户利弊成本权衡,最终放弃了交易确认法,让他走向持签验签的模式。

3、SBT如何在OpenSea上售卖?

至此已经非常显著了,只需要用合约钱包无论是Gnosis还是Ownbit的方法,都可以发起捐赠然后领走NFT,那转移不了Token本身,连着钱包本身一起卖不就可以了么。

当然,获得不是终点,我们的目标是还要有合适的方法来拍卖他!从而为SBT实现定价

这里就需要使用一种特殊的协议名为:A3S

A3S协议架构图

他是构建下一代地址标准的多链协议。为地址提供了流动性和可整合性,A3S使地址能够安全地交易、租赁和托管。因此,他是地址成为可以转移和定价的链上基础设施。

用户从智能合约地址工厂中铸造一个CommanderNFT,它就会自动部署相应的智能合约。智能合约的所有者指向相应的NFT持有者。合约可以接收任何类型的链上资产,并且只允许所有者发送资产,就是将这个智能合约将作为用户与任何区块链dApp交互的载体。

谁持有这个NFT,即是拿着这个智能合约的遥控器,如果NFT发生了转移,那么智能合约的管理权也发送了转移。

通过此原理最终,我们可以看到出现了一些基于此协议的在Opensea上的挂单,当然没啥价格,毕竟钱包地址的交易还不具备较大规模的社会共识。

4、总结

本文概述了SBT的理念基石,高度认可Web3需要以负责任的自由主义作为新的信念基础,但是新的概念需要周全的考虑智能合约这样的黑暗森林中发出的狙击,通过概述链上合约钱包Gnosis和Ownbit的实现原理,并结合较为前沿的A3S钱包地址转移协议,系统的说明SBT即使Token本身不可转移,也会伴随其地址权限本身的转移,而动摇灵魂绑定的意义。

最后当我收集本文资料的时候,也发现原来已经有类似思路的研究者5660.eth,将此种SBT合约钱包转移给到Vitalik的钱包地址,或许可以提醒V神以及其以太坊基金会能够对后续EIp围绕SBT的提案,做更周期的优化,比如检测授予对象是否为合约地址等等。

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

地球链

[0:46ms0-0:688ms