2020-11-01 22:09:36 +00:00
|
|
|
package config
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
"log"
|
|
|
|
"reflect"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/heetch/confita"
|
|
|
|
"github.com/heetch/confita/backend"
|
|
|
|
"github.com/heetch/confita/backend/env"
|
|
|
|
"github.com/heetch/confita/backend/flags"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Config is the exporter CLI configuration.
|
|
|
|
type Config struct {
|
|
|
|
AdguardProtocol string `config:"adguard_protocol"`
|
|
|
|
AdguardHostname string `config:"adguard_hostname"`
|
2020-11-02 18:19:37 +00:00
|
|
|
AdguardUsername string `config:"adguard_username"`
|
2020-11-01 22:09:36 +00:00
|
|
|
AdguardPassword string `config:"adguard_password"`
|
2020-11-04 16:10:50 +00:00
|
|
|
ServerPort string `config:"server_port"`
|
2020-11-01 22:09:36 +00:00
|
|
|
Interval time.Duration `config:"interval"`
|
2020-11-04 16:10:50 +00:00
|
|
|
LogLimit string `config:"log_limit"`
|
2020-11-01 22:09:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func getDefaultConfig() *Config {
|
|
|
|
return &Config{
|
|
|
|
AdguardProtocol: "http",
|
|
|
|
AdguardHostname: "127.0.0.1",
|
2020-11-02 18:19:37 +00:00
|
|
|
AdguardUsername: "",
|
2020-11-01 22:09:36 +00:00
|
|
|
AdguardPassword: "",
|
2020-11-04 16:10:50 +00:00
|
|
|
ServerPort: "9617",
|
2020-11-02 18:19:37 +00:00
|
|
|
Interval: 10 * time.Second,
|
2020-11-04 16:10:50 +00:00
|
|
|
LogLimit: "1000",
|
2020-11-01 22:09:36 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Load method loads the configuration by using both flag or environment variables.
|
|
|
|
func Load() *Config {
|
|
|
|
loaders := []backend.Backend{
|
|
|
|
env.NewBackend(),
|
|
|
|
flags.NewBackend(),
|
|
|
|
}
|
|
|
|
|
|
|
|
loader := confita.NewLoader(loaders...)
|
|
|
|
|
|
|
|
cfg := getDefaultConfig()
|
|
|
|
err := loader.Load(context.Background(), cfg)
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
cfg.show()
|
|
|
|
|
|
|
|
return cfg
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c Config) show() {
|
|
|
|
val := reflect.ValueOf(&c).Elem()
|
|
|
|
log.Println("---------------------------------------")
|
|
|
|
log.Println("- AdGuard Home exporter configuration -")
|
|
|
|
log.Println("---------------------------------------")
|
|
|
|
for i := 0; i < val.NumField(); i++ {
|
|
|
|
valueField := val.Field(i)
|
|
|
|
typeField := val.Type().Field(i)
|
|
|
|
|
|
|
|
// Do not print password or api token but do print the authentication method
|
|
|
|
if typeField.Name != "AdguardPassword" {
|
|
|
|
log.Println(fmt.Sprintf("%s : %v", typeField.Name, valueField.Interface()))
|
|
|
|
} else {
|
|
|
|
showAuthenticationMethod(typeField.Name, valueField.String())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
log.Println("---------------------------------------")
|
|
|
|
}
|
|
|
|
|
|
|
|
func showAuthenticationMethod(name, value string) {
|
|
|
|
if len(value) > 0 {
|
|
|
|
log.Println(fmt.Sprintf("AdGuard Authentication Method : %s", name))
|
|
|
|
}
|
|
|
|
}
|