# find first free uid/gid in range
# find_id passwd 100 999
find_id() {
- local db first last ids
+ local i db first last ids
db=$1
first=$2
last=$3
}
remove_bloat() {
- local to_remove add_this i j text to_show cmd tmpfile installed
- local update_selections pkgs_to_deselect oldifs
+ local to_remove add_this i j n text to_show cmd tmpfile installed
+ local update_selections pkgs_to_deselect pkgs_to_remove oldifs pkglist
text="$msg_remove_bloat"
[ "$DEBUG" ] && set -x
###
run_actions() {
- local line lineno lineno2 f n name action testmsg
+ local line lineno lineno2 f n name action checkmsg check
[ "$DEBUG" ] && set -vx
name="$1"
f="$2"
lineno2=$(($lineno2+1))
line=$(echo -n "$line"| sed 's/\\$//'; head -$lineno2 "$f" | tail -1)
done
- test=$(echo "$line" | sed 's/ */ /g'| awk -F' ' '{print $1}')
+ check=$(echo "$line" | sed 's/ */ /g'| awk -F' ' '{print $1}')
action=$(echo "$line" | sed 's/ */ /g'| awk -F' ' '{print $2}')
- testmsg=""
- [ "$test" != "true" ] && testmsg="if '$test'"
- if eval $test; then
- log "$(printf 'action %02d' $lineno) starting: '${action}' $testmsg "
+ checkmsg=""
+ [ "$check" != "true" ] && checkmsg="if '$check'"
+ if eval $check; then
+ log "$(printf 'action %02d' $lineno) starting: '${action}' $checkmsg "
eval $action
- log "$(printf 'action %02d' $lineno) finished: '${action}' $testmsg"
+ log "$(printf 'action %02d' $lineno) finished: '${action}' $checkmsg"
else
- log "$(printf 'action %02d' $lineno) skipping: '${action}' $testmsg"
+ log "$(printf 'action %02d' $lineno) skipping: '${action}' $checkmsg"
fi
[ "$lineno2" -gt "$lineno" ] && lineno=$lineno2
done
if pkg apache-cn && ! pkg apache2-cn; then
notice "
-Prije prelaska na Debian Etch potrebno je napraviti nadogradnju sa apache 1.3 na apache 2.0.
+Prije prelaska na Debian Etch potrebno je napraviti nadogradnju sa Apache 1.3 na Apache 2.0.
Pokrenite:
'apt-get install apache2-cn'
}
upgrade () {
- local to_install packages
+ local i to_install packages
case "$1" in
first)
packages="$packages_first"
# restore modified config to their package defaults
# so the upgrade doesn't complain so much
restore_configs () {
+ local config_backup
+
pkg base-files lt 4 && restore_config /etc/issue /etc/issue.net
pkg bind9 lt 1:9.3.4 && restore_config /etc/bind/named.conf.options
pkg libpam-modules lt 0.79 && restore_config /etc/security/limits.conf
do
config_backup=$config.$backup_ext
if [ -e $config -a ! -e $config_backup ]; then
+ log "Saving config file $config"
cp -av $config $config_backup
ucf $config_backup $config
fi
DEBIAN_FRONTEND=noninteractive pkgadd libc6
}
-# upgrade apache -> apache2
-upgrade_apache () {
-
- # bugfix for apache2-cn postinst
- mkdir -p /etc/apache2
- touch /etc/apache2/httpd.conf
-
- # temporary remove packages conflicting with apache2
- delpkg=""
- for p in aosi-aai aosi-www-aai \
- php4-cn php4-odbc php4-xslt \
- squirrelmail-cn; do
+# upgrade apache2 to etch
+upgrade_apache2 () {
+ local package
- # remember installed packages
- if pkg $p; then
- delpkg="$delpkg $p"
- fi
+ for package in \
+ libapache2-mod-php4 \
+ php4-cli \
+ php4-cgi \
+ php4-cn \
+ apache2-cn
+ do
+ if pkg $package; then
+ pkgadd $package
+ fi
done
- # remove (but not purge) problematic packages
- if [ "$delpkg" ]; then
- eval apt-get --yes remove $delpkg
- fi
-
- # remove old apache
- pkgrm apache apache-common
-
- # install new packages
- eval pkgadd apache2-cn apache2-mpm-prefork \
- php4-cn libapache2-mod-php4 \
- $delpkg
+ pkgrm php-suhosin-cn # causes removal of applications on dist-upgrade
}
upgrade_amavis () {
+ local conf
+
# remove init script diversion
if [ -L /etc/init.d/amavis -a -f /etc/init.d/amavis.amavisd-new ]; then
rm -vf /etc/init.d/amavis
fi
# move old config aside
- local conf=/etc/amavis/amavisd.conf
+ conf=/etc/amavis/amavisd.conf
if [ -e $conf -a ! -e $conf.$backup_ext ]; then
mv -v $conf $conf.$backup_ext
fi
}
get_variable () {
- name=$1
- file=$2
+ local name=$1 file=$2 val
if [ -f "$file" ]; then
val=$(sed -n "/^[[:space:]]*$name[[:space:]]*=/s/[[:space:]]*//gp" $file)