ceph_exporter/config.go
Yue Zhu 238f39a71b
Refactoring for nautilus branch (#183)
* Run -race for go test

* Upgrade go 1.15.3

* Extract a function to create rados connection

* Convert to go module; update dependencies

* Use environment variables to pass in parameters

* Make rados connection short lived

* Use float64 for JSON number in cluster_usage.go

* Use mocks to replace the NoopConn

* Add "-tags nautilus" for "go test" and "go build"

* Update readme

* Update go mod
2020-10-28 14:42:52 -04:00

41 lines
730 B
Go

package main
import (
"io/ioutil"
"os"
"gopkg.in/yaml.v2"
)
type ClusterConfig struct {
ClusterLabel string `yaml:"cluster_label"`
User string `yaml:"user"`
ConfigFile string `yaml:"config_file"`
}
// Config is the top-level configuration for Metastord.
type Config struct {
Cluster []*ClusterConfig
}
// fileExists returns true if the path exists and is a file.
func fileExists(path string) bool {
stat, err := os.Stat(path)
return !os.IsNotExist(err) && !stat.IsDir()
}
func ParseConfig(p string) (*Config, error) {
cfgData, err := ioutil.ReadFile(p)
if err != nil {
return nil, err
}
var cfg Config
err = yaml.Unmarshal(cfgData, &cfg)
if err != nil {
return nil, err
}
return &cfg, nil
}