--- alx-src/trunk/alxconfig-ng/init.d/alxsetstate 2005/10/09 21:34:47 346 +++ alx-src/trunk/alxconfig-ng/init.d/alxsetstate 2005/10/09 21:35:27 347 @@ -9,26 +9,26 @@ #%before: #%after: -# $Header: /home/cvsd/alx-cvs/alx-src/alxconfig-ng/init.d/alxsetstate,v 1.8 2005-08-28 19:30:25 niro Exp $ +# $Header: /home/cvsd/alx-cvs/alx-src/alxconfig-ng/init.d/alxsetstate,v 1.9 2005-10-09 21:35:27 niro Exp $ source /etc/sysconfig/rc source $rc_functions -#mysql settings +# mysql settings source /etc/alxconfig-ng/config.rc source /usr/lib/alxconfig-ng/functions/mysqlfunctions source /usr/lib/alxconfig-ng/functions/serial_functions -#check if mysql is available +# check if mysql is available [ -x /usr/bin/mysql ] && MYSQL_ALX=true -#other needed vars +# other needed vars ALX_HW_DETECT=false -#unset vars which may kill us -unset ALX_SERIAL ALX_STATE +# unset vars which may kill us +unset ALX_SERIAL ALX_STATE ALX_IFACE -#get current system state +# get current system state if [ -f /etc/alxconfig-ng/state/state ] then source /etc/alxconfig-ng/state/state @@ -36,16 +36,19 @@ ALX_STATE=error fi +[[ -z ${ALX_IFACE} ]] && export ALX_IFACE=eth0 + # need to put this to an extra init script which will be # executed when the real network is up and not the preliminary. # nice name is alx_connected_state or sth like this -set_current_network_state(){ +set_current_network_state() +{ local CUR_IP CUR_MAC ID echo -e ${COLMAGENTA}"Register system to database"${COLDEFAULT} - CUR_IP=$(/sbin/ifconfig eth0 | sed -n '/addr:/s/ [^r]*..//gp') - CUR_MAC=$(/sbin/ifconfig eth0 | grep HWaddr | cut -d ' ' -f11) + CUR_IP=$(/sbin/ifconfig ${ALX_IFACE} | sed -n '/addr:/s/ [^r]*..//gp') + CUR_MAC=$(/sbin/ifconfig ${ALX_IFACE} | grep HWaddr | cut -d ' ' -f11) CUR_MTIME=$(date +%s) # validate current serial @@ -58,22 +61,20 @@ exit 1 fi - #first check if an entry exist with my serial + # first check if an entry exist with my serial # if it exist update this entry else insert a new one - ID=$(mysql_command ${SQL_USER} ${SQL_PASS} ${SQL_HOST} ${SQL_DB} \ - "select serial from state_connected where serial=${ALX_SERIAL};") + ID=$(mysqldo "select serial from state_connected where serial=${ALX_SERIAL};") if [ -n "${ID}" ] then - #run an update + # run an update - #nice status + # nice status $CURS_UP $SET_WCOL echo "[ U, State: ${ALX_STATE} ]" - mysql_command ${SQL_USER} ${SQL_PASS} ${SQL_HOST} ${SQL_DB} \ - "update state_connected set + mysqldo "update state_connected set hostname='${HOSTNAME}', ip='${CUR_IP}', mac='${CUR_MAC}', @@ -81,15 +82,14 @@ mtime='${CUR_MTIME}' where serial=${ALX_SERIAL};" else - #run an insert + # run an insert - #nice status + # nice status $CURS_UP $SET_WCOL echo "[ N, State: ${ALX_STATE} ]" - mysql_command ${SQL_USER} ${SQL_PASS} ${SQL_HOST} ${SQL_DB} \ - "insert into state_connected( + mysqldo "insert into state_connected( serial, hostname, ip, @@ -112,22 +112,23 @@ # need to put this to an extra init script which will # be executed first when the system is going down. # nice name is alx_connected_state or sth like this -unset_alx_connected(){ +unset_alx_connected() +{ local SQL_OPTS local CUR_MAC - CUR_MAC=$(/sbin/ifconfig eth0 | grep HWaddr | cut -d ' ' -f11) + CUR_MAC=$(/sbin/ifconfig ${ALX_IFACE} | grep HWaddr | cut -d ' ' -f11) echo -e ${COLMAGENTA}"Unregister system from database"${COLDEFAULT} - mysql_command ${SQL_USER} ${SQL_PASS} ${SQL_HOST} ${SQL_DB} \ - "delete from state_connected where serial='${ALX_SERIAL}' and mac='${CUR_MAC}';" + mysqldo "delete from state_connected where serial='${ALX_SERIAL}' and mac='${CUR_MAC}';" evaluate_retval } + ########### starts here ################ -#first of all get current system serial +# first of all get current system serial if [ -f /etc/alxconfig-ng/serial ] then source /etc/alxconfig-ng/serial @@ -135,7 +136,6 @@ ALX_SERIAL=0 fi - case $1 in start) # check if mysql server is reachable