summarylogtreecommitdiffstats
path: root/munge.install
blob: f1def7963619b466b9d1c24e3c613d1808f016d4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
_user="munge"

post_install() {
	# The installation process is described at https://github.com/dun/munge/wiki/Installation-Guide

	# Create munge /var/run/munge dir and secure it
	mkdir -p /var/run/munge
	chmod 0755 /var/run/munge

	getent group "${_user}" &>/dev/null
	if [ $? -ne 0 ]; then
		echo "Adding ${_user} system group..."
		groupadd -r ${_user} 1>/dev/null
	fi

	getent passwd "${_user}" &>/dev/null
	if [ $? -ne 0 ]; then
		echo "Adding ${_user} system user..."
		useradd -r -g ${_user} -d "/var/log/munge" -c "Munge Daemon" ${_user} 1>/dev/null
	fi

	echo "Locking Munge User Account..."
	passwd -l munge &>/dev/null

	# Create munge key
	if [[ ! -e /etc/munge/munge.key && -c /dev/urandom ]]; then
		echo "Creating random munge key at /etc/munge/munge.key ..."
		dd if=/dev/urandom bs=1 count=1024 of=/etc/munge/munge.key
		chmod 0400 /etc/munge/munge.key
	else
		if [[ -c /dev/urandom ]]; then
			echo "No munge key is generated since /etc/munge/munge.key already exists."
		else
			echo "Did not create /etc/munge/munge.key since /dev/urandom can not be found."
		fi
	fi

	# Set permissions
	chown ${_user}:${_user} -R /etc/munge
	chown ${_user}:${_user} -R /var/log/munge
	chown ${_user}:${_user} -R /var/lib/munge
	chown ${_user}:${_user} -R /var/run/munge
}

post_upgrade() {
	# Set permissions
	chown ${_user}:${_user} -R /etc/munge
	chown ${_user}:${_user} -R /var/log/munge
	chown ${_user}:${_user} -R /var/lib/munge
	chown ${_user}:${_user} -R /var/run/munge

	if [[ -e /etc/munge/munge.key ]]; then
		chmod 0400 /etc/munge/munge.key
	fi
}

pre_remove() {
	echo "Stopping and disabling munge using SystemD..."
	systemctl stop munge
	systemctl disable munge.service
}

post_remove() {
	# Removing obsolete directory
	rm -rf /var/run/munge

	# Notifying the user of kept dirs and change owner
	[[ -d /etc/munge ]] && chown root:root -R /etc/munge && echo "Custom configuration-file(s) in /etc/munge/ were kept on your system."
	[[ -d /var/log/munge ]] && chown root:root -R /var/log/munge && echo "Logfiles were preserved. They reside under /var/log/munge ."

	echo "Removing ${_user} system user and group..."
	if getent passwd ${_user} >/dev/null 2>&1; then
		userdel ${_user} 2>/dev/null
	fi
	if getent group ${_user} >/dev/null 2>&1; then
		groupdel ${_user}
	fi
}