summaryrefslogtreecommitdiffstats
path: root/etc/rc.d/cleartmp
blob: 94b7799ba6d5fc61f486012b6f722dc9928359e9 (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
#!/bin/sh
#
# $FreeBSD$
#

# PROVIDE: cleartmp
# REQUIRE: mountcritremote tmp
# BEFORE: DAEMON

. /etc/rc.subr

name="cleartmp"
# Disguise rcvar for the start method to run irrespective of its setting.
rcvar1=`set_rcvar clear_tmp`
start_cmd="${name}_start"
stop_cmd=":"

cleartmp_start()
{
	# Make /tmp location variable for easier debugging.
	local tmp="/tmp"

	# X related directories to create in /tmp.
	local x11_socket_dirs="${tmp}/.X11-unix ${tmp}/.XIM-unix \
			       ${tmp}/.ICE-unix ${tmp}/.font-unix"

	if checkyesno ${rcvar1}; then
		check_startmsgs && echo "Clearing ${tmp}."

		# This is not needed for mfs, but doesn't hurt anything.
		# Things to note:
		# + The dot in ${tmp}/. is important.
		# + Put -prune before -exec so find never descends
		#   into a directory that was already passed to rm -rf.
		# + "--" in rm arguments isn't strictly necessary, but
		#   it can prevent foot-shooting in future.
		# + /tmp/lost+found is preserved, but its contents are removed.
		# + lost+found and quota.* in subdirectories are removed.
		find -x ${tmp}/. ! -name . \
		    ! \( -name lost+found -type d -user root \) \
		    ! \( \( -name quota.user -or -name quota.group \) \
			-type f -user root \) \
		    -prune -exec rm -rf -- {} +
	elif checkyesno clear_tmp_X; then
		# Remove X lock files, since they will prevent you from
		# restarting X.  Remove other X related directories.
		check_startmsgs && echo "Clearing ${tmp} (X related)."
		rm -rf ${tmp}/.X[0-9]-lock ${x11_socket_dirs}
	fi
	if checkyesno clear_tmp_X; then
		# Create X related directories with proper permissions.
		mkdir -m 1777 ${x11_socket_dirs}
	fi
}

load_rc_config $name
run_rc_command "$1"
OpenPOWER on IntegriCloud