#/bin/sh -e # Source debconf library. . /usr/share/debconf/confmodule # Function for grabbing a parameter from an smb.conf file smbconf_retr() { if [ -z "$1" ]; then return fi if [ -n "$2" ]; then local FILE="$2" fi if [ -z "$FILE" ]; then return fi sed -n -e" s/^[[:space:]]*\[global\]/\[global\]/i /^\[global\]/,/^[[:space:]]*\[/ { s/^[[:space:]]*$1[[:space:]]*=[[:space:]]*//pi }" $FILE \ | tail -n 1 } FILE=/etc/samba/smb.conf db_title "Samba Server" # We ask the question IFF the config contains complex options that could # cause us to break the config. if [ -f "$FILE" ] && grep -v dhcp.conf $FILE \ | grep -qEi '\\$|^[[:space:]]*include[[:space:]]*=' then db_input high samba-common/do_debconf || true db_go else db_set samba-common/do_debconf true fi # If user doesn't want to use debconf to configure Samba the leave... db_get samba-common/do_debconf || true if [ "${RET}" = "false" ]; then exit 0 fi # User wants to use debconf, let's continue... # Adjust priority of the question about the workgroup name depending # on whether a workgroup name has already being specified. db_get samba-common/workgroup || true if [ "${RET}" ]; then WGPRIORITY=medium else WGPRIORITY=high fi # Preload any values from the existing smb.conf file if [ -f $FILE ]; then WORKGROUP=`smbconf_retr workgroup` if [ "$WORKGROUP" ]; then db_set samba-common/workgroup "$WORKGROUP" fi ENCRYPT=`smbconf_retr "encrypt passwords"` if [ "$ENCRYPT" ]; then ENCRYPT=`echo $ENCRYPT | tr '[A-Z]' '[a-z]'` if [ "$ENCRYPT" = "yes" ]; then ENCRYPT=true elif [ "$ENCRYPT" = "no" ]; then ENCRYPT=false fi db_set samba-common/encrypt_passwords "$ENCRYPT" fi CHARSET=`smbconf_retr "character set"` CODEPAGE=`smbconf_retr "client code page"` UNIXCHARSET=`smbconf_retr "unix charset"` DOSCHARSET=`smbconf_retr "dos charset"` # If we're upgrading from an old version and there's no # 'passdb backend' setting, add one. if [ "$1" = "configure" -a -n "$2" ] \ && dpkg --compare-versions "$2" lt 2.99.cvs.20020713-2 \ && ! grep -q -i '^[[:space:]]*passdb backend[[:space:]]*=' $FILE then TMPFILE=/etc/samba/smb.conf.dpkg-tmp sed -e' s/^\([[:space:]]*\)\[global\]/\1\[global\]/i s/^\([[:space:]]*\)encrypt passwords/\1encrypt passwords/i /^[[:space:]]*\[global\]/,/^[[:space:]]*\[/ { /^[[:space:]]*encrypt passwords[[:space:]]*=/a \ passdb backend = smbpasswd guest }' < $FILE > ${TMPFILE} chmod a+r ${TMPFILE} mv -f ${TMPFILE} /etc/samba/smb.conf fi fi # Get workgroup name db_input $WGPRIORITY samba-common/workgroup || true db_go # Use encrypted passwords? db_input medium samba-common/encrypt_passwords || true db_go # Handle migrating character sets if [ -n "$CHARSET" -a -z "$UNIXCHARSET" ] then UNIXCHARSET=`echo $CHARSET | sed -e's/iso-/ISO/i'` db_set samba-common/character_set "$UNIXCHARSET" # FIXME: should eventually be low. db_input medium samba-common/character_set || true db_go fi if [ -n "$CODEPAGE" -a -z "$DOSCHARSET" ] then DOSCHARSET=CP`echo $CODEPAGE | sed -e's/[[:alpha:]]*//g'` db_set samba-common/codepage "$DOSCHARSET" # FIXME: should eventually be low. db_input medium samba-common/codepage || true db_go fi DHCPPRIORITY=medium #if [ "$DEBCONF_RECONFIGURE" = 1 ] && [ -f /sbin/dhclient3 ] if [ -f /sbin/dhclient3 ] then DHCPPRIORITY=high # TODO: see if we can detect that dhcp3-client is *going* to be installed, # even if it isn't yet. #elif dpkg-query -W --showformat='${Status}\n' dhcp3-client | grep ??? # unknown ok not-installed ? # DHCPPRIORITY=high fi if [ ! -f $FILE ] || grep -q -i 'wins server' $FILE then # check the values before and after; unset the 'applied' flag # if they don't match. db_get samba-common/dhcp || true OLDDHCP="$RET" db_input $DHCPPRIORITY samba-common/dhcp || true db_go db_get samba-common/dhcp || true if [ "$OLDDHCP" != "$RET" ]; then db_fset samba-common/dhcp applied false fi fi