From 5e0726f9f15e4aee89160d92816d63a4ee3c3e9a Mon Sep 17 00:00:00 2001 From: Eike Date: Tue, 28 Feb 2023 12:17:35 +0100 Subject: [PATCH] listing available and running containers --- jlmkr.py | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/jlmkr.py b/jlmkr.py index 0240e12..98c137b 100755 --- a/jlmkr.py +++ b/jlmkr.py @@ -630,6 +630,16 @@ def delete_jail(jail_name): else: eprint("Wrong name, nothing happens.") +def list_jails(): + """ + List all running jails. + """ + jail_path = os.path.join(JAILS_DIR_PATH) + + eprint("\nAvailable containers:\n") + os.system(f"ls -l {jail_path} | grep '^d' | awk '{{print $NF}}'") + eprint("\nCurrently running containers:\n") + os.system(f"machinectl list") def main(): if os.stat(__file__).st_uid != 0: @@ -650,6 +660,8 @@ def main(): start_parser = subparsers.add_parser(name='delete', epilog=DISCLAIMER) start_parser.add_argument('name', help='name of the jail') + start_parser = subparsers.add_parser(name='list', epilog=DISCLAIMER) + parser.usage = f"{parser.format_usage()[7:]}{create_parser.format_usage()}{start_parser.format_usage()}" if os.getuid() != 0: @@ -674,6 +686,9 @@ def main(): elif args.subcommand == 'delete': delete_jail(args.name) + elif args.subcommand == 'list': + list_jails() + elif args.subcommand: parser.print_usage()