From 5dac45c386d1df8bef3cd80483de3125f10c76f0 Mon Sep 17 00:00:00 2001 From: Marco Valle Date: Sun, 28 Apr 2024 18:58:30 +0200 Subject: [PATCH] Authorization header from file implemented. --- snmp/opensearch | 28 +++++++++++++++++++++++++--- 1 file changed, 25 insertions(+), 3 deletions(-) diff --git a/snmp/opensearch b/snmp/opensearch index 300115a32..cac3d5093 100755 --- a/snmp/opensearch +++ b/snmp/opensearch @@ -31,6 +31,7 @@ Add this to snmpd.conf as below and restart snmpd. Supported command line options are as below. + -a Auth token path. -c CA file path. Default: empty -h The host to connect to. @@ -58,6 +59,7 @@ sub main::VERSION_MESSAGE { sub main::HELP_MESSAGE { print "\n" + . "-a Auth token path.\n" . "-c CA file path.\n" . "-h The host to connect to.\n" . " Default: 127.0.0.1\n" @@ -73,7 +75,7 @@ my $schema = 'http'; #gets the options my %opts; -getopts( 'c:h:p:P:S', \%opts ); +getopts( 'a:c:h:p:P:S', \%opts ); if ( defined( $opts{h} ) ) { $host = $opts{h}; } @@ -84,6 +86,14 @@ if ( $opts{S} ) { $schema = 'https'; } +my $auth_token; +if ( defined( $opts{a} ) ) { + open my $auth_file, '<', $opts{a}; + $auth_token = <$auth_file>; + close $auth_file; + chop $auth_token; +} + # my $to_return = { error => 0, @@ -107,7 +117,13 @@ if ( defined( $opts{c} ) ) { $ua->ssl_opts( SSL_ca_file => $opts{c}); } -my $stats_response = $ua->get($stats_url); +my $stats_response; +if ( defined( $opts{a} ) ) { + $stats_response = $ua->get($stats_url, "Authorization" => $auth_token,); +} else { + $stats_response = $ua->get($stats_url); +} + my $stats_json; if ( $stats_response->is_success ) { eval { $stats_json = decode_json( $stats_response->decoded_content ); }; @@ -131,7 +147,13 @@ else { exit; } -my $health_response = $ua->get($health_url); +my $health_response; +if ( defined( $opts{a} ) ) { + $health_response = $ua->get($health_url, "Authorization" => $auth_token,); +} else { + $health_response = $ua->get($health_url); +} + my $health_json; if ( $health_response->is_success ) { eval { $health_json = decode_json( $health_response->decoded_content ); };