1use crate::{
16 triedbmut::TrieDBMutBuilder, CError, DBValue, Result, TrieDBMut, TrieHash, TrieLayout, TrieMut,
17 Value,
18};
19use hash_db::{HashDB, Hasher};
20
21pub struct SecTrieDBMut<'db, L>
26where
27 L: TrieLayout,
28{
29 raw: TrieDBMut<'db, L>,
30}
31
32impl<'db, L> SecTrieDBMut<'db, L>
33where
34 L: TrieLayout,
35{
36 pub fn new(db: &'db mut dyn HashDB<L::Hash, DBValue>, root: &'db mut TrieHash<L>) -> Self {
40 SecTrieDBMut { raw: TrieDBMutBuilder::new(db, root).build() }
41 }
42
43 pub fn from_existing(
45 db: &'db mut dyn HashDB<L::Hash, DBValue>,
46 root: &'db mut TrieHash<L>,
47 ) -> Self {
48 SecTrieDBMut { raw: TrieDBMutBuilder::from_existing(db, root).build() }
49 }
50
51 pub fn db(&self) -> &dyn HashDB<L::Hash, DBValue> {
53 self.raw.db()
54 }
55
56 pub fn db_mut(&mut self) -> &mut dyn HashDB<L::Hash, DBValue> {
58 self.raw.db_mut()
59 }
60}
61
62impl<'db, L> TrieMut<L> for SecTrieDBMut<'db, L>
63where
64 L: TrieLayout,
65{
66 fn root(&mut self) -> &TrieHash<L> {
67 self.raw.root()
68 }
69
70 fn is_empty(&self) -> bool {
71 self.raw.is_empty()
72 }
73
74 fn contains(&self, key: &[u8]) -> Result<bool, TrieHash<L>, CError<L>> {
75 self.raw.contains(&L::Hash::hash(key).as_ref())
76 }
77
78 fn get<'a, 'key>(&'a self, key: &'key [u8]) -> Result<Option<DBValue>, TrieHash<L>, CError<L>>
79 where
80 'a: 'key,
81 {
82 self.raw.get(&L::Hash::hash(key).as_ref())
83 }
84
85 fn insert(
86 &mut self,
87 key: &[u8],
88 value: &[u8],
89 ) -> Result<Option<Value<L>>, TrieHash<L>, CError<L>> {
90 self.raw.insert(&L::Hash::hash(key).as_ref(), value)
91 }
92
93 fn remove(&mut self, key: &[u8]) -> Result<Option<Value<L>>, TrieHash<L>, CError<L>> {
94 self.raw.remove(&L::Hash::hash(key).as_ref())
95 }
96}