introduce noop and refactor checks in all workers
This commit is contained in:
@@ -8,15 +8,23 @@ use NetAddr::IP qw/:rfc3021 :lower/;
|
||||
use App::Netdisco::Util::Device qw/get_device renumber_device/;
|
||||
|
||||
register_worker({ stage => 'check' }, sub {
|
||||
return Status->error('Missing device (-d).')
|
||||
unless defined (shift)->device;
|
||||
|
||||
my $new_ip = NetAddr::IP->new($job->extra);
|
||||
unless ($new_ip and $new_ip->addr ne '0.0.0.0') {
|
||||
return Status->error("Bad host or IP: ".($job->extra || '0.0.0.0'));
|
||||
}
|
||||
|
||||
return Status->done('Renumber is able to run');
|
||||
});
|
||||
|
||||
register_worker({ stage => 'main' }, sub {
|
||||
my ($job, $workerconf) = @_;
|
||||
my ($device, $port, $extra) = map {$job->$_} qw/device port extra/;
|
||||
return Status->error('Missing device (-d).') if !defined $device;
|
||||
my $old_ip = $device->ip;
|
||||
|
||||
my $old_ip = $device->ip;
|
||||
my $new_ip = NetAddr::IP->new($extra);
|
||||
unless ($new_ip and $new_ip->addr ne '0.0.0.0') {
|
||||
return Status->error("Bad host or IP: ".($extra || '0.0.0.0'));
|
||||
}
|
||||
|
||||
my $new_dev = get_device($new_ip->addr);
|
||||
if ($new_dev and $new_dev->in_storage and ($new_dev->ip ne $device->ip)) {
|
||||
|
||||
Reference in New Issue
Block a user