mirror of
https://github.com/status-im/status-mobile.git
synced 2025-01-15 03:05:17 +00:00
Jakub Sokołowski
f2c96dcd3b
Changes: * Create `nix/config.nix` with `config` defaults * Add `nix/tools/gradlePropParser.nix` for reading `gradle.properties` * Add `nix/mobile/android/keystore.nix` for generating a keystore * Load keystore generation in `nix/mobile/android/default.nix` * Use generated keystore if it's not provided via `config` * Add `-deststoretype pkcs12` in `scripts/generate-keystore.sh` * Add `nix/lib/assertEnvVarSet.nix` for checking if env var is set Signed-off-by: Jakub Sokołowski <jakub@status.im>
45 lines
1.3 KiB
Nix
45 lines
1.3 KiB
Nix
#
|
|
# Generates an ad-hoc and temporary keystore for signing debug/pr builds.
|
|
#
|
|
# WARNING: Do NOT use this to make a keystore that needs to be secret!
|
|
# Using a derivation will store the inputs in a .drv file.
|
|
#
|
|
{ stdenv, lib, pkgs }:
|
|
|
|
let
|
|
inherit (lib) getAttr;
|
|
|
|
gradleProps = pkgs.gradlePropParser ../../../android/gradle.properties;
|
|
|
|
# Loading defaults from gradle.properties which should be safe.
|
|
KEYSTORE_ALIAS = getAttr "KEYSTORE_ALIAS" gradleProps;
|
|
KEYSTORE_PASSWORD = getAttr "KEYSTORE_PASSWORD" gradleProps;
|
|
KEYSTORE_KEY_PASSWORD = getAttr "KEYSTORE_KEY_PASSWORD" gradleProps;
|
|
|
|
in stdenv.mkDerivation {
|
|
name = "status-react-android-keystore";
|
|
|
|
buildInputs = [ pkgs.openjdk8 ];
|
|
|
|
phases = [ "generatePhase" ];
|
|
generatePhase = ''
|
|
keytool -genkey -v \
|
|
-keyalg RSA \
|
|
-keysize 2048 \
|
|
-validity 10000 \
|
|
-deststoretype pkcs12 \
|
|
-dname "CN=, OU=, O=, L=, S=, C=" \
|
|
-keystore "$out" \
|
|
-alias "${KEYSTORE_ALIAS}" \
|
|
-storepass "${KEYSTORE_PASSWORD}" \
|
|
-keypass "${KEYSTORE_KEY_PASSWORD}" \
|
|
>&2
|
|
'';
|
|
|
|
shellHook = ''
|
|
export KEYSTORE_ALIAS="${KEYSTORE_ALIAS}"
|
|
export KEYSTORE_PASSWORD="${KEYSTORE_PASSWORD}"
|
|
export KEYSTORE_KEY_PASSWORD="${KEYSTORE_KEY_PASSWORD}"
|
|
'';
|
|
}
|