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:
@ -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 (
|
||||
|
@ -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
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user