#!/bin/sh

#reboot instead of turn to download mode when kernel panic
if [ x`cat /sys/class/android_usb/android0/download` = x"NORMAL" ]; then
    echo "default process for crash: reboot"
    echo 1 > /proc/sys/kernel/panic
    echo 0 > /sys/module/restart/parameters/download_mode
else
    echo "default process for crash: download"
fi

date -s "2012-04-01 00:00:00"
#zte_fota

#################### Factory Restore Function Begin ######################
factory_restore()
{
	echo "start restore configs." >> /tmp/restore.log
	#restore nvconfig
	rm /usr/zte/zte_conf/config/userseting_nvconfig.txt || echo "can not remove userseting_nvconfig.txt" >> /tmp/restore.log
	#restore dnsmasq
	rm /usr/zte/zte_conf/config/dnsmasq.conf || echo "can not remove /usr/zte/zte_conf/config/dnsmasq.conf" >> /tmp/restore.log
	cp /usr/zte_web/web/copy/etc/dnsmasq.conf /usr/zte/zte_conf/config/dnsmasq.conf || echo "can not copy /usr/zte_web/web/copy/etc/dnsmasq.conf" >> /tmp/restore.log
	#restore xxx
	rm /etc/factory_restore || echo "fatal error: can not remove flag /etc/factory_restore" >> /tmp/restore.log
	echo "restore configs finished." >> /tmp/restore.log
}

factory_restore_probe()
{
	if [ -f /etc/factory_restore ]; then
		echo "need restore configs..." >> /tmp/restore.log
		factory_restore
	else
	    echo "no need restore configs." >> /tmp/restore.log
	fi
}

userdata_restore_probe()
{
	#check if restore ztedata
	if [ -f /etc/userdata_restore_flag ]; then
		rm /etc/userdata_restore_flag || echo "fatal error: can not remove /etc/userdata_restore_flag" >> /tmp/restore.log
		echo "need restore userdata..." >> /tmp/restore.log
		######## restore sms and phonebook here ########
		rm /usr/zte/web/sms_db/sms.db || echo "can not remove /usr/zte/web/sms_db/sms.db" >> /tmp/restore.log
		rm /usr/zte/web/pbm_db/pbm.db || echo "can not remove /usr/zte/web/pbm_db/pbm.db" >> /tmp/restore.log
		######## restore userdata here ########
		echo "restore userdata finished." >> /tmp/restore.log
	else
		echo "no need restore userdata." >> /tmp/restore.log
	fi
}
### this must be the first to run ###
echo "checking for restore..." > /tmp/restore.log
echo "start time: `date`" >> /tmp/restore.log
userdata_restore_probe
factory_restore_probe
echo "end time  : `date`" >> /tmp/restore.log

#################### Factory Restore Function End ######################
set_passwd()
{
	echo "root:zte9x15" > /tmp/tmppw
	chpasswd < /tmp/tmppw
	rm -rf /tmp/tmppw
}
set_passwd
#start up telnetd for debug use
#telnetd
#Start ZTE syslog
zte_syslog_start()
{
  SYSLOG_CONFIG_FILE=/usr/zte/zte_conf/scripts/zte_syslog.conf
  
  if [ -f $SYSLOG_CONFIG_FILE ]; then
     syslog_mode=`sed -n '/syslog_mode=/'p $SYSLOG_CONFIG_FILE | sed 's/syslog_mode=//'`
     if [ $syslog_mode = 0 ]; then
        syslog_path=`sed -n '/syslog_path=/'p $SYSLOG_CONFIG_FILE | sed 's/syslog_path=//'`
        syslog_level=`sed -n '/syslog_level=/'p $SYSLOG_CONFIG_FILE | sed 's/syslog_level=//'`
        syslog_size=`sed -n '/syslog_size=/'p $SYSLOG_CONFIG_FILE | sed 's/syslog_size=//'`
        /usr/zte/zte_conf/scripts/zte_syslog.sh -L -o $syslog_path -l $syslog_level -s $syslog_size
     else
        syslog_host_ip=`sed -n '/syslog_host_ip=/'p $SYSLOG_CONFIG_FILE | sed 's/syslog_host_ip=//'`
        /usr/zte/zte_conf/scripts/zte_syslog.sh -R $syslog_host_ip
     fi
  else
      /usr/zte/zte_conf/scripts/zte_syslog.sh -L
  fi
}
zte_syslog_start
#################### Add zte programs below ####################
ifconfig lo up
zte_usb_ctl &

#cfg will start zte_topsw_daemon
zte_topsw_cfg &
zte_fota_vd &
zte_topsw_ota &
zte_report_server &
#zte_topsw_sleep &
start-stop-daemon -S -b -a /sbin/adbd
