2017-12-03 12:41:23 -08:00
|
|
|
package cmd
|
|
|
|
|
|
|
|
import (
|
2019-01-31 18:15:11 -08:00
|
|
|
"github.com/paypal/gorealis/v2/gen-go/apache/aurora"
|
2017-12-03 12:41:23 -08:00
|
|
|
"github.com/spf13/cobra"
|
2018-11-20 20:11:21 -08:00
|
|
|
"time"
|
2018-11-09 15:58:26 -08:00
|
|
|
|
|
|
|
log "github.com/sirupsen/logrus"
|
2017-12-03 12:41:23 -08:00
|
|
|
)
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
rootCmd.AddCommand(stopCmd)
|
|
|
|
|
|
|
|
// Stop subcommands
|
|
|
|
stopCmd.AddCommand(stopMaintCmd)
|
2018-11-20 20:11:21 -08:00
|
|
|
stopMaintCmd.Flags().DurationVar(&monitorInterval,"interval", time.Second * 5, "Interval at which to poll scheduler.")
|
|
|
|
stopMaintCmd.Flags().DurationVar(&monitorTimeout,"timeout", time.Minute * 1, "Time after which the monitor will stop polling and throw an error.")
|
2018-09-16 21:23:36 -07:00
|
|
|
|
|
|
|
// Stop update
|
|
|
|
|
|
|
|
stopCmd.AddCommand(stopUpdateCmd)
|
|
|
|
stopUpdateCmd.Flags().StringVarP(env, "environment", "e", "", "Aurora Environment")
|
|
|
|
stopUpdateCmd.Flags().StringVarP(role, "role", "r", "", "Aurora Role")
|
|
|
|
stopUpdateCmd.Flags().StringVarP(name, "name", "n", "", "Aurora Name")
|
|
|
|
|
2017-12-03 12:41:23 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
var stopCmd = &cobra.Command{
|
|
|
|
Use: "stop",
|
|
|
|
Short: "Stop a service or maintenance on a host (DRAIN).",
|
|
|
|
}
|
|
|
|
|
|
|
|
var stopMaintCmd = &cobra.Command{
|
|
|
|
Use: "drain [space separated host list]",
|
|
|
|
Short: "Stop maintenance on a host (move to NONE).",
|
|
|
|
Long: `Transition a list of hosts currently in a maintenance status out of it.`,
|
|
|
|
Run: endMaintenance,
|
|
|
|
}
|
|
|
|
|
2018-09-16 21:23:36 -07:00
|
|
|
var stopUpdateCmd = &cobra.Command{
|
|
|
|
Use: "update [update ID]",
|
|
|
|
Short: "Stop update",
|
|
|
|
Long: `To be written.`,
|
|
|
|
Run: stopUpdate,
|
|
|
|
}
|
|
|
|
|
2017-12-03 12:41:23 -08:00
|
|
|
func endMaintenance(cmd *cobra.Command, args []string) {
|
2018-11-09 15:58:26 -08:00
|
|
|
log.Println("Setting hosts to NONE maintenance status.")
|
|
|
|
log.Println(args)
|
2018-12-27 11:31:51 -08:00
|
|
|
result, err := client.EndMaintenance(args...)
|
2017-12-03 12:41:23 -08:00
|
|
|
if err != nil {
|
2018-11-09 15:58:26 -08:00
|
|
|
log.Fatalf("error: %+v\n", err)
|
2017-12-03 12:41:23 -08:00
|
|
|
}
|
|
|
|
|
2018-11-09 15:58:26 -08:00
|
|
|
log.Debugln(result)
|
|
|
|
|
2017-12-03 12:41:23 -08:00
|
|
|
// Monitor change to NONE mode
|
2018-12-27 11:31:51 -08:00
|
|
|
hostResult, err := client.HostMaintenanceMonitor(
|
2017-12-03 12:41:23 -08:00
|
|
|
args,
|
|
|
|
[]aurora.MaintenanceMode{aurora.MaintenanceMode_NONE},
|
2018-12-27 11:31:51 -08:00
|
|
|
monitorInterval,
|
|
|
|
monitorTimeout)
|
2017-12-03 12:41:23 -08:00
|
|
|
|
2018-11-16 21:54:18 -08:00
|
|
|
maintenanceMonitorPrint(hostResult,[]aurora.MaintenanceMode{aurora.MaintenanceMode_NONE})
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalln("error: %+v", err)
|
2018-11-09 15:58:26 -08:00
|
|
|
}
|
2017-12-03 12:41:23 -08:00
|
|
|
}
|
2018-09-16 21:23:36 -07:00
|
|
|
|
|
|
|
func stopUpdate(cmd *cobra.Command, args []string) {
|
|
|
|
|
|
|
|
if len(args) != 1 {
|
2018-11-09 15:58:26 -08:00
|
|
|
log.Fatalln("Only a single update ID must be provided.")
|
2018-09-16 21:23:36 -07:00
|
|
|
}
|
|
|
|
|
2018-11-09 15:58:26 -08:00
|
|
|
log.Infof("Stopping (aborting) update [%s/%s/%s] %s\n", *env, *role, *name, args[0])
|
2018-09-16 21:23:36 -07:00
|
|
|
|
2018-12-27 11:31:51 -08:00
|
|
|
err := client.AbortJobUpdate(aurora.JobUpdateKey{
|
2018-09-16 21:23:36 -07:00
|
|
|
Job: &aurora.JobKey{Environment: *env, Role: *role, Name: *name},
|
|
|
|
ID: args[0],
|
|
|
|
},
|
|
|
|
"")
|
|
|
|
|
|
|
|
if err != nil {
|
2018-11-09 15:58:26 -08:00
|
|
|
log.Fatalln(err)
|
2018-09-16 21:23:36 -07:00
|
|
|
}
|
|
|
|
}
|