提交 bbe79545 编写于 作者: O obscuren

Secure trie shakey / key matching

上级 d6da5333
...@@ -28,17 +28,17 @@ func (self *StateDB) RawDump() World { ...@@ -28,17 +28,17 @@ func (self *StateDB) RawDump() World {
it := self.trie.Iterator() it := self.trie.Iterator()
for it.Next() { for it.Next() {
stateObject := NewStateObjectFromBytes(common.BytesToAddress(it.Key), it.Value, self.db) addr := self.trie.GetKey(it.Key)
stateObject := NewStateObjectFromBytes(common.BytesToAddress(addr), it.Value, self.db)
account := Account{Balance: stateObject.balance.String(), Nonce: stateObject.nonce, Root: common.Bytes2Hex(stateObject.Root()), CodeHash: common.Bytes2Hex(stateObject.codeHash)} account := Account{Balance: stateObject.balance.String(), Nonce: stateObject.nonce, Root: common.Bytes2Hex(stateObject.Root()), CodeHash: common.Bytes2Hex(stateObject.codeHash)}
account.Storage = make(map[string]string) account.Storage = make(map[string]string)
storageIt := stateObject.State.trie.Iterator() storageIt := stateObject.State.trie.Iterator()
for storageIt.Next() { for storageIt.Next() {
fmt.Println("value", storageIt.Value) account.Storage[common.Bytes2Hex(self.trie.GetKey(storageIt.Key))] = common.Bytes2Hex(storageIt.Value)
account.Storage[common.Bytes2Hex(storageIt.Key)] = common.Bytes2Hex(storageIt.Value)
} }
world.Accounts[common.Bytes2Hex(it.Key)] = account world.Accounts[common.Bytes2Hex(addr)] = account
} }
return world return world
} }
......
...@@ -2,6 +2,8 @@ package trie ...@@ -2,6 +2,8 @@ package trie
import "github.com/ethereum/go-ethereum/crypto" import "github.com/ethereum/go-ethereum/crypto"
var keyPrefix = []byte("secure-key-")
type SecureTrie struct { type SecureTrie struct {
*Trie *Trie
} }
...@@ -11,7 +13,10 @@ func NewSecure(root []byte, backend Backend) *SecureTrie { ...@@ -11,7 +13,10 @@ func NewSecure(root []byte, backend Backend) *SecureTrie {
} }
func (self *SecureTrie) Update(key, value []byte) Node { func (self *SecureTrie) Update(key, value []byte) Node {
return self.Trie.Update(crypto.Sha3(key), value) shaKey := crypto.Sha3(key)
self.Trie.cache.Put(append(keyPrefix, shaKey...), key)
return self.Trie.Update(shaKey, value)
} }
func (self *SecureTrie) UpdateString(key, value string) Node { func (self *SecureTrie) UpdateString(key, value string) Node {
return self.Update([]byte(key), []byte(value)) return self.Update([]byte(key), []byte(value))
...@@ -34,3 +39,7 @@ func (self *SecureTrie) DeleteString(key string) Node { ...@@ -34,3 +39,7 @@ func (self *SecureTrie) DeleteString(key string) Node {
func (self *SecureTrie) Copy() *SecureTrie { func (self *SecureTrie) Copy() *SecureTrie {
return &SecureTrie{self.Trie.Copy()} return &SecureTrie{self.Trie.Copy()}
} }
func (self *SecureTrie) GetKey(shaKey []byte) []byte {
return self.Trie.cache.Get(append(keyPrefix, shaKey...))
}
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册