Allow people to specify a list of temp dirs to clean in bootmisc #191807.

This commit is contained in:
Mike Frysinger 2007-09-09 15:52:05 +00:00
parent ba4b5d5b7f
commit 06ae2e5593
3 changed files with 59 additions and 40 deletions

View File

@ -1,6 +1,10 @@
# ChangeLog for Gentoo System Intialization ("rc") scripts # ChangeLog for Gentoo System Intialization ("rc") scripts
# Copyright 1999-2007 Gentoo Foundation; Distributed under the GPLv2 # Copyright 1999-2007 Gentoo Foundation; Distributed under the GPLv2
09 Sep 2007; Mike Frysinger <vapier@gentoo.org>:
Allow people to specify a list of temp dirs to clean in bootmisc #191807.
04 Sep 2007; Roy Marples <uberlord@gentoo.org>: 04 Sep 2007; Roy Marples <uberlord@gentoo.org>:
start-stop-daemon now works with userids correctly when a pidfile start-stop-daemon now works with userids correctly when a pidfile

View File

@ -4,5 +4,9 @@
# system startup is complete # system startup is complete
DELAYLOGIN="no" DELAYLOGIN="no"
# List of /tmp directories we should clean up
WIPE_TMP_DIRS="/tmp"
# Should we wipe the tmp paths completely or just selectively remove known
# locks / files / etc... ? # locks / files / etc... ?
WIPE_TMP="yes" WIPE_TMP="yes"

View File

@ -9,6 +9,52 @@ depend() {
after clock sysctl after clock sysctl
} }
cleanup_tmp_dir() {
local dir=$1
mkdir -p ${dir}
cd ${dir}
if [ "${WIPE_TMP}" = "yes" ] ; then
ebegin "Wiping ${dir} directory"
local startopts="-x . -depth"
[ "${RC_UNAME}" = "Linux" ] && startopts=". -xdev -depth"
# Faster than find
rm -rf [b-ikm-pr-zA-Z]*
find ${startopts} ! -name . \
! -path ./lost+found \
! -path "./lost+found/*" \
! -path ./quota.user \
! -path "./quota.user/*" \
! -path ./aquota.user \
! -path "./aquota.user/*" \
! -path ./quota.group \
! -path "./quota.group/*" \
! -path ./aquota.group \
! -path "./aquota.group/*" \
! -path ./journal \
! -path "./journal/*" \
-delete
eend 0
else
ebegin "Cleaning ${dir} directory"
rm -rf ${dir}/.X*-lock ${dir}/esrv* ${dir}/kio* ${dir}/jpsock.* \
${dir}/.fam* ${dir}/.esd* ${dir}/orbit-* ${dir}/ssh-* \
${dir}/ksocket-* ${dir}/.*-unix
eend 0
fi
chmod +t ${dir}
# Make sure our X11 stuff have the correct permissions
# Omit the chown as bootmisc is run before network is up
# and users may be using lame LDAP auth #139411
rm -rf ${dir}/.ICE-unix ${dir}/.X11-unix
mkdir -p ${dir}/.ICE-unix ${dir}/.X11-unix
chmod 1777 ${dir}/.ICE-unix ${dir}/.X11-unix
[ -x /sbin/restorecon ] && restorecon ${dir}/.ICE-unix ${dir}/.X11-unix
}
start() { start() {
# Put a nologin file in /etc to prevent people from logging # Put a nologin file in /etc to prevent people from logging
# in before system startup is complete. # in before system startup is complete.
@ -85,46 +131,11 @@ start() {
printf "" >/var/lock/.keep printf "" >/var/lock/.keep
eend 0 eend 0
# Clean up /tmp directory # Clean up /tmp directories
cd /tmp local tmp
if [ "${WIPE_TMP}" = "yes" ] ; then for tmp in ${WIPE_TMP_DIRS-/tmp} ; do
ebegin "Wiping /tmp directory" cleanup_tmp_dir ${tmp}
local startopts="-x . -depth" done
[ "${RC_UNAME}" = "Linux" ] && startopts=". -xdev -depth"
# Faster than find
rm -rf [b-ikm-pr-zA-Z]*
find ${startopts} ! -name . \
! -path ./lost+found \
! -path "./lost+found/*" \
! -path ./quota.user \
! -path "./quota.user/*" \
! -path ./aquota.user \
! -path "./aquota.user/*" \
! -path ./quota.group \
! -path "./quota.group/*" \
! -path ./aquota.group \
! -path "./aquota.group/*" \
! -path ./journal \
! -path "./journal/*" \
-delete
eend 0
else
ebegin "Cleaning /tmp directory"
rm -rf /tmp/.X*-lock /tmp/esrv* /tmp/kio* /tmp/jpsock.* \
/tmp/.fam* /tmp/.esd* /tmp/orbit-* /tmp/ssh-* \
/tmp/ksocket-* /tmp/.*-unix
eend 0
fi
# Make sure our X11 stuff have the correct permissions
# Omit the chown as bootmisc is run before network is up
# and users may be using lame LDAP auth #139411
rm -rf /tmp/.ICE-unix /tmp/.X11-unix
mkdir -p /tmp/.ICE-unix /tmp/.X11-unix
chmod 1777 /tmp/.ICE-unix /tmp/.X11-unix
[ -x /sbin/restorecon ] && restorecon /tmp/.ICE-unix /tmp/.X11-unix
# Create an 'after-boot' dmesg log # Create an 'after-boot' dmesg log
if [ "${RC_SYS}" != "VPS" ] ; then if [ "${RC_SYS}" != "VPS" ] ; then