Magellan Linux

Diff of /branches/mage-next/src/helper/museradd

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 60 by niro, Tue Feb 15 22:59:14 2005 UTC revision 2268 by niro, Fri Oct 25 06:48:57 2013 UTC
# Line 1  Line 1 
1  #!/bin/bash  #!/bin/bash
2  # version: 0.3.6-r13  # $Id$
3    
4    # include all needed files
5    [ -f /etc/mage.rc.global ] && source /etc/mage.rc.global
6    [ -f ${MAGERC} ] && source ${MAGERC}
7    [ -f ${MLIBDIR}/mage4.functions.sh ] && source ${MLIBDIR}/mage4.functions.sh
8    
9  print_usage()  print_usage()
10  {  {
# Line 13  print_usage() Line 18  print_usage()
18   echo   echo
19  }  }
20    
21    busybox_fix_user_opts()
22    {
23     local i
24     local FIXED_USER_OPTS
25    
26     for i in $*
27     do
28     case $1 in
29     -d) shift; FIXED_USER_OPTS+=" -h $1" ;;
30     -g) shift; FIXED_USER_OPTS+=" -G $1" ;;
31     -G) shift; shift; continue;; # will be parsed through fix_group_opts
32     -u) shift; [[ $1 -lt 100 ]] && FIXED_USER_OPTS+=" -S"; FIXED_USER_OPTS+=" -u $1" ;;
33     -r) FIXED_USER_OPTS+=" -S" ;;
34     -M) FIXED_USER_OPTS+=" -H" ;;
35     *) FIXED_USER_OPTS+=" $1" ;;
36     esac
37     shift
38     done
39    
40     echo "${FIXED_USER_OPTS}"
41    }
42    
43    busybox_fix_group_opts()
44    {
45     local i
46     local FIXED_GROUP_OPTS
47    
48     for i in $*
49     do
50     case $1 in
51     -G) shift; FIXED_GROUP_OPTS+="$(echo $1 | sed 's:,:\ :g')" ;;
52     esac
53     shift
54     done
55    
56     echo "${FIXED_GROUP_OPTS}"
57    }
58    
59    fix_usermod_opts()
60    {
61     local i
62     local FIXED_USERMOD_OPTS
63    
64     for i in $*
65     do
66     case $1 in
67     -M) : ;; # usermod does not support the -M switch
68     *) FIXED_USERMOD_OPTS+=" $1" ;;
69     esac
70     shift
71     done
72    
73     echo "${FIXED_USERMOD_OPTS}"
74    }
75    
76    if [[ ! -z ${MROOT} ]] && [[ ${MROOT} != / ]]
77    then
78     chroot="chroot ${MROOT} "
79    else
80     chroot=""
81    fi
82    
83  while getopts "o:-" opt ; do  while getopts "o:-" opt ; do
84   case "${opt}" in   case "${opt}" in
85   o)   o)
# Line 39  fi Line 106  fi
106    
107  USER_TO_ADD="$1"  USER_TO_ADD="$1"
108    
109  #start nscd to cache passwd  # busybox support needed?
110  $(which nscd) -i passwd  if need_busybox_support adduser
 # get the info  
 my_user="$(getent passwd ${USER_TO_ADD})"  
   
 if [ -z "${my_user}" ]  
111  then  then
112   echo "     Adding user '${USER_TO_ADD}' ..."   echo -n "     Adding user '${USER_TO_ADD}'"
113   useradd ${USER_OPTS} "${USER_TO_ADD}"   [[ ! -z ${chroot} ]] && echo -n " into MROOT='${MROOT}'"
114     echo " ..."
115     ${chroot} adduser -S -D $(busybox_fix_user_opts ${USER_OPTS}) "${USER_TO_ADD}"
116     for grp in $(busybox_fix_group_opts ${USER_OPTS})
117     do
118     ${chroot} addgroup "${USER_TO_ADD}" "${grp}"
119     done
120    
121    # normal systems
122  else  else
123   echo "     Modifing user '${USER_TO_ADD}' ..."   # get the info
124   usermod ${USER_OPTS} "${USER_TO_ADD}"   my_user="$(${chroot} getent passwd ${USER_TO_ADD})"
125    
126     if [ -z "${my_user}" ]
127     then
128     echo -n "     Adding user '${USER_TO_ADD}'"
129     [[ ! -z ${chroot} ]] && echo -n " into MROOT='${MROOT}'"
130     echo " ..."
131     ${chroot} useradd -r ${USER_OPTS} "${USER_TO_ADD}"
132     else
133     echo -n "     Modifing user '${USER_TO_ADD}'"
134     [[ ! -z ${chroot} ]] && echo -n " in MROOT='${MROOT}'"
135     echo " ..."
136     ${chroot} usermod $(fix_usermod_opts ${USER_OPTS}) "${USER_TO_ADD}"
137     fi
138  fi  fi

Legend:
Removed from v.60  
changed lines
  Added in v.2268