X-Git-Url: https://osm.etsi.org/gitweb/?a=blobdiff_plain;f=scripts%2Finstall-openmano.sh;h=ac28f0d7259d4875cf16123d19d7b8a5aa5a2055;hb=5461675ac6705ee92916ed741da1914bd2162482;hp=5cf538c5557dc7b953cb2eed17b9b23e157e2d80;hpb=80fde9891031d17047a15377bfa7538c40305be2;p=osm%2FRO.git diff --git a/scripts/install-openmano.sh b/scripts/install-openmano.sh index 5cf538c5..ac28f0d7 100755 --- a/scripts/install-openmano.sh +++ b/scripts/install-openmano.sh @@ -156,8 +156,8 @@ fi if [ "$_DISTRO" == "Ubuntu" ] then _RELEASE=$(lsb_release -rs) - if [[ ${_RELEASE%%.*} != 14 ]] && [[ ${_RELEASE%%.*} != 16 ]] - then + if [[ ${_RELEASE%%.*} != 14 ]] && [[ ${_RELEASE%%.*} != 16 ]] + then [[ -z $QUIET_MODE ]] && ! ask_user "WARNING! Not tested Ubuntu version. Continue assuming a trusty (14.XX)' (y/N)? " n && echo "Cancelled" && exit 1 @@ -197,14 +197,14 @@ INSTALL_AS_A_SERVICE="" # Next operations require knowing BASEFOLDER if [[ -z "$NOCLONE" ]]; then if [[ -n "$INSTALL_AS_A_SERVICE" ]] ; then - OPENMANO_BASEFOLDER=__openmano__${RANDOM} + BASEFOLDER=__openmano__${RANDOM} else - OPENMANO_BASEFOLDER="${PWD}/openmano" + BASEFOLDER="${PWD}/openmano" fi - [[ -n "$FORCE" ]] && rm -rf $OPENMANO_BASEFOLDER #make idempotent + [[ -n "$FORCE" ]] && rm -rf $BASEFOLDER #make idempotent else - HERE=$(realpath $(dirname $0)) - OPENMANO_BASEFOLDER=$(dirname $HERE) + HERE=$(dirname $(readlink -f ${BASH_SOURCE[0]})) + BASEFOLDER=$(dirname $HERE) fi if [[ -z "$NO_PACKAGES" ]] @@ -249,8 +249,11 @@ then [ "$_DISTRO" == "CentOS" -o "$_DISTRO" == "Red" ] && install_packages "python-boto" #TODO check if at Centos it exists with this name, or PIP should be used # install openstack client needed for using openstack as a VIM - [ "$_DISTRO" == "Ubuntu" ] && install_packages "python-novaclient python-keystoneclient python-glanceclient python-neutronclient python-cinderclient" - [ "$_DISTRO" == "CentOS" -o "$_DISTRO" == "Red" ] && install_packages "python-devel" && easy_install python-novaclient python-keystoneclient python-glanceclient python-neutronclient python-cinderclient #TODO revise if gcc python-pip is needed + [ "$_DISTRO" == "Ubuntu" ] && install_packages "python-novaclient python-keystoneclient python-glanceclient "\ + "python-neutronclient python-cinderclient python-openstackclient" + [ "$_DISTRO" == "CentOS" -o "$_DISTRO" == "Red" ] && install_packages "python-devel" && easy_install \ + python-novaclient python-keystoneclient python-glanceclient python-neutronclient python-cinderclient \ + python-openstackclient #TODO revise if gcc python-pip is needed fi # [[ -z "$NO_PACKAGES" ]] if [[ -z $NOCLONE ]]; then @@ -258,34 +261,36 @@ if [[ -z $NOCLONE ]]; then "#################################################################\n"\ "##### DOWNLOAD SOURCE #####\n"\ "#################################################################" - if [[ -d "${OPENMANO_BASEFOLDER}" ]] ; then + if [[ -d "${BASEFOLDER}" ]] ; then if [[ -n "$FORCE" ]] ; then - echo "deleting '${OPENMANO_BASEFOLDER}' folder" - rm -rf "$OPENMANO_BASEFOLDER" #make idempotent + echo "deleting '${BASEFOLDER}' folder" + rm -rf "$BASEFOLDER" #make idempotent elif [[ -z "$QUIET_MODE" ]] ; then - ! ask_user "folder '${OPENMANO_BASEFOLDER}' exists, overwrite (y/N)? " n && echo "Cancelled!" && exit 1 - rm -rf "$OPENMANO_BASEFOLDER" + ! ask_user "folder '${BASEFOLDER}' exists, overwrite (y/N)? " n && echo "Cancelled!" && exit 1 + rm -rf "$BASEFOLDER" else - echo "'${OPENMANO_BASEFOLDER}' folder exists. Use "--force" to overwrite" >&2 && exit 1 + echo "'${BASEFOLDER}' folder exists. Use "--force" to overwrite" >&2 && exit 1 fi fi - su $SUDO_USER -c "git clone ${GIT_URL} ${OPENMANO_BASEFOLDER}" - su $SUDO_USER -c "cp ${OPENMANO_BASEFOLDER}/.gitignore-common ${OPENMANO_BASEFOLDER}/.gitignore" - [[ -z $DEVELOP ]] && su $SUDO_USER -c "git -C ${OPENMANO_BASEFOLDER} checkout v2.0" + su $SUDO_USER -c "git clone ${GIT_URL} ${BASEFOLDER}" + LATEST_STABLE_TAG=`git -C "${BASEFOLDER}" tag -l v[0-9].* | tail -n1` + [[ -z $DEVELOP ]] && su $SUDO_USER -c "git -C ${BASEFOLDER} checkout tags/${LATEST_STABLE_TAG}" + su $SUDO_USER -c "cp ${BASEFOLDER}/.gitignore-common ${BASEFOLDER}/.gitignore" fi echo -e "\n"\ "#################################################################\n"\ "##### INSTALLING OVIM LIBRARY #####\n"\ "#################################################################" -su $SUDO_USER -c "git -C ${OPENMANO_BASEFOLDER} clone ${GIT_OVIM_URL} openvim" -[[ -z $DEVELOP ]] && su $SUDO_USER -c "git -C ${OPENMANO_BASEFOLDER}/openvim checkout v2.0" +su $SUDO_USER -c "git -C ${BASEFOLDER} clone ${GIT_OVIM_URL} openvim" +LATEST_STABLE_TAG=`git -C "${BASEFOLDER}/openvim" tag -l v[0-9].* | tail -n1` +[[ -z $DEVELOP ]] && su $SUDO_USER -c "git -C ${BASEFOLDER}/openvim checkout tags/${LATEST_STABLE_TAG}" # Install debian dependencies before setup.py [ "$_DISTRO" == "Ubuntu" ] && install_packages "libmysqlclient-dev" [ "$_DISTRO" == "CentOS" -o "$_DISTRO" == "Red" ] && install_packages "libmysqlclient-dev" #TODO check if that's the name in CentOS and RedHat -make -C ${OPENMANO_BASEFOLDER}/openvim lite -rm -rf "${OPENMANO_BASEFOLDER}/openvim" +make -C ${BASEFOLDER}/openvim lite +rm -rf "${BASEFOLDER}/openvim" OSMLIBOVIM_PATH=`python -c 'import lib_osm_openvim; print lib_osm_openvim.__path__[0]'` if [ "$_DISTRO" == "CentOS" -o "$_DISTRO" == "Red" ] @@ -318,8 +323,8 @@ then fi echo -e "\n"\ - "#################################################################n"\ - "##### CONFIGURE OPENMANO CLIENT #####n"\ + "#################################################################\n"\ + "##### CONFIGURE OPENMANO CLIENT #####\n"\ "#################################################################" #creates a link at ~/bin if not configured as a service if [[ -z "$INSTALL_AS_A_SERVICE" ]] @@ -328,9 +333,9 @@ then su $SUDO_USER -c 'rm -f ${HOME}/bin/openmano' su $SUDO_USER -c 'rm -f ${HOME}/bin/openmano-report' su $SUDO_USER -c 'rm -f ${HOME}/bin/service-openmano' - su $SUDO_USER -c "ln -s '${OPENMANO_BASEFOLDER}/openmano' "'${HOME}/bin/openmano' - su $SUDO_USER -c "ln -s '${OPENMANO_BASEFOLDER}/scripts/openmano-report.sh' "'${HOME}/bin/openmano-report' - su $SUDO_USER -c "ln -s '${OPENMANO_BASEFOLDER}/scripts/service-openmano' "'${HOME}/bin/service-openmano' + su $SUDO_USER -c "ln -s '${BASEFOLDER}/openmano' "'${HOME}/bin/openmano' + su $SUDO_USER -c "ln -s '${BASEFOLDER}/scripts/openmano-report.sh' "'${HOME}/bin/openmano-report' + su $SUDO_USER -c "ln -s '${BASEFOLDER}/scripts/service-openmano' "'${HOME}/bin/service-openmano' #insert /home//bin in the PATH #skiped because normally this is done authomatically when ~/bin exists @@ -339,13 +344,14 @@ then # echo " inserting /home/$SUDO_USER/bin in the PATH at .bashrc" # su $SUDO_USER -c 'echo "PATH=\$PATH:\${HOME}/bin" >> ~/.bashrc' #fi - if [[ $SUDO_USER == root ]] + + if [[ $SUDO_USER == root ]] then if ! echo $PATH | grep -q "${HOME}/bin" then echo "PATH=\$PATH:\${HOME}/bin" >> ${HOME}/.bashrc fi - fi + fi fi #configure arg-autocomplete for this user @@ -361,17 +367,17 @@ fi if [ -z "$NO_DB" ]; then echo -e "\n"\ - "#################################################################"\n"\ - "##### INSTALL DATABASE SERVER #####"\n"\ + "#################################################################\n"\ + "##### INSTALL DATABASE SERVER #####\n"\ "#################################################################" if [ -n "$QUIET_MODE" ]; then DB_QUIET='-q' fi - ${OPENMANO_BASEFOLDER}/database_utils/install-db-server.sh -U $DBUSER ${DBPASSWD_PARAM/p/P} $DB_QUIET $DB_FORCE_UPDATE || exit 1 + ${BASEFOLDER}/database_utils/install-db-server.sh -U $DBUSER ${DBPASSWD_PARAM/p/P} $DB_QUIET $DB_FORCE_UPDATE || exit 1 echo -e "\n"\ - "#################################################################"\n"\ - "##### CREATE AND INIT MANO_VIM DATABASE #####"\n"\ + "#################################################################\n"\ + "##### CREATE AND INIT MANO_VIM DATABASE #####\n"\ "#################################################################" # Install mano_vim_db after setup ${OSMLIBOVIM_PATH}/database_utils/install-db-server.sh -U $DBUSER ${DBPASSWD_PARAM/p/P} -u mano -p manopw -d mano_vim_db --no-install-packages $DB_QUIET $DB_FORCE_UPDATE || exit 1 @@ -380,12 +386,12 @@ fi # [ -z "$NO_DB" ] if [[ -n "$INSTALL_AS_A_SERVICE" ]] then echo -e "\n"\ - "#################################################################"\n"\ - "##### CONFIGURE OPENMANO SERVICE #####"\n"\ + "#################################################################\n"\ + "##### CONFIGURE OPENMANO SERVICE #####\n"\ "#################################################################" - ${OPENMANO_BASEFOLDER}/scripts/install-openmano-service.sh -f ${OPENMANO_BASEFOLDER} `[[ -z "$NOCLONE" ]] && echo "-d"` - # rm -rf ${OPENMANO_BASEFOLDER} + ${BASEFOLDER}/scripts/install-openmano-service.sh -f ${BASEFOLDER} `[[ -z "$NOCLONE" ]] && echo "-d"` + # rm -rf ${BASEFOLDER} # alias service-openmano="service openmano" # echo 'alias service-openmano="service openmano"' >> ${HOME}/.bashrc echo @@ -394,5 +400,5 @@ then else echo echo "Done! you may need to logout and login again for loading client configuration" - echo " Run './${OPENMANO_BASEFOLDER}/scripts/service-openmano start' for starting openmano in a screen" + echo " Run './${BASEFOLDER}/scripts/service-openmano start' for starting openmano in a screen" fi