Merge remote-tracking branch 'dheule/type__user'
This commit is contained in:
commit
7fad1074b6
6 changed files with 113 additions and 74 deletions
|
@ -1,2 +0,0 @@
|
|||
- delete users
|
||||
|
|
@ -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
|
||||
|
|
|
@ -20,6 +20,8 @@ None.
|
|||
|
||||
OPTIONAL PARAMETERS
|
||||
-------------------
|
||||
state::
|
||||
absent or present, defaults to present
|
||||
comment::
|
||||
see usermod(8)
|
||||
home::
|
||||
|
@ -33,6 +35,14 @@ shell::
|
|||
uid::
|
||||
see above
|
||||
|
||||
BOOLEAN PARAMETERS
|
||||
------------------
|
||||
system::
|
||||
see useradd(8), apply only on user create
|
||||
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
|
||||
--------------------------------------------------------------------------------
|
||||
|
||||
|
||||
|
|
|
@ -1 +1,3 @@
|
|||
create-home
|
||||
remove-home
|
||||
system
|
||||
|
|
1
cdist/conf/type/__user/parameter/default/state
Normal file
1
cdist/conf/type/__user/parameter/default/state
Normal file
|
@ -0,0 +1 @@
|
|||
present
|
|
@ -1,3 +1,4 @@
|
|||
state
|
||||
comment
|
||||
home
|
||||
gid
|
||||
|
|
Loading…
Reference in a new issue