1
0
mirror of https://github.com/ipfs/kubo.git synced 2025-06-23 13:44:27 +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. // Config is used to load IPFS config files.
type Config struct { type Config struct {
Identity Identity // local node's peer identity Identity Identity // local node's peer identity
Datastore Datastore // local node's storage
Addresses Addresses // local node's addresses Addresses Addresses // local node's addresses
Mounts Mounts // local node's mount points Mounts Mounts // local node's mount points
Version Version // local node's version management Version Version // local node's version management
@ -29,8 +30,6 @@ type Config struct {
SupernodeRouting SupernodeClientConfig // local node's routing servers (if SupernodeRouting enabled) SupernodeRouting SupernodeClientConfig // local node's routing servers (if SupernodeRouting enabled)
API API // local node's API settings API API // local node's API settings
Swarm SwarmConfig Swarm SwarmConfig
Datastore Datastore
} }
const ( const (

View File

@ -324,11 +324,17 @@ func (r *FSRepo) openConfig() error {
// openDatastore returns an error if the config file is not present. // openDatastore returns an error if the config file is not present.
func (r *FSRepo) openDatastore() error { func (r *FSRepo) openDatastore() error {
d, err := openDefaultDatastore(r) switch r.config.Datastore.Type {
if err != nil { case "default", "leveldb", "":
return err 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 return nil
} }