3 |
use warnings; |
use warnings; |
4 |
use strict; |
use strict; |
5 |
|
|
6 |
|
use Data::Dump qw(dump); |
7 |
|
use YAML qw(); |
8 |
|
|
9 |
our $base_dir = '/srv/pxelator'; |
our $base_dir = '/srv/pxelator'; |
10 |
|
|
11 |
use ties; |
use ties; |
18 |
tie our $domain, 'ties', 'domain' => 'pxelator.lan'; |
tie our $domain, 'ties', 'domain' => 'pxelator.lan'; |
19 |
tie our $new_clients, 'ties', 'new_clients' => $ip_to - $ip_from; |
tie our $new_clients, 'ties', 'new_clients' => $ip_to - $ip_from; |
20 |
|
|
21 |
|
if ( my $dev = $ENV{DEV} ) { |
22 |
|
my $ifconfig = `ifconfig $dev`; |
23 |
|
die "can't ifconfig $dev" unless $ifconfig; |
24 |
|
die "device $dev not up: ifconfig $dev\n$ifconfig" unless $ifconfig =~ m/UP/; |
25 |
|
$ip = $1 if $ifconfig =~ m/inet addr:(\S+)/s; |
26 |
|
$netmask = $1 if $ifconfig =~ m/Mask:(\S+)/s; |
27 |
|
$bcast = $1 if $ifconfig =~ m/Bcast:(\S)/s; |
28 |
|
} |
29 |
|
|
30 |
warn "DEV $ip $bcast $netmask"; |
warn "DEV $ip $bcast $netmask"; |
31 |
|
|
32 |
our $conf = "$base_dir/conf"; |
our $conf = "$base_dir/conf"; |
68 |
|
|
69 |
sub debug { shared('debug', @_) || 0 } |
sub debug { shared('debug', @_) || 0 } |
70 |
|
|
71 |
|
sub as_hash_for { |
72 |
|
my $ip = shift; |
73 |
|
|
74 |
|
my $server; |
75 |
|
map { $server->{ $_ } = eval '$server::' . $_ } ( 'ip', 'netmask', 'bcast', 'domain', 'ip_from', 'ip_to', 'new_clients' ); |
76 |
|
|
77 |
|
my $server_path = "$server::conf/ip/$ip/server.yaml"; |
78 |
|
$server = YAML::LoadFile $server_path if -e $server_path; |
79 |
|
|
80 |
|
return $server; |
81 |
|
} |
82 |
|
|
83 |
warn "loaded"; |
warn "loaded"; |
84 |
|
|
85 |
1; |
1; |