Skip to content

Instantly share code, notes, and snippets.

@samhendley
Created July 8, 2010 20:45
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save samhendley/468595 to your computer and use it in GitHub Desktop.
Save samhendley/468595 to your computer and use it in GitHub Desktop.
# based on http://rajith.2rlabs.com/2010/03/01/apache-qpid-securing-connections-with-ssl/
COMPANY="O=GACME,ST=North Carolina,C=US"
CA_NAME="RootCA"
CA_PASS="ccccccccc"
CERT_LOC=~/keys
SERVER_NAME="localhost.localdomain"
SERVER_PASS="sesesese"
JAVA_TRUSTPASS="jjjjjjj"
JAVA_KEYPASS="pppppppp"
mkdir $CERT_LOC
cd $CERT_LOC
rm -rf CA_db
mkdir CA_db
echo "y" > ca_input
echo "0" >> ca_input
echo "n" >> ca_input
echo $CA_PASS > CA_db/pfile
certutil -N -d CA_db -f CA_db/pfile
dd bs=256 count=1 if=/dev/urandom of=noise
cat ca_input | certutil -S -d CA_db -n "$CA_NAME" -s "CN=$CA_NAME,$COMPANY" -t "CT,," -x -2 -f CA_db/pfile -z noise
rm noise ca_input
certutil -L -d CA_db -n "$CA_NAME" -a -o CA_db/rootca.crt -f CA_db/pfile
rm -rf server_db
mkdir server_db
echo $SERVER_PASS > server_db/pfile
certutil -N -d server_db -f server_db/pfile
certutil -A -d server_db -n "$CA_NAME" -t "TC,," -a -i CA_db/rootca.crt -f server_db/pfile
dd bs=256 count=1 if=/dev/urandom of=noise
certutil -R -d server_db -s "CN=$SERVER_NAME,$COMPANY" -a -o server_db/server.req -z noise -f server_db/pfile
rm noise
echo "0" > sign_serv
echo "9" >> sign_serv
echo "n" >> sign_serv
echo "n" >> sign_serv
echo "-1" >> sign_serv
echo "n" >> sign_serv
cat sign_serv | certutil -C -d CA_db -c "$CA_NAME" -a -i server_db/server.req -o server_db/server.crt -2 -6 -f CA_db/pfile
certutil -A -d server_db -n $SERVER_NAME -a -i server_db/server.crt -t ",," -f server_db/pfile
rm -f trust-store.jks key-store.jks sign_serv
keytool -import -v -keystore trust-store.jks -storepass $JAVA_TRUSTPASS -alias $CA_NAME -file CA_db/rootca.crt -noprompt
keytool -import -v -keystore key-store.jks -storepass $JAVA_KEYPASS -alias $CA_NAME -file CA_db/rootca.crt -noprompt
keytool -genkey -alias java-client -keyalg RSA -sigalg MD5withRSA -validity 356 -keystore key-store.jks -storepass $JAVA_KEYPASS -keypass $JAVA_KEYPASS -dname "CN=java-client,$COMPANY"
keytool -certreq -alias java-client -sigalg MD5withRSA -keystore key-store.jks -storepass $JAVA_KEYPASS -keypass $JAVA_KEYPASS -v -file java-client.req
echo "1" > sign_client
echo "9" >> sign_client
echo "n" >> sign_client
echo "n" >> sign_client
echo "-1" >> sign_client
echo "n" >> sign_client
cat sign_client | certutil -C -d CA_db -c "$CA_NAME" -a -i java-client.req -o java-client.crt -2 -6 -f CA_db/pfile
rm sign_client
keytool -import -v -alias java-client -keystore key-store.jks -storepass $JAVA_KEYPASS -file java-client.crt
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment