notary.go 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. // Copyright 2020 The go-ethereum Authors
  2. // This file is part of the go-ethereum library.
  3. //
  4. // The go-ethereum library is free software: you can redistribute it and/or modify
  5. // it under the terms of the GNU Lesser General Public License as published by
  6. // the Free Software Foundation, either version 3 of the License, or
  7. // (at your option) any later version.
  8. //
  9. // The go-ethereum library is distributed in the hope that it will be useful,
  10. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. // GNU Lesser General Public License for more details.
  13. //
  14. // You should have received a copy of the GNU Lesser General Public License
  15. // along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
  16. package trie
  17. import (
  18. "github.com/ethereum/go-ethereum/ethdb"
  19. "github.com/ethereum/go-ethereum/ethdb/memorydb"
  20. )
  21. // keyValueNotary tracks which keys have been accessed through a key-value reader
  22. // with te scope of verifying if certain proof datasets are maliciously bloated.
  23. type keyValueNotary struct {
  24. ethdb.KeyValueReader
  25. reads map[string]struct{}
  26. }
  27. // newKeyValueNotary wraps a key-value database with an access notary to track
  28. // which items have bene accessed.
  29. func newKeyValueNotary(db ethdb.KeyValueReader) *keyValueNotary {
  30. return &keyValueNotary{
  31. KeyValueReader: db,
  32. reads: make(map[string]struct{}),
  33. }
  34. }
  35. // Get retrieves an item from the underlying database, but also tracks it as an
  36. // accessed slot for bloat checks.
  37. func (k *keyValueNotary) Get(key []byte) ([]byte, error) {
  38. k.reads[string(key)] = struct{}{}
  39. return k.KeyValueReader.Get(key)
  40. }
  41. // Accessed returns s snapshot of the original key-value store containing only the
  42. // data accessed through the notary.
  43. func (k *keyValueNotary) Accessed() ethdb.KeyValueStore {
  44. db := memorydb.New()
  45. for keystr := range k.reads {
  46. key := []byte(keystr)
  47. val, _ := k.KeyValueReader.Get(key)
  48. db.Put(key, val)
  49. }
  50. return db
  51. }