2013-12-13 16:14:12 +01:00
#
2020-01-06 15:19:23 +01:00
# Copyright 2020 Centreon (http://www.centreon.com/)
2015-07-21 11:51:02 +02:00
#
# Centreon is a full-fledged industry-strength solution that meets
# the needs in IT infrastructure and application monitoring for
# service performance.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
2013-12-13 16:14:12 +01:00
package centreon::plugins::script_sql ;
use strict ;
use warnings ;
use centreon::plugins::misc ;
sub new {
my ( $ class , % options ) = @ _ ;
my $ self = { } ;
bless $ self , $ class ;
$ self - > { options } = $ options { options } ;
$ self - > { output } = $ options { output } ;
$ self - > { options } - > add_options (
2019-09-19 15:01:10 +02:00
arguments = > {
'mode:s' = > { name = > 'mode_name' } ,
'dyn-mode:s' = > { name = > 'dynmode_name' } ,
'list-mode' = > { name = > 'list_mode' } ,
'mode-version:s' = > { name = > 'mode_version' } ,
'sqlmode:s' = > { name = > 'sqlmode_name' , default = > 'dbi' } ,
'list-sqlmode' = > { name = > 'list_sqlmode' } ,
'multiple' = > { name = > 'multiple' } ,
'no-sanity-options' = > { name = > 'no_sanity_options' } ,
2020-07-01 18:15:11 +02:00
'pass-manager:s' = > { name = > 'pass_manager' }
2019-04-16 17:01:22 +02:00
}
) ;
2013-12-13 16:14:12 +01:00
$ self - > { version } = '1.0' ;
2020-07-07 10:03:22 +02:00
$ self - > { modes } = { } ;
2020-07-01 18:15:11 +02:00
$ self - > { sql_modes } = { 'dbi' = > 'centreon::plugins::dbi' } ;
2013-12-13 16:14:12 +01:00
$ self - > { default } = undef ;
$ self - > { sqldefault } = { } ;
$ self - > { sqlmode_current } = undef ;
$ self - > { sqlmode_stored } = [] ;
$ self - > { options } - > parse_options ( ) ;
$ self - > { option_results } = $ self - > { options } - > get_options ( ) ;
foreach ( keys % { $ self - > { option_results } } ) {
$ self - > { $ _ } = $ self - > { option_results } - > { $ _ } ;
}
$ self - > { options } - > clean ( ) ;
$ self - > { options } - > add_help ( package = > $ options { package } , sections = > 'PLUGIN DESCRIPTION' ) ;
$ self - > { options } - > add_help ( package = > __PACKAGE__ , sections = > 'GLOBAL OPTIONS' ) ;
2019-04-16 17:01:22 +02:00
$ self - > { output } - > mode ( name = > $ self - > { mode_name } ) ;
2013-12-13 16:14:12 +01:00
return $ self ;
}
sub init {
my ( $ self , % options ) = @ _ ;
2019-07-08 14:15:29 +02:00
# add meta mode
$ self - > { modes } - > { multi } = 'centreon::plugins::multi' ;
2013-12-13 16:14:12 +01:00
if ( defined ( $ options { help } ) && ! defined ( $ self - > { mode_name } ) && ! defined ( $ self - > { dynmode_name } ) ) {
$ self - > { options } - > display_help ( ) ;
$ self - > { output } - > option_exit ( ) ;
}
2020-07-28 16:57:30 +02:00
if ( defined ( $ options { version } ) && ! defined ( $ self - > { mode_name } ) && ! defined ( $ self - > { dynmode_name } ) ) {
2013-12-13 16:14:12 +01:00
$ self - > version ( ) ;
}
if ( defined ( $ self - > { list_mode } ) ) {
$ self - > list_mode ( ) ;
}
if ( defined ( $ self - > { list_sqlmode } ) ) {
$ self - > list_sqlmode ( ) ;
}
2019-09-19 15:01:10 +02:00
$ self - > { options } - > set_sanity ( ) if ( ! defined ( $ self - > { no_sanity_options } ) ) ;
2013-12-13 16:14:12 +01:00
# Output HELP
$ self - > { options } - > add_help ( package = > 'centreon::plugins::output' , sections = > 'OUTPUT OPTIONS' ) ;
2019-01-24 13:15:10 +01:00
$ self - > load_password_mgr ( ) ;
2013-12-13 16:14:12 +01:00
if ( defined ( $ self - > { sqlmode_name } ) && $ self - > { sqlmode_name } ne '' ) {
$ self - > is_sqlmode ( sqlmode = > $ self - > { sqlmode_name } ) ;
2020-07-01 18:15:11 +02:00
centreon::plugins::misc:: mymodule_load (
output = > $ self - > { output } , module = > $ self - > { sql_modes } - > { $ self - > { sqlmode_name } } ,
error_msg = > "Cannot load module --sqlmode."
) ;
$ self - > { sqlmode_current } = $ self - > { sql_modes } - > { $ self - > { sqlmode_name } } - > new (
options = > $ self - > { options } ,
output = > $ self - > { output } ,
2020-07-07 10:03:22 +02:00
sqlmode_name = > $ self - > { sqlmode_name } ,
2020-07-01 18:15:11 +02:00
mode_name = > $ self - > { mode_name }
) ;
2013-12-13 16:14:12 +01:00
} else {
$ self - > { output } - > add_option_msg ( short_msg = > "Need to specify '--sqlmode'." ) ;
$ self - > { output } - > option_exit ( ) ;
}
# Load mode
if ( defined ( $ self - > { mode_name } ) && $ self - > { mode_name } ne '' ) {
$ self - > is_mode ( mode = > $ self - > { mode_name } ) ;
centreon::plugins::misc:: mymodule_load ( output = > $ self - > { output } , module = > $ self - > { modes } { $ self - > { mode_name } } ,
error_msg = > "Cannot load module --mode." ) ;
$ self - > { mode } = $ self - > { modes } { $ self - > { mode_name } } - > new ( options = > $ self - > { options } , output = > $ self - > { output } , mode = > $ self - > { mode_name } ) ;
} elsif ( defined ( $ self - > { dynmode_name } ) && $ self - > { dynmode_name } ne '' ) {
2016-05-02 21:06:27 +02:00
( undef , $ self - > { dynmode_name } ) = centreon::plugins::misc:: mymodule_load ( output = > $ self - > { output } , module = > $ self - > { dynmode_name } ,
error_msg = > "Cannot load module --dyn-mode." ) ;
2014-12-08 20:15:21 +01:00
$ self - > { mode } = $ self - > { dynmode_name } - > new ( options = > $ self - > { options } , output = > $ self - > { output } , mode = > $ self - > { dynmode_name } ) ;
2013-12-13 16:14:12 +01:00
} else {
$ self - > { output } - > add_option_msg ( short_msg = > "Need to specify '--mode' or '--dyn-mode' option." ) ;
$ self - > { output } - > option_exit ( ) ;
}
if ( defined ( $ options { help } ) ) {
2014-11-18 15:49:02 +01:00
if ( defined ( $ self - > { mode_name } ) && $ self - > { mode_name } ne '' ) {
$ self - > { options } - > add_help ( package = > $ self - > { modes } { $ self - > { mode_name } } , sections = > 'MODE' ) ;
} else {
$ self - > { options } - > add_help ( package = > $ self - > { dynmode_name } , sections = > 'MODE' ) ;
}
2013-12-13 16:14:12 +01:00
$ self - > { options } - > display_help ( ) ;
$ self - > { output } - > option_exit ( ) ;
}
if ( defined ( $ options { version } ) ) {
$ self - > { mode } - > version ( ) ;
$ self - > { output } - > option_exit ( nolabel = > 1 ) ;
}
2014-06-23 15:32:47 +02:00
if ( centreon::plugins::misc:: minimal_version ( $ self - > { mode } - > { version } , $ self - > { mode_version } ) == 0 ) {
$ self - > { output } - > add_option_msg ( short_msg = > "Not good version for plugin mode. Excepted at least: " . $ self - > { mode_version } . ". Get: " . $ self - > { mode } - > { version } ) ;
$ self - > { output } - > option_exit ( ) ;
}
2013-12-13 16:14:12 +01:00
$ self - > { options } - > parse_options ( ) ;
$ self - > { option_results } = $ self - > { options } - > get_options ( ) ;
2019-01-24 13:15:10 +01:00
$ self - > { pass_mgr } - > manage_options ( option_results = > $ self - > { option_results } ) if ( defined ( $ self - > { pass_mgr } ) ) ;
2013-12-13 16:14:12 +01:00
push @ { $ self - > { sqlmode_stored } } , $ self - > { sqlmode_current } ;
$ self - > { sqlmode_current } - > set_options ( option_results = > $ self - > { option_results } ) ;
$ self - > { sqlmode_current } - > set_defaults ( default = > $ self - > { sqldefault } ) ;
while ( $ self - > { sqlmode_current } - > check_options ( ) ) {
2020-07-01 18:15:11 +02:00
$ self - > { sqlmode_current } = $ self - > { sql_modes } - > { $ self - > { sqlmode_name } } - > new ( noptions = > 1 , options = > $ self - > { options } , output = > $ self - > { output } , mode = > $ self - > { sqlmode_name } ) ;
2013-12-13 16:14:12 +01:00
$ self - > { sqlmode_current } - > set_options ( option_results = > $ self - > { option_results } ) ;
push @ { $ self - > { sqlmode_stored } } , $ self - > { sqlmode_current } ;
}
2019-07-08 14:15:29 +02:00
$ self - > { mode } - > check_options (
option_results = > $ self - > { option_results } ,
default = > $ self - > { default } ,
modes = > $ self - > { modes } # for meta mode multi
) ;
2013-12-13 16:14:12 +01:00
}
2019-01-24 13:15:10 +01:00
sub load_password_mgr {
my ( $ self , % options ) = @ _ ;
return if ( ! defined ( $ self - > { option_results } - > { pass_manager } ) || $ self - > { option_results } - > { pass_manager } eq '' ) ;
( undef , my $ pass_mgr_name ) = centreon::plugins::misc:: mymodule_load (
output = > $ self - > { output } , module = > "centreon::plugins::passwordmgr::" . $ self - > { option_results } - > { pass_manager } ,
error_msg = > "Cannot load module 'centreon::plugins::passwordmgr::" . $ self - > { option_results } - > { pass_manager } . "'"
) ;
$ self - > { pass_mgr } = $ pass_mgr_name - > new ( options = > $ self - > { options } , output = > $ self - > { output } ) ;
}
2013-12-13 16:14:12 +01:00
sub run {
my $ self = shift ;
if ( $ self - > { output } - > is_disco_format ( ) ) {
$ self - > { mode } - > disco_format ( ) ;
$ self - > { output } - > display_disco_format ( ) ;
$ self - > { output } - > exit ( exit_litteral = > 'ok' ) ;
}
if ( $ self - > { output } - > is_disco_show ( ) ) {
if ( defined ( $ self - > { multiple } ) ) {
$ self - > { mode } - > disco_show ( sql = > $ self - > { sqlmode } ) ;
} else {
$ self - > { mode } - > disco_show ( sql = > $ self - > { sqlmode_stored } [ 0 ] ) ;
}
$ self - > { output } - > display_disco_show ( ) ;
$ self - > { output } - > exit ( exit_litteral = > 'ok' ) ;
} else {
if ( defined ( $ self - > { multiple } ) ) {
$ self - > { mode } - > run ( sql = > $ self - > { sqlmode_stored } ) ;
} else {
$ self - > { mode } - > run ( sql = > $ self - > { sqlmode_stored } [ 0 ] ) ;
}
}
}
sub is_mode {
my ( $ self , % options ) = @ _ ;
# $options->{mode} = mode
if ( ! defined ( $ self - > { modes } { $ options { mode } } ) ) {
$ self - > { output } - > add_option_msg ( short_msg = > "mode '" . $ options { mode } . "' doesn't exist (use --list-mode option to show available modes)." ) ;
$ self - > { output } - > option_exit ( ) ;
}
}
sub is_sqlmode {
my ( $ self , % options ) = @ _ ;
# $options->{sqlmode} = mode
2020-07-01 18:15:11 +02:00
if ( ! defined ( $ self - > { sql_modes } - > { $ options { sqlmode } } ) ) {
2013-12-13 16:14:12 +01:00
$ self - > { output } - > add_option_msg ( short_msg = > "mode '" . $ options { sqlmode } . "' doesn't exist (use --list-sqlmode option to show available modes)." ) ;
$ self - > { output } - > option_exit ( ) ;
}
}
sub version {
my $ self = shift ;
$ self - > { output } - > add_option_msg ( short_msg = > "Plugin Version: " . $ self - > { version } ) ;
$ self - > { output } - > option_exit ( nolabel = > 1 ) ;
}
sub list_mode {
my $ self = shift ;
$ self - > { options } - > display_help ( ) ;
2019-07-08 14:15:29 +02:00
$ self - > { output } - > add_option_msg ( long_msg = > 'Modes Meta:' ) ;
$ self - > { output } - > add_option_msg ( long_msg = > ' multi' ) ;
$ self - > { output } - > add_option_msg ( long_msg = > '' ) ;
$ self - > { output } - > add_option_msg ( long_msg = > 'Modes Available:' ) ;
2015-01-27 11:48:33 +01:00
foreach ( sort keys % { $ self - > { modes } } ) {
2019-07-08 14:15:29 +02:00
next if ( $ _ eq 'multi' ) ;
$ self - > { output } - > add_option_msg ( long_msg = > ' ' . $ _ ) ;
2013-12-13 16:14:12 +01:00
}
$ self - > { output } - > option_exit ( nolabel = > 1 ) ;
}
sub list_sqlmode {
my $ self = shift ;
$ self - > { options } - > display_help ( ) ;
$ self - > { output } - > add_option_msg ( long_msg = > "SQL Modes Available:" ) ;
foreach ( keys % { $ self - > { sql_modes } } ) {
$ self - > { output } - > add_option_msg ( long_msg = > " " . $ _ ) ;
}
$ self - > { output } - > option_exit ( nolabel = > 1 ) ;
}
1 ;
__END__
= head1 NAME
-
= head1 SYNOPSIS
-
= head1 GLOBAL OPTIONS
= over 8
= item B <--mode>
Choose a mode .
2014-12-09 19:31:52 +01:00
= item B <--dyn-mode>
2013-12-13 16:14:12 +01:00
2014-12-09 19:31:52 +01:00
Specify a mode with the path ( separated by '::' ) .
2013-12-13 16:14:12 +01:00
2014-12-09 19:31:52 +01:00
= item B <--list-mode>
2013-12-13 16:14:12 +01:00
2014-12-09 19:31:52 +01:00
List available modes .
2013-12-13 16:14:12 +01:00
2014-06-23 15:32:47 +02:00
= item B <--mode-version>
Check minimal version of mode . If not , unknown error .
2014-12-09 19:31:52 +01:00
= item B <--version>
2013-12-13 16:14:12 +01:00
2014-12-09 19:31:52 +01:00
Display plugin version .
2013-12-13 16:14:12 +01:00
= item B <--sqlmode>
Choose a sql mode ( Default: "dbi" ) .
= item B <--list-sqlmode>
List available sql modes .
= item B <--multiple>
2020-04-20 19:37:10 +02:00
Multiple database connections ( required by some specific modes ) .
2013-12-13 16:14:12 +01:00
2019-09-19 15:01:10 +02:00
= item B <--pass-manager>
Use a password manager .
2013-12-13 16:14:12 +01:00
= back
= head1 DESCRIPTION
B < > .
= cut