accept backupID flag, not backupDetailsID (#370)

This commit is contained in:
Keepers 2022-07-19 18:22:25 -06:00 committed by GitHub
parent 9f8287dc48
commit 37f2c44dc7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -14,17 +14,21 @@ import (
"github.com/alcionai/corso/pkg/selectors" "github.com/alcionai/corso/pkg/selectors"
) )
// ------------------------------------------------------------------------------------------------
// setup and globals
// ------------------------------------------------------------------------------------------------
// exchange bucket info from flags // exchange bucket info from flags
var ( var (
backupDetailsID string backupID string
exchangeAll bool exchangeAll bool
exchangeData []string exchangeData []string
contact []string contact []string
contactFolder []string contactFolder []string
email []string email []string
emailFolder []string emailFolder []string
event []string event []string
user []string user []string
) )
const ( const (
@ -33,13 +37,17 @@ const (
dataEvents = "events" dataEvents = "events"
) )
const exchangeServiceCommand = "exchange"
// called by backup.go to map parent subcommands to provider-specific handling. // called by backup.go to map parent subcommands to provider-specific handling.
func addExchangeCommands(parent *cobra.Command) *cobra.Command { func addExchangeCommands(parent *cobra.Command) *cobra.Command {
var ( var (
c *cobra.Command c *cobra.Command
fs *pflag.FlagSet fs *pflag.FlagSet
) )
switch parent.Use { switch parent.Use {
case createCommand: case createCommand:
c, fs = utils.AddCommand(parent, exchangeCreateCmd) c, fs = utils.AddCommand(parent, exchangeCreateCmd)
fs.StringArrayVar(&user, "user", nil, "Backup Exchange data by user ID; accepts "+utils.Wildcard+" to select all users") fs.StringArrayVar(&user, "user", nil, "Backup Exchange data by user ID; accepts "+utils.Wildcard+" to select all users")
@ -50,12 +58,14 @@ func addExchangeCommands(parent *cobra.Command) *cobra.Command {
nil, nil,
"Select one or more types of data to backup: "+dataEmail+", "+dataContacts+", or "+dataEvents) "Select one or more types of data to backup: "+dataEmail+", "+dataContacts+", or "+dataEvents)
options.AddOperationFlags(c) options.AddOperationFlags(c)
case listCommand: case listCommand:
c, _ = utils.AddCommand(parent, exchangeListCmd) c, _ = utils.AddCommand(parent, exchangeListCmd)
case detailsCommand: case detailsCommand:
c, fs = utils.AddCommand(parent, exchangeDetailsCmd) c, fs = utils.AddCommand(parent, exchangeDetailsCmd)
fs.StringVar(&backupDetailsID, "backup-details", "", "ID of the backup details to be shown") fs.StringVar(&backupID, "backup", "", "ID of the backup containing the details to be shown")
cobra.CheckErr(c.MarkFlagRequired("backup-details")) cobra.CheckErr(c.MarkFlagRequired("backup"))
fs.StringArrayVar(&contact, "contact", nil, "Select backup details by contact ID; accepts "+utils.Wildcard+" to select all contacts") fs.StringArrayVar(&contact, "contact", nil, "Select backup details by contact ID; accepts "+utils.Wildcard+" to select all contacts")
fs.StringArrayVar( fs.StringArrayVar(
&contactFolder, &contactFolder,
@ -76,10 +86,13 @@ func addExchangeCommands(parent *cobra.Command) *cobra.Command {
cobra.CheckErr(fs.MarkHidden("contact-folder")) cobra.CheckErr(fs.MarkHidden("contact-folder"))
cobra.CheckErr(fs.MarkHidden("event")) cobra.CheckErr(fs.MarkHidden("event"))
} }
return c return c
} }
const exchangeServiceCommand = "exchange" // ------------------------------------------------------------------------------------------------
// backup create
// ------------------------------------------------------------------------------------------------
// `corso backup create exchange [<flag>...]` // `corso backup create exchange [<flag>...]`
var exchangeCreateCmd = &cobra.Command{ var exchangeCreateCmd = &cobra.Command{
@ -168,7 +181,7 @@ func validateBackupCreateFlags(all bool, users, data []string) error {
return errors.New("requries one or more --user ids, the wildcard --user *, or the --all flag.") return errors.New("requries one or more --user ids, the wildcard --user *, or the --all flag.")
} }
if len(data) > 0 && all { if len(data) > 0 && all {
return errors.New("--all backs up all data, and cannot be reduced with --data") return errors.New("--all does a backup on all data, and cannot be reduced with --data")
} }
for _, d := range data { for _, d := range data {
if d != dataContacts && d != dataEmail && d != dataEvents { if d != dataContacts && d != dataEmail && d != dataEvents {
@ -178,6 +191,10 @@ func validateBackupCreateFlags(all bool, users, data []string) error {
return nil return nil
} }
// ------------------------------------------------------------------------------------------------
// backup list
// ------------------------------------------------------------------------------------------------
// `corso backup list exchange [<flag>...]` // `corso backup list exchange [<flag>...]`
var exchangeListCmd = &cobra.Command{ var exchangeListCmd = &cobra.Command{
Use: exchangeServiceCommand, Use: exchangeServiceCommand,
@ -220,6 +237,10 @@ func listExchangeCmd(cmd *cobra.Command, args []string) error {
return nil return nil
} }
// ------------------------------------------------------------------------------------------------
// backup details
// ------------------------------------------------------------------------------------------------
// `corso backup details exchange [<flag>...]` // `corso backup details exchange [<flag>...]`
var exchangeDetailsCmd = &cobra.Command{ var exchangeDetailsCmd = &cobra.Command{
Use: exchangeServiceCommand, Use: exchangeServiceCommand,
@ -252,7 +273,7 @@ func detailsExchangeCmd(cmd *cobra.Command, args []string) error {
} }
defer utils.CloseRepo(ctx, r) defer utils.CloseRepo(ctx, r)
d, _, err := r.BackupDetails(ctx, backupDetailsID) d, _, err := r.BackupDetails(ctx, backupID)
if err != nil { if err != nil {
return errors.Wrap(err, "Failed to get backup details in the repository") return errors.Wrap(err, "Failed to get backup details in the repository")
} }
@ -266,7 +287,6 @@ func exchangeBackupDetailSelectors(
contacts, contactFolders, emails, emailFolders, events, users []string, contacts, contactFolders, emails, emailFolders, events, users []string,
) selectors.Selector { ) selectors.Selector {
sel := selectors.NewExchangeBackup() sel := selectors.NewExchangeBackup()
// normalize the inputs
lc, lcf := len(contacts), len(contactFolders) lc, lcf := len(contacts), len(contactFolders)
le, lef := len(emails), len(emailFolders) le, lef := len(emails), len(emailFolders)
lev := len(events) lev := len(events)