mirror of https://github.com/hak5/openwrt.git
parent
687dd472af
commit
ab8c3f11f4
|
@ -0,0 +1,54 @@
|
||||||
|
#!/bin/sh
|
||||||
|
# $Id$
|
||||||
|
|
||||||
|
|
||||||
|
[ -f "/tmp/.firstboot" ] && {
|
||||||
|
echo "firstboot is already running"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
touch /tmp/.firstboot
|
||||||
|
|
||||||
|
jdev=$(mount | awk '/jffs2/ {print $3}')
|
||||||
|
|
||||||
|
if [ -z "$jdev" ]; then
|
||||||
|
echo -n "Creating jffs2 partition... "
|
||||||
|
mtd erase OpenWrt >&-
|
||||||
|
mount -t jffs2 /dev/mtdblock/4 /jffs
|
||||||
|
echo "done"
|
||||||
|
cd /jffs
|
||||||
|
else
|
||||||
|
echo "firstboot has already been run"
|
||||||
|
echo "jffs2 partition is mounted, only resetting files"
|
||||||
|
cd $jdev
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec 2>/dev/null
|
||||||
|
|
||||||
|
mount /dev/mtdblock/2 /rom -o ro
|
||||||
|
|
||||||
|
echo -n "creating directories... "
|
||||||
|
{
|
||||||
|
cd /rom
|
||||||
|
find . -type d
|
||||||
|
cd -
|
||||||
|
} | xargs mkdir
|
||||||
|
echo "done"
|
||||||
|
|
||||||
|
echo -n "setting up symlinks... "
|
||||||
|
for file in $(cd /rom; find * -type f; find * -type l;)
|
||||||
|
do {
|
||||||
|
ln -sf /rom/$file $file
|
||||||
|
} done
|
||||||
|
echo "done"
|
||||||
|
|
||||||
|
touch /tmp/resolv.conf
|
||||||
|
ln -s /tmp/resolv.conf /etc/resolv.conf
|
||||||
|
|
||||||
|
umount /rom
|
||||||
|
mount none /jffs/proc -t proc
|
||||||
|
pivot_root /jffs /jffs/rom
|
||||||
|
mount none /dev -t devfs
|
||||||
|
mount none /tmp -t ramfs
|
||||||
|
umount /rom/proc
|
||||||
|
umount /rom/tmp
|
||||||
|
umount /rom/dev
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,2 @@
|
||||||
|
#!/bin/sh
|
||||||
|
exec ash --login
|
|
@ -0,0 +1,6 @@
|
||||||
|
_______ ________ __
|
||||||
|
| |.-----.-----.-----.| | | |.----.| |_
|
||||||
|
| - || _ | -__| || | | || _|| _|
|
||||||
|
|_______|| __|_____|__|__||________||__| |____|
|
||||||
|
|__| W I R E L E S S F R E E D O M
|
||||||
|
|
|
@ -0,0 +1,22 @@
|
||||||
|
# filter what we send upstream
|
||||||
|
domain-needed
|
||||||
|
bogus-priv
|
||||||
|
filterwin2k
|
||||||
|
|
||||||
|
# allow /etc/hosts and dhcp lookups via *.lan
|
||||||
|
local=/lan/
|
||||||
|
domain=lan
|
||||||
|
|
||||||
|
# no dhcp / dns queries from the wan
|
||||||
|
except-interface=vlan1
|
||||||
|
|
||||||
|
# enable dhcp (start,end,netmask,leasetime)
|
||||||
|
dhcp-range=192.168.1.100,192.168.1.250,255.255.255.0,12h
|
||||||
|
dhcp-leasefile=/tmp/dhcp.leases
|
||||||
|
|
||||||
|
# allow a /etc/ethers for static hosts
|
||||||
|
read-ethers
|
||||||
|
|
||||||
|
# other useful options:
|
||||||
|
# default route(s): dhcp-option=3,192.168.1.1,192.168.1.2
|
||||||
|
# dns server(s): dhcp-option=6,192.168.1.1,192.168.1.2
|
|
@ -0,0 +1,26 @@
|
||||||
|
#!/bin/ash
|
||||||
|
|
||||||
|
alias debug=${DEBUG:-:}
|
||||||
|
|
||||||
|
# allow env to override nvram
|
||||||
|
nvram_get () {
|
||||||
|
eval "echo \${$1:-\$(nvram get $1)}"
|
||||||
|
}
|
||||||
|
. /etc/nvram.overrides
|
||||||
|
|
||||||
|
# valid interface?
|
||||||
|
if_valid () (
|
||||||
|
[ "${1%%[0-9]}" = "vlan" ] && {
|
||||||
|
i=${1#vlan}
|
||||||
|
hwname=$(nvram_get vlan${i}hwname)
|
||||||
|
hwaddr=$(nvram_get ${hwname}macaddr)
|
||||||
|
[ -z "$hwaddr" ] && return 1
|
||||||
|
|
||||||
|
vif=$(ifconfig -a | awk '/^eth.*'$hwaddr'/ {print $1; exit}' IGNORECASE=1)
|
||||||
|
debug "# vlan$i: $hwname $hwaddr => $vif"
|
||||||
|
|
||||||
|
$DEBUG ifconfig $vif up
|
||||||
|
$DEBUG vconfig add $vif $i 2>/dev/null
|
||||||
|
}
|
||||||
|
ifconfig "$1" >/dev/null 2>&1 || [ "${1%%[0-9]}" = "br" ]
|
||||||
|
)
|
|
@ -0,0 +1,27 @@
|
||||||
|
#!/bin/sh
|
||||||
|
sysctl -p
|
||||||
|
echo "S" > /proc/jffs2_bbc
|
||||||
|
|
||||||
|
mkdir -p /var/run
|
||||||
|
|
||||||
|
# networking stub
|
||||||
|
[ "$(nvram get il0macaddr)" = "00:90:4c:5f:00:2a" ] && {
|
||||||
|
# force unique wireless mac
|
||||||
|
nvram set il0macaddr=$(nvram get et0macaddr|
|
||||||
|
awk '{OFS=FS=":";for(x=6,y=2;x;x--){$x=sprintf("%02x",(y+="0x"$x)%256);y/=256}print}')
|
||||||
|
}
|
||||||
|
|
||||||
|
insmod et
|
||||||
|
insmod wl
|
||||||
|
|
||||||
|
ifconfig lo 127.0.0.1 up
|
||||||
|
ifconfig eth0 promisc
|
||||||
|
|
||||||
|
HOSTNAME=$(nvram get wan_hostname)
|
||||||
|
DOMAINNAME=${HOSTNAME##*.}
|
||||||
|
HOSTNAME=${HOSTNAME%%.*}
|
||||||
|
|
||||||
|
echo ${HOSTNAME:=OpenWrt} > /proc/sys/kernel/hostname
|
||||||
|
echo ${DOMAINNAME:=lan} > /proc/sys/kernel/domainname
|
||||||
|
|
||||||
|
vconfig set_name_type VLAN_PLUS_VID_NO_PAD
|
|
@ -0,0 +1,15 @@
|
||||||
|
#!/bin/sh
|
||||||
|
. /etc/functions.sh
|
||||||
|
case "$1" in
|
||||||
|
start|restart)
|
||||||
|
ifup lan
|
||||||
|
ifup wan
|
||||||
|
ifup wifi
|
||||||
|
wifi up
|
||||||
|
|
||||||
|
for route in $(nvram_get static_route); do {
|
||||||
|
eval "set $(echo $route | sed 's/:/ /g')"
|
||||||
|
route add -net $1 netmask $2 gw $3 metric $4 dev $5
|
||||||
|
} done
|
||||||
|
;;
|
||||||
|
esac
|
|
@ -0,0 +1,23 @@
|
||||||
|
#!/bin/sh
|
||||||
|
. /etc/functions.sh
|
||||||
|
|
||||||
|
WAN=$(nvram_get wan_ifname)
|
||||||
|
|
||||||
|
IPT=/usr/sbin/iptables
|
||||||
|
|
||||||
|
for T in filter nat mangle ; do
|
||||||
|
$IPT -t $T -F
|
||||||
|
$IPT -t $T -X
|
||||||
|
done
|
||||||
|
|
||||||
|
$IPT -t filter -A INPUT -m state --state INVALID -j DROP
|
||||||
|
$IPT -t filter -A INPUT -m state --state RELATED,ESTABLISHED -j ACCEPT
|
||||||
|
$IPT -t filter -A INPUT -p icmp -j ACCEPT
|
||||||
|
$IPT -t filter -A INPUT -i $WAN -p tcp -j REJECT --reject-with tcp-reset
|
||||||
|
$IPT -t filter -A INPUT -i $WAN -j REJECT --reject-with icmp-port-unreachable
|
||||||
|
$IPT -t filter -A FORWARD -m state --state INVALID -j DROP
|
||||||
|
$IPT -t filter -A FORWARD -m state --state RELATED,ESTABLISHED -j ACCEPT
|
||||||
|
$IPT -t filter -A FORWARD -i $WAN -m state --state NEW,INVALID -j DROP
|
||||||
|
$IPT -t filter -A FORWARD -o $WAN -p tcp --tcp-flags SYN,RST SYN -j TCPMSS --clamp-mss-to-pmtu
|
||||||
|
|
||||||
|
$IPT -t nat -A POSTROUTING -o $WAN -j MASQUERADE
|
|
@ -0,0 +1,4 @@
|
||||||
|
#!/bin/sh
|
||||||
|
/usr/sbin/telnetd -l /bin/login
|
||||||
|
/usr/sbin/httpd -p 80 -h /www -r WRT54G Router
|
||||||
|
/usr/sbin/dnsmasq
|
|
@ -0,0 +1,6 @@
|
||||||
|
#!/bin/sh
|
||||||
|
[ -z "$FAILSAFE" ] && {
|
||||||
|
{ mount | grep jffs2 1>&-; } || firstboot
|
||||||
|
}
|
||||||
|
# turn off DMZ led
|
||||||
|
echo "0x00" > /proc/sys/diag
|
|
@ -0,0 +1,25 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# Start all init scripts in /etc/init.d
|
||||||
|
# executing them in numerical order.
|
||||||
|
#
|
||||||
|
for i in /etc/init.d/S??* ;do
|
||||||
|
|
||||||
|
# Ignore dangling symlinks (if any).
|
||||||
|
[ ! -f "$i" ] && continue
|
||||||
|
|
||||||
|
case "$i" in
|
||||||
|
*.sh)
|
||||||
|
# Source shell script for speed.
|
||||||
|
(
|
||||||
|
trap - INT QUIT TSTP
|
||||||
|
set start
|
||||||
|
. $i
|
||||||
|
)
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
# No sh extension, so fork subprocess.
|
||||||
|
$i start
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
|
@ -0,0 +1,3 @@
|
||||||
|
::sysinit:/etc/init.d/rcS
|
||||||
|
::shutdown:/sbin/halt
|
||||||
|
::respawn:/bin/login
|
|
@ -0,0 +1,3 @@
|
||||||
|
src openwrt http://openwrt.ksilebo.net/ipkg
|
||||||
|
dest root /
|
||||||
|
dest ram /tmp
|
|
@ -0,0 +1,52 @@
|
||||||
|
# NVRAM overrides
|
||||||
|
# This file handles the NVRAM quirks of various hardware
|
||||||
|
# this is not a replacement for nvram.
|
||||||
|
|
||||||
|
# linksys bug has lan doing dhcp; force static
|
||||||
|
lan_proto="static"
|
||||||
|
|
||||||
|
# failsafe if reset is held
|
||||||
|
[ "$FAILSAFE" = "true" ] && {
|
||||||
|
echo "### FAILSAFE MODE ####"
|
||||||
|
lan_ifname="br0"
|
||||||
|
lan_ifnames="vlan0 vlan2 eth1 eth2 eth3"
|
||||||
|
lan_ipaddr="192.168.1.1"
|
||||||
|
lan_netmask="255.255.255.0"
|
||||||
|
lan_hwaddr="00:0B:AD:0A:DD:00"
|
||||||
|
wan_ifname="none"
|
||||||
|
wifi_ifname="none"
|
||||||
|
}
|
||||||
|
|
||||||
|
# hacks for 1.x hardware
|
||||||
|
[ "$(nvram get boardnum)" = "42" ] && \
|
||||||
|
[ "$(nvram get boardtype)" = "bcm94710dev" ] && {
|
||||||
|
debug "### 1.x hardware hack ###"
|
||||||
|
vlan1hwname="et0"
|
||||||
|
vlan2hwname="et0"
|
||||||
|
|
||||||
|
# we remap old device names to new
|
||||||
|
# it's recommended that you continue to
|
||||||
|
# use the old names to preserve backwards
|
||||||
|
# compatibility
|
||||||
|
remap () {
|
||||||
|
eval $1=\"$(nvram_get $1 | awk 'gsub("eth0","vlan2") gsub("eth1","vlan1")')\"
|
||||||
|
}
|
||||||
|
|
||||||
|
remap lan_ifname
|
||||||
|
remap lan_ifnames
|
||||||
|
remap wifi_ifname
|
||||||
|
remap wifi_ifnames
|
||||||
|
remap wan_ifname
|
||||||
|
remap wan_ifnames
|
||||||
|
remap pppoe_ifname
|
||||||
|
}
|
||||||
|
|
||||||
|
[ -z "$(nvram_get lan_ifname)" ] && {
|
||||||
|
lan_ifname="br0"
|
||||||
|
lan_ifnames="vlan0 vlan2 eth1 eth2 eth3"
|
||||||
|
}
|
||||||
|
|
||||||
|
[ -z "$(nvram_get wan_ifname)" ] && {
|
||||||
|
wan_ifname="vlan1"
|
||||||
|
wan_proto="dhcp"
|
||||||
|
}
|
|
@ -0,0 +1,17 @@
|
||||||
|
#!/bin/sh
|
||||||
|
mount none /proc -t proc
|
||||||
|
insmod diag
|
||||||
|
echo 0x01 > /proc/sys/diag
|
||||||
|
sleep 1
|
||||||
|
if /sbin/resetmon ; then
|
||||||
|
mtd unlock mtd4
|
||||||
|
mount -t jffs2 /dev/mtdblock/4 /jffs
|
||||||
|
pivot_root /jffs /jffs/rom
|
||||||
|
mount none /dev -t devfs
|
||||||
|
mount none /proc -t proc
|
||||||
|
umount rom/proc rom/dev
|
||||||
|
else
|
||||||
|
export FAILSAFE=true
|
||||||
|
fi
|
||||||
|
mount none /tmp -t ramfs
|
||||||
|
exec /sbin/init
|
|
@ -0,0 +1,8 @@
|
||||||
|
#!/bin/sh
|
||||||
|
[ -f /etc/banner ] && cat /etc/banner
|
||||||
|
|
||||||
|
export PATH=/bin:/sbin:/usr/bin:/usr/sbin
|
||||||
|
export PS1='\u@\h:\w\$ '
|
||||||
|
|
||||||
|
alias less='more'
|
||||||
|
alias vim='vi'
|
|
@ -0,0 +1,7 @@
|
||||||
|
kernel.panic = 3
|
||||||
|
net.ipv4.ip_forward = 1
|
||||||
|
net.ipv4.icmp_echo_ignore_broadcasts = 1
|
||||||
|
net.ipv4.icmp_ignore_bogus_error_responses = 1
|
||||||
|
net.ipv4.tcp_fin_timeout = 30
|
||||||
|
net.ipv4.tcp_keepalive_time = 120
|
||||||
|
net.ipv4.tcp_timestamps = 0
|
|
@ -0,0 +1,3 @@
|
||||||
|
#!/bin/sh
|
||||||
|
/usr/bin/killall5 -9
|
||||||
|
umount -ar
|
|
@ -0,0 +1,6 @@
|
||||||
|
#!/bin/ash
|
||||||
|
# $Id$
|
||||||
|
[ "${INTERFACE%%[0-9]*}" = "wds" ] && {
|
||||||
|
ifconfig $INTERFACE 0.0.0.0 up
|
||||||
|
/usr/sbin/brctl addif br0 $INTERFACE
|
||||||
|
}
|
|
@ -0,0 +1,8 @@
|
||||||
|
#!/bin/ash
|
||||||
|
. /etc/functions.sh
|
||||||
|
type=$1
|
||||||
|
debug "### ifdown $type ###"
|
||||||
|
if=$(nvram_get ${type}_ifname)
|
||||||
|
if_valid $if || return
|
||||||
|
kill $(cat /var/run/${if}.pid 2>&-) 2>&-
|
||||||
|
$DEBUG ifconfig $if down
|
|
@ -0,0 +1,71 @@
|
||||||
|
#!/bin/ash
|
||||||
|
. /etc/functions.sh
|
||||||
|
type=$1
|
||||||
|
debug "### ifup $type ###"
|
||||||
|
|
||||||
|
if=$(nvram_get ${type}_ifname)
|
||||||
|
if [ "${if%%[0-9]}" = "ppp" ]; then
|
||||||
|
if=$(nvram_get pppoe_ifname)
|
||||||
|
fi
|
||||||
|
|
||||||
|
if_valid $if || return
|
||||||
|
|
||||||
|
$DEBUG ifconfig $if down
|
||||||
|
if [ "${if%%[0-9]}" = "br" ]; then
|
||||||
|
stp=$(nvram_get ${type}_stp)
|
||||||
|
$DEBUG brctl delbr $if
|
||||||
|
$DEBUG brctl addbr $if
|
||||||
|
$DEBUG brctl setfd $if 0
|
||||||
|
$DEBUG brctl stp $if ${stp:-0}
|
||||||
|
for sif in $(nvram_get ${type}_ifnames); do {
|
||||||
|
if_valid $sif || continue
|
||||||
|
$DEBUG ifconfig $sif 0.0.0.0 up
|
||||||
|
$DEBUG brctl addif $if $sif
|
||||||
|
} done
|
||||||
|
fi
|
||||||
|
|
||||||
|
mac=$(nvram_get ${type}_hwaddr)
|
||||||
|
${mac:+$DEBUG ifconfig $if hw ether $mac}
|
||||||
|
|
||||||
|
if_proto=$(nvram_get ${type}_proto)
|
||||||
|
case "$if_proto" in
|
||||||
|
static)
|
||||||
|
ip=$(nvram_get ${type}_ipaddr)
|
||||||
|
netmask=$(nvram_get ${type}_netmask)
|
||||||
|
gateway=$(nvram_get ${type}_gateway)
|
||||||
|
|
||||||
|
$DEBUG ifconfig $if $ip ${netmask:+netmask $netmask} broadcast + up
|
||||||
|
${gateway:+$DEBUG route add default gw $gateway}
|
||||||
|
|
||||||
|
[ -f /etc/resolv.conf ] && return
|
||||||
|
|
||||||
|
debug "# --- creating /etc/resolv.conf ---"
|
||||||
|
for dns in $(nvram_get ${type}_dns); do {
|
||||||
|
echo "nameserver $dns" >> /etc/resolv.conf
|
||||||
|
} done
|
||||||
|
;;
|
||||||
|
dhcp)
|
||||||
|
pidfile=/tmp/dhcp-${type}.pid
|
||||||
|
if [ -f $pidfile ]; then
|
||||||
|
$DEBUG kill $(cat $pidfile)
|
||||||
|
fi
|
||||||
|
${DEBUG:-eval} "udhcpc -i $if -b -p $pidfile &"
|
||||||
|
;;
|
||||||
|
pppoe)
|
||||||
|
username=$(nvram_get ppp_username)
|
||||||
|
password=$(nvram_get ppp_passwd)
|
||||||
|
redial=$(nvram_get ppp_redialperiod)
|
||||||
|
idletime=$(nvram_get ppp_idletime)
|
||||||
|
mtu=$(nvram_get wan_mtu)
|
||||||
|
|
||||||
|
$DEBUG ifconfig $if 0.0.0.0 up
|
||||||
|
|
||||||
|
$DEBUG /sbin/pppoecd $if -u $username -p $password \
|
||||||
|
-i 0 -I $redial -T $idletime -t $mtu -k
|
||||||
|
;;
|
||||||
|
none)
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "### WARNING $if: $if_proto is not supported"
|
||||||
|
;;
|
||||||
|
esac
|
|
@ -0,0 +1,5 @@
|
||||||
|
#!/bin/ash
|
||||||
|
alias debug=${DEBUG:-:}
|
||||||
|
debug "### wifi $1 ###"
|
||||||
|
if=$(awk 'sub(":","") {print $1}' /proc/net/wireless)
|
||||||
|
$DEBUG wlconf $if $1
|
|
@ -0,0 +1,38 @@
|
||||||
|
#!/bin/sh
|
||||||
|
# udhcpc script edited by Tim Riker <Tim@Rikers.org>
|
||||||
|
# (slightly modified)
|
||||||
|
|
||||||
|
[ -z "$1" ] && echo "Error: should be run by udhcpc" && exit 1
|
||||||
|
|
||||||
|
RESOLV_CONF="/tmp/resolv.conf"
|
||||||
|
|
||||||
|
case "$1" in
|
||||||
|
deconfig)
|
||||||
|
ifconfig $interface 0.0.0.0
|
||||||
|
;;
|
||||||
|
|
||||||
|
renew|bound)
|
||||||
|
ifconfig $interface $ip \
|
||||||
|
${broadcast:+broadcast $broadcast} \
|
||||||
|
${subnet:+netmask $subnet}
|
||||||
|
|
||||||
|
if [ -n "$router" ] ; then
|
||||||
|
echo "deleting routers"
|
||||||
|
while route del default gw 0.0.0.0 dev $interface ; do
|
||||||
|
:
|
||||||
|
done
|
||||||
|
|
||||||
|
for i in $router ; do
|
||||||
|
route add default gw $i dev $interface
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo -n > $RESOLV_CONF
|
||||||
|
${domain:+echo search $domain >> $RESOLV_CONF}
|
||||||
|
for i in $dns ; do
|
||||||
|
echo adding dns $i
|
||||||
|
echo nameserver $i >> $RESOLV_CONF
|
||||||
|
done
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
exit 0
|
|
@ -0,0 +1,7 @@
|
||||||
|
<HTML>
|
||||||
|
<HEAD><TITLE>OpenWrt</TITLE></HEAD>
|
||||||
|
<BODY>
|
||||||
|
No webpages currently available
|
||||||
|
<br>- perhaps you need to install a package?
|
||||||
|
</BODY>
|
||||||
|
</HTML>
|
Loading…
Reference in New Issue