Compare commits
65 Commits
test-integ
...
test-cento
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
167ffb2dac | ||
|
|
839c735a25 | ||
|
|
ff9f343c8d | ||
|
|
ca6c9941b2 | ||
|
|
83ad28884d | ||
|
|
a150ab63f1 | ||
|
|
89c1075c2e | ||
|
|
50d0d6fd48 | ||
|
|
03c2570089 | ||
|
|
8ab1733d96 | ||
|
|
34db794886 | ||
|
|
e66f3248be | ||
|
|
3a7165d4f0 | ||
|
|
dedd426979 | ||
|
|
84646a918e | ||
|
|
5d422eb82c | ||
|
|
5f57e49162 | ||
|
|
541cf26fa9 | ||
|
|
836c80428d | ||
|
|
e166c3222e | ||
|
|
f7c1e52dd1 | ||
|
|
1df1421c15 | ||
|
|
a29f8cf801 | ||
|
|
7207e0ad0c | ||
|
|
8488d8bf3a | ||
|
|
c12fb5de4a | ||
|
|
b1ba95cda9 | ||
|
|
c625efdf7f | ||
|
|
3fcb2c2bb1 | ||
|
|
f17ea9b704 | ||
|
|
97de34a81d | ||
|
|
b3342ebdfe | ||
|
|
147e2c3551 | ||
|
|
4b6ef3e44b | ||
|
|
e856d95221 | ||
|
|
6f1121921d | ||
|
|
4bc4bce5f5 | ||
|
|
61a96bdaeb | ||
|
|
f1e580dcaf | ||
|
|
04f2f35fc5 | ||
|
|
20d9e5a7f7 | ||
|
|
1ff005bc29 | ||
|
|
7a2a15ab82 | ||
|
|
588f1bad14 | ||
|
|
153050d0e0 | ||
|
|
50cd32cccf | ||
|
|
bcadc53d26 | ||
|
|
670fc4790b | ||
|
|
122c373bc0 | ||
|
|
9e18b4c384 | ||
|
|
6944b92744 | ||
|
|
6200623416 | ||
|
|
52188c901b | ||
|
|
cd69e26274 | ||
|
|
d73a426698 | ||
|
|
6e5cc6dd06 | ||
|
|
12fa60b191 | ||
|
|
66d1d406ee | ||
|
|
7b456cdf75 | ||
|
|
bbade209aa | ||
|
|
c2d165e88b | ||
|
|
736809c2a3 | ||
|
|
541ea83c59 | ||
|
|
a519b3aac6 | ||
|
|
ee18ee1664 |
27
.travis.yml
27
.travis.yml
@@ -234,6 +234,9 @@ matrix:
|
|||||||
- sudo: required
|
- sudo: required
|
||||||
env: TOXENV=le_auto_centos6
|
env: TOXENV=le_auto_centos6
|
||||||
services: docker
|
services: docker
|
||||||
|
- sudo: required
|
||||||
|
env: TOXENV=le_auto_oraclelinux6
|
||||||
|
services: docker
|
||||||
<<: *extended-test-suite
|
<<: *extended-test-suite
|
||||||
- sudo: required
|
- sudo: required
|
||||||
env: TOXENV=docker_dev
|
env: TOXENV=docker_dev
|
||||||
@@ -298,15 +301,15 @@ script: '$TRAVIS_RETRY tox'
|
|||||||
|
|
||||||
after_success: '[ "$TOXENV" == "py27-cover" ] && codecov -F linux'
|
after_success: '[ "$TOXENV" == "py27-cover" ] && codecov -F linux'
|
||||||
|
|
||||||
notifications:
|
#notifications:
|
||||||
email: false
|
# email: false
|
||||||
irc:
|
# irc:
|
||||||
channels:
|
# channels:
|
||||||
# This is set to a secure variable to prevent forks from sending
|
# # This is set to a secure variable to prevent forks from sending
|
||||||
# notifications. This value was created by installing
|
# # notifications. This value was created by installing
|
||||||
# https://github.com/travis-ci/travis.rb and running
|
# # https://github.com/travis-ci/travis.rb and running
|
||||||
# `travis encrypt "chat.freenode.net#certbot-devel"`.
|
# # `travis encrypt "chat.freenode.net#certbot-devel"`.
|
||||||
- secure: "EWW66E2+KVPZyIPR8ViENZwfcup4Gx3/dlimmAZE0WuLwxDCshBBOd3O8Rf6pBokEoZlXM5eDT6XdyJj8n0DLslgjO62pExdunXpbcMwdY7l1ELxX2/UbnDTE6UnPYa09qVBHNG7156Z6yE0x2lH4M9Ykvp0G0cubjPQHylAwo0="
|
# - secure: "EWW66E2+KVPZyIPR8ViENZwfcup4Gx3/dlimmAZE0WuLwxDCshBBOd3O8Rf6pBokEoZlXM5eDT6XdyJj8n0DLslgjO62pExdunXpbcMwdY7l1ELxX2/UbnDTE6UnPYa09qVBHNG7156Z6yE0x2lH4M9Ykvp0G0cubjPQHylAwo0="
|
||||||
on_cancel: never
|
# on_cancel: never
|
||||||
on_success: never
|
# on_success: never
|
||||||
on_failure: always
|
# on_failure: always
|
||||||
|
|||||||
@@ -15,6 +15,7 @@ Certbot adheres to [Semantic Versioning](https://semver.org/).
|
|||||||
staging server instead of the live server when `--dry-run` is used.
|
staging server instead of the live server when `--dry-run` is used.
|
||||||
* Updated certbot-dns-google to depend on newer versions of
|
* Updated certbot-dns-google to depend on newer versions of
|
||||||
google-api-python-client and oauth2client.
|
google-api-python-client and oauth2client.
|
||||||
|
* Migrated CentOS 6 certbot-auto users from Python 3.4 to Python 3.6.
|
||||||
|
|
||||||
### Fixed
|
### Fixed
|
||||||
|
|
||||||
|
|||||||
@@ -1,9 +1,13 @@
|
|||||||
# For running tests, build a docker image with a passwordless sudo and a trust
|
# For running tests, build a docker image with a passwordless sudo and a trust
|
||||||
# store we can manipulate.
|
# store we can manipulate.
|
||||||
|
|
||||||
FROM centos:6
|
ARG REDHAT_DIST_FLAVOR
|
||||||
|
FROM ${REDHAT_DIST_FLAVOR}:6
|
||||||
|
|
||||||
RUN yum install -y epel-release
|
ARG REDHAT_DIST_FLAVOR
|
||||||
|
|
||||||
|
RUN curl -O https://dl.fedoraproject.org/pub/epel/epel-release-latest-6.noarch.rpm \
|
||||||
|
&& rpm -ivh epel-release-latest-6.noarch.rpm
|
||||||
|
|
||||||
# Install pip and sudo:
|
# Install pip and sudo:
|
||||||
RUN yum install -y python-pip sudo
|
RUN yum install -y python-pip sudo
|
||||||
@@ -27,11 +31,18 @@ RUN mkdir -p /home/lea/certbot
|
|||||||
COPY ./tests/certs/ca/my-root-ca.crt.pem /usr/local/share/ca-certificates/
|
COPY ./tests/certs/ca/my-root-ca.crt.pem /usr/local/share/ca-certificates/
|
||||||
RUN update-ca-trust
|
RUN update-ca-trust
|
||||||
|
|
||||||
# Copy code:
|
# Copy current letsencrypt-auto:
|
||||||
COPY . /home/lea/certbot/letsencrypt-auto-source
|
COPY . /home/lea/certbot/letsencrypt-auto-source
|
||||||
|
|
||||||
|
# Fetch previous letsencrypt-auto that was installing python 3.4
|
||||||
|
RUN curl https://raw.githubusercontent.com/certbot/certbot/v0.38.0/letsencrypt-auto-source/letsencrypt-auto \
|
||||||
|
-o /home/lea/certbot/letsencrypt-auto-source/letsencrypt-auto_py_34 \
|
||||||
|
&& chmod +x /home/lea/certbot/letsencrypt-auto-source/letsencrypt-auto_py_34
|
||||||
|
|
||||||
|
RUN cp /home/lea/certbot/letsencrypt-auto-source/tests/${REDHAT_DIST_FLAVOR}6_tests.sh /home/lea/certbot/letsencrypt-auto-source/tests/redhat6_tests.sh \
|
||||||
|
&& chmod +x /home/lea/certbot/letsencrypt-auto-source/tests/redhat6_tests.sh
|
||||||
|
|
||||||
USER lea
|
USER lea
|
||||||
WORKDIR /home/lea
|
WORKDIR /home/lea
|
||||||
|
|
||||||
RUN sudo chmod +x certbot/letsencrypt-auto-source/tests/centos6_tests.sh
|
CMD ["sudo", "certbot/letsencrypt-auto-source/tests/redhat6_tests.sh"]
|
||||||
CMD sudo certbot/letsencrypt-auto-source/tests/centos6_tests.sh
|
|
||||||
@@ -256,20 +256,28 @@ DeprecationBootstrap() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
MIN_PYTHON_VERSION="2.7"
|
MIN_PYTHON_2_VERSION="2.7"
|
||||||
MIN_PYVER=$(echo "$MIN_PYTHON_VERSION" | sed 's/\.//')
|
MIN_PYVER2=$(echo "$MIN_PYTHON_2_VERSION" | sed 's/\.//')
|
||||||
|
MIN_PYTHON_3_VERSION="3.5"
|
||||||
|
MIN_PYVER3=$(echo "$MIN_PYTHON_3_VERSION" | sed 's/\.//')
|
||||||
# Sets LE_PYTHON to Python version string and PYVER to the first two
|
# Sets LE_PYTHON to Python version string and PYVER to the first two
|
||||||
# digits of the python version
|
# digits of the python version.
|
||||||
|
# MIN_PYVER and MIN_PYTHON_VERSION are also set by this function, and their
|
||||||
|
# values depend on if we try to use Python 3 or Python 2.
|
||||||
DeterminePythonVersion() {
|
DeterminePythonVersion() {
|
||||||
# Arguments: "NOCRASH" if we shouldn't crash if we don't find a good python
|
# Arguments: "NOCRASH" if we shouldn't crash if we don't find a good python
|
||||||
#
|
#
|
||||||
# If no Python is found, PYVER is set to 0.
|
# If no Python is found, PYVER is set to 0.
|
||||||
if [ "$USE_PYTHON_3" = 1 ]; then
|
if [ "$USE_PYTHON_3" = 1 ]; then
|
||||||
|
MIN_PYVER=$MIN_PYVER3
|
||||||
|
MIN_PYTHON_VERSION=$MIN_PYTHON_3_VERSION
|
||||||
for LE_PYTHON in "$LE_PYTHON" python3; do
|
for LE_PYTHON in "$LE_PYTHON" python3; do
|
||||||
# Break (while keeping the LE_PYTHON value) if found.
|
# Break (while keeping the LE_PYTHON value) if found.
|
||||||
$EXISTS "$LE_PYTHON" > /dev/null && break
|
$EXISTS "$LE_PYTHON" > /dev/null && break
|
||||||
done
|
done
|
||||||
else
|
else
|
||||||
|
MIN_PYVER=$MIN_PYVER2
|
||||||
|
MIN_PYTHON_VERSION=$MIN_PYTHON_2_VERSION
|
||||||
for LE_PYTHON in "$LE_PYTHON" python2.7 python27 python2 python; do
|
for LE_PYTHON in "$LE_PYTHON" python2.7 python27 python2 python; do
|
||||||
# Break (while keeping the LE_PYTHON value) if found.
|
# Break (while keeping the LE_PYTHON value) if found.
|
||||||
$EXISTS "$LE_PYTHON" > /dev/null && break
|
$EXISTS "$LE_PYTHON" > /dev/null && break
|
||||||
@@ -285,7 +293,7 @@ DeterminePythonVersion() {
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
PYVER=`"$LE_PYTHON" -V 2>&1 | cut -d" " -f 2 | cut -d. -f1,2 | sed 's/\.//'`
|
PYVER=$("$LE_PYTHON" -V 2>&1 | cut -d" " -f 2 | cut -d. -f1,2 | sed 's/\.//')
|
||||||
if [ "$PYVER" -lt "$MIN_PYVER" ]; then
|
if [ "$PYVER" -lt "$MIN_PYVER" ]; then
|
||||||
if [ "$1" != "NOCRASH" ]; then
|
if [ "$1" != "NOCRASH" ]; then
|
||||||
error "You have an ancient version of Python entombed in your operating system..."
|
error "You have an ancient version of Python entombed in your operating system..."
|
||||||
@@ -368,7 +376,9 @@ BootstrapDebCommon() {
|
|||||||
|
|
||||||
# Sets TOOL to the name of the package manager
|
# Sets TOOL to the name of the package manager
|
||||||
# Sets appropriate values for YES_FLAG and QUIET_FLAG based on $ASSUME_YES and $QUIET_FLAG.
|
# Sets appropriate values for YES_FLAG and QUIET_FLAG based on $ASSUME_YES and $QUIET_FLAG.
|
||||||
# Enables EPEL if applicable and possible.
|
# Note: this function is called both while selecting the bootstrap scripts and
|
||||||
|
# during the actual bootstrap. Some things like prompting to user can be done in the latter
|
||||||
|
# case, but not in the former one.
|
||||||
InitializeRPMCommonBase() {
|
InitializeRPMCommonBase() {
|
||||||
if type dnf 2>/dev/null
|
if type dnf 2>/dev/null
|
||||||
then
|
then
|
||||||
@@ -388,26 +398,6 @@ InitializeRPMCommonBase() {
|
|||||||
if [ "$QUIET" = 1 ]; then
|
if [ "$QUIET" = 1 ]; then
|
||||||
QUIET_FLAG='--quiet'
|
QUIET_FLAG='--quiet'
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if ! $TOOL list *virtualenv >/dev/null 2>&1; then
|
|
||||||
echo "To use Certbot, packages from the EPEL repository need to be installed."
|
|
||||||
if ! $TOOL list epel-release >/dev/null 2>&1; then
|
|
||||||
error "Enable the EPEL repository and try running Certbot again."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
if [ "$ASSUME_YES" = 1 ]; then
|
|
||||||
/bin/echo -n "Enabling the EPEL repository in 3 seconds..."
|
|
||||||
sleep 1s
|
|
||||||
/bin/echo -ne "\e[0K\rEnabling the EPEL repository in 2 seconds..."
|
|
||||||
sleep 1s
|
|
||||||
/bin/echo -e "\e[0K\rEnabling the EPEL repository in 1 second..."
|
|
||||||
sleep 1s
|
|
||||||
fi
|
|
||||||
if ! $TOOL install $YES_FLAG $QUIET_FLAG epel-release; then
|
|
||||||
error "Could not enable EPEL. Aborting bootstrap!"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
|
|
||||||
BootstrapRpmCommonBase() {
|
BootstrapRpmCommonBase() {
|
||||||
@@ -488,13 +478,88 @@ BootstrapRpmCommon() {
|
|||||||
BootstrapRpmCommonBase "$python_pkgs"
|
BootstrapRpmCommonBase "$python_pkgs"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# If new packages are installed by BootstrapRpmPython3 below, this version
|
||||||
|
# number must be increased.
|
||||||
|
BOOTSTRAP_RPM_PYTHON3_LEGACY_VERSION=1
|
||||||
|
|
||||||
|
# Checks if rh-python36 can be installed.
|
||||||
|
Python36SclIsAvailable() {
|
||||||
|
InitializeRPMCommonBase >/dev/null 2>&1;
|
||||||
|
|
||||||
|
if "${TOOL}" list rh-python36 >/dev/null 2>&1; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
if "${TOOL}" list centos-release-scl >/dev/null 2>&1; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# Try to enable rh-python36 from SCL if it is necessary and possible.
|
||||||
|
EnablePython36SCL() {
|
||||||
|
if "$EXISTS" python3.6 > /dev/null 2> /dev/null; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
if ! scl --list 2>/dev/null | grep -q rh-python36; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
set +e
|
||||||
|
. scl_source enable rh-python36
|
||||||
|
set -e
|
||||||
|
}
|
||||||
|
|
||||||
|
# This bootstrap concerns old RedHat-based distributions that do not ship by default
|
||||||
|
# with Python 2.7, but only Python 2.6. We bootstrap them by enabling SCL and installing
|
||||||
|
# Python 3.6. Some of these distributions are: CentOS/RHEL/OL/SL 6.
|
||||||
|
BootstrapRpmPython3Legacy() {
|
||||||
|
# Tested with:
|
||||||
|
# - CentOS 6
|
||||||
|
|
||||||
|
InitializeRPMCommonBase
|
||||||
|
|
||||||
|
if ! "${TOOL}" list rh-python36 >/dev/null 2>&1; then
|
||||||
|
echo "To use Certbot on this operating system, packages from the SCL repository need to be installed."
|
||||||
|
if ! "${TOOL}" list centos-release-scl >/dev/null 2>&1; then
|
||||||
|
error "Enable the SCL repository and try running Certbot again."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
if [ "${ASSUME_YES}" = 1 ]; then
|
||||||
|
/bin/echo -n "Enabling the SCL repository in 3 seconds... (Press Ctrl-C to cancel)"
|
||||||
|
sleep 1s
|
||||||
|
/bin/echo -ne "\e[0K\rEnabling the SCL repository in 2 seconds... (Press Ctrl-C to cancel)"
|
||||||
|
sleep 1s
|
||||||
|
/bin/echo -e "\e[0K\rEnabling the SCL repository in 1 second... (Press Ctrl-C to cancel)"
|
||||||
|
sleep 1s
|
||||||
|
fi
|
||||||
|
if ! "${TOOL}" install "${YES_FLAG}" "${QUIET_FLAG}" centos-release-scl; then
|
||||||
|
error "Could not enable SCL. Aborting bootstrap!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# CentOS 6 must use rh-python36 from SCL
|
||||||
|
if "${TOOL}" list rh-python36 >/dev/null 2>&1; then
|
||||||
|
python_pkgs="rh-python36-python
|
||||||
|
rh-python36-python-virtualenv
|
||||||
|
rh-python36-python-devel
|
||||||
|
"
|
||||||
|
else
|
||||||
|
error "No supported Python package available to install. Aborting bootstrap!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
BootstrapRpmCommonBase "${python_pkgs}"
|
||||||
|
|
||||||
|
# Enable SCL rh-python36 after bootstrapping.
|
||||||
|
EnablePython36SCL
|
||||||
|
}
|
||||||
|
|
||||||
# If new packages are installed by BootstrapRpmPython3 below, this version
|
# If new packages are installed by BootstrapRpmPython3 below, this version
|
||||||
# number must be increased.
|
# number must be increased.
|
||||||
BOOTSTRAP_RPM_PYTHON3_VERSION=1
|
BOOTSTRAP_RPM_PYTHON3_VERSION=1
|
||||||
|
|
||||||
BootstrapRpmPython3() {
|
BootstrapRpmPython3() {
|
||||||
# Tested with:
|
# Tested with:
|
||||||
# - CentOS 6
|
|
||||||
# - Fedora 29
|
# - Fedora 29
|
||||||
|
|
||||||
InitializeRPMCommonBase
|
InitializeRPMCommonBase
|
||||||
@@ -505,12 +570,6 @@ BootstrapRpmPython3() {
|
|||||||
python3-virtualenv
|
python3-virtualenv
|
||||||
python3-devel
|
python3-devel
|
||||||
"
|
"
|
||||||
# EPEL uses python34
|
|
||||||
elif $TOOL list python34 >/dev/null 2>&1; then
|
|
||||||
python_pkgs="python34
|
|
||||||
python34-devel
|
|
||||||
python34-tools
|
|
||||||
"
|
|
||||||
else
|
else
|
||||||
error "No supported Python package available to install. Aborting bootstrap!"
|
error "No supported Python package available to install. Aborting bootstrap!"
|
||||||
exit 1
|
exit 1
|
||||||
@@ -769,31 +828,50 @@ elif [ -f /etc/redhat-release ]; then
|
|||||||
RPM_DIST_VERSION=0
|
RPM_DIST_VERSION=0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Starting to Fedora 29, python2 is on a deprecation path. Let's move to python3 then.
|
# Handle legacy RPM distributions
|
||||||
# RHEL 8 also uses python3 by default.
|
if [ "$PYVER" -eq 26 ]; then
|
||||||
if [ "$RPM_DIST_NAME" = "fedora" -a "$RPM_DIST_VERSION" -ge 29 -o "$PYVER" -eq 26 ]; then
|
# Check if an automated bootstrap can be achieved on this system.
|
||||||
RPM_USE_PYTHON_3=1
|
if ! Python36SclIsAvailable; then
|
||||||
elif [ "$RPM_DIST_NAME" = "rhel" -a "$RPM_DIST_VERSION" -ge 8 ]; then
|
INTERACTIVE_BOOTSTRAP=1
|
||||||
RPM_USE_PYTHON_3=1
|
fi
|
||||||
elif [ "$RPM_DIST_NAME" = "centos" -a "$RPM_DIST_VERSION" -ge 8 ]; then
|
|
||||||
RPM_USE_PYTHON_3=1
|
|
||||||
else
|
|
||||||
RPM_USE_PYTHON_3=0
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "$RPM_USE_PYTHON_3" = 1 ]; then
|
|
||||||
Bootstrap() {
|
Bootstrap() {
|
||||||
BootstrapMessage "RedHat-based OSes that will use Python3"
|
BootstrapMessage "Legacy RedHat-based OSes that will use Python3"
|
||||||
BootstrapRpmPython3
|
BootstrapRpmPython3Legacy
|
||||||
}
|
}
|
||||||
USE_PYTHON_3=1
|
USE_PYTHON_3=1
|
||||||
BOOTSTRAP_VERSION="BootstrapRpmPython3 $BOOTSTRAP_RPM_PYTHON3_VERSION"
|
BOOTSTRAP_VERSION="BootstrapRpmPython3Legacy $BOOTSTRAP_RPM_PYTHON3_LEGACY_VERSION"
|
||||||
|
|
||||||
|
# Try now to enable SCL rh-python36 for systems already bootstrapped
|
||||||
|
# NB: EnablePython36SCL has been defined along with BootstrapRpmPython3Legacy in certbot-auto
|
||||||
|
EnablePython36SCL
|
||||||
else
|
else
|
||||||
Bootstrap() {
|
# Starting to Fedora 29, python2 is on a deprecation path. Let's move to python3 then.
|
||||||
BootstrapMessage "RedHat-based OSes"
|
# RHEL 8 also uses python3 by default.
|
||||||
BootstrapRpmCommon
|
if [ "$RPM_DIST_NAME" = "fedora" -a "$RPM_DIST_VERSION" -ge 29 ]; then
|
||||||
}
|
RPM_USE_PYTHON_3=1
|
||||||
BOOTSTRAP_VERSION="BootstrapRpmCommon $BOOTSTRAP_RPM_COMMON_VERSION"
|
elif [ "$RPM_DIST_NAME" = "rhel" -a "$RPM_DIST_VERSION" -ge 8 ]; then
|
||||||
|
RPM_USE_PYTHON_3=1
|
||||||
|
elif [ "$RPM_DIST_NAME" = "centos" -a "$RPM_DIST_VERSION" -ge 8 ]; then
|
||||||
|
RPM_USE_PYTHON_3=1
|
||||||
|
else
|
||||||
|
RPM_USE_PYTHON_3=0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$RPM_USE_PYTHON_3" = 1 ]; then
|
||||||
|
Bootstrap() {
|
||||||
|
BootstrapMessage "RedHat-based OSes that will use Python3"
|
||||||
|
BootstrapRpmPython3
|
||||||
|
}
|
||||||
|
USE_PYTHON_3=1
|
||||||
|
BOOTSTRAP_VERSION="BootstrapRpmPython3 $BOOTSTRAP_RPM_PYTHON3_VERSION"
|
||||||
|
else
|
||||||
|
Bootstrap() {
|
||||||
|
BootstrapMessage "RedHat-based OSes"
|
||||||
|
BootstrapRpmCommon
|
||||||
|
}
|
||||||
|
BOOTSTRAP_VERSION="BootstrapRpmCommon $BOOTSTRAP_RPM_COMMON_VERSION"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
LE_PYTHON="$prev_le_python"
|
LE_PYTHON="$prev_le_python"
|
||||||
@@ -1078,8 +1156,15 @@ if [ "$1" = "--le-auto-phase2" ]; then
|
|||||||
# If the selected Bootstrap function isn't a noop and it differs from the
|
# If the selected Bootstrap function isn't a noop and it differs from the
|
||||||
# previously used version
|
# previously used version
|
||||||
if [ -n "$BOOTSTRAP_VERSION" -a "$BOOTSTRAP_VERSION" != "$PREV_BOOTSTRAP_VERSION" ]; then
|
if [ -n "$BOOTSTRAP_VERSION" -a "$BOOTSTRAP_VERSION" != "$PREV_BOOTSTRAP_VERSION" ]; then
|
||||||
# if non-interactive mode or stdin and stdout are connected to a terminal
|
# Check if we can rebootstrap without manual user intervention: this requires that
|
||||||
if [ \( "$NONINTERACTIVE" = 1 \) -o \( \( -t 0 \) -a \( -t 1 \) \) ]; then
|
# certbot-auto is in non-interactive mode AND selected bootstrap does not claim to
|
||||||
|
# require a manual user intervention.
|
||||||
|
if [ "$NONINTERACTIVE" = 1 -a "$INTERACTIVE_BOOTSTRAP" != 1 ]; then
|
||||||
|
CAN_REBOOTSTRAP=1
|
||||||
|
fi
|
||||||
|
# Check if rebootstrap can be done non-interactively and current shell is non-interactive
|
||||||
|
# (true if stdin and stdout are not attached to a terminal).
|
||||||
|
if [ \( "$CAN_REBOOTSTRAP" = 1 \) -o \( \( -t 0 \) -a \( -t 1 \) \) ]; then
|
||||||
if [ -d "$VENV_PATH" ]; then
|
if [ -d "$VENV_PATH" ]; then
|
||||||
rm -rf "$VENV_PATH"
|
rm -rf "$VENV_PATH"
|
||||||
fi
|
fi
|
||||||
@@ -1090,12 +1175,21 @@ if [ "$1" = "--le-auto-phase2" ]; then
|
|||||||
ln -s "$VENV_PATH" "$OLD_VENV_PATH"
|
ln -s "$VENV_PATH" "$OLD_VENV_PATH"
|
||||||
fi
|
fi
|
||||||
RerunWithArgs "$@"
|
RerunWithArgs "$@"
|
||||||
|
# Otherwise bootstrap needs to be done manually by the user.
|
||||||
else
|
else
|
||||||
error "Skipping upgrade because new OS dependencies may need to be installed."
|
# If it is because bootstrapping is interactive, --non-interactive will be of no use.
|
||||||
error
|
if [ "$INTERACTIVE_BOOTSTRAP" = 1 ]; then
|
||||||
error "To upgrade to a newer version, please run this script again manually so you can"
|
error "Skipping upgrade because new OS dependencies may need to be installed."
|
||||||
error "approve changes or with --non-interactive on the command line to automatically"
|
error "This requires manual user intervention: please run this script again manually."
|
||||||
error "install any required packages."
|
# If this is because of the environment (eg. non interactive shell without
|
||||||
|
# --non-interactive flag set), help the user in that direction.
|
||||||
|
else
|
||||||
|
error "Skipping upgrade because new OS dependencies may need to be installed."
|
||||||
|
error
|
||||||
|
error "To upgrade to a newer version, please run this script again manually so you can"
|
||||||
|
error "approve changes or with --non-interactive on the command line to automatically"
|
||||||
|
error "install any required packages."
|
||||||
|
fi
|
||||||
# Set INSTALLED_VERSION to be the same so we don't update the venv
|
# Set INSTALLED_VERSION to be the same so we don't update the venv
|
||||||
INSTALLED_VERSION="$LE_AUTO_VERSION"
|
INSTALLED_VERSION="$LE_AUTO_VERSION"
|
||||||
# Continue to use OLD_VENV_PATH if the new venv doesn't exist
|
# Continue to use OLD_VENV_PATH if the new venv doesn't exist
|
||||||
|
|||||||
@@ -256,20 +256,28 @@ DeprecationBootstrap() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
MIN_PYTHON_VERSION="2.7"
|
MIN_PYTHON_2_VERSION="2.7"
|
||||||
MIN_PYVER=$(echo "$MIN_PYTHON_VERSION" | sed 's/\.//')
|
MIN_PYVER2=$(echo "$MIN_PYTHON_2_VERSION" | sed 's/\.//')
|
||||||
|
MIN_PYTHON_3_VERSION="3.5"
|
||||||
|
MIN_PYVER3=$(echo "$MIN_PYTHON_3_VERSION" | sed 's/\.//')
|
||||||
# Sets LE_PYTHON to Python version string and PYVER to the first two
|
# Sets LE_PYTHON to Python version string and PYVER to the first two
|
||||||
# digits of the python version
|
# digits of the python version.
|
||||||
|
# MIN_PYVER and MIN_PYTHON_VERSION are also set by this function, and their
|
||||||
|
# values depend on if we try to use Python 3 or Python 2.
|
||||||
DeterminePythonVersion() {
|
DeterminePythonVersion() {
|
||||||
# Arguments: "NOCRASH" if we shouldn't crash if we don't find a good python
|
# Arguments: "NOCRASH" if we shouldn't crash if we don't find a good python
|
||||||
#
|
#
|
||||||
# If no Python is found, PYVER is set to 0.
|
# If no Python is found, PYVER is set to 0.
|
||||||
if [ "$USE_PYTHON_3" = 1 ]; then
|
if [ "$USE_PYTHON_3" = 1 ]; then
|
||||||
|
MIN_PYVER=$MIN_PYVER3
|
||||||
|
MIN_PYTHON_VERSION=$MIN_PYTHON_3_VERSION
|
||||||
for LE_PYTHON in "$LE_PYTHON" python3; do
|
for LE_PYTHON in "$LE_PYTHON" python3; do
|
||||||
# Break (while keeping the LE_PYTHON value) if found.
|
# Break (while keeping the LE_PYTHON value) if found.
|
||||||
$EXISTS "$LE_PYTHON" > /dev/null && break
|
$EXISTS "$LE_PYTHON" > /dev/null && break
|
||||||
done
|
done
|
||||||
else
|
else
|
||||||
|
MIN_PYVER=$MIN_PYVER2
|
||||||
|
MIN_PYTHON_VERSION=$MIN_PYTHON_2_VERSION
|
||||||
for LE_PYTHON in "$LE_PYTHON" python2.7 python27 python2 python; do
|
for LE_PYTHON in "$LE_PYTHON" python2.7 python27 python2 python; do
|
||||||
# Break (while keeping the LE_PYTHON value) if found.
|
# Break (while keeping the LE_PYTHON value) if found.
|
||||||
$EXISTS "$LE_PYTHON" > /dev/null && break
|
$EXISTS "$LE_PYTHON" > /dev/null && break
|
||||||
@@ -285,7 +293,7 @@ DeterminePythonVersion() {
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
PYVER=`"$LE_PYTHON" -V 2>&1 | cut -d" " -f 2 | cut -d. -f1,2 | sed 's/\.//'`
|
PYVER=$("$LE_PYTHON" -V 2>&1 | cut -d" " -f 2 | cut -d. -f1,2 | sed 's/\.//')
|
||||||
if [ "$PYVER" -lt "$MIN_PYVER" ]; then
|
if [ "$PYVER" -lt "$MIN_PYVER" ]; then
|
||||||
if [ "$1" != "NOCRASH" ]; then
|
if [ "$1" != "NOCRASH" ]; then
|
||||||
error "You have an ancient version of Python entombed in your operating system..."
|
error "You have an ancient version of Python entombed in your operating system..."
|
||||||
@@ -298,6 +306,7 @@ DeterminePythonVersion() {
|
|||||||
{{ bootstrappers/deb_common.sh }}
|
{{ bootstrappers/deb_common.sh }}
|
||||||
{{ bootstrappers/rpm_common_base.sh }}
|
{{ bootstrappers/rpm_common_base.sh }}
|
||||||
{{ bootstrappers/rpm_common.sh }}
|
{{ bootstrappers/rpm_common.sh }}
|
||||||
|
{{ bootstrappers/rpm_python3_legacy.sh }}
|
||||||
{{ bootstrappers/rpm_python3.sh }}
|
{{ bootstrappers/rpm_python3.sh }}
|
||||||
{{ bootstrappers/suse_common.sh }}
|
{{ bootstrappers/suse_common.sh }}
|
||||||
{{ bootstrappers/arch_common.sh }}
|
{{ bootstrappers/arch_common.sh }}
|
||||||
@@ -344,31 +353,50 @@ elif [ -f /etc/redhat-release ]; then
|
|||||||
RPM_DIST_VERSION=0
|
RPM_DIST_VERSION=0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Starting to Fedora 29, python2 is on a deprecation path. Let's move to python3 then.
|
# Handle legacy RPM distributions
|
||||||
# RHEL 8 also uses python3 by default.
|
if [ "$PYVER" -eq 26 ]; then
|
||||||
if [ "$RPM_DIST_NAME" = "fedora" -a "$RPM_DIST_VERSION" -ge 29 -o "$PYVER" -eq 26 ]; then
|
# Check if an automated bootstrap can be achieved on this system.
|
||||||
RPM_USE_PYTHON_3=1
|
if ! Python36SclIsAvailable; then
|
||||||
elif [ "$RPM_DIST_NAME" = "rhel" -a "$RPM_DIST_VERSION" -ge 8 ]; then
|
INTERACTIVE_BOOTSTRAP=1
|
||||||
RPM_USE_PYTHON_3=1
|
fi
|
||||||
elif [ "$RPM_DIST_NAME" = "centos" -a "$RPM_DIST_VERSION" -ge 8 ]; then
|
|
||||||
RPM_USE_PYTHON_3=1
|
|
||||||
else
|
|
||||||
RPM_USE_PYTHON_3=0
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "$RPM_USE_PYTHON_3" = 1 ]; then
|
|
||||||
Bootstrap() {
|
Bootstrap() {
|
||||||
BootstrapMessage "RedHat-based OSes that will use Python3"
|
BootstrapMessage "Legacy RedHat-based OSes that will use Python3"
|
||||||
BootstrapRpmPython3
|
BootstrapRpmPython3Legacy
|
||||||
}
|
}
|
||||||
USE_PYTHON_3=1
|
USE_PYTHON_3=1
|
||||||
BOOTSTRAP_VERSION="BootstrapRpmPython3 $BOOTSTRAP_RPM_PYTHON3_VERSION"
|
BOOTSTRAP_VERSION="BootstrapRpmPython3Legacy $BOOTSTRAP_RPM_PYTHON3_LEGACY_VERSION"
|
||||||
|
|
||||||
|
# Try now to enable SCL rh-python36 for systems already bootstrapped
|
||||||
|
# NB: EnablePython36SCL has been defined along with BootstrapRpmPython3Legacy in certbot-auto
|
||||||
|
EnablePython36SCL
|
||||||
else
|
else
|
||||||
Bootstrap() {
|
# Starting to Fedora 29, python2 is on a deprecation path. Let's move to python3 then.
|
||||||
BootstrapMessage "RedHat-based OSes"
|
# RHEL 8 also uses python3 by default.
|
||||||
BootstrapRpmCommon
|
if [ "$RPM_DIST_NAME" = "fedora" -a "$RPM_DIST_VERSION" -ge 29 ]; then
|
||||||
}
|
RPM_USE_PYTHON_3=1
|
||||||
BOOTSTRAP_VERSION="BootstrapRpmCommon $BOOTSTRAP_RPM_COMMON_VERSION"
|
elif [ "$RPM_DIST_NAME" = "rhel" -a "$RPM_DIST_VERSION" -ge 8 ]; then
|
||||||
|
RPM_USE_PYTHON_3=1
|
||||||
|
elif [ "$RPM_DIST_NAME" = "centos" -a "$RPM_DIST_VERSION" -ge 8 ]; then
|
||||||
|
RPM_USE_PYTHON_3=1
|
||||||
|
else
|
||||||
|
RPM_USE_PYTHON_3=0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$RPM_USE_PYTHON_3" = 1 ]; then
|
||||||
|
Bootstrap() {
|
||||||
|
BootstrapMessage "RedHat-based OSes that will use Python3"
|
||||||
|
BootstrapRpmPython3
|
||||||
|
}
|
||||||
|
USE_PYTHON_3=1
|
||||||
|
BOOTSTRAP_VERSION="BootstrapRpmPython3 $BOOTSTRAP_RPM_PYTHON3_VERSION"
|
||||||
|
else
|
||||||
|
Bootstrap() {
|
||||||
|
BootstrapMessage "RedHat-based OSes"
|
||||||
|
BootstrapRpmCommon
|
||||||
|
}
|
||||||
|
BOOTSTRAP_VERSION="BootstrapRpmCommon $BOOTSTRAP_RPM_COMMON_VERSION"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
LE_PYTHON="$prev_le_python"
|
LE_PYTHON="$prev_le_python"
|
||||||
@@ -545,8 +573,15 @@ if [ "$1" = "--le-auto-phase2" ]; then
|
|||||||
# If the selected Bootstrap function isn't a noop and it differs from the
|
# If the selected Bootstrap function isn't a noop and it differs from the
|
||||||
# previously used version
|
# previously used version
|
||||||
if [ -n "$BOOTSTRAP_VERSION" -a "$BOOTSTRAP_VERSION" != "$PREV_BOOTSTRAP_VERSION" ]; then
|
if [ -n "$BOOTSTRAP_VERSION" -a "$BOOTSTRAP_VERSION" != "$PREV_BOOTSTRAP_VERSION" ]; then
|
||||||
# if non-interactive mode or stdin and stdout are connected to a terminal
|
# Check if we can rebootstrap without manual user intervention: this requires that
|
||||||
if [ \( "$NONINTERACTIVE" = 1 \) -o \( \( -t 0 \) -a \( -t 1 \) \) ]; then
|
# certbot-auto is in non-interactive mode AND selected bootstrap does not claim to
|
||||||
|
# require a manual user intervention.
|
||||||
|
if [ "$NONINTERACTIVE" = 1 -a "$INTERACTIVE_BOOTSTRAP" != 1 ]; then
|
||||||
|
CAN_REBOOTSTRAP=1
|
||||||
|
fi
|
||||||
|
# Check if rebootstrap can be done non-interactively and current shell is non-interactive
|
||||||
|
# (true if stdin and stdout are not attached to a terminal).
|
||||||
|
if [ \( "$CAN_REBOOTSTRAP" = 1 \) -o \( \( -t 0 \) -a \( -t 1 \) \) ]; then
|
||||||
if [ -d "$VENV_PATH" ]; then
|
if [ -d "$VENV_PATH" ]; then
|
||||||
rm -rf "$VENV_PATH"
|
rm -rf "$VENV_PATH"
|
||||||
fi
|
fi
|
||||||
@@ -557,12 +592,21 @@ if [ "$1" = "--le-auto-phase2" ]; then
|
|||||||
ln -s "$VENV_PATH" "$OLD_VENV_PATH"
|
ln -s "$VENV_PATH" "$OLD_VENV_PATH"
|
||||||
fi
|
fi
|
||||||
RerunWithArgs "$@"
|
RerunWithArgs "$@"
|
||||||
|
# Otherwise bootstrap needs to be done manually by the user.
|
||||||
else
|
else
|
||||||
error "Skipping upgrade because new OS dependencies may need to be installed."
|
# If it is because bootstrapping is interactive, --non-interactive will be of no use.
|
||||||
error
|
if [ "$INTERACTIVE_BOOTSTRAP" = 1 ]; then
|
||||||
error "To upgrade to a newer version, please run this script again manually so you can"
|
error "Skipping upgrade because new OS dependencies may need to be installed."
|
||||||
error "approve changes or with --non-interactive on the command line to automatically"
|
error "This requires manual user intervention: please run this script again manually."
|
||||||
error "install any required packages."
|
# If this is because of the environment (eg. non interactive shell without
|
||||||
|
# --non-interactive flag set), help the user in that direction.
|
||||||
|
else
|
||||||
|
error "Skipping upgrade because new OS dependencies may need to be installed."
|
||||||
|
error
|
||||||
|
error "To upgrade to a newer version, please run this script again manually so you can"
|
||||||
|
error "approve changes or with --non-interactive on the command line to automatically"
|
||||||
|
error "install any required packages."
|
||||||
|
fi
|
||||||
# Set INSTALLED_VERSION to be the same so we don't update the venv
|
# Set INSTALLED_VERSION to be the same so we don't update the venv
|
||||||
INSTALLED_VERSION="$LE_AUTO_VERSION"
|
INSTALLED_VERSION="$LE_AUTO_VERSION"
|
||||||
# Continue to use OLD_VENV_PATH if the new venv doesn't exist
|
# Continue to use OLD_VENV_PATH if the new venv doesn't exist
|
||||||
|
|||||||
@@ -3,7 +3,9 @@
|
|||||||
|
|
||||||
# Sets TOOL to the name of the package manager
|
# Sets TOOL to the name of the package manager
|
||||||
# Sets appropriate values for YES_FLAG and QUIET_FLAG based on $ASSUME_YES and $QUIET_FLAG.
|
# Sets appropriate values for YES_FLAG and QUIET_FLAG based on $ASSUME_YES and $QUIET_FLAG.
|
||||||
# Enables EPEL if applicable and possible.
|
# Note: this function is called both while selecting the bootstrap scripts and
|
||||||
|
# during the actual bootstrap. Some things like prompting to user can be done in the latter
|
||||||
|
# case, but not in the former one.
|
||||||
InitializeRPMCommonBase() {
|
InitializeRPMCommonBase() {
|
||||||
if type dnf 2>/dev/null
|
if type dnf 2>/dev/null
|
||||||
then
|
then
|
||||||
@@ -23,26 +25,6 @@ InitializeRPMCommonBase() {
|
|||||||
if [ "$QUIET" = 1 ]; then
|
if [ "$QUIET" = 1 ]; then
|
||||||
QUIET_FLAG='--quiet'
|
QUIET_FLAG='--quiet'
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if ! $TOOL list *virtualenv >/dev/null 2>&1; then
|
|
||||||
echo "To use Certbot, packages from the EPEL repository need to be installed."
|
|
||||||
if ! $TOOL list epel-release >/dev/null 2>&1; then
|
|
||||||
error "Enable the EPEL repository and try running Certbot again."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
if [ "$ASSUME_YES" = 1 ]; then
|
|
||||||
/bin/echo -n "Enabling the EPEL repository in 3 seconds..."
|
|
||||||
sleep 1s
|
|
||||||
/bin/echo -ne "\e[0K\rEnabling the EPEL repository in 2 seconds..."
|
|
||||||
sleep 1s
|
|
||||||
/bin/echo -e "\e[0K\rEnabling the EPEL repository in 1 second..."
|
|
||||||
sleep 1s
|
|
||||||
fi
|
|
||||||
if ! $TOOL install $YES_FLAG $QUIET_FLAG epel-release; then
|
|
||||||
error "Could not enable EPEL. Aborting bootstrap!"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
|
|
||||||
BootstrapRpmCommonBase() {
|
BootstrapRpmCommonBase() {
|
||||||
|
|||||||
@@ -4,7 +4,6 @@ BOOTSTRAP_RPM_PYTHON3_VERSION=1
|
|||||||
|
|
||||||
BootstrapRpmPython3() {
|
BootstrapRpmPython3() {
|
||||||
# Tested with:
|
# Tested with:
|
||||||
# - CentOS 6
|
|
||||||
# - Fedora 29
|
# - Fedora 29
|
||||||
|
|
||||||
InitializeRPMCommonBase
|
InitializeRPMCommonBase
|
||||||
@@ -15,12 +14,6 @@ BootstrapRpmPython3() {
|
|||||||
python3-virtualenv
|
python3-virtualenv
|
||||||
python3-devel
|
python3-devel
|
||||||
"
|
"
|
||||||
# EPEL uses python34
|
|
||||||
elif $TOOL list python34 >/dev/null 2>&1; then
|
|
||||||
python_pkgs="python34
|
|
||||||
python34-devel
|
|
||||||
python34-tools
|
|
||||||
"
|
|
||||||
else
|
else
|
||||||
error "No supported Python package available to install. Aborting bootstrap!"
|
error "No supported Python package available to install. Aborting bootstrap!"
|
||||||
exit 1
|
exit 1
|
||||||
|
|||||||
@@ -0,0 +1,75 @@
|
|||||||
|
# If new packages are installed by BootstrapRpmPython3 below, this version
|
||||||
|
# number must be increased.
|
||||||
|
BOOTSTRAP_RPM_PYTHON3_LEGACY_VERSION=1
|
||||||
|
|
||||||
|
# Checks if rh-python36 can be installed.
|
||||||
|
Python36SclIsAvailable() {
|
||||||
|
InitializeRPMCommonBase >/dev/null 2>&1;
|
||||||
|
|
||||||
|
if "${TOOL}" list rh-python36 >/dev/null 2>&1; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
if "${TOOL}" list centos-release-scl >/dev/null 2>&1; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# Try to enable rh-python36 from SCL if it is necessary and possible.
|
||||||
|
EnablePython36SCL() {
|
||||||
|
if "$EXISTS" python3.6 > /dev/null 2> /dev/null; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
if ! scl --list 2>/dev/null | grep -q rh-python36; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
set +e
|
||||||
|
. scl_source enable rh-python36
|
||||||
|
set -e
|
||||||
|
}
|
||||||
|
|
||||||
|
# This bootstrap concerns old RedHat-based distributions that do not ship by default
|
||||||
|
# with Python 2.7, but only Python 2.6. We bootstrap them by enabling SCL and installing
|
||||||
|
# Python 3.6. Some of these distributions are: CentOS/RHEL/OL/SL 6.
|
||||||
|
BootstrapRpmPython3Legacy() {
|
||||||
|
# Tested with:
|
||||||
|
# - CentOS 6
|
||||||
|
|
||||||
|
InitializeRPMCommonBase
|
||||||
|
|
||||||
|
if ! "${TOOL}" list rh-python36 >/dev/null 2>&1; then
|
||||||
|
echo "To use Certbot on this operating system, packages from the SCL repository need to be installed."
|
||||||
|
if ! "${TOOL}" list centos-release-scl >/dev/null 2>&1; then
|
||||||
|
error "Enable the SCL repository and try running Certbot again."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
if [ "${ASSUME_YES}" = 1 ]; then
|
||||||
|
/bin/echo -n "Enabling the SCL repository in 3 seconds... (Press Ctrl-C to cancel)"
|
||||||
|
sleep 1s
|
||||||
|
/bin/echo -ne "\e[0K\rEnabling the SCL repository in 2 seconds... (Press Ctrl-C to cancel)"
|
||||||
|
sleep 1s
|
||||||
|
/bin/echo -e "\e[0K\rEnabling the SCL repository in 1 second... (Press Ctrl-C to cancel)"
|
||||||
|
sleep 1s
|
||||||
|
fi
|
||||||
|
if ! "${TOOL}" install "${YES_FLAG}" "${QUIET_FLAG}" centos-release-scl; then
|
||||||
|
error "Could not enable SCL. Aborting bootstrap!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# CentOS 6 must use rh-python36 from SCL
|
||||||
|
if "${TOOL}" list rh-python36 >/dev/null 2>&1; then
|
||||||
|
python_pkgs="rh-python36-python
|
||||||
|
rh-python36-python-virtualenv
|
||||||
|
rh-python36-python-devel
|
||||||
|
"
|
||||||
|
else
|
||||||
|
error "No supported Python package available to install. Aborting bootstrap!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
BootstrapRpmCommonBase "${python_pkgs}"
|
||||||
|
|
||||||
|
# Enable SCL rh-python36 after bootstrapping.
|
||||||
|
EnablePython36SCL
|
||||||
|
}
|
||||||
@@ -1,81 +1,140 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
# Start by making sure your system is up-to-date:
|
# Start by making sure your system is up-to-date:
|
||||||
yum update -y > /dev/null
|
yum update -y >/dev/null
|
||||||
yum install -y centos-release-scl > /dev/null
|
yum install -y centos-release-scl >/dev/null
|
||||||
yum install -y python27 > /dev/null 2> /dev/null
|
yum install -y python27 >/dev/null 2>/dev/null
|
||||||
|
|
||||||
|
LE_AUTO_PY_34="certbot/letsencrypt-auto-source/letsencrypt-auto_py_34"
|
||||||
LE_AUTO="certbot/letsencrypt-auto-source/letsencrypt-auto"
|
LE_AUTO="certbot/letsencrypt-auto-source/letsencrypt-auto"
|
||||||
|
|
||||||
|
# Last version of certbot-auto that was bootstraping Python 3.4 for CentOS 6 users
|
||||||
|
INITIAL_CERTBOT_VERSION_PY34="certbot 0.38.0"
|
||||||
|
|
||||||
# we're going to modify env variables, so do this in a subshell
|
# we're going to modify env variables, so do this in a subshell
|
||||||
(
|
(
|
||||||
source /opt/rh/python27/enable
|
. scl_source enable python27
|
||||||
|
|
||||||
# ensure python 3 isn't installed
|
# ensure python 3 isn't installed
|
||||||
python3 --version 2> /dev/null
|
python3 --version >/dev/null 2>/dev/null
|
||||||
RESULT=$?
|
RESULT=$?
|
||||||
if [ $RESULT -eq 0 ]; then
|
if [ $RESULT -eq 0 ]; then
|
||||||
error "Python3 is already installed."
|
echo "ERROR: Python3 is already installed."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# ensure python2.7 is available
|
# ensure python2.7 is available
|
||||||
python2.7 --version 2> /dev/null
|
python2.7 --version >/dev/null 2>/dev/null
|
||||||
RESULT=$?
|
RESULT=$?
|
||||||
if [ $RESULT -ne 0 ]; then
|
if [ $RESULT -ne 0 ]; then
|
||||||
error "Python3 is not available."
|
echo "ERROR: Python2.7 is not available."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# bootstrap, but don't install python 3.
|
# bootstrap, but don't install python 3.
|
||||||
"$LE_AUTO" --no-self-upgrade -n > /dev/null 2> /dev/null
|
"$LE_AUTO" --no-self-upgrade -n >/dev/null 2>/dev/null
|
||||||
|
|
||||||
# ensure python 3 isn't installed
|
# ensure python 3 isn't installed
|
||||||
python3 --version 2> /dev/null
|
python3 --version >/dev/null 2>/dev/null
|
||||||
RESULT=$?
|
RESULT=$?
|
||||||
if [ $RESULT -eq 0 ]; then
|
if [ $RESULT -eq 0 ]; then
|
||||||
error "letsencrypt-auto installed Python3 even though Python2.7 is present."
|
echo "ERROR: letsencrypt-auto installed Python3 even though Python2.7 is present."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo ""
|
echo "PASSED: Did not upgrade to Python3 when Python2.7 is present."
|
||||||
echo "PASSED: Did not upgrade to Python3 when Python2.7 is present."
|
|
||||||
)
|
)
|
||||||
|
|
||||||
# ensure python2.7 isn't available
|
# ensure python2.7 isn't available
|
||||||
python2.7 --version 2> /dev/null
|
python2.7 --version >/dev/null 2>/dev/null
|
||||||
RESULT=$?
|
RESULT=$?
|
||||||
if [ $RESULT -eq 0 ]; then
|
if [ $RESULT -eq 0 ]; then
|
||||||
error "Python2.7 is still available."
|
error "ERROR: Python2.7 is still available."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Skip self upgrade due to Python 3 not being available.
|
# Skip self upgrade due to Python 3 not being available.
|
||||||
if ! "$LE_AUTO" 2>&1 | grep -q "WARNING: couldn't find Python"; then
|
if ! "$LE_AUTO" 2>&1 | grep -q "WARNING: couldn't find Python"; then
|
||||||
echo "Python upgrade failure warning not printed!"
|
echo "ERROR: Python upgrade failure warning not printed!"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# bootstrap, this time installing python3
|
# bootstrap from the old letsencrypt-auto, this time installing python3.4
|
||||||
"$LE_AUTO" --no-self-upgrade -n > /dev/null 2> /dev/null
|
"$LE_AUTO_PY_34" --no-self-upgrade -n >/dev/null 2>/dev/null
|
||||||
|
|
||||||
# ensure python 3 is installed
|
# ensure python 3.4 is installed
|
||||||
python3 --version > /dev/null
|
python3.4 --version >/dev/null 2>/dev/null
|
||||||
RESULT=$?
|
RESULT=$?
|
||||||
if [ $RESULT -ne 0 ]; then
|
if [ $RESULT -ne 0 ]; then
|
||||||
error "letsencrypt-auto failed to install Python3 when only Python2.6 is present."
|
echo "ERROR: letsencrypt-auto failed to install Python3.4 using letsencrypt-auto < 0.37.0 when only Python2.6 is present."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "PASSED: Successfully upgraded to Python3 when only Python2.6 is present."
|
echo "PASSED: Successfully upgraded to Python3.4 using letsencrypt-auto < 0.37.0 when only Python2.6 is present."
|
||||||
echo ""
|
|
||||||
|
|
||||||
export VENV_PATH=$(mktemp -d)
|
# As "certbot-auto" (so without implicit --non-interactive flag set), check that the script
|
||||||
"$LE_AUTO" -n --no-bootstrap --no-self-upgrade --version >/dev/null 2>&1
|
# refuses to install SCL Python 3.6 when run in a non interactive shell (simulated here
|
||||||
if [ "$($VENV_PATH/bin/python -V 2>&1 | cut -d" " -f2 | cut -d. -f1)" != 3 ]; then
|
# using | tee /dev/null) if --non-interactive flag is not provided.
|
||||||
echo "Python 3 wasn't used with --no-bootstrap!"
|
cp "$LE_AUTO" /tmp/certbot-auto
|
||||||
|
# NB: Readline has an issue on all Python versions for CentOS 6, making `certbot --version`
|
||||||
|
# output an unprintable ASCII character on a new line at the end.
|
||||||
|
# So we take the second last line of the output.
|
||||||
|
version=$(/tmp/certbot-auto --version 2>/dev/null | tee /dev/null | tail -2 | head -1)
|
||||||
|
|
||||||
|
if [ "$version" != "$INITIAL_CERTBOT_VERSION_PY34" ]; then
|
||||||
|
echo "ERROR: certbot-auto upgraded certbot in a non-interactive shell with --non-interactive flag not set."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
unset VENV_PATH
|
|
||||||
|
echo "PASSED: certbot-auto did not upgrade certbot in a non-interactive shell with --non-interactive flag not set."
|
||||||
|
|
||||||
|
if [ -f /opt/rh/rh-python36/enable ]; then
|
||||||
|
echo "ERROR: certbot-auto installed Python3.6 in a non-interactive shell with --non-interactive flag not set."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "PASSED: certbot-auto did not install Python3.6 in a non-interactive shell with --non-interactive flag not set."
|
||||||
|
|
||||||
|
# now bootstrap from current letsencrypt-auto, that will install python3.6 from SCL
|
||||||
|
"$LE_AUTO" --no-self-upgrade -n >/dev/null 2>/dev/null
|
||||||
|
|
||||||
|
# Following test is exectued in a subshell, to not leak any environment variable
|
||||||
|
(
|
||||||
|
# enable SCL rh-python36
|
||||||
|
. scl_source enable rh-python36
|
||||||
|
|
||||||
|
# ensure python 3.6 is installed
|
||||||
|
python3.6 --version >/dev/null 2>/dev/null
|
||||||
|
RESULT=$?
|
||||||
|
if [ $RESULT -ne 0 ]; then
|
||||||
|
echo "ERROR: letsencrypt-auto failed to install Python3.6 using current letsencrypt-auto when only Python2.6/Python3.4 are present."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "PASSED: Successfully upgraded to Python3.6 using current letsencrypt-auto when only Python2.6/Python3.4 are present."
|
||||||
|
)
|
||||||
|
|
||||||
|
# Following test is exectued in a subshell, to not leak any environment variable
|
||||||
|
(
|
||||||
|
export VENV_PATH=$(mktemp -d)
|
||||||
|
"$LE_AUTO" -n --no-bootstrap --no-self-upgrade --version >/dev/null 2>&1
|
||||||
|
if [ "$($VENV_PATH/bin/python -V 2>&1 | cut -d" " -f2 | cut -d. -f1-2)" != "3.6" ]; then
|
||||||
|
echo "ERROR: Python 3.6 wasn't used with --no-bootstrap!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
)
|
||||||
|
|
||||||
|
# Following test is exectued in a subshell, to not leak any environment variable
|
||||||
|
(
|
||||||
|
# enable SCL rh-python36
|
||||||
|
. scl_source enable rh-python36
|
||||||
|
|
||||||
|
# ensure everything works fine with certbot-auto bootstrap when python 3.6 is already enabled
|
||||||
|
export VENV_PATH=$(mktemp -d)
|
||||||
|
if ! "$LE_AUTO" --no-self-upgrade -n --version >/dev/null 2>/dev/null; then
|
||||||
|
echo "ERROR: Certbot-auto broke when Python 3.6 SCL is already enabled."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
)
|
||||||
|
|
||||||
# test using python3
|
# test using python3
|
||||||
pytest -v -s certbot/letsencrypt-auto-source/tests
|
pytest -v -s certbot/letsencrypt-auto-source/tests
|
||||||
|
|||||||
85
letsencrypt-auto-source/tests/oraclelinux6_tests.sh
Normal file
85
letsencrypt-auto-source/tests/oraclelinux6_tests.sh
Normal file
@@ -0,0 +1,85 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -eo pipefail
|
||||||
|
# Start by making sure your system is up-to-date:
|
||||||
|
yum update -y >/dev/null
|
||||||
|
|
||||||
|
LE_AUTO_PY_34="certbot/letsencrypt-auto-source/letsencrypt-auto_py_34"
|
||||||
|
LE_AUTO="certbot/letsencrypt-auto-source/letsencrypt-auto"
|
||||||
|
|
||||||
|
# Apply installation instructions from official documentation:
|
||||||
|
# https://certbot.eff.org/lets-encrypt/centosrhel6-other
|
||||||
|
cp "$LE_AUTO" /usr/local/bin/certbot-auto
|
||||||
|
chown root /usr/local/bin/certbot-auto
|
||||||
|
chmod 0755 /usr/local/bin/certbot-auto
|
||||||
|
LE_AUTO=/usr/local/bin/certbot-auto
|
||||||
|
|
||||||
|
# Last version of certbot-auto that was bootstraping Python 3.4 for CentOS 6 users
|
||||||
|
INITIAL_CERTBOT_VERSION_PY34="certbot 0.38.0"
|
||||||
|
|
||||||
|
# Check bootstrap from current certbot-auto will fail, because SCL is not enabled.
|
||||||
|
set +o pipefail
|
||||||
|
if ! "$LE_AUTO" -n 2>&1 | grep -q "Enable the SCL repository and try running Certbot again."; then
|
||||||
|
echo "ERROR: Bootstrap was not aborted although SCL was not installed!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
set -o pipefail
|
||||||
|
|
||||||
|
echo "PASSED: Bootstrap was aborted since SCL was not installed."
|
||||||
|
|
||||||
|
# Bootstrap from the old letsencrypt-auto, Python 3.4 will be installed from EPEL.
|
||||||
|
"$LE_AUTO_PY_34" --no-self-upgrade -n --install-only >/dev/null 2>/dev/null
|
||||||
|
|
||||||
|
# Ensure Python 3.4 is installed
|
||||||
|
if ! command -v python3.4 &>/dev/null; then
|
||||||
|
echo "ERROR: old letsencrypt-auto failed to install Python3.4 using letsencrypt-auto < 0.37.0 when only Python2.6 is present."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "PASSED: Bootstrap from old letsencrypt-auto succeeded and installed Python 3.4"
|
||||||
|
|
||||||
|
# Expect certbot-auto to skip rebootstrapping with a warning since SCL is not installed.
|
||||||
|
if ! "$LE_AUTO" --non-interactive --version 2>&1 | grep -q "This requires manual user intervention"; then
|
||||||
|
echo "FAILED: Script certbot-auto managed to start Certbot in interactive shell while SCL is not enabled!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "PASSED: Script certbot-auto did not rebootstrap."
|
||||||
|
|
||||||
|
# NB: Readline has an issue on all Python versions for OL 6, making `certbot --version`
|
||||||
|
# output an unprintable ASCII character on a new line at the end.
|
||||||
|
# So we take the second last line of the output.
|
||||||
|
version=$($LE_AUTO --version 2>/dev/null | tail -2 | head -1)
|
||||||
|
|
||||||
|
if [ "$version" != "$INITIAL_CERTBOT_VERSION_PY34" ]; then
|
||||||
|
echo "ERROR: Script certbot-auto upgraded certbot in a non-interactive shell while SCL was not enabled."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "PASSED: Script certbot-auto did not upgrade certbot but started it successfully while SCL was not enabled."
|
||||||
|
|
||||||
|
# Enable SCL
|
||||||
|
yum install -y oracle-softwarecollection-release-el6 >/dev/null
|
||||||
|
|
||||||
|
# Expect certbot-auto to bootstrap successfully since SCL is available.
|
||||||
|
"$LE_AUTO" -n --version &>/dev/null
|
||||||
|
|
||||||
|
if [ "$(/opt/eff.org/certbot/venv/bin/python -V 2>&1 | cut -d" " -f2 | cut -d. -f1-2)" != "3.6" ]; then
|
||||||
|
echo "ERROR: Script certbot-auto failed to bootstrap and install Python 3.6 while SCL is available."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! /opt/eff.org/certbot/venv/bin/certbot --version > /dev/null 2> /dev/null; then
|
||||||
|
echo "ERROR: Script certbot-auto did not install certbot correctly while SCL is enabled."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "PASSED: Script certbot-auto correctly bootstraped Certbot using rh-python36 when SCL is available."
|
||||||
|
|
||||||
|
# Expect certbot-auto will be totally silent now that everything has been correctly boostraped.
|
||||||
|
OUTPUT_LEN=$("$LE_AUTO" --install-only --no-self-upgrade --quiet 2>&1 | wc -c)
|
||||||
|
if [ "$OUTPUT_LEN" != 0 ]; then
|
||||||
|
echo certbot-auto produced unexpected output!
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "PASSED: Script certbot-auto did not print anything in quiet mode."
|
||||||
@@ -117,6 +117,8 @@ if ! diff letsencrypt-auto letsencrypt-auto-source/letsencrypt-auto ; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$RUN_RHEL6_TESTS" = 1 ]; then
|
if [ "$RUN_RHEL6_TESTS" = 1 ]; then
|
||||||
|
# Add the SCL python release to PATH in order to resolve python3 command
|
||||||
|
PATH="/opt/rh/rh-python36/root/usr/bin:$PATH"
|
||||||
if ! command -v python3; then
|
if ! command -v python3; then
|
||||||
echo "Python3 wasn't properly installed"
|
echo "Python3 wasn't properly installed"
|
||||||
exit 1
|
exit 1
|
||||||
|
|||||||
@@ -1,8 +1,21 @@
|
|||||||
#!/bin/sh -xe
|
#!/bin/sh -xe
|
||||||
|
|
||||||
cd letsencrypt
|
cd letsencrypt
|
||||||
|
|
||||||
|
# If we're on a RHEL 6 based system, we can be confident Python is already
|
||||||
|
# installed because the package manager is written in Python.
|
||||||
|
if command -v python && [ $(python -V 2>&1 | cut -d" " -f 2 | cut -d. -f1,2 | sed 's/\.//') -eq 26 ]; then
|
||||||
|
# RHEL/CentOS 6 will need a special treatment, so we need to detect that environment
|
||||||
|
RUN_RHEL6_TESTS=1
|
||||||
|
fi
|
||||||
|
|
||||||
letsencrypt-auto-source/letsencrypt-auto --install-only -n --debug
|
letsencrypt-auto-source/letsencrypt-auto --install-only -n --debug
|
||||||
|
|
||||||
|
if [ "$RUN_RHEL6_TESTS" = 1 ]; then
|
||||||
|
# Enable the SCL Python 3.6 installed by letsencrypt-auto bootstrap
|
||||||
|
PATH="/opt/rh/rh-python36/root/usr/bin:$PATH"
|
||||||
|
fi
|
||||||
|
|
||||||
PLUGINS="certbot-apache certbot-nginx"
|
PLUGINS="certbot-apache certbot-nginx"
|
||||||
PYTHON_MAJOR_VERSION=$(/opt/eff.org/certbot/venv/bin/python --version 2>&1 | cut -d" " -f 2 | cut -d. -f1)
|
PYTHON_MAJOR_VERSION=$(/opt/eff.org/certbot/venv/bin/python --version 2>&1 | cut -d" " -f 2 | cut -d. -f1)
|
||||||
TEMP_DIR=$(mktemp -d)
|
TEMP_DIR=$(mktemp -d)
|
||||||
|
|||||||
12
tox.ini
12
tox.ini
@@ -206,7 +206,17 @@ passenv = DOCKER_*
|
|||||||
# At the moment, this tests under Python 2.6 only, as only that version is
|
# At the moment, this tests under Python 2.6 only, as only that version is
|
||||||
# readily available on the CentOS 6 Docker image.
|
# readily available on the CentOS 6 Docker image.
|
||||||
commands =
|
commands =
|
||||||
docker build -f letsencrypt-auto-source/Dockerfile.centos6 -t lea letsencrypt-auto-source
|
docker build -f letsencrypt-auto-source/Dockerfile.redhat6 --build-arg REDHAT_DIST_FLAVOR=centos -t lea letsencrypt-auto-source
|
||||||
|
docker run --rm -t -i lea
|
||||||
|
whitelist_externals =
|
||||||
|
docker
|
||||||
|
passenv = DOCKER_*
|
||||||
|
|
||||||
|
[testenv:le_auto_oraclelinux6]
|
||||||
|
# At the moment, this tests under Python 2.6 only, as only that version is
|
||||||
|
# readily available on the Oracle Linux 6 Docker image.
|
||||||
|
commands =
|
||||||
|
docker build -f letsencrypt-auto-source/Dockerfile.redhat6 --build-arg REDHAT_DIST_FLAVOR=oraclelinux -t lea letsencrypt-auto-source
|
||||||
docker run --rm -t -i lea
|
docker run --rm -t -i lea
|
||||||
whitelist_externals =
|
whitelist_externals =
|
||||||
docker
|
docker
|
||||||
|
|||||||
Reference in New Issue
Block a user