7-api-sequencing #8
@ -15,6 +15,10 @@ my $ua = LWP::UserAgent->new;
|
|||||||
my %seen;
|
my %seen;
|
||||||
my $DRY_RUN = $ENV{DRY_RUN};
|
my $DRY_RUN = $ENV{DRY_RUN};
|
||||||
|
|
||||||
|
my @to_create;
|
||||||
|
my @to_delete;
|
||||||
|
my @to_update;
|
||||||
|
|
||||||
sub _debug {
|
sub _debug {
|
||||||
print STDERR ("=== DEBUG ===\n", Dumper(@_), "=== END ===\n") if $ENV{DEBUG} or $in->[0]->{debug};
|
print STDERR ("=== DEBUG ===\n", Dumper(@_), "=== END ===\n") if $ENV{DEBUG} or $in->[0]->{debug};
|
||||||
}
|
}
|
||||||
@ -204,41 +208,22 @@ sub check_and_update_record($$$$$) {
|
|||||||
if($record->{ttl} ne $in->[0]->{defaults}->{ttl}->{$zone}) {
|
if($record->{ttl} ne $in->[0]->{defaults}->{ttl}->{$zone}) {
|
||||||
# Update the record
|
# Update the record
|
||||||
$record->{ttl} = $in->[0]->{defaults}->{ttl}->{$zone};
|
$record->{ttl} = $in->[0]->{defaults}->{ttl}->{$zone};
|
||||||
_debug("Update ", $url, $record, to_json($record));
|
_debug("Will update ", $url, $record, to_json($record));
|
||||||
unless ($DRY_RUN) {
|
push(@to_update, $record);
|
||||||
my $res = $ua->put(
|
|
||||||
$url,
|
|
||||||
"Content-Type" => "application/json",
|
|
||||||
"Content" => to_json({ records => [ $record ] }),
|
|
||||||
);
|
|
||||||
warn "Failed to update $url: " . $res->status_line unless $res->is_success;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
# Create new record
|
# Create new record
|
||||||
my $new = format_record($zone, $type, $host, $value);
|
my $new = format_record($zone, $type, $host, $value);
|
||||||
_notice("Created new record: %s %s %s", $host, $type, $value);
|
_notice("Will create new record: %s %s %s", $host, $type, $value);
|
||||||
_debug($new);
|
push(@to_create, $new);
|
||||||
unless ($DRY_RUN) {
|
|
||||||
my $res = $ua->post(
|
|
||||||
$url,
|
|
||||||
"Content-Type" => "application/json",
|
|
||||||
Content => to_json({
|
|
||||||
records => [ $new ]
|
|
||||||
})
|
|
||||||
);
|
|
||||||
warn "Failed to create $url: " . $res->status_line . "\n" . $res->content unless $res->is_success;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
sub delete_record($$) {
|
sub delete_record($$) {
|
||||||
my ($zone, $record) = @_;
|
my ($zone, $record) = @_;
|
||||||
return if $DRY_RUN;
|
|
||||||
|
|
||||||
my $url = $in->[0]->{defaults}->{api} . "/$zone/records/$record->{host}/$record->{type}?host=$record->{host}&data=$record->{data}";
|
my $url = $in->[0]->{defaults}->{api} . "/$zone/records/$record->{host}/$record->{type}?host=$record->{host}&data=$record->{data}";
|
||||||
my $res = $ua->delete($url);
|
_notice("Will delete: %s %s %s", $record->{host}, $record->{type}, $record->{data});
|
||||||
warn "Failed to delete $url: " . $res->status_line . "\n" . $res->content unless $res->is_success;
|
push(@to_delete, $url);
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach my $z (keys %{$in->[0]->{zones}}) {
|
foreach my $z (keys %{$in->[0]->{zones}}) {
|
||||||
@ -297,5 +282,41 @@ foreach my $z (keys %{$in->[0]->{zones}}) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
_info("Finished processing %s", $z);
|
_info("Finished pre-processing %s", $z);
|
||||||
|
}
|
||||||
|
|
||||||
|
unless($DRY_RUN) {
|
||||||
|
_info("Applying changes (%d creates, %d updates, %d deletes)", scalar @to_create, scalar @to_update, scalar @to_delete);
|
||||||
|
|
||||||
|
# Delete
|
||||||
|
foreach my $url (@to_delete) {
|
||||||
|
my $res = $ua->delete($url);
|
||||||
|
warn "Failed to delete $url: " . $res->status_line . "\n" . $res->content unless $res->is_success;
|
||||||
|
}
|
||||||
|
|
||||||
|
# Create
|
||||||
|
foreach my $record (@to_create) {
|
||||||
|
my $res = $ua->post(
|
||||||
|
$url,
|
||||||
|
"Content-Type" => "application/json",
|
||||||
|
Content => to_json({
|
||||||
|
records => [ $record ]
|
||||||
|
})
|
||||||
|
);
|
||||||
|
warn "Failed to create $url: " . $res->status_line . "\n" . $res->content unless $res->is_success;
|
||||||
|
}
|
||||||
|
|
||||||
|
# Update
|
||||||
|
foreach my $record (@to_update) {
|
||||||
|
my $res = $ua->put(
|
||||||
|
$url,
|
||||||
|
"Content-Type" => "application/json",
|
||||||
|
"Content" => to_json({ records => [ $record ] }),
|
||||||
|
);
|
||||||
|
warn "Failed to update $url: " . $res->status_line unless $res->is_success;
|
||||||
|
}
|
||||||
|
|
||||||
|
_info("Finished applying changes")
|
||||||
|
} else {
|
||||||
|
_info("DRY RUN: Skipped applying changes (%d creates, %d updates, %d deletes)", scalar @to_create, scalar @to_update, scalar @to_delete);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user