mirror of
https://github.com/status-im/status-react.git
synced 2025-01-09 18:46:19 +00:00
Jakub Sokołowski
4e567cf782
This PR extracts all the ci/*.groovy scripts into a separate private repo located at: https://github.com/status-im/status-react-jenkins The main reasons for a separate repo are: * Hiding the internal details of our CI setup * Hiding names of Jenkins credentials available in CI jobs * Lowering attack surface for malicious external contributors * Increasing focus on PRs related to CI setup You can read more about how Jenkins pipeline shared libraries work here: https://jenkins.io/doc/book/pipeline/shared-libraries/ In simple terms I've added the repo to the main Jenkins configuration in "Global Pipeline Libraries" section and load it using: library 'status-react-jenkins@master' Which makes globally available all of the libraries defined in the `vars` directory of that repo. This also eliminates the need for statements like `android = load 'ci/android.groovy'`. Signed-off-by: Jakub Sokołowski <jakub@status.im>
50 lines
1.3 KiB
Bash
Executable File
50 lines
1.3 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
set -euf pipefail
|
|
|
|
GIT_ROOT=$(cd "${BASH_SOURCE%/*}" && git rev-parse --show-toplevel)
|
|
source "${GIT_ROOT}/scripts/colors.sh"
|
|
|
|
function property() {
|
|
grep "${2}" "${1}" | cut -d'=' -f2
|
|
}
|
|
|
|
function property_gradle() {
|
|
property ${GIT_ROOT}/android/gradle.properties ${1}
|
|
}
|
|
|
|
KEYSTORE_PASSWORD=$(property_gradle 'KEYSTORE_PASSWORD')
|
|
KEYSTORE_ALIAS=$(property_gradle 'KEYSTORE_ALIAS')
|
|
KEYSTORE_KEY_PASSWORD=$(property_gradle 'KEYSTORE_KEY_PASSWORD')
|
|
|
|
# Allow Makefile modify Keystore path if necessary
|
|
if [[ -z ${KEYSTORE_PATH} ]]; then
|
|
KEYSTORE_PATH=$(property_gradle 'KEYSTORE_FILE')
|
|
fi
|
|
# Replace ~ with proper absolute path
|
|
KEYSTORE_PATH=${KEYSTORE_PATH/#\~/$HOME}
|
|
|
|
if [[ -e "${KEYSTORE_PATH}" ]]; then
|
|
echo -e "${YLW}Keystore file already exists:${RST} ${KEYSTORE_PATH}" > /dev/stderr
|
|
echo "${KEYSTORE_PATH}"
|
|
exit 0
|
|
fi
|
|
|
|
KEYSTORE_DIR=$(dirname "${S/TATUS_RELEASE_STORE_FILE}")
|
|
[[ -d $KEYSTORE_DIR ]] || mkdir -p $KEYSTORE_DIR
|
|
|
|
echo -e "${GRN}Generating keystore...${RST}" > /dev/stderr
|
|
|
|
keytool -genkey -v \
|
|
-keyalg RSA \
|
|
-keysize 2048 \
|
|
-validity 10000 \
|
|
-dname "CN=, OU=, O=, L=, S=, C=" \
|
|
-keystore "${KEYSTORE_PATH}" \
|
|
-alias "${KEYSTORE_ALIAS}" \
|
|
-storepass "${KEYSTORE_PASSWORD}" \
|
|
-keypass "${KEYSTORE_KEY_PASSWORD}" \
|
|
> /dev/stderr
|
|
|
|
echo "${KEYSTORE_PATH}"
|