|
package proxy
|
|
|
|
import (
|
|
"github.com/tendermint/tendermint/lite"
|
|
lclient "github.com/tendermint/tendermint/lite/client"
|
|
cmn "github.com/tendermint/tmlibs/common"
|
|
dbm "github.com/tendermint/tmlibs/db"
|
|
log "github.com/tendermint/tmlibs/log"
|
|
)
|
|
|
|
func NewCertifier(chainID, rootDir string, client lclient.SignStatusClient, logger log.Logger) (*lite.InquiringCertifier, error) {
|
|
|
|
logger = logger.With("module", "lite/proxy")
|
|
logger.Info("lite/proxy/NewCertifier()...", "chainID", chainID, "rootDir", rootDir, "client", client)
|
|
|
|
memProvider := lite.NewDBProvider("trusted.mem", dbm.NewMemDB()).SetLimit(10)
|
|
lvlProvider := lite.NewDBProvider("trusted.lvl", dbm.NewDB("trust-base", dbm.LevelDBBackend, rootDir))
|
|
trust := lite.NewMultiProvider(
|
|
memProvider,
|
|
lvlProvider,
|
|
)
|
|
source := lclient.NewProvider(chainID, client)
|
|
cert := lite.NewInquiringCertifier(chainID, trust, source)
|
|
cert.SetLogger(logger) // Sets logger recursively.
|
|
|
|
// TODO: Make this more secure, e.g. make it interactive in the console?
|
|
_, err := trust.LatestFullCommit(chainID, 1, 1<<63-1)
|
|
if err != nil {
|
|
logger.Info("lite/proxy/NewCertifier found no trusted full commit, initializing from source from height 1...")
|
|
fc, err := source.LatestFullCommit(chainID, 1, 1)
|
|
if err != nil {
|
|
return nil, cmn.ErrorWrap(err, "fetching source full commit @ height 1")
|
|
}
|
|
err = trust.SaveFullCommit(fc)
|
|
if err != nil {
|
|
return nil, cmn.ErrorWrap(err, "saving full commit to trusted")
|
|
}
|
|
}
|
|
|
|
return cert, nil
|
|
}
|