Do not allow nil values to be set in CacheKVStore (#2708)
* Do not allow nil values to be set in CacheKVStore
This commit is contained in:
parent
4f46a4c4d5
commit
c7b3efdd02
|
@ -52,7 +52,8 @@ IMPROVEMENTS
|
|||
- \#2660 [x/mock/simulation] Staking transactions get tested far more frequently
|
||||
- \#2610 [x/stake] Block redelegation to and from the same validator
|
||||
- \#2652 [x/auth] Add benchmark for get and set account
|
||||
- \#2685 [x/store] Add general merkle absence proof (also for empty substores)
|
||||
- \#2685 [store] Add general merkle absence proof (also for empty substores)
|
||||
- \#2708 [store] Disallow setting nil values
|
||||
|
||||
* Tendermint
|
||||
|
||||
|
|
|
@ -61,6 +61,7 @@ func (ci *cacheKVStore) Set(key []byte, value []byte) {
|
|||
ci.mtx.Lock()
|
||||
defer ci.mtx.Unlock()
|
||||
ci.assertValidKey(key)
|
||||
ci.assertValidValue(value)
|
||||
|
||||
ci.setCacheValue(key, value, false, true)
|
||||
}
|
||||
|
@ -196,6 +197,12 @@ func (ci *cacheKVStore) assertValidKey(key []byte) {
|
|||
}
|
||||
}
|
||||
|
||||
func (ci *cacheKVStore) assertValidValue(value []byte) {
|
||||
if value == nil {
|
||||
panic("value is nil")
|
||||
}
|
||||
}
|
||||
|
||||
// Only entrypoint to mutate ci.cache.
|
||||
func (ci *cacheKVStore) setCacheValue(key, value []byte, deleted bool, dirty bool) {
|
||||
ci.cache[string(key)] = cValue{
|
||||
|
|
|
@ -127,7 +127,7 @@ type KVStore interface {
|
|||
// Has checks if a key exists. Panics on nil key.
|
||||
Has(key []byte) bool
|
||||
|
||||
// Set sets the key. Panics on nil key.
|
||||
// Set sets the key. Panics on nil key or value.
|
||||
Set(key, value []byte)
|
||||
|
||||
// Delete deletes the key. Panics on nil key.
|
||||
|
|
Loading…
Reference in New Issue