2019-09-10 11:50:09 +02:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
2020-03-02 12:18:01 +01:00
|
|
|
# Needed to fail on must_get_env()
|
|
|
|
set -e
|
|
|
|
|
2019-09-10 11:50:09 +02:00
|
|
|
GIT_ROOT=$(cd "${BASH_SOURCE%/*}" && git rev-parse --show-toplevel)
|
2020-03-02 12:18:01 +01:00
|
|
|
source "${GIT_ROOT}/scripts/colors.sh"
|
|
|
|
|
|
|
|
function must_get_env() {
|
|
|
|
declare -n VAR_NAME="$1"
|
|
|
|
if [[ -n "${VAR_NAME}" ]]; then
|
|
|
|
echo "${VAR_NAME}"
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
echo -e "${RED}No required env variable:${RST} ${BLD}${!VAR_NAME}${RST}" 1>&2
|
|
|
|
exit 1
|
|
|
|
}
|
2019-09-10 11:50:09 +02:00
|
|
|
|
2020-03-13 13:01:17 +01:00
|
|
|
function append_env_export() {
|
|
|
|
ENV_VAR_NAME=${1}
|
|
|
|
if [[ -n "${!ENV_VAR_NAME}" ]]; then
|
|
|
|
echo "export ${ENV_VAR_NAME}=\"${!ENV_VAR_NAME}\";" >> "${SECRETS_FILE_PATH}"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2020-01-13 15:28:40 +01:00
|
|
|
config=''
|
2020-01-08 15:41:07 +01:00
|
|
|
if [ -n "${STATUS_GO_SRC_OVERRIDE}" ]; then
|
2020-01-13 15:28:40 +01:00
|
|
|
config+="status-im.status-go.src-override=\"${STATUS_GO_SRC_OVERRIDE}\";"
|
2020-01-08 15:41:07 +01:00
|
|
|
fi
|
2020-01-21 08:19:49 +01:00
|
|
|
if [ -n "${NIMBUS_SRC_OVERRIDE}" ]; then
|
|
|
|
config+="status-im.nimbus.src-override=\"${NIMBUS_SRC_OVERRIDE}\";"
|
|
|
|
fi
|
2020-03-02 12:18:01 +01:00
|
|
|
config+="status-im.build-type=\"$(must_get_env BUILD_TYPE)\";"
|
2020-04-26 14:40:06 +02:00
|
|
|
config+="status-im.build-number=\"$(must_get_env BUILD_NUMBER)\";"
|
|
|
|
config+="status-im.android.keystore-path=\"$(must_get_env KEYSTORE_PATH)\";"
|
2020-07-28 10:33:37 +02:00
|
|
|
config+="status-im.android.apk-signed=\"$(must_get_env ANDROID_APK_SIGNED)\";"
|
2020-04-26 14:40:06 +02:00
|
|
|
config+="status-im.android.abi-split=\"$(must_get_env ANDROID_ABI_SPLIT)\";"
|
|
|
|
config+="status-im.android.abi-include=\"$(must_get_env ANDROID_ABI_INCLUDE)\";"
|
2020-03-13 13:01:17 +01:00
|
|
|
nixOpts=()
|
|
|
|
|
2020-06-21 11:18:59 +02:00
|
|
|
# If no secrets were passed there's no need to pass the 'secretsFile'
|
|
|
|
if [[ -n "${KEYSTORE_ALIAS}${KEYSTORE_ALIAS}${KEYSTORE_ALIAS}" ]]; then
|
|
|
|
# Secrets like this can't be passed via args or they end up in derivation
|
|
|
|
SECRETS_FILE_PATH=$(mktemp)
|
|
|
|
trap "rm -f ${SECRETS_FILE_PATH}" EXIT ERR INT QUIT
|
|
|
|
chmod 644 ${SECRETS_FILE_PATH}
|
|
|
|
append_env_export 'KEYSTORE_PASSWORD'
|
|
|
|
append_env_export 'KEYSTORE_ALIAS'
|
|
|
|
append_env_export 'KEYSTORE_KEY_PASSWORD'
|
|
|
|
nixOpts+=("--argstr" "secretsFile" "${SECRETS_FILE_PATH}")
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Used by Clojure at compile time to include JS modules
|
2020-04-26 14:40:06 +02:00
|
|
|
nixOpts+=("--argstr" "buildEnv" "$(must_get_env BUILD_ENV)")
|
2019-09-10 11:50:09 +02:00
|
|
|
|
2020-04-14 17:33:11 +02:00
|
|
|
if [[ "$(uname -s)" =~ Darwin ]]; then
|
2019-09-10 11:50:09 +02:00
|
|
|
# Start a watchman instance if not started already and store its socket path.
|
2020-02-19 14:15:28 +01:00
|
|
|
# In order to get access to the right versions of watchman and jq,
|
|
|
|
# we start an ad-hoc nix-shell that imports the packages from nix/nixpkgs-bootstrap.
|
2020-01-13 15:28:40 +01:00
|
|
|
WATCHMAN_SOCKFILE=$(watchman get-sockname --no-pretty | jq -r .sockname)
|
2019-09-10 11:50:09 +02:00
|
|
|
nixOpts+=(
|
2020-04-14 17:33:11 +02:00
|
|
|
"--argstr" "watchmanSockPath" "${WATCHMAN_SOCKFILE}"
|
|
|
|
"--option" "extra-sandbox-paths" "${KEYSTORE_PATH} ${SECRETS_FILE_PATH} ${WATCHMAN_SOCKFILE}"
|
2019-09-10 11:50:09 +02:00
|
|
|
)
|
|
|
|
else
|
|
|
|
nixOpts+=(
|
2020-07-27 22:57:41 +02:00
|
|
|
"--option" "build-use-sandbox" "true"
|
2020-03-13 13:01:17 +01:00
|
|
|
"--option" "extra-sandbox-paths" "${KEYSTORE_PATH} ${SECRETS_FILE_PATH}"
|
2019-09-10 11:50:09 +02:00
|
|
|
)
|
|
|
|
fi
|
|
|
|
|
2020-04-26 14:40:06 +02:00
|
|
|
nixOpts+=("--arg" "config" "{${config}}")
|
2020-03-13 13:01:17 +01:00
|
|
|
|
2019-11-29 11:20:08 +01:00
|
|
|
${GIT_ROOT}/nix/scripts/build.sh targets.mobile.android.release "${nixOpts[@]}"
|