func runCmdUp(cmd *cobra.Command, args []string) error { conf, err := config.ClusterFromFile(configPath) if err != nil { return fmt.Errorf("Failed to read cluster config: %v", err) } if err := conf.ValidateUserData(stackTemplateOptions); err != nil { return err } data, err := conf.RenderStackTemplate(stackTemplateOptions) if err != nil { return fmt.Errorf("Failed to render stack template: %v", err) } if upOpts.export { templatePath := fmt.Sprintf("%s.stack-template.json", conf.ClusterName) fmt.Printf("Exporting %s\n", templatePath) if err := ioutil.WriteFile(templatePath, data, 0600); err != nil { return fmt.Errorf("Error writing %s : %v", templatePath, err) } if conf.KMSKeyARN == "" { fmt.Printf("BEWARE: %s contains your TLS secrets!\n", templatePath) } return nil } cluster := cluster.New(conf, upOpts.awsDebug) if upOpts.update { report, err := cluster.Update(string(data)) if err != nil { return fmt.Errorf("Error updating cluster: %v", err) } if report != "" { fmt.Printf("Update stack: %s\n", report) } } else { fmt.Printf("Creating AWS resources. This should take around 5 minutes.\n") if err := cluster.Create(string(data)); err != nil { return fmt.Errorf("Error creating cluster: %v", err) } } info, err := cluster.Info() if err != nil { return fmt.Errorf("Failed fetching cluster info: %v", err) } successMsg := `Success! Your AWS resources have been created: %s The containers that power your cluster are now being dowloaded. You should be able to access the Kubernetes API once the containers finish downloading. ` fmt.Printf(successMsg, info.String()) return nil }
func runCmdUp(cmd *cobra.Command, args []string) { cfg, err := config.NewConfigFromFile(ConfigPath) if err != nil { stderr("Unable to load cluster config: %v", err) os.Exit(1) } if err := cfg.ReadAssetsFromFiles(); err != nil { stderr("Error reading assets from files: %v", err) os.Exit(1) } if err := cfg.TemplateAndEncodeAssets(); err != nil { stderr("Error templating assets: %v", err) os.Exit(1) } if upOpts.export { templatePath := fmt.Sprintf("./%s.stack-template.json", cfg.ClusterName) fmt.Printf("Exporting %s\n", templatePath) if err := ioutil.WriteFile(templatePath, cfg.StackTemplate.Bytes(), 0600); err != nil { stderr("Error writing %s : %v", templatePath, err) os.Exit(1) } fmt.Printf("BEWARE: %s contains your TLS secrets!\n", templatePath) os.Exit(0) } cluster := cluster.New(cfg, upOpts.awsDebug) if upOpts.update { if err := cluster.Update(); err != nil { stderr("Error updating cluster: %v", err) os.Exit(1) } } else { if err := cluster.Create(); err != nil { stderr("Error creating cluster: %v", err) os.Exit(1) } } info, err := cluster.Info() if err != nil { stderr("Failed fetching cluster info: %v", err) os.Exit(1) } fmt.Print(info.String()) }
func runCmdStatus(cmd *cobra.Command, args []string) { cfg, err := config.NewConfigFromFile(ConfigPath) if err != nil { stderr("Error parsing config: %v", err) os.Exit(1) } cluster := cluster.New(cfg, false) info, err := cluster.Info() if err != nil { stderr("Failed fetching cluster info: %v", err) os.Exit(1) } fmt.Print(info.String()) }
func runCmdUp(cmd *cobra.Command, args []string) error { conf, err := config.ClusterFromFile(configPath) if err != nil { return fmt.Errorf("Failed to read cluster config: %v", err) } data, err := conf.RenderStackTemplate(stackTemplateOptions) if err != nil { return fmt.Errorf("Failed to render stack template: %v", err) } if upOpts.export { templatePath := fmt.Sprintf("%s.stack-template.json", conf.ClusterName) fmt.Printf("Exporting %s\n", templatePath) if err := ioutil.WriteFile(templatePath, data, 0600); err != nil { return fmt.Errorf("Error writing %s : %v", templatePath, err) } if conf.KMSKeyARN == "" { fmt.Printf("BEWARE: %s contains your TLS secrets!\n", templatePath) } return nil } cluster := cluster.New(conf, upOpts.awsDebug) if upOpts.update { report, err := cluster.Update(string(data)) if err != nil { return fmt.Errorf("Error updating cluster: %v", err) } if report != "" { fmt.Printf("Update stack: %s\n", report) } } else { if err := cluster.Create(string(data)); err != nil { return fmt.Errorf("Error creating cluster: %v", err) } } info, err := cluster.Info() if err != nil { return fmt.Errorf("Failed fetching cluster info: %v", err) } fmt.Print(info.String()) return nil }