diff options
author | Christian Poessinger <christian@poessinger.com> | 2021-04-21 20:48:55 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-04-21 20:48:55 +0200 |
commit | 821d9e4d36d7520973d6f2cd146feebb9918227a (patch) | |
tree | 2aa19621ea0f2d812151c23acc5bf924c0a25464 /src | |
parent | ee6bf7e9af5c6a25177a652f6a455ebb7438186d (diff) | |
parent | d657e65d66c14c007c235779ecb73ef5b8cfa327 (diff) | |
download | vyos-1x-821d9e4d36d7520973d6f2cd146feebb9918227a.tar.gz vyos-1x-821d9e4d36d7520973d6f2cd146feebb9918227a.zip |
Merge pull request #816 from sever-sever/T2216-op-mode
container: T2216: Rewrite op-mode to python
Diffstat (limited to 'src')
-rwxr-xr-x | src/op_mode/containers_op.py | 59 | ||||
-rwxr-xr-x | src/op_mode/containers_op.sh | 60 |
2 files changed, 59 insertions, 60 deletions
diff --git a/src/op_mode/containers_op.py b/src/op_mode/containers_op.py new file mode 100755 index 000000000..1e3fc3a8f --- /dev/null +++ b/src/op_mode/containers_op.py @@ -0,0 +1,59 @@ +#!/usr/bin/env python3 +# +# Copyright (C) 2021 VyOS maintainers and contributors +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License version 2 or later as +# published by the Free Software Foundation. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see <http://www.gnu.org/licenses/>. + +import argparse +from vyos.configquery import query_context, ConfigQueryError +from vyos.util import cmd + +config, op = query_context() + +parser = argparse.ArgumentParser() +parser.add_argument("-a", "--all", action="store_true", help="Show all containers") +parser.add_argument("-i", "--image", action="store_true", help="Show container images") +parser.add_argument("-n", "--networks", action="store_true", help="Show container images") +parser.add_argument("-p", "--pull", action="store", help="Pull image for container") +parser.add_argument("-d", "--remove", action="store", help="Delete container image") + +if not config.exists(['container']): + print('Containers not configured') + exit(0) + +if __name__ == '__main__': + args = parser.parse_args() + + if args.all: + print(cmd('podman ps --all')) + exit(0) + if args.image: + print(cmd('podman image ls')) + exit(0) + if args.networks: + print(cmd('podman network ls')) + exit(0) + if args.pull: + image = args.pull + try: + print(cmd(f'sudo podman image pull {image}')) + except: + print(f'Can\'t find or download image "{image}"') + exit(0) + if args.remove: + image = args.remove + try: + print(cmd(f'sudo podman image rm {image}')) + except: + print(f'Can\'t delete image "{image}"') + exit(0) diff --git a/src/op_mode/containers_op.sh b/src/op_mode/containers_op.sh deleted file mode 100755 index 9c410bd7f..000000000 --- a/src/op_mode/containers_op.sh +++ /dev/null @@ -1,60 +0,0 @@ -#!/usr/bin/env bash - -# Expect 2 args or "show-containers" or "show-images" -if [[ $# -ne 2 ]] && [[ $1 != "--show-containers" ]] && [[ $1 != "--show-images" ]] && [[ $1 != "--show-networks" ]] ; then - echo "Image not set or not found" - exit 1 -fi - -OPTION=$1 -IMAGE=$2 - -# Download image -pull_image() { - sudo podman pull ${IMAGE} -} - -# Remove image -remove_image() { - sudo podman image rm ${IMAGE} -} - -# Show containers -show_containers() { - sudo podman ps -a -} - -# Show image -show_images() { - sudo podman image ls -} - -# Show networks -show_networks() { - sudo podman network ls -} - -if [ "$OPTION" = "--pull" ]; then - pull_image - exit 0 -fi - -if [ "$OPTION" = "--remove" ]; then - remove_image - exit 0 -fi - -if [ "$OPTION" = "--show-containers" ]; then - show_containers - exit 0 -fi - -if [ "$OPTION" = "--show-networks" ]; then - show_networks - exit 0 -fi - -if [ "$OPTION" = "--show-images" ]; then - show_images - exit 0 -fi |