2005-04-29 20:24:44 +02:00
|
|
|
#!/bin/sh
|
|
|
|
|
2005-08-16 12:04:13 +02:00
|
|
|
RunUser=firebird
|
|
|
|
export RunUser
|
2006-04-16 14:58:29 +02:00
|
|
|
RunGroup=firebird
|
|
|
|
export RunGroup
|
|
|
|
PidDir=/var/run/firebird
|
|
|
|
export PidDir
|
2005-08-16 12:04:13 +02:00
|
|
|
|
2005-04-29 20:24:44 +02:00
|
|
|
#------------------------------------------------------------------------
|
|
|
|
# Add new user and group
|
|
|
|
|
|
|
|
TryAddGroup() {
|
|
|
|
|
|
|
|
AdditionalParameter=$1
|
|
|
|
testStr=`grep firebird /etc/group`
|
|
|
|
|
|
|
|
if [ -z "$testStr" ]
|
|
|
|
then
|
|
|
|
groupadd $AdditionalParameter firebird
|
|
|
|
fi
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TryAddUser() {
|
|
|
|
|
|
|
|
AdditionalParameter=$1
|
2005-05-05 10:39:12 +02:00
|
|
|
testStr=`grep firebird /etc/passwd`
|
2005-04-29 20:24:44 +02:00
|
|
|
|
|
|
|
if [ -z "$testStr" ]
|
|
|
|
then
|
2007-03-09 14:32:17 +01:00
|
|
|
useradd $AdditionalParameter -d $FBRootDir -s /bin/false \
|
2005-04-29 20:24:44 +02:00
|
|
|
-c "Firebird Database Owner" -g firebird firebird
|
|
|
|
fi
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
addFirebirdUser() {
|
|
|
|
|
|
|
|
TryAddGroup "-g 84 -r" >/dev/null 2>&1
|
|
|
|
TryAddGroup "-g 84" >/dev/null 2>&1
|
|
|
|
TryAddGroup "-r" >/dev/null 2>&1
|
|
|
|
TryAddGroup " "
|
|
|
|
|
2007-03-09 14:32:17 +01:00
|
|
|
TryAddUser "-u 84 -r -M" >/dev/null 2>&1
|
|
|
|
TryAddUser "-u 84 -M" >/dev/null 2>&1
|
|
|
|
TryAddUser "-r -M" >/dev/null 2>&1
|
2008-01-17 12:36:15 +01:00
|
|
|
TryAddUser "-M" >/dev/null 2>&1
|
2005-04-29 20:24:44 +02:00
|
|
|
TryAddUser "-u 84 -r" >/dev/null 2>&1
|
|
|
|
TryAddUser "-u 84" >/dev/null 2>&1
|
|
|
|
TryAddUser "-r" >/dev/null 2>&1
|
|
|
|
TryAddUser " "
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2005-08-16 12:04:13 +02:00
|
|
|
|
|
|
|
#------------------------------------------------------------------------
|
|
|
|
# Detect Distribution.
|
|
|
|
# AP: very beautiful, but unused. Let's keep alive for a while. (2005)
|
|
|
|
|
|
|
|
detectDistro() {
|
|
|
|
|
|
|
|
# it's not provided...
|
|
|
|
if [ -z "$linuxDistro" ]
|
|
|
|
then
|
|
|
|
if [ -e /etc/SuSE-release ]
|
|
|
|
then
|
|
|
|
# SuSE
|
|
|
|
linuxDistro="SuSE"
|
|
|
|
elif [ -e /etc/mandrake-release ]
|
|
|
|
then
|
|
|
|
# Mandrake
|
|
|
|
linuxDistro="MDK"
|
|
|
|
elif [ -e /etc/debian_version ]
|
|
|
|
then
|
|
|
|
# Debian
|
|
|
|
linuxDistro="Debian"
|
|
|
|
elif [ -e /etc/gentoo-release ]
|
|
|
|
then
|
|
|
|
# Debian
|
|
|
|
linuxDistro="Gentoo"
|
|
|
|
elif [ -e /etc/rc.d/init.d/functions ]
|
|
|
|
then
|
|
|
|
# very likely Red Hat
|
|
|
|
linuxDistro="RH"
|
|
|
|
elif [ -d /etc/rc.d/init.d ]
|
|
|
|
then
|
|
|
|
# generic Red Hat
|
|
|
|
linuxDistro="G-RH"
|
|
|
|
elif [ -d /etc/init.d ]
|
|
|
|
then
|
|
|
|
# generic SuSE
|
|
|
|
linuxDistro="G-SuSE"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#------------------------------------------------------------------------
|
|
|
|
# print location of init script
|
|
|
|
|
|
|
|
getInitScriptLocation() {
|
|
|
|
if [ -f /etc/rc.d/init.d/firebird ]
|
|
|
|
then
|
|
|
|
echo -n /etc/rc.d/init.d/firebird
|
2006-04-24 12:08:16 +02:00
|
|
|
elif [ -f /etc/rc.d/rc.firebird ]
|
|
|
|
then
|
|
|
|
echo -n /etc/rc.d/rc.firebird
|
2005-08-16 12:04:13 +02:00
|
|
|
elif [ -f /etc/init.d/firebird ]
|
|
|
|
then
|
|
|
|
echo -n /etc/init.d/firebird
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#------------------------------------------------------------------------
|
|
|
|
# stop super server if it is running
|
|
|
|
|
|
|
|
stopSuperServerIfRunning() {
|
2007-03-09 14:32:17 +01:00
|
|
|
checkString=`ps -efww| egrep "\b(fbserver|fbguard)\b" |grep -v grep`
|
2005-08-16 12:04:13 +02:00
|
|
|
|
|
|
|
if [ ! -z "$checkString" ]
|
|
|
|
then
|
|
|
|
init_d=`getInitScriptLocation`
|
|
|
|
|
2006-04-16 14:58:29 +02:00
|
|
|
if [ -x "$init_d" ]
|
2005-08-16 12:04:13 +02:00
|
|
|
then
|
2008-05-04 17:18:42 +02:00
|
|
|
i=1
|
|
|
|
while [ $i -le 20 ]
|
|
|
|
do
|
|
|
|
$init_d stop
|
|
|
|
sleep 1
|
|
|
|
checkString=`ps -efww| egrep "\b(fbserver|fbguard)\b" |grep -v grep`
|
|
|
|
if [ -z "$checkString" ]
|
|
|
|
then
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
i=$((i+1))
|
|
|
|
done
|
2005-08-16 12:04:13 +02:00
|
|
|
fi
|
|
|
|
fi
|
|
|
|
}
|
2008-01-09 12:05:20 +01:00
|
|
|
|
|
|
|
#------------------------------------------------------------------------
|
|
|
|
# Generate new sysdba password - this routine is used only in the
|
|
|
|
# rpm file not in the install script.
|
|
|
|
|
|
|
|
generateNewDBAPassword() {
|
|
|
|
# openssl generates random data.
|
|
|
|
openssl </dev/null >/dev/null 2&>/dev/null
|
|
|
|
if [ $? -eq 0 ]
|
|
|
|
then
|
|
|
|
# We generate 20 random chars, strip any '/''s and get the first 8
|
|
|
|
NewPasswd=`openssl rand -base64 20 | tr -d '/' | cut -c1-8`
|
|
|
|
fi
|
|
|
|
|
|
|
|
# mkpasswd is a bit of a hassle, but check to see if it's there
|
|
|
|
if [ -z "$NewPasswd" ]
|
|
|
|
then
|
|
|
|
if [ -f /usr/bin/mkpasswd ]
|
|
|
|
then
|
|
|
|
NewPasswd=`/usr/bin/mkpasswd -l 8`
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
# On some systems the mkpasswd program doesn't appear and on others
|
|
|
|
# there is another mkpasswd which does a different operation. So if
|
|
|
|
# the specific one isn't available then keep the original password.
|
|
|
|
if [ -z "$NewPasswd" ]
|
|
|
|
then
|
|
|
|
NewPasswd="masterkey"
|
|
|
|
fi
|
|
|
|
|
|
|
|
writeNewPassword $NewPasswd
|
|
|
|
}
|