diff options
author | Renato Botelho <renato@netgate.com> | 2016-04-29 16:00:35 -0300 |
---|---|---|
committer | Renato Botelho <renato@netgate.com> | 2016-04-29 16:00:35 -0300 |
commit | a07d27e544882076e17da718a3dd98a403761b5c (patch) | |
tree | d40c8a21ea7ec57a0c5d65e70c022ffbc06ada02 /src/usr/local/share | |
parent | 17b31252fa105f473ac4c77fc200baf9dcb5f51b (diff) | |
download | pfsense-a07d27e544882076e17da718a3dd98a403761b5c.zip pfsense-a07d27e544882076e17da718a3dd98a403761b5c.tar.gz |
Fix #6137:
- Uninstall all packages on current system before upgrade using
pre_upgrade_command script
- Create a file containing all packages previously installed and
reinstall them on first boot after upgrade
Diffstat (limited to 'src/usr/local/share')
-rw-r--r-- | src/usr/local/share/pfSense/pre_upgrade_command | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/src/usr/local/share/pfSense/pre_upgrade_command b/src/usr/local/share/pfSense/pre_upgrade_command index 8c141a4..bf6ddd6 100644 --- a/src/usr/local/share/pfSense/pre_upgrade_command +++ b/src/usr/local/share/pfSense/pre_upgrade_command @@ -12,6 +12,51 @@ echo $PRIOR_VERSION > /tmp/pre_upgrade_version # De-activate sync on the root slice only. This will not match NanoBSD since it already has sync,noatime /usr/bin/sed -i '' 's/^\(\/.*[[:space:]]*\/[[:space:]]*ufs[[:space:]]*\)rw,sync\([[:space:]]*[[:digit:]][[:space:]]*[[:digit:]]\)$/\1rw\2/' /etc/fstab +# Uninstall all packages before upgrade to 2.3 +PFSENSE_VERSION=$(cat /etc/version) + +if echo "$PFSENSE_VERSION" | grep -q '^1.2'; then + UNINSTALL="uninstall_package_from_name" +else + UNINSTALL="uninstall_package" +fi + +cat >/tmp/remove_all_packages.php <<EOD +#!/usr/local/bin/php +<?php + +require_once("pkg-utils.inc"); + +global \$pkg_interface; +\$pkg_interface = "console"; + +if (!isset(\$config['installedpackages']['package'])) { + exit(0); +} + +if (!is_array(\$config['installedpackages']['package'])) { + exit(0); +} + +\$removed_packages = array(); +foreach (\$config['installedpackages']['package'] as \$package) { + if (isset(\$package['internal_name'])) { + \$removed_packages[] = \$package['internal_name']; + } else { + \$removed_packages[] = \$package['name']; + } + //${UNINSTALL}(\$package['name']); +} + +@file_put_contents("{\$g['cf_conf_path']}/packages_to_reinstall_after_upgrade.txt", implode("\\n",\$removed_packages)); + +?> +EOD + +/usr/local/bin/php /tmp/remove_all_packages.php +exit +rm -f /tmp/remove_all_packages.php + # Cleanup PBIs if which pbi_info >/dev/null 2>&1; then for pbi in $(pbi_info); do |