Files
bpfire/src/initscripts/init.d/red
ms 24249567ce Credits ueberarbeitet.
Menue Rewrite
Connectioncheck gefixt --> DSL/PPPoE works!


git-svn-id: http://svn.ipfire.org/svn/ipfire/trunk@418 ea5c0bd1-69bd-2848-81d8-4f18e57aeed8
2007-02-14 19:30:59 +00:00

844 lines
28 KiB
Perl

#!/usr/bin/perl
#
# This file is part of the IPCop Firewall.
#
# IPCop is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# IPCop is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with IPCop; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#
# (c) The SmoothWall Team
#
# Clean up our environment (we're running SUID!)
delete @ENV{qw(IFS CDPATH ENV BASH_ENV PATH)};
$< = $>;
use strict;
require '/var/ipfire/general-functions.pl';
my %pppsettings;
my %isdnsettings;
my %netsettings;
my %dhcpsettings;
my $iface;
# read vars back from file.
&General::readhash("${General::swroot}/ppp/settings", \%pppsettings);
&General::readhash("${General::swroot}/isdn/settings", \%isdnsettings);
&General::readhash("${General::swroot}/ethernet/settings", \%netsettings);
&General::readhash("${General::swroot}/dhcp/settings", \%dhcpsettings);
sub dodhcpdial($;$) {
my ($iface,$dhcp_name)=@_;
system ('/sbin/iptables', '-A', 'REDINPUT', '-p', 'tcp', '--source-port', '67',
'--destination-port', '68', '-i', $iface, '-j', 'ACCEPT');
system ('/sbin/iptables', '-A', 'REDINPUT', '-p', 'udp', '--source-port', '67',
'--destination-port', '68', '-i', $iface, '-j', 'ACCEPT');
foreach ("<${General::swroot}/dhcpc/*.info>") { unlink $1 if ( $_ =~ /^([\/\w.-]+)$/ ); }
my @dhcpcommand = ('/sbin/dhcpcd');
push(@dhcpcommand, ('-N', '-R', "$iface",'-L', "${General::swroot}/dhcpc"));
#FIXME the only way actually to set debug use is in pppsetup.cgi and 'RED is modem/isdn' interface
if ($pppsettings{'DEBUG'} eq 'on') {
push(@dhcpcommand, ('-d'));
}
if ($dhcp_name ne '') { push(@dhcpcommand, ('-h', "$dhcp_name", "&>/dev/null")); }
if ($netsettings{'RED_TYPE'} eq 'PPTP') { push(@dhcpcommand, '-G'); }
if (system (@dhcpcommand)) {
&General::log('dhcpcd fail');
exit 1;
} else {
&General::log('dhcpcd success');
}
}
sub doupdatesettings {
# complete cleanup only if settings were changed or clear is ordered
system('/sbin/modprobe', '-r', 'pppoatm');
system('/sbin/modprobe', '-r', 'pppoe');
system('/bin/killall /usr/bin/br2684ctl 2>/dev/null');
system('/sbin/modprobe', '-r', 'br2684');
system('/sbin/modprobe', '-r', 'clip');
if ($pppsettings{'TYPE'} ne 'fritzdsl') {
system('/sbin/modprobe', '-r', 'fcdsl', 'fcdsl2', 'fcdslsl', 'fcdslusb', 'fcdslslusb');}
sleep 1;
# remove existing default route (for static address) if it was been changed from setup or web interface SF1175052
system ('/sbin/route del default 2>/dev/null');
# erase in case it was created once with 'persistent' selected but rc.red stop never used : SF1171610
unlink ("${General::swroot}/red/iface");
}
# No output should be sent to the webclient
open STDIN, '</dev/zero' or die "Can't read from /dev/zero";
open STDOUT, '>/dev/null' or die "Can't write to /dev/null";
if ($ARGV[0] eq 'start') {
if (-e "${General::swroot}/red/active" ||
-e '/var/run/ppp-ipfire.pid')
{
&General::log ("ERROR: Can't start RED when it's still active");
exit 1;
}
if ( ( ( ($netsettings{'RED_TYPE'} =~ /^(PPPOE|PPTP)$/) && ($netsettings{'CONFIG_TYPE'} =~ /^(2|3|6|7)$/) ) ||
( ( ($pppsettings{'METHOD'} =~ /^(PPPOE|PPPOE_PLUGIN)$/) || ($pppsettings{'PROTOCOL'} eq 'RFC2364') ) &&
($netsettings{'CONFIG_TYPE'} =~ /^(0|1|4|5)$/) ) ) && ($pppsettings{'RECONNECTION'} ne 'manual') ) {
system ('/etc/rc.d/init.d/connectioncheck start &');
}
###
### Red device is ethernet
###
if ($netsettings{'CONFIG_TYPE'} =~ /^(2|3|6|7)$/)
{
if ($netsettings{'RED_DEV'} ne '')
{
&General::log("Starting RED device $netsettings{'RED_DEV'}.");
if ( $netsettings{'RED_TYPE'} eq 'DHCP')
{
if (open(FILE, ">${General::swroot}/red/iface")) { print FILE $netsettings{'RED_DEV'}; close FILE; }
dodhcpdial($netsettings{'RED_DEV'},$netsettings{'RED_DHCP_HOSTNAME'});
exit 0;
}
elsif ( ( $netsettings{'RED_TYPE'} eq 'PPTP') && ( $pppsettings{'METHOD'} eq 'DHCP') )
{
if (open(FILE, ">${General::swroot}/red/device")) { print FILE $netsettings{'RED_DEV'}; close FILE; }
unlink ("${General::swroot}/red/iface");
dodhcpdial($netsettings{'RED_DEV'},$netsettings{'RED_DHCP_HOSTNAME'});
}
elsif ( ( $netsettings{'RED_TYPE'} eq 'STATIC') ||
( $netsettings{'RED_TYPE'} eq 'PPTP') && ( $pppsettings{'METHOD'} ne 'DHCP') )
{
system ("/sbin/ifconfig",
$netsettings{'RED_DEV'}, $netsettings{'RED_ADDRESS'},
"netmask", $netsettings{'RED_NETMASK'},
"broadcast", $netsettings{'RED_BROADCAST'},"up");
if ( $netsettings{'RED_TYPE'} eq 'STATIC')
{
system("/usr/local/bin/setaliases");
system("echo $netsettings{'DNS1'} > ${General::swroot}/red/dns1");
system("echo $netsettings{'DNS2'} > ${General::swroot}/red/dns2");
system("echo $netsettings{'RED_ADDRESS'} > ${General::swroot}/red/local-ipaddress");
system("echo $netsettings{'DEFAULT_GATEWAY'} > ${General::swroot}/red/remote-ipaddress");
} elsif ( $netsettings{'RED_TYPE'} eq 'PPTP' ) {
if (open(FILE, ">${General::swroot}/red/device")) { print FILE $netsettings{'RED_DEV'}; close FILE; }
unlink ("${General::swroot}/red/iface");
}
if ( $netsettings{'DEFAULT_GATEWAY'} ne '' )
{
system ("/sbin/route","add","default","gw",
$netsettings{'DEFAULT_GATEWAY'});
}
}
else
{
# PPPoE
system ("/sbin/ifconfig", $netsettings{'RED_DEV'}, "1.1.1.1",
"netmask", "255.255.255.0", "broadcast", "1.1.1.255", "up");
}
if ( $netsettings{'RED_TYPE'} eq 'STATIC')
{
if (open(FILE, ">${General::swroot}/red/iface")) { print FILE $netsettings{'RED_DEV'}; close FILE; }
system ("/bin/touch", "${General::swroot}/red/active");
system ("/etc/rc.d/init.d/network red update");
exit 0;
}
}
else
{
&General::log ("ERROR: Can't start RED when RED device not set!");
exit 1;
}
}
if ($pppsettings{'RECONNECTION'} eq 'dialondemand')
{
system ('/bin/touch', "${General::swroot}/red/dial-on-demand");
}
if ($pppsettings{'VALID'} ne 'yes') {
&General::log("Profile has errors.");
exit 1;
}
if (-e "${General::swroot}/ppp/updatesettings") {
&doupdatesettings;
}
if (( $pppsettings{'METHOD'} eq 'STATIC') && ( $pppsettings{'DNS'} eq 'Manual')) {
system("/usr/local/bin/setaliases");
if (open(FILE, ">${General::swroot}/red/dns1")) { print FILE $pppsettings{'DNS1'}; close FILE; }
if (open(FILE, ">${General::swroot}/red/dns2")) { print FILE $pppsettings{'DNS2'}; close FILE; }
if (open(FILE, ">${General::swroot}/red/local-ipaddress")) { print FILE $pppsettings{'IP'}; close FILE; }
if (open(FILE, ">${General::swroot}/red/remote-ipaddress")) { print FILE $pppsettings{'GATEWAY'}; close FILE; }
}
if ($pppsettings{'RECONNECTION'} eq 'dialondemand') {
&General::log("Dial-on-Demand waiting to dial $pppsettings{'PROFILENAME'}.");
} else {
&General::log("Dialling $pppsettings{'PROFILENAME'}.");
}
if ($pppsettings{'TYPE'} eq 'modem') { &domodemdial(); }
elsif ($pppsettings{'TYPE'} eq 'serial') { &doserialdial(); }
elsif ($pppsettings{'TYPE'} eq 'isdn') { &doisdndial(); }
elsif ($pppsettings{'TYPE'} eq 'pppoe') { &dopppoedial(); }
elsif ($pppsettings{'TYPE'} eq 'pptp') { &dopptpdial(); }
elsif ($pppsettings{'TYPE'} eq 'fritzdsl') { &dofritzdsldial(); }
if (-e "${General::swroot}/ppp/updatesettings") {
# erase update mark only after specific script had run, allowing specific script to treat the update
unlink ("${General::swroot}/ppp/updatesettings");
}
if ( ($pppsettings{'RECONNECTION'} eq 'dialondemand') || ($pppsettings{'METHOD'} eq 'STATIC') ){
system ("/etc/rc.d/init.d/network red update");
}
}
elsif ($ARGV[0] eq 'stop')
{
if (open(IFACE, "${General::swroot}/red/iface")) {
$iface = <IFACE>;
close IFACE;
chomp ($iface);
$iface =~ /([a-zA-Z0-9]*)/; $iface = $1;
}
my $device;
if (open(FILE, "${General::swroot}/red/device")) {
$device = <FILE>;
close FILE;
chomp ($device);
$device =~ /([a-zA-Z0-9]*)/; $device = $1;
}
unlink "${General::swroot}/red/dial-on-demand";
unlink "${General::swroot}/red/active";
unlink "${General::swroot}/red/local-ipaddress";
unlink "${General::swroot}/red/remote-ipaddress";
unlink "${General::swroot}/red/dns1";
unlink "${General::swroot}/red/dns2";
unlink "${General::swroot}/red/resolv.conf";
unlink "${General::swroot}/red/device";
# stay with keepconnected during transitional rc.red stop ordered by connectioncheck
if ( ! -e "${General::swroot}/red/redial") {
unlink "${General::swroot}/red/keepconnected";
}
unlink "${General::swroot}/red/redial";
# Kill PPPD
if (open(FILE, "/var/run/ppp-ipfire.pid")) {
my $pid = <FILE>;
close FILE;
chomp ($pid);
$pid =~ /(\d*)/; $pid = $1;
system ('/bin/kill', $pid);
}
# Bring down Ethernet interfaces & Kill DHCPC daemons
if (($netsettings{'CONFIG_TYPE'} =~ /^(2|3|6|7)$/) && ( $netsettings{'RED_TYPE'} eq 'PPPOE') && $iface ) {
system ("/sbin/ifconfig", $iface, "down");
}
if ($device) {
system ("/sbin/ifconfig", $device, "down");
}
my $file;
while (($file = glob("/var/run/dhcpcd-*.pid") )) {
if (open(FILE, $file)) {
my $pid = <FILE>;
close FILE;
chomp ($pid);
$pid =~ /(\d*)/; $pid = $1;
system ('/bin/kill', $pid);
}
}
if (!system ('/bin/ps -ef | /bin/grep -q [a]tmarpd')) {
if ($pppsettings{'GATEWAY'} ne '') {
system("/usr/sbin/atmarp -d $pppsettings{'GATEWAY'} 2>/dev/null"); }
system('/bin/killall /usr/sbin/atmarpd 2>/dev/null');
system ('/sbin/ifconfig', 'atm0', 'down');
}
if ($pppsettings{'TYPE'} eq 'isdn') { system('/etc/rc.d/rc.isdn','stop'); }
if ($pppsettings{'TYPE'} eq 'fritzdsl') { system ('/etc/rc.d/rc.fritzdsl','stop'); }
if ( ( $netsettings{'CONFIG_TYPE'} =~ /^(2|3|6|7)$/ && $netsettings{'RED_TYPE'} eq 'STATIC') ||
( $netsettings{'CONFIG_TYPE'} =~ /^(0|1|4|5)$/ && $pppsettings{'PROTOCOL'} eq 'RFC1483' &&
$pppsettings{'METHOD'} eq 'STATIC' ) ) {
system ("/etc/rc.d/init.d/network red update");
}
}
elsif ($ARGV[0] eq 'clear')
{
&doupdatesettings();
&docleanup();
}
exit 0;
sub docleanup
{
if ($pppsettings{'TYPE'} eq 'fritzdsl') { system ('/etc/rc.d/rc.fritzdsl','cleanup'); }
}
sub domodemdial
{
my @pppcommand = ('/usr/sbin/pppd');
my $loginscript = '';
if ($pppsettings{'COMPORT'} =~ /ttyACM/) {
system ('/sbin/rmmod acm');
sleep 1;
system ('/sbin/modprobe acm');
}
my $device = "/dev/${pppsettings{'COMPORT'}}";
if ($pppsettings{'DNS'} eq 'Automatic') {
push(@pppcommand, ('usepeerdns')); }
if ($pppsettings{'AUTH'} eq 'pap') {
push(@pppcommand, ('-chap'));
} elsif ($pppsettings{'AUTH'} eq 'chap') {
push(@pppcommand, ('-pap'));
} elsif ($pppsettings{'AUTH'} eq 'standard-login-script') {
$loginscript = 'standardloginscript';
} elsif ($pppsettings{'AUTH'} eq 'demon-login-script') {
$loginscript = 'demonloginscript';
} else {
$loginscript = $pppsettings{'LOGINSCRIPT'};
}
if ($pppsettings{'RECONNECTION'} ne 'persistent') {
if ($pppsettings{'TIMEOUT'} != 0)
{
my $seconds = $pppsettings{'TIMEOUT'} * 60;
push (@pppcommand, ('idle', $seconds));
}
if ($pppsettings{'RECONNECTION'} eq 'dialondemand') {
push (@pppcommand, ('demand', 'nopersist'));
}
push (@pppcommand,
('active-filter',
'outbound and not icmp[0] == 3 and not tcp[13] & 4 != 0 ' ));
}
push (@pppcommand, ('novj', 'novjccomp'));
push (@pppcommand, ('lock', 'modem', 'crtscts', $device,
$pppsettings{'DTERATE'}, 'noipdefault',
'defaultroute', 'user', $pppsettings{'USERNAME'},
'maxfail', $pppsettings{'MAXRETRIES'}, 'connect',
'/etc/ppp/dialer'));
if ($pppsettings{'DEBUG'} eq 'on') {
push(@pppcommand, ('debug'));
}
system @pppcommand;
}
sub doserialdial
{
my @pppcommand = ('/usr/sbin/pppd');
my $loginscript = '';
if ($pppsettings{'COMPORT'} =~ /ttyACM/) {
system ('/sbin/rmmod acm');
sleep 1;
system ('/sbin/modprobe acm');
}
my $device = "/dev/${pppsettings{'COMPORT'}}";
if ($pppsettings{'DNS'} eq 'Automatic') {
push(@pppcommand, ('usepeerdns')); }
if ($pppsettings{'AUTH'} eq 'pap') {
push(@pppcommand, ('-chap'));
} elsif ($pppsettings{'AUTH'} eq 'chap') {
push(@pppcommand, ('-pap'));
}
if ($pppsettings{'RECONNECTION'} ne 'persistent') {
if ($pppsettings{'TIMEOUT'} != 0)
{
my $seconds = $pppsettings{'TIMEOUT'} * 60;
push (@pppcommand, ('idle', $seconds));
}
if ($pppsettings{'RECONNECTION'} eq 'dialondemand') {
push (@pppcommand, ('demand', 'nopersist'));
}
push (@pppcommand,
('active-filter',
'outbound and not icmp[0] == 3 and not tcp[13] & 4 != 0 ' ));
}
push (@pppcommand, ('novj', 'novjccomp'));
push (@pppcommand, ('lock', 'modem', 'crtscts', $device,
$pppsettings{'DTERATE'}, 'noipdefault',
'defaultroute', 'user', $pppsettings{'USERNAME'},
'maxfail', $pppsettings{'MAXRETRIES'}, 'connect',
'/bin/true'));
if ($pppsettings{'DEBUG'} eq 'on') {
push(@pppcommand, ('debug'));
}
system @pppcommand;
}
sub doisdndial
{
my $pppoptions;
my $seconds;
my $phone;
if (system ('/etc/rc.d/rc.isdn', 'start')) {
&General::log ("ERROR: ISDN module failed to load");
exit 1;
}
$seconds = $pppsettings{'TIMEOUT'} * 60;
if ($pppsettings{'USEDOV'} eq 'on')
{
$phone = 'v' . $pppsettings{'TELEPHONE'};
}
else
{
$phone = $pppsettings{'TELEPHONE'};
};
if ($pppsettings{'COMPORT'} eq 'isdn2')
{
system('/usr/sbin/isdnctrl','addif','ippp0');
system('/usr/sbin/isdnctrl','addslave','ippp0','ippp1');
system('/usr/sbin/isdnctrl','l2_prot','ippp0','hdlc');
system('/usr/sbin/isdnctrl','l3_prot','ippp0','trans');
system('/usr/sbin/isdnctrl','encap','ippp0','syncppp');
system('/usr/sbin/isdnctrl','dialmax','ippp0',$pppsettings{'MAXRETRIES'});
system('/usr/sbin/isdnctrl','eaz','ippp0',$isdnsettings{'MSN'});
system('/usr/sbin/isdnctrl','addphone','ippp0','out',$phone);
system('/usr/sbin/isdnctrl','huptimeout','ippp0',$seconds);
system('/usr/sbin/isdnctrl','l2_prot','ippp1','hdlc');
system('/usr/sbin/isdnctrl','l3_prot','ippp1','trans');
system('/usr/sbin/isdnctrl','encap','ippp1','syncppp');
system('/usr/sbin/isdnctrl','dialmax','ippp1',$pppsettings{'MAXRETRIES'});
system('/usr/sbin/isdnctrl','eaz','ippp0',$isdnsettings{'MSN'});
system('/usr/sbin/isdnctrl','addphone','ippp1','out',$phone);
system('/usr/sbin/isdnctrl','huptimeout','ippp1',$seconds);
system('/usr/sbin/isdnctrl','dialmode','ippp1','auto');
my @pppcommand = ('/usr/sbin/ipppd','ms-get-dns','noipdefault','+mp',
'defaultroute','user',$pppsettings{'USERNAME'},
'name',$pppsettings{'USERNAME'},
'active-filter','outbound and not icmp[0] == 3 and not tcp[13] & 4 != 0',
'pidfile','/var/run/ppp-ipfire.pid','/dev/ippp0','/dev/ippp1');
if ($pppsettings{'DEBUG'} eq 'on') {
push(@pppcommand, ('debug'));
}
if ($pppsettings{'AUTH'} eq 'pap') {
push(@pppcommand, ('-chap'));
} elsif ($pppsettings{'AUTH'} eq 'chap') {
push(@pppcommand, ('-pap'));
}
system (@pppcommand);
}
else
{
system('/usr/sbin/isdnctrl','addif','ippp0');
system('/usr/sbin/isdnctrl','l2_prot','ippp0','hdlc');
system('/usr/sbin/isdnctrl','l3_prot','ippp0','trans');
system('/usr/sbin/isdnctrl','encap','ippp0','syncppp');
system('/usr/sbin/isdnctrl','dialmax','ippp0',$pppsettings{'MAXRETRIES'});
system('/usr/sbin/isdnctrl','eaz','ippp0',$isdnsettings{'MSN'});
system('/usr/sbin/isdnctrl','addphone','ippp0','out',$phone);
system('/usr/sbin/isdnctrl','huptimeout','ippp0',$seconds);
my @pppcommand = ('/usr/sbin/ipppd','ms-get-dns','noipdefault',
'defaultroute','user',$pppsettings{'USERNAME'},
'name',$pppsettings{'USERNAME'},
'active-filter','outbound and not icmp[0] == 3 and not tcp[13] & 4 != 0',
'pidfile','/var/run/ppp-ipfire.pid','/dev/ippp0');
if ($pppsettings{'DEBUG'} eq 'on') {
push(@pppcommand, ('debug'));
}
if ($pppsettings{'AUTH'} eq 'pap') {
push(@pppcommand, ('-chap'));
} elsif ($pppsettings{'AUTH'} eq 'chap') {
push(@pppcommand, ('-pap'));
}
system (@pppcommand);
}
sleep 1;
if ($pppsettings{'RECONNECTION'} eq 'dialondemand') {
system('/usr/sbin/isdnctrl','dialmode','ippp0','auto');
system('/sbin/ifconfig','ippp0','10.112.112.112','pointopoint','10.112.112.113');
system('/sbin/ifconfig','ippp0','-arp','-broadcast');
system('/sbin/route','add','default','dev','ippp0');
} else {
system('/usr/sbin/isdnctrl', 'dial', 'ippp0');
}
system('/bin/killall', 'ibod');
if ($pppsettings{'COMPORT'} eq 'isdn2') {
if ($pppsettings{'USEIBOD'} eq 'on') {
system("/usr/sbin/ibod &");
} else {
system('/usr/sbin/isdnctrl', 'addlink', 'ippp0');
}
}
}
sub dopppoedial
{
system("mknod /dev/ppp c 108 0 2>/dev/null");
if ($pppsettings{'METHOD'} ne 'PPPOE_PLUGIN') {
my @pppcommand = ('/usr/sbin/pppd', 'pty');
my @pppoecommand = ('/usr/sbin/pppoe', '-p','/var/run/pppoe.pid','-I',
$netsettings{'RED_DEV'}, '-T', '80', '-U', '-m', '1412');
if ($pppsettings{'SERVICENAME'}) {
push(@pppoecommand, ('-S', $pppsettings{'SERVICENAME'})); }
if ($pppsettings{'CONCENTRATORNAME'}) {
push(@pppoecommand, ('-C', $pppsettings{'CONCENTRATORNAME'})); }
push(@pppcommand, "@pppoecommand");
if ($pppsettings{'DNS'} eq 'Automatic') {
push(@pppcommand, ('usepeerdns'));
}
if ($pppsettings{'AUTH'} eq 'pap') {
push(@pppcommand, ('-chap'));
} elsif ($pppsettings{'AUTH'} eq 'chap') {
push(@pppcommand, ('-pap'));
}
if ($pppsettings{'RECONNECTION'} ne 'persistent') {
if ($pppsettings{'TIMEOUT'} != 0) {
my $seconds = $pppsettings{'TIMEOUT'} * 60;
push(@pppcommand, ('idle', "$seconds"));
}
if ($pppsettings{'RECONNECTION'} eq 'dialondemand') {
push (@pppcommand, ('demand','nopersist','connect','/bin/true'));
}
push (@pppcommand,
('active-filter',
'outbound and not icmp[0] == 3 and not tcp[13] & 4 != 0 ' ));
}
push(@pppcommand, ('noipdefault', 'default-asyncmap',
'defaultroute', 'hide-password', 'local',
'mtu', '1492', 'mru', '1492', 'noaccomp', 'noccp',
'nobsdcomp', 'nodeflate', 'nopcomp', 'novj', 'novjccomp',
'user', $pppsettings{'USERNAME'}, 'lcp-echo-interval', '20',
'lcp-echo-failure', '3', 'lcp-max-configure', '50',
'maxfail',$pppsettings{'MAXRETRIES'}));
if ($pppsettings{'DEBUG'} eq 'on') {
push(@pppcommand, ('debug'));
}
system (@pppcommand);
} else {
# PPPoE plugin
system ('/sbin/modprobe pppoe');
my @pppcommand = ('/usr/sbin/pppd');
push(@pppcommand,'plugin','rp-pppoe.so',"$netsettings{'RED_DEV'}");
if ($pppsettings{'DNS'} eq 'Automatic') {
push(@pppcommand, ('usepeerdns'));
}
if ($pppsettings{'AUTH'} eq 'pap') {
push(@pppcommand, ('-chap'));
} elsif ($pppsettings{'AUTH'} eq 'chap') {
push(@pppcommand, ('-pap'));
}
if ($pppsettings{'RECONNECTION'} ne 'persistent') {
if ($pppsettings{'TIMEOUT'} != 0) {
my $seconds = $pppsettings{'TIMEOUT'} * 60;
push(@pppcommand, ('idle', "$seconds"));
}
if ($pppsettings{'RECONNECTION'} eq 'dialondemand') {
push (@pppcommand, ('demand','nopersist'));
}
push (@pppcommand,
('active-filter',
'outbound and not icmp[0] == 3 and not tcp[13] & 4 != 0 ' ));
}
push(@pppcommand, ('noipdefault', 'defaultroute', 'hide-password', 'ipcp-accept-local',
'ipcp-accept-remote', 'passive', 'noccp','nopcomp', 'novjccomp',
'user', $pppsettings{'USERNAME'}, 'lcp-echo-interval', '20',
'lcp-echo-failure', '3', 'lcp-max-configure', '50',
'maxfail',$pppsettings{'MAXRETRIES'}));
if ($pppsettings{'DEBUG'} eq 'on') {
push(@pppcommand, ('debug'));
}
system (@pppcommand);
}
}
sub dopptpdial
{
my %pptpdhcpc;
my $routerip = $pppsettings{'ROUTERIP'} ? $pppsettings{'ROUTERIP'} : "10.0.0.138";
system("mknod /dev/ppp c 108 0 2>/dev/null");
if ( $pppsettings{'METHOD'} eq 'DHCP' && open(FILE, "${General::swroot}/red/device")) {
my $device = <FILE>;
close FILE;
chomp ($device);
$device =~ /([a-zA-Z0-9]*)/; $device = $1;
if (&General::readhash("${General::swroot}/dhcpc/dhcpcd-$device.info", \%pptpdhcpc)) {
system("/sbin/route add -host $routerip gw $pptpdhcpc{'GATEWAY'}");
} else {
system("/sbin/route add -host $routerip dev $device");
}
}
my @pppcommand = ('/usr/sbin/pppd', 'pty');
my @pptpcommand = ('/usr/sbin/pptp', $routerip, '--nobuffer', '--nolaunchpppd', '--sync');
if ($pppsettings{'PHONEBOOK'}) {
push (@pptpcommand, ('--phone ', $pppsettings{'PHONEBOOK'}));
}
push(@pppcommand, "@pptpcommand");
if ($pppsettings{'DNS'} eq 'Automatic') {
push(@pppcommand, ('usepeerdns'));
}
if ($pppsettings{'AUTH'} eq 'pap') {
push(@pppcommand, ('-chap'));
} elsif ($pppsettings{'AUTH'} eq 'chap') {
push(@pppcommand, ('-pap'));
}
if ($pppsettings{'RECONNECTION'} ne 'persistent') {
if ($pppsettings{'TIMEOUT'} != 0) {
my $seconds = $pppsettings{'TIMEOUT'} * 60;
push(@pppcommand, ('idle', "$seconds"));
}
if ($pppsettings{'RECONNECTION'} eq 'dialondemand') {
push (@pppcommand, ('demand','nopersist','connect','/bin/true'));
}
push (@pppcommand,
('active-filter',
'outbound and not icmp[0] == 3 and not tcp[13] & 4 != 0 ' ));
}
push(@pppcommand, ('noipdefault', 'default-asyncmap',
'defaultroute', 'hide-password', 'local','noaccomp', 'noccp',
'nobsdcomp', 'nodeflate', 'nopcomp', 'novj', 'novjccomp',
'user', $pppsettings{'USERNAME'}, 'lcp-echo-interval', '20',
'lcp-echo-failure', '3', 'lcp-max-configure', '50',
'maxfail',$pppsettings{'MAXRETRIES'},'sync'));
if ($pppsettings{'DEBUG'} eq 'on') {
push(@pppcommand, ('debug'));
}
system (@pppcommand);
}
sub dofritzdsldial
{
my $controller;
if (system ('/etc/rc.d/rc.fritzdsl','start')) {
&General::log ("ERROR: Fritz DSL module failed to load");
exit 1;
}
# controller number
if ($pppsettings{'TYPE'} eq 'fritzdsl') {
if ( ! system ('/bin/grep', '1244:2700', '/proc/pci')) {
$controller=1; # fcdslsl
} elsif (! system('/bin/grep', '1244:2900', '/proc/pci')) {
$controller=2; # fcdsl2
} elsif (! system('/bin/grep', '1131:5402', '/proc/pci')) {
$controller=2; # fdsl
} elsif (! system('/bin/grep', 'Vendor=057c ProdID=2300', '/proc/bus/usb/devices')) {
$controller=1; # fcdslusb
} elsif (! system('/bin/grep', 'Vendor=057c ProdID=3500', '/proc/bus/usb/devices')) {
$controller=1; # fcdslslusb
}
}
system("mknod /dev/ppp c 108 0 2>/dev/null");
my @pppcommand = ('/usr/sbin/pppd');
my @capiplugin;
if ($pppsettings{'DNS'} eq 'Automatic') {
push(@pppcommand, ('usepeerdns'));
}
if ($pppsettings{'RECONNECTION'} ne 'persistent') {
if ($pppsettings{'TIMEOUT'} != 0) {
my $seconds = $pppsettings{'TIMEOUT'} * 60;
push(@pppcommand, ('idle', "$seconds"));
}
if ($pppsettings{'RECONNECTION'} eq 'dialondemand') {
push (@pppcommand, ('demand','nopersist','connect','/bin/true'));
}
push (@pppcommand,
('active-filter',
'outbound and not icmp[0] == 3 and not tcp[13] & 4 != 0 ' ));
}
push(@pppcommand, ('noipdefault', 'defaultroute', 'sync', 'user',
$pppsettings{'USERNAME'}, 'ipcp-accept-local', 'ipcp-accept-remote', 'passive',
'noaccomp', 'nopcomp', 'noccp', 'novj', 'nobsdcomp',
'nodeflate', 'lcp-echo-interval', '20', 'lcp-echo-failure', '3',
'lcp-max-configure', '50', 'maxfail', $pppsettings{'MAXRETRIES'}));
if ($pppsettings{'DEBUG'} eq 'on') {
push(@pppcommand, ('debug'));
}
if ($pppsettings {'PROTOCOL'} eq 'RFC1483') {
@capiplugin = ('plugin', 'capiplugin.so', 'protocol', 'adslpppoe',
'controller', $controller, 'vpi', $pppsettings{'VPI'},'vci',$pppsettings{'VCI'});
} else {
if ($pppsettings {'ENCAP'} eq '1') {
@capiplugin = ('plugin', 'capiplugin.so', 'protocol', 'adslpppoallc',
'controller', $controller, 'vpi', $pppsettings{'VPI'},'vci',$pppsettings{'VCI'});
} else {
@capiplugin = ('plugin', 'capiplugin.so', 'protocol', 'adslpppoa',
'controller', $controller,'vpi', $pppsettings{'VPI'},'vci',$pppsettings{'VCI'});
}
}
push(@pppcommand, @capiplugin);
push(@pppcommand, '/dev/null');
system (@pppcommand);
}
sub doatmdial
{
my $ENCAP;
system("mknod /dev/ppp c 108 0 2>/dev/null");
if ($pppsettings {'PROTOCOL'} eq 'RFC2364') {
system ('/sbin/modprobe pppoatm');
my @pppcommand = ('/usr/sbin/pppd');
if ($pppsettings{'ENCAP'} eq '0') { $ENCAP='vc-encaps'; } else { $ENCAP='llc-encaps'; }
push(@pppcommand,'plugin', 'pppoatm.so',$pppsettings{'VPI'}.".".$pppsettings{'VCI'},"$ENCAP");
if ($pppsettings{'DNS'} eq 'Automatic') { push(@pppcommand, ('usepeerdns'));}
if ($pppsettings{'AUTH'} eq 'pap') {
push(@pppcommand, ('-chap'));
} elsif ($pppsettings{'AUTH'} eq 'chap') {
push(@pppcommand, ('-pap'));
}
if ($pppsettings{'RECONNECTION'} ne 'persistent') {
if ($pppsettings{'TIMEOUT'} != 0) {
my $seconds = $pppsettings{'TIMEOUT'} * 60;
push(@pppcommand, ('idle', "$seconds"));
}
if ($pppsettings{'RECONNECTION'} eq 'dialondemand') {
push (@pppcommand, ('demand','nopersist'));
}
push (@pppcommand,
('active-filter',
'outbound and not icmp[0] == 3 and not tcp[13] & 4 != 0 ' ));
}
push(@pppcommand, ('noipdefault', 'defaultroute', 'user',
$pppsettings{'USERNAME'}, 'ipcp-accept-local', 'ipcp-accept-remote', 'passive',
'nopcomp', 'noccp', 'novj', 'nobsdcomp',
'nodeflate', 'lcp-echo-interval', '20', 'lcp-echo-failure', '3',
'lcp-max-configure', '50', 'maxfail', $pppsettings{'MAXRETRIES'}));
if ($pppsettings{'DEBUG'} eq 'on') {
push(@pppcommand, ('debug'));
}
system (@pppcommand);
} elsif ($pppsettings {'PROTOCOL'} eq 'RFC1483') {
if ($pppsettings {'METHOD'} =~ /^(PPPOE|PPPOE_PLUGIN)$/) {
my $itf='0';
my $device = "nas$itf";
if (open(FILE, ">${General::swroot}/red/device")) { print FILE $device; close FILE; }
$netsettings{'RED_DEV'} = $device;
if (system ('/bin/ps -ef | /bin/grep -q [b]r2684ctl')) {
system ('/sbin/modprobe br2684');
system ('/usr/bin/br2684ctl', '-b', '-c', "$itf", '-e', $pppsettings{'ENCAP'}, '-a', "$itf.$pppsettings{'VPI'}.$pppsettings{'VCI'}");
sleep 3;
}
system ('/sbin/ifconfig',"$device",'up');
&dopppoedial();
} elsif ($pppsettings{'ENCAP'} =~ /^(0|1)$/) {
my $itf='0';
$iface = "nas$itf";
if (open(FILE, ">${General::swroot}/red/iface")) { print FILE $iface; close FILE; }
if (system ('/bin/ps -ef | /bin/grep -q [b]r2684ctl')) {
system ('/sbin/modprobe br2684');
system ('/usr/bin/br2684ctl', '-b', '-c', "$itf", '-e', $pppsettings{'ENCAP'}, '-a', "$itf.$pppsettings{'VPI'}.$pppsettings{'VCI'}");
sleep 3;
}
system ('/sbin/ifconfig',"$iface",'up');
if ($pppsettings{'METHOD'} eq 'STATIC') {
my @staticcommand = ('/sbin/ifconfig');
push(@staticcommand, ($iface, $pppsettings{'IP'},'netmask', $pppsettings{'NETMASK'}));
if ($pppsettings{'BROADCAST'} ne '') {
push(@staticcommand, ('broadcast', $pppsettings{'BROADCAST'}));
}
system (@staticcommand);
system ("/sbin/route","add","default","gw",$pppsettings{'GATEWAY'});
system ("/bin/touch", "${General::swroot}/red/active");
system ("/etc/rc.d/init.d/network red update");
} elsif ($pppsettings {'METHOD'} eq 'DHCP') {
dodhcpdial($iface,$pppsettings{'DHCP_HOSTNAME'});
}
} elsif ($pppsettings{'ENCAP'} =~ /^(2|3)$/) {
my $itf='0';
$iface = "atm$itf";
if (open(FILE, ">${General::swroot}/red/iface")) { print FILE $iface; close FILE; }
if (system ('/bin/ps -ef | /bin/grep -q [a]tmarpd')) {
if (system ('/usr/sbin/atmarpd -b -l syslog')) {
&General::log('atmarpd fail');
exit 1;
}
# it will fail on all attempt after the first because interface still exist
system ("/usr/sbin/atmarp -c $iface 2>/dev/null");
if ($pppsettings{'METHOD'} eq 'STATIC') {
my @staticcommand = ('/sbin/ifconfig');
push(@staticcommand, ($iface, $pppsettings{'IP'},'netmask', $pppsettings{'NETMASK'}, 'up'));
if ($pppsettings{'BROADCAST'} ne '') {
push(@staticcommand, ('broadcast', $pppsettings{'BROADCAST'}));
}
system (@staticcommand);
# we have to wait a bit before launching atmarp -s
sleep 2;
my @atmarp = ('/usr/sbin/atmarp', '-s', $pppsettings{'GATEWAY'}, "$itf.$pppsettings{'VPI'}.$pppsettings{'VCI'}");
if ($pppsettings{'ENCAP'} eq '3') {
push(@atmarp, 'null' ); # routed ip vc encap
}
system (@atmarp);
system ("/sbin/route", "add", "default", "gw", $pppsettings{'GATEWAY'});
system ("/bin/touch", "${General::swroot}/red/active");
}
}
}
}
}