summaryrefslogtreecommitdiff
path: root/contrib/python/podman/examples/eg_new_image.py
diff options
context:
space:
mode:
authorMatthew Heon <matthew.heon@gmail.com>2018-07-13 16:34:51 -0400
committerGitHub <noreply@github.com>2018-07-13 16:34:51 -0400
commita689639a6502bab3f49b853bc2983c1b44363b2f (patch)
tree75ba256d70545d79aa61d7c57c20df886be1555f /contrib/python/podman/examples/eg_new_image.py
parent14a6d51a8432fc0c3324fec02e8729d3032f2af2 (diff)
parent74ccd9ce5f29a1df4ffe70b4d8bd00c29d5d9d15 (diff)
downloadpodman-a689639a6502bab3f49b853bc2983c1b44363b2f.tar.gz
podman-a689639a6502bab3f49b853bc2983c1b44363b2f.tar.bz2
podman-a689639a6502bab3f49b853bc2983c1b44363b2f.zip
Merge pull request #1081 from jwhonce/wip/client
remote python client for podman
Diffstat (limited to 'contrib/python/podman/examples/eg_new_image.py')
-rw-r--r--contrib/python/podman/examples/eg_new_image.py32
1 files changed, 32 insertions, 0 deletions
diff --git a/contrib/python/podman/examples/eg_new_image.py b/contrib/python/podman/examples/eg_new_image.py
new file mode 100644
index 000000000..21e076dcb
--- /dev/null
+++ b/contrib/python/podman/examples/eg_new_image.py
@@ -0,0 +1,32 @@
+#!/usr/bin/env python3
+"""Example: Create new image from container."""
+
+import sys
+
+import podman
+
+
+def print_history(details):
+ """Format history data from an image, in a table."""
+ for i, r in enumerate(details):
+ print(
+ '{}: {} {} {}'.format(i, r.id[:12],
+ podman.datetime_format(r.created), r.tags),
+ sep='\n')
+ print("-" * 25)
+
+
+print('{}\n'.format(__doc__))
+
+with podman.Client() as client:
+ ctnr = next(
+ (c for c in client.containers.list() if 'alpine' in c['image']), None)
+
+ if ctnr:
+ print_history(client.images.get(ctnr.imageid).history())
+
+ # Make changes as we save the container to a new image
+ id = ctnr.commit('alpine-ash', changes=['CMD=/bin/ash'])
+ print_history(client.images.get(id).history())
+ else:
+ print('Unable to find "alpine" container.', file=sys.stderr)