Gabriele M | 6c0aa81 | 2018-04-09 12:41:30 +0200 | [diff] [blame] | 1 | #!/bin/bash |
Gabriele M | 3fc1749 | 2017-11-30 23:41:00 +0100 | [diff] [blame] | 2 | |
Gabriele M | 6c0aa81 | 2018-04-09 12:41:30 +0200 | [diff] [blame] | 3 | if [ $# -ne 4 ]; then |
Gabriele M | 3fc1749 | 2017-11-30 23:41:00 +0100 | [diff] [blame] | 4 | echo "Usage: `basename $0` PRIVATE_KEY CERTIFICATE \\" |
Gabriele M | 6c0aa81 | 2018-04-09 12:41:30 +0200 | [diff] [blame] | 5 | echo " KEY_ALIAS OUTPUT_KEYSTORE_PATH" |
Gabriele M | 3fc1749 | 2017-11-30 23:41:00 +0100 | [diff] [blame] | 6 | echo |
| 7 | echo "Example:" |
| 8 | echo " `basename $0` \\" |
| 9 | echo " ../../../build/target/product/security/testkey.pk8 \\" |
| 10 | echo " ../../../build/target/product/security/testkey.x509.pem \\" |
Gabriele M | 6c0aa81 | 2018-04-09 12:41:30 +0200 | [diff] [blame] | 11 | echo " android testkey.jks" |
Gabriele M | 3fc1749 | 2017-11-30 23:41:00 +0100 | [diff] [blame] | 12 | exit 0 |
| 13 | fi |
| 14 | |
| 15 | PRIVATE_KEY="$1" |
| 16 | CERTIFICATE="$2" |
Gabriele M | 6c0aa81 | 2018-04-09 12:41:30 +0200 | [diff] [blame] | 17 | KEY_ALIAS="$3" |
| 18 | KEYSTORE_PATH="$4" |
Gabriele M | 3fc1749 | 2017-11-30 23:41:00 +0100 | [diff] [blame] | 19 | |
| 20 | if [ -f "$KEYSTORE_PATH" ]; then |
| 21 | echo "$KEYSTORE_PATH already exists" |
| 22 | exit 1 |
| 23 | fi |
| 24 | |
Gabriele M | 6c0aa81 | 2018-04-09 12:41:30 +0200 | [diff] [blame] | 25 | echo "The passwords will be stored in clear text" |
| 26 | read -p "Enter new keystore password: " -s KEYSTORE_PASSWORD |
| 27 | echo |
| 28 | read -p "Enter new key password: " -s KEY_PASSWORD |
| 29 | echo |
| 30 | |
Gabriele M | 3fc1749 | 2017-11-30 23:41:00 +0100 | [diff] [blame] | 31 | tmpdir=`mktemp -d` |
| 32 | trap 'rm -rf $tmpdir;' 0 |
| 33 | |
| 34 | key="$tmpdir/platform.key" |
| 35 | pk12="$tmpdir/platform.pk12" |
| 36 | openssl pkcs8 -in "$PRIVATE_KEY" -inform DER -outform PEM -nocrypt -out "$key" |
| 37 | if [ $? -ne 0 ]; then |
| 38 | exit 1 |
| 39 | fi |
| 40 | openssl pkcs12 -export -in "$CERTIFICATE" -inkey "$key" -name "$KEY_ALIAS" \ |
| 41 | -out "$pk12" -password pass:"$KEY_PASSWORD" |
| 42 | if [ $? -ne 0 ]; then |
| 43 | exit 1 |
| 44 | fi |
| 45 | |
| 46 | keytool -importkeystore \ |
| 47 | -srckeystore "$pk12" -srcstoretype pkcs12 -srcstorepass "$KEY_PASSWORD" \ |
| 48 | -destkeystore "$KEYSTORE_PATH" -deststorepass "$KEYSTORE_PASSWORD" \ |
| 49 | -destkeypass "$KEY_PASSWORD" |
| 50 | if [ $? -ne 0 ]; then |
| 51 | exit 1 |
| 52 | fi |
| 53 | |
| 54 | |
| 55 | echo |
| 56 | echo "Generating keystore.properties..." |
| 57 | if [ -f keystore.properties ]; then |
| 58 | echo "keystore.properties already exists, overwrite it? [Y/n]" |
| 59 | read reply |
| 60 | if [ "$reply" = "n" -o "$reply" = "N" ]; then |
| 61 | exit 0 |
| 62 | fi |
| 63 | fi |
| 64 | |
| 65 | cat > keystore.properties <<EOF |
| 66 | keyAlias=$KEY_ALIAS |
| 67 | keyPassword=$KEY_PASSWORD |
| 68 | storeFile=$KEYSTORE_PATH |
| 69 | storePassword=$KEYSTORE_PASSWORD |
| 70 | EOF |