X-Git-Url: https://osm.etsi.org/gitweb/?a=blobdiff_plain;f=scripts%2Finstall-openvim-service.sh;h=f9270f278b748bdb2e9b33c17ee048699ac58a2b;hb=9cead2a0262deabadc900d580ef312fbc468efc0;hp=f673502bd830f82b82c1036028261f143787707a;hpb=f13617a350092613d22a39997fb00afda7da209c;p=osm%2Fopenvim.git diff --git a/scripts/install-openvim-service.sh b/scripts/install-openvim-service.sh index f673502..f9270f2 100755 --- a/scripts/install-openvim-service.sh +++ b/scripts/install-openvim-service.sh @@ -26,31 +26,37 @@ function usage(){ echo -e "usage: sudo $0 [OPTIONS]" - echo -e "Configures openvim to run as a service" + echo -e "Configures openvim to run as a service at /opt" echo -e " OPTIONS" echo -e " -u USER_OWNER user owner of the service, 'root' by default" echo -e " -f PATH path where openvim source is located. If missing it is downloaded from git" - #echo -e " -q: install in an unattended mode" + echo -e " -d --delete: if -f is provided, delete this path after copying to /opt" echo -e " -h: show this help" echo -e " --uninstall: remove created service and files" } function uninstall(){ - service openvim stop - for file in /opt/openvim /etc/default/openvimd.cfg /var/log/openvim /etc/systemd/system/openvim.service + echo "systemctl disable openvim.service " && systemctl disable openvim.service 2>/dev/null || + echo " Already done" + echo "systemctl disable osm-openvim.service " && systemctl disable osm-openvim.service 2>/dev/null || + echo " Already done" + echo "service osm-openvim stop " && service osm-openvim stop 2>/dev/null || echo " Already done" + for file in /opt/openvim /etc/default/openvimd.cfg /etc/osm/openvimd.cfg /var/log/openvim /var/log/osm/openvim* \ + /etc/systemd/system/openvim.service /etc/systemd/system/osm-openvim.service /usr/bin/openvim /usr/sbin/service-openvim \ + /usr/bin/openvim-report /usr/bin/initopenvim /usr/bin/openflow do + echo rm $file rm -rf $file || ! echo "Can not delete '$file'. Needed root privileges?" >&2 || exit 1 done echo "Done" } -BAD_PATH_ERROR="Path '$FILE' does not contain a valid openvim distribution" -GIT_URL=https://osm.etsi.org/gerrit/osm/RO.git +GIT_URL=https://osm.etsi.org/gerrit/osm/openvim.git USER_OWNER="root" QUIET_MODE="" FILE="" DELETE="" -while getopts ":u:f:hq-:" o; do +while getopts ":u:f:hdq-:" o; do case "${o}" in u) export USER_OWNER="$OPTARG" @@ -64,10 +70,14 @@ while getopts ":u:f:hq-:" o; do h) usage && exit 0 ;; + d) + DELETE=y + ;; -) [ "${OPTARG}" == "help" ] && usage && exit 0 [ "${OPTARG}" == "uninstall" ] && uninstall && exit 0 - echo -e "Invalid option: '--$OPTARG'\nTry $0 --help for more information" >&2 + [ "${OPTARG}" == "delete" ] && DELETE=y && continue + echo -e "Invalid option: '--$OPTARG'\nTry $0 --help for more information" >&2 exit 1 ;; \?) @@ -84,6 +94,7 @@ while getopts ":u:f:hq-:" o; do ;; esac done +BAD_PATH_ERROR="Path '$FILE' does not contain a valid openvim distribution" #check root privileges [ "$USER" != "root" ] && echo "Needed root privileges" >&2 && exit 1 @@ -109,44 +120,50 @@ else fi -if [[ -z $FILE ]] +if [[ -z "$FILE" ]] then - git clone $GIT_URL __temp__ || ! echo "Cannot get openvim source code from $GIT_URL" >&2 || exit 1 - #git checkout - FILE=./__temp__ + FILE=__temp__${RANDOM} + git clone $GIT_URL $FILE || ! echo "Cannot get openvim source code from $GIT_URL" >&2 || exit 1 DELETE=y +else + [[ -d "$FILE" ]] || ! echo $BAD_PATH_ERROR >&2 || exit 1 fi -#make idenpotent -rm -rf /opt/openvim -rm -f /etc/default/openvimd.cfg -rm -f /var/log/openvim -cp -r $FILE /opt/openvim || ! echo $BAD_PATH_ERROR >&2 || exit 1 -mkdir -p /opt/openvim/logs -#cp ${FILE}/openvim /usr/sbin/ || ! echo $BAD_PATH_ERROR >&2 || exit 1 -ln -s /opt/openvim/openvimd.cfg /etc/default/openvimd.cfg || echo "warning cannot create link '/etc/default/openvimd.cfg'" -ln -s /opt/openvim/logs /var/log/openvim || echo "warning cannot create link '/var/log/openvim'" - -chown $USER_OWNER /opt/openvim/openvimd.cfg -chown -R $USER_OWNER /opt/openvim - -mkdir -p etc/systemd/system/ -cat > /etc/systemd/system/openvim.service << EOF +#make idempotent +uninstall +#copy files +cp -r "$FILE" /opt/openvim || ! echo $BAD_PATH_ERROR >&2 || exit 1 +mkdir -p /etc/osm || echo "warning cannot create config folder '/etc/osm'" +cp /opt/openvim/osm_openvim/openvimd.cfg /etc/osm/openvimd.cfg || + echo "warning cannot create file '/etc/osm/openvimd.cfg'" +mkdir -p /var/log/osm || echo "warning cannot create log folder '/var/log/osm'" +#makes links +ln -s -v /opt/openvim/openvim /usr/bin/openvim +ln -s -v /opt/openvim/scripts/service-openvim /usr/sbin/service-openvim +ln -s -v /opt/openvim/scripts/openvim-report /usr/bin/openvim-report +ln -s -v /opt/openvim/scripts/initopenvim /usr/bin/initopenvim +ln -s -v /opt/openvim/openflow /usr/bin/openflow + +chown -R $SUDO_USER /opt/openvim + +mkdir -p /etc/systemd/system/ +cat > /etc/systemd/system/osm-openvim.service << EOF [Unit] Description=openvim server [Service] User=${USER_OWNER} -ExecStart=/opt/openvim/openvimd.py -c /opt/openvim/openvimd.cfg --log-file=/opt/openvim/logs/openvim.log +ExecStart=/opt/openvim/openvimd -c /etc/osm/openvimd.cfg --log-file=/var/log/osm/openvim.log Restart=always [Install] WantedBy=multi-user.target EOF -[[ -n $DELETE ]] && rm -rf $FILE +[[ -n $DELETE ]] && rm -rf "${FILE}" -service openvim start +service osm-openvim start +systemctl enable osm-openvim.service echo Done exit