corso/src/cli/restore/exchange.go
Keepers 243343c0e9
Replace fmt prints with the logger (#220)
Now that we have the logger in place, we should use it
in place of fmt.Print calls for development and debugging output.
2022-06-17 13:45:22 -06:00

105 lines
2.6 KiB
Go

package restore
import (
"fmt"
"github.com/pkg/errors"
"github.com/spf13/cobra"
"github.com/alcionai/corso/cli/config"
"github.com/alcionai/corso/cli/utils"
"github.com/alcionai/corso/pkg/credentials"
"github.com/alcionai/corso/pkg/logger"
"github.com/alcionai/corso/pkg/repository"
)
// exchange bucket info from flags
var (
folder string
mail string
user string
)
// called by restore.go to map parent subcommands to provider-specific handling.
func addExchangeApp(parent *cobra.Command) *cobra.Command {
parent.AddCommand(exchangeCmd)
fs := exchangeCmd.Flags()
fs.StringVar(&user, "user", "", "ID of the user whose echange data will get restored.")
fs.StringVar(&folder, "folder", "", "Name of the mail folder being restored.")
fs.StringVar(&mail, "mail", "", "ID of the mail message being restored.")
return exchangeCmd
}
// `corso restore create exchange [<flag>...]`
var exchangeCmd = &cobra.Command{
Use: "exchange",
Short: "Restore M365 Exchange service data",
RunE: createExchangeCmd,
Args: cobra.NoArgs,
}
// initializes a s3 repo.
func createExchangeCmd(cmd *cobra.Command, args []string) error {
ctx := cmd.Context()
if utils.HasNoFlagsAndShownHelp(cmd) {
return nil
}
if err := validateRestoreFlags(user, folder, mail); err != nil {
return errors.Wrap(err, "Missing required flags")
}
s, cfgTenantID, err := config.MakeS3Config(true, nil)
if err != nil {
return err
}
m365 := credentials.GetM365()
a := repository.Account{
TenantID: m365.TenantID,
ClientID: m365.ClientID,
ClientSecret: m365.ClientSecret,
}
if len(cfgTenantID) > 0 {
a.TenantID = cfgTenantID
}
logger.Ctx(ctx).Debugw(
"Called - "+cmd.CommandPath(),
"tenantID", m365.TenantID,
"clientID", m365.ClientID,
"hasClientSecret", len(m365.ClientSecret) > 0)
r, err := repository.Connect(ctx, a, s)
if err != nil {
return errors.Wrapf(err, "Failed to connect to the %s repository", s.Provider)
}
defer utils.CloseRepo(ctx, r)
ro, err := r.NewRestore(ctx, []string{user, folder, mail})
if err != nil {
return errors.Wrap(err, "Failed to initialize Exchange restore")
}
if _, err := ro.Run(ctx); err != nil {
return errors.Wrap(err, "Failed to run Exchange restore")
}
fmt.Printf("Restored Exchange in %s for user %s.\n", s.Provider, user)
return nil
}
func validateRestoreFlags(u, f, m string) error {
lu, lf, lm := len(u), len(f), len(m)
if (lu == 0 || u == "*") && (lf+lm > 0) {
return errors.New("a specific --user must be provided if --folder or --mail is specified")
}
if (lf == 0 || f == "*") && lm > 0 {
return errors.New("a specific --folder must be provided if a --mail is specified")
}
return nil
}