blob: 65b38ec7753370308f80594d68beb116d999cb1b [file] [log] [blame]
#!/bin/bash
# Copyright 2022 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
################################################################################
# This scripts installs OpenSSL of a given version and SHA256. If the version is
# not specified, DEFAULT_OPENSSL_VERSION is used; similarly the digest is by
# default DEFAULT_OPENSSL_SHA256.
#
# NOTEs:
# * If not running on Kokoro, this script will do nothing.
# * This script MUST be sourced to update the environment of the calling
# script.
# * If a custom version is passed, the corresponding digest should be passed
# too.
#
# Usage:
# source ./kokoro/testutils/install_openssl.sh [version] [sha256]
readonly DEFAULT_OPENSSL_VERSION="1.1.1l"
readonly DEFAULT_OPENSSL_SHA256="0b7a3e5e59c34827fe0c3a74b7ec8baef302b98fa80088d7f9153aa16fa76bd1"
readonly PLATFORM="$(uname | tr '[:upper:]' '[:lower:]')"
install_openssl() {
local openssl_version="${1:-${DEFAULT_OPENSSL_VERSION}}"
local openssl_sha256="${2:-${DEFAULT_OPENSSL_SHA256}}"
local openssl_name="openssl-${openssl_version}"
local openssl_archive="${openssl_name}.tar.gz"
local openssl_url="https://www.openssl.org/source/${openssl_archive}"
local openssl_tmpdir="$(mktemp -dt tink-openssl-${openssl_version}.XXXXXX)"
echo "Building and installing OpensSSL ${openssl_version} to \
${openssl_tmpdir}..."
(
cd "${openssl_tmpdir}"
curl -OLsS "${openssl_url}"
echo "${openssl_sha256} ${openssl_archive}" | sha256sum -c
tar xzf "${openssl_archive}"
cd "${openssl_name}"
./config --prefix="${openssl_tmpdir}" --openssldir="${openssl_tmpdir}"
if [[ "${PLATFORM}" == "darwin" ]]; then
make -j "$(sysctl -n hw.ncpu)" > /dev/null
else
make -j "$(nproc)" > /dev/null
fi
make install_sw > /dev/null
)
echo "Done"
export OPENSSL_ROOT_DIR="${openssl_tmpdir}"
export PATH="${openssl_tmpdir}/bin:${PATH}"
}
if [[ -n "${KOKORO_ARTIFACTS_DIR:-}" ]]; then
# If specifying the version, users must also specify the digest.
if (( "$#" == 1 )); then
echo \
"The SHA256 digest must be provided too when specifying OpenSSL's version" \
>&2
exit 1
fi
install_openssl "$@"
fi