forked from cerc-io/ipld-eth-server
2de9c5bd48
* Use groupcache pool for state db access * Group cache config and logging stats on timer * Integrate state validator into server * Use tagged ipfs-ethdb * groupcache config for tests * Work around duplicate registration of groupcache error in tests * Use tagged version of eth-ipfs-state-validator * State validation command. * Validator for static replicas to keep cache warm * Update docker go-version and go.mod. * Address comments and self review. * Fix ipfs-ethdb version. Co-authored-by: Arijit Das <arijitad.in@gmail.com>
39 lines
1.1 KiB
Go
39 lines
1.1 KiB
Go
// VulcanizeDB
|
|
// Copyright © 2021 Vulcanize
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU Affero General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU Affero General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU Affero General Public License
|
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
package shared
|
|
|
|
type PoolConfig struct {
|
|
Enabled bool
|
|
HttpEndpoint string
|
|
PeerHttpEndpoints []string
|
|
}
|
|
|
|
type GroupConfig struct {
|
|
CacheSizeInMB int
|
|
CacheExpiryInMins int
|
|
LogStatsIntervalInSecs int
|
|
|
|
// Used in tests to override the cache name, to work around
|
|
// the "duplicate registration of group" error from groupcache
|
|
Name string
|
|
}
|
|
|
|
type GroupCacheConfig struct {
|
|
Pool PoolConfig
|
|
StateDB GroupConfig
|
|
}
|