1
0
mirror of git://git.code.sf.net/p/zsh/code synced 2024-11-20 05:53:52 +01:00
zsh/Completion/Unix/Command/_user_admin

69 lines
2.0 KiB
Plaintext

#compdef useradd usermod groupadd groupmod
local args shells home=${${words[(r)-D]:+b}:-d} sun redhat
[[ -e /etc/redhat-release || -e /etc/mandrake-release ]]
redhat=$?
if [[ $service = user* ]]; then
if [[ -r /etc/shells ]]; then
shells=( ${${(f)"$(</etc/shells)"}:#\#*} )
else
shells=( ${(M)commands:#*/(|[abckz]|tc|ba)sh} )
fi
args=(
'(-D)-c+[comment]:comment'
"(-D)-${home}+[home directory]:home directory:_directories -W /"
'(-D)-e+[specify expiration date]:expiration date (YYYY-MM-DD)'
'(-D)-f+[specify inactive days]:inactive days'
'(-D)-g+[initial group]:initial group:_groups'
'(-D)-G+[supplementary groups]:supplementary groups:_groups -S,'
"(-D)-s+[shell]:shell:( $shells /bin/false )"
'(-D -M)-m[create home directory]'
'(-D)-u[uid]:uid'
'(-D)-o[allow non unique uid]'
)
[[ $OSTYPE = linux* ]] && args=( $args[@]
'(-D -U -L)-p+[specify encrypted password]:encrypted password' )
if [[ $service = useradd ]]; then
(( redhat )) || args=( $args[@]
"(-D -k -m)-M[don't create home]"
'(-D)-r[create system account]'
"(-D)-n[don't create mirrored user]"
)
[[ $OSTYPE = linux* ]] || sun=" -s"
args=( $args[@]
"(-c -G -m -k -M -p -u -o -n -r$sun)-D[modify or display defaults]"
'(-D -M)-k[skeleton home directory]:skeleton directory:_directories -W /'
':username'
)
else
(( redhat )) || args=( $args[@]
"(-U -p)-L[lock user's password]"
"(-L -p)-U[unlock user's password]"
)
args=( $args[@]
'-l[specify new user name]:new username'
':username:_users'
)
fi
else
args=( '-g+[gid]:gid' '-o[allow non unique gid]' )
if [[ $service = groupadd ]]; then
args=( $args[@] ':group name' )
(( redhat )) || args=( $args[@]
'-r[create system group]'
'-f[force]'
)
else
args=( $args[@]
'-n[specify new group name]:new group name'
':group name:_groups'
)
fi
fi
_arguments -A "-*" -s $args[@]