大神教你:如何防止意外的 RAM 消耗
最爱小仙炖
发表于 2022-11-17 15:14:04
145
0
0
概述# z' z( b2 [& L1 t. ^ D4 ~
. j- U- C- A- o, N3 @8 c! W2 d9 V
1.没有Token被偷窃$ [! i& p# m a: t8 s) {$ q
2.正确执行的合约不容易受到攻击% }( M& R' A h" D7 P# I
# m) i" G6 R3 n- y$ h: t" T" W' k
3.治理流程可以修正与各方意图相悖的代码表现9 K& X( C6 [$ {6 ^4 o, W; R
4.出块者-对于保护的措施只有缓解的选项是可行的
5.长期的升级可以使默认的行为更加安全: G: m Z" q$ `* [9 Q1 L
没有Token丢失
4 }# d6 l/ f6 p) V+ m! T5 _
恶意合约利用了智能合约开发者和用户对开发中智能合约最佳实践的误解。这种攻击类似于估计破坏而不是盗窃,一旦EOS治理程序可以审查和纠正这种情况就对于相关方不会有长期损害。
' P4 F1 P, b9 |
防止滥用的最佳实践
P3 O0 g( D& V f4 ^
希望每个用户都可以审查一下他们会与之交互的合约,或者交由信任的第三方代他们去审查合约。这意味着审查者应该谨慎地与使用通知功能的智能合约交互。例如消耗他们的CPU和RAM,发送Token到他们不信任的智能合约。
开发者以编程方式发送Token到一个不信任的第三方指定账号,应该通过一个没有可用RAM资源的账号中继传送。这既适用于中心化交易所处理用户提款,也适用于去中心化交易所通过智能合约操作。有几个可信任的中继合约可用。# m/ H z" u4 X3 H4 c
2 O; |- a" k0 p8 j0 a# j4 K
许多钱包的开发者已经采取行动去提醒用户交易时可能会消耗RAM资源。. o) k! }3 R7 [
通过治理程序释放消耗的RAM
F9 D8 }# n+ \; {& I
我认为代码的意图(【翻译】“代码的意图”即法律)正如用户和开发者所理解的那样,就应该被强制执行。如果一个恶意合约很明显的利用用户意图和代码实际效果之间的不匹配,那么当恶意合约的始作俑者和那些与之牵连的人进行争议仲裁时,BP们有权将恶意合约列入黑名单。
如果仲裁发现代码的行为违背与代码有关联的各方的意图,那么当选的出块者可以更新代码,使结果与各方的原始意图尽可能的匹配。在这种情况下,代码将被更新以释放意外消耗的RAM资源,并且将来不会消耗RAM。: D6 D; G) Q9 \# ?# C, I: B
; B. C& ]; v! n& B6 `( U( u
为什么这是EOSIO的一个功能?9 |& y! D! O0 G/ N1 F% e
5 Q! X% v; B- W
目前有很多针对这个功能导致RAM被滥用的案例。最基本的案例是想要接受用户资金存款的游戏合约。交易所将实施代码以处理来自代币合约的转账通知,然后将交易所的余额记入发送人。在这种情况下,交易所和存款用户可以合理地授权交易合约消费用户的RAM来存储他们的余额。交易所不一定要将用户的余额存储在他们自己的RAM中,因为当许多帐户向交易所发送微小余额可以启用不同的攻击。5 g* N9 J6 h' Y3 v
7 \" j Z2 k& [6 o
EOSIO有一个相关的功能,内联actions,允许合约作为当前交易的一部分调用另一个合约的代码。与action通知功能不同,内联actions仅限于分配生成内联actions的合约的资源。Action通知依靠着原始action所分配的资源权限。
防止意外行为继续发生
; y% n& J3 M+ ~; D: A
虽然现在的设计有很多正当用途,但我们认为现在代码的默认行为与用户和开发者的直觉思维相反运行。为了简化不太常见的使用案例,必须采取措施,防止滥用而导致正常使用更加复杂。- x( M# Q+ X1 H% ?" B- E2 \) z
接下来我们建议只有接收通知的一方才有权利消耗RAM。这样可以安全地将Token发送到任何合约而不必担心它会意外消耗。交易所能够安全的处理提款,无需在处理提款请求前去审查部署到用户账号的合约。; S! p1 M0 s* L5 ?5 ^/ x1 R
在此提议下,现有合约必须获得直接授权才能消耗一些用户可用的RAM。在接受用户的存入之前,交易所合约将要求用户“开立账户以预留用于存储其余额的空间”。然后,传入的存入通知将简单地增加预先分配的RAM,而不是分配新的RAM。
+ T" B& G* S, |5 X% J0 O% I
提议升级路径
: o' X9 m9 ~# ^, T/ G
我们正在准备一个仅限于出块者的升级,它将改变默认行为,以防止action通知的接收者(例如token转账通知)意外消耗发送者的RAM。如果所有的BP都采用这个升级,那么就不太需要滥用的缓解措施了。不幸的是,这个缓解措施可能会破坏有效合约,直到他们可以在action通知处理期间更新到不依赖用户账号上的RAM分配。# k4 h& t& |) J0 [
* C! X& V" ^ C" d! \2 ]9 r
幸运的是,升级合约以采用最新最佳实践的过程应该相对简单。7 N2 B0 W% v1 ?
$ P$ c( S/ f7 e7 E, j- G- @
是否所有节点都采用这个仅限于出块者的升级将会是下一次公投的一部分。 r- A2 K# Q% ^2 _! {: J
1 M% S2 r. G" P7 q. l3 S7 k2 ^
结论
EOSIO正在如当初设计的一般运行,当你正确使用它的时候,它就是安全的。我们相信,对于大多数的情况,我们可以更轻松地使用EOSIO,并与EOS社区合作开发最强大的整体解决方案。
=END=
成为第一个吐槽的人