#!/bin/sh # This script installs the Nix package manager on your system by # downloading a binary distribution and running its installer script # (which in turn creates and populates /nix). { # Prevent execution if this script was only partially downloaded oops() { echo "$0:" "$@" >&2 exit 1 } umask 0022 tmpDir="$(mktemp -d -t nix-binary-tarball-unpack.XXXXXXXXXX || \ oops "Can't create temporary directory for downloading the Nix binary tarball")" cleanup() { rm -rf "$tmpDir" } trap cleanup EXIT INT QUIT TERM require_util() { command -v "$1" > /dev/null 2>&1 || oops "you do not have '$1' installed, which I need to $2" } case "$(uname -s).$(uname -m)" in Linux.x86_64) system=x86_64-linux; hash=8e05e7604ad570e7f816ebfdb905d084a27ba2c2a606996860976fc07201fd20;; Linux.i?86) system=i686-linux; hash=fd0472d5b597e7d423ded1b36de893973f3f3aa6dcf3940054ecc4faead28908;; Linux.aarch64) system=aarch64-linux; hash=f8c29aac37df7216a5c75bde9c55ec5abbee848bcde62a86655a6b2b40bb86c2;; Darwin.x86_64) system=x86_64-darwin; hash=81cc3f2d5b06162b43a4695b37952ef569318d44c999558b8c54a925bab24ded;; # eventually maybe: system=arm64-darwin; hash=@binaryTarball_arm64-darwin@;; Darwin.arm64) system=x86_64-darwin; hash=81cc3f2d5b06162b43a4695b37952ef569318d44c999558b8c54a925bab24ded;; *) oops "sorry, there is no binary distribution of Nix for your platform";; esac url="https://releases.nixos.org/nix/nix-2.3.13/nix-2.3.13-$system.tar.xz" tarball="$tmpDir/$(basename "$tmpDir/nix-2.3.13-$system.tar.xz")" require_util curl "download the binary tarball" require_util tar "unpack the binary tarball" if [ "$(uname -s)" != "Darwin" ]; then require_util xz "unpack the binary tarball" fi echo "downloading Nix 2.3.13 binary tarball for $system from '$url' to '$tmpDir'..." curl -L "$url" -o "$tarball" || oops "failed to download '$url'" if command -v sha256sum > /dev/null 2>&1; then hash2="$(sha256sum -b "$tarball" | cut -c1-64)" elif command -v shasum > /dev/null 2>&1; then hash2="$(shasum -a 256 -b "$tarball" | cut -c1-64)" elif command -v openssl > /dev/null 2>&1; then hash2="$(openssl dgst -r -sha256 "$tarball" | cut -c1-64)" else oops "cannot verify the SHA-256 hash of '$url'; you need one of 'shasum', 'sha256sum', or 'openssl'" fi if [ "$hash" != "$hash2" ]; then oops "SHA-256 hash mismatch in '$url'; expected $hash, got $hash2" fi unpack=$tmpDir/unpack mkdir -p "$unpack" tar -xJf "$tarball" -C "$unpack" || oops "failed to unpack '$url'" script=$(echo "$unpack"/*/install) [ -e "$script" ] || oops "installation script is missing from the binary tarball!" "$script" "$@" } # End of wrapping