revertprovider.go 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. package cmd
  2. import (
  3. "os"
  4. "github.com/rs/zerolog"
  5. "github.com/spf13/cobra"
  6. "github.com/spf13/viper"
  7. "github.com/drakkan/sftpgo/config"
  8. "github.com/drakkan/sftpgo/dataprovider"
  9. "github.com/drakkan/sftpgo/logger"
  10. "github.com/drakkan/sftpgo/utils"
  11. )
  12. var (
  13. revertProviderTargetVersion int
  14. revertProviderCmd = &cobra.Command{
  15. Use: "revertprovider",
  16. Short: "Revert the configured data provider to a previous version",
  17. Long: `This command reads the data provider connection details from the specified
  18. configuration file and restore the provider schema and/or data to a previous version.
  19. This command is not supported for the memory provider.
  20. Please take a look at the usage below to customize the options.`,
  21. Run: func(cmd *cobra.Command, args []string) {
  22. logger.DisableLogger()
  23. logger.EnableConsoleLogger(zerolog.DebugLevel)
  24. configDir = utils.CleanDirInput(configDir)
  25. err := config.LoadConfig(configDir, configFile)
  26. if err != nil {
  27. logger.WarnToConsole("Unable to initialize data provider, config load error: %v", err)
  28. return
  29. }
  30. kmsConfig := config.GetKMSConfig()
  31. err = kmsConfig.Initialize()
  32. if err != nil {
  33. logger.ErrorToConsole("unable to initialize KMS: %v", err)
  34. os.Exit(1)
  35. }
  36. providerConf := config.GetProviderConf()
  37. logger.InfoToConsole("Reverting provider: %#v config file: %#v target version %v", providerConf.Driver,
  38. viper.ConfigFileUsed(), revertProviderTargetVersion)
  39. err = dataprovider.RevertDatabase(providerConf, configDir, revertProviderTargetVersion)
  40. if err != nil {
  41. logger.WarnToConsole("Error reverting provider: %v", err)
  42. os.Exit(1)
  43. }
  44. logger.InfoToConsole("Data provider successfully reverted")
  45. },
  46. }
  47. )
  48. func init() {
  49. addConfigFlags(revertProviderCmd)
  50. revertProviderCmd.Flags().IntVar(&revertProviderTargetVersion, "to-version", 0, `4 means the version supported in v1.0.0-v1.2.x`)
  51. rootCmd.AddCommand(revertProviderCmd)
  52. }