宇宙链 宇宙链
Ctrl+D收藏宇宙链
首页 > 币安币 > 正文

Rust智能合约养成日记(9)

作者:

时间:1900/1/1 0:00:00

程序维护中的一个基本问题是——缺陷修复总会以%的机率引入新的bug。所以整个过程是前进两步,后退一步。——布鲁克斯《人月神话》

智能合约本质上是程序,既然是程序,缺陷就不可避免。即便是经过大量测试和审计的智能合约,仍然可能会有漏洞。合约的漏洞如果被攻击者利用,可能造成用户资产的损失,导致严重的后果。漏洞的修复往往需要通过合约升级来实现。除了漏洞修复,新特性的加入也需要合约升级。因此合约的可升级性非常有必要。本期Rust智能合约养成日记,将为大家介绍Rust合约的升级方式。2.Solidity合约常见升级方式

以太坊中,智能合约具有不可变性,一旦被部署到链上,没有人可以改变它。

那么如果合约存在漏洞或合约需要添加新功能,该如何修改合约的代码?解决方案是将新的合约部署到区块链上。

First Digital Trust首席执行官:香港仍是安全的金融中心,可与新加坡携手探索加密领域:10月20日消息,香港数字资产托管机构First Digital Trust的首席执行官Vincent Chok表示,香港没有资本管制,没有外汇管制,仍然是一个非常安全的金融中心。此外,他认为香港和新加坡之间是互补关系而不是竞争关系,新加坡在监管数字资产方面非常强大,香港凭借金融经验和基础设施可以与其建立良好的伙伴关系,共同创建一个真正强大的司法管辖区。

据悉,First Digital Trust是香港咨询公司First Digital旗下的数字资产平台。据此前报道,香港政府将发布虚拟资产政策宣言,推动建设国际虚拟资产中心。(Forkast)[2022/10/20 16:32:24]

该方法面临的挑战是,solidity每次部署合约后,合约都会被分配一个唯一的地址。因此所有用到了该合约的DApps都需要修改合约地址来适配新的合约。此外,旧版本合约中的状态需要迁移到新版本合约中,状态较为复杂的合约迁移的工作量很大,容易出错,而且复制数据的Gas费用高。

Trusted computing将开展NFT相关业务:据官方消息,Trusted computing(TCP)宣布在NFT领域进行多项开发,综合数据隐私属性推出NFT市场平台 、NFT挖矿 、NFT生成工具等。[2021/10/22 20:49:30]

因此,我们通常采用数据和逻辑分离的架构,将数据保存在一个不处理任何逻辑的合约中,所有的逻辑在另一个合约中实现。通常合约升级修改的是逻辑,使用该架构只需要升级逻辑合约,不需要担心状态迁移。

为了解决这个问题,可以使用代理合约,具体架构如下图所示。

代理合约用来来存储数据,并且使用delegatecall调用逻辑合约A,这样合约A读写的数据都存储在代理合约中。如果需要升级逻辑合约,部署新的合约B,然后发一条交易给代理合约,让代理合约指向新的逻辑合约B即可。

BENQI宣布Avalanche Rush计划第二阶段已启动:10月5日消息,算法流动性市场协议BENQI宣布Avalanche Rush计划的第二阶段已启动,将持续45天。据了解,该计划的第一阶段是Avalanche生态系统的广泛成功,特别是BENQI的贷款市场。该协议的供应价值达到了28亿美元的峰值,借款超过10亿美元,用户总数接近14000。在这一阶段,BENQI获得了400万美元的AVAX额外奖励,其中大部分将用于QI和AVAX市场。[2021/10/5 18:19:12]

3.NEAR合约升级常用方法

接下来我们将以StatusMessage项目为例,给大家介绍NEAR合约的常用升级方法,如下是StatusMessage的合约代码

我们先将编译好的合约部署在测试网上。

GMO Trust与Celsius达成合作,支持稳定币ZUSD作为加密贷款抵押品:日本互联网集团GMO旗下的合规加密货币子公司GMO Trust宣布与加密货币借贷平台Celsius展开新合作。客户将能够使用ZUSD作为加密贷款的抵押品。ZUSD是GMO Trust发行的一种受监管的、与美元挂钩的稳定币。据悉,ZUSD最初将上线Celsius平台。(PRNewswire)[2021/5/7 21:35:15]

transaction如下

接着我们调用set_status方法,向合约中存储数据

transaction如下

接下来我们详细讨论两种不同的合约升级情况

3.1合约数据结构未被修改

例如我们增加一个函数:

编译后使用deploy重新部署:

编译后使用deploy重新部署:

接着我们调用get_status方法读取之前写入的数据

原来合约中的数据能成功读取:

这是因为NEAR合约可以重复部署,如果一个账户已经部署过合约,再次调用neardeploy命令可以将新的合约代码部署到该账户上。如果我们只修改合约逻辑,不涉及数据结构的修改,可以直接使用neardeploy部署新的代码。

3.2?合约数据结构被修改

我们将该合约升级,修改了原来的数据结构,去除了records,新增了taglines和bios

我们尝试再次重新部署:

合约还是成功部署了:

但是我们调用get_tagline方法读取存储的数据:

会发现出错了,错误提示如下:

Cannotdeserializethecontractstate.

具体的transaction见:

https://explorer.testnet.near.org/transactions/4hQQ1zAwU5bsbfb6tA6DQDqjmFcHsBwaBctdHaPiCKHu

这是因为合约的状态是以序列化数据的形式进行持久化存储的,重新部署合约后,代码中的数据结构变了,状态没有变,新的数据结构匹配不上旧状态,就出错了。

3.3?Migrate升级智能合约

NEAR提供了Migrate方法去帮助我们对合约进行升级,针对3.2中所出现的错误,我们在新的合约中加入migrate方法:

代码中的#表示在migrate函数执行前不要加载状态。接着,我们重新部署合约,但是在部署的同时调用migrate方法

如下所示,该合约被成功部署:

我们尝试调用合约新增的方法get_tagline去获取新增的数据taglines

可以看到方法被成功调用,旧的合约数据也被迁移到新的合约

4.合约升级的安全考量

合约安全升级首先要考虑权限控制,一般合约只能由开发者或DAO升级。上一期Rust智能合约养成日记合约安全之权限控制介绍了特权函数的访问控制,一般合约的升级函数为onlyowner函数,确保只能由owner调用。

我们推荐尽可能将合约的owner设置为DAO,通过提案和投票来共同管理合约。因为owner设置为个人账户,合约高度中心化,owner可以随意修改合约数据,还存在owner私钥丢失的风险。

除此之外,开发者在做合约迁移时,还可以考虑以下几点建议

在迁移函数前加入#,确保执行迁移函数前不加载状态。

迁移完成后尽量删除迁移函数,确保迁移函数只被调用一次。

新增的数据结构在迁移时完成初始化。

标签:USTTRUSTTRUNEARAustralian Safe ShepherdMixTrustUtrustnear币是中国团队的项目

币安币热门资讯
Libcoin (LIB)

一、项目简介? Libcoin通过插入第一个标记化的Gigafactory来增强加密功能。这使新一类投资者参与顶级绿色能源投资的去中心化.

1900/1/1 0:00:00
Gate.io Presents High Quality Trading Strategies To Facilitate Your Trading Experience

Gate.ioCopyTradingisnowhometo16quantitativeproducts.

1900/1/1 0:00:00
Hotcoin關於支持ERC20 Injective Protocol(INJ)主網置換的公告

尊敬的用戶:根據INJ官方計劃,Hotcoin將支持ERC20InjectiveProtocol主網置換的計劃,具體安排如下:Hotcoin將於(GMT8)2022年04月11日17:00暫停ERC20INJ的充值、提現業務.

1900/1/1 0:00:00
Cessation of all Point Card Functionalities for Singapore-based Accounts

DearValuedUsers,FollowingHuobiGlobal’s(“Huobi”)announcementofthe?retirementofSingapore-basedusers.

1900/1/1 0:00:00
Element空投了,但我却被“反薅”了

今日,羊毛党们再次回忆起了被BetaFinance支配的恐惧,只不过这次的主角换成了?ElementFinance.

1900/1/1 0:00:00
BKEX 关于ETP专区WAVES3S、COTI3S、XLM3S等10种标的进行份额合并的公告

尊敬的用户:?? 由于ETP专区部分标的触发了BKEXETP产品份额合并机制。BKEX将在2022年3月30日15:00对ETP专区部分标的进行合并操作,详情如下:合并后新份额的名称、简称、交易对都与合并前相同,合并前后时间区间合并标.

1900/1/1 0:00:00