mirror of
				git://git.code.sf.net/p/zsh/code
				synced 2025-11-04 07:21:06 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			68 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			Text
		
	
	
	
	
	
#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=( $(</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 expriration 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 /dev/null )"
 | 
						|
    '(-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[@]
 |