// Copyright 2016-2017, Pulumi Corporation. All rights reserved. package cmd import ( "bufio" "flag" "fmt" "os" "strings" "github.com/golang/glog" "github.com/spf13/cobra" "github.com/pulumi/pulumi/pkg/diag/colors" "github.com/pulumi/pulumi/pkg/util/cmdutil" ) // pulumiBackend is the "backend" that we talk to. When the application launches, if the environment variable PULUMI_API is set, we // use a backend that targets the pulumi.com API, otherwise we use the local backend (i.e. "fire and forget" mode) var backend pulumiBackend func init() { if usePulumiCloudCommands() { backend = &pulumiCloudPulumiBackend{} } else { backend = &localPulumiBackend{} } } // NewPulumiCmd creates a new Pulumi Cmd instance. func NewPulumiCmd(version string) *cobra.Command { var logFlow bool var logToStderr bool var tracing string var verbose int var cwd string cmd := &cobra.Command{ Use: "pulumi", PersistentPreRun: func(cmd *cobra.Command, args []string) { if cwd != "" { err := os.Chdir(cwd) if err != nil { cmdutil.ExitError(err.Error()) } } cmdutil.InitLogging(logToStderr, verbose, logFlow) cmdutil.InitTracing("pulumi-cli", tracing) }, PersistentPostRun: func(cmd *cobra.Command, args []string) { glog.Flush() cmdutil.CloseTracing() }, } cmd.PersistentFlags().StringVarP(&cwd, "cwd", "C", "", "Run pulumi as if it had been started in another directory") cmd.PersistentFlags().BoolVar(&logFlow, "logflow", false, "Flow log settings to child processes (like plugins)") cmd.PersistentFlags().BoolVar(&logToStderr, "logtostderr", false, "Log to stderr instead of to files") cmd.PersistentFlags().StringVar(&tracing, "tracing", "", "Emit tracing to a Zipkin-compatible tracing endpoint") cmd.PersistentFlags().IntVarP( &verbose, "verbose", "v", 0, "Enable verbose logging (e.g., v=3); anything >3 is very verbose") cmd.AddCommand(newConfigCmd()) cmd.AddCommand(newDestroyCmd()) cmd.AddCommand(newStackCmd()) cmd.AddCommand(newPreviewCmd()) cmd.AddCommand(newUpdateCmd()) cmd.AddCommand(newVersionCmd(version)) cmd.AddCommand(newInitCmd()) cmd.AddCommand(newLogsCmd()) // Commands specific to the Pulumi Cloud Management Console. cmd.AddCommand(newLoginCmd()) cmd.AddCommand(newLogoutCmd()) // Tell flag about -C, so someone can do pulumi -C stack and the call to cmdutil.InitLogging // which calls flag.Parse under the hood doesn't yell at you. // // TODO[pulumi/pulumi#301]: when we move away from using glog, it should be safe to remove this. flag.StringVar(&cwd, "C", "", "Run pulumi as if it had been started in another directory") return cmd } func confirmPrompt(msg string, name string) bool { prompt := fmt.Sprintf(msg, name) fmt.Print( colors.ColorizeText(fmt.Sprintf("%v%v%v\n", colors.SpecAttention, prompt, colors.Reset))) fmt.Printf("Please confirm that this is what you'd like to do by typing (\"%v\"): ", name) reader := bufio.NewReader(os.Stdin) if line, _ := reader.ReadString('\n'); strings.TrimSpace(line) != name { fmt.Fprintf(os.Stderr, "Confirmation declined -- exiting without doing anything\n") return false } return true }