USD:浅析Move语言背后的设计思想:“不授权”到底安不安全?

最近关于用户和Move智能合约交互,不需要授权(Approve)是更安全还是更不安全的争论很多,这里尝试用通俗的方式来解释一下二者背后的区别以及Move这样设计背后的思想。

我们先理解一下用户和智能合约交互的方式。当我们签了一个交易,去调用一个链上的智能合约,就好比从物理世界进入了一个智能合约的数字世界,我们在这个数字世界有一个分身,而这个分身做什么,是智能合约定义的。

在EVM中,每个合约都相当于一个独立的小世界,分身进入这个世界后,只能操作用户在当前合约世界中的状态。

LeverFi宣布从Unicorn Web3获得500万美元战略融资:据官方消息,LeverFi表示,我们很高兴的宣布从Unicorn Web3获得了500万美元的战略融资,通过这项融资,我们扩大了与Unicorn-Verse的深度合作,这笔投资将用于LeverFi的全新升级,帮助LeverFi生态落地,以实现广大的增长目标。九月,将是LeverFi全新未来的开始。[2023/9/7 13:24:46]

比如进入swap世界,想用自己的usdt交换其他资产,而usdt存在定义usdt的那个合约世界,没办法直接在swap中以自己的身份从usdt合约里提取资产。于是用户只能先去usdt的合约世界执行approve,告诉usdt的合约,swap可以代自己提取自己的资产,然后再进入swap世界进行操作。

社交媒体应用程序MeWe宣布采用基于Polkadot的Frequency区块链:金色财经报道,社交媒体应用程序MeWe宣布正在采用基于Polkadot的Frequency区块链,为其2000万用户带来基于区块链的自主权身份。这种整合将使MeWe的用户能够控制他们的身份数据,并控制他们在不同应用程序上的隐私设置。

Frequency是Polkadot区块链的平行链,与Polkadot主链以及其他平行链兼容。平行链向Polkadot支付综合租赁费,通常使用从其社区收集的资金,而不是对每个区块收取费用。据Frequency称,这提高了系统的可扩展性和稳定性。因此,Frequency区块链可以较为高效的处理社交媒体应用程序中的大量请求。[2023/4/27 14:29:22]

操作完成之后,再去usdt那边取消授权。但这里的approve和revoke操作都需要独立的交易,用户往往为了节省gas费用,不进行revoke,结果如果swap合约出安全问题,用户的资产就可能在不知情的情况下被盗取。

一沉睡三年的以太坊ICO投资者近两日向Kraken转入2400枚以太坊:1月14日消息,据Lookonchain监测,一沉睡三年的以太坊ICO投资者地址(0x0CFb172335b16c87D519cD1475530D20577f5E0E),近两日向Kraken转入2400枚以太坊。该地址于2015年7月30日收到了10万枚以太坊。[2023/1/15 11:12:30]

而在Move中,所有的合约都在一个大的数字世界运行。用户的数字分身可以自由的在合约间移动,执行任何操作,同时用户的状态存在用户自己的存储空间。

外媒:SBF在巴哈马监狱中获得“优待”:12月22日消息,据外媒报道,前FTX首席执行官Sam Bankman-Fried(SBF)在巴哈马福克斯山监狱中一直被关押在医务室,与其他囚犯不同,他可以获得自来水,甚至还有厕所,以及其他福利。据不愿透露姓名的监狱官员说,SBF整天都在看电视新闻和阅读有关自己的文章。

在福克斯山监狱,SBF与其他四名男子共用一间病房。他们都有帆布床,这在监狱里是一种奢侈,囚犯们抱怨说他们被迫睡在光秃秃的地面上,或者睡在老鼠出没的牢房里的临时纸板床上。按照标准程序,那些被限制在医疗单位的人不允许出去锻炼,SBF大部分时间都在帆布床上度过。尽管他最初表示他会反对引渡,但SBF上周晚些时候开始表示他准备返回美国。据一位直接了解此事的人士透露,SBF态度的转变部分与他能够在美国获得保释的预期有关。

此前今日早些时候消息,SBF已抵达巴哈马机场接受美国引渡。(彭博社)[2022/12/22 22:00:42]

用户从swap入口进入,从自己的余额提取usdt,交换,存储可以在同一个交易里原子化完成。这种模式给合约带来更自由的组合模式,可以玩出很多EVM上很难实现的组合玩法,这也是EVM上的账户抽象方案想实现的模式。当然,这也带来了新的安全挑战。

那EVM中能否直接增加一个特性,让合约间的调用可以把用户身份直接带过去?这个技术上是可以实现的,但EVM中支持动态调用,可以调用任意地址的合约,让这种操作的风险变的很难度量,同时EVM的状态变更对用户和钱包都不友好,钱包很难通过状态变化对用户进行提示。

而Move中解决这个安全挑战有两个方法:

1.在预执行合约的时候把合约执行后的状态变更提示给用户,让用户可以知道这个交易操作了自己的哪些重要资产,以及执行后的结果。这个方法StarMask中已经实现,参看链接以及附图https://starcoin.medium.com/starmask-v4-6-

2.可能有部分合约可以通过设置条件,让一部分用户预执行的时候无法发现状态变更。@0xmetazen的分析https://twitter.com/0xmetazen/status/1582581013972414465,但Move中没有动态调用,合约在部署时,它的执行逻辑就是确定的。可以通过静态分析字节码,得到合约所有可能路径上操作的状态,在区块浏览器或钱包里提示给用户。

EVM和Move的两种方案,带来的安全风险是不一样的。Approve方案的安全风险是把一个即时的授权变为长期授权,它的风险不是立刻发生的,比如合约漏洞未被发现或者恶意合约放长线钓大鱼。而一旦发生,用户往往很被动,很多用户可能都忘记授权过哪些合约了。

而Move的方案给了合约更大的自由权,遇到恶意合约会有较大风险,但这种风险是即刻发生的,是可以通过技术手段来检测的。最坏的情况,至少前面冲的快到人趟坑了,可以给后面的人警示,恶意合约会快速暴露出来。

最后,世上没有银弹,不可能靠用了某种技术就解决了所有安全问题,需要链,工具,用户一起努力。

对Move用户的安全建议:

1.选用状态变更提示更完备的钱包,并尝试理解钱包的提示。

2.不要随意和来源未知或未开源的DApp交互。

3.如果做不到上面两点,可以等别人先趟一下坑。

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

金星链

[0:0ms0-0:538ms