X-Git-Url: http://git.ipfire.org/?p=people%2Fteissler%2Fipfire-2.x.git;a=blobdiff_plain;f=src%2Finitscripts%2Finit.d%2Fnetworking%2Fred;h=28df551038efaa9dae66e6cae0f1b8f5a7f87a81;hp=54df34f16b9452f0d7e287908c04c9bad4e09b0a;hb=7b1db453c034fd88217f2f9b38ff1c57a9ec1f52;hpb=4cd4876aa710566f92e6305dacc40186df857ebf diff --git a/src/initscripts/init.d/networking/red b/src/initscripts/init.d/networking/red index 54df34f16..28df55103 100644 --- a/src/initscripts/init.d/networking/red +++ b/src/initscripts/init.d/networking/red @@ -17,7 +17,24 @@ . /etc/sysconfig/rc . ${rc_functions} +. /etc/init.d/networking/functions.network + +#Define some defaults +INET_VLAN=7 +IPTV_VLAN=8 + +eval $(/usr/local/bin/readhash /var/ipfire/main/settings) +if [ "$RRDLOG" == "" ]; then + RRDLOG=/var/log/rrd +fi + eval $(/usr/local/bin/readhash /var/ipfire/ethernet/settings) +eval $(/usr/local/bin/readhash /var/ipfire/dns/settings) +eval $(/usr/local/bin/readhash /var/ipfire/mac/settings) + +MAC=$(tr - : <<<$MAC) +MAC1=$(tr - : <<<$MAC1) +MAC2=$(tr - : <<<$MAC2) TYPE="${RED_TYPE}" DEVICE="${RED_DEV}" @@ -59,14 +76,6 @@ if [ "${TYPE}" == "STATIC" ]; then echo_failure exit 1 fi - -elif [ "${TYPE}" == "DHCP" ]; then - - PIDFILE="/var/run/dhcpcd-${DEVICE}.pid" - LEASEINFO="/var/ipfire/dhcpc/dhcpcd-${DEVICE}.info" - DHCP_START="-N -R -L /var/ipfire/dhcpc -c /var/ipfire/dhcpc/dhcpcd.exe " - DHCP_STOP="-k -c /var/ipfire/dhcpc/dhcpcd.exe " - fi case "${1}" in @@ -79,6 +88,11 @@ case "${1}" in link_status=`ip link show ${DEVICE} 2> /dev/null` if [ -n "${link_status}" ]; then if ! echo "${link_status}" | grep -q UP; then + if [ -n "$MAC" ]; then + boot_mesg "Setting mac address on ${DEVICE} to ${MAC}" + ip link set dev ${DEVICE} address ${MAC} + evaluate_retval + fi ip link set ${DEVICE} up fi fi @@ -88,6 +102,9 @@ case "${1}" in exit 1 fi fi + + ## Create & Enable vnstat + /usr/bin/vnstat -u -i ${DEVICE} -r --enable --force > /dev/null 2>&1 if [ "${TYPE}" == "STATIC" ]; then @@ -99,6 +116,9 @@ case "${1}" in echo -n "${DEVICE}" > /var/ipfire/red/iface echo -n "${ADDRESS}" > /var/ipfire/red/local-ipaddress echo -n "${GATEWAY}" > /var/ipfire/red/remote-ipaddress + grep -v -E "\" /etc/hosts > /tmp/hosts + echo "$GATEWAY gateway" >> /tmp/hosts + mv /tmp/hosts /etc/hosts echo -n "${DNS1}" > /var/ipfire/red/dns1 echo -n "${DNS2}" > /var/ipfire/red/dns2 touch /var/ipfire/red/active @@ -108,66 +128,31 @@ case "${1}" in evaluate_retval run_subdir ${rc_base}/init.d/networking/red.up/ - - elif [ "${TYPE}" == "DHCP" ]; then - boot_mesg -n "Starting dhcpcd on the ${DEVICE} interface..." - echo -n "${DEVICE}" > /var/ipfire/red/iface - # Test to see if there is a stale pid file - if [ -f "$PIDFILE" ]; then - ps `cat "$PIDFILE"` | grep dhcpcd > /dev/null - if [ $? != 0 ]; then - rm -f /var/run/dhcpcd-${DEVICE}.pid > /dev/null - else - boot_mesg "dhcpcd already running!" ${WARNING} - echo_warning - exit 2 - fi - fi - + # Configure aliases only if red static + /usr/local/bin/setaliases + + elif [ "${TYPE}" == "DHCP" ]; then + # Add firewall rules to allow comunication with the dhcp server on red. iptables -A REDINPUT -p tcp --source-port 67 --destination-port 68 -i ${DEVICE} -j ACCEPT iptables -A REDINPUT -p udp --source-port 67 --destination-port 68 -i ${DEVICE} -j ACCEPT - - if [ -n "${RED_DHCP_HOSTNAME}" ]; then - DHCP_START+="-h ${RED_DHCP_HOSTNAME} " - fi - - /sbin/dhcpcd ${DEVICE} ${DHCP_START} >/dev/null 2>&1 - RET="$?" - - if [ "$RET" = "0" ]; then - . /var/ipfire/dhcpc/dhcpcd-${DEVICE}.info - echo "" - echo_ok - boot_mesg " DHCP Assigned Settings for ${DEVICE}:" - boot_mesg_flush - boot_mesg " IP Address: $IPADDR" - boot_mesg_flush - if [ -n "${RED_DHCP_HOSTNAME}" ]; then - boot_mesg " Hostname: $RED_DHCP_HOSTNAME" - boot_mesg_flush - fi - boot_mesg " Subnet Mask: $NETMASK" - boot_mesg_flush - boot_mesg " Default Gateway: $GATEWAY" - boot_mesg_flush - boot_mesg " DNS Server: $DNS" - boot_mesg_flush - - echo -n `/etc/rc.d/helper/getdnsfromdhcpc.pl 1` > /var/ipfire/red/dns1 - echo -n `/etc/rc.d/helper/getdnsfromdhcpc.pl 2` > /var/ipfire/red/dns2 - . /var/ipfire/dhcpc/dhcpcd-${DEVICE}.info - echo "$IPADDR" > /var/ipfire/red/local-ipaddress - echo "$GATEWAY" > /var/ipfire/red/remote-ipaddress - else - echo "" - $(exit "$RET") - evaluate_retval + echo -n "${DEVICE}" > /var/ipfire/red/iface + + # Check if the wlan-client is used on red. + # To determine this we check if a wpa_supplicant is running. + pid="$(pidof wpa_supplicant)" + + if [ -z "${pid}" ]; then + # No wpa_supplicant is running. So it's save to start dhcpcd. + dhcpcd_start "${DEVICE}" fi - + + ## Create & Enable vnstat + /usr/bin/vnstat -u -i ${DEVICE} -r --enable --force > /dev/null 2>&1 + elif [ "$TYPE" == "PPPOE" ]; then - + if ( ps ax | grep -q [p]ppd ); then boot_mesg "pppd is still running." ${FAILURE} echo_failure @@ -177,24 +162,144 @@ case "${1}" in eval $(/usr/local/bin/readhash /var/ipfire/ppp/settings) [ -c "/dev/ppp" ] || mknod /dev/ppp c 108 0 - + + # We force the plugin method, anyway. + METHOD="PPPOE_PLUGIN" + PPP_NIC=${DEVICE} - - if [ "$TYPE" == "pppoeatm" ]; then + + + if [ "$TYPE" == "pppoeatm" ] || [ "$TYPE" == "pptpatm" ]; then PPP_NIC=nas0 + DEVICE=nas0 boot_mesg "Createing ATM-Bridge as $PPP_NIC ..." br2684ctl -c0 -e${ENCAP} -a0.${VPI}.${VCI} >/dev/null 2>&1 & sleep 1 - ifconfig $PPP_NIC up + if [ "$TYPE" == "pppoeatm" ]; then + TYPE="pppoe" + fi + if [ "$TYPE" == "pptpatm" ]; then + TYPE="pptp" + fi + fi + + if [ "$TYPE" == "vdsl" ]; then + boot_mesg "Createing VLAN Interface ${DEVICE}.${INET_VLAN} ..." + modprobe 8021q + vconfig add ${DEVICE} ${INET_VLAN} + if [ -n "$MAC1" ]; then + boot_mesg "Setting mac address on ${DEVICE}.${INET_VLAN} to ${MAC1}" + ip link set dev ${DEVICE}.${INET_VLAN} address ${MAC1} + evaluate_retval + fi + PPP_NIC=${DEVICE}.${INET_VLAN} + sleep 0.2 + ip link set ${PPP_NIC} up TYPE="pppoe" fi - if [ "$TYPE" == "pppoe" ]; then + if [ "${IPTV}" == "enable" ]; then + PIDFILE="/var/run/dhcpcd-${DEVICE}.${IPTV_VLAN}.pid" + LEASEINFO="/var/ipfire/dhcpc/dhcpcd-${DEVICE}.${IPTV_VLAN}.info" + # Test to see if there is a stale pid file + if [ -f "$PIDFILE" ]; then + ps `cat "$PIDFILE"` | grep dhcpcd > /dev/null + if [ $? != 0 ]; then + rm -f /var/run/dhcpcd-${DEVICE}.${IPTV_VLAN}.pid > /dev/null + fi + fi + + if [ ! -f "$PIDFILE" ]; then + boot_mesg "Createing VLAN Interface ${DEVICE}.${IPTV_VLAN} ..." + modprobe 8021q + vconfig add ${DEVICE} ${IPTV_VLAN} + if [ -n "$MAC2" ]; then + boot_mesg "Setting mac address on ${DEVICE}.${IPTV_VLAN} to ${MAC2}" + ip link set dev ${DEVICE}.${IPTV_VLAN} address ${MAC2} + evaluate_retval + fi + boot_mesg -n "Starting dhcpcd on the ${DEVICE}.${IPTV_VLAN} interface..." + /sbin/dhcpcd ${DEVICE}.${IPTV_VLAN} ${DHCP_START} >/dev/null 2>&1 + RET="$?" + + if [ "$RET" = "0" ]; then + . /var/ipfire/dhcpc/dhcpcd-${DEVICE}.${IPTV_VLAN}.info + echo "" + echo_ok + boot_mesg " DHCP Assigned Settings for ${DEVICE}.${IPTV_VLAN}:" + boot_mesg_flush + boot_mesg " IP Address: $ip_address" + boot_mesg_flush + boot_mesg " Hostname: $RED_DHCP_HOSTNAME" + boot_mesg_flush + boot_mesg " Subnet Mask: $subnet_mask" + boot_mesg_flush + boot_mesg " Default Gateway: $routers" + boot_mesg_flush + boot_mesg " DNS Server: $domain_name_servers" + boot_mesg_flush + + else + echo "" + $(exit "$RET") + evaluate_retval + fi + fi + fi + if [ "$TYPE" == "pppoe" ] || [ "$TYPE" == "pptp" ]; then if [ "$PPP_NIC" == "" ]; then boot_mesg "No device for red interface given. Check netsetup or dialprofile!" ${FAILURE} echo_failure + exit 0 + fi + boot_mesg "Bringing up the $TYPE interface on $PPP_NIC ..." + ip addr flush dev $PPP_NIC >/dev/null 2>&1 + if [ "$TYPE" == "pptp" ]; then + if [ "$PPTP_NICCFG" == "dhcp" ]; then + # Test to see if there is a stale pid file + if [ -f "$PIDFILE" ]; then + ps `cat "$PIDFILE"` | grep dhcpcd > /dev/null + if [ $? != 0 ]; then + rm -f /var/run/dhcpcd-${DEVICE}.pid > /dev/null + fi + fi + + if [ ! -f "$PIDFILE" ]; then + boot_mesg -n "Starting dhcpcd on the ${DEVICE} interface..." + /sbin/dhcpcd ${DEVICE} ${DHCP_START} >/dev/null 2>&1 + RET="$?" + + if [ "$RET" = "0" ]; then + . /var/ipfire/dhcpc/dhcpcd-${DEVICE}.info + echo "" + echo_ok + boot_mesg " DHCP Assigned Settings for ${DEVICE}:" + boot_mesg_flush + boot_mesg " IP Address: $ip_address" + boot_mesg_flush + boot_mesg " Hostname: $RED_DHCP_HOSTNAME" + boot_mesg_flush + boot_mesg " Subnet Mask: $subnet_mask" + boot_mesg_flush + boot_mesg " Default Gateway: $routers" + boot_mesg_flush + boot_mesg " DNS Server: $domain_name_servers" + boot_mesg_flush + /sbin/route add $PPTP_PEER gw $routers $PPP_NIC + else + echo "" + $(exit "$RET") + evaluate_retval + fi + fi + else + ip addr add $PPTP_NICCFG dev $PPP_NIC + fi + fi + ip link set ${PPP_NIC} up + if [ -n "${PPTP_ROUTE}" ]; then + boot_mesg "Set route ${PPTP_ROUTE} to pptp server..." + route add ${PPTP_ROUTE} fi - boot_mesg "Bringing up the PPPoE interface on $PPP_NIC ..." - ip addr add 1.1.1.1/24 broadcast 1.1.1.255 dev $PPP_NIC else boot_mesg "Bringing up the PPP via ${TYPE} on ${COMPORT}..." fi @@ -205,10 +310,10 @@ case "${1}" in ### Plugin Options # - [ "${METHOD}" == "PPPOE_PLUGIN" ] && \ - PLUGOPTS="plugin /usr/lib/pppd/2.4.4/rp-pppoe.so" - - # PLUGOPTS="plugin /usr/lib/pppd/2.4.4/rp-pppoe.so nic-$PPP_NIC" + if [ "$TYPE" == "pppoe" ]; then + [ "${METHOD}" == "PPPOE_PLUGIN" ] && \ + PLUGOPTS="plugin rp-pppoe.so" + fi ### Synchronous Mode # @@ -249,7 +354,6 @@ case "${1}" in DNS="" echo nameserver=$DNS1 > /etc/ppp/resolv.conf echo nameserver=$DNS2 >> /etc/ppp/resolv.conf - fi ### Dial On Demand @@ -267,23 +371,35 @@ case "${1}" in fi fi - ### When using pppoe-plugin the device has to be the last option - # - [ "${METHOD}" == "PPPOE_PLUGIN" ] && PLUGOPTS+=" $PPP_NIC" + if [ "$TYPE" == "pppoe" ]; then + ### When using pppoe-plugin the device has to be the last option + # + [ "${METHOD}" == "PPPOE_PLUGIN" ] && PLUGOPTS+=" $PPP_NIC" + fi if [ "$TYPE" == "modem" ]; then PLUGOPTS=" /dev/${COMPORT} ${DTERATE} connect /etc/ppp/dialer lock modem crtscts" + METHOD="PPPOE_PLUGIN" elif [ "$TYPE" == "serial" ]; then PLUGOPTS=" /dev/${COMPORT} ${DTERATE} connect /bin/true lock modem crtscts" + METHOD="PPPOE_PLUGIN" fi ### Standard PPP options we always use # PPP_STD_OPTIONS="$PLUGOPTS $DNS defaultroute noipdefault noauth" - PPP_STD_OPTIONS+=" default-asyncmap hide-password nodetach mtu ${MTU}" - PPP_STD_OPTIONS+=" mru ${MTU} noaccomp nodeflate nopcomp novj novjccomp" + PPP_STD_OPTIONS+=" default-asyncmap hide-password nodetach" + PPP_STD_OPTIONS+=" noaccomp nodeflate nopcomp novj novjccomp" PPP_STD_OPTIONS+=" nobsdcomp user ${USERNAME} lcp-echo-interval 20" - PPP_STD_OPTIONS+=" lcp-echo-failure 3 ${AUTH}" + PPP_STD_OPTIONS+=" lcp-echo-failure 5 ${AUTH}" + + if [ -n "${MTU}" ]; then + PPP_STD_OPTIONS="${PPP_STD_OPTIONS} mtu ${MTU}" + fi + + if [ -n "${MRU}" ]; then + PPP_STD_OPTIONS="${PPP_STD_OPTIONS} mru ${MRU}" + fi ### Debugging # @@ -299,10 +415,17 @@ case "${1}" in PPPOE_CMD="/usr/sbin/pppoe -p /var/run/ppp-ipfire.pid.pppoe -I $PPP_NIC" PPPOE_CMD+=" -T 80 -U $PPPOE_SYNC $ACNAME $SERVICENAMEOPT" fi + + ### PPTP ### + # + if [ "$TYPE" == "pptp" ]; then + PPPOE_CMD="pptp $PPTP_PEER --nolaunchpppd" + METHOD="" + fi ### Run everything # - if [ "${METHOD}" == "PPPOE_PLUGIN" ]; then + if [ "$METHOD" == "PPPOE_PLUGIN" ]; then /usr/sbin/pppd $PPP_STD_OPTIONS $DEBUG $DEMAND >/dev/null 2>&1 & evaluate_retval # echo PLUGIN: /usr/sbin/pppd $PPP_STD_OPTIONS $DEBUG $DEMAND @@ -311,9 +434,13 @@ case "${1}" in evaluate_retval # echo PPP: /usr/sbin/pppd pty "$PPPOE_CMD" $PPP_STD_OPTIONS $DEBUG $DEMAND $PPPD_SYNC fi - + ## Create & Enable vnstat + /usr/bin/vnstat -u -i ppp0 -r --enable --force > /dev/null 2>&1 /etc/rc.d/init.d/connectd start - + # Add a NaN value to ppp0 rrd to supress spikes at reconnect + rrdtool update $RRDLOG/collectd/localhost/interface/if_octets-ppp0.rrd \ + $(date +%s):: > /dev/null 2>&1 + exit 0 fi ;; @@ -323,69 +450,68 @@ case "${1}" in ip route del default via ${GATEWAY} >/dev/null 2>&1 echo_ok if [ "$DEVICE" != "${GREEN_DEV}" ]; then - boot_mesg "Removing IPv4 address ${ADDRESS} from the ${DEVICE} interface..." - ip addr del ${args} dev ${DEVICE} + boot_mesg "Removing IPv4 addresses from the ${DEVICE} interface..." + ip addr flush dev ${DEVICE} evaluate_retval fi run_subdir ${rc_base}/init.d/networking/red.down/ - - elif [ "$TYPE" == "DHCP" ]; then - boot_mesg -n "Stopping dhcpcd on the ${DEVICE} interface..." - if [ -e $LEASEINFO ]; then - . $LEASEINFO - if [ "$LEASETIME" = "4294967295" ]; then - # do nothing, just echo ok - echo "" - echo_ok - else - if [ -n "$DHCP_STOP" ]; then - /sbin/dhcpcd ${DEVICE} $DHCP_STOP &> /dev/null - RET="$?" - if [ "$RET" -eq 0 ]; then - echo "" - echo_ok - elif [ "$RET" -eq 1 ]; then - boot_mesg "dhcpcd not running!" ${WARNING} - echo_warning - else - echo "" - echo_failure - fi - else - echo "" - killproc dhcpcd - fi - fi - else - boot_mesg -n "LEASEINFO Test failed! - " ${WARNING} - boot_mesg "dhcpcd is not running!" ${WARNING} - echo_warning - exit 1 - fi - + elif [ "$TYPE" == "PPPOE" ]; then boot_mesg "Bringing down the PPP interface ..." + ## Disable vnstat collection + /usr/bin/vnstat -u -i ppp0 -r --disable > /dev/null 2>&1 rm -f /var/ipfire/red/keepconnected killall -w -s TERM /usr/sbin/pppd 2>/dev/null evaluate_retval - ip addr del 1.1.1.1/24 broadcast 1.1.1.255 dev ${DEVICE} >/dev/null 2>&1 + # Add a NaN value to ppp0 rrd to supress spikes at reconnect + rrdtool update $RRDLOG/collectd/localhost/interface/if_octets-ppp0.rrd \ + $(date +%s):: > /dev/null 2>&1 + + elif [ "$TYPE" == "DHCP" ]; then + # Check if the wlan-client is used on red. + # To determine this we check if a wpa_supplicant is running. + pid="$(pidof wpa_supplicant)" + + if [ -z "${pid}" ]; then + # Stop dhcpcd. + dhcpcd_stop "${DEVICE}" + fi + fi + + if [ -n "${PPTP_ROUTE}" ]; then + route del ${PPTP_ROUTE} fi if [ "$DEVICE" != "${GREEN_DEV}" ] && [ "$DEVICE" != "" ]; then - link_status=`ip link show $DEVICE 2> /dev/null` + link_status=`ip link show $DEVICE.${INET_VLAN} 2> /dev/null` if [ -n "${link_status}" ]; then if echo "${link_status}" | grep -q UP; then - boot_mesg "Bringing down the ${DEVICE} interface..." - ip link set ${DEVICE} down + boot_mesg "Bringing down the ${DEVICE}.${INET_VLAN} interface..." + ip link set ${DEVICE}.${INET_VLAN} down + vconfig rem ${DEVICE}.${INET_VLAN} evaluate_retval fi + else + link_status=`ip link show $DEVICE 2> /dev/null` + if [ -n "${link_status}" ]; then + if echo "${link_status}" | grep -q UP; then + boot_mesg "Bringing down the ${DEVICE} interface..." + ip link set ${DEVICE} down + evaluate_retval + fi + fi fi fi - killall -w -s TERM /usr/sbin/pppd >/dev/null 2>&1 - killall -w -s TERM br2684ctl >/dev/null 2>&1 + killall -w -s KILL /usr/sbin/pppd >/dev/null 2>&1 + killall -w -s KILL pptp >/dev/null 2>&1 + killall -w -s KILL br2684ctl >/dev/null 2>&1 + + ## Disable vnstat collection + /usr/bin/vnstat -u -i ${DEVICE} -r --disable > /dev/null 2>&1 + rm -f /var/ipfire/red/{active,device,dial-on-demand,dns1,dns2,local-ipaddress,remote-ipaddress,resolv.conf} + exit 0; ;; - esac # End