2013-12-13 16:14:12 +01:00
#
2017-01-09 17:12:12 +01:00
# Copyright 2017 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 ;
# $options{package} = parent package caller
# $options{options} = options object
# $options{output} = output object
$ self - > { options } = $ options { options } ;
$ self - > { output } = $ options { output } ;
$ self - > { options } - > add_options (
arguments = > {
2014-06-23 15:32:47 +02:00
'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' } ,
2015-11-10 10:44:19 +01:00
'sanity-options' = > { name = > 'sanity_options' } , # keep it for 6 month before remove it
2013-12-13 16:14:12 +01:00
}
) ;
$ self - > { version } = '1.0' ;
% { $ self - > { modes } } = ( ) ;
% { $ self - > { sql_modes } } = ( 'dbi' = > 'centreon::plugins::dbi' ) ;
$ 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' ) ;
return $ self ;
}
sub init {
my ( $ self , % options ) = @ _ ;
# $options{version} = string version
# $options{help} = string help
if ( defined ( $ options { help } ) && ! defined ( $ self - > { mode_name } ) && ! defined ( $ self - > { dynmode_name } ) ) {
$ self - > { options } - > display_help ( ) ;
$ self - > { output } - > option_exit ( ) ;
}
if ( defined ( $ options { version } ) && ! defined ( $ self - > { mode_name } ) && ! defined ( $ self - > { dynmode_name } ) ) {
$ self - > version ( ) ;
}
if ( defined ( $ self - > { list_mode } ) ) {
$ self - > list_mode ( ) ;
}
if ( defined ( $ self - > { list_sqlmode } ) ) {
$ self - > list_sqlmode ( ) ;
}
2015-11-10 10:44:19 +01:00
$ self - > { options } - > set_sanity ( ) ;
2013-12-13 16:14:12 +01:00
# Output HELP
$ self - > { options } - > add_help ( package = > 'centreon::plugins::output' , sections = > 'OUTPUT OPTIONS' ) ;
if ( defined ( $ self - > { sqlmode_name } ) && $ self - > { sqlmode_name } ne '' ) {
$ self - > is_sqlmode ( sqlmode = > $ self - > { sqlmode_name } ) ;
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 } , mode = > $ self - > { sqlmode_name } ) ;
} 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 ( ) ;
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 ( ) ) {
$ self - > { sqlmode_current } = $ self - > { sql_modes } { $ self - > { sqlmode_name } } - > new ( noptions = > 1 , options = > $ self - > { options } , output = > $ self - > { output } , mode = > $ self - > { sqlmode_name } ) ;
$ self - > { sqlmode_current } - > set_options ( option_results = > $ self - > { option_results } ) ;
push @ { $ self - > { sqlmode_stored } } , $ self - > { sqlmode_current } ;
}
$ self - > { mode } - > check_options ( option_results = > $ self - > { option_results } , default = > $ self - > { default } ) ;
}
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
if ( ! defined ( $ self - > { sql_modes } { $ options { sqlmode } } ) ) {
$ 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 ( ) ;
$ self - > { output } - > add_option_msg ( long_msg = > "Modes Available:" ) ;
2015-01-27 11:48:33 +01:00
foreach ( sort keys % { $ self - > { modes } } ) {
2013-12-13 16:14:12 +01:00
$ self - > { output } - > add_option_msg ( long_msg = > " " . $ _ ) ;
}
$ 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>
Multiple database connections ( some mode needs it ) .
= back
= head1 DESCRIPTION
B < > .
= cut