Skip to content

Commit

Permalink
Merge branch 'nmis9_dev_mongo42' into nmis9_dev
Browse files Browse the repository at this point in the history
  • Loading branch information
James Greenwood committed Jun 24, 2022
2 parents 54e64cc + 3c9102c commit 7540002
Show file tree
Hide file tree
Showing 20 changed files with 930 additions and 140 deletions.
2 changes: 1 addition & 1 deletion admin/import_nodes.pl
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@
# *****************************************************************************
# a command-line node import tool for NMIS 9
use strict;
our $VERSION = "9.1.0";
our $VERSION = "9.4.0";

if (@ARGV == 1 && $ARGV[0] eq "--version")
{
Expand Down
76 changes: 75 additions & 1 deletion admin/node_admin.pl
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@
#
# a command-line node administration tool for NMIS 9
use strict;
our $VERSION = "9.1.1";
our $VERSION = "9.4.0";

if (@ARGV == 1 && $ARGV[0] eq "--version")
{
Expand Down Expand Up @@ -1213,6 +1213,80 @@
if (-t \*STDERR); # if terminal
}
}
elsif ( $cmdline->{act} =~ /validate[-_]node[-_]inventory/ ) {

my $concept = $cmdline->{concept};
my $make_historic = NMISNG::Util::getbool( $cmdline->{make_historic} );
my $dryrun = NMISNG::Util::getbool( $cmdline->{dryrun} );
die "concept not defined or not yet supported"
if ( $concept !~ /^(catchall)$/ );
my ( $entries, undef, $error ) = NMISNG::DB::aggregate(
collection => $nmisng->inventory_collection,
count => 0,
pre_count_pipeline => [
{ '$match' => { "concept" => "catchall", "enabled" => 1} },
{
'$group' => {
'_id' => '$node_uuid',
'count' => { '$sum' => 1 },
'broken' => { '$addToSet' => '$_id' }
}
},
{ '$sort' => { 'lastupdate' => -1 } },
{ '$match' => { "count" => { '$gt' => 1 } } },
]
);

die "Cannot aggregate on inventory collection: $error" if ($error);

my $count = scalar( @{$entries} );
if ( $count > 0 ) {
if ( $make_historic == 1 ) {
print("Making $count nodes $concept documents historic\n")
if ( !$dryrun );
print("Dryrun of making $count nodes $concept documents historic\n")
if ($dryrun);
foreach my $record ( @{$entries} ) {
print("Working on $record->{_id}\n");
my $broken = $record->{broken};
#keep the first value
shift(@{$broken});
my $record = { historic => 1, enabled => 0, _made_historic_by => "node_admin" };
$record = {} if ($dryrun);
my $result = NMISNG::DB::update(
collection => $nmisng->inventory_collection,
query => NMISNG::DB::get_query(
and_part => { _id => $broken },
no_regex => 1
),
record => { '$set' => $record },
freeform => 1,
multiple => 1
);
print(
"Success Matched: $result->{matched_records}, Updated: $result->{updated_records} \n"
) if ( $result->{success} );
print(
"Error updating extra catchall records, error type: $result->{error_type}, $result->{error} \n"
) if ( $result->{error} );
}
}
else {
print(
"You have $count nodes with more than one catchall document, pass make_historic=true to fix\n"
);
foreach my $record ( @{$entries} ) {
print("UUID: $record->{_id} Count: $record->{count}\n");
}
}

}
else {
print("$concept looks normal\n");
}
}


else
{
# fallback: complain about the arguments
Expand Down
2 changes: 1 addition & 1 deletion bin/nmis-cli
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@
#
# *****************************************************************************
use strict;
our $VERSION = "9.0.12";
our $VERSION = "9.4.0";


use FindBin;
Expand Down
2 changes: 1 addition & 1 deletion bin/nmisd
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@
#
# *****************************************************************************
use strict;
our $VERSION="9.0.8";
our $VERSION="9.4.0";

if (@ARGV == 1 && $ARGV[0] eq "--version")
{
Expand Down
2 changes: 1 addition & 1 deletion cgi-bin/network.pl
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@

use FindBin;
use lib "$FindBin::Bin/../lib";
our $VERSION = "9.0.5";
our $VERSION = "9.4.0";

use strict;
use URI::Escape;
Expand Down
26 changes: 23 additions & 3 deletions installer
Original file line number Diff line number Diff line change
Expand Up @@ -915,9 +915,29 @@ sub execPrint
}

logmsg(0,"\n###+++\nEXEC: $cmd");
my $out = `$cmd 2>&1 </dev/null`;
my $rawstatus = $?;
my $res = POSIX::WIFEXITED($rawstatus)? POSIX::WEXITSTATUS($rawstatus): -1;
# robust: retry on failure
my $out;
my $res;
foreach ( 1, 2, 3, 4, 5, 6) {
$out = `$cmd 2>&1`;
my $rawstatus = $?;
$res = POSIX::WIFEXITED($rawstatus)? POSIX::WEXITSTATUS($rawstatus): -1;
if ($res == 0)
{
logmsg($debug,"\n###+++\nexecPrint '$cmd' succeeded\n\n");
last;
}
if ($debug)
{
printBanner("execPrint '$cmd' failed. Retrying...");
}
#else
#{
# print "\n###+++\nexecPrint '$cmd' failed. Retrying...\n\n";
# logmsg(0,"\n###+++\nexecPrint '$cmd' failed. Retrying...\n\n");
#}
sleep 10;
}

if ( $res != 0 )
{
Expand Down
Loading

0 comments on commit 7540002

Please sign in to comment.