208 |
) |
) |
209 |
; |
; |
210 |
} elsif ( $path =~ m!^/client(?:/$RE{net}{IPv4}{-keep})?! ) { |
} elsif ( $path =~ m!^/client(?:/$RE{net}{IPv4}{-keep})?! ) { |
211 |
my $ip = $1 || $client->peerhost; |
my $ip = $1; |
212 |
|
|
213 |
if ( my $new_ip = $param->{change_ip} ) { |
if ( my $new_ip = $param->{change_ip} ) { |
214 |
client::change_ip( $ip, $new_ip ); |
client::change_ip( $ip, $new_ip ); |
215 |
$ip = $new_ip; |
$ip = $new_ip; |
216 |
} |
} |
217 |
|
|
218 |
my $ip_short = (split(/\./, $ip, 4))[3]; |
if ( ! $ip ) { |
219 |
|
my $peer_ip = $client->peerhost; |
220 |
|
|
221 |
# if ( $ip ne $server::ip ) -- not flexible enough for tunnel endpoints |
warn "XXX peer_ip $peer_ip"; |
222 |
if ( $ip_short >= $server::ip_from && $ip_short <= $server::ip_to ) { |
|
223 |
|
my $netmask = ip::to_int $server::netmask; |
224 |
|
my $network = ip::to_int $server::ip & $netmask; |
225 |
|
my ( $from, $to ) = ( $network | $server::ip_from, $network | $server::ip_to ); |
226 |
|
my $ip_int = ip::to_int $peer_ip; |
227 |
|
|
228 |
|
warn dump( $ip_int, $from, $to ); |
229 |
|
|
230 |
|
# show edit for our our class |
231 |
|
if ( $ip_int >= ( $network | $server::ip_from ) && $ip_int <= ( $network | $server::ip_to ) ) { |
232 |
|
$ip = $peer_ip; |
233 |
|
} |
234 |
|
} |
235 |
|
|
236 |
|
if ( $ip && $ip ne $server::ip ) { |
237 |
my $hostname = client::conf( $ip, 'hostname' => $param->{hostname} ); |
my $hostname = client::conf( $ip, 'hostname' => $param->{hostname} ); |
238 |
|
|
239 |
my @table = ( |
my @table = ( |
303 |
$ip; |
$ip; |
304 |
} glob("$server::conf/ip/*") |
} glob("$server::conf/ip/*") |
305 |
) |
) |
|
, qq|<h2>ARP</h2>| |
|
|
, html::table( -3, 'ip', 'mac', 'dev', |
|
|
map { |
|
|
my $c = $arp->{$_}; |
|
|
( $c->[0], format::mac( $_ => 'html' ), $c->[1] ) |
|
|
} sort keys %$arp |
|
|
) |
|
306 |
; |
; |
307 |
} |
} |
308 |
} elsif ( $path =~ m{^/brctl} ) { |
} elsif ( $path =~ m{^/brctl} ) { |