postinst is in fex 20160919-1.
This file is a maintainer script. It is executed when installing (*inst) or removing (*rm) the package.
The actual contents of the file can be viewed below.
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 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 | #!/bin/sh
# postinst script for fex
#
# see: dh_installdeb(1)
set -e
. /usr/share/debconf/confmodule
# summary of how this script can be called:
# * <postinst> `configure' <most-recently-configured-version>
# * <old-postinst> `abort-upgrade' <new version>
# * <conflictor's-postinst> `abort-remove' `in-favour' <package>
# <new-version>
# * <postinst> `abort-remove'
# * <deconfigured's-postinst> `abort-deconfigure' `in-favour'
# <failed-install-package> <version> `removing'
# <conflicting-package> <version>
# for details, see http://www.debian.org/doc/debian-policy/ or
# the debian-policy package
case "$1" in
configure)
# lets give them a fex user/group in all cases.
getent group fex >/dev/null 2>&1 || addgroup --system fex
getent passwd fex >/dev/null 2>&1 || adduser --system --home /usr/share/fex --no-create-home \
--disabled-password --shell /bin/sh --ingroup fex fex
FEX_USER_SHELL=$(getent passwd fex|awk -F: '{print $7}')
if [ "$FEX_USER_SHELL" = "/bin/false" ];then
echo "Updating user fex to have a valid shell (/bin/sh)"
chsh -s /bin/sh fex
fi
# ensure fac and fex_cleanup are run as user fex
for file in fex_cleanup logwatch fexwall;do
dpkg-statoverride --list /usr/share/fex/bin/$file >/dev/null || dpkg-statoverride --add fex fex 4750 /usr/share/fex/bin/$file
chown fex:fex /usr/share/fex/bin/$file
chmod 4750 /usr/share/fex/bin/$file
done
dpkg-statoverride --list /usr/bin/fac >/dev/null || dpkg-statoverride --add fex fex 4750 /usr/bin/fac
chown fex:fex /usr/bin/fac
chmod 4750 /usr/bin/fac
if [ ! -d /var/lib/fex/htdocs ]; then
echo "Installing initial copy of htdocs into /var/lib/fex/htdocs ..."
mkdir -p /var/lib/fex/htdocs/FAQ/
cd /usr/share/fex/htdocs/
find . -type f -exec cp {} /var/lib/fex/htdocs/{} \;
ln -sf /usr/share/javascript/jquery/jquery.js /var/lib/fex/htdocs/FAQ/jquery.js
ln -s /usr/share/fex/htdocs/download /var/lib/fex/htdocs/
else
echo "Upgrading version file in /var/lib/fex/htdocs"
cp /usr/share/fex/htdocs/version /var/lib/fex/htdocs/version
echo "/var/lib/fex/htdocs exists already, checking for default install"
[ -d /var/lib/fex/htdocs/FAQ/ ]||mkdir /var/lib/fex/htdocs/FAQ/
tmp=$(mktemp)
vers=$(mktemp -d)
(cd ${vers};tar xfz /usr/share/fex/.md5/htdocs.tgz)
if [ -f /usr/share/fex/.lastver ];then
lastinst=$(cat /usr/share/fex/.lastver)
db_set fex/lastver "$lastinst"
rm -f /usr/share/fex/.lastver
else
db_get fex/lastver
lastinst=$RET
fi
lastinstnoepoch=$(echo $lastinst | cut -d':' -f 2)
if [ -f ${vers}/${lastinst} ];then
if (cd /var/lib/fex;md5sum -c --quiet "${vers}/${lastinst}" >/dev/null 2>&1);then
# htdocs is identical
echo "Updating $lastinst default htdocs to new default htdocs"
cd /usr/share/fex/htdocs/
find . -type f -exec cp {} /var/lib/fex/htdocs/{} \;
rm -f "$tmp"
fi
if [ -L /var/lib/fex/htdocs/download ];then
if [ "$(readlink /var/lib/fex/htdocs/download)" = "/usr/share/fex/htdocs/download" ];then
#echo "Download directory is up to date."
true
else
echo "Download directory is pointing to non-default location."
echo "Please update client scripts yourself"
fi
else
for file in /usr/share/fex/htdocs/download/*;do
ln -sf "$file" /var/lib/fex/htdocs/download
done
fi
if [ -L /var/lib/fex/htdocs/FAQ/jquery.js ];then
if [ "$(readlink /var/lib/fex/htdocs/FAQ/jquery.js)" = "/usr/share/javascript/jquery/jquery.js" ];then
#echo "jquery.js link is up to date."
true
else
echo "jquery.js in htdocs/FAQ is pointing to non-default location."
echo "Please update jquery.js symlink yourself unless intended to not be system default"
fi
elif [ ! -f "/var/lib/fex/htdocs/FAQ/jquery.js" ];then
ln -s /usr/share/javascript/jquery/jquery.js /var/lib/fex/htdocs/FAQ/jquery.js
fi
fi
# tmp is created by mktemp and not cleaned up
# if we don't have ${vers}/${lastinst} -
# thus custom builds are always custom
if [ -f "$tmp" ];then
echo "Customizations in htdocs found. Not touching any files."
echo "The new default pages are at /usr/share/fex/htdocs/."
echo "Please check the diff yourself and update your htdocs dir if required."
rm "$tmp"
fi
if [ -e /var/lib/fex/htdocs/FIX.jar ];then
echo "F*IX is no longer supported. You should remove /var/lib/fex/htdocs/FIX.jar."
elif [ -L /var/lib/fex/htdocs/FIX.jar -a ! -e /var/lib/fex/htdocs/FIX.jar ];then
echo "Removing dangling symlink to FIX.jar"
rm -f /var/lib/fex/htdocs/FIX.jar
fi
rm -rf ${vers}
fi
# make sure we don't have MYHOSTNAME.MYDOMAIN as $hostname in /etc/fex/fex.ph
myhostname=$(hostname -f) # in case our piuparts chroot doesn't know about hostname
if [ ! -f /etc/fex/fex.ph ];then
if [ -z "$myhostname" ];then
echo 'Initializing /etc/fex/fex.ph WITHOUT hostname (Please correct before using F*EX)'
cat /usr/share/fex/templates/fex.ph >/var/lib/fex/fex.ph
else
echo 'Initializing /etc/fex/fex.ph with correcting hostname (using: '${myhostname}')'
cat /usr/share/fex/templates/fex.ph|sed -e 's/^\$hostname.*/\$hostname = '"'${myhostname}'"';/' >/var/lib/fex/fex.ph
fi
# make sure we reset ucf here..
ucfr --purge fex /etc/fex/fex.ph
mv /var/lib/fex/fex.ph /etc/fex/fex.ph
ucfr fex /etc/fex/fex.ph
# XXX: fex adminpw and ~fex/.fex/id will be autocreated by fex_cleanup further down
else
if egrep -q '^\$hostname.*=.*'"'MYHOSTNAME.MYDOMAIN'" /etc/fex/fex.ph 2>/dev/null;then
echo 'Unconfigured hostname found in /etc/fex/fex.ph! Please correct before using F*EX'
else
PW=$(perl -e 'require "/etc/fex/fex.ph";print $admin_pw;')
ADMIN=$(perl -e 'require "/etc/fex/fex.ph";print $admin;')
if [ ! -f /usr/share/fex/.fex/id -a -n "$PW" ];then
echo "Creating fex admin login. Moving admin_pw from fex.ph"
[ -d /usr/share/fex/.fex/ ]||install -d -m 0700 -o fex -g fex /usr/share/fex/.fex/
touch /usr/share/fex/.fex/id
chmod 0600 /usr/share/fex/.fex/id
chown fex:fex /usr/share/fex/.fex/id
perl -e 'require "/etc/fex/fex.ph";$opt_p ||= "8888";print "$hostname:$opt_p\n$admin\n$admin_pw\n";' > /usr/share/fex/.fex/id
fi
if [ ! -f "/usr/share/fex/spool/${ADMIN}/@" ];then
mkdir -p "/usr/share/fex/spool/${ADMIN}"
chmod 0700 "/usr/share/fex/spool/${ADMIN}"
touch "/usr/share/fex/spool/${ADMIN}/@"
chmod 0600 "/usr/share/fex/spool/${ADMIN}/@"
chown fex:fex "/usr/share/fex/spool/${ADMIN}"
echo "$PW" > "/usr/share/fex/spool/${ADMIN}/@"
fi
if grep -q '^$admin_pw' /etc/fex/fex.ph 2>/dev/null;then
echo '$admin_pw is set in /etc/fex/fex.ph ...'
echo 'Removing line and replacing by comment.'
echo 'From now on the fexmaster account also works in the web fac UI.'
sed -i -e '/^$admin_pw/s,^$admin_pw.*$,### $admin_pw is no longer used - fexmaster account may now also login via web-fac,' /etc/fex/fex.ph
PW=$(perl -e 'require "/etc/fex/fex.ph";print $admin_pw;')
if [ -n "$PW" ];then
echo
echo ' *** WARNING ***'
echo 'Some sort of include happening inside fex.ph. Please remove $admin_pw in include manually!'
echo ' *** WARNING ***'
echo
fi
fi
fi
NOTIFY=$(perl -e 'require "/etc/fex/fex.ph";print $notify_newrelease;')
if [ "$NOTIFY" != "" ];then
echo "You have notify_newrelease defined in /etc/fex/fex.ph!"
echo 'This should be set to'
echo '# ************************************************************'
echo '$notify_newrelease='"'';"
echo '# ************************************************************'
echo 'to ensure you do not get nagged for new upstream releases.'
echo "Updates for Debian fex come through apt/aptitude and don't need this obviously."
fi
fi
if [ -f /etc/aliases -o -L /etc/aliases ]; then
if ! grep -qi "^\s*fex\s*:" /etc/aliases; then
if [ -z "$2" ];then
echo "Adding system alias for fex to root"
echo "fex: root" >> /etc/aliases
# run newaliases for e.g. postfix
newal=`which newaliases || true`
if [ -n "$newal" ] && [ -x "$newal" ]; then
$newal || true
fi
else
echo "You have no alias set for user fex in /etc/aliases!"
echo "Consider adding one or you will not receive bounced emails from"
echo "fex daemon email notifications"
fi
fi
fi
if [ -f /etc/exim/exim.conf -o -f /var/lib/exim4/config.autogenerated ]; then
# exim4 found...
[ ! -f /var/lib/exim4/config.autogenerated ]||ISTRUSTED=$(egrep '^\s*(MAIN_TRUSTED_USERS|trusted_users)\s*=.*fex' /var/lib/exim4/config.autogenerated||true)
[ ! -f /etc/exim/exim.conf ]||ISTRUSTED=$(egrep '^\s*(MAIN_TRUSTED_USERS|trusted_users)\s*=.*fex' /etc/exim/exim.conf||true)
[ -z "$ISTRUSTED" ]||echo "You're running exim4 and fex isn't in the trusted_users list. Consider adding or email notifications may not work!"
fi
# make sure we have correct permissions
dpkg-statoverride --list /etc/fex/fex.ph >/dev/null || dpkg-statoverride --add fex fex 0640 /etc/fex/fex.ph
dpkg-statoverride --list /etc/fex/fup.pl >/dev/null || dpkg-statoverride --add fex fex 0640 /etc/fex/fup.pl
chown fex:fex /etc/fex/fex.ph /etc/fex/fup.pl
chmod 0640 /etc/fex/fex.ph /etc/fex/fup.pl
logdir=`sed -n '/\$logdir/s/^\$logdir\s*=\s*['"'"'"]\(.*\)['"'"'"].*/\1/p' /etc/fex/fex.ph|tail -n 1||true`
if [ "$logdir" = "/var/log/fex" ];then
for log in cleanup.log dop.log error.log fexsrv.log fop.log fup.log;do
if [ -r /var/spool/fex/${log} ];then
echo -n "Moving old log file ${log} to /var/log/fex"
if [ ! -r /var/log/fex/${log} ];then
mv /var/spool/fex/${log} /var/log/fex/
chmod 0640 /var/log/fex/${log}
echo '.'
elif [ ! -r /var/log/fex/${log}.1 ];then
# we already have a new logfile in /var/log/fex
mv /var/spool/fex/${log} /var/log/fex/${log}.1
chmod 0640 /var/log/fex/${log}*
echo '.'
else
echo ': failed!'
echo "New logdir already populated."
echo "Please move /var/spool/fex/${log} yourself if required."
fi
else
# Create new logfile with correct permissions
touch /var/log/fex/${log}
chmod 0640 /var/log/fex/${log}
fi
done
elif [ -z "$logdir" -o "${logdir}" = '$spooldir' ];then
echo 'Logdir still pointing to $spooldir. Please update to /var/log/fex'
echo 'in order to take full advantage of logrotate settings.'
echo 'Once you have updated your configfiles just run:'
echo ' dpkg-reconfigure fex'
echo 'To have the logfiles moved into their new location'
else
echo "Custom logdir configured. Not moving logfile to /var/log/fex."
fi
echo -n "Adding default spool keys dirs with secure permissions: "
for dir in .dkeys .ukeys .akeys .skeys .gkeys .xkeys .locks;do
mkdir -p "/var/spool/fex/$dir"
chmod 0700 "/var/spool/fex/$dir"
done
echo "done."
chown -R fex:fex /usr/share/fex/ /var/lib/fex/ /var/log/fex/ /var/spool/fex/
chmod 0750 /usr/share/fex/ /var/lib/fex/ /var/log/fex/ /var/spool/fex/
if [ -d /etc/xinetd.d ];then
ucf --debconf-ok /usr/share/fex/templates/xinetd_fex /etc/xinetd.d/fex
remainingsrv=`grep -r /usr/share/fex/bin/fexsrv /etc/xinetd.d|grep -v '^/etc/xinetd.d/fex:'|sed -e 's#^/etc/xinetd.d/\([^:]\+\):.*#\1#'|grep -v 'fex.*-*'||true`
if [ ! -z "$remainingsrv" ];then
echo "User-defined services in xinetd not updated: ${remainingsrv}. Please update yourself!"
fi
if [ -x /etc/init.d/xinetd ]; then
if [ -x /usr/sbin/invoke-rc.d ]; then
invoke-rc.d xinetd reload || true
else
/etc/init.d/xinetd reload || true
fi
fi
elif [ -r /etc/inetd.conf ];then
# We're running openbsd-inetd or something similar
fexsrv=`egrep '\s/usr/share/fex/bin/fexsrv' /etc/inetd.conf 2>/dev/null||true`
if [ -x /usr/sbin/update-inetd -a -z "$fexsrv" ];then
# as --multi is ugly we'll only support v4 through inetd.conf
# whoever wants IPv6 needs to go xinetd or hack his own version
# i.e. replace tcp with tcp6
update-inetd --add '8888\tstream\ttcp\tnowait\tfex:fex\t/usr/sbin/tcpd\t/usr/share/fex/bin/fexsrv'
elif [ -z "$fexsrv" ];then
echo 'Unable to automatically update inetd.conf'
echo 'Please update yourself and restart inetd'
fi
fi
echo 'Running fex_cleanup to verify config integrity ...'
su -s /bin/bash -c /usr/share/fex/bin/fex_cleanup fex
;;
abort-upgrade|abort-remove|abort-deconfigure)
;;
*)
echo "postinst called with unknown argument \`$1'" >&2
exit 1
;;
esac
# dh_installdeb will replace this with shell code automatically
# generated by other debhelper scripts.
exit 0
# vi: set smartindent ts=4 sw=4 expandtab autoindent sts=4:
|