mirror of
https://github.com/mail-in-a-box/mailinabox.git
synced 2024-11-26 02:57:04 +00:00
merge v0.21c hot fix release
This commit is contained in:
commit
2c86fa3755
@ -12,6 +12,13 @@ In Development
|
|||||||
* Made nightly re-provisioning of TLS certificates less noisy.
|
* Made nightly re-provisioning of TLS certificates less noisy.
|
||||||
* Fixed bugs in rsync backup method.
|
* Fixed bugs in rsync backup method.
|
||||||
|
|
||||||
|
v0.21c (February 1, 2017)
|
||||||
|
-------------------------
|
||||||
|
|
||||||
|
Installations and upgrades started failing about 10 days ago with the error "ImportError: No module named 'packaging'" after an upstream package (Python's setuptools) was updated by its maintainers. The updated package conflicted with Ubuntu 14.04's version of another package (Python's pip). This update upgrades both packages to remove the conflict.
|
||||||
|
|
||||||
|
If you already encountered the error during installation or upgrade of Mail-in-a-Box, this update may not correct the problem on your existing system. See https://discourse.mailinabox.email/t/v0-21c-release-fixes-python-package-installation-issue/1881 for help if the problem persists after upgrading to this version of Mail-in-a-Box.
|
||||||
|
|
||||||
v0.21b (December 4, 2016)
|
v0.21b (December 4, 2016)
|
||||||
-------------------------
|
-------------------------
|
||||||
|
|
||||||
|
@ -59,7 +59,7 @@ by me:
|
|||||||
$ curl -s https://keybase.io/joshdata/key.asc | gpg --import
|
$ curl -s https://keybase.io/joshdata/key.asc | gpg --import
|
||||||
gpg: key C10BDD81: public key "Joshua Tauberer <jt@occams.info>" imported
|
gpg: key C10BDD81: public key "Joshua Tauberer <jt@occams.info>" imported
|
||||||
|
|
||||||
$ git verify-tag v0.21b
|
$ git verify-tag v0.21c
|
||||||
gpg: Signature made ..... using RSA key ID C10BDD81
|
gpg: Signature made ..... using RSA key ID C10BDD81
|
||||||
gpg: Good signature from "Joshua Tauberer <jt@occams.info>"
|
gpg: Good signature from "Joshua Tauberer <jt@occams.info>"
|
||||||
gpg: WARNING: This key is not certified with a trusted signature!
|
gpg: WARNING: This key is not certified with a trusted signature!
|
||||||
@ -72,7 +72,7 @@ and on my [personal homepage](https://razor.occams.info/). (Of course, if this r
|
|||||||
|
|
||||||
Checkout the tag corresponding to the most recent release:
|
Checkout the tag corresponding to the most recent release:
|
||||||
|
|
||||||
$ git checkout v0.21b
|
$ git checkout v0.21c
|
||||||
|
|
||||||
Begin the installation.
|
Begin the installation.
|
||||||
|
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
#########################################################
|
#########################################################
|
||||||
|
|
||||||
if [ -z "$TAG" ]; then
|
if [ -z "$TAG" ]; then
|
||||||
TAG=v0.21b
|
TAG=v0.21c
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Are we running as root?
|
# Are we running as root?
|
||||||
|
@ -4,7 +4,10 @@ source setup/functions.sh
|
|||||||
|
|
||||||
echo "Installing Mail-in-a-Box system management daemon..."
|
echo "Installing Mail-in-a-Box system management daemon..."
|
||||||
|
|
||||||
# Install packages.
|
# DEPENDENCIES
|
||||||
|
|
||||||
|
# Install Python packages that are available from the Ubuntu
|
||||||
|
# apt repository:
|
||||||
# flask, yaml, dnspython, and dateutil are all for our Python 3 management daemon itself.
|
# flask, yaml, dnspython, and dateutil are all for our Python 3 management daemon itself.
|
||||||
# duplicity does backups. python-pip is so we can 'pip install boto' for Python 2, for duplicity, so it can do backups to AWS S3.
|
# duplicity does backups. python-pip is so we can 'pip install boto' for Python 2, for duplicity, so it can do backups to AWS S3.
|
||||||
apt_install python3-flask links duplicity libyaml-dev python3-dnspython python3-dateutil python-pip
|
apt_install python3-flask links duplicity libyaml-dev python3-dnspython python3-dateutil python-pip
|
||||||
@ -12,18 +15,46 @@ apt_install python3-flask links duplicity libyaml-dev python3-dnspython python3-
|
|||||||
# These are required to pip install cryptography.
|
# These are required to pip install cryptography.
|
||||||
apt_install build-essential libssl-dev libffi-dev python3-dev
|
apt_install build-essential libssl-dev libffi-dev python3-dev
|
||||||
|
|
||||||
|
# pip<6.1 + setuptools>=34 have a problem with packages that
|
||||||
|
# try to update setuptools during installation, like cryptography.
|
||||||
|
# See https://github.com/pypa/pip/issues/4253. The Ubuntu 14.04
|
||||||
|
# package versions are pip 1.5.4 and setuptools 3.3. When we
|
||||||
|
# install cryptography under those versions, it tries to update
|
||||||
|
# setuptools to version 34, which now creates the conflict, and
|
||||||
|
# then pip gets permanently broken with errors like
|
||||||
|
# "ImportError: No module named 'packaging'".
|
||||||
|
#
|
||||||
|
# Let's test for the error:
|
||||||
|
if ! python3 -c "from pkg_resources import load_entry_point" 2&> /dev/null; then
|
||||||
|
# This system seems to be broken already.
|
||||||
|
echo "Fixing broken pip and setuptools..."
|
||||||
|
rm -rf /usr/local/lib/python3.4/dist-packages/{pkg_resources,setuptools}*
|
||||||
|
apt-get install --reinstall python3-setuptools python3-pip python3-pkg-resources
|
||||||
|
fi
|
||||||
|
#
|
||||||
|
# The easiest work-around on systems that aren't already broken is
|
||||||
|
# to upgrade pip (to >=9.0.1) and setuptools (to >=34.1) individually
|
||||||
|
# before we install any package that tries to update setuptools.
|
||||||
|
hide_output pip3 install --upgrade pip
|
||||||
|
hide_output pip3 install --upgrade setuptools
|
||||||
|
|
||||||
# Install other Python 3 packages used by the management daemon.
|
# Install other Python 3 packages used by the management daemon.
|
||||||
# The first line is the packages that Josh maintains himself!
|
# The first line is the packages that Josh maintains himself!
|
||||||
# NOTE: email_validator is repeated in setup/questions.sh, so please keep the versions synced.
|
# NOTE: email_validator is repeated in setup/questions.sh, so please keep the versions synced.
|
||||||
|
# Force acme to be updated because it seems to need it after the
|
||||||
|
# pip/setuptools breakage (see above) and the ACME protocol may
|
||||||
|
# have changed (I got an error on one of my systems).
|
||||||
hide_output pip3 install --upgrade \
|
hide_output pip3 install --upgrade \
|
||||||
rtyaml "email_validator>=1.0.0" "free_tls_certificates>=0.1.3" "exclusiveprocess" \
|
rtyaml "email_validator>=1.0.0" "free_tls_certificates>=0.1.3" "exclusiveprocess" \
|
||||||
"idna>=2.0.0" "cryptography>=1.0.2" boto psutil
|
"idna>=2.0.0" "cryptography>=1.0.2" acme boto psutil
|
||||||
|
|
||||||
# duplicity uses python 2 so we need to get the python 2 package of boto to have backups to S3.
|
# duplicity uses python 2 so we need to get the python 2 package of boto to have backups to S3.
|
||||||
# boto from the Ubuntu package manager is too out-of-date -- it doesn't support the newer
|
# boto from the Ubuntu package manager is too out-of-date -- it doesn't support the newer
|
||||||
# S3 api used in some regions, which breaks backups to those regions. See #627, #653.
|
# S3 api used in some regions, which breaks backups to those regions. See #627, #653.
|
||||||
hide_output pip install --upgrade boto
|
hide_output pip install --upgrade boto
|
||||||
|
|
||||||
|
# CONFIGURATION
|
||||||
|
|
||||||
# Create a backup directory and a random key for encrypting backups.
|
# Create a backup directory and a random key for encrypting backups.
|
||||||
mkdir -p $STORAGE_ROOT/backup
|
mkdir -p $STORAGE_ROOT/backup
|
||||||
if [ ! -f $STORAGE_ROOT/backup/secret_key.txt ]; then
|
if [ ! -f $STORAGE_ROOT/backup/secret_key.txt ]; then
|
||||||
|
Loading…
Reference in New Issue
Block a user