gomuks/config/config.go

99 lines
2.7 KiB
Go
Raw Normal View History

// gomuks - A terminal Matrix client written in Go.
// Copyright (C) 2018 Tulir Asokan
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
2018-03-18 21:24:03 +02:00
package config
import (
"fmt"
"io/ioutil"
"os"
"path/filepath"
"gopkg.in/yaml.v2"
"maunium.net/go/gomuks/debug"
)
2018-03-23 23:39:17 +02:00
// Config contains the main config of gomuks.
type Config struct {
2018-03-21 23:29:58 +02:00
UserID string `yaml:"mxid"`
HS string `yaml:"homeserver"`
2018-03-22 19:51:20 +02:00
Dir string `yaml:"-"`
HistoryDir string `yaml:"history_dir"`
MediaDir string `yaml:"media_dir"`
2018-03-22 19:51:20 +02:00
Session *Session `yaml:"-"`
}
2018-03-23 23:39:17 +02:00
// NewConfig creates a config that loads data from the given directory.
func NewConfig(configDir, cacheDir string) *Config {
2018-03-13 21:58:43 +02:00
return &Config{
Dir: configDir,
HistoryDir: filepath.Join(cacheDir, "history"),
MediaDir: filepath.Join(cacheDir, "media"),
2018-03-13 21:58:43 +02:00
}
}
2018-03-23 23:39:17 +02:00
// Clear clears the session cache and removes all history.
2018-03-22 19:51:20 +02:00
func (config *Config) Clear() {
if config.Session != nil {
config.Session.Clear()
}
os.RemoveAll(config.HistoryDir)
2018-04-17 18:13:38 +03:00
os.RemoveAll(config.MediaDir)
2018-03-22 19:51:20 +02:00
}
2018-03-23 23:39:17 +02:00
// Load loads the config from config.yaml in the directory given to the config struct.
2018-03-13 21:58:43 +02:00
func (config *Config) Load() {
2018-03-22 19:51:20 +02:00
os.MkdirAll(config.Dir, 0700)
2018-04-17 18:13:38 +03:00
2018-03-22 19:51:20 +02:00
configPath := filepath.Join(config.Dir, "config.yaml")
data, err := ioutil.ReadFile(configPath)
if err != nil {
if os.IsNotExist(err) {
2018-04-17 18:13:38 +03:00
os.MkdirAll(config.HistoryDir, 0700)
os.MkdirAll(config.MediaDir, 0700)
return
}
2018-04-22 20:13:57 +03:00
fmt.Println("Failed to read config from", configPath)
panic(err)
}
err = yaml.Unmarshal(data, &config)
if err != nil {
fmt.Println("Failed to parse config at", configPath)
panic(err)
}
2018-04-17 18:13:38 +03:00
os.MkdirAll(config.HistoryDir, 0700)
os.MkdirAll(config.MediaDir, 0700)
}
2018-03-23 23:39:17 +02:00
// Save saves this config to config.yaml in the directory given to the config struct.
func (config *Config) Save() {
2018-03-22 19:51:20 +02:00
os.MkdirAll(config.Dir, 0700)
data, err := yaml.Marshal(&config)
if err != nil {
2018-03-18 21:24:03 +02:00
debug.Print("Failed to marshal config")
panic(err)
}
2018-03-22 19:51:20 +02:00
path := filepath.Join(config.Dir, "config.yaml")
err = ioutil.WriteFile(path, data, 0600)
if err != nil {
2018-03-18 21:24:03 +02:00
debug.Print("Failed to write config to", path)
panic(err)
}
}