diff options
author | Daniel J Walsh <dwalsh@redhat.com> | 2022-01-11 16:15:56 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-01-11 16:15:56 -0500 |
commit | 3404ad042def1c02872f66836feae19c814901a4 (patch) | |
tree | a454ef259ab28f85b17f53b3273725480aa78515 /libpod | |
parent | c4142ce0cfff792092bf420950b1985058cc241c (diff) | |
parent | 8f2358eeaa59fe369eebc6186403f95c2d66e49b (diff) | |
download | podman-3404ad042def1c02872f66836feae19c814901a4.tar.gz podman-3404ad042def1c02872f66836feae19c814901a4.tar.bz2 podman-3404ad042def1c02872f66836feae19c814901a4.zip |
Merge pull request #12694 from rhatdan/depend
Add podman rm --depend
Diffstat (limited to 'libpod')
-rw-r--r-- | libpod/runtime_ctr.go | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/libpod/runtime_ctr.go b/libpod/runtime_ctr.go index 59a1fd153..2891eb783 100644 --- a/libpod/runtime_ctr.go +++ b/libpod/runtime_ctr.go @@ -915,6 +915,37 @@ func (r *Runtime) evictContainer(ctx context.Context, idOrName string, removeVol return id, cleanupErr } +// RemoveDepend removes all dependencies for a container +func (r *Runtime) RemoveDepend(ctx context.Context, rmCtr *Container, force bool, removeVolume bool, timeout *uint) ([]*reports.RmReport, error) { + rmReports := make([]*reports.RmReport, 0) + deps, err := r.state.ContainerInUse(rmCtr) + if err != nil { + if err == define.ErrCtrRemoved { + return rmReports, nil + } + return rmReports, err + } + for _, cid := range deps { + ctr, err := r.state.Container(cid) + if err != nil { + if err == define.ErrNoSuchCtr { + continue + } + return rmReports, err + } + + reports, err := r.RemoveDepend(ctx, ctr, force, removeVolume, timeout) + if err != nil { + return rmReports, err + } + rmReports = append(rmReports, reports...) + } + report := reports.RmReport{Id: rmCtr.ID()} + report.Err = r.removeContainer(ctx, rmCtr, force, removeVolume, false, timeout) + + return append(rmReports, &report), nil +} + // GetContainer retrieves a container by its ID func (r *Runtime) GetContainer(id string) (*Container, error) { r.lock.RLock() |