package config import ( "fmt" "github.com/rs/zerolog" "github.com/rs/zerolog/log" "gopkg.in/yaml.v3" "os" "path/filepath" "strconv" "strings" ) var OpengistVersion = "1.2.0" var C *config // Not using nested structs because the library // doesn't support dot notation in this case sadly type config struct { LogLevel string `yaml:"log-level"` ExternalUrl string `yaml:"external-url"` OpengistHome string `yaml:"opengist-home"` DBFilename string `yaml:"db-filename"` HttpHost string `yaml:"http.host"` HttpPort string `yaml:"http.port"` HttpGit bool `yaml:"http.git-enabled"` HttpTLSEnabled bool `yaml:"http.tls-enabled"` HttpCertFile string `yaml:"http.cert-file"` HttpKeyFile string `yaml:"http.key-file"` SshGit bool `yaml:"ssh.git-enabled"` SshHost string `yaml:"ssh.host"` SshPort string `yaml:"ssh.port"` SshExternalDomain string `yaml:"ssh.external-domain"` SshKeygen string `yaml:"ssh.keygen-executable"` GithubClientKey string `yaml:"github.client-key"` GithubSecret string `yaml:"github.secret"` GiteaClientKey string `yaml:"gitea.client-key"` GiteaSecret string `yaml:"gitea.secret"` GiteaUrl string `yaml:"gitea.url"` } func configWithDefaults() (*config, error) { homeDir, err := os.UserHomeDir() c := &config{} if err != nil { return c, err } c.LogLevel = "warn" c.OpengistHome = filepath.Join(homeDir, ".opengist") c.DBFilename = "opengist.db" c.HttpHost = "0.0.0.0" c.HttpPort = "6157" c.HttpGit = true c.HttpTLSEnabled = false c.SshGit = true c.SshHost = "0.0.0.0" c.SshPort = "2222" c.SshKeygen = "ssh-keygen" c.GiteaUrl = "http://gitea.com" return c, nil } func InitConfig(configPath string) error { // Default values c, err := configWithDefaults() if err != nil { return err } if configPath != "" { absolutePath, _ := filepath.Abs(configPath) absolutePath = filepath.Clean(absolutePath) file, err := os.Open(absolutePath) if err != nil { if !os.IsNotExist(err) { return err } fmt.Println("No YML config file found at " + absolutePath) } else { fmt.Println("Using config file: " + absolutePath) // Override default values with values from config.yml d := yaml.NewDecoder(file) if err = d.Decode(&c); err != nil { return err } defer file.Close() } } else { fmt.Println("No config file specified. Using default values.") } // Override default values with environment variables (as yaml) configEnv := os.Getenv("CONFIG") if configEnv != "" { fmt.Println("Using config from environment variable: CONFIG") d := yaml.NewDecoder(strings.NewReader(configEnv)) if err = d.Decode(&c); err != nil { return err } } C = c return nil } func InitLog() { if err := os.MkdirAll(filepath.Join(GetHomeDir(), "log"), 0755); err != nil { panic(err) } file, err := os.OpenFile(filepath.Join(GetHomeDir(), "log", "opengist.log"), os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0644) if err != nil { panic(err) } var level zerolog.Level level, err = zerolog.ParseLevel(C.LogLevel) if err != nil { level = zerolog.InfoLevel } if os.Getenv("DEV") == "1" { multi := zerolog.MultiLevelWriter(zerolog.NewConsoleWriter(), file) log.Logger = zerolog.New(multi).Level(level).With().Timestamp().Logger() } else { log.Logger = zerolog.New(file).Level(level).With().Timestamp().Logger() } } func CheckGitVersion(version string) (bool, error) { versionParts := strings.Split(version, ".") if len(versionParts) < 2 { return false, fmt.Errorf("invalid version string") } major, err := strconv.Atoi(versionParts[0]) if err != nil { return false, fmt.Errorf("invalid major version number") } minor, err := strconv.Atoi(versionParts[1]) if err != nil { return false, fmt.Errorf("invalid minor version number") } // Check if version is prior to 2.20 if major < 2 || (major == 2 && minor < 20) { return false, nil } return true, nil } func GetHomeDir() string { absolutePath, _ := filepath.Abs(C.OpengistHome) return filepath.Clean(absolutePath) }