This commit is contained in:
2022-02-16 21:42:54 +01:00
parent 75160d4d6a
commit db9f5dea66
9 changed files with 43 additions and 30 deletions

View File

@@ -9,6 +9,7 @@ import (
"strings"
"github.com/cupcakearmy/autorestic/internal/colors"
"github.com/cupcakearmy/autorestic/internal/flags"
)
type BackendRest struct {
@@ -128,7 +129,7 @@ func (b Backend) validate() error {
// If not initialize
colors.Body.Printf("Initializing backend \"%s\"...\n", b.name)
out, err := ExecuteResticCommand(options, "init")
if VERBOSE {
if flags.VERBOSE {
colors.Faint.Println(out)
}
return err
@@ -146,7 +147,7 @@ func (b Backend) Exec(args []string) error {
colors.Error.Println(out)
return err
}
if VERBOSE {
if flags.VERBOSE {
colors.Faint.Println(out)
}
return nil

View File

@@ -9,6 +9,7 @@ import (
"sync"
"github.com/cupcakearmy/autorestic/internal/colors"
"github.com/cupcakearmy/autorestic/internal/flags"
"github.com/cupcakearmy/autorestic/internal/lock"
"github.com/joho/godotenv"
"github.com/mitchellh/go-homedir"
@@ -16,11 +17,7 @@ import (
"github.com/spf13/viper"
)
const VERSION = "1.5.3"
var CI bool = false
var VERBOSE bool = false
var CRON_LEAN bool = false
const VERSION = "1.5.4"
type OptionMap map[string][]interface{}
type Options map[string]OptionMap
@@ -52,15 +49,15 @@ func GetConfig() *Config {
if config == nil {
once.Do(func() {
if err := viper.ReadInConfig(); err == nil {
if !CRON_LEAN {
absConfig, _ := filepath.Abs(viper.ConfigFileUsed())
absConfig, _ := filepath.Abs(viper.ConfigFileUsed())
if !flags.CRON_LEAN {
colors.Faint.Println("Using config: \t", absConfig)
// Load env file
envFile := filepath.Join(filepath.Dir(absConfig), ".autorestic.env")
err = godotenv.Load(envFile)
if err == nil {
colors.Faint.Println("Using env:\t", envFile)
}
}
// Load env file
envFile := filepath.Join(filepath.Dir(absConfig), ".autorestic.env")
err = godotenv.Load(envFile)
if err == nil {
colors.Faint.Println("Using env:\t", envFile)
}
} else {
cfgFileName := ".autorestic"

5
internal/flags/flags.go Normal file
View File

@@ -0,0 +1,5 @@
package flags
var CI bool = false
var VERBOSE bool = false
var CRON_LEAN bool = false

View File

@@ -9,6 +9,7 @@ import (
"time"
"github.com/cupcakearmy/autorestic/internal/colors"
"github.com/cupcakearmy/autorestic/internal/flags"
"github.com/cupcakearmy/autorestic/internal/lock"
"github.com/cupcakearmy/autorestic/internal/metadata"
"github.com/robfig/cron"
@@ -108,7 +109,7 @@ func (l Location) ExecuteHooks(commands []string, options ExecuteOptions) error
colors.Error.Println(out)
return err
}
if VERBOSE {
if flags.VERBOSE {
colors.Faint.Println(out)
}
}
@@ -227,7 +228,7 @@ func (l Location) Backup(cron bool, specificBackend string) []error {
options.Envs[k+"_"+fmt.Sprint(i)] = v
options.Envs[k+"_"+strings.ToUpper(backend.name)] = v
}
if VERBOSE {
if flags.VERBOSE {
colors.Faint.Println(out)
}
}
@@ -276,7 +277,7 @@ func (l Location) Forget(prune bool, dry bool) error {
}
cmd = append(cmd, combineOptions("forget", l, backend)...)
out, err := ExecuteResticCommand(options, cmd...)
if VERBOSE {
if flags.VERBOSE {
colors.Faint.Println(out)
}
if err != nil {
@@ -367,7 +368,7 @@ func (l Location) RunCron() error {
lock.SetCron(l.name, now.Unix())
l.Backup(true, "")
} else {
if !CRON_LEAN {
if !flags.CRON_LEAN {
colors.Body.Printf("Skipping \"%s\", not due yet.\n", l.name)
}
}

View File

@@ -6,6 +6,7 @@ import (
"sync"
"github.com/cupcakearmy/autorestic/internal/colors"
"github.com/cupcakearmy/autorestic/internal/flags"
"github.com/spf13/viper"
)
@@ -25,7 +26,9 @@ func getLock() *viper.Viper {
os.Exit(1)
}
file = path.Join(path.Dir(p), ".autorestic.lock.yml")
colors.Faint.Println("Using lock:\t", file)
if !flags.CRON_LEAN {
colors.Faint.Println("Using lock:\t", file)
}
lock.SetConfigFile(file)
lock.SetConfigType("yml")
lock.ReadInConfig()

View File

@@ -8,6 +8,7 @@ import (
"os/exec"
"github.com/cupcakearmy/autorestic/internal/colors"
"github.com/cupcakearmy/autorestic/internal/flags"
)
var RESTIC_BIN string
@@ -36,7 +37,7 @@ func ExecuteCommand(options ExecuteOptions, args ...string) (string, error) {
cmd.Env = env
cmd.Dir = options.Dir
if VERBOSE {
if flags.VERBOSE {
colors.Faint.Printf("> Executing: %s\n", cmd)
}