blob: 55a1ec38b4e0b7ee5185cd3a9a1869e80d9a964f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
|
#!/sbin/runscript
# Copyright 1999-2000 Gentoo Technologies, Inc.
# Distributed under the terms of the GNU General Public License, v2 or later
# Author Martin Schlemmer <azarah@gentoo.org>
# Credits To all those I got ideas from :)
# $Header: /var/cvsroot/gentoo-x86/net-dialup/ppp/files/2.4.1-r6/net.ppp0,v 1.1 2001/11/11 19:47:03 azarah Exp $
PEER="isp" # Define peer (aka ISP)
DEBUG="no" # Turn on debugging
PERSIST="no" # Redial after being dropped
ONDEMAND="no" # Only bring the interface up on demand?
MODEMPORT="/dev/ttyS0" # TTY device modem is connected to
LINESPEED="115200" # Speed pppd should try to connect at
INITSTRING="AT&S2=255" # Extra init string for the modem
DEFROUTE="yes" # Must pppd set the default route?
HARDFLOWCTL="yes" # Use hardware flow control?
ESCAPECHARS="yes" # Use escape caracters ?
PPPOPTIONS="" # Extra options for pppd
USERNAME="user" # The PAP/CHAP username
PASSWORD="passwd" # Your password/secret. Ugly I know, but i
# will work on something more secure later
# on. 700 permission on /etc/init.d/net.ppp0
# should be enouth for now.
NUMBER="9180000" # The telephone number of your ISP
REMIP="" # The ip of the remote box if it should be set
NETMASK="" # Netmask
IPADDR="" # Our IP if we have a static one
MRU="768" # Sets the MRU
MTU="768" # Sets the MTU
RETRYTIMEOUT="60" # Retry timeout for when ONDEMAND="yes" or
# PERSIST="yes"
IDLETIMEOUT="600" # Idle timeout for when ONDEMAND="yes"
PEERDNS="no" # Should pppd set the peer dns?
FWSCRIPT="/etc/init.d/firewall" # Optional FW script that pppd should start
# and stop when the link comes up or drop.
# It should be a script that takes two
# argument, namely the name of the external
# interface on which the firewall should be
# activated and start/stop.
#
# called: ${FWSCRIPT} ${DEVICE} [start|stop]
AUTOCFGFILES="yes" # By default this scripts will generate
# /etc/ppp/chat-isp, /etc/ppp/chap-secrets,
# /etc/ppp/pap-secrets and /etc/ppp/peers/isp
# automagically. Set to "no" if you experience
# problems, or need specialized scripts. You
# will have to create these files by hand then.
# Also, the FWSTART/FWSTOP feature will not
# work.
# Do not change .. for determining name of interface
DEVICE="${1##*.}"
local CMD_LINE
checkconfig() {
if [ ! -x "`which pppd`" ] || [ ! -x "`which chat`" ] ; then
eerror "pppd and chat needs to be installed"
return 1
fi
if [ -e "/var/run/ppp-${DEVICE}.pid" ] && [ "${1}" = "start" ] ; then
eerror "ppp0 is already up"
return 1
fi
if [ ! -e "/var/run/ppp-${DEVICE}.pid" ] && [ "${1}" = "stop" ] ; then
eerror "ppp0 not up"
return 1
fi
}
start() {
checkconfig || return 1
setup_cmd_line
setup_cfg_files
ebegin "Bringing ${DEVICE} up"
if [ -x "`which pppd`" ]; then
if [ "${DEFROUTE}" = "yes" ] ; then
[ "`/sbin/route |grep default`" ] && route del default
fi
if [ "${PEERDNS}" = "yes" ] ; then
[ -e /etc/ppp/resolv.conf ] && mv /etc/ppp/resolv.conf
/usr/sbin/pppd ${CMD_LINE} ${MODEMPORT} ${LINESPEED} ipparam ${DEVICE} \
linkname ${DEVICE} call ${PEER} noauth ${PPPOPTIONS}
fi
eend
}
stop() {
checkconfig || return 1
ebegin "Bringing ${DEVICE} down"
if [ -x "`which ifconfig`" ]; then
/sbin/ifconfig ${DEVICE} down
fi
eend
}
setup_cmd_line() {
CMD_LINE="lock"
if [ "${DEBUG}" = "yes" ] ; then
CMD_LINE="${CMD_LINE} debug"
fi
if [ "${PERSIST}" = "yes" ] ; then
CMD_LINE="${CMD_LINE} persist holdoff ${RETRYTIMEOUT}"
fi
if [ "${DEFROUTE}" = "yes" ] ; then
CMD_LINE="${CMD_LINE} defaultroute"
fi
if [ "${HARDFLOWCTL}" = "yes" ] ; then
CMD_LINE="${CMD_LINE} modem crtscts"
fi
if [ "${ESCAPECHARS}" = "yes" ] ; then
CMD_LINE="${CMD_LINE} asyncmap 00000000"
fi
if [ "${PEERDNS}" = "yes" ] ; then
CMD_LINE="${CMD_LINE} usepeerdns"
fi
if [ -n "${IPADDR}${REMIP}" ] ; then
CMD_LINE="${CMD_LINE} ${IPADDR}:${REMIP}"
fi
if [ -n "${NETMASK}" ] ; then
CMD_LINE="${CMD_LINE} netmask ${NETMASK}"
fi
if [ -n "${MRU}" ] ; then
CMD_LINE="${CMD_LINE} mru ${MRU}"
fi
if [ -n "${MTU}" ] ; then
CMD_LINE="${CMD_LINE} mtu ${MTU}"
fi
if [ -n "${PAPNAME}" ] ; then
CMD_LINE="${CMD_LINE} user ${USERNAME} remotename ${PEER}"
fi
if [ "${ONDEMAND}" = "yes" ] ; then
CMD_LINE="${CMD_LINE} demand ktune idle ${IDLETIMEOUT} holdoff ${RETRYTIMEOUT}"
fi
}
setup_cfg_files() {
if [ "${AUTOCFGFILES}" = "yes" ] ; then
# Setup the peers file
echo "connect '/usr/sbin/chat -v -f /etc/ppp/chat-${PEER}'" \
>/etc/ppp/peers/${PEER}
# Setup the secrets files
echo "${USERNAME} ${PEER} ${PASSWORD}" >/etc/ppp/chap-secrets
chmod 660 /etc/ppp/chap-secrets
echo "${USERNAME} ${PEER} ${PASSWORD}" >/etc/ppp/pap-secrets
chmod 660 /etc/ppp/pap-secrets
# Setup the chat file
sed -e "9i\\'OK\' \'${INITSTRING}\'" \
-e "s:\$NUMBER:${NUMBER}:" \
/usr/lib/ppp/chat-default \
>/etc/ppp/chat-${PEER}
# Setup if-up and if-down
if [ -x ${FWSCRIPT} ] ; then
echo "${FWSCRIPT} \${6} start" >/etc/ppp/if-up
chmod 770 /etc/ppp/if-up
echo "${FWSCRIPT} \${6} stop" >/etc/ppp/if-down
chmod 770 /etc/ppp/if-down
if [ "${PEERDNS}" = "yes" ] ; then
# if-up: add the server supplied DNS entries to
# /etc/resolv.conf
echo "cp -f /etc/resolv.conf /etc/resolv.conf.old" \
>>/etc/ppp/if-up
echo "cat /etc/ppp/resolv.conf >> /etc/resolv.conf" \
>>/etc/ppp/if-up
# if-down: restore original /etc/resolv.conf
echo "mv -f /etc/resolv.conf.old /etc/resolv.conf" \
>>/etc/ppp/if-down
fi
fi
fi
}
|