add new rc.common for standardized init scripts, convert existing init scripts

SVN-Revision: 4915
This commit is contained in:
Felix Fietkau 2006-10-04 20:05:48 +00:00
parent 1bb321cbec
commit af5f6ac550
16 changed files with 1152 additions and 1024 deletions

View File

@ -1,8 +1,12 @@
#!/bin/sh #!/bin/sh /etc/rc.common
# ADAM2 patcher for Netgear DG834 and compatible # ADAM2 patcher for Netgear DG834 and compatible
MD5="$(md5sum /dev/mtdblock/0 | awk '{print $1}')" # Copyright (C) 2006 OpenWrt.org
[ "$MD5" = "0530bfdf00ec155f4182afd70da028c1" ] && {
start() {
MD5="$(md5sum /dev/mtdblock/0 | awk '{print $1}')"
[ "$MD5" = "0530bfdf00ec155f4182afd70da028c1" ] && {
mtd unlock adam2 mtd unlock adam2
/sbin/adam2patcher /dev/mtdblock/0 /sbin/adam2patcher /dev/mtdblock/0
}
rm -f /etc/init.d/S00adam2 /sbin/adam2patcher >&- 2>&-
} }
rm -f /etc/init.d/S00adam2 /sbin/adam2patcher >&- 2>&-

View File

@ -1,35 +1,36 @@
#!/bin/sh #!/bin/sh /etc/rc.common
# Copyright (C) 2006 OpenWrt.org # Copyright (C) 2006 OpenWrt.org
[ -e /etc/config/network ] && exit 0 start() {
[ -e /etc/config/network ] && exit 0
mkdir -p /etc/config mkdir -p /etc/config
( (
if grep -E 'mtd0: 000(6|a)0000' /proc/mtd 2>&- >&-; then if grep -E 'mtd0: 000(6|a)0000' /proc/mtd 2>&- >&-; then
# WGT634u # WGT634u
echo boardtype=wgt634u echo boardtype=wgt634u
else else
strings /dev/mtdblock/3 strings /dev/mtdblock/3
fi fi
) | awk ' ) | awk '
function p(cfgname, name) { function p(cfgname, name) {
if (c[name] != "") print " option " cfgname " \"" c[name] "\"" if (c[name] != "") print " option " cfgname " \"" c[name] "\""
} }
BEGIN { BEGIN {
FS="=" FS="="
c["lan_ifname"]="eth0.0 wl0" c["lan_ifname"]="eth0.0 wl0"
c["wan_ifname"]="eth0.1" c["wan_ifname"]="eth0.1"
c["vlan0ports"]="1 2 3 4 5*" c["vlan0ports"]="1 2 3 4 5*"
c["vlan1ports"]="0 5" c["vlan1ports"]="0 5"
} }
($1 == "boardnum") || ($1 == "boardtype") || ($1 == "boardflags") { ($1 == "boardnum") || ($1 == "boardtype") || ($1 == "boardflags") {
nvram[$1] = $2 nvram[$1] = $2
} }
END { END {
# v1 hardware # v1 hardware
if (nvram["boardtype"] == "bcm94710dev") { if (nvram["boardtype"] == "bcm94710dev") {
# Asus WL-500g # Asus WL-500g
@ -82,5 +83,5 @@ END {
print "config interface wan" print "config interface wan"
p("ifname", "wan_ifname") p("ifname", "wan_ifname")
print " option proto dhcp" print " option proto dhcp"
}' > /etc/config/network
} }
' > /etc/config/network

View File

@ -1,35 +1,36 @@
#!/bin/sh #!/bin/sh /etc/rc.common
# Copyright (C) 2006 OpenWrt.org # Copyright (C) 2006 OpenWrt.org
[ -e /etc/config/network ] && exit 0 start() {
[ -e /etc/config/network ] && exit 0
mkdir -p /etc/config mkdir -p /etc/config
( (
if grep -E 'mtd0: 000(6|a)0000' /proc/mtd 2>&- >&-; then if grep -E 'mtd0: 000(6|a)0000' /proc/mtd 2>&- >&-; then
# WGT634u # WGT634u
echo boardtype=wgt634u echo boardtype=wgt634u
else else
strings /dev/mtdblock/3 strings /dev/mtdblock/3
fi fi
) | awk ' ) | awk '
function p(cfgname, name) { function p(cfgname, name) {
if (c[name] != "") print " option " cfgname " \"" c[name] "\"" if (c[name] != "") print " option " cfgname " \"" c[name] "\""
} }
BEGIN { BEGIN {
FS="=" FS="="
c["lan_ifname"]="eth0.0 wl0" c["lan_ifname"]="eth0.0 wl0"
c["wan_ifname"]="eth0.1" c["wan_ifname"]="eth0.1"
c["vlan0ports"]="1 2 3 4 5*" c["vlan0ports"]="1 2 3 4 5*"
c["vlan1ports"]="0 5" c["vlan1ports"]="0 5"
} }
($1 == "boardnum") || ($1 == "boardtype") || ($1 == "boardflags") { ($1 == "boardnum") || ($1 == "boardtype") || ($1 == "boardflags") {
nvram[$1] = $2 nvram[$1] = $2
} }
END { END {
# v1 hardware # v1 hardware
if (nvram["boardtype"] == "bcm94710dev") { if (nvram["boardtype"] == "bcm94710dev") {
# Asus WL-500g # Asus WL-500g
@ -82,5 +83,5 @@ END {
print "config interface wan" print "config interface wan"
p("ifname", "wan_ifname") p("ifname", "wan_ifname")
print " option proto dhcp" print " option proto dhcp"
}' > /etc/config/network
} }
' > /etc/config/network

View File

@ -1,25 +1,25 @@
#!/bin/sh #!/bin/sh /etc/rc.common
# Copyright (C) 2006 OpenWrt.org # Copyright (C) 2006 OpenWrt.org
. /etc/functions.sh start() {
[ -f /proc/mounts ] || /sbin/mount_root
[ -f /proc/jffs2_bbc ] && echo "S" > /proc/jffs2_bbc
vconfig set_name_type DEV_PLUS_VID_NO_PAD
[ -f /proc/mounts ] || /sbin/mount_root HOSTNAME=${wan_hostname%%.*}
[ -f /proc/jffs2_bbc ] && echo "S" > /proc/jffs2_bbc echo ${HOSTNAME:=OpenWrt}>/proc/sys/kernel/hostname
vconfig set_name_type DEV_PLUS_VID_NO_PAD
HOSTNAME=${wan_hostname%%.*} mkdir -p /var/run
echo ${HOSTNAME:=OpenWrt}>/proc/sys/kernel/hostname mkdir -p /var/log
mkdir -p /var/lock
touch /var/log/wtmp
touch /var/log/lastlog
[ "$FAILSAFE" = "true" ] && touch /tmp/.failsafe
mkdir -p /var/run # manually trigger hotplug before loading modules
mkdir -p /var/log for iface in $(awk -F: '/:/ {print $1}' /proc/net/dev); do
mkdir -p /var/lock
touch /var/log/wtmp
touch /var/log/lastlog
[ "$FAILSAFE" = "true" ] && touch /tmp/.failsafe
# manually trigger hotplug before loading modules
for iface in $(awk -F: '/:/ {print $1}' /proc/net/dev); do
/usr/bin/env -i ACTION=add INTERFACE="$iface" /sbin/hotplug net /usr/bin/env -i ACTION=add INTERFACE="$iface" /sbin/hotplug net
done done
load_modules /etc/modules /etc/modules.d/* load_modules /etc/modules /etc/modules.d/*
}

View File

@ -1,9 +1,11 @@
#!/bin/sh #!/bin/sh /etc/rc.common
# Copyright (C) 2006 OpenWrt.org # Copyright (C) 2006 OpenWrt.org
setup_switch() { return 0; } start() {
setup_switch() { return 0; }
include /lib/network
setup_switch
/sbin/wifi
}
. /etc/functions.sh
include /lib/network
setup_switch
/sbin/wifi

View File

@ -1,4 +1,10 @@
#!/bin/sh #!/bin/sh /etc/rc.common
# Copyright (C) 2006 OpenWrt.org # Copyright (C) 2006 OpenWrt.org
[ -d /www ] && httpd -p 80 -h /www -r OpenWrt start() {
[ -d /www ] && httpd -p 80 -h /www -r OpenWrt
}
stop() {
killall httpd
}

View File

@ -1,4 +1,10 @@
#!/bin/sh #!/bin/sh /etc/rc.common
# Copyright (C) 2006 OpenWrt.org # Copyright (C) 2006 OpenWrt.org
if awk -F: '/^root:/ && $2 !~ /\!/ {exit 1}' /etc/passwd 2>/dev/null; then telnetd -l /bin/login; fi start() {
if awk -F: '/^root:/ && $2 !~ /\!/ {exit 1}' /etc/passwd 2>/dev/null; then telnetd -l /bin/login; fi
}
stop() {
killall telnetd
}

View File

@ -1,6 +1,12 @@
#!/bin/sh #!/bin/sh /etc/rc.common
# Copyright (C) 2006 OpenWrt.org # Copyright (C) 2006 OpenWrt.org
mkdir -p /var/spool/cron start () {
ln -s /etc/crontabs /var/spool/cron/crontabs mkdir -p /var/spool/cron
crond -c /etc/crontabs ln -s /etc/crontabs /var/spool/cron/crontabs
crond -c /etc/crontabs
}
stop() {
killall crond
}

View File

@ -1,11 +0,0 @@
#!/bin/sh
# Copyright (C) 2006 OpenWrt.org
sysctl -p >&-
# automagically run firstboot
{ mount|grep "on / type tmpfs" 1>&-; } && {
lock /tmp/.switch2jffs
firstboot switch2jffs
lock -u /tmp/.switch2jffs
}

View File

@ -10,6 +10,17 @@ ${FAILSAFE:+exit}
syslogd -C 16 #${log_ipaddr:+-L -R $log_ipaddr} syslogd -C 16 #${log_ipaddr:+-L -R $log_ipaddr}
klogd klogd
for i in /etc/init.d/S*; do (
for i in /etc/init.d/S*; do
$i start 2>&1 $i start 2>&1
done | logger -s -p 6 -t '' & done
sysctl -p >&-
# automagically run firstboot
{ mount|grep "on / type tmpfs" 1>&-; } && {
lock /tmp/.switch2jffs
firstboot switch2jffs
lock -u /tmp/.switch2jffs
}
) | logger -s -p 6 -t '' &

View File

@ -0,0 +1,77 @@
#!/bin/sh
. /etc/functions.sh
start() {
return 0
}
stop() {
return 0
}
reload() {
return 1
}
restart() {
stop
start
}
boot() {
start
}
shutdown() {
return 0
}
disable() {
rm -f /etc/rc.d/${initscript##*/}
}
enable() {
disable
ln -s /etc/init.d/${initscript##*/} /etc/rc.d/${initscript##*/}
}
depends() {
return 0
}
help() {
cat <<EOF
Syntax: $0 [command]
Available commands:
start Start the service
stop Stop the service
restart Restart the service
reload Reload configuration files (or restart if that fails)
enable Enable the service (load at boot time)
disable Disable the service
$EXTRA_HELP
EOF
}
initscript="$1"
action="$2"
. "$initscript"
cmds=
for cmd in $EXTRA_COMMANDS; do
cmds="$cmd) $cmd;;"
done
eval "case \"\$action\" in
start) start;;
stop) stop;;
reload) reload || restart;;
restart) restart;;
enable) enable;;
disable) disable;;
boot) boot;;
shutdown) shutdown;;
$cmds
*) help;;
esac"

View File

@ -1,30 +1,32 @@
#!/bin/sh #!/bin/sh /etc/rc.common
. /etc/functions.sh # Copyright (C) 2006 OpenWrt.org
include /lib/network
scan_interfaces
# The following is to automatically configure the DHCP settings start() {
# based on config settings. Feel free to replace all this crap include /lib/network
# with a simple "dnsmasq" and manage everything via the scan_interfaces
# /etc/dnsmasq.conf config file
[ -f /etc/dnsmasq.conf ] || exit # The following is to automatically configure the DHCP settings
# based on config settings. Feel free to replace all this crap
# with a simple "dnsmasq" and manage everything via the
# /etc/dnsmasq.conf config file
args="" [ -f /etc/dnsmasq.conf ] || exit
iface=lan
config_get ifname "$iface" ifname
config_get proto "$iface" proto
[ "$proto" = static ] && dhcp_enable="${dhcp_enable:-1}" args=""
dhcp_start="${dhcp_start:-100}" iface=lan
dhcp_num="${dhcp_num:-50}" config_get ifname "$iface" ifname
dhcp_lease="${dhcp_lease:-12h}" config_get proto "$iface" proto
# if dhcp_enable is unset and there is a dhcp server on the network already, default to dhcp_enable=0 [ "$proto" = static ] && dhcp_enable="${dhcp_enable:-1}"
[ -z "$dhcp_enable" ] && udhcpc -n -q -R -s /bin/true -i $ifname >&- && dhcp_enable="${dhcp_enable:-0}" dhcp_start="${dhcp_start:-100}"
dhcp_num="${dhcp_num:-50}"
dhcp_lease="${dhcp_lease:-12h}"
# dhcp_enable=0 disables the dhcp server # if dhcp_enable is unset and there is a dhcp server on the network already, default to dhcp_enable=0
( [ -z "$dhcp_enable" ] && udhcpc -n -q -R -s /bin/true -i $ifname >&- && dhcp_enable="${dhcp_enable:-0}"
# dhcp_enable=0 disables the dhcp server
(
[ -z "$dhcp_enable" -o "$dhcp_enable" -eq 1 ] && { [ -z "$dhcp_enable" -o "$dhcp_enable" -eq 1 ] && {
# no existing DHCP server? # no existing DHCP server?
@ -47,4 +49,9 @@ dhcp_lease="${dhcp_lease:-12h}"
[ -z "$wan_proto" -o "$wan_proto" = "none" ] || echo "@define wan_ifname $wan_ifname" [ -z "$wan_proto" -o "$wan_proto" = "none" ] || echo "@define wan_ifname $wan_ifname"
cat /etc/dnsmasq.conf cat /etc/dnsmasq.conf
) | awk -f /usr/lib/parse-config.awk | dnsmasq -C /proc/self/fd/0 ) | awk -f /usr/lib/parse-config.awk | dnsmasq -C /proc/self/fd/0
}
stop() {
killall dnsmasq
}

View File

@ -1,6 +1,8 @@
#!/bin/sh #!/bin/sh /etc/rc.common
# Copyright (C) 2006 OpenWrt.org
for type in rsa dss; do { start() {
for type in rsa dss; do {
# check for keys # check for keys
key=/etc/dropbear/dropbear_${type}_host_key key=/etc/dropbear/dropbear_${type}_host_key
[ ! -f $key ] && { [ ! -f $key ] && {
@ -11,6 +13,7 @@ for type in rsa dss; do {
} & } &
exit 0 exit 0
} }
}; done }; done
/usr/sbin/dropbear /usr/sbin/dropbear
}

View File

@ -1,34 +1,34 @@
#!/bin/sh #!/bin/sh /etc/rc.common
# Copyright (C) 2006 OpenWrt.org # Copyright (C) 2006 OpenWrt.org
## Please make changes in /etc/firewall.user ## Please make changes in /etc/firewall.user
. /etc/functions.sh start() {
include /lib/network include /lib/network
scan_interfaces
scan_interfaces config_get WAN wan ifname
config_get WAN wan ifname config_get LAN lan ifname
config_get LAN lan ifname
## CLEAR TABLES ## CLEAR TABLES
for T in filter nat; do for T in filter nat; do
iptables -t $T -F iptables -t $T -F
iptables -t $T -X iptables -t $T -X
done done
iptables -N input_rule iptables -N input_rule
iptables -N output_rule iptables -N output_rule
iptables -N forwarding_rule iptables -N forwarding_rule
iptables -t nat -N prerouting_rule iptables -t nat -N prerouting_rule
iptables -t nat -N postrouting_rule iptables -t nat -N postrouting_rule
iptables -N LAN_ACCEPT iptables -N LAN_ACCEPT
[ -z "$WAN" ] || iptables -A LAN_ACCEPT -i "$WAN" -j RETURN [ -z "$WAN" ] || iptables -A LAN_ACCEPT -i "$WAN" -j RETURN
iptables -A LAN_ACCEPT -j ACCEPT iptables -A LAN_ACCEPT -j ACCEPT
### INPUT ### INPUT
### (connections with the router as destination) ### (connections with the router as destination)
# base case # base case
iptables -P INPUT DROP iptables -P INPUT DROP
@ -50,8 +50,8 @@ iptables -A LAN_ACCEPT -j ACCEPT
iptables -A INPUT -p tcp -j REJECT --reject-with tcp-reset iptables -A INPUT -p tcp -j REJECT --reject-with tcp-reset
iptables -A INPUT -j REJECT --reject-with icmp-port-unreachable iptables -A INPUT -j REJECT --reject-with icmp-port-unreachable
### OUTPUT ### OUTPUT
### (connections with the router as source) ### (connections with the router as source)
# base case # base case
iptables -P OUTPUT DROP iptables -P OUTPUT DROP
@ -70,8 +70,8 @@ iptables -A LAN_ACCEPT -j ACCEPT
iptables -A OUTPUT -p tcp -j REJECT --reject-with tcp-reset iptables -A OUTPUT -p tcp -j REJECT --reject-with tcp-reset
iptables -A OUTPUT -j REJECT --reject-with icmp-port-unreachable iptables -A OUTPUT -j REJECT --reject-with icmp-port-unreachable
### FORWARDING ### FORWARDING
### (connections routed through the router) ### (connections routed through the router)
# base case # base case
iptables -P FORWARD DROP iptables -P FORWARD DROP
@ -91,13 +91,25 @@ iptables -A LAN_ACCEPT -j ACCEPT
# reject (what to do with anything not allowed earlier) # reject (what to do with anything not allowed earlier)
# uses the default -P DROP # uses the default -P DROP
### MASQ ### MASQ
iptables -t nat -A PREROUTING -j prerouting_rule iptables -t nat -A PREROUTING -j prerouting_rule
iptables -t nat -A POSTROUTING -j postrouting_rule iptables -t nat -A POSTROUTING -j postrouting_rule
[ -z "$WAN" ] || iptables -t nat -A POSTROUTING -o $WAN -j MASQUERADE [ -z "$WAN" ] || iptables -t nat -A POSTROUTING -o $WAN -j MASQUERADE
## USER RULES ## USER RULES
[ -f /etc/firewall.user ] && . /etc/firewall.user [ -f /etc/firewall.user ] && . /etc/firewall.user
[ -n "$WAN" -a -e /etc/config/firewall ] && { [ -n "$WAN" -a -e /etc/config/firewall ] && {
awk -f /usr/lib/common.awk -f /usr/lib/firewall.awk /etc/config/firewall | ash awk -f /usr/lib/common.awk -f /usr/lib/firewall.awk /etc/config/firewall | ash
}
}
stop() {
iptables -P INPUT ACCEPT
iptables -P OUTPUT ACCEPT
iptables -P FORWARD ACCEPT
iptables -F
iptables -t nat -P PREROUTING ACCEPT
iptables -t nat -P POSTROUTING ACCEPT
iptables -t nat -P OUTPUT ACCEPT
iptables -t nat -F
} }

View File

@ -1,2 +1,4 @@
#!/bin/sh #!/bin/sh /etc/rc.common
iwpriv ath0 mode 3 start() {
iwpriv ath0 mode 3
}

File diff suppressed because it is too large Load Diff