mirror of
https://github.com/digitalocean/ceph_exporter
synced 2025-01-25 08:22:48 +00:00
238f39a71b
* 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
41 lines
730 B
Go
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
|
|
}
|