Skip to content

Commit

Permalink
download rustup-init without --proto to work around outdated centos6 …
Browse files Browse the repository at this point in the history
…curl version (pantsbuild#7615)

### Problem

Our CI is broken right now, failing to build `pants.pex` in our Linux shards running CentOS6, e.g. https://travis-ci.org/pantsbuild/pants/jobs/523606246. This appears to be an instance of an upstream rustup development, noted by @Eric-Arellano in rust-lang/rustup#1794 (comment). While there may be a solution which maintains the security that the rustup folks desire, this diff should work around the issue for now.

### Solution

- Download the backup script as per rust-lang/rustup#1794 (comment) if the original request fails.

### Result

CI should pass!
  • Loading branch information
cosmicexplorer authored Apr 24, 2019
1 parent c4b066b commit 7ba2e9c
Showing 1 changed file with 34 additions and 10 deletions.
44 changes: 34 additions & 10 deletions build-support/bin/native/bootstrap_rust.sh
Original file line number Diff line number Diff line change
Expand Up @@ -7,16 +7,38 @@ REPO_ROOT="$(cd "$(dirname "${BASH_SOURCE[0]}")" && cd ../../.. && pwd -P)"
# + fingerprint_data: Fingerprints the data on stdin.
source "${REPO_ROOT}/build-support/common.sh"

readonly rust_toolchain_root="${CACHE_ROOT}/rust"
rust_toolchain_root="${CACHE_ROOT}/rust"
export CARGO_HOME="${rust_toolchain_root}/cargo"
export RUSTUP_HOME="${rust_toolchain_root}/rustup"

readonly RUSTUP="${CARGO_HOME}/bin/rustup"
RUSTUP="${CARGO_HOME}/bin/rustup"

function cargo_bin() {
"${RUSTUP}" which cargo
}

# TODO(7288): RustUp tries to use a more secure protocol to avoid downgrade attacks. This, however,
# broke support for Centos6 (https://github.com/rust-lang/rustup.rs/issues/1794). So, we first try
# to use their recommend install, and downgrade to their workaround if necessary.
function curl_rustup_init_script_while_maybe_downgrading() {
if ! curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs; then
log "Initial 'curl' command failed, trying backup url..."
case "$(uname)" in
Darwin)
host_triple='x86_64-apple-darwin'
;;
Linux)
host_triple='x86_64-unknown-linux-gnu'
;;
*)
die "unrecognized platform $(uname) -- could not bootstrap rustup!"
;;
esac
full_rustup_backup_url="https://static.rust-lang.org/rustup/dist/${host_triple}/rustup-init"
curl -sSf "$full_rustup_backup_url"
fi
}

function bootstrap_rust() {
RUST_TOOLCHAIN="$(cat ${REPO_ROOT}/rust-toolchain)"
RUST_COMPONENTS=(
Expand All @@ -26,22 +48,24 @@ function bootstrap_rust() {
)

# Control a pants-specific rust toolchain.
if [[ ! -x "${RUSTUP}" ]]
then
if [[ ! -x "${RUSTUP}" ]]; then
log "A pants owned rustup installation could not be found, installing via the instructions at" \
"https://www.rustup.rs ..."
local -r rustup_tmp=$(mktemp -t pants.rustup.XXXXXX)
curl https://sh.rustup.rs -sSf > ${rustup_tmp}
local -r rustup_tmp_dir="$(mktemp -d)"
trap "rm -rf ${rustup_tmp_dir}" EXIT
# NB: The downloaded file here *must* be named `rustup-init`, or the workaround binary fails
# with "info: caused by: No such file or directory (os error 2)".
local -r rustup_init_destination="${rustup_tmp_dir}/rustup-init"
# NB: rustup installs itself into CARGO_HOME, but fetches toolchains into RUSTUP_HOME.
sh ${rustup_tmp} -y --no-modify-path --default-toolchain none 1>&2
rm -f ${rustup_tmp}
curl_rustup_init_script_while_maybe_downgrading > "$rustup_init_destination"
chmod +x "$rustup_init_destination"
"$rustup_init_destination" -y --no-modify-path --default-toolchain none 1>&2
fi

local -r cargo="${CARGO_HOME}/bin/cargo"
local -r cargo_components_fp=$(echo "${RUST_COMPONENTS[@]}" | fingerprint_data)
local -r cargo_versioned="cargo-${RUST_TOOLCHAIN}-${cargo_components_fp}"
if [[ ! -x "${rust_toolchain_root}/${cargo_versioned}" || "${RUST_TOOLCHAIN}" == "nightly" ]]
then
if [[ ! -x "${rust_toolchain_root}/${cargo_versioned}" || "${RUST_TOOLCHAIN}" == "nightly" ]]; then
# If rustup was already bootstrapped against a different toolchain in the past, freshen it and
# ensure the toolchain and components we need are installed.
"${RUSTUP}" self update
Expand Down

0 comments on commit 7ba2e9c

Please sign in to comment.