diff options
author | Brent Baude <bbaude@redhat.com> | 2020-03-27 11:06:16 -0500 |
---|---|---|
committer | Brent Baude <bbaude@redhat.com> | 2020-03-28 10:11:50 -0500 |
commit | 3ff1583814b4e69d2d85ee2b1d342d0d5974b9de (patch) | |
tree | 3d52acd1653ff0682b3430d13b174a1dddd8dd18 /pkg/domain/infra/tunnel | |
parent | 21b67e64694fb58535a6b61fb7f3bc43ccda1d11 (diff) | |
download | podman-3ff1583814b4e69d2d85ee2b1d342d0d5974b9de.tar.gz podman-3ff1583814b4e69d2d85ee2b1d342d0d5974b9de.tar.bz2 podman-3ff1583814b4e69d2d85ee2b1d342d0d5974b9de.zip |
podmanv2 commit
add commit of a container to a container-image
Signed-off-by: Brent Baude <bbaude@redhat.com>
Diffstat (limited to 'pkg/domain/infra/tunnel')
-rw-r--r-- | pkg/domain/infra/tunnel/containers.go | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/pkg/domain/infra/tunnel/containers.go b/pkg/domain/infra/tunnel/containers.go index 3db38ea5c..3c8be90dc 100644 --- a/pkg/domain/infra/tunnel/containers.go +++ b/pkg/domain/infra/tunnel/containers.go @@ -3,6 +3,8 @@ package tunnel import ( "context" + "github.com/containers/image/v5/docker/reference" + "github.com/containers/libpod/pkg/bindings/containers" "github.com/containers/libpod/pkg/domain/entities" "github.com/pkg/errors" @@ -172,3 +174,39 @@ func (ic *ContainerEngine) ContainerTop(ctx context.Context, options entities.To } return &entities.StringSliceReport{Value: topOutput}, nil } + +func (ic *ContainerEngine) ContainerCommit(ctx context.Context, nameOrId string, options entities.CommitOptions) (*entities.CommitReport, error) { + var ( + repo string + tag string = "latest" + ) + if len(options.ImageName) > 0 { + ref, err := reference.Parse(options.ImageName) + if err != nil { + return nil, err + } + if t, ok := ref.(reference.Tagged); ok { + tag = t.Tag() + } + if r, ok := ref.(reference.Named); ok { + repo = r.Name() + } + if len(repo) < 1 { + return nil, errors.Errorf("invalid image name %q", options.ImageName) + } + } + commitOpts := containers.CommitOptions{ + Author: &options.Author, + Changes: options.Changes, + Comment: &options.Message, + Format: &options.Format, + Pause: &options.Pause, + Repo: &repo, + Tag: &tag, + } + response, err := containers.Commit(ic.ClientCxt, nameOrId, commitOpts) + if err != nil { + return nil, err + } + return &entities.CommitReport{Id: response.ID}, nil +} |