--- trunk/mage/usr/lib/mage/museradd 2005/02/15 00:37:07 57 +++ trunk/mage/usr/lib/mage/museradd 2011/08/30 10:37:48 1500 @@ -1,5 +1,10 @@ #!/bin/bash -# version: 0.3.6-r12 +# $Header: /home/cvsd/magellan-cvs/magellan-src/mage/usr/lib/mage/museradd,v 1.4 2005-06-01 15:48:43 niro Exp $ + +# include all needed files +[ -f /etc/mage.rc.global ] && source /etc/mage.rc.global +[ -f ${MAGERC} ] && source ${MAGERC} +[ -f ${MLIBDIR}/mage4.functions.sh ] && source ${MLIBDIR}/mage4.functions.sh print_usage() { @@ -13,6 +18,50 @@ echo } +busybox_fix_user_opts() +{ + local i + local FIXED_USER_OPTS + + for i in $* + do + case $1 in + -d) shift; FIXED_USER_OPTS+=" -h $1" ;; + -g) shift; FIXED_USER_OPTS+=" -G $1" ;; + -G) shift; shift; continue;; # will be parsed through fix_group_opts + -u) shift; [[ $1 -lt 100 ]] && FIXED_USER_OPTS+=" -S"; FIXED_USER_OPTS+=" -u $1" ;; + -r) FIXED_USER_OPTS+=" -S" ;; + *) FIXED_USER_OPTS+=" $1" ;; + esac + shift + done + + echo "${FIXED_USER_OPTS}" +} + +busybox_fix_group_opts() +{ + local i + local FIXED_GROUP_OPTS + + for i in $* + do + case $1 in + -G) shift; FIXED_GROUP_OPTS+="$(echo $1 | sed 's:,:\ :g')" ;; + esac + shift + done + + echo "${FIXED_GROUP_OPTS}" +} + +if [[ ! -z ${MROOT} ]] && [[ ${MROOT} != / ]] +then + chroot="chroot ${MROOT} " +else + chroot="" +fi + while getopts "o:-" opt ; do case "${opt}" in o) @@ -39,16 +88,33 @@ USER_TO_ADD="$1" -#start nscd to cache passwd -$(which nscd) -i passwd -# get the info -my_user="$(getent passwd ${USER_TO_ADD})" - -if [ -z "${my_user}" ] +# busybox support needed? +if need_busybox_support adduser then - echo " Adding user '${USER_TO_ADD}' ..." - useradd ${USER_OPTS} "${USER_TO_ADD}" + echo -n " Adding user '${USER_TO_ADD}'" + [[ ! -z ${chroot} ]] && echo -n " into MROOT='${MROOT}'" + echo " ..." + ${chroot} adduser -D $(busybox_fix_user_opts ${USER_OPTS}) "${USER_TO_ADD}" + for grp in $(busybox_fix_group_opts ${USER_OPTS}) + do + ${chroot} addgroup "${USER_TO_ADD}" "${grp}" + done + +# normal systems else - echo " Modifing user '${USER_TO_ADD}' ..." - usermod ${USER_OPTS} "${USER_TO_ADD}" + # get the info + my_user="$(${chroot} getent passwd ${USER_TO_ADD})" + + if [ -z "${my_user}" ] + then + echo -n " Adding user '${USER_TO_ADD}'" + [[ ! -z ${chroot} ]] && echo -n " into MROOT='${MROOT}'" + echo " ..." + ${chroot} useradd ${USER_OPTS} "${USER_TO_ADD}" + else + echo -n " Modifing user '${USER_TO_ADD}'" + [[ ! -z ${chroot} ]] && echo -n " in MROOT='${MROOT}'" + echo " ..." + ${chroot} usermod ${USER_OPTS} "${USER_TO_ADD}" + fi fi