2019-07-21 02:00:04 +00:00
|
|
|
package cmd
|
|
|
|
|
|
|
|
import (
|
2019-08-07 03:27:30 +00:00
|
|
|
"github.com/greenled/portainer-stack-utils/client"
|
2019-08-02 16:03:43 +00:00
|
|
|
"github.com/greenled/portainer-stack-utils/common"
|
2019-08-06 06:18:49 +00:00
|
|
|
"github.com/sirupsen/logrus"
|
2019-07-21 02:00:04 +00:00
|
|
|
"github.com/spf13/cobra"
|
2019-08-02 16:03:43 +00:00
|
|
|
"github.com/spf13/viper"
|
2019-07-21 02:00:04 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// stackRemoveCmd represents the remove command
|
|
|
|
var stackRemoveCmd = &cobra.Command{
|
|
|
|
Use: "remove STACK_NAME",
|
|
|
|
Short: "Remove a stack",
|
|
|
|
Aliases: []string{"rm", "down"},
|
|
|
|
Example: "psu stack rm mystack",
|
|
|
|
Args: cobra.ExactArgs(1),
|
|
|
|
Run: func(cmd *cobra.Command, args []string) {
|
2019-08-09 04:12:15 +00:00
|
|
|
portainerClient, clientRetrievalErr := common.GetClient()
|
|
|
|
common.CheckError(clientRetrievalErr)
|
|
|
|
|
2019-07-21 02:00:04 +00:00
|
|
|
stackName := args[0]
|
2019-08-08 23:00:01 +00:00
|
|
|
endpointId := viper.GetInt32("stack.remove.endpoint")
|
2019-08-07 03:27:30 +00:00
|
|
|
var endpointSwarmClusterId string
|
|
|
|
var stack client.Stack
|
2019-08-09 04:12:15 +00:00
|
|
|
|
|
|
|
// Guess EndpointID if not set
|
2019-08-07 03:27:30 +00:00
|
|
|
if endpointId == 0 {
|
2019-08-09 04:12:15 +00:00
|
|
|
logrus.Warning("Endpoint ID not set")
|
|
|
|
endpoint, err := common.GetDefaultEndpoint()
|
|
|
|
common.CheckError(err)
|
|
|
|
endpointId = int32(endpoint.Id)
|
2019-08-07 03:27:30 +00:00
|
|
|
logrus.WithFields(logrus.Fields{
|
2019-08-09 04:12:15 +00:00
|
|
|
"endpoint": endpointId,
|
|
|
|
}).Debug("Using the only available endpoint")
|
|
|
|
}
|
|
|
|
|
|
|
|
var selectionErr, stackRetrievalErr error
|
|
|
|
endpointSwarmClusterId, selectionErr = common.GetEndpointSwarmClusterId(uint32(endpointId))
|
|
|
|
switch selectionErr.(type) {
|
|
|
|
case nil:
|
|
|
|
// It's a swarm cluster
|
|
|
|
logrus.WithFields(logrus.Fields{
|
|
|
|
"stack": stackName,
|
|
|
|
"endpoint": endpointId,
|
|
|
|
"swarm": endpointSwarmClusterId,
|
|
|
|
}).Debug("Getting stack")
|
|
|
|
stack, stackRetrievalErr = common.GetStackByName(stackName, endpointSwarmClusterId, uint32(endpointId))
|
|
|
|
case *common.StackClusterNotFoundError:
|
|
|
|
// It's not a swarm cluster
|
|
|
|
logrus.WithFields(logrus.Fields{
|
|
|
|
"stack": stackName,
|
|
|
|
"endpoint": endpointId,
|
|
|
|
}).Debug("Getting stack")
|
|
|
|
stack, stackRetrievalErr = common.GetStackByName(stackName, "", uint32(endpointId))
|
|
|
|
default:
|
|
|
|
// Something else happened
|
|
|
|
common.CheckError(selectionErr)
|
2019-08-07 03:27:30 +00:00
|
|
|
}
|
2019-07-21 02:00:04 +00:00
|
|
|
|
2019-08-09 15:45:51 +00:00
|
|
|
switch stackRetrievalErr.(type) {
|
2019-07-21 02:00:04 +00:00
|
|
|
case nil:
|
|
|
|
// The stack exists
|
|
|
|
stackId := stack.Id
|
|
|
|
|
2019-08-06 06:18:49 +00:00
|
|
|
logrus.WithFields(logrus.Fields{
|
|
|
|
"stack": stackName,
|
|
|
|
}).Info("Removing stack")
|
2019-08-09 15:45:51 +00:00
|
|
|
err := portainerClient.DeleteStack(stackId)
|
2019-08-03 13:51:11 +00:00
|
|
|
common.CheckError(err)
|
2019-08-09 15:38:59 +00:00
|
|
|
logrus.WithFields(logrus.Fields{
|
|
|
|
"stack": stack.Name,
|
|
|
|
"endpoint": stack.EndpointID,
|
|
|
|
}).Info("Stack removed")
|
2019-07-21 02:00:04 +00:00
|
|
|
case *common.StackNotFoundError:
|
|
|
|
// The stack does not exist
|
2019-08-06 06:18:49 +00:00
|
|
|
logrus.WithFields(logrus.Fields{
|
|
|
|
"stack": stackName,
|
|
|
|
}).Debug("Stack not found")
|
2019-07-21 02:00:04 +00:00
|
|
|
if viper.GetBool("stack.remove.strict") {
|
2019-08-06 06:18:49 +00:00
|
|
|
logrus.WithFields(logrus.Fields{
|
|
|
|
"stack": stackName,
|
|
|
|
}).Fatal("Stack does not exist")
|
2019-07-21 02:00:04 +00:00
|
|
|
}
|
|
|
|
default:
|
|
|
|
// Something else happened
|
2019-08-09 15:45:51 +00:00
|
|
|
common.CheckError(stackRetrievalErr)
|
2019-07-21 02:00:04 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
stackCmd.AddCommand(stackRemoveCmd)
|
|
|
|
|
2019-08-06 22:51:56 +00:00
|
|
|
stackRemoveCmd.Flags().Bool("strict", false, "Fail if stack does not exist.")
|
2019-08-07 03:27:30 +00:00
|
|
|
stackRemoveCmd.Flags().Uint32("endpoint", 0, "Endpoint ID.")
|
2019-07-21 02:00:04 +00:00
|
|
|
viper.BindPFlag("stack.remove.strict", stackRemoveCmd.Flags().Lookup("strict"))
|
2019-08-07 03:27:30 +00:00
|
|
|
viper.BindPFlag("stack.remove.endpoint", stackRemoveCmd.Flags().Lookup("endpoint"))
|
2019-07-21 02:00:04 +00:00
|
|
|
}
|