feat: add --preserve-config flag to restore command (#1939)

Add a new `--preserve-config` flag to the restore command that allows
users to restore database and files from a dump while keeping their
existing configuration file untouched.
This commit is contained in:
kolaente
2025-12-07 22:44:45 +01:00
committed by GitHub
parent f14f6ba38f
commit 0a78f7608a
2 changed files with 16 additions and 6 deletions

View File

@@ -23,8 +23,11 @@ import (
"github.com/spf13/cobra"
)
var preserveConfig bool
func init() {
rootCmd.AddCommand(restoreCmd)
restoreCmd.Flags().BoolVar(&preserveConfig, "preserve-config", false, "Preserve existing configuration instead of restoring from dump")
}
var restoreCmd = &cobra.Command{
@@ -35,7 +38,7 @@ var restoreCmd = &cobra.Command{
initialize.FullInitWithoutAsync()
},
Run: func(_ *cobra.Command, args []string) {
if err := dump.Restore(args[0]); err != nil {
if err := dump.Restore(args[0], !preserveConfig); err != nil {
log.Critical(err.Error())
}
},

View File

@@ -45,7 +45,7 @@ import (
const maxConfigSize = 5 * 1024 * 1024 // 5 MB, should be largely enough
// Restore takes a zip file name and restores it
func Restore(filename string) error {
func Restore(filename string, overrideConfig bool) error {
r, err := zip.OpenReader(filename)
if err != nil {
@@ -101,9 +101,14 @@ func Restore(filename string) error {
///////
// Restore the config file
err = restoreConfig(configFile, dotEnvFile)
if err != nil {
return err
if overrideConfig {
err = restoreConfig(configFile, dotEnvFile)
if err != nil {
return err
}
} else {
log.Warning("Preserving existing configuration (--preserve-config flag used)")
log.Warning("Configuration preserved - ensure your current config is compatible with the restored data")
}
log.Info("Restoring...")
@@ -188,7 +193,9 @@ func Restore(filename string) error {
///////
// Done
log.Infof("Done restoring dump.")
log.Infof("Restart Vikunja to make sure the new configuration file is applied.")
if overrideConfig {
log.Infof("Restart Vikunja to make sure the new configuration file is applied.")
}
return nil
}