4
0
Fork 0
ldap-admin/bin/add-user

73 lines
2.3 KiB
Bash
Executable File

#!/bin/bash
#% Usage: add-user [-l <login>] [-N <full name>] [-e <email>] [-g <membership group (fatty/starving)]
#% Adds a user to LDAP. Interactive if parameters not specified on command line
#% Switches:
#% -l <login> - Set the user's login name. It will be stored in the 'uid' LDAP field
#% -N <full name> - Set the full name of the user. It will be stored in the the 'givenName' and 'surname' LDAP fields
#% -e <email> - Set the email address of the user. It will be stored in the 'mailRoutingAddress' and 'mail' LDAP fields
#% -g <membership group> - Set the membership group name (starving/fatty). If it's defined then the user will have full hackerspace membership features unlocked (xmpp, vpn and shell)
. $LIB_DIR/common.sh
function readvar() {
vname=$1
prompt=${2:-$1}
echo -n "$prompt: "
read $vname
}
function confirm() {
read -p "$* [Y] " -n 1 -r
echo # (optional) move to a new line
[[ $REPLY =~ ^([Yy]|)$ ]]
}
while getopts l:N:e:g: opt; do case $opt in
l)
login="$OPTARG";;
N)
cn="$OPTARG";;
e)
email="$OPTARG";;
g)
membership_group="$OPTARG";;
--)
break;;
*)
break;;
esac
done
uid=$((`maxuid`+1))
[ ! "$login" ] && readvar login "Login"
[ ! "$cn" ] && readvar cn "Full name"
[ ! "$email" ] && readvar email "Email"
[ ! "$membership_group" ] && readvar membership_group "Membership group (starving/fatty), press Enter to not assign a membership group"
readvar mifare_hash "Mifare card hash"
if ! [[ "$login" =~ ^[a-z][a-z0-9_]{2,}$ ]] ; then
echo "Login most start with a small lettr and contain only small letters, numbers and underscore" >&2
exit 1
fi
raw-add-user $login "$cn" "$email"
add-to-wiki $login
create-posix-group $login $uid
if [ "$membership_group" ]; then
grant-member-privileges -g $membership_group $login
fi
if [ "$mifare_hash" ]; then
set-mifare-hash $login $mifare_hash
fi
msg "After commiting, please issue welcome-email $login to activate the mailbox"
if confirm "Commit?"; then
commit
confirm "Setup homedir?" && sudo $BIN_DIR/setup-boston-homedir $login
confirm "Setup mailbox?" && sudo $BIN_DIR/setup-boston-mailbox $login
confirm "Send email?" && $BIN_DIR/welcome-email $login
# confirm "Setup password?" && kadmin add_principal
fi