2018-04-09 14:12:54 +02:00
|
|
|
package app
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2018-04-09 15:27:21 +02:00
|
|
|
"github.com/spf13/viper"
|
2018-04-09 15:24:57 +02:00
|
|
|
"log"
|
2018-04-09 15:27:21 +02:00
|
|
|
"os"
|
2018-04-09 14:12:54 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// Config represents the configuration of the server application.
|
|
|
|
type Config struct {
|
|
|
|
Address string
|
2018-04-09 15:24:57 +02:00
|
|
|
Port string
|
2018-04-10 15:20:23 +02:00
|
|
|
Prefix string
|
|
|
|
Dir string
|
2018-04-09 15:24:57 +02:00
|
|
|
TLS *TLS
|
2018-04-10 15:20:23 +02:00
|
|
|
Users map[string]*UserInfo
|
2018-04-09 15:24:57 +02:00
|
|
|
}
|
|
|
|
|
2018-04-10 15:20:23 +02:00
|
|
|
// TLS allows specification of a certificate and private key file.
|
2018-04-09 15:24:57 +02:00
|
|
|
type TLS struct {
|
|
|
|
CertFile string
|
|
|
|
KeyFile string
|
2018-04-09 14:12:54 +02:00
|
|
|
}
|
|
|
|
|
2018-04-10 15:20:23 +02:00
|
|
|
// UserInfo allows storing of a password and user directory.
|
|
|
|
type UserInfo struct {
|
|
|
|
Password string
|
|
|
|
Dir string
|
|
|
|
}
|
|
|
|
|
2018-04-09 14:12:54 +02:00
|
|
|
// ParseConfig parses the application configuration an sets defaults.
|
2018-04-10 15:20:23 +02:00
|
|
|
func ParseConfig() *Config {
|
|
|
|
var cfg = &Config{}
|
2018-04-09 14:12:54 +02:00
|
|
|
|
2018-04-09 15:27:21 +02:00
|
|
|
setDefaults()
|
2018-04-09 14:12:54 +02:00
|
|
|
viper.SetConfigName("config")
|
|
|
|
viper.AddConfigPath("./config")
|
|
|
|
viper.AddConfigPath("$HOME/.swd")
|
|
|
|
viper.AddConfigPath(".")
|
|
|
|
|
|
|
|
err := viper.ReadInConfig()
|
|
|
|
if err != nil {
|
2018-04-09 15:24:57 +02:00
|
|
|
log.Fatal(fmt.Errorf("Fatal error config file: %s", err))
|
2018-04-09 14:12:54 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
err = viper.Unmarshal(&cfg)
|
|
|
|
if err != nil {
|
2018-04-09 15:24:57 +02:00
|
|
|
log.Fatal(fmt.Errorf("Fatal error parsing config file: %s", err))
|
|
|
|
}
|
|
|
|
|
|
|
|
if cfg.TLS != nil {
|
|
|
|
if _, err := os.Stat(cfg.TLS.KeyFile); err != nil {
|
|
|
|
log.Fatal(fmt.Errorf("TLS keyFile doesn't exist: %s", err))
|
|
|
|
}
|
|
|
|
if _, err := os.Stat(cfg.TLS.CertFile); err != nil {
|
|
|
|
log.Fatal(fmt.Errorf("TLS certFile doesn't exist: %s", err))
|
|
|
|
}
|
2018-04-09 14:12:54 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return cfg
|
|
|
|
}
|
|
|
|
|
|
|
|
// setDefaults adds some default values for the configuration
|
|
|
|
func setDefaults() {
|
|
|
|
viper.SetDefault("Address", "127.0.0.1")
|
|
|
|
viper.SetDefault("Port", "8000")
|
2018-04-10 15:20:23 +02:00
|
|
|
viper.SetDefault("Prefix", "")
|
|
|
|
viper.SetDefault("Dir", "/tmp")
|
2018-04-09 15:24:57 +02:00
|
|
|
viper.SetDefault("TLS", nil)
|
2018-04-09 14:12:54 +02:00
|
|
|
}
|