adding custom config library, can read/write TOML, started config validation

This commit is contained in:
2020-05-26 22:58:24 -04:00
commit 5d7cd68279
14 changed files with 352 additions and 0 deletions

95
client/client.go Normal file
View File

@@ -0,0 +1,95 @@
package main
import (
"fmt"
"os"
clir "github.com/deranjer/clir"
clientcmd "github.com/deranjer/gvc/client/clientcmd"
clientconfig "github.com/deranjer/gvc/client/clientconfig"
"github.com/deranjer/store"
)
var version = "0.1.5"
func main() {
var conf clientconfig.Gvcconfig
err := store.Load(".gvcconfig.toml", &conf)
if err != nil {
fmt.Println("Error loading config file into struct! ", err)
}
clientconfig.ValidateConfig(&conf, version)
// Initialize our new cli
cli := clir.NewCli("gvcc", "Version control client for GVC", version)
// Adding the init command
initCommand(cli, &conf)
// Adding all the "add" commands
addCommands(cli, &conf)
err = cli.Run()
if err != nil {
fmt.Printf("Error occurred: : %v\n", err)
}
// After the cli is finished running and writing new values, then validate the input and write it back to the TOML config file
clientconfig.ValidateConfig(&conf, version)
err = store.Save(".gvcconfigNew.toml", &conf)
if err != nil {
fmt.Println("Error saving config back to toml file: ", err)
}
}
// validateRepo just ensures that the command is being run against an actual repo (bool yes or no)
func validateRepo() bool {
if _, err := os.Stat(".gvcconfig.toml"); os.IsNotExist(err) {
return false
}
return true
}
func initCommand(cli *clir.Cli, conf *clientconfig.Gvcconfig) {
//The init subcommand
initCmd := cli.NewSubCommand("init", "initializes a new gvc repo")
initCmd.LongDescription("This will create the .gvcconfig.toml (with defaults) file in this directory. You can edit this file directly (unsafe) or with the client(safe)")
initCmd.Action(func() error {
isRepo := validateRepo()
if !isRepo {
err := clientcmd.InitializeRepo()
if err != nil {
err = fmt.Errorf("unable to initialize repo: %s", err)
fmt.Println(err)
return err
}
return nil
}
fmt.Println("appears that this directory is already a gvc repo")
return nil
})
}
func addCommands(cli *clir.Cli, conf *clientconfig.Gvcconfig) {
//All the add commands and subcommands
//The add subcommand
addCmd := cli.NewSubCommand("add", "adds file(s)/folder(s) (recursively for folder) to repo")
addCmd.LongDescription("You can add all: all, a -file: file.txt, or a -folder: folder, or a -wildcard: *.txt")
//File/Folder/Wildcard adding
addCmd.Action(clientcmd.AddFiles)
//Add all files recursively to repo
addall := addCmd.NewSubCommand("all", "add all of the file(s)/folders(s) recursively to repo")
addall.Action(clientcmd.AddAll)
//The remote command
remoteCmd := cli.NewSubCommand("remote", "add/delete/show remotes")
var name string
var host string
var port int
remoteAddCmd := remoteCmd.NewSubCommand("add", "add a remote, requires -name -host and -port")
remoteAddCmd.LongDescription("Adds a remote to the .gvcconfig.toml. Requires the -name, -host and -port flags. Example: gvc remote add -name exampleRemote -host examplehost.com -port 8080")
remoteAddCmd.StringFlag("name", "the name you want for your remote server", &name)
remoteAddCmd.StringFlag("host", "the hostname or IP Address of the remote", &host)
remoteAddCmd.IntFlag("port", "the port the remote server is listening on", &port)
}