From 82a69f0a234e73e447d0ea8c8b3443b84fd31944 Mon Sep 17 00:00:00 2001 From: Luca Di Maio Date: Mon, 11 Mar 2024 14:03:30 +0100 Subject: [PATCH] enter: do not use a shell when executing a custom command, Fix #1275 Signed-off-by: Luca Di Maio --- distrobox-enter | 8 ++------ 1 file changed, 2 insertions(+), 6 deletions(-) diff --git a/distrobox-enter b/distrobox-enter index dda867e3f4..84dbb7741c 100755 --- a/distrobox-enter +++ b/distrobox-enter @@ -58,8 +58,6 @@ fi container_command="" # by default we use getent to get the login shell of the user and use that container_command_login="/bin/sh -c \"\\\$(getent passwd ${USER} | cut -f 7 -d :) -l\"" -# and we execute container_command using sh -c -container_command_prefix="/bin/sh -c" container_image_default="registry.fedoraproject.org/fedora-toolbox:39" container_manager="autodetect" container_manager_additional_flags="" @@ -214,7 +212,7 @@ while :; do ;; -e | --exec | --) shift - container_command="$1" + container_command="\"$1\"" shift for arg in "$@"; do arg="$(echo "${arg}x" | sed 's|'\''|'\'\\\\\'\''|g')" @@ -335,7 +333,6 @@ generate_command() { container_command_login="${container_command_login} --pty" fi container_command_login="${container_command_login} -c \"\\\$(getent passwd ${USER} | cut -f 7 -d :) -l\"" - container_command_prefix="${container_command_login} -c" else result_command="${result_command} --user=\"${USER}"\" @@ -468,8 +465,7 @@ generate_command() { ${container_name}" if [ -n "${container_command}" ]; then - result_command="${result_command} - ${container_command_prefix} \"${container_command}\"" + result_command="${result_command} ${container_command}" else # if no command was specified, let's execute a command that will find # and run the default shell for the user