#!/bin/sh /etc/rc.common
# Copyright (C) 2006 OpenWrt.org

START=10

system_config() {
	local cfg="$1"
	local hostname
	
	config_get hostname "$cfg" hostname
	echo "${hostname:-Vigor2130}" > /proc/sys/kernel/hostname

	config_get conloglevel "$cfg" conloglevel
	[ -n "$conloglevel" ] && dmesg -n "$conloglevel"
	
	config_get timezone "$cfg" timezone 
	[ -z "$timezone" ] && timezone=UTC
	echo "$timezone" > /tmp/TZ

	config_get log_ip "$cfg" log_ip 
	config_get log_size "$cfg" log_size
	config_get log_port "$cfg" log_port
	config_get log_level "$cfg" log_level
	config_get log_enable "$cfg" log_enable
	if [ "$log_enable" = "1" ]; then 
		syslogd -C${log_size:-16} -l ${log_level:-8} ${log_ip:+-L -R $log_ip:${log_port:-514}}
	else
		syslogd -C${log_size:-16}
	fi
	klogd
}

apply_uci_config() {(
	include /lib/config
	uci_apply_defaults
)}

start() {
    
	[ -f /jffs/etc/config/firewall ] && {
		cp /rom/etc/config/firewall /etc/config/firewall
		rm /jffs/etc/config/firewall
    }
	
	#V1000
	# sn2 101 - Glasoperator
	# sn2 200 - Retail
	# sn2 200 sn3 105 - Unet
	# sn2 103 - Vodafone
	# sn2 106 - CBizz
	#V2130F
	# sn2 102 - Glasoperator
	# sn2 104 - Vodafone
	# sn2 107 - CBizz
	# And have 3 cfg file
	# 1: 101&102
	# 2: 103&104
	sn2=$(strings /dev/mtdblock2 | grep -E "sn2=101|sn2=102|sn2=103|sn2=104|sn2=106|sn2=107")
	if [ "$sn2" != "" ]; then
		CHIPID_2880=18140801
		if [ "$sn2" == "sn2=106" -o "$sn2" == "sn2=107" ]; then
			sn2file="_106_107"
		else
			sn2file=""
		fi
		[ -e /etc/G1K_default"$sn2file".tar.gz ] && {
			[ -e /etc/model.sn2 ] || { 
				tar -xzf /etc/G1K_default"$sn2file".tar.gz -C /
				echo "Apply default configuration for model $sn2 ....." >/dev/console
				logger "Apply default configuration for model $sn2"
				
				if [ "$sn2" == "sn2=103" -o "$sn2" == "sn2=104" -o "$sn2" == "sn2=106" -o "$sn2" == "sn2=107" ]; then
					rm /etc/config/wireless		# remove to apply default
				fi
			}
		}
		devid=$(cat /proc/bus/pci/devices | cut -f2)
		echo "$devid" | grep -q $CHIPID_2880 || {
			sed -i 's/rt2880/rt3062/g' /etc/config/wireless
		}
		
		if [ "$sn2" == "sn2=102" -o "$sn2" == "sn2=104" -o "$sn2" == "sn2=107" ]; then
			uci set system.@system[0].hostname=Vigor2130
			uci commit system
		fi
		
		# config upgrade for nocadmin 
		grep -q "^nocadmin" /etc/httpusers.conf || {
			echo "nocadmin:Vigor:b3da085ac1495efb4acdceb88bd89c44" >> /etc/httpusers.conf
		}
		grep -q "^nocadmin" /etc/passwd || {
			echo 'nocadmin:$1$15kWEq6V$gAg.bsGw/OXVOZlVNYzda0:65537:65534:6hSMxIczcWUuhOoZl0lD:/home/nocadmin:/bin/ash' >> /etc/passwd
			echo 'nocadmin:*:65537:65534:6hSMxIczcWUuhOoZl0lD:/home/nocadmin:/bin/ash' >> /etc/passwd-
		}
	fi
	[ -e /etc/G1K_default.tar.gz ] && {
		rm /etc/G1K_default.tar.gz
	}
	[ -e /etc/G1K_default"$sn2file".tar.gz ] && {
		rm /etc/G1K_default"$sn2file".tar.gz
	}
	
	sn3=$(strings /dev/mtdblock2 | grep sn3= | cut -d '=' -f 2)
	[ -e /etc/"$sn3"_default.tar.gz ] && {
		CHIPID_2880=18140801
		[ -e /etc/model.sn2 ] || { 
			tar -xzf /etc/"$sn3"_default.tar.gz -C /
			echo "Apply default configuration for model $sn3 ....." >/dev/console
			logger "Apply default configuration for model $sn3"
		}
		devid=$(cat /proc/bus/pci/devices | cut -f2)
		echo "$devid" | grep -q $CHIPID_2880 || {
			sed -i 's/rt2880/rt3062/g' /etc/config/wireless
		}		
	}	
	[ -e /etc/"$sn3"_default.tar.gz ] && {
		rm /etc/"$sn3"_default.tar.gz
	}
	
	[ "$(strings /etc/model.sn2 2> /dev/null)" == "" ] && { 
		sn1=$(strings /dev/mtdblock2 | grep sn1= | cut -d '=' -f 2)
		uci set system.@system[0].sn1=$sn1
		sn2=$(strings /dev/mtdblock2 | grep sn2= | cut -d '=' -f 2)
		uci set system.@system[0].sn2=$sn2
		uci commit system
		case "$sn2" in
			101|200|103|106)
				echo "Vigor1000" > /etc/model.sn2
				;;
			*)
				[ -e /lib/modules/2.6.23.17/vdsl.ko ] && {
					echo "Vigor2750" > /etc/model.sn2
				} || {
					echo "Vigor2130" > /etc/model.sn2
				}
				;;
		esac
	}


	[ -e /mnt/usb_disk1 ] && {
		rm -f /mnt/usb_disk1
    }
	[ -f /proc/mounts ] || /sbin/mount_root
	[ -f /proc/jffs2_bbc ] && echo "S" > /proc/jffs2_bbc
	[ -f /proc/net/vlan/config ] && vconfig set_name_type DEV_PLUS_VID_NO_PAD

	apply_uci_config
	config_load system
	config_foreach system_config system
	
	mkdir -p /var/run
	mkdir -p /var/log
	mkdir -p /var/lock
	mkdir -p /var/state
	mkdir -p /tmp/pppoe.info
	mkdir -p /tmp/.uci
	chown 0700 /tmp/.uci
	touch /var/log/wtmp
	touch /var/log/lastlog
	touch /tmp/resolv.conf.auto
	ln -sf /tmp/resolv.conf.auto /tmp/resolv.conf
	[ "$FAILSAFE" = "true" ] && touch /tmp/.failsafe

	killall -q hotplug2
	[ -x /sbin/hotplug2 ] && /sbin/hotplug2 --override --persistent \
						--set-worker /lib/hotplug2/worker_fork.so \
						--set-rules-file /etc/hotplug2.rules \
						--max-children 1 >/dev/null 2>&1 &


	# the coldplugging of network interfaces needs to happen later, so we do it manually here
	for iface in $(awk -F: '/:/ {print $1}' /proc/net/dev); do
		/usr/bin/env -i ACTION=add INTERFACE="$iface" /sbin/hotplug-call net
	done

	# create /dev/root if it doesn't exist
	[ -e /dev/root ] || {
		rootdev=$(awk 'BEGIN { RS=" "; FS="="; } $1 == "root" { print $2 }' < /proc/cmdline)
		[ -n "$rootdev" ] && ln -s "$rootdev" /dev/root
	}

    rt=`cat /etc/iproute2/rt_tables | grep "1 wan"` 
	[ -z "$rt" ] && echo "1 wan" >> /etc/iproute2/rt_tables
	rt=`cat /etc/iproute2/rt_tables | grep "2 wan2"` 
	[ -z "$rt" ] && echo "2 wan2" >> /etc/iproute2/rt_tables
	rt=`cat /etc/iproute2/rt_tables | grep "3 voipwan"` 
	[ -z "$rt" ] && echo "3 voipwan" >> /etc/iproute2/rt_tables
	rt=`cat /etc/iproute2/rt_tables | grep "4 iptvwan"` 
	[ -z "$rt" ] && echo "4 iptvwan" >> /etc/iproute2/rt_tables
	rt=`cat /etc/iproute2/rt_tables | grep "5 mngtwan"` 
	[ -z "$rt" ] && echo "5 mngtwan" >> /etc/iproute2/rt_tables
	rt=`cat /etc/iproute2/rt_tables | grep "100 policy_route"` 
	[ -z "$rt" ] && echo "100 policy_route" >> /etc/iproute2/rt_tables
	
	load_modules /etc/modules.d/*
}
