1 |
dpavlin |
82 |
package network; |
2 |
|
|
|
3 |
|
|
use warnings; |
4 |
|
|
use strict; |
5 |
|
|
|
6 |
|
|
use File::Slurp; |
7 |
|
|
|
8 |
|
|
use server; |
9 |
|
|
|
10 |
dpavlin |
83 |
sub ifconfig { |
11 |
|
|
my $dev = shift; |
12 |
|
|
`/sbin/ifconfig $dev` |
13 |
|
|
} |
14 |
|
|
|
15 |
dpavlin |
82 |
sub tap { |
16 |
|
|
|
17 |
|
|
my $interfaces = read_file '/etc/network/interfaces'; |
18 |
|
|
|
19 |
dpavlin |
130 |
if ( $interfaces !~ m{tap0}s ) { |
20 |
dpavlin |
82 |
|
21 |
|
|
system "sudo apt-get install vde2"; |
22 |
|
|
|
23 |
dpavlin |
99 |
write_file '/tmp/interfaces', qq{ |
24 |
dpavlin |
82 |
|
25 |
dpavlin |
99 |
# added by PXElator |
26 |
|
|
iface tap0 inet static |
27 |
|
|
address $server::ip |
28 |
|
|
netmask $server::netmask |
29 |
|
|
vde2-switch - |
30 |
dpavlin |
144 |
# setup NAT for vde network |
31 |
|
|
post-up sysctl -w net.ipv4.ip_forward=1 |
32 |
|
|
post-up iptables -t nat -A POSTROUTING -s $server::ip/$server::netmask -o wlan0 -j MASQUERADE |
33 |
dpavlin |
82 |
|
34 |
|
|
}; |
35 |
|
|
|
36 |
dpavlin |
99 |
system q|sudo sh -c 'cat /tmp/interfaces >> /etc/network/interfaces'|; |
37 |
|
|
system q|sudo sh -c 'usermod -G vde2-net -a $SUDO_USER'|; |
38 |
dpavlin |
82 |
|
39 |
|
|
} |
40 |
|
|
|
41 |
dpavlin |
84 |
my $ifconfig = ifconfig('tap0'); |
42 |
|
|
if ( $ifconfig =~ m{UP} ) { |
43 |
|
|
$ifconfig =~ m{$server::ip}s && return 'up'; |
44 |
|
|
system("sudo /sbin/ifconfig tap0 $server::ip netmask $server::netmask") == 0 && return "ip changed $server::ip"; |
45 |
|
|
die "can't change IP address of tap0 to $server::ip"; |
46 |
dpavlin |
140 |
} else { |
47 |
|
|
die "bring interface up with: sudo ifup tap0\n"; |
48 |
dpavlin |
84 |
} |
49 |
dpavlin |
82 |
} |
50 |
|
|
|
51 |
|
|
1; |