#!/bin/bash if [ $# -ne 4 ]; then echo "Usage: `basename $0` PRIVATE_KEY CERTIFICATE \\" echo " KEY_ALIAS OUTPUT_KEYSTORE_PATH" echo echo "Example:" echo " `basename $0` \\" echo " ../../../build/target/product/security/testkey.pk8 \\" echo " ../../../build/target/product/security/testkey.x509.pem \\" echo " android testkey.jks" exit 0 fi PRIVATE_KEY="$1" CERTIFICATE="$2" KEY_ALIAS="$3" KEYSTORE_PATH="$4" if [ -f "$KEYSTORE_PATH" ]; then echo "$KEYSTORE_PATH already exists" exit 1 fi echo "The passwords will be stored in clear text" read -p "Enter new keystore password: " -s KEYSTORE_PASSWORD echo read -p "Enter new key password: " -s KEY_PASSWORD echo tmpdir=`mktemp -d` trap 'rm -rf $tmpdir;' 0 key="$tmpdir/platform.key" pk12="$tmpdir/platform.pk12" openssl pkcs8 -in "$PRIVATE_KEY" -inform DER -outform PEM -nocrypt -out "$key" if [ $? -ne 0 ]; then exit 1 fi openssl pkcs12 -export -in "$CERTIFICATE" -inkey "$key" -name "$KEY_ALIAS" \ -out "$pk12" -password pass:"$KEY_PASSWORD" if [ $? -ne 0 ]; then exit 1 fi keytool -importkeystore \ -srckeystore "$pk12" -srcstoretype pkcs12 -srcstorepass "$KEY_PASSWORD" \ -destkeystore "$KEYSTORE_PATH" -deststorepass "$KEYSTORE_PASSWORD" \ -destkeypass "$KEY_PASSWORD" if [ $? -ne 0 ]; then exit 1 fi echo echo "Generating keystore.properties..." if [ -f keystore.properties ]; then echo "keystore.properties already exists, overwrite it? [Y/n]" read reply if [ "$reply" = "n" -o "$reply" = "N" ]; then exit 0 fi fi cat > keystore.properties <