revertprovider.go 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  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/v2/config"
  8. "github.com/drakkan/sftpgo/v2/dataprovider"
  9. "github.com/drakkan/sftpgo/v2/logger"
  10. "github.com/drakkan/sftpgo/v2/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. if revertProviderTargetVersion != 10 {
  25. logger.WarnToConsole("Unsupported target version, 10 is the only supported one")
  26. os.Exit(1)
  27. }
  28. configDir = utils.CleanDirInput(configDir)
  29. err := config.LoadConfig(configDir, configFile)
  30. if err != nil {
  31. logger.WarnToConsole("Unable to initialize data provider, config load error: %v", err)
  32. os.Exit(1)
  33. }
  34. kmsConfig := config.GetKMSConfig()
  35. err = kmsConfig.Initialize()
  36. if err != nil {
  37. logger.ErrorToConsole("unable to initialize KMS: %v", err)
  38. os.Exit(1)
  39. }
  40. providerConf := config.GetProviderConf()
  41. logger.InfoToConsole("Reverting provider: %#v config file: %#v target version %v", providerConf.Driver,
  42. viper.ConfigFileUsed(), revertProviderTargetVersion)
  43. err = dataprovider.RevertDatabase(providerConf, configDir, revertProviderTargetVersion)
  44. if err != nil {
  45. logger.WarnToConsole("Error reverting provider: %v", err)
  46. os.Exit(1)
  47. }
  48. logger.InfoToConsole("Data provider successfully reverted")
  49. },
  50. }
  51. )
  52. func init() {
  53. addConfigFlags(revertProviderCmd)
  54. revertProviderCmd.Flags().IntVar(&revertProviderTargetVersion, "to-version", 10, `10 means the version supported in v2.1.x`)
  55. revertProviderCmd.MarkFlagRequired("to-version") //nolint:errcheck
  56. rootCmd.AddCommand(revertProviderCmd)
  57. }