add bind9 api v2 management
This commit is contained in:
parent
20230f5a8e
commit
613bebbe7c
|
@ -192,7 +192,7 @@ sub get_api_version_xml {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
eval {
|
eval {
|
||||||
my $nodesets = $self->{xpath_response}->find('/statistics/@version');
|
my $nodesets = $self->{xpath_response}->find('//statistics/@version');
|
||||||
my $node = $nodesets->get_node(1);
|
my $node = $nodesets->get_node(1);
|
||||||
$self->{api_version} = $node->getNodeValue();
|
$self->{api_version} = $node->getNodeValue();
|
||||||
};
|
};
|
||||||
|
@ -207,19 +207,28 @@ sub load_memory_xml_v3 {
|
||||||
|
|
||||||
my $memory = {};
|
my $memory = {};
|
||||||
|
|
||||||
my $nodesets = $self->{xpath_response}->find('//memory//TotalUse');
|
my $nodesets = $self->{xpath_response}->find('//memory/summary');
|
||||||
my $node = $nodesets->get_node(1);
|
my $node_memory = $nodesets->get_node(1);
|
||||||
return $memory if (!defined($node));
|
foreach my $node ($node_memory->getChildNodes()) {
|
||||||
$memory->{total_use} = $node->string_value;
|
my $name = $node->getLocalName();
|
||||||
|
next if (!defined($name));
|
||||||
$nodesets = $self->{xpath_response}->find('//memory//InUse');
|
if ($name eq 'TotalUse') {
|
||||||
$node = $nodesets->get_node(1);
|
$memory->{total_use} = $node->string_value;
|
||||||
return $memory if (!defined($node));
|
}
|
||||||
$memory->{in_use} = $node->string_value;
|
if ($name eq 'InUse') {
|
||||||
|
$memory->{in_use} = $node->string_value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return $memory;
|
return $memory;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub load_memory_xml_v2 {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
return $self->load_memory_xml_v3();
|
||||||
|
}
|
||||||
|
|
||||||
sub load_zones_xml_v3 {
|
sub load_zones_xml_v3 {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
@ -242,6 +251,35 @@ sub load_zones_xml_v3 {
|
||||||
return $zones;
|
return $zones;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub load_zones_xml_v2 {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
my $zones = {};
|
||||||
|
my $nodesets = $self->{xpath_response}->find('//views//zones/zone');
|
||||||
|
foreach my $node ($nodesets->get_nodelist()) {
|
||||||
|
my $name;
|
||||||
|
my $counters = {};
|
||||||
|
foreach my $subnode ($node->getChildNodes()) {
|
||||||
|
my $tag_name = $subnode->getLocalName();
|
||||||
|
$name = $subnode->string_value
|
||||||
|
if ($tag_name eq 'name');
|
||||||
|
if ($tag_name eq 'counters') {
|
||||||
|
foreach my $counter_node ($subnode->getChildNodes()) {
|
||||||
|
$tag_name = $counter_node->getLocalName();
|
||||||
|
next if (!defined($tag_name));
|
||||||
|
$counters->{$tag_name} = $counter_node->string_value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (defined($name)) {
|
||||||
|
$zones->{$name}->{counters}->{rcode} = $counters;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $zones;
|
||||||
|
}
|
||||||
|
|
||||||
sub load_server_xml_v3 {
|
sub load_server_xml_v3 {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
@ -261,6 +299,62 @@ sub load_server_xml_v3 {
|
||||||
return $server;
|
return $server;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub load_server_xml_v2 {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
my $server = { counters => { opcode => {}, nsstat => {}, qtype => {} } };
|
||||||
|
|
||||||
|
my $nodesets = $self->{xpath_response}->find('//server//opcode');
|
||||||
|
foreach my $node ($nodesets->get_nodelist()) {
|
||||||
|
my ($name, $value);
|
||||||
|
foreach my $counter_node ($node->getChildNodes()) {
|
||||||
|
my $tag_name = $counter_node->getLocalName();
|
||||||
|
next if (!defined($tag_name));
|
||||||
|
|
||||||
|
$name = $counter_node->string_value if ($tag_name eq 'name');
|
||||||
|
$value = $counter_node->string_value if ($tag_name eq 'counter');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (defined($name) && defined($value)) {
|
||||||
|
$server->{counters}->{opcode}->{$name} = $value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$nodesets = $self->{xpath_response}->find('//server//rdtype');
|
||||||
|
foreach my $node ($nodesets->get_nodelist()) {
|
||||||
|
my ($name, $value);
|
||||||
|
foreach my $counter_node ($node->getChildNodes()) {
|
||||||
|
my $tag_name = $counter_node->getLocalName();
|
||||||
|
next if (!defined($tag_name));
|
||||||
|
|
||||||
|
$name = $counter_node->string_value if ($tag_name eq 'name');
|
||||||
|
$value = $counter_node->string_value if ($tag_name eq 'counter');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (defined($name) && defined($value)) {
|
||||||
|
$server->{counters}->{qtype}->{$name} = $value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$nodesets = $self->{xpath_response}->find('//server//nsstat');
|
||||||
|
foreach my $node ($nodesets->get_nodelist()) {
|
||||||
|
my ($name, $value);
|
||||||
|
foreach my $counter_node ($node->getChildNodes()) {
|
||||||
|
my $tag_name = $counter_node->getLocalName();
|
||||||
|
next if (!defined($tag_name));
|
||||||
|
|
||||||
|
$name = $counter_node->string_value if ($tag_name eq 'name');
|
||||||
|
$value = $counter_node->string_value if ($tag_name eq 'counter');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (defined($name) && defined($value)) {
|
||||||
|
$server->{counters}->{nsstat}->{$name} = $value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $server;
|
||||||
|
}
|
||||||
|
|
||||||
sub get_memory {
|
sub get_memory {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue