123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303 |
- #!/bin/bash
- ################################################################################
- # HPCC SYSTEMS software Copyright (C) 2012 HPCC Systems®.
- #
- # Licensed under the Apache License, Version 2.0 (the "License");
- # you may not use this file except in compliance with the License.
- # You may obtain a copy of the License at
- #
- # http://www.apache.org/licenses/LICENSE-2.0
- #
- # Unless required by applicable law or agreed to in writing, software
- # distributed under the License is distributed on an "AS IS" BASIS,
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- # See the License for the specific language governing permissions and
- # limitations under the License.
- ################################################################################
- ###<REPLACE>###
- source ${INSTALL_DIR}/etc/init.d/hpcc_common
- source ${INSTALL_DIR}/etc/init.d/init-functions
- installConfs ()
- {
- fileName=$1
- configPath=$2
- mkdir -p ${configPath}
- mkdir -p ${configPath}/rpmnew
- printf "Installing %-44s ..." "${fileName}"
- if [ ! -e ${configPath}/${fileName} ]; then
- # Always install new files without comment
- cp -f ${INSTALL_DIR}/${configPath}/rpmnew/${fileName} ${configPath}/${fileName}
- cp -f ${INSTALL_DIR}/${configPath}/rpmnew/${fileName} ${configPath}/rpmnew/${fileName}
- log_success_msg
- elif [ -e ${configPath}/rpmnew/${fileName} ] && ! `diff -q ${configPath}/rpmnew/${fileName} ${INSTALL_DIR}/${configPath}/rpmnew/${fileName} >/dev/null` ; then
- # There are changes in the default config since last installed
- if ! `diff -q ${configPath}/rpmnew/${fileName} ${configPath}/${fileName} >/dev/null` ; then
- # User has made their own changes too, so don't overwrite
- log_failure_msg "Not overwriting modified configuration file ${fileName}"
- else
- # User has NOT made their own changes - ok to update
- cp -f ${INSTALL_DIR}/${configPath}/rpmnew/${fileName} ${configPath}/${fileName}
- cp -f ${INSTALL_DIR}/${configPath}/rpmnew/${fileName} ${configPath}/rpmnew/${fileName}
- log_success_msg "Updated configuration file ${fileName}"
- fi
- else
- log_success_msg "No changes to configuration file ${fileName}"
- fi
- }
- installFile ()
- {
- fileNameFrom=$1
- fileNameTo=$2
- symlink=$3
- createDir=$4
- option="-f"
- if [ ${symlink} != 0 ];then
- option="-sf"
- fi
- if [ ! -z "${createDir}" ]; then
- if [ ! -d ${createDir} ];then
- mkdir -p ${createDir}
- fi
- fi
- cp ${option} ${fileNameFrom} ${fileNameTo} 2> /dev/null
- printf "Installing %-44s ..." "${fileNameTo}"
- if [ -L ${fileNameTo} ]; then
- log_success_msg
- elif [ -e ${fileNameTo} ] && [ ! -L ${fileNameTo} ] ; then
- log_success_msg
- else
- log_failure_msg
- fi
- }
- fileCheck ()
- {
- inFile=$1
- echo -n "Checking SSH Key for user $user ..."
- if [ ! -e $inFile ]; then
- echo "Fail"
- echo "Bad File name"
- fi
- while read line
- do
- first=$( echo $line | awk '{ print $1 }' )
- second=$( echo $line | awk '{ print $2 }' )
- passValue=0
- if [ -f $first ] && [ -f $second ]; then
- newSum=$( md5sum $second )
- if [ ${newSum} -eq ${first} ]; then
- sc=0
- else
- sc=1
- fi
- else
- sc=0
- fi
- if [ "$sc" -gt 0 ]; then
- passValue=$(( ${passValue} + 1 ))
- fi
- done < ${inFile}
- if [ ${passValue} -lt 3 ]; then
- __fileCheck=0
- echo "Fail"
- echo "*** Security Alert ***"
- echo "You are using a publicly available default key."
- echo "Please run 'sudo ${path}/sbin/keygen.sh' to generate a new key to make your system secure."
- echo "*** Security Alert ***"
- else
- __fileCheck=1
- echo "OK"
- fi
- }
- #---------------------------------------------------------------------
- # Main code
- #---------------------------------------------------------------------
- SECTION=${SECTION:-DEFAULT}
- confToUse="${INSTALL_DIR}${CONFIG_DIR}/${ENV_CONF_FILE}"
- if [ -d ${CONFIG_DIR} ]; then
- if [ -f ${CONFIG_DIR}/installed ] ; then
- exit 0
- fi
- if [ -e ${CONFIG_DIR}/${ENV_CONF_FILE} ]; then
- confToUse="${CONFIG_DIR}/${ENV_CONF_FILE}"
- fi
- fi
- # Reading and processing conf file
- cfg.parser ${confToUse}
- cfg.section.${SECTION}
- if [ ${DEBUG:-NO_DEBUG} != "NO_DEBUG" ]; then
- echo "\$runtime=$runtime"
- echo "\$path=$path"
- echo "\$configs=$configs"
- echo "\$configsbackup=$configsbackup"
- echo "\$user=$user"
- echo "\$lock=$lock"
- echo "\$pid=$pid"
- echo "\$log=$log"
- echo "\$environment=$environment"
- echo "\$interface=$interface"
- echo "\$sourcedir=$sourcedir"
- echo
- fi
- #Checking if user exists and if doesn't then creating one
- useradd_d=$(echo "[DEFAULTLINUX]" > /tmp/tmp_defaultuser.conf;useradd -D >> /tmp/tmp_defaultuser.conf)
- cfg.parser /tmp/tmp_defaultuser.conf
- cfg.section.DEFAULTLINUX
- if [ "$HOME" != "$home" ]; then
- echo "Linux Default home directory is different from HPCC default."
- echo "Will continue to work with Linux Default $HOME....."
- homePath=$HOME/$user
- fi
- initPath="$path/etc/init.d"
- homePath=$HOME/$user
- binPath="$path/bin"
- add_user $user $group $homePath || exit 1
- # If user already exists get the home directory
- homePath=$(cat /etc/passwd | grep -e "^${user}:" | cut -d':' -f6)
- homeBase=$(dirname $homePath)
- echo ""
- # installing files
- installConfs "environment.conf" $configs/ 1 || exit 1
- installConfs "environment.xml" $configs/ 1 || exit 1
- installConfs "genenvrules.conf" $configs/ 1 || exit 1
- installFile "$path${CONFIG_DIR}/version" "${CONFIG_DIR}/version" 1 || exit 1
- installFile "$binPath/dfuplus" "/usr/bin/dfuplus" 1 || exit 1
- installFile "$binPath/ecl" "/usr/bin/ecl" 1 || exit 1
- installFile "$binPath/eclcc" "/usr/bin/eclcc" 1 || exit 1
- installFile "$binPath/eclplus" "/usr/bin/eclplus" 1 || exit 1
- installFile "$binPath/wuget" "/usr/bin/wuget" 1 || exit 1
- installFile "$configs/$environment" "$sourcedir/$environment" 0 "$sourcedir"
- # locate sub install files.
- if [ -d ${INSTALL_DIR}/etc/init.d/install ]; then
- for subInstall in $(ls ${INSTALL_DIR}/etc/init.d/install); do
- source ${INSTALL_DIR}/etc/init.d/install/${subInstall}
- done
- fi
- # bash completion
- if [ -d ${INSTALL_DIR}/etc/bash_completion.d ] && [ -d /etc/bash_completion.d ]; then
- for subInstall in $(ls ${INSTALL_DIR}/etc/bash_completion.d | grep -v dpkg-tmp); do
- installFile ${INSTALL_DIR}/etc/bash_completion.d/$subInstall /etc/bash_completion.d/$subInstall 1 || exit 1
- done
- fi
- # Ubuntu Unity Launcher
- if [ -f ${INSTALL_DIR}/share/hpcc-systems.desktop ] && [ -d /usr/share/applications ]; then
- installFile ${INSTALL_DIR}/share/hpcc-systems.desktop /usr/share/applications 1 || exit 1
- fi
- # SSH config dir
- if [ ! -d ${homePath}/.ssh ]; then
- mkdir -p ${homePath}/.ssh
- fi
- totalFiles=$(ls -l ${homePath}/.ssh | head -n 1 | awk '{ print $2 }' )
- if [ -d $homePath/.ssh ] && [ "$totalFiles" -le 3 ]; then
- installFile "${path}/etc/sshkey/.ssh.md5" "${homePath}/.ssh.md5" 0 || exit 1
- fileCheck "${homePath}/.ssh.md5"
- if [ ${__fileCheck} -eq 0 ]; then
- installFile "${path}/etc/sshkey/.ssh/authorized_keys" "${homePath}/.ssh/authorized_keys" 0 || exit 1
- installFile "${path}/etc/sshkey/.ssh/id_rsa" "${homePath}/.ssh/id_rsa" 0 || exit 1
- installFile "${path}/etc/sshkey/.ssh/id_rsa.pub" "${homePath}/.ssh/id_rsa.pub" 0 || exit 1
- fi
- else
- printf "SSH keys are already installed for user %-15s ..." "$user"
- log_success_msg
- fi
- # Added code to change environment.conf file user home directory location for key generation
- if [ "$homeBase" != "$home" ]; then
- sed -e "s;^[[:space:]]*home[[:space:]]*=.*$;home=$homeBase;" ${CONFIG_DIR}/${ENV_CONF_FILE} > temp.conf
- mv temp.conf ${CONFIG_DIR}/${ENV_CONF_FILE}
- fi
- # Setting up values for /etc/sudoers and /etc/security/limits.conf files
- ${path}/sbin/add_conf_settings.sh
- groupNum=`grep -w ${user} /etc/passwd | cut -d ':' -f 4`
- group=`grep -w ${groupNum} /etc/group | cut -d ':' -f 1`
- #Assigning correct permission for /User/hpcc
- chmod 700 ${homePath}/.ssh
- [ -e ${homePath}/.ssh/id_rsa.pub ] && chmod 600 ${homePath}/.ssh/id_rsa.pub
- chown -R $user:$group ${homePath}
- $path/sbin/add_conf_settings.sh
- confPath=${path}${CONFIG_DIR}
- if [ -d ${confPath} ]; then
- for i in $(find $confPath)
- do
- if [ -d $confPath/$i ]; then
- if [ -d $configs/$i ]; then
- for infile in $(find $confPath/$i)
- do
- cp $confPath/$i/$infile $configs/$i/$infile
- done
- else
- mkdir $configs/$i
- for infile in $(find $confPath/$i)
- do
- cp "$confPath/$i/$infile" "$configs/$i/$infile"
- done
- fi
- fi
- done
- fi
- chown root:$group ${configs}
- chown -R $user:$group ${configs}/*
- chmod 775 ${configs}
- # Add systemd support
- distrib_check
- if [ "${DISTRIB_NAME}" = "ubuntu" ] &&
- [ ${DISTRIB_MAJOR_VERSION} -ge 15 ]; then
- dpkg -l | grep -q -e "^ii[[:space:]]*systemd "
- if [ $? -eq 0 ]; then
- cp ${INSTALL_DIR}/etc/init.d/hpcc-init.service /lib/systemd/system/
- cp ${INSTALL_DIR}/etc/init.d/hpcc-init@.service /lib/systemd/system/
- cp ${INSTALL_DIR}/etc/init.d/dafilesrv.service /lib/systemd/system/
- cp ${INSTALL_DIR}/etc/init.d/dafilesrv@.service /lib/systemd/system/
- systemctl daemon-reload
- fi
- fi
- createRuntime
- [ -e ${LOG_DIR}/hpcc-init.debug ] && chown ${user}:${user} ${LOG_DIR}/hpcc-init.debug
- exit 0
|