|
Zbigniew Jędrzejewski-Szmek |
ced923 |
#!/bin/bash
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
# -*- mode: shell-script; indent-tabs-mode: true; tab-width: 4; -*-
|
|
Zbigniew Jędrzejewski-Szmek |
ced923 |
|
|
Zbigniew Jędrzejewski-Szmek |
ced923 |
# This script turns sysuser.d files into scriptlets mandated by Fedora
|
|
Zbigniew Jędrzejewski-Szmek |
ced923 |
# packaging guidelines. The general idea is to define users using the
|
|
Zbigniew Jędrzejewski-Szmek |
ced923 |
# declarative syntax but to turn this into traditional scriptlets.
|
|
Zbigniew Jędrzejewski-Szmek |
ced923 |
|
|
Zbigniew Jędrzejewski-Szmek |
ced923 |
user() {
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
user="$1"
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
uid="$2"
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
desc="$3"
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
group="$4"
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
home="$5"
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
shell="$6"
|
|
Zbigniew Jędrzejewski-Szmek |
ced923 |
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
[ "$desc" = '-' ] && desc=
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
{ [ "$home" = '-' ] || [ "$home" = '' ]; } && home=/
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
{ [ "$shell" = '-' ] || [ "$shell" = '' ]; } && shell=/usr/sbin/nologin
|
|
Zbigniew Jędrzejewski-Szmek |
ced923 |
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
if [ "$uid" = '-' ] || [ "$uid" = '' ]; then
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
cat <<-EOF
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
getent passwd '$user' >/dev/null || \\
|
|
Zbigniew Jędrzejewski-Szmek |
7e62bd |
useradd -r -g ${group@Q} -d ${home@Q} -s ${shell@Q} -c ${desc@Q} ${user@Q} || :
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
EOF
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
else
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
cat <<-EOF
|
|
Zbigniew Jędrzejewski-Szmek |
7e62bd |
if ! getent passwd ${user@Q} >/dev/null; then
|
|
Zbigniew Jędrzejewski-Szmek |
7e62bd |
if ! getent passwd ${uid@Q} >/dev/null; then
|
|
Zbigniew Jędrzejewski-Szmek |
7e62bd |
useradd -r -u ${uid@Q} -g ${group@Q} -d ${home@Q} -s ${shell@Q} -c ${desc@Q} ${user@Q} || :
|
|
Zbigniew Jędrzejewski-Szmek |
ef79df |
else
|
|
Zbigniew Jędrzejewski-Szmek |
7e62bd |
useradd -r -g ${group@Q} -d ${home@Q} -s ${shell@Q} -c ${desc@Q} ${user@Q} || :
|
|
Zbigniew Jędrzejewski-Szmek |
ef79df |
fi
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
fi
|
|
Zbigniew Jędrzejewski-Szmek |
ced923 |
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
EOF
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
fi
|
|
Zbigniew Jędrzejewski-Szmek |
ced923 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
ced923 |
|
|
Zbigniew Jędrzejewski-Szmek |
ced923 |
group() {
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
group="$1"
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
gid="$2"
|
|
Luca BRUNO |
f27d46 |
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
if [ "$gid" = '-' ]; then
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
cat <<-EOF
|
|
Zbigniew Jędrzejewski-Szmek |
7e62bd |
getent group ${group@Q} >/dev/null || groupadd -r ${group@Q} || :
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
EOF
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
else
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
cat <<-EOF
|
|
Zbigniew Jędrzejewski-Szmek |
7e62bd |
getent group ${group@Q} >/dev/null || groupadd -f -g ${gid@Q} -r ${group@Q} || :
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
EOF
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
fi
|
|
Zbigniew Jędrzejewski-Szmek |
ced923 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
ced923 |
|
|
Luca BRUNO |
f27d46 |
usermod() {
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
user="$1"
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
group="$2"
|
|
Luca BRUNO |
f27d46 |
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
cat <<-EOF
|
|
Zbigniew Jędrzejewski-Szmek |
7e62bd |
if getent group ${group@Q} >/dev/null; then
|
|
Zbigniew Jędrzejewski-Szmek |
7e62bd |
usermod -a -G ${group@Q} '$user' || :
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
fi
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
EOF
|
|
Luca BRUNO |
f27d46 |
}
|
|
Luca BRUNO |
f27d46 |
|
|
Zbigniew Jędrzejewski-Szmek |
ced923 |
parse() {
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
while read -r line || [ -n "$line" ] ; do
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
{ [ "${line:0:1}" = '#' ] || [ "${line:0:1}" = ';' ]; } && continue
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
line="${line## *}"
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
[ -z "$line" ] && continue
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
eval "arr=( $line )"
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
case "${arr[0]}" in
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
('u')
|
|
Martin Osvald |
833015 |
if [[ "${arr[2]}" == *":"* ]]; then
|
|
Martin Osvald |
833015 |
user "${arr[1]}" "${arr[2]%:*}" "${arr[3]}" "${arr[2]#*:}" "${arr[4]}" "${arr[5]}"
|
|
Martin Osvald |
833015 |
else
|
|
Martin Osvald |
833015 |
group "${arr[1]}" "${arr[2]}"
|
|
Martin Osvald |
833015 |
user "${arr[1]}" "${arr[2]}" "${arr[3]}" "${arr[1]}" "${arr[4]}" "${arr[5]}"
|
|
Martin Osvald |
833015 |
fi
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
;;
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
('g')
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
group "${arr[1]}" "${arr[2]}"
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
;;
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
('m')
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
group "${arr[2]}" "-"
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
user "${arr[1]}" "-" "" "${arr[1]}" "" ""
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
usermod "${arr[1]}" "${arr[2]}"
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
;;
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
esac
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
done
|
|
Zbigniew Jędrzejewski-Szmek |
ced923 |
}
|
|
Zbigniew Jędrzejewski-Szmek |
ced923 |
|
|
Zbigniew Jędrzejewski-Szmek |
ced923 |
for fn in "$@"; do
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
[ -e "$fn" ] || continue
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
echo "# generated from $(basename "$fn")"
|
|
Zbigniew Jędrzejewski-Szmek |
3c5b26 |
parse <"$fn"
|
|
Zbigniew Jędrzejewski-Szmek |
ced923 |
done
|