1
0
mirror of https://github.com/ipfs/kubo.git synced 2025-06-22 12:51:19 +08:00

Implement pluggable Datastore types, with nothing implemented yet

License: MIT
Signed-off-by: Tommi Virtanen <tv@eagain.net>
This commit is contained in:
Tommi Virtanen
2015-05-20 10:17:38 -07:00
committed by Jeromy
parent b76581d6c7
commit 9497e26fbd
2 changed files with 11 additions and 6 deletions

View File

@ -18,6 +18,7 @@ var log = logging.Logger("config")
// Config is used to load IPFS config files.
type Config struct {
Identity Identity // local node's peer identity
Datastore Datastore // local node's storage
Addresses Addresses // local node's addresses
Mounts Mounts // local node's mount points
Version Version // local node's version management
@ -29,8 +30,6 @@ type Config struct {
SupernodeRouting SupernodeClientConfig // local node's routing servers (if SupernodeRouting enabled)
API API // local node's API settings
Swarm SwarmConfig
Datastore Datastore
}
const (

View File

@ -324,11 +324,17 @@ func (r *FSRepo) openConfig() error {
// openDatastore returns an error if the config file is not present.
func (r *FSRepo) openDatastore() error {
d, err := openDefaultDatastore(r)
if err != nil {
return err
switch r.config.Datastore.Type {
case "default", "leveldb", "":
d, err := openDefaultDatastore(r)
if err != nil {
return err
}
r.ds = d
default:
return fmt.Errorf("unknown datastore type: %s", r.config.Datastore.Type)
}
r.ds = d
return nil
}