mq5.1-source.src.solaris.bin.imqkeytool.sh Maven / Gradle / Ivy
The newest version!
#!/bin/sh
#
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
#
# Copyright (c) 2000-2012 Oracle and/or its affiliates. All rights reserved.
#
# The contents of this file are subject to the terms of either the GNU
# General Public License Version 2 only ("GPL") or the Common Development
# and Distribution License("CDDL") (collectively, the "License"). You
# may not use this file except in compliance with the License. You can
# obtain a copy of the License at
# https://glassfish.dev.java.net/public/CDDL+GPL_1_1.html
# or packager/legal/LICENSE.txt. See the License for the specific
# language governing permissions and limitations under the License.
#
# When distributing the software, include this License Header Notice in each
# file and include the License file at packager/legal/LICENSE.txt.
#
# GPL Classpath Exception:
# Oracle designates this particular file as subject to the "Classpath"
# exception as provided by Oracle in the GPL Version 2 section of the License
# file that accompanied this code.
#
# Modifications:
# If applicable, add the following below the License Header, with the fields
# enclosed by brackets [] replaced by your own identifying information:
# "Portions Copyright [year] [name of copyright owner]"
#
# Contributor(s):
# If you wish your version of this file to be governed by only the CDDL or
# only the GPL Version 2, indicate your decision by adding "[Contributor]
# elects to include this software in this distribution under the [CDDL or GPL
# Version 2] license." If you don't indicate a single choice of license, a
# recipient has the option to distribute your version of this file under
# either the CDDL, the GPL Version 2 or to extend the choice of license to
# its licensees as provided above. However, if you add GPL Version 2 code
# and therefore, elected the GPL Version 2 license, then the option applies
# only if the new code is made subject to such option by the copyright
# holder.
#
#
# imqkeytool is a wrapper script for JDK Keytool for generation of a keystore
# and a self signed certificate for use with SSL.
#
# To generate keystore and self signed certificate for the broker
# usage: imqkeytool [-broker]
#
# To generate keystore and a self-signed certificate for the HTTPS tunnel
# servlet
# usage: imqkeytool -servlet
#
#
# print usage
#
usage() {
echo ""
echo "usage:"
echo "imqkeytool [-broker]"
echo " generates a keystore and self-signed certificate for the broker"
echo ""
echo "imqkeytool -servlet "
echo " generates a keystore and self-signed certificate for the HTTPS"
echo " tunnel servlet, keystore_location specifies the name and location"
echo " of the keystore file"
echo ""
exit 1
}
_bin_home=`/usr/bin/dirname $0`
_init_file="imqinit"
# Source initialization file. This intitializes the imq_* variables
if [ -f $_bin_home/../share/lib/imq/$_init_file ]; then
# bundled location
. $_bin_home/../share/lib/imq/$_init_file
elif [ -f $_bin_home/../lib/$_init_file ]; then
# unbundled location
. $_bin_home/../lib/$_init_file
elif [ -f $_bin_home/../private/share/lib/$_init_file ]; then
# Linux "standard" location
. $_bin_home/../private/share/lib/$_init_file
#####hpux-dev#####
elif [ -f $_bin_home/../private/share/lib/$_init_file ]; then
# HP-UX "standard" location
. $_bin_home/../private/share/lib/$_init_file
else
echo "Error: Could not find required Message Queue initialization file '$_init_file'"
exit 1
fi
# file is stored (by default) in /etc/imq/keystore
keystore_home=$imq_etchome
cmd=broker
while [ $# != 0 ]; do
case "$1" in
-broker) cmd="broker"; shift ;;
-servlet)
cmd="servlet"
if [ $# = 1 ]; then
echo "Please specify keystore location for the -servlet option"
usage
else
keystore=$2
shift 2
fi
;;
-verbose) shift 1;; # Handled by imqinit
-javahome) shift 2;; # Handled by imqinit
-varhome) shift 2;; # Handled by imqinit
*) usage ;;
esac
done
if [ $cmd = broker ]; then
#
# generate keystore and certificate for the broker
#
echo "Generating keystore for the broker ..."
if [ ! -w $keystore_home ]; then
/bin/echo "You do not have permission to create the keystore file in"
/bin/ls -ld $keystore_home
exit 1
fi
keystore=$keystore_home/keystore
echo Keystore=$keystore
# Generate the keypair. This also wraps them in a self-signed certificate
$imq_javahome/bin/keytool -genkey -keyalg "RSA" -alias imq -keystore $keystore -v
status=$?
#Make sure keystore is readable by everybody so broker can read it
chmod a+r $keystore
elif [ $cmd = servlet ]; then
#
# generate keystore and certificate for the HTTPS tunnel servlet
#
echo "Generating keystore for the HTTPS tunnel servlet ..."
keystoredir=`/usr/bin/dirname $keystore`
if [ ! -w $keystoredir ]; then
/bin/echo "You do not have permission to create the keystore file in"
/bin/ls -ld $keystoredir
exit 1
fi
echo Keystore=$keystore
# Generate the keypair. This also wraps them in a self-signed certificate
"$imq_javahome/bin/keytool" -genkey -keyalg "RSA" -alias imqservlet -keystore $keystore -v
status=$?
if [ $status = 0 ]; then
echo "Make sure the keystore is accessible and readable by"
echo "the HTTPS tunnel servlet."
fi
else
#
# print usage
#
usage
fi
exit $status