Rework argument generation to adhere directly to what podman accepts.

This commit is contained in:
Martin Häcker 2021-04-26 14:07:14 +02:00 committed by Muayyad Alsadi
parent d3df688aee
commit 669953b3d3

View File

@ -1252,16 +1252,20 @@ def compose_exec(compose, args):
container_names=compose.container_names_by_service[args.service] container_names=compose.container_names_by_service[args.service]
container_name=container_names[args.index - 1] container_name=container_names[args.index - 1]
cnt = compose.container_by_name[container_name] cnt = compose.container_by_name[container_name]
if args.user: cnt["user"] = args.user podman_args = ['exec', '--interactive']
if args.workdir: cnt["working_dir"] = args.workdir if args.privileged: podman_args += ['--privileged']
cnt['tty']=False if args.T else True if args.user: podman_args += ['--user', args.user]
if args.cnt_command is not None and len(args.cnt_command) > 0: if args.workdir: podman_args += ['--workdir', args.workdir]
cnt['command']=args.cnt_command if not args.T: podman_args += ['--tty']
env = dict(cnt['environment'])
if args.env: if args.env:
additional_env_vars = dict(map(lambda each: each.split('='), args.env)) additional_env_vars = dict(map(lambda each: each.split('='), args.env))
cnt['environment'].update(additional_env_vars) env.update(additional_env_vars)
# run podman for name, value in env.items():
podman_args = container_to_args(compose, cnt, args.detach, podman_command="exec") podman_args += ['--env', "%s=%s" % (name, value)]
podman_args += [container_name]
if args.cnt_command is not None and len(args.cnt_command) > 0:
podman_args += args.cnt_command
compose.podman.run(podman_args, sleep=0) compose.podman.run(podman_args, sleep=0)
@ -1388,7 +1392,8 @@ def compose_run_parse(parser):
def compose_run_parse(parser): def compose_run_parse(parser):
parser.add_argument("-d", "--detach", action='store_true', parser.add_argument("-d", "--detach", action='store_true',
help="Detached mode: Run container in the background, print new container name.") help="Detached mode: Run container in the background, print new container name.")
# --privileged - not supported yet parser.add_argument("--privileged", action='store_true', default=False,
help="Give the process extended Linux capabilities inside the container")
parser.add_argument("-u", "--user", type=str, default=None, parser.add_argument("-u", "--user", type=str, default=None,
help="Run as specified username or uid") help="Run as specified username or uid")
parser.add_argument("-T", action='store_true', parser.add_argument("-T", action='store_true',