#!/bin/sh ######################################################################## # Begin $rc_base/init.d/network # # Description : Network Control Script # # Authors : Michael Tremer - m.s.tremer@googlemail.com # # Version : 01.00 # # Notes : Written for IPFire by its team # ######################################################################## . /etc/sysconfig/rc . ${rc_functions} eval $(/usr/local/bin/readhash /var/ipfire/vpn/settings) eval $(/usr/local/bin/readhash /var/ipfire/dhcp/settings) eval $(/usr/local/bin/readhash /var/ipfire/ethernet/settings) eval $(/usr/local/bin/readhash /var/ipfire/ppp/settings) case "${1}" in start) boot_mesg "Loading iptables helper modules" modprobe iptable_nat || failed=1 modprobe ip_conntrack || failed=1 modprobe ip_conntrack_ftp || failed=1 modprobe ip_nat_ftp || failed=1 modprobe ip_conntrack_h323 || failed=1 modprobe ip_nat_h323 || failed=1 modprobe ip_conntrack_irc || failed=1 modprobe ip_nat_irc || failed=1 modprobe ip_conntrack_mms || failed=1 modprobe ip_nat_mms || failed=1 modprobe ip_conntrack_pptp || failed=1 modprobe ip_nat_pptp || failed=1 modprobe ip_conntrack_sip || failed=1 modprobe ip_nat_sip || failed=1 (exit ${failed}) evaluate_retval # Remove possible leftover files rm -f /var/ipfire/red/{active,device,dial-on-demand,dns1,dns2,local-ipaddress,remote-ipaddress,resolv.conf} boot_mesg "Setting up IPFire firewall rules" /etc/rc.d/init.d/firewall start; evaluate_retval boot_mesg "Setting up IP Accounting" /etc/rc.d/helper/writeipac.pl || failed=1 /usr/sbin/fetchipac -S || failed=1 (exit ${failed}) evaluate_retval boot_mesg "Setting IPFire DMZ pinholes" /usr/local/bin/setdmzholes; evaluate_retval if [ "$CONFIG_TYPE" = "4" -o "$CONFIG_TYPE" = "5" -o "$CONFIG_TYPE" = "6" -o "$CONFIG_TYPE" = "7" ]; then boot_mesg "Setting up wireless firewall rules" /usr/local/bin/restartwireless; evaluate_retval fi # Starting interfaces... # GREEN name=green /etc/rc.d/init.d/net/ifup # BLUE if [ "$CONFIG_TYPE" = "4" -o "$CONFIG_TYPE" = "5" -o "$CONFIG_TYPE" = "6" -o "$CONFIG_TYPE" = "7" ]; then name=blue /etc/rc.d/init.d/net/ifup fi # ORANGE if [ "$CONFIG_TYPE" = "1" -o "$CONFIG_TYPE" = "3" -o "$CONFIG_TYPE" = "5" -o "$CONFIG_TYPE" = "7" ]; then name=orange /etc/rc.d/init.d/net/ifup fi # Start DNSMASQ with defaults killall -KILL dnsmasq 2> /dev/null sleep 1 if [ "$DOMAIN_NAME_GREEN" == "" ]; then /usr/sbin/dnsmasq -l /var/state/dhcp/dhcpd.leases else /usr/sbin/dnsmasq -l /var/state/dhcp/dhcpd.leases -s "$DOMAIN_NAME_GREEN" fi # RED if [ "$CONFIG_TYPE" = "2" -o "$CONFIG_TYPE" = "3" -o "$CONFIG_TYPE" = "6" -o "$CONFIG_TYPE" = "7" ]; then if [ "$AUTOCONNECT" == "off" ]; then echo -n # Do anything else name=red /etc/rc.d/init.d/net/ifup fi fi ;; stop) # Stopping interfaces... # GREEN name=green /etc/rc.d/init.d/net/ifdown # BLUE if [ "$CONFIG_TYPE" = "4" -o "$CONFIG_TYPE" = "5" -o "$CONFIG_TYPE" = "6" -o "$CONFIG_TYPE" = "7" ]; then name=blue /etc/rc.d/init.d/net/ifdown fi # ORANGE if [ "$CONFIG_TYPE" = "1" -o "$CONFIG_TYPE" = "3" -o "$CONFIG_TYPE" = "5" -o "$CONFIG_TYPE" = "7" ]; then name=orange /etc/rc.d/init.d/net/ifdown fi # RED if [ "$CONFIG_TYPE" = "2" -o "$CONFIG_TYPE" = "3" -o "$CONFIG_TYPE" = "6" -o "$CONFIG_TYPE" = "7" ]; then name=red /etc/rc.d/init.d/net/ifdown fi ;; restart) ${0} stop sleep 1 ${0} start ;; *) echo "Usage: ${0} {start|stop|restart}" exit 1 ;; esac # End /etc/rc.d/init.d/network