aboutsummaryrefslogtreecommitdiffstats
path: root/useradd.sh
diff options
context:
space:
mode:
Diffstat (limited to 'useradd.sh')
-rw-r--r--useradd.sh110
1 files changed, 110 insertions, 0 deletions
diff --git a/useradd.sh b/useradd.sh
new file mode 100644
index 0000000..9ad307f
--- /dev/null
+++ b/useradd.sh
@@ -0,0 +1,110 @@
+#!/usr/bin/env bash
+# useradd.sh v1.2
+# (cc) 2006 Filipp Lepalaan <filipp@mac.com>
+# Updated to support both Tiger & Leopard <filipp@mac.com>
+# Updated for Leopard by Allan Sanderson <allanbee@mac.com>
+# Included non-interactive password setting - this is a contencious issue for
+# many, but it fits with what I need it to do!
+
+usage="sudo $(basename $0) [-u uid] [-g group] [-a] [-c] [-d home] \
+ [-p passwd] [-s shell] [-rn realname] name"
+
+if [ $# -eq 0 ]
+ then echo "Usage: $usage" >&2;
+ exit 1
+fi
+
+# Thnx to pea!
+if [ $USER != "root" ]
+ then echo "$(basename $0) must be run as root" >&2
+ exit 1
+fi
+
+# Some defaults
+def_shell=$SHELL
+def_home='/Users'
+make_home=true
+make_admin=false
+set_home=false
+make_passwd=true
+def_passwd=$(cat -n /usr/share/dict/words | grep -w $(jot -r 1 1 $n) | cut -f2)
+
+nextid() {
+ max_id=$(dscl . -list $1 $2 | awk '{print $2}' | sort -n | tail -n 1)
+ (( max_id++ ))
+ echo $max_id
+}
+
+new_uid=$(nextid /Users UniqueID)
+new_gid=$(nextid /Groups PrimaryGroupID)
+
+os_ver=$(sysctl -n kern.osrelease);os_ver=${os_ver:0:1}
+
+while getopts "u:g:acd:p:s:rn:" param
+do
+ case $param in
+ u ) new_uid=${OPTARG:-$new_uid};;
+ g ) new_gid=${OPTARG:-$new_gid};;
+ a ) make_admin=true;;
+ c ) make_home=true;;
+ d ) set_home=true; new_home=${OPTARG:-$new_user};;
+ p ) new_passwd=${OPTARG:-$def_passwd};;
+ s ) new_shell=${OPTARG:-$def_shell};;
+ rn ) new_fn=${OPTARG:-$def_rn};;
+ esac
+done
+
+shift $(($# - 1)); new_user=$1 # Get the last argument
+
+# Check if user already exists
+dscl . -read /Users/$new_user &> /dev/null
+if [ $? -eq 0 ]
+ then echo "Error: user $new_user already exists" >&2
+ exit 1
+fi
+
+# Set to default if not given
+new_rn=${new_fn:-$new_user}
+new_shell=${new_shell:-$def_shell}
+new_passwd=${new_passwd:-"$def_passwd"}
+new_home=${new_home:-"$def_home/$new_user"}
+
+# Process user record
+dscl . -create /Users/$new_user UniqueID $new_uid
+dscl . -create /Users/$new_user RealName "$new_rn"
+dscl . -create /Users/$new_user UserShell $new_shell
+dscl . -create /Users/$new_user GeneratedUID $(uuidgen)
+dscl . -create /Users/$new_user PrimaryGroupID $new_gid
+
+# Process group record
+if [ $os_ver -lt 9 ]
+ then dscl . -create /Groups/$new_user PrimaryGroupID $new_gid
+ dscl . -create /Groups/$new_user GroupMembership $new_user
+fi
+
+# Create home directory
+if [ $make_home == true ]
+ then echo "Creating $new_home"
+ cp -r /System/Library/User\ Template/English.lproj/ $new_home
+ cp -r /System/Library/User\ Template/Non_localized/* $new_home/
+ chown -R $new_user:$new_gid $new_home
+ set_home=true # Otherwise this'd be pretty pointless
+fi
+
+if [ $set_home == true ]
+ then dscl . -create /Users/$new_user NFSHomeDirectory $new_home
+fi
+
+if [ $make_admin == true ]
+ then echo "Adminning $new_user"
+ dscl . -append /Groups/admin users $new_user
+fi
+
+if [ $make_passwd == true ]
+ then echo "Setting password for $new_user"
+ dscl . -passwd /Users/$new_user "$new_passwd"
+fi
+
+echo "User $new_user ($new_uid) created, password: $new_passwd"
+
+exit 0