extended type __user: parameter state, system, remove-home new

This commit is contained in:
Daniel Heule 2013-12-17 14:13:20 +01:00
parent f165b5611e
commit 138d26e398
9 changed files with 113 additions and 74 deletions

View File

@ -1,2 +0,0 @@
- delete users

0
cdist/conf/type/__user/explorer/group Executable file → Normal file
View File

0
cdist/conf/type/__user/explorer/passwd Executable file → Normal file
View File

0
cdist/conf/type/__user/explorer/shadow Executable file → Normal file
View File

21
cdist/conf/type/__user/gencode-remote Executable file → Normal file
View File

@ -2,6 +2,7 @@
#
# 2011 Steven Armstrong (steven-cdist at armstrong.cc)
# 2011 Nico Schottelius (nico-cdist at schottelius.org)
# 2013 Daniel Heule (hda at sfs.biz)
#
# This file is part of cdist.
#
@ -21,11 +22,14 @@
#
# Manage users.
#
#set -x
name="$__object_id"
os="$(cat "$__global/explorer/os")"
state=$(cat "$__object/parameter/state")
# We need to shorten options for both usermod and useradd since on some
# systems (such as *BSD, Darwin) those commands do not handle GNU style long
# options.
@ -40,10 +44,12 @@ shorten_property() {
shell) ret="-s";;
uid) ret="-u";;
create-home) ret="-m";;
system) ret="-r";;
esac
echo "$ret"
}
if [ "$state" = "present" ]; then
cd "$__object/parameter"
if grep -q "^${name}:" "$__object/explorer/passwd"; then
for property in $(ls .); do
@ -78,6 +84,9 @@ if grep -q "^${name}:" "$__object/explorer/passwd"; then
shell) field=7 ;;
uid) field=3 ;;
create-home) continue;; # Does not apply to user modification
system) continue;; # Does not apply to user modification
state) continue;; # Does not apply to user modification
remove-home) continue;; # Does not apply to user modification
esac
# If we haven't already set $current_value above, pull it from the
@ -103,6 +112,8 @@ if grep -q "^${name}:" "$__object/explorer/passwd"; then
fi
else
for property in $(ls .); do
[ "$property" = "state" ] && continue
[ "$property" = "remove-home" ] && continue
new_value="$(cat "$property")"
if [ -z "$new_value" ];then # Boolean values have no value
set -- "$@" "$(shorten_property $property)"
@ -117,3 +128,13 @@ else
echo useradd "$@" "$name"
fi
fi
else
if grep -q "^${name}:" "$__object/explorer/passwd"; then
#user exists, but state != present, so delete it
if [ -f "$__object/parameter/remove-home" ]; then
echo userdel -r "${name}"
else
echo userdel "${name}"
fi
fi
fi

View File

@ -20,6 +20,8 @@ None.
OPTIONAL PARAMETERS
-------------------
state::
absent or present, defaults to present
comment::
see usermod(8)
home::
@ -32,7 +34,15 @@ shell::
see above
uid::
see above
system::
see above
BOOLEAN PARAMETERS
------------------
create-home::
see useradd(8), apply only on user create
remove-home::
see userdel(8), apply only on user delete
EXAMPLES
--------
@ -44,8 +54,14 @@ __user foobar
# Same but with a different shell
__user foobar --shell /bin/zsh
# Same but for a system account
__user foobar --system
# Set explicit uid and home
__user foobar --uid 1001 --shell /bin/zsh --home /home/foobar
# Drop user if exists
__user foobar --state absent
--------------------------------------------------------------------------------

View File

@ -1 +1,3 @@
create-home
remove-home
system

View File

@ -0,0 +1 @@
present

View File

@ -1,3 +1,4 @@
state
comment
home
gid