diff options
-rw-r--r-- | ChangeLog | 8 | ||||
-rw-r--r-- | Makefile | 2 | ||||
-rw-r--r-- | initscripts.spec | 9 | ||||
-rwxr-xr-x | rc.d/init.d/network | 3 | ||||
-rwxr-xr-x | sysconfig/network-scripts/ifdown-ippp | 26 | ||||
-rwxr-xr-x | sysconfig/network-scripts/ifup-ippp | 290 |
6 files changed, 335 insertions, 3 deletions
@@ -1,3 +1,11 @@ +2001-06-21 Than Ngo <than@redhat.com> + * initscripts.spec: 5.91-1 + + * add sysconfig/network-scripts/ifup-ippp sysconfig/network-scripts/ifdown-ippp + * rc.d/init.d/network + * Makefile + - add support isdn + 2001-06-20 Bill Nottingham <notting@redhat.com> * initscripts.spec: 5.90-1 @@ -45,6 +45,8 @@ install: mv $(ROOT)/etc/sysconfig/network-scripts/ifup $(ROOT)/sbin mv $(ROOT)/etc/sysconfig/network-scripts/ifdown $(ROOT)/sbin (cd $(ROOT)/etc/sysconfig/network-scripts; \ + ln -sf ifup-ippp ifup-isdn ; \ + ln -sf ifdown-ippp ifdown-isdn ; \ ln -sf ../../../sbin/ifup . ; \ ln -sf ../../../sbin/ifdown . ) (cd src; make install ROOT=$(ROOT) mandir=$(mandir)) diff --git a/initscripts.spec b/initscripts.spec index 5881e67d..ad86ad1e 100644 --- a/initscripts.spec +++ b/initscripts.spec @@ -1,6 +1,6 @@ Summary: The inittab file and the /etc/init.d scripts. Name: initscripts -Version: 5.90 +Version: 5.91 License: GPL Group: System Environment/Base Release: 1 @@ -172,6 +172,10 @@ rm -rf $RPM_BUILD_ROOT %config /etc/sysconfig/network-scripts/ifup-sit %config /etc/sysconfig/network-scripts/ifdown-sit %config /etc/sysconfig/network-scripts/ifup-aliases +%config /etc/sysconfig/network-scripts/ifup-ippp +%config /etc/sysconfig/network-scripts/ifdown-ippp +/etc/sysconfig/network-scripts/ifup-isdn +/etc/sysconfig/network-scripts/ifdown-isdn %ifarch s390 s390x %config /etc/sysconfig/network-scripts/ifup-ctc %config /etc/sysconfig/network-scripts/ifup-iucv @@ -217,6 +221,9 @@ rm -rf $RPM_BUILD_ROOT %ghost %attr(0664,root,utmp) /var/run/utmp %changelog +* Thu Jun 21 2001 Than Ngo <than@redhat.com> +- add support ISDN + * Wed Jun 20 2001 Bill Nottingham <notting@redhat.com> - fix extremely broken new network scripts diff --git a/rc.d/init.d/network b/rc.d/init.d/network index 21df2eb5..60913df7 100755 --- a/rc.d/init.d/network +++ b/rc.d/init.d/network @@ -1,4 +1,4 @@ -#!/bin/bash +#! /bin/bash # # network Bring up/down networking # @@ -45,7 +45,6 @@ cd /etc/sysconfig/network-scripts interfaces=`ls ifcfg* | LANG=C egrep -v '(ifcfg-lo|:|rpmsave|rpmorig|rpmnew)' | \ LANG=C egrep -v '(~|\.bak)$' | \ LANG=C egrep -v 'ifcfg-cipcb[0-9]+$' | \ - LANG=C egrep -v 'ifcfg-ippp[0-9]+$' | \ LANG=C egrep 'ifcfg-[a-z0-9]+$' | \ sed 's/^ifcfg-//g'` diff --git a/sysconfig/network-scripts/ifdown-ippp b/sysconfig/network-scripts/ifdown-ippp new file mode 100755 index 00000000..f124a867 --- /dev/null +++ b/sysconfig/network-scripts/ifdown-ippp @@ -0,0 +1,26 @@ +#! /bin/sh + +PATH=/sbin:/usr/sbin:/bin:/usr/bin + +CONFIG=$1 + +. $CONFIG + +# stopping ibod daemon for channel bundling +if [ -f /var/lock/subsys/ibod ] ; then + kill -9 $(pidof ibod) >/dev/null 2>&1 + rm -f /var/lock/subsys/ibod +fi + +# shutdown isdn device +ifconfig $DEVICE down >/dev/null 2>&1 + +# delete isdn device +isdnctrl delif $DEVICE >/dev/null 2>&1 + +# kill ipppd daemon +if [ -f /var/run/ipppd.$DEVICE.pid ] ; then + pppdpid=`cat /var/run/ipppd.$DEVICE.pid` + kill -9 $pppdpid > /dev/null 2>&1 + rm -f /var/run/ipppd.$DEVICE.pid > /dev/null 2>&1 +fi diff --git a/sysconfig/network-scripts/ifup-ippp b/sysconfig/network-scripts/ifup-ippp new file mode 100755 index 00000000..91584fc2 --- /dev/null +++ b/sysconfig/network-scripts/ifup-ippp @@ -0,0 +1,290 @@ +#! /bin/sh +# +# ifup-ippp +# +# This script is normally called from the ifup script when it detects a ippp device. + +PATH=/sbin:/usr/sbin:/bin:/usr/bin + +DEBUG="no" + +# set device +CONFIG=$1 + +# load device net config +. $CONFIG + +# check that ipppd is available for syncppp +if [ "$ENCAP" = "syncppp" ]; then + if [ ! -x /usr/sbin/ipppd -a ! -x /sbin/ipppd ] ; then + logger -p daemon.info -t ifup-ippp "ipppd does not exist or is not executable" + exit 1 + fi +fi + +# check that isdnctrl is available +if [ ! -x /usr/sbin/isdnctrl -a ! -x /sbin/isdnctrl ] ; then + logger -p daemon.info -t ifup-ippp "isdnctrl does not exist or is not executable" + exit 1 +fi + +# load provider config +#[ -f /etc/sysconfig/networking/devices/$DEVICE.d/dialup ] || exit 1 +#. /etc/sysconfig/networking/devices/$DEVICE.d/dialup + +# check if device already is configured +isdnctrl list $DEVICE >/dev/null 2>&1 && exit 0 + +function log_echo() +{ + logger -p daemon.info -t ifup-ppp $"$*" +} + +function log_isdnctrl() +{ + logger -p daemon.info -t ifup-ppp isdnctrl $* + isdnctrl $* >/dev/null 2>&1 +} + +function start_ibod() +{ + # don't start ibod, if it's running + [ -f /var/lock/subsys/ibod ] && return + + device=$1 + if [ -f /etc/isdn/ibod.cf -a -x /usr/sbin/ibod ] ; then + ibod $device & + pid=`pidof ibod` + [ -n "$pid" ] && touch /var/lock/subsys/ibod + fi +} + +function addprovider() +{ + options= + if [ -z "$MSN" ]; then + log_echo "Error: $1: MSN not set" + return 1 + fi + if [ -z "$PHONE_OUT" ]; then + log_echo "Error: $1: no outgoing phone number set" + return 1 + fi + + # set the encapsulation mode + [ -z "$ENCAP" ] && ENCAP="syncppp" + + # set the dial mode + [ -z "$DIALMODE" ] && DIALMODE="off" + + [ "$AUTH" = "none" ] && AUTH="" + + # set layer-2/3 protocol + [ -z "$L2_PROT" ] && L2_PROT="hdlc" + [ -z "$L3_PROT" ] && L3_PROT="trans" + + # check local/remote IP + [ -z "$LOCAL_IP" ] && LOCAL_IP="0.0.0.0" + [ -z "$REMOTE_IP" ] && REMOTE_IP="0.0.0.0" + + # set default route + [ "$DELDEFAULTROUTE" = "enabled" -o -z "$DELDEFAULTROUTE" ] && options="$options deldefaultroute" + + # set authentication + [ -z "$USER" ] && USER="dialup" + if [ "$AUTH" = "-pap +chap" ]; then + options="$options name $USER" + else + options="$options user $USER" + fi + + # add ISDN device + log_isdnctrl addif $DEVICE + + # set local MSN + log_isdnctrl eaz $DEVICE $MSN + + # set dialout numbers + for i in $PHONE_OUT; do + log_isdnctrl addphone $DEVICE out $COUNTRYCODE$PREFIX$AREACODE$i + done + for i in $PHONE_IN; do + log_isdnctrl addphone $DEVICE in $i + done + + # set layer-2/3 protocol + log_isdnctrl l2_prot $DEVICE $L2_PROT + log_isdnctrl l3_prot $DEVICE $L3_PROT + + # set encapsulation + log_isdnctrl encap $DEVICE $ENCAP + + # set dialmode + log_isdnctrl dialmode $DEVICE $DIALMODE + + [ -n "$SECURE" ] && log_isdnctrl secure $DEVICE $SECURE + [ -n "$HUPTIMEOUT" ] && log_isdnctrl huptimeout $DEVICE $HUPTIMEOUT + [ -n "$CHARGEHUP" ] && log_isdnctrl chargehup $DEVICE $CHARGEHUP + [ -n "$CHARGEINT" ] && log_isdnctrl chargeint $DEVICE $CHARGEINT + + [ -n "$IHUP" ] && log_isdnctrl ihup $DEVICE $IHUP + + # set the number of dial atempts for each number + [ -n "$DIALMAX" ] && log_isdnctrl dialmax $DEVICE $DIALMAX + + # set callback + if [ "$CALLBACK" = "out" ]; then + log_isdnctrl callback $DEVICE $CALLBACK + else + log_isdnctrl callback $DEVICE off + fi + [ -n "$CBDELAY" ] && log_isdnctrl cbdelay $DEVICE $CBDELAY + [ -n "$CBHUP" ] && log_isdnctrl cbhup $DEVICE $CBHUP + + options="$options ipparam $DEVICE" + log_isdnctrl pppbind $DEVICE + if [ -z "$LOCAL_IP" ]; then + LOCAL_IP="0.0.0.0" + options="$options ipcp-accept-local" + else + options="$options noipdefault" + fi + # Add device + options="$options /dev/$DEVICE" + + # set channel bundling + if [ "$BUNDLING" = "yes" -a -n "$SLAVE_DEVICE" ]; then + [ -z "$SLAVE_MSN" ] && SLAVE_MSN="$MSN" + [ -z "$SLAVE_PHONE_OUT" ] && SLAVE_PHONE_OUT="$PHONE_OUT" + [ -z "$SLAVE_PHONE_IN" ] && SLAVE_PHONE_IN="$PHONE_IN" + [ -z "$SLAVE_HUPTIMEOUT" ] && SLAVE_HUPTIMEOUT="$HUPTIMEOUT" + [ -z "$SLAVE_CHARGEHUP" ] && SLAVE_CHARGEHUP="$CHARGEHUP" + [ -z "$SLAVE_CHARGEINT" ] && SLAVE_CHARGEINT="$CHARGEINT" + [ -z "$SLAVE_CBHUP" ] && SLAVE_CBHUP="$CBHUP" + [ -z "$SLAVE_IHUP" ] && SLAVE_IHUP="$IHUP" + [ -z "$SLAVE_DIALMAX" ] && SLAVE_DIALMAX="$DIALMAX" + [ -z "$SLAVE_CALLBACK" ] && SLAVE_CALLBACK="$CALLBACK" + [ -z "$SLAVE_CBDELAY" ] && SLAVE_CBDELAY="$CBDELAY" + [ -z "$SLAVE_DIALMODE" ] && SLAVE_DIALMODE="auto" + + slave=$SLAVE_DEVICE + options="$options /dev/$slave +mp" + + # Create slave and set options + log_isdnctrl addslave $DEVICE $slave + log_isdnctrl eaz $slave $SLAVE_MSN + + # set phone number + for i in $SLAVE_PHONE_OUT; do + log_isdnctrl addphone $slave out $COUNTRYCODE$PREFIX$AREACODE$i + done + for i in $SLAVE_PHONE_IN; do + log_isdnctrl addphone $slave in $i + done + + # set layer-2/3 protocol + log_isdnctrl l2_prot $slave $L2_PROT + log_isdnctrl l3_prot $slave $L3_PROT + + # set encapsulation + log_isdnctrl encap $slave $ENCAP + + # set dial mode + log_isdnctrl dialmode $slave $SLAVE_DIALMODE + + [ -n "$SECURE" ] && log_isdnctrl secure $slave $SECURE + [ -n "$SLAVE_HUPTIMEOUT" ] && log_isdnctrl huptimeout $slave $SLAVE_HUPTIMEOUT + [ -n "$SLAVE_CHARGEHUP" ] && log_isdnctrl chargehup $slave $SLAVE_CHARGEHUP + [ -n "$SLAVE_CHARGEINT" ] && log_isdnctrl chargeint $slave $SLAVE_CHARGEINT + [ -n "$SLAVE_IHUP" ] && log_isdnctrl ihup $slave $SLAVE_IHUP + [ -n "$SLAVE_DIALMAX" ] && log_isdnctrl dialmax $slave $SLAVE_DIALMAX + + # set callback + [ -n "$SLAVE_CBHUP" ] && log_isdnctrl cbhup $slave $SLAVE_CBHUP + [ -n "$SLAVE_CALLBACK" ] || SLAVE_CALLBACK="off" + log_isdnctrl callback $slave $SLAVE_CALLBACK + [ -n "$SLAVE_CBDELAY" ] && log_isdnctrl cbdelay $DEVICE $SLAVE_CBDELAY + + # options for master device + [ -n "$SLAVE_DELAY" ] && log_isdnctrl sdelay $DEVICE $SLAVE_DELAY + [ -n "$SLAVE_TRIGGER" ] && log_isdnctrl trigger $DEVICE $SLAVE_TRIGGER + fi + + if [ -z "$REMOTE_IP" ]; then + REMOTE_IP="0.0.0.0" + options="$options ipcp-accept-remote" + options="$LOCAL_IP:$REMOTE_IP $options" + else + options="$options $LOCAL_IP:$REMOTE_IP" + fi + + # Add default route while connection + options="$options defaultroute" + + # configure Van Jacobson style TCP/IP header compression and + # VJ connection-ID compression + [ "$VJ" = "off" ] && options="$options -vj" + [ "$VJCCOMP" = "off" ] && options="$options -vjccomp" + + # configure Address/Control compression, protocol field compression and + # BSD-Compression scheme + [ "$AC" = "off" ] && options="$options -ac" + [ "$PC" = "off" ] && options="$options -pc" + [ "$BSDCOMP" = "off" ] && options="$options -bsdcomp" + + # Set max receive and max transmit units + [ -n "$MRU" ] && options="$options mru $MRU" + [ -n "$MTU" ] && options="$options mtu $MTU" + + # set CBCP protocoll + [ "$CBCP" = "on" ] && options="$options callback 6" + + # set CCP protocoll + [ "$CCP" = "off" ] && options="$options noccp" + + # set host name + [ -n "$ISDN_HOSTNAME" ] && options="$options hostname $ISDN_HOSTNAME" + + # Set authentication + for i in $AUTH ; do + options="$options $i" + done + + # check dns entry + if [ -z "$DNS1" -a -z "$DNS2" ]; then + options="$options ms-get-dns" + else + options="$options ms-dns $DNS1 $DNS2" + fi + + # set debug + [ "$DEBUG" = "yes" ] && options="-d $options" + + # activate ISDN device + ifconfig $DEVICE $LOCAL_IP pointopoint $REMOTE_IP up >/dev/null 2>&1 + + if [ "$ENCAP" = "syncppp" ]; then + # start ipppd daemon + ipppd $options + + # start ibod daemon + [ "$BUNDLING" = "yes" -a -n "$SLAVE_DEVICE" ] && start_ibod $DEVICE + fi + + # set default gateway for dial on demand + if [ "$DIALMODE" = "auto" ]; then + echo 1 > /proc/sys/net/ipv4/ip_dynaddr + route del default >/dev/null 2>&1 + if [ -z "$REMOTE_IP" -o "$REMOTE_IP" = "0.0.0.0" ]; then + route add default $DEVICE >/dev/null 2>&1 + else + route add default gw $REMOTE_IP >/dev/null 2>&1 + fi + fi +} + +addprovider || exit 1 + +/etc/sysconfig/network-scripts/ifup-post $CONFIG + +exit 0 |