Try to handle pagination - WIP
This commit is contained in:
parent
5a6c0ad398
commit
a74b144a90
|
@ -76,9 +76,9 @@ sub check_options {
|
||||||
|
|
||||||
$self->{option_results}->{url_path} = "/repos/" . $self->{option_results}->{owner} . "/" . $self->{option_results}->{repository} . "/issues";
|
$self->{option_results}->{url_path} = "/repos/" . $self->{option_results}->{owner} . "/" . $self->{option_results}->{repository} . "/issues";
|
||||||
if (defined($self->{option_results}->{label}) && $self->{option_results}->{label} ne '') {
|
if (defined($self->{option_results}->{label}) && $self->{option_results}->{label} ne '') {
|
||||||
$self->{option_results}->{get_param} = ['state=open', 'labels=' . $self->{option_results}->{label}, 'per_page=1000'];
|
$self->{option_results}->{get_param} = ['state=open', 'labels=' . $self->{option_results}->{label}, 'per_page=100'];
|
||||||
} else {
|
} else {
|
||||||
$self->{option_results}->{get_param} = ['state=open', 'per_page=1000'];
|
$self->{option_results}->{get_param} = ['state=open', 'per_page=100'];
|
||||||
}
|
}
|
||||||
$self->{http}->set_options(%{$self->{option_results}});
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
}
|
}
|
||||||
|
@ -86,22 +86,62 @@ sub check_options {
|
||||||
sub run {
|
sub run {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $jsoncontent = $self->{http}->request();
|
my $pagination = 1;
|
||||||
|
|
||||||
my $json = JSON->new;
|
my $nb_issues = 0;
|
||||||
my $webcontent;
|
my $header;
|
||||||
eval {
|
my $attemps = 3;
|
||||||
$webcontent = $json->decode($jsoncontent);
|
my $next_url = "";
|
||||||
};
|
|
||||||
|
|
||||||
if ($@) {
|
while ($pagination && $attemps > 0) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Cannot decode json response");
|
$attemps -= 1;
|
||||||
$self->{output}->option_exit();
|
|
||||||
|
my $jsoncontent;
|
||||||
|
if ($next_url eq "") {
|
||||||
|
print 'Next url null.\n';
|
||||||
|
$jsoncontent = $self->{http}->request();
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
print 'New next url: ' . $next_url . '\n';
|
||||||
|
#$next_url = "/repositories/9074774/issues?per_page=100&state=open&page=3";
|
||||||
|
$self->{option_results}->{url_path} = $next_url;
|
||||||
|
$self->{http}->set_options(%{$self->{option_results}});
|
||||||
|
$jsoncontent = $self->{http}->request(url_path => $next_url, get_param => $self->{option_results}->{get_param});
|
||||||
|
#$jsoncontent = $self->{http}->request(url_path => $next_url);
|
||||||
|
}
|
||||||
|
|
||||||
|
my $json = JSON->new;
|
||||||
|
my $webcontent;
|
||||||
|
eval {
|
||||||
|
$webcontent = $json->decode($jsoncontent);
|
||||||
|
};
|
||||||
|
|
||||||
|
if ($@) {
|
||||||
|
$self->{output}->add_option_msg(short_msg => "Cannot decode json response");
|
||||||
|
$self->{output}->option_exit();
|
||||||
|
}
|
||||||
|
|
||||||
|
# Number of issues is array length
|
||||||
|
$nb_issues += @{$webcontent};
|
||||||
|
|
||||||
|
$header = $self->{http}->get_header();
|
||||||
|
#use Data::Dumper;
|
||||||
|
#print Dumper($header);
|
||||||
|
if (defined($header->header('link'))) {
|
||||||
|
print "Link found\n";
|
||||||
|
if ($header->header('link') =~ /<https:\/\/api.github.com(\/.*)>; rel="next"/) {
|
||||||
|
print "Found regex\n";
|
||||||
|
$next_url = $1;
|
||||||
|
print $next_url . "\n";
|
||||||
|
} else {
|
||||||
|
$pagination = 0;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
$pagination = 0;
|
||||||
|
print "No link found\n";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
# Number of issues is array length
|
|
||||||
my $nb_issues = @{$webcontent};
|
|
||||||
|
|
||||||
my $exit = $self->{perfdata}->threshold_check(value => $nb_issues, threshold => [ { label => 'critical', exit_litteral => 'critical' }, , { label => 'warning', exit_litteral => 'warning' } ]);
|
my $exit = $self->{perfdata}->threshold_check(value => $nb_issues, threshold => [ { label => 'critical', exit_litteral => 'critical' }, , { label => 'warning', exit_litteral => 'warning' } ]);
|
||||||
|
|
||||||
if (defined($self->{option_results}->{label}) && $self->{option_results}->{label} ne '') {
|
if (defined($self->{option_results}->{label}) && $self->{option_results}->{label} ne '') {
|
||||||
|
|
Loading…
Reference in New Issue