
Also fix help/usage to reveal delete accepts multiple container IDs. Signed-off-by: Phil Estes <estesp@linux.vnet.ibm.com>
75 lines
1.8 KiB
Go
75 lines
1.8 KiB
Go
package main
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
"fmt"
|
|
|
|
"github.com/containerd/containerd"
|
|
"github.com/containerd/containerd/log"
|
|
"github.com/urfave/cli"
|
|
)
|
|
|
|
var containersDeleteCommand = cli.Command{
|
|
Name: "delete",
|
|
Usage: "deletes one or more existing containers",
|
|
ArgsUsage: "CONTAINER [CONTAINER, ...]",
|
|
Aliases: []string{"del", "rm"},
|
|
Flags: []cli.Flag{
|
|
cli.BoolFlag{
|
|
Name: "keep-snapshot",
|
|
Usage: "do not clean up snapshot with container",
|
|
},
|
|
},
|
|
Action: func(context *cli.Context) error {
|
|
var exitErr error
|
|
ctx, cancel := appContext(context)
|
|
defer cancel()
|
|
client, err := newClient(context)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
deleteOpts := []containerd.DeleteOpts{}
|
|
if !context.Bool("keep-snapshot") {
|
|
deleteOpts = append(deleteOpts, containerd.WithSnapshotCleanup)
|
|
}
|
|
|
|
if context.NArg() == 0 {
|
|
return errors.New("must specify at least one container to delete")
|
|
}
|
|
for _, arg := range context.Args() {
|
|
if err := deleteContainer(ctx, client, arg, deleteOpts...); err != nil {
|
|
if exitErr == nil {
|
|
exitErr = err
|
|
}
|
|
log.G(ctx).WithError(err).Errorf("failed to delete container %q", arg)
|
|
}
|
|
}
|
|
|
|
return exitErr
|
|
},
|
|
}
|
|
|
|
func deleteContainer(ctx context.Context, client *containerd.Client, id string, opts ...containerd.DeleteOpts) error {
|
|
container, err := client.LoadContainer(ctx, id)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
task, err := container.Task(ctx, nil)
|
|
if err != nil {
|
|
return container.Delete(ctx, opts...)
|
|
}
|
|
status, err := task.Status(ctx)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if status.Status == containerd.Stopped || status.Status == containerd.Created {
|
|
if _, err := task.Delete(ctx); err != nil {
|
|
return err
|
|
}
|
|
return container.Delete(ctx, opts...)
|
|
}
|
|
return fmt.Errorf("cannot delete a non stopped container: %v", status)
|
|
|
|
}
|