gitpb/config.go

109 lines
3.1 KiB
Go
Raw Normal View History

package gitpb
// functions to import and export the protobuf
// data to and from config files
import (
"errors"
"os"
"path/filepath"
"go.wit.com/log"
)
2024-12-07 16:50:26 -06:00
// write to ~/.config/forge/ unless ENV{FORGE_GOSRC} is set
func (all *Repos) ConfigSave() error {
2024-12-07 16:50:26 -06:00
if os.Getenv("FORGE_GOSRC") == "" {
homeDir, _ := os.UserHomeDir()
fullpath := filepath.Join(homeDir, ".config/forge")
2024-12-07 16:50:26 -06:00
os.Setenv("FORGE_GOSRC", fullpath)
}
if all == nil {
log.Warn("gitpb all == nil")
2024-12-01 22:37:11 -06:00
return errors.New("gitpb.ConfigSave() all == nil")
}
data, err := all.Marshal()
if err != nil {
log.Info("gitpb proto.Marshal() failed len", len(data), err)
return err
}
log.Info("gitpb.ConfigSave() repos.Marshal() worked len", len(data))
configWrite("repos.pb", data)
return nil
}
2024-12-17 06:37:14 -06:00
// load the repos.pb file. I shouldn't really matter if this
// fails. the file should be autogenerated. This is used
// locally just for speed
func (all *Repos) ConfigLoad() error {
2024-12-07 16:50:26 -06:00
if os.Getenv("FORGE_GOSRC") == "" {
homeDir, _ := os.UserHomeDir()
fullpath := filepath.Join(homeDir, ".config/forge")
2024-12-07 16:50:26 -06:00
os.Setenv("FORGE_GOSRC", fullpath)
}
var data []byte
var err error
2024-12-13 12:57:02 -06:00
cfgname := filepath.Join(os.Getenv("FORGE_GOSRC"), "repos.pb")
if data, err = loadFile(cfgname); err != nil {
// something went wrong loading the file
2024-12-17 06:37:14 -06:00
// all.sampleConfig() // causes nil panic
return err
}
2024-12-17 06:37:14 -06:00
// this means the forge.pb file exists and was read
if len(data) == 0 {
all.sampleConfig() // causes nil panic
return errors.New("gitpb.ConfigLoad() repos.pb is empty")
}
return all.Unmarshal(data)
}
func (all *Repos) sampleConfig() {
newr := new(Repo)
newr.FullPath = "/opt/forge/dummyentry"
if all.Append(newr) {
log.Info("added", newr.GetGoPath(), "ok")
} else {
log.Info("added", newr.GetGoPath(), "failed")
}
}
2024-12-13 12:57:02 -06:00
func loadFile(fullname string) ([]byte, error) {
data, err := os.ReadFile(fullname)
if errors.Is(err, os.ErrNotExist) {
// if file does not exist, just return nil. this
// will cause ConfigLoad() to try the next config file like "forge.text"
// because the user might want to edit the .config by hand
return nil, nil
}
if err != nil {
// log.Info("open config file :", err)
return nil, err
}
return data, nil
}
func configWrite(filename string, data []byte) error {
2024-12-07 16:50:26 -06:00
fullname := filepath.Join(os.Getenv("FORGE_GOSRC"), filename)
2024-12-11 13:55:36 -06:00
cfgfile, err := os.OpenFile(fullname, os.O_RDWR|os.O_CREATE|os.O_TRUNC, 0644)
defer cfgfile.Close()
if err != nil {
log.Warn("open config file :", err)
return err
}
if filename == "forge.text" {
// add header
cfgfile.Write([]byte("# this file is automatically re-generated from forge.pb, however,\n"))
cfgfile.Write([]byte("# if you want to edit it by hand, you can:\n"))
cfgfile.Write([]byte("# stop forge; remove forge.pb; edit forge.text; start forge\n"))
cfgfile.Write([]byte("# this will cause the default behavior to fallback to parsing this file for the config\n"))
cfgfile.Write([]byte("\n"))
cfgfile.Write([]byte("# this file is intended to be used to customize settings on what\n"))
cfgfile.Write([]byte("# git repos you have write access to. That is, where you can run 'git push'\n"))
}
cfgfile.Write(data)
return nil
}