]> andersk Git - openssh.git/commitdiff
- (dtucker) [contrib/cygwin/ssh-host-config] better support for automated
authordtucker <dtucker>
Tue, 7 Jul 2009 11:19:11 +0000 (11:19 +0000)
committerdtucker <dtucker>
Tue, 7 Jul 2009 11:19:11 +0000 (11:19 +0000)
   scripts and fix usage of eval.  Patch from Corinna Vinschen.

ChangeLog
contrib/cygwin/ssh-host-config

index 290d906752cabded7096bfe529596823c81d7b09..5e77f831546d443244b8c3ff68144ed6877849fe 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+20090707
+ - (dtucker) [contrib/cygwin/ssh-host-config] better support for automated
+   scripts and fix usage of eval.  Patch from Corinna Vinschen.
+
+20090705
  - (dtucker) OpenBSD CVS Sync
    - andreas@cvs.openbsd.org 2009/06/27 09:29:06
      [packet.h packet.c]
index 57e728fbc6dd3e5551faed8f3f0e3fcf931477c6..32cb6ba23b7a5586373ddf6e6def538fd775fb11 100644 (file)
@@ -1,6 +1,6 @@
 #!/bin/bash
 #
-# ssh-host-config, Copyright 2000, 2001, 2002, 2003 Red Hat Inc.
+# ssh-host-config, Copyright 2000-2009 Red Hat Inc.
 #
 # This file is part of the Cygwin port of OpenSSH.
 
@@ -26,7 +26,9 @@ port_number=22
 privsep_configured=no
 privsep_used=yes
 cygwin_value=""
+user_account=
 password_value=
+opt_force=no
 
 # ======================================================================
 # Routine: create_host_keys
@@ -287,6 +289,11 @@ install_service() {
          csih_inform "sshd requires.  You need to have or to create a privileged"
          csih_inform "account.  This script will help you do so."
          echo
+
+         [ "${opt_force}" = "yes" ] && opt_f=-f
+         [ -n "${user_account}" ] && opt_u="-u ""${user_account}"""
+         csih_select_privileged_username ${opt_f} ${opt_u} sshd
+
          if ! csih_create_privileged_user "${password_value}"
          then
            csih_error_recoverable "There was a serious problem creating a privileged user."
@@ -316,12 +323,12 @@ install_service() {
 
        if [ -n "${csih_cygenv}" ]
        then
-         cygwin_env="-e CYGWIN=\"${csih_cygenv}\""
+         cygwin_env=( -e "CYGWIN=${csih_cygenv}" )
        fi
        if [ -z "${password}" ]
        then
-         if eval cygrunsrv -I sshd -d \"CYGWIN sshd\" -p /usr/sbin/sshd \
-                           -a "-D" -y tcpip ${cygwin_env}
+         if cygrunsrv -I sshd -d "CYGWIN sshd" -p /usr/sbin/sshd \
+                           -a "-D" -y tcpip "${cygwin_env[@]}"
          then
            echo
            csih_inform "The sshd service has been installed under the LocalSystem"
@@ -330,8 +337,8 @@ install_service() {
            csih_inform "will start automatically after the next reboot."
          fi
        else
-         if eval cygrunsrv -I sshd -d \"CYGWIN sshd\" -p /usr/sbin/sshd \
-                           -a "-D" -y tcpip ${cygwin_env} \
+         if cygrunsrv -I sshd -d "CYGWIN sshd" -p /usr/sbin/sshd \
+                           -a "-D" -y tcpip "${cygwin_env[@]}" \
                            -u "${run_service_as}" -w "${password}"
          then
            echo
@@ -378,11 +385,13 @@ if [ "$PROGDIR" = "/etc/postinstall" ]
 then
   csih_auto_answer="no"
   csih_disable_color
+  opt_force=yes
 fi
 if [ -n "${SSH_HOST_CONFIG_AUTO_ANSWER_NO}" ]
 then
   csih_auto_answer="no"
   csih_disable_color
+  opt_force=yes
 fi
 
 # ======================================================================
@@ -407,10 +416,12 @@ do
 
   -y | --yes )
     csih_auto_answer=yes
+    opt_force=yes
     ;;
 
   -n | --no )
     csih_auto_answer=no
+    opt_force=yes
     ;;
 
   -c | --cygwin )
@@ -423,6 +434,11 @@ do
     shift
     ;;
 
+  -u | --user )
+    user_account="$1"
+    shift
+    ;;
+    
   -w | --pwd )
     password_value="$1"
     shift
@@ -443,6 +459,7 @@ do
     echo "  --no     -n            Answer all questions with \"no\" automatically."
     echo "  --cygwin -c <options>  Use \"options\" as value for CYGWIN environment var."
     echo "  --port   -p <n>        sshd listens on port n."
+    echo "  --user   -u <account>  privileged user for service."
     echo "  --pwd    -w <passwd>   Use \"pwd\" as password for privileged user."
     echo "  --privileged           On Windows NT/2k/XP, require privileged user"
     echo "                         instead of LocalSystem for sshd service."
@@ -489,7 +506,7 @@ then
 fi
 
 # Create /var/empty file used as chroot jail for privilege separation
-csih_make_dir "${LOCALSTATEDIR}/empty" "Cannot create log directory."
+csih_make_dir "${LOCALSTATEDIR}/empty" "Cannot create ${LOCALSTATEDIR}/empty directory."
 chmod 755 "${LOCALSTATEDIR}/empty"
 setfacl -m u:system:rwx "${LOCALSTATEDIR}/empty"
 
This page took 0.114636 seconds and 5 git commands to generate.