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