diff --git a/extras/android-event-viewer/.idea/misc.xml b/extras/android-event-viewer/.idea/misc.xml
index 38041c7cc6..a4aaf9f97e 100644
--- a/extras/android-event-viewer/.idea/misc.xml
+++ b/extras/android-event-viewer/.idea/misc.xml
@@ -1,8 +1,5 @@
-
-
-
@@ -27,17 +24,7 @@
-
-
-
-
-
-
-
-
-
-
-
+
diff --git a/extras/android-event-viewer/app/build.gradle b/extras/android-event-viewer/app/build.gradle
index 92924f93b3..d9a280d817 100644
--- a/extras/android-event-viewer/app/build.gradle
+++ b/extras/android-event-viewer/app/build.gradle
@@ -2,7 +2,7 @@ apply plugin: 'com.android.application'
android {
compileSdkVersion 8
- buildToolsVersion "25.0.2"
+ buildToolsVersion "26.0.2"
defaultConfig {
applicationId "pandroid_event_viewer.pandorafms"
diff --git a/extras/android-event-viewer/app/src/main/java/pandroid_event_viewer/pandorafms/EventList.java b/extras/android-event-viewer/app/src/main/java/pandroid_event_viewer/pandorafms/EventList.java
index 15ca771bad..b208855e0b 100644
--- a/extras/android-event-viewer/app/src/main/java/pandroid_event_viewer/pandorafms/EventList.java
+++ b/extras/android-event-viewer/app/src/main/java/pandroid_event_viewer/pandorafms/EventList.java
@@ -159,8 +159,14 @@ public class EventList extends ListActivity {
}
});
-
-
+ ImageButton btnSettings = (ImageButton) findViewById(R.id.settings_icon_button_list);
+ // Open the settings
+ btnSettings.setOnClickListener(new View.OnClickListener() {
+ public void onClick(View v) {
+ startActivity(new Intent(v.getContext(), Options.class));
+ }
+ });
+
registerReceiver(onBroadcast, new IntentFilter("eventlist.java"));
this.toggleLoadingLayout();
diff --git a/extras/android-event-viewer/app/src/main/java/pandroid_event_viewer/pandorafms/Main.java b/extras/android-event-viewer/app/src/main/java/pandroid_event_viewer/pandorafms/Main.java
index 6ab57371e9..2548b8023b 100644
--- a/extras/android-event-viewer/app/src/main/java/pandroid_event_viewer/pandorafms/Main.java
+++ b/extras/android-event-viewer/app/src/main/java/pandroid_event_viewer/pandorafms/Main.java
@@ -96,10 +96,29 @@ public class Main extends Activity {
Activity.MODE_PRIVATE);
setContentView(R.layout.main);
+ final ImageButton btnSettings = (ImageButton) findViewById(R.id.settings_icon_button_main);
+ final ImageButton btnFilter = (ImageButton) findViewById(R.id.filter_icon_button_main);
final Button buttonSetAsFilterWatcher = (Button) findViewById(R.id.button_set_as_filter_watcher);
final ImageButton buttonSearch = (ImageButton) findViewById(R.id.refresh_icon_button_main);
final ImageButton buttonDeleteProfile = (ImageButton) findViewById(R.id.button_delete_profile);
final ImageButton buttonSaveProfile = (ImageButton) findViewById(R.id.button_save_profile);
+
+ // Open the settings
+ btnSettings.setOnClickListener(new View.OnClickListener() {
+ public void onClick(View v) {
+ startActivity(new Intent(v.getContext(), Options.class));
+ }
+ });
+
+ // Go to the events list
+ btnFilter.setOnClickListener(new View.OnClickListener() {
+ public void onClick(View v) {
+ Activity a = (Activity) v.getContext();
+ TabActivity ta = (TabActivity) a.getParent();
+ ta.getTabHost().setCurrentTab(1);
+ }
+ });
+
// Check if the user preferences it is set.
if (object.user.length() == 0 || object.password.length() == 0
|| object.url.length() == 0) {
diff --git a/extras/android-event-viewer/app/src/main/res/layout/list_view_layout.xml b/extras/android-event-viewer/app/src/main/res/layout/list_view_layout.xml
index 9b32dfe1dc..b0135b4489 100644
--- a/extras/android-event-viewer/app/src/main/res/layout/list_view_layout.xml
+++ b/extras/android-event-viewer/app/src/main/res/layout/list_view_layout.xml
@@ -63,8 +63,22 @@
android:layout_weight="0"
android:padding="0dp"
android:src="@drawable/filter_icon_button"
+ android:background="@null" />
+
+
+
+
+ android:tint="@android:color/white"
+ android:src="@android:drawable/ic_menu_preferences" />
+
+
+
+
+
+
/dev/null
diff --git a/pandora_agents/unix/Darwin/pandora_agent.conf b/pandora_agents/unix/Darwin/pandora_agent.conf
index 723b17232c..d7647191a4 100644
--- a/pandora_agents/unix/Darwin/pandora_agent.conf
+++ b/pandora_agents/unix/Darwin/pandora_agent.conf
@@ -1,5 +1,5 @@
# Base config file for Pandora FMS agents
-# Version 7.0NG.714, GNU/Linux
+# Version 7.0NG.716, GNU/Linux
# Licensed under GPL license v2,
# Copyright (c) 2003-2012 Artica Soluciones Tecnologicas
# http://www.pandorafms.com
diff --git a/pandora_agents/unix/FreeBSD/pandora_agent.conf b/pandora_agents/unix/FreeBSD/pandora_agent.conf
index 8a8ecd3451..2625ca7542 100644
--- a/pandora_agents/unix/FreeBSD/pandora_agent.conf
+++ b/pandora_agents/unix/FreeBSD/pandora_agent.conf
@@ -1,5 +1,5 @@
# Base config file for Pandora FMS agents
-# Version 7.0NG.714, FreeBSD Version
+# Version 7.0NG.716, FreeBSD Version
# Licensed under GPL license v2,
# Copyright (c) 2003-2016 Artica Soluciones Tecnologicas
# http://www.pandorafms.com
diff --git a/pandora_agents/unix/HP-UX/pandora_agent.conf b/pandora_agents/unix/HP-UX/pandora_agent.conf
index f31d7e6cd0..2387412e15 100644
--- a/pandora_agents/unix/HP-UX/pandora_agent.conf
+++ b/pandora_agents/unix/HP-UX/pandora_agent.conf
@@ -1,5 +1,5 @@
# Base config file for Pandora FMS agents
-# Version 7.0NG.714, HP-UX Version
+# Version 7.0NG.716, HP-UX Version
# Licensed under GPL license v2,
# Copyright (c) 2003-2009 Artica Soluciones Tecnologicas
# http://www.pandorafms.com
diff --git a/pandora_agents/unix/Linux/pandora_agent.conf b/pandora_agents/unix/Linux/pandora_agent.conf
index 59ea7ed59d..da5c2b2c18 100644
--- a/pandora_agents/unix/Linux/pandora_agent.conf
+++ b/pandora_agents/unix/Linux/pandora_agent.conf
@@ -1,5 +1,5 @@
# Base config file for Pandora FMS agents
-# Version 7.0NG.714, GNU/Linux
+# Version 7.0NG.716, GNU/Linux
# Licensed under GPL license v2,
# Copyright (c) 2003-2014 Artica Soluciones Tecnologicas
# http://www.pandorafms.com
diff --git a/pandora_agents/unix/NT4/pandora_agent.conf b/pandora_agents/unix/NT4/pandora_agent.conf
index ee6b7bb18d..a0717d889e 100644
--- a/pandora_agents/unix/NT4/pandora_agent.conf
+++ b/pandora_agents/unix/NT4/pandora_agent.conf
@@ -1,5 +1,5 @@
# Base config file for Pandora FMS agents
-# Version 7.0NG.714, GNU/Linux
+# Version 7.0NG.716, GNU/Linux
# Licensed under GPL license v2,
# Copyright (c) 2003-2009 Artica Soluciones Tecnologicas
# http://www.pandorafms.com
diff --git a/pandora_agents/unix/NetBSD/pandora_agent.conf b/pandora_agents/unix/NetBSD/pandora_agent.conf
index aa64beba39..0cc5dc41cc 100644
--- a/pandora_agents/unix/NetBSD/pandora_agent.conf
+++ b/pandora_agents/unix/NetBSD/pandora_agent.conf
@@ -1,5 +1,5 @@
# Base config file for Pandora FMS agents
-# Version 7.0NG.714, NetBSD Version
+# Version 7.0NG.716, NetBSD Version
# Licensed under GPL license v2,
# Copyright (c) 2003-2010 Artica Soluciones Tecnologicas
# http://www.pandorafms.com
diff --git a/pandora_agents/unix/SunOS/pandora_agent.conf b/pandora_agents/unix/SunOS/pandora_agent.conf
index 3dada142de..ac8ece9b0c 100644
--- a/pandora_agents/unix/SunOS/pandora_agent.conf
+++ b/pandora_agents/unix/SunOS/pandora_agent.conf
@@ -1,5 +1,5 @@
# Base config file for Pandora FMS agents
-# Version 7.0NG.714, Solaris Version
+# Version 7.0NG.716, Solaris Version
# Licensed under GPL license v2,
# Copyright (c) 2003-2009 Artica Soluciones Tecnologicas
# http://www.pandorafms.com
diff --git a/pandora_agents/unix/pandora_agent b/pandora_agents/unix/pandora_agent
index 1baa741ddd..7c1cbe610c 100755
--- a/pandora_agents/unix/pandora_agent
+++ b/pandora_agents/unix/pandora_agent
@@ -40,8 +40,8 @@ my $Sem = undef;
# Semaphore used to control the number of threads
my $ThreadSem = undef;
-use constant AGENT_VERSION => '7.0NG.714';
-use constant AGENT_BUILD => '171026';
+use constant AGENT_VERSION => '7.0NG.716';
+use constant AGENT_BUILD => '171130';
# Agent log default file size maximum and instances
use constant DEFAULT_MAX_LOG_SIZE => 600000;
@@ -1244,7 +1244,11 @@ sub check_collections () {
# Delete old collections if there are no broker agents
if ($BrokerEnabled == 0) {
- opendir (DIR, "$ConfDir/collections") || return;
+ if(!opendir (DIR, "$ConfDir/collections")){
+ log_message ('Collection', "Could not open dir $ConfDir/collections");
+ return;
+ }
+
while (defined (my $file_name = readdir(DIR))) {
next if ($file_name eq '.' || $file_name eq '..');
@@ -1252,8 +1256,14 @@ sub check_collections () {
$file_name =~ s/\.md5$//;
if (! defined ($Collections{$file_name})) {
- rmrf ("$ConfDir/collections/$file_name");
- unlink ("$ConfDir/collections/$file_name.md5");
+ if(opendir (DIR_check, "$ConfDir/collections/$file_name")){
+ closedir (DIR_check);
+ rmrf ("$ConfDir/collections/$file_name");
+ unlink ("$ConfDir/collections/$file_name.md5");
+ }
+ else {
+ log_message ('Collection', "Could not open dir $ConfDir/collections/$file_name");
+ }
}
}
closedir (DIR);
@@ -1272,7 +1282,11 @@ sub check_collections () {
# Get remote md5
error ("File '$Conf{'temporal'}/$collection_md5_file' already exists as a symlink and could not be removed: $!.") if (-l "$Conf{'temporal'}/$collection_md5_file" && !unlink("$Conf{'temporal'}/$collection_md5_file"));
- next unless (recv_file ($collection_md5_file, $Conf{'server_path_md5'}) == 0);
+ if(recv_file ($collection_md5_file, $Conf{'server_path_md5'}) != 0){
+ log_message ('Collection', "Could not write $collection_md5_file on " . $Conf{'server_path_md5'});
+ next;
+ }
+
open (MD5_FILE, "< $Conf{'temporal'}/$collection_md5_file") || error ("Could not open file '$Conf{'temporal'}/$collection_md5_file' for reading: $!.");
my $remote_collection_md5 = ;
close (MD5_FILE);
@@ -1284,13 +1298,20 @@ sub check_collections () {
$local_collection_md5 = ;
close MD5_FILE;
}
+ else{
+ log_message ('Collection', "Could not open dir $ConfDir/collections/$collection_md5_file");
+ next;
+ }
# Check for changes
$local_collection_md5 = $remote_collection_md5 unless defined ($local_collection_md5);
next if ($local_collection_md5 eq $remote_collection_md5);
# Download and unzip
- next unless (recv_file ($collection_file, $Conf{'server_path_zip'}) == 0);
+ if(recv_file ($collection_md5_file, $Conf{'server_path_md5'}) != 0){
+ log_message ('Collection', "Could not write $collection_file on " . $Conf{'server_path_zip'});
+ next;
+ }
rmrf ("$ConfDir/collections/$collection");
`unzip -d "$ConfDir/collections/$collection" "$Conf{'temporal'}/$collection_file" 2>$DevNull`;
unlink ("$Conf{'temporal'}/$collection_file");
diff --git a/pandora_agents/unix/pandora_agent.redhat.spec b/pandora_agents/unix/pandora_agent.redhat.spec
index d5e904b50b..582cba7a4c 100644
--- a/pandora_agents/unix/pandora_agent.redhat.spec
+++ b/pandora_agents/unix/pandora_agent.redhat.spec
@@ -2,8 +2,8 @@
#Pandora FMS Linux Agent
#
%define name pandorafms_agent_unix
-%define version 7.0NG.714
-%define release 171026
+%define version 7.0NG.716
+%define release 171130
Summary: Pandora FMS Linux agent, PERL version
Name: %{name}
diff --git a/pandora_agents/unix/pandora_agent.spec b/pandora_agents/unix/pandora_agent.spec
index c42622d2fa..1e91878da6 100644
--- a/pandora_agents/unix/pandora_agent.spec
+++ b/pandora_agents/unix/pandora_agent.spec
@@ -2,8 +2,8 @@
#Pandora FMS Linux Agent
#
%define name pandorafms_agent_unix
-%define version 7.0NG.714
-%define release 171026
+%define version 7.0NG.716
+%define release 171130
Summary: Pandora FMS Linux agent, PERL version
Name: %{name}
diff --git a/pandora_agents/unix/pandora_agent_installer b/pandora_agents/unix/pandora_agent_installer
index 8aabf312e2..696fa280a0 100755
--- a/pandora_agents/unix/pandora_agent_installer
+++ b/pandora_agents/unix/pandora_agent_installer
@@ -9,8 +9,8 @@
# Please see http://www.pandorafms.org. This code is licensed under GPL 2.0 license.
# **********************************************************************
-PI_VERSION="7.0NG.714"
-PI_BUILD="171026"
+PI_VERSION="7.0NG.716"
+PI_BUILD="171130"
OS_NAME=`uname -s`
FORCE=0
diff --git a/pandora_agents/unix/plugins/route_parser b/pandora_agents/unix/plugins/route_parser
new file mode 100644
index 0000000000..40cfcea36f
--- /dev/null
+++ b/pandora_agents/unix/plugins/route_parser
@@ -0,0 +1,780 @@
+#!/usr/bin/perl
+#
+# Dynamic route parser
+# Combines MTR and Ping features
+#
+#
+
+use strict;
+use warnings;
+use POSIX qw(strftime);
+use Scalar::Util qw(looks_like_number);
+use Socket;
+
+my $HELP=< 1 } @{$array};
+ if (exists($params{$value})) {
+ return 1;
+ }
+ return 0;
+}
+
+################################################################################
+# Check if a given variable contents a number
+################################################################################
+sub to_number($) {
+ my $n = shift;
+
+ if(empty($n)) {
+ return undef;
+ }
+
+ if ($n =~ /[\d+,]*\d+\.\d+/) {
+ # American notation
+ $n =~ s/,//g;
+ }
+ elsif ($n =~ /[\d+\.]*\d+,\d+/) {
+ # Spanish notation
+ $n =~ s/\.//g;
+ $n =~ s/,/./g;
+ }
+ if(looks_like_number($n)) {
+ return $n;
+ }
+ return undef;
+}
+
+################################################################################
+# Erase blank spaces before and after the string
+################################################################################
+sub trim($){
+ my $string = shift;
+ if (empty ($string)){
+ return "";
+ }
+
+ $string =~ s/\r//g;
+
+ chomp ($string);
+ $string =~ s/^\s+//g;
+ $string =~ s/\s+$//g;
+
+ return $string;
+}
+
+################################################################################
+# Empty
+################################################################################
+sub empty($){
+ my $str = shift;
+
+ if (! (defined ($str)) ){
+ return 1;
+ }
+
+ if(looks_like_number($str)){
+ return 0;
+ }
+
+ if (ref ($str) eq "ARRAY") {
+ return (($#{$str}<0)?1:0);
+ }
+
+ if (ref ($str) eq "HASH") {
+ my @tmp = keys %{$str};
+ return (($#tmp<0)?1:0);
+ }
+
+ if ($str =~ /^\ *[\n\r]{0,2}\ *$/) {
+ return 1;
+ }
+ return 0;
+}
+
+################################################################################
+# is Enabled
+################################################################################
+sub is_enabled($){
+ my $value = shift;
+
+ if ((defined ($value)) && ($value > 0)){
+ # return true
+ return 1;
+ }
+ #return false
+ return 0;
+
+}
+
+################################################################################
+# print_module
+################################################################################
+sub print_module ($$;$){
+ my $config = shift;
+ my $data = shift;
+ my $not_print_flag = shift;
+
+ if ((ref($data) ne "HASH") || (!defined $data->{name})) {
+ return undef;
+ }
+
+ my $xml_module = "";
+ # If not a string type, remove all blank spaces!
+ if ($data->{type} !~ m/string/){
+ $data->{value} = trim($data->{value});
+ }
+
+ $data->{tags} = $data->{tags}?$data->{tags}:($config->{MODULE_TAG_LIST}?$config->{MODULE_TAG_LIST}:undef);
+ $data->{interval} = $data->{interval}?$data->{interval}:($config->{MODULE_INTERVAL}?$config->{MODULE_INTERVAL}:undef);
+ $data->{module_group} = $data->{module_group}?$data->{module_group}:($config->{MODULE_GROUP}?$config->{MODULE_GROUP}:undef);
+
+ # Global instructions (if defined)
+ $data->{unknown_instructions} = $config->{unknown_instructions} unless (defined($data->{unknown_instructions}) || (!defined($config->{unknown_instructions})));
+ $data->{warning_instructions} = $config->{warning_instructions} unless (defined($data->{warning_instructions}) || (!defined($config->{warning_instructions})));
+ $data->{critical_instructions} = $config->{critical_instructions} unless (defined($data->{critical_instructions}) || (!defined($config->{critical_instructions})));
+
+ $xml_module .= "\n";
+ $xml_module .= "\t{name} . "]]> \n";
+ $xml_module .= "\t" . $data->{type} . " \n";
+
+ if (ref ($data->{value}) eq "ARRAY") {
+ $xml_module .= "\t\n";
+ foreach (@{$data->{value}}) {
+ $xml_module .= "\t{value} . "]]> \n";
+ }
+ $xml_module .= "\t \n";
+ }
+ else {
+ $xml_module .= "\t{value} . "]]> \n";
+ }
+
+ if ( !(empty($data->{desc}))) {
+ $xml_module .= "\t{desc} . "]]> \n";
+ }
+ if ( !(empty ($data->{unit})) ) {
+ $xml_module .= "\t{unit} . "]]> \n";
+ }
+ if (! (empty($data->{interval})) ) {
+ $xml_module .= "\t{interval} . "]]> \n";
+ }
+ if (! (empty($data->{tags})) ) {
+ $xml_module .= "\t" . $data->{tags} . " \n";
+ }
+ if (! (empty($data->{module_group})) ) {
+ $xml_module .= "\t" . $data->{module_group} . " \n";
+ }
+ if (! (empty($data->{module_parent})) ) {
+ $xml_module .= "\t" . $data->{module_parent} . " \n";
+ }
+ if (! (empty($data->{wmin})) ) {
+ $xml_module .= "\t{wmin} . "]]> \n";
+ }
+ if (! (empty($data->{wmax})) ) {
+ $xml_module .= "\t{wmax} . "]]> \n";
+ }
+ if (! (empty ($data->{cmin})) ) {
+ $xml_module .= "\t{cmin} . "]]> \n";
+ }
+ if (! (empty ($data->{cmax})) ){
+ $xml_module .= "\t{cmax} . "]]> \n";
+ }
+ if (! (empty ($data->{wstr}))) {
+ $xml_module .= "\t{wstr} . "]]> \n";
+ }
+ if (! (empty ($data->{cstr}))) {
+ $xml_module .= "\t{cstr} . "]]> \n";
+ }
+ if (! (empty ($data->{cinv}))) {
+ $xml_module .= "\t{cinv} . "]]> \n";
+ }
+ if (! (empty ($data->{winv}))) {
+ $xml_module .= "\t{winv} . "]]> \n";
+ }
+ if (! (empty ($data->{max}))) {
+ $xml_module .= "\t{max} . "]]> \n";
+ }
+ if (! (empty ($data->{min}))) {
+ $xml_module .= "\t{min} . "]]> \n";
+ }
+ if (! (empty ($data->{post_process}))) {
+ $xml_module .= "\t{post_process} . "]]> \n";
+ }
+ if (! (empty ($data->{disabled}))) {
+ $xml_module .= "\t{disabled} . "]]> \n";
+ }
+ if (! (empty ($data->{min_ff_event}))) {
+ $xml_module .= "\t{min_ff_event} . "]]> \n";
+ }
+ if (! (empty ($data->{status}))) {
+ $xml_module .= "\t{status} . "]]> \n";
+ }
+ if (! (empty ($data->{timestamp}))) {
+ $xml_module .= "\t{timestamp} . "]]> \n";
+ }
+ if (! (empty ($data->{custom_id}))) {
+ $xml_module .= "\t{custom_id} . "]]> \n";
+ }
+ if (! (empty ($data->{critical_instructions}))) {
+ $xml_module .= "\t{critical_instructions} . "]]> \n";
+ }
+ if (! (empty ($data->{warning_instructions}))) {
+ $xml_module .= "\t{warning_instructions} . "]]> \n";
+ }
+ if (! (empty ($data->{unknown_instructions}))) {
+ $xml_module .= "\t{unknown_instructions} . "]]> \n";
+ }
+ if (! (empty ($data->{quiet}))) {
+ $xml_module .= "\t{quiet} . "]]> \n";
+ }
+ if (! (empty ($data->{module_ff_interval}))) {
+ $xml_module .= "\t{module_ff_interval} . "]]> \n";
+ }
+ if (! (empty ($data->{crontab}))) {
+ $xml_module .= "\t{crontab} . "]]> \n";
+ }
+ if (! (empty ($data->{min_ff_event_normal}))) {
+ $xml_module .= "\t{min_ff_event_normal} . "]]> \n";
+ }
+ if (! (empty ($data->{min_ff_event_warning}))) {
+ $xml_module .= "\t{min_ff_event_warning} . "]]> \n";
+ }
+ if (! (empty ($data->{min_ff_event_critical}))) {
+ $xml_module .= "\t{min_ff_event_critical} . "]]> \n";
+ }
+ if (! (empty ($data->{ff_timeout}))) {
+ $xml_module .= "\t{ff_timeout} . "]]> \n";
+ }
+ if (! (empty ($data->{each_ff}))) {
+ $xml_module .= "\t{each_ff} . "]]> \n";
+ }
+ if (! (empty ($data->{parent_unlink}))) {
+ $xml_module .= "\t{parent_unlink} . "]]> \n";
+ }
+ if (! (empty ($data->{alerts}))) {
+ foreach my $alert (@{$data->{alerts}}){
+ $xml_module .= "\t \n";
+ }
+ }
+ if (defined ($config->{global_alerts})){
+ foreach my $alert (@{$config->{global_alerts}}){
+ $xml_module .= "\t \n";
+ }
+ }
+
+ $xml_module .= " \n";
+
+ if (empty ($not_print_flag)) {
+ print $xml_module;
+ }
+
+ return $xml_module;
+}
+
+################################################################################
+# General arguments parser
+################################################################################
+sub parse_arguments($) {
+ my $raw = shift;
+ my @args;
+ if (defined($raw)){
+ @args = @{$raw};
+ }
+ else {
+ return {};
+ }
+
+ my %data;
+ for (my $i = 0; $i < $#args; $i+=2) {
+ my $key = trim($args[$i]);
+
+ $key =~ s/^-//;
+ $data{$key} = trim($args[$i+1]);
+ }
+
+ return \%data;
+
+}
+
+################################################################################
+# General configuration file parser
+#
+# log=/PATH/TO/LOG/FILE
+#
+################################################################################
+sub parse_configuration($;$$){
+ my $conf_file = shift;
+ my $separator;
+ $separator = shift or $separator = "=";
+ my $custom_eval = shift;
+ my $_CFILE;
+
+ my $_config;
+
+ if (empty($conf_file)) {
+ return {
+ error => "Configuration file not specified"
+ };
+ }
+
+ if( !open ($_CFILE,"<", "$conf_file")) {
+ return {
+ error => "Cannot open configuration file"
+ };
+ }
+
+ while (my $line = <$_CFILE>){
+ if (($line =~ /^ *\r*\n*$/)
+ || ($line =~ /^#/ )){
+ # skip blank lines and comments
+ next;
+ }
+ my @parsed = split /$separator/, $line, 2;
+ if ($line =~ /^\s*global_alerts/){
+ push (@{$_config->{global_alerts}}, trim($parsed[1]));
+ next;
+ }
+ if (ref ($custom_eval) eq "ARRAY") {
+ my $f = 0;
+ foreach my $item (@{$custom_eval}) {
+ if ($line =~ /$item->{exp}/) {
+ $f = 1;
+ my $aux;
+ eval {
+ $aux = $item->{target}->($item->{exp},$line);
+ };
+
+ if (empty($_config)) {
+ $_config = $aux;
+ }
+ elsif (!empty($aux) && (ref ($aux) eq "HASH")) {
+ $_config = merge_hashes($_config, $aux);
+ }
+ }
+ }
+
+ if (is_enabled($f)){
+ next;
+ }
+ }
+ $_config->{trim($parsed[0])} = trim($parsed[1]);
+ }
+ close ($_CFILE);
+
+ return $_config;
+}
+
+################################################################################
+# End of import
+################################################################################
+
+
+##########################################################################
+# Show a message to STDERR
+##########################################################################
+sub msg {
+ my $msg = shift;
+ print STDERR strftime ("%Y-%m-%d %H:%M:%S", localtime()) . ": $msg\n";
+}
+
+
+sub get_next {
+ my ($route, $step) = @_;
+ return $route->{'next'}->{$step};
+}
+
+##########################################################################
+# Extract route steps & timming from mtr output
+##########################################################################
+sub get_steps {
+ my ($conf) = @_;
+ my $target = $conf->{'t'};
+
+ return [] if empty($target);
+
+ my $mtr_r = "";
+ my $ping_r = "";
+
+ my @route_raw;
+ my @ping_raw;
+
+
+ if ($^O =~ /win/i){
+ $ping_r = trim(`ping -r 9 $target -n 1 | tr "Routea:->-" " " | gawk "/^[0-9\. ]*\$/ {if (\$1 != \\"\\"){ print \$1\";\"0}}"`) unless is_enabled($conf->{'-no-ping'});
+
+ @ping_raw = split /\n/, $ping_r;
+
+ if ($#ping_raw < 0) {
+ $mtr_r = trim(`mtr -n -o A -c $conf->{'c'} -r $target 2>/NUL | gawk "{print \$2";"\$3}"`) unless is_enabled($conf->{'-no-mtr'});
+ }
+ }
+ else {
+ $ping_r = trim(`for x in \$(ping -n -c 1 -R $target 2>/dev/null | tr -s "R:" " " | awk '/^[0-9\. \t]*\$/ {if (\$1 != ""){print \$1}}'); do echo -n \$x";"; ping -c $conf->{'c'} \$x 2>/dev/null | grep rtt |awk '{print \$4}'| cut -f2 -d"/"; done`) unless is_enabled($conf->{'-no-ping'});
+
+ @ping_raw = split /\n/, $ping_r;
+
+ if ($#ping_raw < 0) {
+ $mtr_r = trim(`mtr -n -c $conf->{'c'} -r $target -o A 2>/dev/null | awk '/^[0-9\\|\\-\\. \\t]*\$/ {print \$2\";\"\$3}'`) unless is_enabled($conf->{'-no-mtr'});
+ }
+
+ }
+
+ @route_raw = split /\n/, $mtr_r;
+
+ my @modules;
+ my @steps;
+ my $route;
+
+ if ($#ping_raw >= 0) {
+ # PING mode
+
+ my $rng = scalar @ping_raw;
+ my $checked;
+ my $j;
+
+ if (is_enabled($conf->{'s'})) {
+ # Symmetric routing
+
+ if ($^O =~ /win/i){
+ $j = 1;
+ }
+ else {
+ $j = 0;
+ }
+
+ for (my $i=0; $i< ($rng/2); $i++) {
+ my ($step,$time) = split /;/, $ping_raw[$i];
+ my $_r;
+
+ if (defined($checked->{$step})) {
+ $j-=2;
+ next;
+ }
+ $checked->{$step} = 1;
+
+ $_r->{'step'} = $step;
+ if ($^O =~ /win/i) {
+ $_r->{'time'} = trim(`ping -n $conf->{'c'} $_r->{'step'} | grep -e "Av" -e "Me" | gawk "{print \$NF}" | tr -d "ms"`) unless ((!defined($_r->{'step'}) || ($_r->{'step'} eq "")));
+ }
+ else {
+ $_r->{'time'} = $time;
+ }
+
+ if ((!defined($_r->{'step'}) || ($_r->{'step'} eq ""))) {
+ $_r->{'step'} = "???";
+ }
+
+ $steps[$j] = $_r;
+ $j+=2;
+ }
+
+ if ($^O =~ /win/i){
+ $j = 0;
+ }
+ else {
+ $j = 1;
+ }
+ for (my $i=$rng-1; $i>= ($rng/2); $i--) {
+ my ($step,$time) = split /;/, $ping_raw[$i];
+ my $_r;
+
+ if (defined($checked->{$step})) {
+ $j-=2 if $j>2;
+ next;
+ }
+
+ $_r->{'step'} = $step;
+ if ($^O =~ /win/i) {
+ $_r->{'time'} = trim(`ping -n $conf->{'c'} $_r->{'step'} | grep -e "Av" -e "Me" | gawk "{print \$NF}" | tr -d "ms"`) unless ((!defined($_r->{'step'}) || ($_r->{'step'} eq "")));
+ }
+ else {
+ $_r->{'time'} = $time;
+ }
+
+
+ if ((!defined($_r->{'step'}) || ($_r->{'step'} eq ""))) {
+ $_r->{'step'} = "???";
+ }
+
+ $steps[$j] = $_r;
+ $j+=2;
+ }
+ }
+ else {
+ # Asymmetric routing
+
+ for (my $i=0; $i< $rng; $i++) {
+ my ($step,$time) = split /;/, $ping_raw[$i];
+ my $_r;
+
+ if (defined($checked->{$step})) {
+ # target reached
+ last;
+ }
+
+ $checked->{$step} = 1;
+
+ $_r->{'step'} = $step;
+ if ($^O =~ /win/i) {
+ $_r->{'time'} = trim(`ping -n $conf->{'c'} $_r->{'step'} | grep -e "Av" -e "Me" | gawk "{print \$NF}" | tr -d "ms"`) unless ((!defined($_r->{'step'}) || ($_r->{'step'} eq "")));
+ }
+ else {
+ $_r->{'time'} = $time;
+ }
+
+ if ((!defined($_r->{'step'}) || ($_r->{'step'} eq ""))) {
+ $_r->{'step'} = "???";
+ }
+
+ $steps[$i] = $_r;
+ }
+ }
+
+ my $__origin;
+
+ if ($^O !~ /win/i){
+ $__origin = shift @steps;
+ }
+
+ my $gw;
+
+ if ($^O =~ /win/i) {
+ ($gw->{'step'},$__origin->{'step'}) = split /;/, trim(`route print -4 | gawk "BEGIN {min=10000} /^\\ *0.0.0.0/ {met=\$NF;if(met{'time'} = trim(`ping -n $conf->{'c'} $gw->{'step'} 2>/NUL | grep ms | grep -v TTL | gawk "{print \$NF}" | tr -d "ms"`);
+ $__origin->{'time'} = 0;
+ }
+ else {
+ $gw->{'step'} = trim(`route -n | awk 'BEGIN {min=100000} /^0/ {met=\$5; if(min>met){gw=\$2;min=met} } END { print gw}'`);
+ $gw->{'time'} = trim(`ping -c $conf->{'c'} $gw->{'step'} 2>/dev/null | grep rtt |awk '{print \$4}'| cut -f2 -d"/"`);
+ }
+
+ unshift (@steps,($__origin,$gw));
+
+ my $unknown_count = 0;
+ my $previous = undef;
+
+ for(my $i=0; $i <= $#steps; $i++) {
+ my $host = $steps[$i]->{'step'};
+ my $time = to_number($steps[$i]->{'time'});
+ my $preffix = 'RouteStep_';
+ my $desc = '';
+
+ if (!defined($time)) {
+ next;
+ }
+
+ if ($host eq "???") {
+ $host = "Hidden_" . (++$unknown_count);
+ }
+ if (($i == $#steps) && in_array($conf->{'target_ip'},$host)) {
+ $preffix = 'RouteStepTarget_';
+ }
+ elsif($i == $#steps) {
+ $desc = 'Step unreachable';
+ }
+
+ push @modules, {
+ name => $preffix . $host,
+ type => "generic_data",
+ value => $time,
+ unit => 'ms',
+ desc => $desc,
+ module_parent => $previous,
+ parent_unlink => (empty($previous)?'1':undef)
+ };
+
+ $previous = $preffix . $host;
+ }
+
+ return \@modules;
+ }
+ else {
+ # MTR mode
+
+ if ($#route_raw < 0) {
+ # Empty output
+ msg("Failed to analyze [$target]");
+ return [];
+
+ }
+
+ for (my $i=0; $i <= $#route_raw; $i++) {
+ my $line = $route_raw[$i];
+ if (trim($line) =~ /(.*?);(.*)/) {
+ my $host = $1;
+ my $time = to_number($2);
+ my $preffix = 'RouteStep_';
+ my $desc = '';
+ my $item;
+ my $_r;
+
+ if (!defined($time)) {
+ next;
+ }
+
+ $_r->{'step'} = $host;
+ $_r->{'time'} = $time;
+
+ push @steps, $_r;
+ }
+ }
+
+ my $__origin;
+
+ if ($^O !~ /win/i){
+ $__origin = shift @steps;
+ }
+
+ my $gw;
+
+ if ($^O =~ /win/i) {
+ ($gw->{'step'},$__origin->{'step'}) = split /;/, trim(`route print -4 | gawk "BEGIN {min=10000} /^\\ *0.0.0.0/ {met=\$NF;if(met{'time'} = trim(`ping -n $conf->{'c'} $gw->{'step'} 2>/NUL | grep ms | grep -v TTL | gawk "{print \$NF}" | tr -d "ms"`);
+ $__origin->{'time'} = 0;
+ }
+ else {
+ $gw->{'step'} = trim(`route -n | awk 'BEGIN {min=100000} /^0/ {met=\$5; if(min>met){gw=\$2;min=met} } END { print gw}'`);
+ $gw->{'time'} = trim(`ping -c $conf->{'c'} $gw->{'step'} 2>/dev/null | grep rtt |awk '{print \$4}'| cut -f2 -d"/"`);
+
+ my $__xorigin = trim(`ip a show dev \`route -n | awk 'BEGIN {min=100000} /^0/ {met=\$5; if(min>met){iface=\$NF;min=met} } END { print iface}'\` | grep -w inet | awk '{print \$2}' | cut -d'/' -f1`);
+
+ if ($__xorigin ne $__origin->{'step'}) {
+ unshift(@steps, $__origin);
+ $__origin = {};
+ $__origin->{'step'} = $__xorigin;
+ $__origin->{'time'} = 0;
+ }
+ }
+
+ unshift (@steps,($__origin,$gw));
+
+ my $unknown_count = 0;
+ my $previous = undef;
+
+ for(my $i=0; $i <= $#steps; $i++) {
+ my $host = $steps[$i]->{'step'};
+ my $time = to_number($steps[$i]->{'time'});
+ my $preffix = 'RouteStep_';
+ my $desc = '';
+
+ if (!defined($time)) {
+ next;
+ }
+
+ if ($host eq "???") {
+ $host = "Hidden_" . (++$unknown_count);
+ }
+ if (($i == $#steps) && in_array($conf->{'target_ip'},$host)) {
+ $preffix = 'RouteStepTarget_';
+ }
+ elsif($i == $#steps) {
+ $desc = 'Step unreachable';
+ }
+
+ push @modules, {
+ name => $preffix . $host,
+ type => "generic_data",
+ value => $time,
+ unit => 'ms',
+ desc => $desc,
+ module_parent => $previous,
+ parent_unlink => (empty($previous)?'1':undef)
+ };
+
+ $previous = $preffix . $host;
+ }
+ }
+
+ return \@modules;
+}
+
+
+##########################################################################
+##########################################################################
+# MAIN
+##########################################################################
+##########################################################################
+
+if ($#ARGV < 0) {
+ print STDERR $HELP;
+ exit 1;
+}
+
+my $conf;
+my $file_conf = {};
+my $args_conf = {};
+
+if (-e $ARGV[0]) {
+ $file_conf = parse_configuration($ARGV[0]);
+ shift @ARGV;
+}
+
+$args_conf = parse_arguments(\@ARGV);
+$conf = merge_hashes($file_conf,$args_conf);
+
+if (!defined $conf->{'t'}) {
+ print STDERR $HELP;
+ exit 1;
+}
+
+my @targets = gethostbyname($conf->{'t'});
+@targets = map { inet_ntoa($_) } @targets[4 .. $#targets];
+if (empty(\@targets)) {
+ print STDERR "Cannot resolve $conf->{'t'} \n";
+ exit 2;
+}
+
+
+$conf->{'target_ip'} = \@targets;
+
+$conf->{'c'} = 4 unless looks_like_number($conf->{'c'});
+$conf->{'s'} = 1 unless looks_like_number($conf->{'s'});
+
+
+my $results = get_steps($conf);
+
+foreach (@{$results}) {
+ print_module($conf, $_);
+}
+
+
+
diff --git a/pandora_agents/win32/bin/pandora_agent.conf b/pandora_agents/win32/bin/pandora_agent.conf
index c8c32e84d0..5cbf2b0876 100644
--- a/pandora_agents/win32/bin/pandora_agent.conf
+++ b/pandora_agents/win32/bin/pandora_agent.conf
@@ -1,6 +1,6 @@
# Base config file for Pandora FMS Windows Agent
-# (c) 2006-2014 Artica Soluciones Tecnologicas
-# Version 7.0NG.714
+# (c) 2006-2017 Artica Soluciones Tecnologicas
+# Version 7.0NG.716
# This program is Free Software, you can redistribute it and/or modify it
# under the terms of the GNU General Public Licence as published by the Free Software
@@ -21,6 +21,13 @@ server_ip $ServerIP$
server_path /var/spool/pandora/data_in
temporal "%ProgramFiles%\pandora_agent\temp"
+# Group assigned for this agent (descriptive, p.e: Servers)
+group $GroupName$
+
+# If set to 1 allows the agent to be configured via the web console
+# (only works on enterprise version). Set to 0 to disable it
+remote_config 0
+
#include "C:\Archivos de programa\pandora_agent\pandora_agent_alt.conf"
#broker_agent name_agent
@@ -43,15 +50,10 @@ agent_name_cmd __rand__
# address: Enforce to server a ip address to this agent
# You can also try to detect the first IP using "auto", for example
-
address auto
-
# or setting a fixed IP address, like for example:
#address 192.168.36.73
-# Group assigned for this agent (descriptive, p.e: Servers)
-group Servers
-
# This limits operation if temporal dir has not enough free disk.
#temporal_min_size 1024
@@ -80,10 +82,6 @@ server_port 41121
# Debug mode renames XML in the temp folder and continues running
# debug 1
-# If set to 1 allows the agent to be configured via the web console
-# (only works on enterprise version). Set to 0 to disable it
-remote_config 0
-
# XML encoding (ISO-8859-1 by default). Most windows servers experience problems when you set to UTF-8. Other special codepages may be specified here.
#encoding ISO-8859-1
@@ -102,6 +100,10 @@ xml_buffer 1
# Agent mode: Learn (default), No-learn, Autodisable
# agent_mode autodisable
+# EHorus configuration file default full path.
+#It try to find the EKID and set it like a custom field.
+ehorus_conf "C:\Program Files\ehorus_agent\ehorus_agent.conf"
+
# Secondary server configuration
# ==============================
@@ -127,74 +129,166 @@ xml_buffer 1
#process_firefox_stop killall firefox
#service_messenger 1
+###############################################
# Module Definition
# Check online documentation and module library at http://pandorafms.org
# =================
-# Get Network information using Agent plugin
-module_plugin cscript //B "%ProgramFiles%\Pandora_Agent\util\nettraffic.vbs"
-
-# Get disk occupation (percent)
-module_plugin cscript.exe //B "%ProgramFiles%\Pandora_Agent\util\df_percent.vbs"
-
-# External inventory plugin
-module_begin
-module_plugin cscript.exe //B "%ProgramFiles%\Pandora_Agent\util\software_installed.vbs"
-module_interval 288
-# 288 x 5min = 24 hr, one execution per day, using module_interval
-module_end
-
-# CPU Load
-
+# CPU Load using WMI
module_begin
module_name CPU Load
module_type generic_data
-#module_wmiquery SELECT LoadPercentage FROM Win32_Processor
-#module_wmicolumn LoadPercentage
-module_cpuusage all
-module_description CPU Load (%)
-module_unit %
-module_min_warning 80
+module_wmiquery SELECT LoadPercentage FROM Win32_Processor
+module_wmicolumn LoadPercentage
+module_max 100
+module_min 0
+module_description User CPU Usage (%)
+module_min_warning 70
module_max_warning 90
module_min_critical 91
module_max_critical 100
+module_unit %
+module_group System
module_end
-# Number processes
+# Basic info about TCP Connection
module_begin
-module_name Number processes
-module_type generic_data
-module_exec tasklist | gawk "NR > 3 {print$0}" | wc -l
-module_description Number of processes running
-module_min_warning 175
-module_max_warning 249
-module_min_critical 250
-module_max_critical 300
+module_name TCP_Connections
+module_type generic_data
+module_exec netstat -an | find /c /v "estab"
+module_description Total number of TCP connections active
+module_group Networking
module_end
+# Example plugin to retrieve drive usage
+module_plugin cscript.exe //B "%ProgramFiles%\Pandora_Agent\util\df_percent_used.vbs"
+
+# Example plugin to retrieve memory usage
+module_plugin cscript.exe //B "%ProgramFiles%\Pandora_Agent\util\mem_percent_used.vbs"
+
+# Example plugin to retrieve network usage
+module_plugin cscript.exe //B "%ProgramFiles%\Pandora_Agent\util\network.vbs"
+
+## Windows inventory module (This information will be displayed only in enterprise version)
+## Please check the WMI is healthy before activate this functionality
+
+#module_begin
+#module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\cpuinfo.vbs"
+#module_crontab * 12-15 * * 1
+#module_end
+
+#module_begin
+#module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\moboinfo.vbs"
+#module_crontab * 12-15 * * 1
+#module_end
+
+#module_begin
+#module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\diskdrives.vbs"
+#module_crontab * 12-15 * * 1
+#module_end
+
+#module_begin
+#module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\cdromdrives.vbs"
+#module_crontab * 12-15 * * 1
+#module_end
+
+#module_begin
+#module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\videocardinfo.vbs"
+#module_crontab * 12-15 * * 1
+#module_end
+
+#module_begin
+#module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\ifaces.vbs"
+#module_crontab * 12-15 * * 1
+#module_end
+
+#module_begin
+#module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\monitors.vbs"
+#module_crontab * 12-15 * * 1
+#module_end
+
+#module_begin
+#module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\printers.vbs"
+#module_crontab * 12-15 * * 1
+#module_end
+
+#module_begin
+#module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\raminfo.vbs"
+#module_crontab * 12-15 * * 1
+#module_end
+
+#module_begin
+#module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\software_installed.vbs"
+#module_crontab * 12-15 * * 1
+#module_end
+
+#module_begin
+#module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\userslogged.vbs"
+#module_crontab * 12-15 * * 1
+#module_end
+
+#module_begin
+#module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\productkey.vbs"
+#module_crontab * 12-15 * * 1
+#module_end
+
+#module_begin
+#module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\productID.vbs"
+#module_crontab * 12-15 * * 1
+#module_end
+
+#########################################
+# EXAMPLES #
+#########################################
+
+# Example: get Network information using Agent plugin
+#module_plugin cscript //B "%ProgramFiles%\Pandora_Agent\util\nettraffic.vbs"
+
+# External inventory plugin
+#module_begin
+#module_plugin cscript.exe //B "%ProgramFiles%\Pandora_Agent\util\software_installed.vbs"
+#module_interval 288
+## 288 x 5min = 24 hr, one execution per day, using module_interval
+#module_end
+
# Free Memory
-module_begin
-module_name FreeMemory
-module_type generic_data
-module_freepercentmemory
-module_unit %
-module_description Free memory (%).
-module_min_warning 21
-module_max_warning 30
-module_min_critical 0
-module_max_critical 20
-module_end
+#module_begin
+#module_name FreeMemory
+#module_type generic_data
+#module_freepercentmemory
+#module_description Free memory (%).
+#module_min_warning 21
+#module_max_warning 30
+#module_min_critical 0
+#module_max_critical 20
+#module_end
# Log events
+#module_begin
+#module_name System Events (TermService)
+#module_type async_string
+#module_logevent
+#module_description Log Events coming from Terminal Service
+#module_source System
+#module_application TermService
+#module_end
-module_begin
-module_name Security Events (Invalid Login)
-module_type async_string
-module_description Security log events for invalid login attempt
-module_logevent
-module_source Security
-module_eventcode 529
-module_end
+#module_begin
+#module_name Security Events (Invalid Login)
+#module_type async_string
+#module_description Security log events for invalid login attempt
+#module_logevent
+#module_source Security
+#module_eventcode 529
+#module_end
+
+# Check if Dhcp service is enabled
+#module_begin
+#module_name DHCP Enabled
+#module_type generic_proc
+#module_service Dhcp
+#module_description Check DCHP service enabled
+#module_end
#Antivirus monitoring
#This modules checks the antivirus is running on your system, if there is and antivirus
@@ -207,72 +301,51 @@ module_end
#module_description Last update for Antivirus Signature file
#module_end
-## Windows inventory module (This information will be displayed only in enterprise version)
-## Please check the WMI is healthy before activate this functionality
+# Number processes
+#module_begin
+#module_name Number processes
+#module_type generic_data
+#module_exec tasklist | gawk "NR > 3 {print$0}" | wc -l
+#module_description Number of processes running
+#module_min_warning 175
+#module_max_warning 249
+#module_min_critical 250
+#module_max_critical 300
+#module_end
-# module_begin
-# module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\cpuinfo.vbs"
-# module_crontab * 12-15 * * 1
-# module_end
+# Example plugin to retrieve drive usage
+#module_plugin cscript.exe //B "%ProgramFiles%\Pandora_Agent\util\df.vbs"
-# module_begin
-# module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\moboinfo.vbs"
-# module_crontab * 12-15 * * 1
-# module_end
+# Free space on disk C: (%)
+#module_begin
+#module_name FreeDiskC
+#module_type generic_data
+#module_freepercentdisk C:
+#module_description Free space on drive C: (%)
+#module_min_warning 31
+#module_max_warning 40
+#module_min_critical 0
+#module_max_critical 30
+#module_end
-# module_begin
-# module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\diskdrives.vbs"
-# module_crontab * 12-15 * * 1
-# module_end
+# CPU usage percentage
+#module_begin
+#module_name CPUUse
+#module_type generic_data
+#module_cpuusage all
+#module_description CPU# usage
+#module_min_warning 70
+#module_max_warning 90
+#module_min_critical 91
+#module_max_critical 100
+#module_end
+# Free space on disk D: (%)
# module_begin
-# module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\cdromdrives.vbs"
-# module_crontab * 12-15 * * 1
-# module_end
-
-# module_begin
-# module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\videocardinfo.vbs"
-# module_crontab * 12-15 * * 1
-# module_end
-
-# module_begin
-# module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\ifaces.vbs"
-# module_crontab * 12-15 * * 1
-# module_end
-
-# module_begin
-# module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\monitors.vbs"
-# module_crontab * 12-15 * * 1
-# module_end
-
-# module_begin
-# module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\printers.vbs"
-# module_crontab * 12-15 * * 1
-# module_end
-
-# module_begin
-# module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\raminfo.vbs"
-# module_crontab * 12-15 * * 1
-# module_end
-
-# module_begin
-# module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\software_installed.vbs"
-# module_crontab * 12-15 * * 1
-# module_end
-
-# module_begin
-# module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\userslogged.vbs"
-# module_crontab * 12-15 * * 1
-# module_end
-
-# module_begin
-# module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\productkey.vbs"
-# module_crontab * 12-15 * * 1
-# module_end
-
-# module_begin
-# module_plugin cscript.exe //B //t:20 "%PROGRAMFILES%\Pandora_Agent\util\productID.vbs"
-# module_crontab * 12-15 * * 1
+# module_name FreeDiskD
+# module_type generic_data
+# module_freepercentdisk D:
+# module_description Free space on drive D: (%)
# module_end
## Plugin example for custom fields (version, architecture, IP, IPv6, MAC)
@@ -281,10 +354,9 @@ module_end
# module_crontab * 12-15 * * 1
# module_end
-# ----------------------------------------------------------------------------------------------------
-# This samples below need to be reconfigured and uncommented. Please read documentation
-# on how to setup pandora fms windows agent at http://wiki.pandorafms.com
-# ----------------------------------------------------------------------------------------------------
+# Example plugin to retrieve last 5 min events in log4x format
+# module_plugin cscript.exe //B "%ProgramFiles%\Pandora_Agent\util\logevent_log4x.vbs" Aplicacion System 300
+
# Sample on how to get a value from registry
# This returns the last time user launch microsoft Windows update
#module_begin
@@ -391,11 +463,11 @@ module_end
#module_description Postcondition test module
#module_end
-#Example of when module_native_encoding is necessary
-#Dont uncomment module_native_encoding tag to see the difference
+# Example of native encoding.
#module_begin
-#module_name Accent_example
+#module_name Written Accent
#module_type generic_data_string
#module_exec echo Bordón
#module_native_encoding OEM
#module_end
+
diff --git a/pandora_agents/win32/bin/util/mtr.exe b/pandora_agents/win32/bin/util/mtr.exe
new file mode 100644
index 0000000000..3646ca89aa
Binary files /dev/null and b/pandora_agents/win32/bin/util/mtr.exe differ
diff --git a/pandora_agents/win32/bin/util/route_parser.exe b/pandora_agents/win32/bin/util/route_parser.exe
new file mode 100644
index 0000000000..4da75a272a
Binary files /dev/null and b/pandora_agents/win32/bin/util/route_parser.exe differ
diff --git a/pandora_agents/win32/installer/pandora.mpi b/pandora_agents/win32/installer/pandora.mpi
index 044490051c..d3ca83843f 100644
--- a/pandora_agents/win32/installer/pandora.mpi
+++ b/pandora_agents/win32/installer/pandora.mpi
@@ -3,7 +3,7 @@ AllowLanguageSelection
{Yes}
AppName
-{Pandora FMS Windows Agent v7.0NG.714}
+{Pandora FMS Windows Agent v7.0NG.716}
ApplicationID
{17E3D2CF-CA02-406B-8A80-9D31C17BD08F}
@@ -186,7 +186,7 @@ UpgradeApplicationID
{}
Version
-{171026}
+{171130}
ViewReadme
{Yes}
diff --git a/pandora_agents/win32/modules/pandora_module_factory.cc b/pandora_agents/win32/modules/pandora_module_factory.cc
index ad449a6a84..90c82d5457 100644
--- a/pandora_agents/win32/modules/pandora_module_factory.cc
+++ b/pandora_agents/win32/modules/pandora_module_factory.cc
@@ -1170,7 +1170,7 @@ Pandora_Module_Factory::getModuleFromDefinition (string definition) {
try {
char buffer[100];
unsigned long memory = Pandora_Wmi::getDiskFreeSpace(module_freedisk_percent);
- if (sprintf(buffer, "Free memory %s %dMB",
+ if (sprintf(buffer, "Free space on drive %s %dMB",
module_freedisk_percent.c_str(), memory) > 0) {
module->setDescription(buffer);
}
diff --git a/pandora_agents/win32/pandora.cc b/pandora_agents/win32/pandora.cc
index dac37430c2..7b1eb275ba 100644
--- a/pandora_agents/win32/pandora.cc
+++ b/pandora_agents/win32/pandora.cc
@@ -30,7 +30,7 @@ using namespace Pandora;
using namespace Pandora_Strutils;
#define PATH_SIZE _MAX_PATH+1
-#define PANDORA_VERSION ("7.0NG.714(Build 171026)")
+#define PANDORA_VERSION ("7.0NG.716(Build 171130)")
string pandora_path;
string pandora_dir;
diff --git a/pandora_agents/win32/versioninfo.rc b/pandora_agents/win32/versioninfo.rc
index c34abc2ebe..9bc83625c4 100644
--- a/pandora_agents/win32/versioninfo.rc
+++ b/pandora_agents/win32/versioninfo.rc
@@ -11,7 +11,7 @@ BEGIN
VALUE "LegalCopyright", "Artica ST"
VALUE "OriginalFilename", "PandoraAgent.exe"
VALUE "ProductName", "Pandora FMS Windows Agent"
- VALUE "ProductVersion", "(7.0NG.714(Build 171026))"
+ VALUE "ProductVersion", "(7.0NG.716(Build 171130))"
VALUE "FileVersion", "1.0.0.0"
END
END
diff --git a/pandora_console/DEBIAN/control b/pandora_console/DEBIAN/control
index 0f7f4593d0..b9efaf31e9 100644
--- a/pandora_console/DEBIAN/control
+++ b/pandora_console/DEBIAN/control
@@ -1,5 +1,5 @@
package: pandorafms-console
-Version: 7.0NG.714-171026
+Version: 7.0NG.716-171130
Architecture: all
Priority: optional
Section: admin
diff --git a/pandora_console/DEBIAN/make_deb_package.sh b/pandora_console/DEBIAN/make_deb_package.sh
index 19b0e092c0..43009ec1fd 100644
--- a/pandora_console/DEBIAN/make_deb_package.sh
+++ b/pandora_console/DEBIAN/make_deb_package.sh
@@ -14,7 +14,7 @@
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
-pandora_version="7.0NG.714-171026"
+pandora_version="7.0NG.716-171130"
package_pear=0
package_pandora=1
diff --git a/pandora_console/extensions/agents_alerts.php b/pandora_console/extensions/agents_alerts.php
index 97f1bc7589..f5cad20d74 100755
--- a/pandora_console/extensions/agents_alerts.php
+++ b/pandora_console/extensions/agents_alerts.php
@@ -546,9 +546,11 @@ ui_require_jquery_file('pandora');
});
$('#group_id').change(function(){
- var regx = /&group_id=\d*/g;
- var url = location.href.replace(regx, "");
- location.href = url+"&group_id="+$("#group_id").val();
+ if(location.href.indexOf("extensions/agents_modules") == -1){
+ var regx = /&group_id=\d*/g;
+ var url = location.href.replace(regx, "");
+ location.href = url+"&group_id="+$("#group_id").val();
+ }
});
});
diff --git a/pandora_console/extensions/agents_modules.php b/pandora_console/extensions/agents_modules.php
index a69343d6dd..6e6cf9a92e 100644
--- a/pandora_console/extensions/agents_modules.php
+++ b/pandora_console/extensions/agents_modules.php
@@ -72,7 +72,7 @@ function mainAgentsModules() {
$hor_offset = (int)get_parameter('hor_offset', 0);
$block = $config['block_size'];
if(get_parameter('modulegroup') != null){
- $agents_id = (array)get_parameter('id_agents2', -1);
+ $agents_id = (array)get_parameter('id_agents2', -1);
}
$selection_a_m = (int)get_parameter('selection_agent_module');
$modules_selected = (array)get_parameter('module', 0);
diff --git a/pandora_console/extensions/db_status.php b/pandora_console/extensions/db_status.php
index 2b0e281993..d184850a34 100755
--- a/pandora_console/extensions/db_status.php
+++ b/pandora_console/extensions/db_status.php
@@ -259,80 +259,60 @@ function extension_db_check_tables_differences($connection_test,
$field_system = $fields_system[$name_field];
$diff = array_diff($field_test, $field_system);
+
if (!empty($diff)) {
- foreach ($diff as $config_field => $value) {
- switch ($config_field) {
- case 'type':
- ui_print_error_message(
- __('Unsuccessful the field %s in the table %s must be set the type with %s.',
- $name_field, $table, $value));
- ui_print_info_message(
- __('You can execute this SQL query for to fix.') . " " .
- '' .
- "ALTER TABLE " . $table . " MODIFY COLUMN " . $name_field . " " . $value . ";" .
- ' '
- );
- break;
- case 'null':
- ui_print_error_message(
- __('Unsuccessful the field %s in the table %s must be null: (%s).',
- $name_field, $table, $value));
+ $info_message = "";
+ $error_message = "";
+ if($diff['type']){
+ $error_message .= "Unsuccessful the field ".$name_field." in the table ".$table." must be set the type with ".$diff['type']." ";
+ }
+
+ if($diff['null']){
+ $error_message .= "Unsuccessful the field $name_field in the table $table must be null: (".$diff['null']."). ";
+ }
+
+ if($diff['default']){
+ $error_message .= "Unsuccessful the field $name_field in the table $table must be set ".$diff['default']." as default value. ";
+ }
+
+ if($field_test['null'] == "YES" || !isset($field_test['null']) || $field_test['null'] == ""){
+ $null_defect = " NULL";
+ }
+ else{
+ $null_defect = " NOT NULL";
+ }
+
+ if(!isset($field_test['default']) || $field_test['default'] == ""){
+ $default_value = "";
+ }
+ else{
+ $default_value = " DEFAULT ".$field_test['default'];
+ }
+
+ if($diff['type'] || $diff['null'] || $diff['default']){
+ $info_message .= "ALTER TABLE " . $table . " MODIFY COLUMN " . $name_field . " " . $field_test['type'] . $null_defect . $default_value.";";
+ }
+
+ if($diff['key']){
+ $error_message .= "Unsuccessful the field $name_field in the table $table must be set the key as defined in the SQL file. ";
+ $info_message .= " Please check the SQL file for to know the kind of key needed.";
+ }
+
+ if($diff['extra']){
+ $error_message .= "Unsuccessful the field $name_field in the table $table must be set as defined in the SQL file. ";
+ $info_message .= " Please check the SQL file for to know the kind of extra config needed.";
+ }
+
+ ui_print_error_message(
+ __($error_message));
- if ($value == "YES") {
- ui_print_info_message(
- __('You can execute this SQL query for to fix.') . " " .
- '' .
- "ALTER TABLE " . $table . " MODIFY COLUMN " . $name_field . " " . $field_test['type'] . " NULL;" .
- ' '
- );
- }
- else {
- ui_print_info_message(
- __('You can execute this SQL query for to fix.') . " " .
- '' .
- "ALTER TABLE " . $table . " MODIFY COLUMN " . $name_field . " " . $field_test['type'] . " NOT NULL;" .
- ' '
- );
- }
+ ui_print_info_message(
+ __($info_message));
- break;
- case 'key':
- ui_print_error_message(
- __('Unsuccessful the field %s in the table %s must be set the key as defined in the SQL file.',
- $name_field, $table));
- ui_print_info_message(
- __('Please check the SQL file for to know the kind of key needed.'));
- break;
- case 'default':
- if($field_test['null'] == "YES" || !isset($field_test['null']) || $field_test['null'] == ""){
- $null_defect = " NULL";
- }
- else{
- $null_defect = " NOT NULL";
- }
- ui_print_error_message(
- __('Unsuccessful the field %s in the table %s must be set %s as default value.',
- $name_field, $table, $value));
- ui_print_info_message(
- __('You can execute this SQL query for to fix.') . " " .
- '' .
- "ALTER TABLE " . $table . " MODIFY COLUMN " . $name_field . " " . $field_test['type'] . $null_defect . " DEFAULT " . $value . ";" .
- ' '
- );
- break;
- case 'extra':
- ui_print_error_message(
- __('Unsuccessful the field %s in the table %s must be set as defined in the SQL file.',
- $name_field, $table));
- ui_print_info_message(
- __('Please check the SQL file for to know the kind of extra config needed.'));
- break;
}
}
}
}
- }
- }
if ($correct_fields) {
ui_print_success_message(
@@ -366,4 +346,4 @@ function extension_db_status_execute_sql_file($url, $connection) {
extensions_add_godmode_function('extension_db_status');
extensions_add_godmode_menu_option(__('DB Schema check'), 'DM', 'gextensions', null, "v1r1", 'gdbman');
-?>
\ No newline at end of file
+?>
diff --git a/pandora_console/extensions/pandora_logs.php b/pandora_console/extensions/pandora_logs.php
index f20bcab720..4241018a16 100644
--- a/pandora_console/extensions/pandora_logs.php
+++ b/pandora_console/extensions/pandora_logs.php
@@ -69,9 +69,9 @@ function pandoralogs_extension_main () {
ui_print_page_header (__("System logfile viewer"), "images/extensions.png", false, "", true, "" );
- echo "" . __('This tool is used just to view your Pandora FMS system logfiles directly from console') . "
";
+ echo "" . __('Use this tool to view your Pandora FMS logfiles directly on the console') . "
";
- echo "" . __('You can control the size information to show in general setup (Log size limit in view extension), actually ') . $config['max_log_size'] * 1000 . "B" . "
";
+ echo "" . __('You can choose the amount of information shown in general setup (Log size limit in system logs viewer extension), ' . $config['max_log_size'] * 1000 . 'B at the moment') . "
";
$logs_directory = (!empty($config["server_log_dir"])) ? io_safe_output($config["server_log_dir"]) : "/var/log/pandora";
diff --git a/pandora_console/extras/mr/10.sql b/pandora_console/extras/mr/10.sql
new file mode 100644
index 0000000000..e27f4fccf1
--- /dev/null
+++ b/pandora_console/extras/mr/10.sql
@@ -0,0 +1,5 @@
+START TRANSACTION;
+
+ALTER TABLE tsnmp_filter ADD unified_filters_id int(10) NOT NULL DEFAULT 0;
+
+COMMIT;
\ No newline at end of file
diff --git a/pandora_console/extras/mr/8.sql b/pandora_console/extras/mr/8.sql
new file mode 100644
index 0000000000..402fb7e82c
--- /dev/null
+++ b/pandora_console/extras/mr/8.sql
@@ -0,0 +1,21 @@
+START TRANSACTION;
+ALTER TABLE tusuario ADD COLUMN `time_autorefresh` int(5) unsigned NOT NULL default '30';
+ALTER TABLE treport_content ADD COLUMN lapse_calc tinyint(1) default '0';
+ALTER TABLE treport_content ADD COLUMN lapse int(11) default '300';
+ALTER TABLE treport_content ADD COLUMN visual_format tinyint(1) default '0';
+ALTER TABLE treport_content_template ADD COLUMN lapse_calc tinyint(1) default '0';
+ALTER TABLE treport_content_template ADD COLUMN lapse int(11) default '300';
+ALTER TABLE treport_content_template ADD COLUMN visual_format tinyint(1) default '0';
+
+UPDATE `talert_commands`
+SET `description` = 'This alert send an email using internal Pandora FMS Server SMTP capabilities (defined in each server, using:
_field1_ as destination email address, and
_field2_ as subject for message.
_field3_ as text of message.
_field4_ as content type (text/plain or html/text).',
+ `fields_descriptions` = '[\"Destination address\",\"Subject\",\"Text\",\"Content Type\",\"\",\"\",\"\",\"\",\"\",\"\"]',
+ `fields_values` = '[\"\",\"\",\"_html_editor_\",\"_content_type_\",\"\",\"\",\"\",\"\",\"\",\"\"]'
+WHERE id=1;
+
+UPDATE `talert_actions`
+SET `field4` = 'text/html',
+ `field4_recovery` = 'text/html'
+WHERE id = 1;
+
+COMMIT;
\ No newline at end of file
diff --git a/pandora_console/extras/mr/9.sql b/pandora_console/extras/mr/9.sql
new file mode 100644
index 0000000000..dbf0456323
--- /dev/null
+++ b/pandora_console/extras/mr/9.sql
@@ -0,0 +1,24 @@
+START TRANSACTION;
+
+SET @st_oum708 = (SELECT IF(
+ (SELECT COUNT(*) FROM information_schema.tables WHERE table_schema = DATABASE() AND table_name = 'tuser_task_scheduled') > 0,
+ "ALTER TABLE tuser_task_scheduled MODIFY args TEXT NOT NULL",
+ "SELECT 1"
+));
+
+PREPARE pr_oum708 FROM @st_oum708;
+EXECUTE pr_oum708;
+DEALLOCATE PREPARE pr_oum708;
+
+ALTER TABLE tagente ADD COLUMN `safe_mode_module` int(10) unsigned NOT NULL default '0';
+ALTER TABLE tmetaconsole_agent ADD COLUMN `safe_mode_module` int(10) unsigned NOT NULL default '0';
+
+alter table tlayout_data add column element_group int(10) not null default 0;
+
+alter table tlayout_data add column id_layout_linked_weight int(10) not null default 0;
+
+ALTER TABLE tlayout_data ADD COLUMN show_on_top tinyint(1) default 0;
+
+ALTER TABLE `tdashboard` ADD COLUMN `cells_slideshow` TINYINT(1) NOT NULL default 0;
+
+COMMIT;
diff --git a/pandora_console/extras/pandoradb_migrate_6.0_to_7.0.mysql.sql b/pandora_console/extras/pandoradb_migrate_6.0_to_7.0.mysql.sql
index 22bcc52766..111ac54ee0 100644
--- a/pandora_console/extras/pandoradb_migrate_6.0_to_7.0.mysql.sql
+++ b/pandora_console/extras/pandoradb_migrate_6.0_to_7.0.mysql.sql
@@ -725,6 +725,9 @@ CREATE TABLE IF NOT EXISTS `treport_content_template` (
`module_free_text` TEXT,
`each_agent` tinyint(1) default 1,
`historical_db` tinyint(1) UNSIGNED NOT NULL default 0,
+ `lapse_calc` tinyint(1) UNSIGNED NOT NULL default '0',
+ `lapse` int(11) UNSIGNED NOT NULL default '300',
+ `visual_format` tinyint(1) UNSIGNED NOT NULL default '0',
PRIMARY KEY(`id_rc`)
) ENGINE = InnoDB DEFAULT CHARSET=utf8;
@@ -1134,6 +1137,10 @@ ALTER TABLE talert_actions ADD COLUMN `field15_recovery` TEXT NOT NULL DEFAULT "
-- ---------------------------------------------------------------------
UPDATE `talert_commands` SET `fields_descriptions` = '[\"Integria IMS API path\",\"Integria IMS API pass\",\"Integria IMS user\",\"Integria IMS user pass\",\"Ticket title\",\"Ticket group ID\",\"Ticket priority\",\"Email copy\",\"Ticket owner\",\"Ticket description\"]', `fields_values` = '[\"\",\"\",\"\",\"\",\"\",\"\",\"10,Maintenance;0,Informative;1,Low;2,Medium;3,Serious;4,Very Serious\",\"\",\"\",\"\"]' WHERE `id` = 11 AND `name` = 'Integria IMS Ticket';
+UPDATE `talert_commands` SET `description` = 'This alert send an email using internal Pandora FMS Server SMTP capabilities (defined in each server, using:
_field1_ as destination email address, and
_field2_ as subject for message.
_field3_ as text of message.
_field4_ as content type (text/plain or html/text).', `fields_descriptions` = '[\"Destination address\",\"Subject\",\"Text\",\"Content Type\",\"\",\"\",\"\",\"\",\"\",\"\"]', `fields_values` = '[\"\",\"\",\"_html_editor_\",\"_content_type_\",\"\",\"\",\"\",\"\",\"\",\"\"]' WHERE id=1;
+
+UPDATE `talert_actions` SET `field4` = 'text/html', `field4_recovery` = 'text/html' WHERE id = 1;
+
-- ---------------------------------------------------------------------
-- Table `tmap`
-- ---------------------------------------------------------------------
@@ -1150,10 +1157,10 @@ ALTER TABLE titem MODIFY `source_data` int(10) unsigned;
INSERT INTO `tconfig` (`token`, `value`) VALUES ('big_operation_step_datos_purge', '100');
INSERT INTO `tconfig` (`token`, `value`) VALUES ('small_operation_step_datos_purge', '1000');
INSERT INTO `tconfig` (`token`, `value`) VALUES ('days_autodisable_deletion', '30');
-INSERT INTO `tconfig` (`token`, `value`) VALUES ('MR', 7);
+INSERT INTO `tconfig` (`token`, `value`) VALUES ('MR', 9);
UPDATE tconfig SET value = 'https://licensing.artica.es/pandoraupdate7/server.php' WHERE token='url_update_manager';
DELETE FROM `tconfig` WHERE `token` = 'current_package_enterprise';
-INSERT INTO `tconfig` (`token`, `value`) VALUES ('current_package_enterprise', '714');
+INSERT INTO `tconfig` (`token`, `value`) VALUES ('current_package_enterprise', '716');
-- ---------------------------------------------------------------------
-- Table `tplanned_downtime_agents`
@@ -1183,6 +1190,7 @@ ALTER TABLE tusuario ADD COLUMN `id_filter` int(10) UNSIGNED NULL DEFAULT NULL;
ALTER TABLE tusuario ADD CONSTRAINT `fk_id_filter` FOREIGN KEY (`id_filter`) REFERENCES tevent_filter(`id_filter`) ON DELETE SET NULL;
ALTER TABLE tusuario ADD COLUMN `session_time` int(10) signed NOT NULL default '0';
alter table tusuario add autorefresh_white_list text not null default '';
+ALTER TABLE tusuario ADD COLUMN `time_autorefresh` int(5) unsigned NOT NULL default '30';
-- ---------------------------------------------------------------------
-- Table `tagente_modulo`
@@ -1218,6 +1226,7 @@ ALTER TABLE tagente ADD `remote` tinyint(1) NOT NULL default 0;
ALTER TABLE tagente ADD COLUMN `cascade_protection_module` int(10) unsigned NOT NULL default '0';
ALTER TABLE tagente ADD COLUMN (alias varchar(600) not null default '');
ALTER TABLE tagente ADD `alias_as_name` int(2) unsigned default '0';
+ALTER TABLE tagente ADD COLUMN `safe_mode_module` int(10) unsigned NOT NULL default '0';
UPDATE tagente SET tagente.alias = tagente.nombre;
-- ---------------------------------------------------------------------
@@ -1231,6 +1240,9 @@ ALTER TABLE tlayout ADD `background_color` varchar(50) NOT NULL default '#FFF';
ALTER TABLE tlayout_data ADD `type_graph` varchar(50) NOT NULL default 'area';
ALTER TABLE tlayout_data ADD `label_position` varchar(50) NOT NULL default 'down';
ALTER TABLE tlayout_data ADD COLUMN `show_statistics` tinyint(2) NOT NULL default '0';
+ALTER TABLE tlayout_data ADD COLUMN `element_group` int(10) NOT NULL default '0';
+ALTER TABLE tlayout_data ADD COLUMN `id_layout_linked_weight` int(10) NOT NULL default '0';
+ALTER TABLE tlayout_data ADD COLUMN `show_on_top` tinyint(1) NOT NULL default '0';
-- ---------------------------------------------------------------------
-- Table `tagent_custom_fields`
@@ -1248,6 +1260,8 @@ UPDATE tagente_modulo SET cron_interval = '' WHERE cron_interval LIKE '% %';
-- Table `tgraph`
-- ---------------------------------------------------------------------
ALTER TABLE tgraph ADD COLUMN `percentil` int(4) unsigned default '0';
+ALTER TABLE tgraph ADD COLUMN `summatory_series` tinyint(1) UNSIGNED NOT NULL default '0';
+ALTER TABLE tgraph ADD COLUMN `average_series` tinyint(1) UNSIGNED NOT NULL default '0';
-- ---------------------------------------------------------------------
-- Table `tnetflow_filter`
@@ -1269,6 +1283,9 @@ UPDATE treport_custom_sql SET `sql` = 'select t1.alias as agent_n
-- ---------------------------------------------------------------------
ALTER TABLE treport_content ADD COLUMN `historical_db` tinyint(1) NOT NULL DEFAULT '0';
+ALTER TABLE treport_content ADD COLUMN `lapse_calc` tinyint(1) default '0';
+ALTER TABLE treport_content ADD COLUMN `lapse` int(11) default '300';
+ALTER TABLE treport_content ADD COLUMN `visual_format` tinyint(1) default '0';
-- ---------------------------------------------------------------------
-- Table `tmodule_relationship`
@@ -1295,6 +1312,7 @@ ALTER TABLE tmetaconsole_agent ADD COLUMN `cascade_protection_module` int(10) de
ALTER TABLE tmetaconsole_agent ADD COLUMN `transactional_agent` tinyint(1) NOT NULL default '0';
ALTER TABLE tmetaconsole_agent ADD COLUMN `alias` VARCHAR(600) not null DEFAULT '';
ALTER TABLE tmetaconsole_agent ADD COLUMN `alias_as_name` int(2) unsigned default '0';
+ALTER TABLE tmetaconsole_agent ADD COLUMN `safe_mode_module` int(10) unsigned NOT NULL default '0';
UPDATE `tmetaconsole_agent` SET tmetaconsole_agent.alias = tmetaconsole_agent.nombre;
-- ---------------------------------------------------------------------
@@ -1326,6 +1344,10 @@ SET @vv1 = (SELECT COUNT(*) FROM information_schema.tables WHERE table_schema =
IF @vv1>0 THEN
ALTER TABLE tbackup ADD COLUMN `filepath` varchar(512) NOT NULL DEFAULT "";
END IF;
+SET @vv2 = (SELECT COUNT(*) FROM information_schema.tables WHERE table_schema = DATABASE() AND table_name = 'tuser_task_scheduled');
+IF @vv2>0 THEN
+ ALTER TABLE tuser_task_scheduled MODIFY args TEXT NOT NULL;
+END IF;
END;
//
delimiter ;
@@ -1440,3 +1462,7 @@ INSERT INTO tmodule VALUES (8, 'Wux module');
INSERT INTO ttipo_modulo VALUES (25,'web_analysis', 8, 'Web analysis data', 'module-wux.png');
+-- ---------------------------------------------------------------------
+-- Table `tdashboard`
+-- ---------------------------------------------------------------------
+ALTER TABLE `tdashboard` ADD COLUMN `cells_slideshow` TINYINT(1) NOT NULL default 0;
diff --git a/pandora_console/general/header.php b/pandora_console/general/header.php
index 46e95a7026..2ac1e34df4 100644
--- a/pandora_console/general/header.php
+++ b/pandora_console/general/header.php
@@ -191,7 +191,7 @@ config_check();
$_GET['refr'] = null;
}
- $select = db_process_sql("SELECT autorefresh_white_list FROM tusuario WHERE id_user = '" . $config['id_user'] . "'");
+ $select = db_process_sql("SELECT autorefresh_white_list,time_autorefresh FROM tusuario WHERE id_user = '" . $config['id_user'] . "'");
$autorefresh_list = json_decode($select[0]['autorefresh_white_list']);
if ($autorefresh_list !== null && array_search($_GET['sec2'], $autorefresh_list) !== false) {
@@ -261,7 +261,13 @@ config_check();
if ($check_minor_release_available) {
if (users_is_admin($config['id_user'])) {
- set_pandora_error_for_header('There are one or more minor releases waiting for update', 'minor release/s available');
+
+ if($config['language'] == 'es'){
+ set_pandora_error_for_header('Hay una o mas revisiones menores en espera para ser actualizadas. '.__('Sobre actualización de revisión menor').' ', 'Revisión/es menor/es disponible/s');
+ }
+ else{
+ set_pandora_error_for_header('There are one or more minor releases waiting for update. '.__('About minor release update').' ', 'minor release/s available');
+ }
}
}
echo '
';
@@ -382,6 +388,12 @@ config_check();
$do_refresh = false;
}
}
+
+ $new_dashboard = get_parameter('new_dashboard',0);
+
+ if ($_GET['sec2'] == 'enterprise/dashboard/main_dashboard' && $new_dashboard) {
+ $do_refresh = false;
+ }
if ($do_refresh) {
?>
@@ -389,7 +401,15 @@ config_check();
$("#combo_refr").toggle ();
$("#combo_refr").css('padding-right', '9px');
href = $("a.autorefresh").attr ("href");
- $(document).attr ("location", href + "30");
+
+ var refresh = '';
+ $(document).attr ("location", href + refresh);
+
+
data[3][0] = __('Parent');
-$params = array();
-$params['return'] = true;
-$params['show_helptip'] = true;
-$params['input_name'] = 'id_parent';
-$params['print_hidden_input_idagent'] = true;
-$params['hidden_input_idagent_name'] = 'id_agent_parent';
-$params['hidden_input_idagent_value'] = $id_parent;
-$params['value'] = db_get_value ("alias","tagente","id_agente",$id_parent);
-$params['selectbox_id'] = 'cascade_protection_module';
-$params['javascript_is_function_select'] = true;
-$params['cascade_protection'] = true;
-
-$table->data[3][1] = ui_print_agent_autocomplete_input($params);
-
-$table->data[3][1] .= html_print_checkbox ("cascade_protection", 1, $cascade_protection, true).__('Cascade protection'). " " . ui_print_help_icon("cascade_protection", true);
-
-$table->data[3][1] .= " " . __('Module') . " " . html_print_select ($modules_values, "cascade_protection_module", $cascade_protection_module, "", "", 0, true);
-
$table->data[4][0] = __('Group');
$table->data[4][1] = html_print_select_groups(false, "AR", false, 'grupo', $grupo, '', '', 0, true);
$table->data[4][1] .= ' ';
@@ -320,52 +301,87 @@ $table->class = "databox filters";
$table->head = array ();
$table->style = array ();
$table->style[0] = 'font-weight: bold; ';
-$table->style[2] = 'font-weight: bold;';
+$table->style[4] = 'font-weight: bold;';
$table->data = array ();
// Custom ID
$table->data[0][0] = __('Custom ID');
$table->data[0][1] = html_print_input_text ('custom_id', $custom_id, '', 16, 255, true);
+$table->data[1][0] = __('Parent');
+$params = array();
+$params['return'] = true;
+$params['show_helptip'] = true;
+$params['input_name'] = 'id_parent';
+$params['print_hidden_input_idagent'] = true;
+$params['hidden_input_idagent_name'] = 'id_agent_parent';
+$params['hidden_input_idagent_value'] = $id_parent;
+$params['value'] = db_get_value ("alias","tagente","id_agente",$id_parent);
+$params['selectbox_id'] = 'cascade_protection_module';
+$params['javascript_is_function_select'] = true;
+$params['cascade_protection'] = true;
+
+$table->data[1][1] = ui_print_agent_autocomplete_input($params);
+$table->data[1][1] .= html_print_checkbox ("cascade_protection", 1, $cascade_protection, true).__('Cascade protection'). " " . ui_print_help_icon("cascade_protection", true);
+$table->data[1][1] .= " " . __('Module') . " " . html_print_select ($modules_values, "cascade_protection_module", $cascade_protection_module, "", "", 0, true);
+
+//safe operation mode
+if($id_agente){
+ $sql_modules = db_get_all_rows_sql("SELECT id_agente_modulo as id_module, nombre as name FROM tagente_modulo
+ WHERE id_agente = " . $id_agente);
+ $safe_mode_modules = array();
+ $safe_mode_modules[0] = __('Any');
+ foreach ($sql_modules as $m) {
+ $safe_mode_modules[$m['id_module']] = $m['name'];
+ }
+
+ $table->data[2][0] = __('Safe operation mode')
+ . ui_print_help_tip(__('This mode allow Pandora FMS to disable all modules
+ of this agent while the selected module is on CRITICAL status'), true);
+ $table->data[2][1] = html_print_checkbox('safe_mode', 1, $safe_mode, true);
+ $table->data[2][1] .= " " . __('Module') . " " . html_print_select ($safe_mode_modules, "safe_mode_module", $safe_mode_module, "", "", 0, true);
+}
+
+
// Learn mode / Normal mode
-$table->data[1][0] = __('Module definition') .
+$table->data[3][0] = __('Module definition') .
ui_print_help_icon("module_definition", true);
-$table->data[1][1] = __('Learning mode') . ' ' .
+$table->data[3][1] = __('Learning mode') . ' ' .
html_print_radio_button_extended ("modo", 1, '', $modo, false, 'show_modules_not_learning_mode_context_help();',
'style="margin-right: 40px;"', true);
-$table->data[1][1] .= __('Normal mode') . ' ' .
+$table->data[3][1] .= __('Normal mode') . ' ' .
html_print_radio_button_extended ("modo", 0, '', $modo, false, 'show_modules_not_learning_mode_context_help();',
'style="margin-right: 40px;"', true);
-$table->data[1][1] .= __('Autodisable mode') . ' ' .
+$table->data[3][1] .= __('Autodisable mode') . ' ' .
html_print_radio_button_extended ("modo", 2, '', $modo, false, 'show_modules_not_learning_mode_context_help();',
'style="margin-right: 40px;"', true);
// Status (Disabled / Enabled)
-$table->data[2][0] = __('Status');
-$table->data[2][1] = __('Disabled') . ' ' .
+$table->data[4][0] = __('Status');
+$table->data[4][1] = __('Disabled') . ' ' .
html_print_radio_button_extended ("disabled", 1, '', $disabled, false, '', 'style="margin-right: 40px;"', true);
-$table->data[2][1] .= __('Active') . ' ' .
+$table->data[4][1] .= __('Active') . ' ' .
html_print_radio_button_extended ("disabled", 0, '', $disabled, false, '', 'style="margin-right: 40px;"', true);
// Remote configuration
-$table->data[3][0] = __('Remote configuration');
+$table->data[5][0] = __('Remote configuration');
if (!$new_agent) {
- $table->data[3][1] = '' . __('Not available') . ' ';
+ $table->data[5][1] = '' . __('Not available') . ' ';
if (isset($filename)) {
if (file_exists ($filename['md5'])) {
- $table->data[3][1] = date ("F d Y H:i:s", fileatime ($filename['md5']));
+ $table->data[5][1] = date ("F d Y H:i:s", fileatime ($filename['md5']));
// Delete remote configuration
- $table->data[3][1] .= '';
- $table->data[3][1] .= html_print_image(
+ $table->data[5][1] .= html_print_image(
"images/cross.png", true,
array ('title' => __('Delete remote configuration file'), 'style' => 'vertical-align: middle;')).' ';
- $table->data[3][1] .= '' .
+ $table->data[5][1] .= '' .
ui_print_help_tip(
__('Delete this conf file implies that for restore you must reactive remote config in the local agent.'),
true);
@@ -373,7 +389,7 @@ if (!$new_agent) {
}
}
else
- $table->data[3][1] = '' . __('Not available') . ' ';
+ $table->data[5][1] = '' . __('Not available') . ' ';
$listIcons = gis_get_array_list_icons();
@@ -411,23 +427,23 @@ $table->data[0][3] = html_print_select($arraySelectIcon, "icon_path",
array("id" => "icon_warning", "style" => "display:".$display_icons.";"));
if ($config['activate_gis']) {
- $table->data[1][2] = __('Ignore new GIS data:');
- $table->data[1][3] = __('Yes') . ' ' .
+ $table->data[3][2] = __('Ignore new GIS data:');
+ $table->data[3][3] = __('Yes') . ' ' .
html_print_radio_button_extended ("update_gis_data", 0, '',
$update_gis_data, false, '', 'style="margin-right: 40px;"', true);
- $table->data[1][3] .= __('No') . ' ' .
+ $table->data[3][3] .= __('No') . ' ' .
html_print_radio_button_extended ("update_gis_data", 1, '',
$update_gis_data, false, '', 'style="margin-right: 40px;"', true);
}
-$table->data[2][2] = __('Url address');
-$table->data[2][3] = html_print_input_text ('url_description',
+$table->data[4][2] = __('Url address');
+$table->data[4][3] = html_print_input_text ('url_description',
$url_description, '', 45, 255, true);
-$table->data[3][2] = __('Quiet');
-$table->data[3][3] = ui_print_help_tip(
+$table->data[5][2] = __('Quiet');
+$table->data[5][3] = ui_print_help_tip(
__('The agent still runs but the alerts and events will be stop'), true);
-$table->data[3][3] .= html_print_checkbox('quiet', 1, $quiet, true);
+$table->data[5][3] .= html_print_checkbox('quiet', 1, $quiet, true);
ui_toggle(html_print_table ($table, true), __('Advanced options'));
unset($table);
@@ -582,6 +598,26 @@ ui_require_jquery_file('bgiframe');
$("#cascade_protection_module").attr("disabled", 'disabled');
}
});
+
+ var safe_mode_checked = $("#checkbox-safe_mode").is(":checked");
+ if (safe_mode_checked) {
+ $("#safe_mode_module").removeAttr("disabled");
+ }
+ else {
+ $("#safe_mode_module").attr("disabled", 'disabled');
+ }
+
+ $("#checkbox-safe_mode").change(function () {
+ var safe_mode_checked = $("#checkbox-safe_mode").is(":checked");
+
+ if (safe_mode_checked) {
+ $("#safe_mode_module").removeAttr("disabled");
+ }
+ else {
+ $("#safe_mode_module").val(0);
+ $("#safe_mode_module").attr("disabled", 'disabled');
+ }
+ });
paint_qrcode(
"data[0][1] = '';
$table->data[0][2] = ''.__('Modules').' ';
- $table->data[1][0] = html_print_select ($interfaces_list, 'id_snmp[]', 0, false, '', '', true, true, true, '', false, 'width:200px;');
+ $table->data[1][0] = html_print_select ($interfaces_list, 'id_snmp[]', 0, false, '', '', true, true, true, '', false, 'width:500px;');
$table->data[1][1] = html_print_image('images/darrowright.png', true);
$table->data[1][2] = html_print_select (array (), 'module[]', 0, false, '', 0, true, true, true, '', false, 'width:200px;');
$table->data[1][2] .= html_print_input_hidden('agent', $id_agent, true);
diff --git a/pandora_console/godmode/agentes/configurar_agente.php b/pandora_console/godmode/agentes/configurar_agente.php
index e2a264e6e0..1311620c34 100644
--- a/pandora_console/godmode/agentes/configurar_agente.php
+++ b/pandora_console/godmode/agentes/configurar_agente.php
@@ -135,6 +135,8 @@ $id_os = 9; // Windows
$custom_id = "";
$cascade_protection = 0;
$cascade_protection_modules = 0;
+$safe_mode = 0;
+$safe_mode_module = 0;
$icon_path = '';
$update_gis_data = 0;
$unit = "";
@@ -166,6 +168,8 @@ if ($create_agent) {
$custom_id = (string) get_parameter_post ("custom_id",'');
$cascade_protection = (int) get_parameter_post ("cascade_protection", 0);
$cascade_protection_module = (int) get_parameter_post("cascade_protection_module", 0);
+ $safe_mode = (int) get_parameter_post ("safe_mode", 0);
+ $safe_mode_module = (int) get_parameter_post ("safe_mode_module", 0);
$icon_path = (string) get_parameter_post ("icon_path",'');
$update_gis_data = (int) get_parameter_post("update_gis_data", 0);
$url_description = (string) get_parameter("url_description");
@@ -228,7 +232,7 @@ if ($create_agent) {
if ($id_agente !== false) {
// Create custom fields for this agent
foreach ($field_values as $key => $value) {
- db_process_sql_insert ('tagent_custom_data',
+ $update_custom = db_process_sql_insert ('tagent_custom_data',
array('id_field' => $key, 'id_agent' => $id_agente,
'description' => $value));
}
@@ -707,6 +711,7 @@ if ($update_agent) { // if modified some agent paramenter
$custom_id = (string) get_parameter_post ("custom_id", "");
$cascade_protection = (int) get_parameter_post ("cascade_protection", 0);
$cascade_protection_module = (int) get_parameter ("cascade_protection_module", 0);
+ $safe_mode_module = (int) get_parameter ("safe_mode_module", 0);
$icon_path = (string) get_parameter_post ("icon_path",'');
$update_gis_data = (int) get_parameter_post("update_gis_data", 0);
$url_description = (string) get_parameter("url_description");
@@ -730,13 +735,17 @@ if ($update_agent) { // if modified some agent paramenter
if ($old_value === false) {
// Create custom field if not exist
- db_process_sql_insert ('tagent_custom_data',
+ $update_custom = db_process_sql_insert ('tagent_custom_data',
array('id_field' => $key,'id_agent' => $id_agente, 'description' => $value));
}
else {
- db_process_sql_update ('tagent_custom_data',
+ $update_custom = db_process_sql_update ('tagent_custom_data',
array('description' => $value),
array('id_field' => $key,'id_agent' => $id_agente));
+
+ if($update_custom == 1){
+ $update_custom_result = 1;
+ }
}
}
@@ -782,7 +791,8 @@ if ($update_agent) { // if modified some agent paramenter
'update_gis_data' => $update_gis_data,
'url_address' => $url_description,
'url_address' => $url_description,
- 'quiet' => $quiet);
+ 'quiet' => $quiet,
+ 'safe_mode_module' => $safe_mode_module);
if ($config['metaconsole_agent_cache'] == 1) {
$values['update_module_count'] = 1; // Force an update of the agent cache.
@@ -793,7 +803,9 @@ if ($update_agent) { // if modified some agent paramenter
WHERE id_group = ".$group_old);
$result = db_process_sql_update ('tagente', $values, array ('id_agente' => $id_agente));
- if ($result == false) {
+
+
+ if ($result == false && $update_custom_result == false) {
ui_print_error_message(
__('There was a problem updating the agent'));
}
@@ -900,6 +912,8 @@ if ($id_agente) {
$update_gis_data = $agent["update_gis_data"];
$url_description = $agent["url_address"];
$quiet = $agent["quiet"];
+ $safe_mode_module = $agent["safe_mode_module"];
+ $safe_mode = ($safe_mode_module) ? 1 : 0;
}
$update_module = (bool) get_parameter ('update_module');
diff --git a/pandora_console/godmode/agentes/modificar_agente.php b/pandora_console/godmode/agentes/modificar_agente.php
index 090011dae9..1f8afb37f4 100644
--- a/pandora_console/godmode/agentes/modificar_agente.php
+++ b/pandora_console/godmode/agentes/modificar_agente.php
@@ -24,6 +24,7 @@ $sortField = get_parameter('sort_field');
$sort = get_parameter('sort', 'none');
$recursion = (bool) get_parameter('recursion',false);
$disabled = get_parameter('disabled', 0);
+$os = get_parameter('os', 0);
if ($ag_group == -1 )
$ag_group = (int) get_parameter ("ag_group", -1);
@@ -163,6 +164,20 @@ html_print_select($fields,"disabled",$disabled,'this.form.submit()');
echo "";
+echo " ";
+echo __('Operative System') . ' ';
+
+$pre_fields = db_get_all_rows_sql('select distinct(tagente.id_os),tconfig_os.description from tagente,tconfig_os where tagente.id_os = tconfig_os.id_os');
+$fields = array();
+
+foreach ($pre_fields as $key => $value) {
+ $fields[$value['id_os']] = $value['description'];
+}
+
+html_print_select($fields,"os",$os,'this.form.submit()','All',0);
+
+echo " ";
+
echo "";
echo __('Recursion') . ' ';
html_print_checkbox ("recursion", 1, $recursion, false, false, 'this.form.submit()');
@@ -171,6 +186,8 @@ echo " ";
echo __('Search') . ' ';
html_print_input_text ("search", $search, '', 12);
+echo ui_print_help_tip(__('Search filter by alias, name, description, IP address or custom fields content'), true);
+
echo " ";
echo " ";
echo "";
@@ -201,13 +218,13 @@ switch ($sortField) {
switch ($sort) {
case 'up':
$selectRemoteUp = $selected;
- $order = array('field' => 'remote ' . $order_collation,
+ $order = array('field' => 'remote ',
'field2' => 'nombre ' . $order_collation,
'order' => 'ASC');
break;
case 'down':
$selectRemoteDown = $selected;
- $order = array('field' => 'remote ' . $order_collation,
+ $order = array('field' => 'remote ',
'field2' => 'nombre ' . $order_collation,
'order' => 'DESC');
break;
@@ -296,20 +313,26 @@ if ($search != "") {
}else{
$search_sql = " AND ( nombre " . $order_collation . "
LIKE LOWER('%$search%') OR alias " . $order_collation . "
- LIKE LOWER('%$search%')) ";
+ LIKE LOWER('%$search%') OR comentarios " . $order_collation . " LIKE LOWER('%$search%')
+ OR EXISTS (SELECT * FROM tagent_custom_data
+ WHERE id_agent = id_agente AND description LIKE '%$search%'))";
}
}
if ($disabled == 1)
{
- $search_sql = " AND disabled = ". $disabled . $search_sql;
+ $search_sql .= " AND disabled = ". $disabled . $search_sql;
}
else {
if ($disabled == 0) {
- $search_sql = " AND disabled = 0" . $search_sql;
+ $search_sql .= " AND disabled = 0" . $search_sql;
}
}
+if($os != 0){
+ $search_sql .= " AND id_os = " . $os;
+}
+
// Show only selected groups
if ($ag_group > 0) {
diff --git a/pandora_console/godmode/agentes/module_manager.php b/pandora_console/godmode/agentes/module_manager.php
index 1fbf08bf80..b22bc0f626 100644
--- a/pandora_console/godmode/agentes/module_manager.php
+++ b/pandora_console/godmode/agentes/module_manager.php
@@ -45,10 +45,10 @@ echo " ";
echo __('Search') . ' ' .
html_print_input_text ('search_string', $search_string, '', 15, 255, true);
echo " ";
-echo "";
+echo " ";
html_print_submit_button (__('Filter'), 'filter', false, 'class="sub search"');
echo " ";
-echo " ";
+echo " ";
echo '';
// Check if there is at least one server of each type available to assign that
// kind of modules. If not, do not show server type in combo
@@ -119,7 +119,7 @@ if (($policy_page) || (isset($agent))) {
// Create module/type combo
echo ' ';
diff --git a/pandora_console/godmode/agentes/module_manager_editor.php b/pandora_console/godmode/agentes/module_manager_editor.php
index e2739aee29..921296545d 100644
--- a/pandora_console/godmode/agentes/module_manager_editor.php
+++ b/pandora_console/godmode/agentes/module_manager_editor.php
@@ -111,12 +111,12 @@ if (is_ajax ()) {
else
$snmp_community = (string) get_parameter ('snmp_community');
$snmp_version = get_parameter('snmp_version');
- $snmp3_auth_user = get_parameter('snmp3_auth_user');
+ $snmp3_auth_user = io_safe_output(get_parameter('snmp3_auth_user'));
$snmp3_security_level = get_parameter('snmp3_security_level');
$snmp3_auth_method = get_parameter('snmp3_auth_method');
- $snmp3_auth_pass = get_parameter('snmp3_auth_pass');
+ $snmp3_auth_pass = io_safe_output(get_parameter('snmp3_auth_pass'));
$snmp3_privacy_method = get_parameter('snmp3_privacy_method');
- $snmp3_privacy_pass = get_parameter('snmp3_privacy_pass');
+ $snmp3_privacy_pass = io_safe_output(get_parameter('snmp3_privacy_pass'));
$snmp_port = get_parameter('snmp_port');
$snmpwalk = get_snmpwalk($ip_target, $snmp_version, $snmp_community,
diff --git a/pandora_console/godmode/agentes/module_manager_editor_common.php b/pandora_console/godmode/agentes/module_manager_editor_common.php
index f66aa17296..473e36dfdc 100644
--- a/pandora_console/godmode/agentes/module_manager_editor_common.php
+++ b/pandora_console/godmode/agentes/module_manager_editor_common.php
@@ -291,7 +291,7 @@ if (modules_is_string_type($id_module_type) || $edit) {
$table_simple->data[4][1] .= ''.__('Inverse interval').' ';
$table_simple->data[4][1] .= html_print_checkbox ("warning_inverse", 1, $warning_inverse, true, $disabledBecauseInPolicy);
if (!modules_is_string_type($id_module_type) || $edit) {
- $table_simple->data[4][2] = ' ';
+ $table_simple->data[4][2] = ' ';
$table_simple->colspan[4][2] = 2;
$table_simple->rowspan[4][2] = 3;
}
@@ -590,8 +590,7 @@ $table_advanced->colspan[10][1] = 6;
if (isset($id_agente) && $moduletype == MODULE_DATA) {
$has_remote_conf = enterprise_hook('config_agents_has_remote_configuration',array($agent["id_agente"]));
if ($has_remote_conf) {
- $table_advanced->data[11][0] = __('Cron from') .
- ui_print_help_tip (__('If cron is set the module interval is ignored and the module runs on the specified date and time'), true);
+ $table_advanced->data[11][0] = __('Cron from') . ui_print_help_icon ('cron', true);
$table_advanced->data[11][1] = html_print_extended_select_for_cron ($hour_from, $minute_from, $mday_from, $month_from, $wday_from, true, $disabledBecauseInPolicy);
$table_advanced->colspan[11][1] = 6;
@@ -600,8 +599,7 @@ if (isset($id_agente) && $moduletype == MODULE_DATA) {
$table_advanced->colspan[12][1] = 6;
}
else {
- $table_advanced->data[11][0] = __('Cron from') .
- ui_print_help_tip (__('If cron is set the module interval is ignored and the module runs on the specified date and time'), true);
+ $table_advanced->data[11][0] = __('Cron from') . ui_print_help_icon ('cron', true);
$table_advanced->data[11][1] = html_print_extended_select_for_cron ($hour_from, $minute_from, $mday_from, $month_from, $wday_from, true, true);
$table_advanced->colspan[11][1] = 6;
@@ -611,8 +609,7 @@ if (isset($id_agente) && $moduletype == MODULE_DATA) {
}
}
else {
- $table_advanced->data[11][0] = __('Cron from') .
- ui_print_help_tip (__('If cron is set the module interval is ignored and the module runs on the specified date and time'), true);
+ $table_advanced->data[11][0] = __('Cron from') . ui_print_help_icon ('cron', true);
$table_advanced->data[11][1] = html_print_extended_select_for_cron ($hour_from, $minute_from, $mday_from, $month_from, $wday_from, true, $disabledBecauseInPolicy);
$table_advanced->colspan[11][1] = 6;
@@ -1323,8 +1320,8 @@ function paint_graph_status(min_w, max_w, min_c, max_c, inverse_w, inverse_c, er
.attr("id", "legend_normal")
.attr("x", 72)
.attr("y", -30)
- .attr("width", 10)
- .attr("height", 10)
+ .attr("width", '10px')
+ .attr("height", '10px')
.style("fill", "#82B92E");
//legend Warning text
@@ -1343,8 +1340,8 @@ function paint_graph_status(min_w, max_w, min_c, max_c, inverse_w, inverse_c, er
.attr("id", "legend_warning")
.attr("x", 168)
.attr("y", -30)
- .attr("width", 10)
- .attr("height", 10)
+ .attr("width", '10px')
+ .attr("height", '10px')
.style("fill", "#ffd731");
//legend Critical text
@@ -1363,8 +1360,8 @@ function paint_graph_status(min_w, max_w, min_c, max_c, inverse_w, inverse_c, er
.attr("id", "legend_critical")
.attr("x", 258)
.attr("y", -30)
- .attr("width", 10)
- .attr("height", 10)
+ .attr("width", '10px')
+ .attr("height", '10px')
.style("fill", "#fc4444");
//styles for number and axes
@@ -1382,8 +1379,8 @@ function paint_graph_status(min_w, max_w, min_c, max_c, inverse_w, inverse_c, er
.attr("id", "warning_rect")
.attr("x", 3)
.attr("y", 0)
- .attr("width", 300)
- .attr("height", 200)
+ .attr("width", '300px')
+ .attr("height", '200px')
.style("fill", "#82B92E");
//controls the inverse warning
diff --git a/pandora_console/godmode/agentes/module_manager_editor_network.php b/pandora_console/godmode/agentes/module_manager_editor_network.php
index 24d0105d42..b640243cfe 100644
--- a/pandora_console/godmode/agentes/module_manager_editor_network.php
+++ b/pandora_console/godmode/agentes/module_manager_editor_network.php
@@ -398,12 +398,12 @@ function snmpBrowserWindow () {
$('#text-target_ip').val($('#text-ip_target').val());
$('#text-community').val($('#text-snmp_community').val());
$('#snmp_browser_version').val($('#snmp_version').val());
- $('#snmp3_browser_auth_user').val($('#snmp3_auth_user').val());
+ $('#text-snmp3_browser_auth_user').val($('#text-snmp3_auth_user').val());
$('#snmp3_browser_security_level').val($('#snmp3_security_level').val());
$('#snmp3_browser_auth_method').val($('#snmp3_auth_method').val());
- $('#snmp3_browser_auth_pass').val($('#snmp3_auth_pass').val());
+ $('#password-snmp3_browser_auth_pass').val($('#password-snmp3_auth_pass').val());
$('#snmp3_browser_privacy_method').val($('#snmp3_privacy_method').val());
- $('#snmp3_browser_privacy_pass').val($('#snmp3_privacy_pass').val());
+ $('#password-snmp3_browser_privacy_pass').val($('#password-snmp3_privacy_pass').val());
$("#snmp_browser_container").show().dialog ({
title: '',
diff --git a/pandora_console/godmode/alerts/alert_commands.php b/pandora_console/godmode/alerts/alert_commands.php
index d4106e3460..10edc6bead 100644
--- a/pandora_console/godmode/alerts/alert_commands.php
+++ b/pandora_console/godmode/alerts/alert_commands.php
@@ -165,8 +165,26 @@ if (is_ajax ()) {
$rfield = $editor_type_chkbx;
$rfield .= html_print_textarea ('field'.$i.'_recovery_value', 1, 1, '', 'class="fields_recovery"', true);
}
+ elseif(preg_match ("/^_content_type_$/i", $field_value)){
+ $editor_type_chkbx = "";
+ $editor_type_chkbx .= __('Text/plain') . ui_print_help_tip (__("For sending emails only text plain"), true);
+ $editor_type_chkbx .= html_print_radio_button_extended ('field'.$i.'_value', 'text/plain', '', '', false, '', '', true);
+ $editor_type_chkbx .= " ";
+ $editor_type_chkbx .= __('Text/html') . " ";
+ $editor_type_chkbx .= html_print_radio_button_extended ('field'.$i.'_value', 'text/html', '', 'text/html', false, '', '', true);
+ $editor_type_chkbx .= "
";
+ $ffield = $editor_type_chkbx;
+
+ $editor_type_chkbx = "";
+ $editor_type_chkbx .= __('Text/plain') . ui_print_help_tip (__("For sending emails only text plain"), true);
+ $editor_type_chkbx .= html_print_radio_button_extended ('field'.$i.'_recovery_value', 'text/plain', '', '', false, '', '', true);
+ $editor_type_chkbx .= " ";
+ $editor_type_chkbx .= __('Text/html') . " ";
+ $editor_type_chkbx .= html_print_radio_button_extended ('field'.$i.'_recovery_value', 'text/html', '', 'text/html', false, '', '', true);
+ $editor_type_chkbx .= "
";
+ $rfield = $editor_type_chkbx;
// Select type
- else {
+ }else {
$fields_value_select = array();
$fv = explode(';', $field_value);
diff --git a/pandora_console/godmode/alerts/alert_list.list.php b/pandora_console/godmode/alerts/alert_list.list.php
index 4b57931a2c..8a2a7c6702 100644
--- a/pandora_console/godmode/alerts/alert_list.list.php
+++ b/pandora_console/godmode/alerts/alert_list.list.php
@@ -132,8 +132,8 @@ $form_filter .= "";
$form_filter .= "";
$form_filter .= "".__('Enabled / Disabled')." ";
$ed_list = array ();
-$ed_list[0] = __('Enable');
-$ed_list[1] = __('Disable');
+$ed_list[0] = __('Enabled');
+$ed_list[1] = __('Disabled');
$form_filter .= html_print_select ($ed_list, 'enabledisable', $enabledisable, '', __('All'), -1, true);
$form_filter .= " ".__('Standby')." ";
$sb_list = array ();
diff --git a/pandora_console/godmode/alerts/configure_alert_action.php b/pandora_console/godmode/alerts/configure_alert_action.php
index bef56c026c..990653f19f 100644
--- a/pandora_console/godmode/alerts/configure_alert_action.php
+++ b/pandora_console/godmode/alerts/configure_alert_action.php
@@ -305,8 +305,33 @@ $(document).ready (function () {
// Replace the old column with the new
$table_macros_field.replaceWith(field_row);
if (old_value != '' || old_recovery_value != '') {
- $("[name=field" + i + "_value]").val(old_value);
- $("[name=field" + i + "_recovery_value]").val(old_recovery_value);
+ var inputType = $("[name=field" + i + "_value]").attr('type')
+ if (inputType == 'radio') {
+ if(old_value == 'text/plain'){
+ if ($("[name=field" + i + "_value]").val() == 'text/plain') {
+ $("[name=field" + i + "_value]").attr('checked','checked');
+ }
+ }
+ else{
+ if($("[name=field" + i + "_value]").val() == 'text/html') {
+ $("[name=field" + i + "_value]").attr('checked','checked');
+ }
+ }
+ if(old_recovery_value == 'text/plain'){
+ if ($("[name=field" + i + "_recovery_value]").val() == 'text/plain') {
+ $("[name=field" + i + "_recovery_value]").attr('checked','checked');
+ }
+ }
+ else{
+ if ($("[name=field" + i + "_recovery_value]").val() == 'text/html') {
+ $("[name=field" + i + "_recovery_value]").attr('checked','checked');
+ }
+ }
+ }
+ else {
+ $("[name=field" + i + "_value]").val(old_value);
+ $("[name=field" + i + "_recovery_value]").val(old_recovery_value);
+ }
}
else {
$("[name=field" + i + "_value]")
diff --git a/pandora_console/godmode/events/custom_events.php b/pandora_console/godmode/events/custom_events.php
index 94e834bbf5..f60ba4e5a6 100644
--- a/pandora_console/godmode/events/custom_events.php
+++ b/pandora_console/godmode/events/custom_events.php
@@ -30,15 +30,15 @@ $default = (int) get_parameter('default', 0);
if ($default != 0) {
- $event_fields = io_safe_input('evento,id_agente,estado,timestamp');
- $fields_selected = explode (',', $event_fields);
+ //$event_fields = io_safe_input('evento,id_agente,estado,timestamp');
+ $fields_selected = explode (',', $config['event_fields']);
}
else if ($update != '') {
$fields_selected = (array)get_parameter('fields_selected');
if ($fields_selected[0] == '') {
- $event_fields = io_safe_input('evento,id_agente,estado,timestamp');
- $fields_selected = explode (',', $event_fields);
+ //$event_fields = io_safe_input('evento,id_agente,estado,timestamp');
+ $fields_selected = explode (',', $config['event_fields']);
}
else {
$event_fields = implode (',', $fields_selected);
@@ -130,7 +130,7 @@ $event = array();
echo '';
$table = new stdClass();
diff --git a/pandora_console/godmode/massive/massive_edit_modules.php b/pandora_console/godmode/massive/massive_edit_modules.php
index 933bb747c8..f37a39e10d 100755
--- a/pandora_console/godmode/massive/massive_edit_modules.php
+++ b/pandora_console/godmode/massive/massive_edit_modules.php
@@ -503,6 +503,10 @@ $table->data['edit3'][2] = __('SMNP community');
$table->data['edit3'][3] = html_print_input_text ('snmp_community', '',
'', 10, 100, true);
+$table->data['edit15'][2] = __('SNMP OID');
+$table->data['edit15'][3] = html_print_input_text ('snmp_oid', '',
+ '', 80, 80, true);
+
$target_ip_values = array();
$target_ip_values['auto'] = __('Auto');
$target_ip_values['force_pri'] = __('Force primary key');
@@ -736,7 +740,8 @@ $(document).ready (function () {
"tr#delete_table-edit11, " +
"tr#delete_table-edit12, " +
"tr#delete_table-edit13, " +
- "tr#delete_table-edit14").hide ();
+ "tr#delete_table-edit14, " +
+ "tr#delete_table-edit15").hide ();
var params = {
"page" : "operation/agentes/ver_agente",
@@ -800,7 +805,8 @@ $(document).ready (function () {
"tr#delete_table-edit11, " +
"tr#delete_table-edit12, " +
"tr#delete_table-edit13, " +
- "tr#delete_table-edit14").show ();
+ "tr#delete_table-edit14, " +
+ "tr#delete_table-edit15").show ();
}
function clean_lists() {
@@ -829,7 +835,8 @@ $(document).ready (function () {
"tr#delete_table-edit11, " +
"tr#delete_table-edit12, " +
"tr#delete_table-edit13, " +
- "tr#delete_table-edit14").hide ();
+ "tr#delete_table-edit14, " +
+ "tr#delete_table-edit15").hide ();
$('input[type=checkbox]').attr('checked', false);
$('input[type=checkbox]').attr('disabled', true);
@@ -877,7 +884,8 @@ $(document).ready (function () {
"tr#delete_table-edit11, " +
"tr#delete_table-edit12, " +
"tr#delete_table-edit13, " +
- "tr#delete_table-edit14").hide ();
+ "tr#delete_table-edit14, " +
+ "tr#delete_table-edit15").hide ();
}
}
}
@@ -919,7 +927,8 @@ $(document).ready (function () {
"tr#delete_table-edit11, " +
"tr#delete_table-edit12, " +
"tr#delete_table-edit13, " +
- "tr#delete_table-edit14").show ();
+ "tr#delete_table-edit14, " +
+ "tr#delete_table-edit15").show ();
}
else {
$(".select_agents_row_2").css('display', '');
@@ -942,7 +951,8 @@ $(document).ready (function () {
"tr#delete_table-edit11, " +
"tr#delete_table-edit12, " +
"tr#delete_table-edit13, " +
- "tr#delete_table-edit14").hide ();
+ "tr#delete_table-edit14, " +
+ "tr#delete_table-edit15").hide ();
}
}
}
@@ -1026,7 +1036,8 @@ $(document).ready (function () {
"tr#delete_table-edit11, " +
"tr#delete_table-edit12, " +
"tr#delete_table-edit13, " +
- "tr#delete_table-edit14").hide ();
+ "tr#delete_table-edit14, " +
+ "tr#delete_table-edit15").hide ();
jQuery.post ("ajax.php",
{"page" : "operation/agentes/ver_agente",
@@ -1158,8 +1169,8 @@ function process_manage_edit ($module_name, $agents_select = null, $module_statu
/* List of fields which can be updated */
$fields = array ('dynamic_interval', 'dynamic_max', 'dynamic_min', 'dynamic_two_tailed', 'min_warning', 'max_warning', 'str_warning',
'min_critical', 'max_critical', 'str_critical', 'min_ff_event',
- 'module_interval', 'disabled', 'post_process', 'unit_select',
- 'snmp_community', 'tcp_send', 'custom_string_1',
+ 'module_interval', 'disabled', 'post_process', 'unit',
+ 'snmp_community','snmp_oid','tcp_send', 'custom_string_1',
'plugin_parameter', 'custom_string_2', 'custom_string_3', 'min',
'max', 'id_module_group', 'plugin_user', 'plugin_pass',
'id_export', 'history_data', 'critical_inverse',
diff --git a/pandora_console/godmode/modules/manage_network_components.php b/pandora_console/godmode/modules/manage_network_components.php
index ec448f0cf4..e2f3cdab26 100644
--- a/pandora_console/godmode/modules/manage_network_components.php
+++ b/pandora_console/godmode/modules/manage_network_components.php
@@ -129,7 +129,7 @@ else {
}
$snmp_version = (string) get_parameter('snmp_version');
-$snmp3_auth_user = (string) get_parameter('snmp3_auth_user');
+$snmp3_auth_user = (string) io_safe_output(get_parameter('snmp3_auth_user'));
$snmp3_auth_pass = io_input_password((string) get_parameter('snmp3_auth_pass'));
$snmp3_auth_method = (string) get_parameter('snmp3_auth_method');
$snmp3_privacy_method = (string) get_parameter('snmp3_privacy_method');
diff --git a/pandora_console/godmode/modules/manage_network_components_form_common.php b/pandora_console/godmode/modules/manage_network_components_form_common.php
index 83b21b225b..b9cc96a468 100644
--- a/pandora_console/godmode/modules/manage_network_components_form_common.php
+++ b/pandora_console/godmode/modules/manage_network_components_form_common.php
@@ -473,8 +473,8 @@ $next_row++;
.attr("id", "legend_normal")
.attr("x", 72)
.attr("y", -30)
- .attr("width", 10)
- .attr("height", 10)
+ .attr("width", '10px')
+ .attr("height", '10px')
.style("fill", "#82B92E");
//legend Warning text
diff --git a/pandora_console/godmode/reporting/reporting_builder.item_editor.php b/pandora_console/godmode/reporting/reporting_builder.item_editor.php
index 2651751809..b1dffe8e5b 100755
--- a/pandora_console/godmode/reporting/reporting_builder.item_editor.php
+++ b/pandora_console/godmode/reporting/reporting_builder.item_editor.php
@@ -112,6 +112,10 @@ $netflow_filter = 0;
$max_values = 0;
$resolution = 0;
+$lapse_calc = 0;
+$lapse = 300;
+$visual_format = 0;
+
//Others
$filter_search = "";
@@ -148,6 +152,7 @@ switch ($action) {
case 'network_interfaces_report':
case 'availability':
case 'event_report_log':
+ case 'increment':
case 'availability_graph':
case 'agent_module':
$get_data_editor = true;
@@ -195,12 +200,6 @@ switch ($action) {
$name = $item['name'];
switch ($type) {
- case 'avg_value':
- $period = $item['period'];
- $description = $item['description'];
- $idAgentModule = $item['id_agent_module'];
- $idAgent = db_get_value_filter('id_agente', 'tagente_modulo', array('id_agente_modulo' => $idAgentModule));
- break;
case 'event_report_log':
$period = $item['period'];
$description = $item['description'];
@@ -282,6 +281,13 @@ switch ($action) {
$idAgent = db_get_value_filter('id_agente', 'tagente_modulo', array('id_agente_modulo' => $idAgentModule));
break;
+ case 'increment':
+ $description = $item['description'];
+ $idAgentModule = $item['id_agent_module'];
+ $idAgent = db_get_value_filter('id_agente', 'tagente_modulo', array('id_agente_modulo' => $idAgentModule));
+ $period = $item['period'];
+ break;
+
case 'SLA_services':
$description = $item['description'];
$period = $item['period'];
@@ -312,6 +318,9 @@ switch ($action) {
$idAgent = db_get_value_filter('id_agente', 'tagente_modulo', array('id_agente_modulo' => $idAgentModule));
$idAgentModule = $item['id_agent_module'];
$period = $item['period'];
+ $lapse = $item['lapse'];
+ $lapse_calc = $item['lapse_calc'];
+ $visual_format = $item['visual_format'];
break;
case 'max_value':
$description = $item['description'];
@@ -319,6 +328,9 @@ switch ($action) {
$idAgent = db_get_value_filter('id_agente', 'tagente_modulo', array('id_agente_modulo' => $idAgentModule));
$idAgentModule = $item['id_agent_module'];
$period = $item['period'];
+ $lapse = $item['lapse'];
+ $lapse_calc = $item['lapse_calc'];
+ $visual_format = $item['visual_format'];
break;
case 'min_value':
$description = $item['description'];
@@ -326,6 +338,9 @@ switch ($action) {
$idAgent = db_get_value_filter('id_agente', 'tagente_modulo', array('id_agente_modulo' => $idAgentModule));
$idAgentModule = $item['id_agent_module'];
$period = $item['period'];
+ $lapse = $item['lapse'];
+ $lapse_calc = $item['lapse_calc'];
+ $visual_format = $item['visual_format'];
break;
case 'sumatory':
$description = $item['description'];
@@ -593,6 +608,7 @@ switch ($action) {
case 'MTTR':
case 'simple_baseline_graph':
case 'event_report_log':
+ case 'increment':
$label = (isset($style['label'])) ? $style['label'] : '';
break;
default:
@@ -1580,6 +1596,78 @@ You can of course remove the warnings, that's why we include the source and do n
?>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ ';
+ html_print_radio_button ('visual_format', 1, '', $visual_format_table,'',!$lapse_calc);
+ echo (' ');
+ echo __('Graph only').' ';
+ html_print_radio_button ('visual_format', 2, '', $visual_format_graph,'',!$lapse_calc);
+ echo (' ');
+ echo __('Graph and table').' ';
+ html_print_radio_button ('visual_format', 3, '', $visual_format_both,'',!$lapse_calc);
+
+ ?>
+
+
+
+
+
@@ -2211,6 +2299,19 @@ $(document).ready (function () {
}
});
+ $("#checkbox-lapse_calc").change(function () {
+
+ if($(this).is(":checked")){
+ $( "#lapse_select" ).prop( "disabled", false );
+ $("[name=visual_format]").prop( "disabled", false );
+ }
+ else{
+ $( "#lapse_select" ).prop( "disabled", true );
+ $("[name=visual_format]").prop( "disabled", true );
+ }
+
+ });
+
});
function create_custom_graph() {
@@ -2692,6 +2793,9 @@ function chooseType() {
$("#row_show_in_two_columns").hide();
$("#row_show_in_same_row").hide();
$("#row_historical_db_check").hide();
+ $("#row_lapse_calc").hide();
+ $("#row_lapse").hide();
+ $("#row_visual_format").hide();
$("#row_show_in_landscape").hide();
$('#row_hide_notinit_agents').hide();
$("#row_module_group").hide();
@@ -2763,6 +2867,13 @@ function chooseType() {
$("#row_source").show();
$("#row_historical_db_check").hide();
break;
+
+ case 'increment':
+ $("#row_description").show();
+ $("#row_agent").show();
+ $("#row_module").show();
+ $("#row_period").show();
+ break;
case 'simple_graph':
$("#row_time_compare_overlapped").show();
@@ -2884,6 +2995,9 @@ function chooseType() {
$("#row_module").show();
$("#row_period").show();
$("#row_show_in_two_columns").show();
+ $("#row_lapse_calc").show();
+ $("#row_lapse").show();
+ $("#row_visual_format").show();
$("#row_historical_db_check").hide();
break;
@@ -2893,6 +3007,9 @@ function chooseType() {
$("#row_module").show();
$("#row_period").show();
$("#row_show_in_two_columns").show();
+ $("#row_lapse_calc").show();
+ $("#row_lapse").show();
+ $("#row_visual_format").show();
$("#row_historical_db_check").hide();
break;
@@ -2902,6 +3019,9 @@ function chooseType() {
$("#row_module").show();
$("#row_period").show();
$("#row_show_in_two_columns").show();
+ $("#row_lapse_calc").show();
+ $("#row_lapse").show();
+ $("#row_visual_format").show();
$("#row_historical_db_check").hide();
break;
diff --git a/pandora_console/godmode/reporting/reporting_builder.php b/pandora_console/godmode/reporting/reporting_builder.php
index f2f780b911..e52994b810 100755
--- a/pandora_console/godmode/reporting/reporting_builder.php
+++ b/pandora_console/godmode/reporting/reporting_builder.php
@@ -1069,6 +1069,15 @@ switch ($action) {
$values['period'] = get_parameter('period');
$good_format = true;
break;
+ case 'min_value':
+ case 'max_value':
+ case 'avg_value':
+ $values['period'] = get_parameter('period');
+ $values['lapse_calc'] = get_parameter('lapse_calc');
+ $values['lapse'] = get_parameter('lapse');
+ $values['visual_format'] = get_parameter('visual_format');
+ $good_format = true;
+ break;
default:
$values['period'] = get_parameter('period');
$values['top_n'] = get_parameter('radiobutton_max_min_avg',0);
@@ -1404,6 +1413,15 @@ switch ($action) {
$values['period'] = get_parameter('period');
$good_format = true;
break;
+ case 'min_value':
+ case 'max_value':
+ case 'avg_value':
+ $values['period'] = get_parameter('period');
+ $values['lapse_calc'] = get_parameter('lapse_calc');
+ $values['lapse'] = get_parameter('lapse');
+ $values['visual_format'] = get_parameter('visual_format');
+ $good_format = true;
+ break;
default:
$values['period'] = get_parameter('period');
$values['top_n'] = get_parameter('radiobutton_max_min_avg',0);
diff --git a/pandora_console/godmode/reporting/visual_console_builder.data.php b/pandora_console/godmode/reporting/visual_console_builder.data.php
index 056d44e61d..8d9edddd88 100644
--- a/pandora_console/godmode/reporting/visual_console_builder.data.php
+++ b/pandora_console/godmode/reporting/visual_console_builder.data.php
@@ -201,7 +201,23 @@ echo "";
diff --git a/pandora_console/godmode/update_manager/update_manager.offline.php b/pandora_console/godmode/update_manager/update_manager.offline.php
index 2079678fa8..afad03cc2c 100644
--- a/pandora_console/godmode/update_manager/update_manager.offline.php
+++ b/pandora_console/godmode/update_manager/update_manager.offline.php
@@ -58,7 +58,14 @@ $baseurl = ui_get_full_url(false, false, false, false);
var text1_mr_file = "\n";
var text2_mr_file = "\n";
var text3_mr_file = "\n";
- var text4_mr_file = "\n";
+ var text4_mr_file = "'.__('About minor release update').' ';
+ }
+ else{
+ echo __(' to this process').''.__('About minor release update').' ';
+ }
+ ?>";
var text1_package_file = "\n";
var text2_package_file = "\n";
var applying_mr = "\n";
diff --git a/pandora_console/godmode/users/configure_user.php b/pandora_console/godmode/users/configure_user.php
index ef2e4f0f9c..cdd4157fca 100644
--- a/pandora_console/godmode/users/configure_user.php
+++ b/pandora_console/godmode/users/configure_user.php
@@ -236,6 +236,8 @@ if ($create_user) {
case "postgresql":
$result = create_user($id, $password_new, $values);
if ($result) {
+ db_process_sql_insert ('tsesion', array('id_sesion' => '','id_usuario' => $id,'ip_origen' => $_SERVER['REMOTE_ADDR'],'accion' => 'Password change',
+ 'descripcion' => 'Access password updated','fecha' => date("Y-m-d H:i:s"),'utimestamp' => time()));
$res = save_pass_history($id, $password_new);
}
break;
@@ -334,6 +336,8 @@ if ($update_user) {
else {
$res2 = update_user_password ($id, $password_new);
if ($res2) {
+ db_process_sql_insert ('tsesion', array('id_sesion' => '','id_usuario' => $id,'ip_origen' => $_SERVER['REMOTE_ADDR'],'accion' => 'Password change',
+ 'descripcion' => 'Access password updated','fecha' => date("Y-m-d H:i:s"),'utimestamp' => time()));
$res3 = save_pass_history($id, $password_new);
}
ui_print_result_message ($res1 || $res2,
@@ -345,6 +349,8 @@ if ($update_user) {
$res2 = update_user_password ($id, $password_new);
if ($res2) {
$res3 = save_pass_history($id, $password_new);
+ db_process_sql_insert ('tsesion', array('id_sesion' => '','id_usuario' => $id,'ip_origen' => $_SERVER['REMOTE_ADDR'],'accion' => 'Password change',
+ 'descripcion' => 'Access password updated','fecha' => date("Y-m-d H:i:s"),'utimestamp' => time()));
}
ui_print_result_message ($res1 || $res2,
__('User info successfully updated'),
diff --git a/pandora_console/images/console/signes/barras-no.png b/pandora_console/images/console/signes/barras-no.png
new file mode 100644
index 0000000000..c4545405e0
Binary files /dev/null and b/pandora_console/images/console/signes/barras-no.png differ
diff --git a/pandora_console/images/console/signes/barras.png b/pandora_console/images/console/signes/barras.png
new file mode 100644
index 0000000000..be81fb2212
Binary files /dev/null and b/pandora_console/images/console/signes/barras.png differ
diff --git a/pandora_console/images/console/signes/circular-progress-bar-interior.png b/pandora_console/images/console/signes/circular-progress-bar-interior.png
new file mode 100644
index 0000000000..221c626f25
Binary files /dev/null and b/pandora_console/images/console/signes/circular-progress-bar-interior.png differ
diff --git a/pandora_console/images/console/signes/circular-progress-bar.png b/pandora_console/images/console/signes/circular-progress-bar.png
new file mode 100644
index 0000000000..640a8050b4
Binary files /dev/null and b/pandora_console/images/console/signes/circular-progress-bar.png differ
diff --git a/pandora_console/images/console/signes/donut-graph.png b/pandora_console/images/console/signes/donut-graph.png
new file mode 100644
index 0000000000..57a2d3eb2b
Binary files /dev/null and b/pandora_console/images/console/signes/donut-graph.png differ
diff --git a/pandora_console/images/console/signes/wrong_donut_graph.png b/pandora_console/images/console/signes/wrong_donut_graph.png
new file mode 100644
index 0000000000..8005a9ac46
Binary files /dev/null and b/pandora_console/images/console/signes/wrong_donut_graph.png differ
diff --git a/pandora_console/images/groups_small/application_osx_terminal.bad.png b/pandora_console/images/groups_small/application_osx_terminal.bad.png
index ccc8f3f04d..3862246d9e 100644
Binary files a/pandora_console/images/groups_small/application_osx_terminal.bad.png and b/pandora_console/images/groups_small/application_osx_terminal.bad.png differ
diff --git a/pandora_console/images/groups_small/application_osx_terminal.default.png b/pandora_console/images/groups_small/application_osx_terminal.default.png
index 85f0016ce2..7ddaec3117 100644
Binary files a/pandora_console/images/groups_small/application_osx_terminal.default.png and b/pandora_console/images/groups_small/application_osx_terminal.default.png differ
diff --git a/pandora_console/images/groups_small/application_osx_terminal.ok.png b/pandora_console/images/groups_small/application_osx_terminal.ok.png
index 0678cb09a1..1da9e887bf 100644
Binary files a/pandora_console/images/groups_small/application_osx_terminal.ok.png and b/pandora_console/images/groups_small/application_osx_terminal.ok.png differ
diff --git a/pandora_console/images/groups_small/application_osx_terminal.warning.png b/pandora_console/images/groups_small/application_osx_terminal.warning.png
index e95f210a5f..41fcb8eaf0 100644
Binary files a/pandora_console/images/groups_small/application_osx_terminal.warning.png and b/pandora_console/images/groups_small/application_osx_terminal.warning.png differ
diff --git a/pandora_console/images/groups_small/bricks.bad.png b/pandora_console/images/groups_small/bricks.bad.png
index 0a0cd5459f..5f22537353 100644
Binary files a/pandora_console/images/groups_small/bricks.bad.png and b/pandora_console/images/groups_small/bricks.bad.png differ
diff --git a/pandora_console/images/groups_small/bricks.default.png b/pandora_console/images/groups_small/bricks.default.png
index 14d8bab5ca..1fccda728d 100644
Binary files a/pandora_console/images/groups_small/bricks.default.png and b/pandora_console/images/groups_small/bricks.default.png differ
diff --git a/pandora_console/images/groups_small/bricks.ok.png b/pandora_console/images/groups_small/bricks.ok.png
index 931d1a389c..304efe93df 100644
Binary files a/pandora_console/images/groups_small/bricks.ok.png and b/pandora_console/images/groups_small/bricks.ok.png differ
diff --git a/pandora_console/images/groups_small/bricks.png b/pandora_console/images/groups_small/bricks.png
index c234efafb6..d197f3fd56 100644
Binary files a/pandora_console/images/groups_small/bricks.png and b/pandora_console/images/groups_small/bricks.png differ
diff --git a/pandora_console/images/groups_small/bricks.warning.png b/pandora_console/images/groups_small/bricks.warning.png
index bbfeb0ce3f..0345d612f3 100644
Binary files a/pandora_console/images/groups_small/bricks.warning.png and b/pandora_console/images/groups_small/bricks.warning.png differ
diff --git a/pandora_console/images/groups_small/chart_organisation.bad.png b/pandora_console/images/groups_small/chart_organisation.bad.png
index 410cd5116c..51771a4664 100644
Binary files a/pandora_console/images/groups_small/chart_organisation.bad.png and b/pandora_console/images/groups_small/chart_organisation.bad.png differ
diff --git a/pandora_console/images/groups_small/chart_organisation.default.png b/pandora_console/images/groups_small/chart_organisation.default.png
index 53619a608b..597c229fa0 100644
Binary files a/pandora_console/images/groups_small/chart_organisation.default.png and b/pandora_console/images/groups_small/chart_organisation.default.png differ
diff --git a/pandora_console/images/groups_small/chart_organisation.ok.png b/pandora_console/images/groups_small/chart_organisation.ok.png
index ca7f04061b..5d34f43765 100644
Binary files a/pandora_console/images/groups_small/chart_organisation.ok.png and b/pandora_console/images/groups_small/chart_organisation.ok.png differ
diff --git a/pandora_console/images/groups_small/chart_organisation.warning.png b/pandora_console/images/groups_small/chart_organisation.warning.png
index c9ba529187..7dac5502fc 100644
Binary files a/pandora_console/images/groups_small/chart_organisation.warning.png and b/pandora_console/images/groups_small/chart_organisation.warning.png differ
diff --git a/pandora_console/images/groups_small/clock.bad.png b/pandora_console/images/groups_small/clock.bad.png
index f281439c87..c1241ce275 100644
Binary files a/pandora_console/images/groups_small/clock.bad.png and b/pandora_console/images/groups_small/clock.bad.png differ
diff --git a/pandora_console/images/groups_small/clock.default.png b/pandora_console/images/groups_small/clock.default.png
index 2b7a58aa20..b8d58d6dec 100644
Binary files a/pandora_console/images/groups_small/clock.default.png and b/pandora_console/images/groups_small/clock.default.png differ
diff --git a/pandora_console/images/groups_small/clock.ok.png b/pandora_console/images/groups_small/clock.ok.png
index a3cb173d9e..1ab3c8383f 100644
Binary files a/pandora_console/images/groups_small/clock.ok.png and b/pandora_console/images/groups_small/clock.ok.png differ
diff --git a/pandora_console/images/groups_small/clock.warning.png b/pandora_console/images/groups_small/clock.warning.png
index 20880b31df..a06ceda51f 100644
Binary files a/pandora_console/images/groups_small/clock.warning.png and b/pandora_console/images/groups_small/clock.warning.png differ
diff --git a/pandora_console/images/groups_small/drive.network.bad.png b/pandora_console/images/groups_small/drive.network.bad.png
new file mode 100644
index 0000000000..886ca44d2b
Binary files /dev/null and b/pandora_console/images/groups_small/drive.network.bad.png differ
diff --git a/pandora_console/images/groups_small/drive_network.default.png b/pandora_console/images/groups_small/drive_network.default.png
index 428b2eb2a4..2fd2519029 100644
Binary files a/pandora_console/images/groups_small/drive_network.default.png and b/pandora_console/images/groups_small/drive_network.default.png differ
diff --git a/pandora_console/images/groups_small/drive_network.ok.png b/pandora_console/images/groups_small/drive_network.ok.png
index dbe58f007c..c84acaa7f4 100644
Binary files a/pandora_console/images/groups_small/drive_network.ok.png and b/pandora_console/images/groups_small/drive_network.ok.png differ
diff --git a/pandora_console/images/groups_small/drive_network.warning.png b/pandora_console/images/groups_small/drive_network.warning.png
index 0dbdd4b2a5..3abda093e3 100644
Binary files a/pandora_console/images/groups_small/drive_network.warning.png and b/pandora_console/images/groups_small/drive_network.warning.png differ
diff --git a/pandora_console/images/groups_small/email.bad.png b/pandora_console/images/groups_small/email.bad.png
index 064222d63e..78a2ed0913 100644
Binary files a/pandora_console/images/groups_small/email.bad.png and b/pandora_console/images/groups_small/email.bad.png differ
diff --git a/pandora_console/images/groups_small/email.default.png b/pandora_console/images/groups_small/email.default.png
index 1486cd82a0..e07d9c3022 100644
Binary files a/pandora_console/images/groups_small/email.default.png and b/pandora_console/images/groups_small/email.default.png differ
diff --git a/pandora_console/images/groups_small/email.ok.png b/pandora_console/images/groups_small/email.ok.png
index 681fc2ddfa..5d5fca4f0c 100644
Binary files a/pandora_console/images/groups_small/email.ok.png and b/pandora_console/images/groups_small/email.ok.png differ
diff --git a/pandora_console/images/groups_small/email.warning.png b/pandora_console/images/groups_small/email.warning.png
index b08c99d7c1..10662435e1 100644
Binary files a/pandora_console/images/groups_small/email.warning.png and b/pandora_console/images/groups_small/email.warning.png differ
diff --git a/pandora_console/images/groups_small/eye.bad.png b/pandora_console/images/groups_small/eye.bad.png
index f8191a1b17..9c08baf0a3 100644
Binary files a/pandora_console/images/groups_small/eye.bad.png and b/pandora_console/images/groups_small/eye.bad.png differ
diff --git a/pandora_console/images/groups_small/eye.default.png b/pandora_console/images/groups_small/eye.default.png
index cd852b7502..a8dc65e8be 100644
Binary files a/pandora_console/images/groups_small/eye.default.png and b/pandora_console/images/groups_small/eye.default.png differ
diff --git a/pandora_console/images/groups_small/eye.ok.png b/pandora_console/images/groups_small/eye.ok.png
index 0da4304f71..abf8578709 100644
Binary files a/pandora_console/images/groups_small/eye.ok.png and b/pandora_console/images/groups_small/eye.ok.png differ
diff --git a/pandora_console/images/groups_small/eye.warning.png b/pandora_console/images/groups_small/eye.warning.png
index 65a5722201..2bd3af45f8 100644
Binary files a/pandora_console/images/groups_small/eye.warning.png and b/pandora_console/images/groups_small/eye.warning.png differ
diff --git a/pandora_console/images/groups_small/heart.bad.png b/pandora_console/images/groups_small/heart.bad.png
index ff3008fcc4..f9da31b2c5 100644
Binary files a/pandora_console/images/groups_small/heart.bad.png and b/pandora_console/images/groups_small/heart.bad.png differ
diff --git a/pandora_console/images/groups_small/heart.default.png b/pandora_console/images/groups_small/heart.default.png
index a7cfff0cc3..73a101809a 100644
Binary files a/pandora_console/images/groups_small/heart.default.png and b/pandora_console/images/groups_small/heart.default.png differ
diff --git a/pandora_console/images/groups_small/heart.ok.png b/pandora_console/images/groups_small/heart.ok.png
index 0f0798523d..0b2b4e0653 100644
Binary files a/pandora_console/images/groups_small/heart.ok.png and b/pandora_console/images/groups_small/heart.ok.png differ
diff --git a/pandora_console/images/groups_small/heart.warning.png b/pandora_console/images/groups_small/heart.warning.png
index 66b8583393..f97cc1251b 100644
Binary files a/pandora_console/images/groups_small/heart.warning.png and b/pandora_console/images/groups_small/heart.warning.png differ
diff --git a/pandora_console/images/groups_small/house.bad.png b/pandora_console/images/groups_small/house.bad.png
index 815f719f7c..a7dcd9b6fd 100644
Binary files a/pandora_console/images/groups_small/house.bad.png and b/pandora_console/images/groups_small/house.bad.png differ
diff --git a/pandora_console/images/groups_small/house.default.png b/pandora_console/images/groups_small/house.default.png
index fac912b267..07b9842b2d 100644
Binary files a/pandora_console/images/groups_small/house.default.png and b/pandora_console/images/groups_small/house.default.png differ
diff --git a/pandora_console/images/groups_small/house.ok.png b/pandora_console/images/groups_small/house.ok.png
index c3a2e9053e..9190bfd075 100644
Binary files a/pandora_console/images/groups_small/house.ok.png and b/pandora_console/images/groups_small/house.ok.png differ
diff --git a/pandora_console/images/groups_small/house.warning.png b/pandora_console/images/groups_small/house.warning.png
index cf76552f5f..27ba33bca9 100644
Binary files a/pandora_console/images/groups_small/house.warning.png and b/pandora_console/images/groups_small/house.warning.png differ
diff --git a/pandora_console/images/groups_small/images.bad.png b/pandora_console/images/groups_small/images.bad.png
index 454b36e1d5..cdcb423d83 100644
Binary files a/pandora_console/images/groups_small/images.bad.png and b/pandora_console/images/groups_small/images.bad.png differ
diff --git a/pandora_console/images/groups_small/images.default.png b/pandora_console/images/groups_small/images.default.png
index 501a97fe27..04b186e57f 100644
Binary files a/pandora_console/images/groups_small/images.default.png and b/pandora_console/images/groups_small/images.default.png differ
diff --git a/pandora_console/images/groups_small/images.ok.png b/pandora_console/images/groups_small/images.ok.png
index 530af4f4c4..0936d2f2e0 100644
Binary files a/pandora_console/images/groups_small/images.ok.png and b/pandora_console/images/groups_small/images.ok.png differ
diff --git a/pandora_console/images/groups_small/images.warning.png b/pandora_console/images/groups_small/images.warning.png
index 46cd29d989..f735403dc8 100644
Binary files a/pandora_console/images/groups_small/images.warning.png and b/pandora_console/images/groups_small/images.warning.png differ
diff --git a/pandora_console/images/groups_small/lightning.bad.png b/pandora_console/images/groups_small/lightning.bad.png
index a6ec10a2bc..dc4de71df3 100644
Binary files a/pandora_console/images/groups_small/lightning.bad.png and b/pandora_console/images/groups_small/lightning.bad.png differ
diff --git a/pandora_console/images/groups_small/lightning.default.png b/pandora_console/images/groups_small/lightning.default.png
index 47447d48be..b50d496caa 100644
Binary files a/pandora_console/images/groups_small/lightning.default.png and b/pandora_console/images/groups_small/lightning.default.png differ
diff --git a/pandora_console/images/groups_small/lightning.ok.png b/pandora_console/images/groups_small/lightning.ok.png
index 7dee1c4a81..7b134afecf 100644
Binary files a/pandora_console/images/groups_small/lightning.ok.png and b/pandora_console/images/groups_small/lightning.ok.png differ
diff --git a/pandora_console/images/groups_small/lightning.warning.png b/pandora_console/images/groups_small/lightning.warning.png
index 020cfe9ac7..3182a8aa72 100644
Binary files a/pandora_console/images/groups_small/lightning.warning.png and b/pandora_console/images/groups_small/lightning.warning.png differ
diff --git a/pandora_console/images/groups_small/lock.bad.png b/pandora_console/images/groups_small/lock.bad.png
index 29fecde26d..0f25d5361b 100644
Binary files a/pandora_console/images/groups_small/lock.bad.png and b/pandora_console/images/groups_small/lock.bad.png differ
diff --git a/pandora_console/images/groups_small/lock.default.png b/pandora_console/images/groups_small/lock.default.png
index d462751473..b3958972ed 100644
Binary files a/pandora_console/images/groups_small/lock.default.png and b/pandora_console/images/groups_small/lock.default.png differ
diff --git a/pandora_console/images/groups_small/lock.ok.png b/pandora_console/images/groups_small/lock.ok.png
index fb9a8749bd..06e639a7bf 100644
Binary files a/pandora_console/images/groups_small/lock.ok.png and b/pandora_console/images/groups_small/lock.ok.png differ
diff --git a/pandora_console/images/groups_small/lock.warning.png b/pandora_console/images/groups_small/lock.warning.png
index bfb2826d31..9cd24bc69b 100644
Binary files a/pandora_console/images/groups_small/lock.warning.png and b/pandora_console/images/groups_small/lock.warning.png differ
diff --git a/pandora_console/images/groups_small/network.bad.png b/pandora_console/images/groups_small/network.bad.png
index f3293d77ac..fec08fa66b 100644
Binary files a/pandora_console/images/groups_small/network.bad.png and b/pandora_console/images/groups_small/network.bad.png differ
diff --git a/pandora_console/images/groups_small/network.default.png b/pandora_console/images/groups_small/network.default.png
index c330e90893..6b2107017f 100644
Binary files a/pandora_console/images/groups_small/network.default.png and b/pandora_console/images/groups_small/network.default.png differ
diff --git a/pandora_console/images/groups_small/network.ok.png b/pandora_console/images/groups_small/network.ok.png
index edd8831666..ce767cf880 100644
Binary files a/pandora_console/images/groups_small/network.ok.png and b/pandora_console/images/groups_small/network.ok.png differ
diff --git a/pandora_console/images/groups_small/network.warning.png b/pandora_console/images/groups_small/network.warning.png
index 6ddd996e56..66a55e22b4 100644
Binary files a/pandora_console/images/groups_small/network.warning.png and b/pandora_console/images/groups_small/network.warning.png differ
diff --git a/pandora_console/images/groups_small/old/application_osx_terminal.bad.png b/pandora_console/images/groups_small/old/application_osx_terminal.bad.png
new file mode 100644
index 0000000000..ccc8f3f04d
Binary files /dev/null and b/pandora_console/images/groups_small/old/application_osx_terminal.bad.png differ
diff --git a/pandora_console/images/groups_small/old/application_osx_terminal.default.png b/pandora_console/images/groups_small/old/application_osx_terminal.default.png
new file mode 100644
index 0000000000..85f0016ce2
Binary files /dev/null and b/pandora_console/images/groups_small/old/application_osx_terminal.default.png differ
diff --git a/pandora_console/images/groups_small/old/application_osx_terminal.ok.png b/pandora_console/images/groups_small/old/application_osx_terminal.ok.png
new file mode 100644
index 0000000000..0678cb09a1
Binary files /dev/null and b/pandora_console/images/groups_small/old/application_osx_terminal.ok.png differ
diff --git a/pandora_console/images/groups_small/old/application_osx_terminal.warning.png b/pandora_console/images/groups_small/old/application_osx_terminal.warning.png
new file mode 100644
index 0000000000..e95f210a5f
Binary files /dev/null and b/pandora_console/images/groups_small/old/application_osx_terminal.warning.png differ
diff --git a/pandora_console/images/groups_small/applications.bad_old.png b/pandora_console/images/groups_small/old/applications.bad_old.png
similarity index 100%
rename from pandora_console/images/groups_small/applications.bad_old.png
rename to pandora_console/images/groups_small/old/applications.bad_old.png
diff --git a/pandora_console/images/groups_small/applications.default_old.png b/pandora_console/images/groups_small/old/applications.default_old.png
similarity index 100%
rename from pandora_console/images/groups_small/applications.default_old.png
rename to pandora_console/images/groups_small/old/applications.default_old.png
diff --git a/pandora_console/images/groups_small/applications.ok_old.png b/pandora_console/images/groups_small/old/applications.ok_old.png
similarity index 100%
rename from pandora_console/images/groups_small/applications.ok_old.png
rename to pandora_console/images/groups_small/old/applications.ok_old.png
diff --git a/pandora_console/images/groups_small/applications.warning_old.png b/pandora_console/images/groups_small/old/applications.warning_old.png
similarity index 100%
rename from pandora_console/images/groups_small/applications.warning_old.png
rename to pandora_console/images/groups_small/old/applications.warning_old.png
diff --git a/pandora_console/images/groups_small/old/bricks.bad.png b/pandora_console/images/groups_small/old/bricks.bad.png
new file mode 100644
index 0000000000..0a0cd5459f
Binary files /dev/null and b/pandora_console/images/groups_small/old/bricks.bad.png differ
diff --git a/pandora_console/images/groups_small/old/bricks.default.png b/pandora_console/images/groups_small/old/bricks.default.png
new file mode 100644
index 0000000000..14d8bab5ca
Binary files /dev/null and b/pandora_console/images/groups_small/old/bricks.default.png differ
diff --git a/pandora_console/images/groups_small/old/bricks.ok.png b/pandora_console/images/groups_small/old/bricks.ok.png
new file mode 100644
index 0000000000..931d1a389c
Binary files /dev/null and b/pandora_console/images/groups_small/old/bricks.ok.png differ
diff --git a/pandora_console/images/groups_small/old/bricks.warning.png b/pandora_console/images/groups_small/old/bricks.warning.png
new file mode 100644
index 0000000000..bbfeb0ce3f
Binary files /dev/null and b/pandora_console/images/groups_small/old/bricks.warning.png differ
diff --git a/pandora_console/images/groups_small/old/chart_organisation.bad.png b/pandora_console/images/groups_small/old/chart_organisation.bad.png
new file mode 100644
index 0000000000..410cd5116c
Binary files /dev/null and b/pandora_console/images/groups_small/old/chart_organisation.bad.png differ
diff --git a/pandora_console/images/groups_small/old/chart_organisation.default.png b/pandora_console/images/groups_small/old/chart_organisation.default.png
new file mode 100644
index 0000000000..53619a608b
Binary files /dev/null and b/pandora_console/images/groups_small/old/chart_organisation.default.png differ
diff --git a/pandora_console/images/groups_small/old/chart_organisation.ok.png b/pandora_console/images/groups_small/old/chart_organisation.ok.png
new file mode 100644
index 0000000000..ca7f04061b
Binary files /dev/null and b/pandora_console/images/groups_small/old/chart_organisation.ok.png differ
diff --git a/pandora_console/images/groups_small/old/chart_organisation.warning.png b/pandora_console/images/groups_small/old/chart_organisation.warning.png
new file mode 100644
index 0000000000..c9ba529187
Binary files /dev/null and b/pandora_console/images/groups_small/old/chart_organisation.warning.png differ
diff --git a/pandora_console/images/groups_small/old/clock.bad.png b/pandora_console/images/groups_small/old/clock.bad.png
new file mode 100644
index 0000000000..f281439c87
Binary files /dev/null and b/pandora_console/images/groups_small/old/clock.bad.png differ
diff --git a/pandora_console/images/groups_small/old/clock.default.png b/pandora_console/images/groups_small/old/clock.default.png
new file mode 100644
index 0000000000..2b7a58aa20
Binary files /dev/null and b/pandora_console/images/groups_small/old/clock.default.png differ
diff --git a/pandora_console/images/groups_small/old/clock.ok.png b/pandora_console/images/groups_small/old/clock.ok.png
new file mode 100644
index 0000000000..a3cb173d9e
Binary files /dev/null and b/pandora_console/images/groups_small/old/clock.ok.png differ
diff --git a/pandora_console/images/groups_small/old/clock.warning.png b/pandora_console/images/groups_small/old/clock.warning.png
new file mode 100644
index 0000000000..20880b31df
Binary files /dev/null and b/pandora_console/images/groups_small/old/clock.warning.png differ
diff --git a/pandora_console/images/groups_small/computer.bad_old.png b/pandora_console/images/groups_small/old/computer.bad_old.png
similarity index 100%
rename from pandora_console/images/groups_small/computer.bad_old.png
rename to pandora_console/images/groups_small/old/computer.bad_old.png
diff --git a/pandora_console/images/groups_small/computer.default_old.png b/pandora_console/images/groups_small/old/computer.default_old.png
similarity index 100%
rename from pandora_console/images/groups_small/computer.default_old.png
rename to pandora_console/images/groups_small/old/computer.default_old.png
diff --git a/pandora_console/images/groups_small/computer.ok_old.png b/pandora_console/images/groups_small/old/computer.ok_old.png
similarity index 100%
rename from pandora_console/images/groups_small/computer.ok_old.png
rename to pandora_console/images/groups_small/old/computer.ok_old.png
diff --git a/pandora_console/images/groups_small/computer.warning_old.png b/pandora_console/images/groups_small/old/computer.warning_old.png
similarity index 100%
rename from pandora_console/images/groups_small/computer.warning_old.png
rename to pandora_console/images/groups_small/old/computer.warning_old.png
diff --git a/pandora_console/images/groups_small/database_gear.bad_old.png b/pandora_console/images/groups_small/old/database_gear.bad_old.png
similarity index 100%
rename from pandora_console/images/groups_small/database_gear.bad_old.png
rename to pandora_console/images/groups_small/old/database_gear.bad_old.png
diff --git a/pandora_console/images/groups_small/database_gear.default_old.png b/pandora_console/images/groups_small/old/database_gear.default_old.png
similarity index 100%
rename from pandora_console/images/groups_small/database_gear.default_old.png
rename to pandora_console/images/groups_small/old/database_gear.default_old.png
diff --git a/pandora_console/images/groups_small/database_gear.ok_old.png b/pandora_console/images/groups_small/old/database_gear.ok_old.png
similarity index 100%
rename from pandora_console/images/groups_small/database_gear.ok_old.png
rename to pandora_console/images/groups_small/old/database_gear.ok_old.png
diff --git a/pandora_console/images/groups_small/database_gear.warning_old.png b/pandora_console/images/groups_small/old/database_gear.warning_old.png
similarity index 100%
rename from pandora_console/images/groups_small/database_gear.warning_old.png
rename to pandora_console/images/groups_small/old/database_gear.warning_old.png
diff --git a/pandora_console/images/groups_small/drive_network.bad.png b/pandora_console/images/groups_small/old/drive_network.bad.png
similarity index 100%
rename from pandora_console/images/groups_small/drive_network.bad.png
rename to pandora_console/images/groups_small/old/drive_network.bad.png
diff --git a/pandora_console/images/groups_small/old/drive_network.default.png b/pandora_console/images/groups_small/old/drive_network.default.png
new file mode 100644
index 0000000000..428b2eb2a4
Binary files /dev/null and b/pandora_console/images/groups_small/old/drive_network.default.png differ
diff --git a/pandora_console/images/groups_small/old/drive_network.ok.png b/pandora_console/images/groups_small/old/drive_network.ok.png
new file mode 100644
index 0000000000..dbe58f007c
Binary files /dev/null and b/pandora_console/images/groups_small/old/drive_network.ok.png differ
diff --git a/pandora_console/images/groups_small/old/drive_network.png b/pandora_console/images/groups_small/old/drive_network.png
new file mode 100644
index 0000000000..952cf5352c
Binary files /dev/null and b/pandora_console/images/groups_small/old/drive_network.png differ
diff --git a/pandora_console/images/groups_small/old/drive_network.warning.png b/pandora_console/images/groups_small/old/drive_network.warning.png
new file mode 100644
index 0000000000..0dbdd4b2a5
Binary files /dev/null and b/pandora_console/images/groups_small/old/drive_network.warning.png differ
diff --git a/pandora_console/images/groups_small/old/email.bad.png b/pandora_console/images/groups_small/old/email.bad.png
new file mode 100644
index 0000000000..064222d63e
Binary files /dev/null and b/pandora_console/images/groups_small/old/email.bad.png differ
diff --git a/pandora_console/images/groups_small/old/email.default.png b/pandora_console/images/groups_small/old/email.default.png
new file mode 100644
index 0000000000..1486cd82a0
Binary files /dev/null and b/pandora_console/images/groups_small/old/email.default.png differ
diff --git a/pandora_console/images/groups_small/old/email.ok.png b/pandora_console/images/groups_small/old/email.ok.png
new file mode 100644
index 0000000000..681fc2ddfa
Binary files /dev/null and b/pandora_console/images/groups_small/old/email.ok.png differ
diff --git a/pandora_console/images/groups_small/old/email.warning.png b/pandora_console/images/groups_small/old/email.warning.png
new file mode 100644
index 0000000000..b08c99d7c1
Binary files /dev/null and b/pandora_console/images/groups_small/old/email.warning.png differ
diff --git a/pandora_console/images/groups_small/old/eye.bad.png b/pandora_console/images/groups_small/old/eye.bad.png
new file mode 100644
index 0000000000..f8191a1b17
Binary files /dev/null and b/pandora_console/images/groups_small/old/eye.bad.png differ
diff --git a/pandora_console/images/groups_small/old/eye.default.png b/pandora_console/images/groups_small/old/eye.default.png
new file mode 100644
index 0000000000..cd852b7502
Binary files /dev/null and b/pandora_console/images/groups_small/old/eye.default.png differ
diff --git a/pandora_console/images/groups_small/old/eye.ok.png b/pandora_console/images/groups_small/old/eye.ok.png
new file mode 100644
index 0000000000..0da4304f71
Binary files /dev/null and b/pandora_console/images/groups_small/old/eye.ok.png differ
diff --git a/pandora_console/images/groups_small/old/eye.warning.png b/pandora_console/images/groups_small/old/eye.warning.png
new file mode 100644
index 0000000000..65a5722201
Binary files /dev/null and b/pandora_console/images/groups_small/old/eye.warning.png differ
diff --git a/pandora_console/images/groups_small/firewall.bad_old.png b/pandora_console/images/groups_small/old/firewall.bad_old.png
similarity index 100%
rename from pandora_console/images/groups_small/firewall.bad_old.png
rename to pandora_console/images/groups_small/old/firewall.bad_old.png
diff --git a/pandora_console/images/groups_small/firewall.default_old.png b/pandora_console/images/groups_small/old/firewall.default_old.png
similarity index 100%
rename from pandora_console/images/groups_small/firewall.default_old.png
rename to pandora_console/images/groups_small/old/firewall.default_old.png
diff --git a/pandora_console/images/groups_small/firewall.ok_old.png b/pandora_console/images/groups_small/old/firewall.ok_old.png
similarity index 100%
rename from pandora_console/images/groups_small/firewall.ok_old.png
rename to pandora_console/images/groups_small/old/firewall.ok_old.png
diff --git a/pandora_console/images/groups_small/firewall.warning_old.png b/pandora_console/images/groups_small/old/firewall.warning_old.png
similarity index 100%
rename from pandora_console/images/groups_small/firewall.warning_old.png
rename to pandora_console/images/groups_small/old/firewall.warning_old.png
diff --git a/pandora_console/images/groups_small/old/heart.bad.png b/pandora_console/images/groups_small/old/heart.bad.png
new file mode 100644
index 0000000000..ff3008fcc4
Binary files /dev/null and b/pandora_console/images/groups_small/old/heart.bad.png differ
diff --git a/pandora_console/images/groups_small/old/heart.default.png b/pandora_console/images/groups_small/old/heart.default.png
new file mode 100644
index 0000000000..a7cfff0cc3
Binary files /dev/null and b/pandora_console/images/groups_small/old/heart.default.png differ
diff --git a/pandora_console/images/groups_small/old/heart.ok.png b/pandora_console/images/groups_small/old/heart.ok.png
new file mode 100644
index 0000000000..0f0798523d
Binary files /dev/null and b/pandora_console/images/groups_small/old/heart.ok.png differ
diff --git a/pandora_console/images/groups_small/old/heart.warning.png b/pandora_console/images/groups_small/old/heart.warning.png
new file mode 100644
index 0000000000..66b8583393
Binary files /dev/null and b/pandora_console/images/groups_small/old/heart.warning.png differ
diff --git a/pandora_console/images/groups_small/old/house.bad.png b/pandora_console/images/groups_small/old/house.bad.png
new file mode 100644
index 0000000000..815f719f7c
Binary files /dev/null and b/pandora_console/images/groups_small/old/house.bad.png differ
diff --git a/pandora_console/images/groups_small/old/house.default.png b/pandora_console/images/groups_small/old/house.default.png
new file mode 100644
index 0000000000..fac912b267
Binary files /dev/null and b/pandora_console/images/groups_small/old/house.default.png differ
diff --git a/pandora_console/images/groups_small/old/house.ok.png b/pandora_console/images/groups_small/old/house.ok.png
new file mode 100644
index 0000000000..c3a2e9053e
Binary files /dev/null and b/pandora_console/images/groups_small/old/house.ok.png differ
diff --git a/pandora_console/images/groups_small/old/house.warning.png b/pandora_console/images/groups_small/old/house.warning.png
new file mode 100644
index 0000000000..cf76552f5f
Binary files /dev/null and b/pandora_console/images/groups_small/old/house.warning.png differ
diff --git a/pandora_console/images/groups_small/old/images.bad.png b/pandora_console/images/groups_small/old/images.bad.png
new file mode 100644
index 0000000000..454b36e1d5
Binary files /dev/null and b/pandora_console/images/groups_small/old/images.bad.png differ
diff --git a/pandora_console/images/groups_small/old/images.default.png b/pandora_console/images/groups_small/old/images.default.png
new file mode 100644
index 0000000000..501a97fe27
Binary files /dev/null and b/pandora_console/images/groups_small/old/images.default.png differ
diff --git a/pandora_console/images/groups_small/old/images.ok.png b/pandora_console/images/groups_small/old/images.ok.png
new file mode 100644
index 0000000000..530af4f4c4
Binary files /dev/null and b/pandora_console/images/groups_small/old/images.ok.png differ
diff --git a/pandora_console/images/groups_small/old/images.warning.png b/pandora_console/images/groups_small/old/images.warning.png
new file mode 100644
index 0000000000..46cd29d989
Binary files /dev/null and b/pandora_console/images/groups_small/old/images.warning.png differ
diff --git a/pandora_console/images/groups_small/old/lightning.bad.png b/pandora_console/images/groups_small/old/lightning.bad.png
new file mode 100644
index 0000000000..a6ec10a2bc
Binary files /dev/null and b/pandora_console/images/groups_small/old/lightning.bad.png differ
diff --git a/pandora_console/images/groups_small/old/lightning.default.png b/pandora_console/images/groups_small/old/lightning.default.png
new file mode 100644
index 0000000000..47447d48be
Binary files /dev/null and b/pandora_console/images/groups_small/old/lightning.default.png differ
diff --git a/pandora_console/images/groups_small/old/lightning.ok.png b/pandora_console/images/groups_small/old/lightning.ok.png
new file mode 100644
index 0000000000..7dee1c4a81
Binary files /dev/null and b/pandora_console/images/groups_small/old/lightning.ok.png differ
diff --git a/pandora_console/images/groups_small/old/lightning.warning.png b/pandora_console/images/groups_small/old/lightning.warning.png
new file mode 100644
index 0000000000..020cfe9ac7
Binary files /dev/null and b/pandora_console/images/groups_small/old/lightning.warning.png differ
diff --git a/pandora_console/images/groups_small/old/lock.bad.png b/pandora_console/images/groups_small/old/lock.bad.png
new file mode 100644
index 0000000000..29fecde26d
Binary files /dev/null and b/pandora_console/images/groups_small/old/lock.bad.png differ
diff --git a/pandora_console/images/groups_small/old/lock.default.png b/pandora_console/images/groups_small/old/lock.default.png
new file mode 100644
index 0000000000..d462751473
Binary files /dev/null and b/pandora_console/images/groups_small/old/lock.default.png differ
diff --git a/pandora_console/images/groups_small/old/lock.ok.png b/pandora_console/images/groups_small/old/lock.ok.png
new file mode 100644
index 0000000000..fb9a8749bd
Binary files /dev/null and b/pandora_console/images/groups_small/old/lock.ok.png differ
diff --git a/pandora_console/images/groups_small/old/lock.warning.png b/pandora_console/images/groups_small/old/lock.warning.png
new file mode 100644
index 0000000000..bfb2826d31
Binary files /dev/null and b/pandora_console/images/groups_small/old/lock.warning.png differ
diff --git a/pandora_console/images/groups_small/old/network.bad.png b/pandora_console/images/groups_small/old/network.bad.png
new file mode 100644
index 0000000000..f3293d77ac
Binary files /dev/null and b/pandora_console/images/groups_small/old/network.bad.png differ
diff --git a/pandora_console/images/groups_small/old/network.default.png b/pandora_console/images/groups_small/old/network.default.png
new file mode 100644
index 0000000000..c330e90893
Binary files /dev/null and b/pandora_console/images/groups_small/old/network.default.png differ
diff --git a/pandora_console/images/groups_small/old/network.ok.png b/pandora_console/images/groups_small/old/network.ok.png
new file mode 100644
index 0000000000..edd8831666
Binary files /dev/null and b/pandora_console/images/groups_small/old/network.ok.png differ
diff --git a/pandora_console/images/groups_small/old/network.warning.png b/pandora_console/images/groups_small/old/network.warning.png
new file mode 100644
index 0000000000..6ddd996e56
Binary files /dev/null and b/pandora_console/images/groups_small/old/network.warning.png differ
diff --git a/pandora_console/images/groups_small/old/plugin.bad.png b/pandora_console/images/groups_small/old/plugin.bad.png
new file mode 100644
index 0000000000..6d156e363f
Binary files /dev/null and b/pandora_console/images/groups_small/old/plugin.bad.png differ
diff --git a/pandora_console/images/groups_small/old/plugin.default.png b/pandora_console/images/groups_small/old/plugin.default.png
new file mode 100644
index 0000000000..d97051dec6
Binary files /dev/null and b/pandora_console/images/groups_small/old/plugin.default.png differ
diff --git a/pandora_console/images/groups_small/old/plugin.ok.png b/pandora_console/images/groups_small/old/plugin.ok.png
new file mode 100644
index 0000000000..ff830a1475
Binary files /dev/null and b/pandora_console/images/groups_small/old/plugin.ok.png differ
diff --git a/pandora_console/images/groups_small/old/plugin.warning.png b/pandora_console/images/groups_small/old/plugin.warning.png
new file mode 100644
index 0000000000..58104424a0
Binary files /dev/null and b/pandora_console/images/groups_small/old/plugin.warning.png differ
diff --git a/pandora_console/images/groups_small/old/printer.bad.png b/pandora_console/images/groups_small/old/printer.bad.png
new file mode 100644
index 0000000000..9b2d285e85
Binary files /dev/null and b/pandora_console/images/groups_small/old/printer.bad.png differ
diff --git a/pandora_console/images/groups_small/old/printer.default.png b/pandora_console/images/groups_small/old/printer.default.png
new file mode 100644
index 0000000000..859c2474af
Binary files /dev/null and b/pandora_console/images/groups_small/old/printer.default.png differ
diff --git a/pandora_console/images/groups_small/old/printer.ok.png b/pandora_console/images/groups_small/old/printer.ok.png
new file mode 100644
index 0000000000..8f17c7a050
Binary files /dev/null and b/pandora_console/images/groups_small/old/printer.ok.png differ
diff --git a/pandora_console/images/groups_small/old/printer.warning.png b/pandora_console/images/groups_small/old/printer.warning.png
new file mode 100644
index 0000000000..7eb19cf180
Binary files /dev/null and b/pandora_console/images/groups_small/old/printer.warning.png differ
diff --git a/pandora_console/images/groups_small/server_database.bad_old.png b/pandora_console/images/groups_small/old/server_database.bad_old.png
similarity index 100%
rename from pandora_console/images/groups_small/server_database.bad_old.png
rename to pandora_console/images/groups_small/old/server_database.bad_old.png
diff --git a/pandora_console/images/groups_small/server_database.default_old.png b/pandora_console/images/groups_small/old/server_database.default_old.png
similarity index 100%
rename from pandora_console/images/groups_small/server_database.default_old.png
rename to pandora_console/images/groups_small/old/server_database.default_old.png
diff --git a/pandora_console/images/groups_small/server_database.ok_old.png b/pandora_console/images/groups_small/old/server_database.ok_old.png
similarity index 100%
rename from pandora_console/images/groups_small/server_database.ok_old.png
rename to pandora_console/images/groups_small/old/server_database.ok_old.png
diff --git a/pandora_console/images/groups_small/server_database.warning_old.png b/pandora_console/images/groups_small/old/server_database.warning_old.png
similarity index 100%
rename from pandora_console/images/groups_small/server_database.warning_old.png
rename to pandora_console/images/groups_small/old/server_database.warning_old.png
diff --git a/pandora_console/images/groups_small/transmit.bad_old.png b/pandora_console/images/groups_small/old/transmit.bad_old.png
similarity index 100%
rename from pandora_console/images/groups_small/transmit.bad_old.png
rename to pandora_console/images/groups_small/old/transmit.bad_old.png
diff --git a/pandora_console/images/groups_small/transmit.default_old.png b/pandora_console/images/groups_small/old/transmit.default_old.png
similarity index 100%
rename from pandora_console/images/groups_small/transmit.default_old.png
rename to pandora_console/images/groups_small/old/transmit.default_old.png
diff --git a/pandora_console/images/groups_small/transmit.ok_old.png b/pandora_console/images/groups_small/old/transmit.ok_old.png
similarity index 100%
rename from pandora_console/images/groups_small/transmit.ok_old.png
rename to pandora_console/images/groups_small/old/transmit.ok_old.png
diff --git a/pandora_console/images/groups_small/transmit.warning_old.png b/pandora_console/images/groups_small/old/transmit.warning_old.png
similarity index 100%
rename from pandora_console/images/groups_small/transmit.warning_old.png
rename to pandora_console/images/groups_small/old/transmit.warning_old.png
diff --git a/pandora_console/images/groups_small/without_group.bad_old.png b/pandora_console/images/groups_small/old/without_group.bad_old.png
similarity index 100%
rename from pandora_console/images/groups_small/without_group.bad_old.png
rename to pandora_console/images/groups_small/old/without_group.bad_old.png
diff --git a/pandora_console/images/groups_small/without_group.default_old.png b/pandora_console/images/groups_small/old/without_group.default_old.png
similarity index 100%
rename from pandora_console/images/groups_small/without_group.default_old.png
rename to pandora_console/images/groups_small/old/without_group.default_old.png
diff --git a/pandora_console/images/groups_small/without_group.ok_old.png b/pandora_console/images/groups_small/old/without_group.ok_old.png
similarity index 100%
rename from pandora_console/images/groups_small/without_group.ok_old.png
rename to pandora_console/images/groups_small/old/without_group.ok_old.png
diff --git a/pandora_console/images/groups_small/without_group.warning_old.png b/pandora_console/images/groups_small/old/without_group.warning_old.png
similarity index 100%
rename from pandora_console/images/groups_small/without_group.warning_old.png
rename to pandora_console/images/groups_small/old/without_group.warning_old.png
diff --git a/pandora_console/images/groups_small/world.bad_old.png b/pandora_console/images/groups_small/old/world.bad_old.png
similarity index 100%
rename from pandora_console/images/groups_small/world.bad_old.png
rename to pandora_console/images/groups_small/old/world.bad_old.png
diff --git a/pandora_console/images/groups_small/world.default_old.png b/pandora_console/images/groups_small/old/world.default_old.png
similarity index 100%
rename from pandora_console/images/groups_small/world.default_old.png
rename to pandora_console/images/groups_small/old/world.default_old.png
diff --git a/pandora_console/images/groups_small/world.ok_old.png b/pandora_console/images/groups_small/old/world.ok_old.png
similarity index 100%
rename from pandora_console/images/groups_small/world.ok_old.png
rename to pandora_console/images/groups_small/old/world.ok_old.png
diff --git a/pandora_console/images/groups_small/world.warning_old.png b/pandora_console/images/groups_small/old/world.warning_old.png
similarity index 100%
rename from pandora_console/images/groups_small/world.warning_old.png
rename to pandora_console/images/groups_small/old/world.warning_old.png
diff --git a/pandora_console/images/groups_small/plugin.bad.png b/pandora_console/images/groups_small/plugin.bad.png
index 6d156e363f..7004df6a1e 100644
Binary files a/pandora_console/images/groups_small/plugin.bad.png and b/pandora_console/images/groups_small/plugin.bad.png differ
diff --git a/pandora_console/images/groups_small/plugin.default.png b/pandora_console/images/groups_small/plugin.default.png
index d97051dec6..d815c117ba 100644
Binary files a/pandora_console/images/groups_small/plugin.default.png and b/pandora_console/images/groups_small/plugin.default.png differ
diff --git a/pandora_console/images/groups_small/plugin.ok.png b/pandora_console/images/groups_small/plugin.ok.png
index ff830a1475..dfa215c35e 100644
Binary files a/pandora_console/images/groups_small/plugin.ok.png and b/pandora_console/images/groups_small/plugin.ok.png differ
diff --git a/pandora_console/images/groups_small/plugin.warning.png b/pandora_console/images/groups_small/plugin.warning.png
index 58104424a0..957bedbc15 100644
Binary files a/pandora_console/images/groups_small/plugin.warning.png and b/pandora_console/images/groups_small/plugin.warning.png differ
diff --git a/pandora_console/images/groups_small/printer.bad.png b/pandora_console/images/groups_small/printer.bad.png
index 9b2d285e85..79ad2126d4 100644
Binary files a/pandora_console/images/groups_small/printer.bad.png and b/pandora_console/images/groups_small/printer.bad.png differ
diff --git a/pandora_console/images/groups_small/printer.default.png b/pandora_console/images/groups_small/printer.default.png
index 859c2474af..c16416c149 100644
Binary files a/pandora_console/images/groups_small/printer.default.png and b/pandora_console/images/groups_small/printer.default.png differ
diff --git a/pandora_console/images/groups_small/printer.ok.png b/pandora_console/images/groups_small/printer.ok.png
index 8f17c7a050..4f2cd88e81 100644
Binary files a/pandora_console/images/groups_small/printer.ok.png and b/pandora_console/images/groups_small/printer.ok.png differ
diff --git a/pandora_console/images/groups_small/printer.warning.png b/pandora_console/images/groups_small/printer.warning.png
index 7eb19cf180..f3aaa8ef07 100644
Binary files a/pandora_console/images/groups_small/printer.warning.png and b/pandora_console/images/groups_small/printer.warning.png differ
diff --git a/pandora_console/images/icono-barras-arriba.disabled.png b/pandora_console/images/icono-barras-arriba.disabled.png
new file mode 100644
index 0000000000..94fb50dc5f
Binary files /dev/null and b/pandora_console/images/icono-barras-arriba.disabled.png differ
diff --git a/pandora_console/images/icono-barras-arriba.png b/pandora_console/images/icono-barras-arriba.png
new file mode 100644
index 0000000000..4029c48c87
Binary files /dev/null and b/pandora_console/images/icono-barras-arriba.png differ
diff --git a/pandora_console/images/icono-quesito.disabled.png b/pandora_console/images/icono-quesito.disabled.png
new file mode 100644
index 0000000000..8202e2040b
Binary files /dev/null and b/pandora_console/images/icono-quesito.disabled.png differ
diff --git a/pandora_console/images/icono-quesito.png b/pandora_console/images/icono-quesito.png
new file mode 100644
index 0000000000..f1a0ed73ff
Binary files /dev/null and b/pandora_console/images/icono-quesito.png differ
diff --git a/pandora_console/images/reset.png b/pandora_console/images/reset.png
new file mode 100644
index 0000000000..a3304f8263
Binary files /dev/null and b/pandora_console/images/reset.png differ
diff --git a/pandora_console/include/ajax/graph.ajax.php b/pandora_console/include/ajax/graph.ajax.php
index 1b537f8a48..ac7decf965 100644
--- a/pandora_console/include/ajax/graph.ajax.php
+++ b/pandora_console/include/ajax/graph.ajax.php
@@ -64,7 +64,7 @@ if ($print_custom_graph) {
$ttl = (int) get_parameter('ttl', 1);
$dashboard = (bool) get_parameter('dashboard');
$vconsole = (bool) get_parameter('vconsole');
-
+
echo custom_graphs_print($id_graph, $height, $width, $period, $stacked,
true, $date, $only_image, $background_color, $modules_param,
$homeurl, $name_list, $unit_list, $show_last, $show_max,
@@ -102,13 +102,14 @@ if ($print_sparse_graph) {
$percentil = get_parameter('percentil', null);
$dashboard = (bool) get_parameter('dashboard');
$vconsole = (bool) get_parameter('vconsole');
+ $type_g = get_parameter('type_g', $config['type_module_charts']);
echo grafico_modulo_sparse($agent_module_id, $period, $show_events,
$width, $height , $title, $unit_name, $show_alerts, $avg_only,
$pure, $date, $unit, $baseline, $return_data, $show_title,
$only_image, $homeurl, $ttl, $projection, $adapt_key, $compare,
$show_unknown, $menu, $backgroundColor, $percentil,
- $dashboard, $vconsole, $config['type_module_charts']);
+ $dashboard, $vconsole, $type_g);
return;
}
diff --git a/pandora_console/include/ajax/module.php b/pandora_console/include/ajax/module.php
index 32de285b11..66063ed5ab 100755
--- a/pandora_console/include/ajax/module.php
+++ b/pandora_console/include/ajax/module.php
@@ -123,12 +123,17 @@ if ($get_module_detail) {
$time_from = (string) get_parameter ('time_from', date ('h:iA'));
$date_to = (string) get_parameter ('date_to', date ('Y-m-j'));
$time_to = (string) get_parameter ('time_to', date ('h:iA'));
+ $freesearch = (string) get_parameter ('freesearch', '');
+ $free_checkbox = (bool) get_parameter ('free_checkbox', false);
$formtable->width = '98%';
$formtable->class = "databox";
$formtable->data = array ();
$formtable->size = array ();
+ $moduletype_name = modules_get_moduletype_name(
+ modules_get_agentmodule_type($module_id));
+
$periods = array(SECONDS_5MINUTES =>__('5 minutes'),
SECONDS_30MINUTES =>__('30 minutes'),
SECONDS_1HOUR =>__('1 hour'),
@@ -175,10 +180,19 @@ if ($get_module_detail) {
$formtable->data[1][2] .= html_print_input_text('time_to', $time_to,
'', 9, 7, true);
- html_print_table($formtable);
+ $freesearch_object = '';
+ if (preg_match("/_string/", $moduletype_name)) {
+ $formtable->data[2][0] = __('Free search') . ' ';
+ $formtable->data[2][1] = html_print_input_text ('freesearch', $freesearch, '', 20, null, true);
+ $formtable->data[2][2] = html_print_checkbox('free_checkbox', 1, $free_checkbox, true);
+ $formtable->data[2][2] .= ' ' . __('Exact phrase');
+ $freesearch_object = json_encode( array(
+ 'value' => io_safe_output($freesearch),
+ 'exact' => (bool)$free_checkbox
+ ));
+ }
- $moduletype_name = modules_get_moduletype_name(
- modules_get_agentmodule_type($module_id));
+ html_print_table($formtable);
$offset = (int) get_parameter("offset");
$block_size = (int) $config["block_size"];
@@ -222,10 +236,10 @@ if ($get_module_detail) {
}
$count = modules_get_agentmodule_data ($module_id, $period,
- $date, true, $conexion);
+ $date, true, $conexion, 'ASC', $freesearch_object);
$module_data = modules_get_agentmodule_data ($module_id, $period,
- $date, false, $conexion, 'DESC');
+ $date, false, $conexion, 'DESC', $freesearch_object);
if (empty($module_data)) {
$result = array();
diff --git a/pandora_console/include/ajax/snmp.ajax.php b/pandora_console/include/ajax/snmp.ajax.php
index 7b3e45c704..a372d50e11 100644
--- a/pandora_console/include/ajax/snmp.ajax.php
+++ b/pandora_console/include/ajax/snmp.ajax.php
@@ -20,6 +20,7 @@ require_once("include/functions_snmp.php");
$save_snmp_translation = (bool)get_parameter('save_snmp_translation', 0);
$delete_snmp_translation = (bool)get_parameter('delete_snmp_translation', 0);
$update_snmp_translation = (bool)get_parameter('update_snmp_translation', 0);
+$delete_snmp_filter = (bool)get_parameter('delete_snmp_filter', 0);
/* skins image checks */
if ($save_snmp_translation) {
@@ -56,4 +57,12 @@ if ($update_snmp_translation) {
return;
}
+
+if ($delete_snmp_filter) {
+ $filter_id = get_parameter('filter_id');
+html_debug($filter_id, true);
+ db_process_sql_delete('tsnmp_filter', array('id_snmp_filter' => $filter_id));
+
+ return;
+}
?>
diff --git a/pandora_console/include/ajax/snmp_browser.ajax.php b/pandora_console/include/ajax/snmp_browser.ajax.php
index 3376245093..f7414c2fe1 100644
--- a/pandora_console/include/ajax/snmp_browser.ajax.php
+++ b/pandora_console/include/ajax/snmp_browser.ajax.php
@@ -25,16 +25,14 @@ if(is_ajax()){
$target_ip = (string) get_parameter ("target_ip", '');
$community = (string) get_parameter ("community", '');
$snmp_version = (string) get_parameter ("snmp_browser_version", '');
- $snmp3_auth_user = get_parameter('snmp3_browser_auth_user');
+ $snmp3_auth_user = io_safe_output(get_parameter('snmp3_browser_auth_user'));
$snmp3_security_level = get_parameter('snmp3_browser_security_level');
$snmp3_auth_method = get_parameter('snmp3_browser_auth_method');
- $snmp3_auth_pass = get_parameter('snmp3_browser_auth_pass');
+ $snmp3_auth_pass = io_safe_output(get_parameter('snmp3_browser_auth_pass'));
$snmp3_privacy_method = get_parameter('snmp3_browser_privacy_method');
- $snmp3_privacy_pass = get_parameter('snmp3_browser_privacy_pass');
+ $snmp3_privacy_pass = io_safe_output(get_parameter('snmp3_browser_privacy_pass'));
$targets_oids = get_parameter ("oids", "");
- $targets_oids = explode(",", $targets_oids);
-
$custom_action = get_parameter ("custom_action", "");
if ($custom_action != "") {
diff --git a/pandora_console/include/ajax/tree.ajax.php b/pandora_console/include/ajax/tree.ajax.php
index 89f2cf3bf7..6e7a612171 100644
--- a/pandora_console/include/ajax/tree.ajax.php
+++ b/pandora_console/include/ajax/tree.ajax.php
@@ -17,8 +17,25 @@
if (is_ajax ()) {
global $config;
- // Login check
- check_login ();
+ enterprise_include_once("include/functions_dashboard.php");
+
+ $public_hash = get_parameter('hash', 0);
+
+ // Try to authenticate by hash on public dashboards
+ if ($public_hash == 0) {
+ // Login check
+ check_login();
+ } else {
+ $validate_hash = enterprise_hook(
+ 'dasboard_validate_public_hash',
+ array($public_hash, 'tree_view')
+ );
+ if ($validate_hash === false || $validate_hash === ENTERPRISE_NOT_HOOK) {
+ db_pandora_audit("Invalid public hash", "Trying to access report builder");
+ require ("general/noaccess.php");
+ exit;
+ }
+ }
require_once($config['homedir'] . "/include/class/Tree.class.php");
enterprise_include_once("include/class/Tree.class.php");
@@ -36,6 +53,10 @@ if (is_ajax ()) {
$rootID = get_parameter('rootID', -1);
$serverID = get_parameter('serverID', false);
$childrenMethod = get_parameter('childrenMethod', 'on_demand');
+ $hash = get_parameter('hash', false);
+ if ($hash !== false) {
+ enterprise_hook('dasboard_validate_public_hash', array($hash, 'tree_view'));
+ }
$default_filters = array(
'searchAgent' => '',
diff --git a/pandora_console/include/ajax/visual_console.ajax.php b/pandora_console/include/ajax/visual_console.ajax.php
index 789398139c..91af22ec7e 100644
--- a/pandora_console/include/ajax/visual_console.ajax.php
+++ b/pandora_console/include/ajax/visual_console.ajax.php
@@ -12,10 +12,30 @@
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
-// Login check
global $config;
-check_login ();
+enterprise_include_once ('include/functions_dashboard.php');
+require_once('include/functions_visual_map.php');
+enterprise_include_once('include/functions_visual_map.php');
+
+$public_hash = get_parameter('hash', false);
+$id_visual_console = get_parameter('id_visual_console', null);
+
+// Try to authenticate by hash on public dashboards
+if ($public_hash === false) {
+ // Login check
+ check_login();
+} else {
+ $validate_hash = enterprise_hook(
+ 'dasboard_validate_public_hash',
+ array($public_hash, $id_visual_console, 'visual_console')
+ );
+ if ($validate_hash === false || $validate_hash === ENTERPRISE_NOT_HOOK) {
+ db_pandora_audit("Invalid public hash", "Trying to access report builder");
+ require ("general/noaccess.php");
+ exit;
+ }
+}
// Fix: IW was the old ACL to check for report editing, now is RW
if (! check_acl ($config['id_user'], 0, "VR")) {
@@ -29,12 +49,6 @@ if (! check_acl ($config['id_user'], 0, "VR")) {
//Fix ajax to avoid include the file, 'functions_graph.php'.
$ajax = true;
-
-require_once('include/functions_visual_map.php');
-enterprise_include_once('include/functions_visual_map.php');
-
-$id_visual_console = get_parameter('id_visual_console', null);
-
$render_map = (bool)get_parameter('render_map', false);
$graph_javascript = (bool)get_parameter('graph_javascript', false);
diff --git a/pandora_console/include/ajax/visual_console_builder.ajax.php b/pandora_console/include/ajax/visual_console_builder.ajax.php
index f1e3d43350..05e6f7fc4c 100755
--- a/pandora_console/include/ajax/visual_console_builder.ajax.php
+++ b/pandora_console/include/ajax/visual_console_builder.ajax.php
@@ -100,10 +100,14 @@ $width = get_parameter('width', null);
$height = get_parameter('height', null);
$parent = get_parameter('parent', null);
$map_linked = get_parameter('map_linked', null);
+$map_linked_weight = get_parameter('map_linked_weight', null);
+$element_group = get_parameter('element_group', null);
$width_percentile = get_parameter('width_percentile', null);
+$bars_graph_height = get_parameter('bars_graph_height', null);
$max_percentile = get_parameter('max_percentile', null);
$height_module_graph = get_parameter('height_module_graph', null);
$width_module_graph = get_parameter('width_module_graph', null);
+$bars_graph_type = get_parameter('bars_graph_type', null);
$id_agent_module = get_parameter('id_agent_module', 0);
$process_simple_value = get_parameter('process_simple_value', PROCESS_VALUE_NONE);
$type_percentile = get_parameter('type_percentile', 'percentile');
@@ -112,12 +116,18 @@ $metaconsole = get_parameter('metaconsole', 0);
$server_name = get_parameter('server_name', null);
$server_id = (int)get_parameter('server_id', 0);
$id_agent = get_parameter('id_agent', null);
+$id_agent_string = get_parameter('id_agent_string', null);
$id_metaconsole = get_parameter('id_metaconsole', null);
$id_group = (int)get_parameter('id_group', 0);
$id_custom_graph = get_parameter('id_custom_graph', null);
$border_width = (int)get_parameter('border_width', 0);
$border_color = get_parameter('border_color', '');
+$grid_color = get_parameter('grid_color', '');
+$resume_color = get_parameter('resume_color', '');
$fill_color = get_parameter('fill_color', '');
+$percentile_color = get_parameter('percentile_color', '');
+$percentile_label = io_safe_output(get_parameter('percentile_label', ''));
+$percentile_label_color = get_parameter('percentile_label_color', '');
$width_box = (int)get_parameter('width_box', 0);
$height_box = (int)get_parameter('height_box', 0);
$line_start_x = (int)get_parameter('line_start_x', 0);
@@ -130,6 +140,7 @@ $line_color = get_parameter('line_color', '');
$get_element_status = get_parameter('get_element_status', 0);
$enable_link = get_parameter('enable_link', 1);
+$show_on_top = get_parameter('show_on_top', 0);
$type_graph = get_parameter('type_graph', 'area');
$label_position = get_parameter('label_position', 'down');
$show_statistics = get_parameter('show_statistics', 0);
@@ -140,6 +151,57 @@ switch ($action) {
$return['font'] = $config['fontpath'];
echo json_encode($return);
break;
+
+ case 'get_image_from_module':
+ $layoutData = db_get_row_filter('tlayout_data', array('id' => $id_element));
+ $sql = 'SELECT datos FROM tagente_estado WHERE id_agente_modulo = '.$layoutData['id_agente_modulo'];
+ ob_clean();
+ $result = db_get_sql($sql);
+ $image = strpos($result, 'data:image');
+
+ if($image === false){
+ $return['correct'] = false;
+ }
+ else{
+ $return['correct'] = true;
+ }
+
+ echo json_encode($return);
+
+ break;
+
+ case 'get_module_type_string':
+ $data = array ();
+
+ $layoutData = db_get_row_filter('tlayout_data', array('id' => $id_element));
+
+ if ($layoutData['id_metaconsole'] != 0) {
+ $connection = db_get_row_filter ('tmetaconsole_setup', $layoutData['id_metaconsole']);
+
+ if (metaconsole_load_external_db($connection) != NOERR) {
+ continue;
+ }
+ }
+
+ $is_string = db_get_value_filter ('id_tipo_modulo', 'tagente_modulo',
+ array ('id_agente' => $id_agent,
+ 'id_agente_modulo' => $id_module));
+
+ if ($layoutData['id_metaconsole'] != 0) {
+ metaconsole_restore_db();
+ }
+
+ $return = array();
+ if (($is_string == 17) || ($is_string == 23) || ($is_string == 3) ||
+ ($is_string == 10) || ($is_string == 33)) {
+ $return['no_data'] = false;
+ }
+ else {
+ $return['no_data'] = true;
+ }
+
+ echo json_encode($return);
+ break;
case 'get_module_events':
$data = array ();
@@ -321,7 +383,7 @@ switch ($action) {
// Linked to other layout ?? - Only if not module defined
if ($layoutData['id_layout_linked'] != 0) {
- $status = visual_map_get_layout_status ($layoutData['id_layout_linked']);
+ $status = visual_map_get_layout_status ($layoutData['id_layout_linked'], $layoutData['id_layout_linked_weight']);
// Single object
}
@@ -431,6 +493,7 @@ switch ($action) {
$values = array();
$values['label_position'] = $label_position;
+ $values['show_on_top'] = $show_on_top;
// In Graphs, background color is stored in column image (sorry)
if ($type == 'module_graph') {
@@ -452,12 +515,6 @@ switch ($action) {
echo (int)$result;
break;
case 'simple_value':
- if ($action == 'update') {
- $values['type'] = visual_map_get_simple_value_type(
- $process_simple_value);
- $values['period'] = $period;
- $values['width'] = $width;
- }
case 'percentile_bar':
case 'percentile_item':
case 'static_graph':
@@ -465,6 +522,8 @@ switch ($action) {
case 'label':
case 'icon':
case 'auto_sla_graph':
+ case 'bars_graph':
+ case 'donut_graph':
default:
if ($type == 'label') {
$values['type'] = LABEL;
@@ -474,6 +533,9 @@ switch ($action) {
if ($enable_link !== null) {
$values['enable_link'] = $enable_link;
}
+ if ($show_on_top !== null) {
+ $values['show_on_top'] = $show_on_top;
+ }
if ($label !== null) {
$values['label'] = $label;
}
@@ -499,8 +561,6 @@ switch ($action) {
break;
}
-
-
if (defined('METACONSOLE') && $metaconsole) {
if ($server_name !== null) {
$values['id_metaconsole'] = db_get_value('id',
@@ -515,11 +575,14 @@ switch ($action) {
$values['id_agent'] = $id_agent;
}
}
- else if ($agent !== null) {
- $id_agent = agents_get_agent_id($agent);
+ else if ($id_agent == 0) {
+ $values['id_agent'] = 0;
+ }
+ else if (!empty($id_agent)) {
$values['id_agent'] = $id_agent;
}
- else {
+ else if ($agent !== null) {
+ $id_agent = agents_get_agent_id($agent);
$values['id_agent'] = $id_agent;
}
if ($id_module !== null) {
@@ -531,6 +594,12 @@ switch ($action) {
if ($map_linked !== null) {
$values['id_layout_linked'] = $map_linked;
}
+ if ($element_group !== null) {
+ $values['element_group'] = $element_group;
+ }
+ if ($map_linked_weight !== null) {
+ $values['id_layout_linked_weight'] = $map_linked_weight;
+ }
switch ($type) {
// -- line_item ------------------------------------
case 'handler_start':
@@ -551,6 +620,15 @@ switch ($action) {
$values['height'] = $height;
}
break;
+ case 'donut_graph':
+ if ($width_percentile !== null) {
+ $values['width'] = $width_percentile;
+ $values['height'] = $width_percentile;
+ }
+ $values['border_color'] = $resume_color;
+ $values['type'] = DONUT_GRAPH;
+ $values['id_agent'] = $id_agent_string;
+ break;
case 'box_item':
$values['border_width'] = $border_width;
$values['border_color'] = $border_color;
@@ -588,6 +666,24 @@ switch ($action) {
$values['id_custom_graph'] = $id_custom_graph;
}
break;
+ case 'bars_graph':
+ if ($width_percentile !== null) {
+ $values['width'] = $width_percentile;
+ }
+ if ($bars_graph_height !== null) {
+ $values['height'] = $bars_graph_height;
+ }
+ if ($bars_graph_type !== null) {
+ $values['type_graph'] = $bars_graph_type;
+ }
+ if ($background_color !== null) {
+ $values['image'] = $background_color;
+ }
+ if ($grid_color !== null) {
+ $values['border_color'] = $grid_color;
+ }
+ $values['id_agent'] = $id_agent_string;
+ break;
case 'percentile_item':
case 'percentile_bar':
if ($action == 'update') {
@@ -602,15 +698,21 @@ switch ($action) {
if ($type_percentile == 'percentile') {
$values['type'] = PERCENTILE_BAR;
}
+ elseif ($type_percentile == 'circular_progress_bar') {
+ $values['type'] = CIRCULAR_PROGRESS_BAR;
+ }
+ elseif ($type_percentile == 'interior_circular_progress_bar') {
+ $values['type'] = CIRCULAR_INTERIOR_PROGRESS_BAR;
+ }
elseif ($type_percentile == 'bubble') {
$values['type'] = PERCENTILE_BUBBLE;
}
- //Check the field's value for back compatibility
- $values['image'] = 'percent';
- if (($value_show == 'percent') ||
- ($value_show == 'value'))
- $values['image'] = $value_show;
+ $values['image'] = $value_show;
+
+ $values['border_color'] = $percentile_color;
+ $values['fill_color'] = $percentile_label_color;
+ $values['label'] = $percentile_label;
}
break;
case 'icon':
@@ -624,6 +726,15 @@ switch ($action) {
if ($height !== null) {
$values['height'] = $height;
}
+ break;
+ case 'simple_value':
+ if ($action == 'update') {
+ $values['type'] = visual_map_get_simple_value_type(
+ $process_simple_value);
+ $values['period'] = $period;
+ $values['width'] = $width;
+ }
+
break;
default:
if (enterprise_installed()) {
@@ -639,6 +750,14 @@ switch ($action) {
// Don't change the label because only change the positions
unset($values['label']);
unset($values['label_position']);
+ // Don't change this values when move
+ unset($values['id_agent']);
+ unset($values['id_agente_modulo']);
+ unset($values['enable_link']);
+ unset($values['show_on_top']);
+ unset($values['id_layout_linked']);
+ unset($values['element_group']);
+ unset($values['id_layout_linked_weight']);
// Don't change background color in graphs when move
switch ($type) {
@@ -650,6 +769,19 @@ switch ($action) {
unset($values['image']);
unset($values['type_graph']);
break;
+ case 'bars_graph':
+ unset($values['image']);
+ unset($values['type_graph']);
+ unset($values['border_color']);
+ unset($values['width']);
+ unset($values['id_agent']);
+ unset($values['height']);
+ break;
+ case 'donut_graph':
+ unset($values['border_color']);
+ unset($values['width']);
+ unset($values['id_agent']);
+ break;
case 'box_item':
unset($values['border_width']);
unset($values['border_color']);
@@ -707,10 +839,12 @@ switch ($action) {
case 'static_graph':
case 'group_item':
case 'module_graph':
+ case 'bars_graph':
case 'simple_value':
case 'label':
case 'icon':
case 'auto_sla_graph':
+ case 'donut_graph':
$elementFields = db_get_row_filter('tlayout_data',
array('id' => $id_element));
@@ -768,11 +902,8 @@ switch ($action) {
case 'percentile_bar':
$elementFields['width_percentile'] = $elementFields['width'];
$elementFields['max_percentile'] = $elementFields['height'];
- //Check the field's value for back compatibility
- $elementFields['value_show'] = 'percent';
- if (($elementFields['image'] == 'percent') ||
- ($elementFields['image'] == 'value'))
- $elementFields['value_show'] = $elementFields['image'];
+
+ $elementFields['value_show'] = $elementFields['image'];
$elementFields['type_percentile'] = 'percentile';
if ($elementFields['type'] == PERCENTILE_BAR) {
@@ -781,12 +912,59 @@ switch ($action) {
elseif ($elementFields['type'] == PERCENTILE_BUBBLE) {
$elementFields['type_percentile'] = 'bubble';
}
+ elseif ($elementFields['type'] == CIRCULAR_PROGRESS_BAR) {
+ $elementFields['type_percentile'] = 'circular_progress_bar';
+ }
+ elseif ($elementFields['type'] == CIRCULAR_INTERIOR_PROGRESS_BAR) {
+ $elementFields['type_percentile'] = 'interior_circular_progress_bar';
+ }
+ $elementFields['percentile_color'] = $elementFields['border_color'];
+ $elementFields['percentile_label_color'] = $elementFields['fill_color'];
+ $elementFields['percentile_label'] = $elementFields['label'];
+ break;
+ case 'donut_graph':
+ $elementFields['width_percentile'] = $elementFields['width'];
+ $elementFields['resume_color'] = $elementFields['border_color'];
+ $elementFields['id_agent_string'] = $elementFields['id_agent'];
+ if (($elementFields['id_agent_string'] != 0)
+ && ($elementFields['id_layout_linked'] == 0)) {
+ $modules = agents_get_modules(
+ $elementFields['id_agent'], false,
+ array('disabled' => 0,
+ 'id_agente' => $elementFields['id_agent'],
+ 'tagente_modulo.id_tipo_modulo IN' => "(17,23,3,10,33)"));
+
+ $elementFields['modules_html'] = '-- ';
+ foreach ($modules as $id => $name) {
+ $elementFields['modules_html'] .= '' . io_safe_output($name) . ' ';
+ }
+ }
break;
case 'module_graph':
$elementFields['width_module_graph'] = $elementFields['width'];
$elementFields['height_module_graph'] = $elementFields['height'];
break;
+ case 'bars_graph':
+ $elementFields['width_percentile'] = $elementFields['width'];
+ $elementFields['bars_graph_height'] = $elementFields['height'];
+ $elementFields['bars_graph_type'] = $elementFields['type_graph'];
+ $elementFields['grid_color'] = $elementFields['border_color'];
+ $elementFields['id_agent_string'] = $elementFields['id_agent'];
+ if (($elementFields['id_agent_string'] != 0)
+ && ($elementFields['id_layout_linked'] == 0)) {
+ $modules = agents_get_modules(
+ $elementFields['id_agent'], false,
+ array('disabled' => 0,
+ 'id_agente' => $elementFields['id_agent'],
+ 'tagente_modulo.id_tipo_modulo IN' => "(17,23,3,10,33)"));
+
+ $elementFields['modules_html'] = '-- ';
+ foreach ($modules as $id => $name) {
+ $elementFields['modules_html'] .= '' . io_safe_output($name) . ' ';
+ }
+ }
+ break;
case 'box_item':
$elementFields['width_box'] = $elementFields['width'];
$elementFields['height_box'] = $elementFields['height'];
@@ -865,8 +1043,11 @@ switch ($action) {
}
$values['id_agente_modulo'] = $id_module;
$values['id_layout_linked'] = $map_linked;
+ $values['element_group'] = $element_group;
+ $values['id_layout_linked_weight'] = $map_linked_weight;
$values['parent_item'] = $parent;
$values['enable_link'] = $enable_link;
+ $values['show_on_top'] = $show_on_top;
$values['image'] = $background_color;
$values['type_graph'] = $type_graph;
@@ -891,6 +1072,13 @@ switch ($action) {
$values['width'] = $width_box;
$values['height'] = $height_box;
break;
+ case 'donut_graph':
+ $values['type'] = DONUT_GRAPH;
+ $values['width'] = $width_percentile;
+ $values['height'] = $width_percentile;
+ $values['border_color'] = $resume_color;
+ $values['id_agent'] = $id_agent_string;
+ break;
case 'module_graph':
$values['type'] = MODULE_GRAPH;
@@ -923,6 +1111,15 @@ switch ($action) {
}
$values['period'] = $period;
break;
+ case 'bars_graph':
+ $values['type'] = BARS_GRAPH;
+ $values['width'] = $width_percentile;
+ $values['height'] = $bars_graph_height;
+ $values['type_graph'] = $bars_graph_type;
+ $values['image'] = $background_color;
+ $values['border_color'] = $grid_color;
+ $values['id_agent'] = $id_agent_string;
+ break;
case 'auto_sla_graph':
$values['type'] = AUTO_SLA_GRAPH;
$values['period'] = $event_max_time_row;
@@ -934,21 +1131,27 @@ switch ($action) {
if ($type_percentile == 'percentile') {
$values['type'] = PERCENTILE_BAR;
}
+ elseif ($type_percentile == 'circular_progress_bar') {
+ $values['type'] = CIRCULAR_PROGRESS_BAR;
+ }
+ elseif ($type_percentile == 'interior_circular_progress_bar') {
+ $values['type'] = CIRCULAR_INTERIOR_PROGRESS_BAR;
+ }
else {
$values['type'] = PERCENTILE_BUBBLE;
}
+ $values['border_color'] = $percentile_color;
$values['image'] = $value_show; //Hack to save it show percent o value.
$values['width'] = $width_percentile;
$values['height'] = $max_percentile;
+ $values['fill_color'] = $percentile_label_color;
+ $values['label'] = $percentile_label;
break;
case 'static_graph':
$values['type'] = STATIC_GRAPH;
$values['image'] = $image;
$values['width'] = $width;
$values['height'] = $height;
- if(defined('METACONSOLE') && $values['id_agent'] == 0){
- $values['id_metaconsole'] = 1;
- }
break;
case 'group_item':
$values['type'] = GROUP_ITEM;
@@ -967,18 +1170,12 @@ switch ($action) {
case 'label':
$values['type'] = LABEL;
$values['label'] = $label;
- if(defined('METACONSOLE') && $values['id_agent'] == 0){
- $values['id_metaconsole'] = 1;
- }
break;
case 'icon':
$values['type'] = ICON;
$values['image'] = $image;
$values['width'] = $width;
$values['height'] = $height;
- if(defined('METACONSOLE') && $values['id_agent'] == 0){
- $values['id_metaconsole'] = 1;
- }
break;
default:
if (enterprise_installed()) {
@@ -986,7 +1183,7 @@ switch ($action) {
}
break;
}
-
+
$idData = db_process_sql_insert('tlayout_data', $values);
$return = array();
@@ -1040,9 +1237,17 @@ switch ($action) {
$return['values']['height_box'] = $values['height'];
break;
- case PERCENTILE_BUBBLE:
+ case CIRCULAR_PROGRESS_BAR:
$return['values']['type_percentile'] = 'bubble';
break;
+
+ case CIRCULAR_INTERIOR_PROGRESS_BAR:
+ $return['values']['type_percentile'] = 'circular_progress_bar';
+ break;
+
+ case PERCENTILE_BUBBLE:
+ $return['values']['type_percentile'] = 'interior_circular_progress_bar';
+ break;
case PERCENTILE_BAR:
$return['values']['type_percentile'] = 'percentile';
diff --git a/pandora_console/include/auth/mysql.php b/pandora_console/include/auth/mysql.php
index 139543ee75..acd777102c 100644
--- a/pandora_console/include/auth/mysql.php
+++ b/pandora_console/include/auth/mysql.php
@@ -215,6 +215,13 @@ function process_user_login_remote ($login, $pass, $api = false) {
break;
}
+ if ($config["auth"] === 'ldap') {
+ $login_user_attribute = $login;
+ if (($config['ldap_login_user_attr'] != 'name') && ($config['ldap_login_user_attr'] != null)) {
+ $login = get_ldap_login_attr($login);
+ }
+ }
+
// Authentication ok, check if the user exists in the local database
if (is_user ($login)) {
if (!user_can_login($login)) {
@@ -240,26 +247,19 @@ function process_user_login_remote ($login, $pass, $api = false) {
}
}
}
- elseif (($config["auth"] === 'ldap') &&
- (isset($config['ldap_advanced_config']) && $config['ldap_advanced_config'])) {
+ elseif ($config["auth"] === 'ldap') {
+ if ($config['ldap_save_password']) {
+ $update_credentials = change_local_user_pass_ldap ($login, $pass);
- $return = enterprise_hook ('prepare_permissions_groups_of_user_ldap',
- array ($login, $pass, false, true, defined('METACONSOLE')));
-
- if ($return === "error_permissions") {
- $config["auth_error"] =
- __("Problems with configuration permissions. Please contact with Administrator");
- return false;
- }
- else {
- if ($return === "permissions_changed") {
+ if ($update_credentials) {
$config["auth_error"] =
__("Your permissions have changed. Please, login again.");
return false;
}
}
-
- change_local_user_pass_ldap ($login, $pass);
+ else {
+ delete_user_pass_ldap ($login);
+ }
}
return $login;
@@ -310,9 +310,7 @@ function process_user_login_remote ($login, $pass, $api = false) {
return false;
}
}
- elseif ($config["auth"] === 'ldap' &&
- (isset($config['ldap_advanced_config']) &&
- $config['ldap_advanced_config'])) {
+ elseif ($config["auth"] === 'ldap') {
if ( defined('METACONSOLE') ) {
enterprise_include_once('include/functions_metaconsole.php');
enterprise_include_once ('meta/include/functions_groups_meta.php');
@@ -332,13 +330,11 @@ function process_user_login_remote ($login, $pass, $api = false) {
}
// Create the user
- if (enterprise_hook ('prepare_permissions_groups_of_user_ldap',
- array($login,
- $pass,
- array ('fullname' => $login,
- 'comments' => 'Imported from ' . $config['auth']),
- false, defined('METACONSOLE'))) === false) {
-
+ $prepare_perms = prepare_permissions_groups_of_user_ldap($login_user_attribute, $pass,
+ array ('fullname' => $login_user_attribute, 'comments' => 'Imported from ' . $config['auth']),
+ false, defined('METACONSOLE'));
+
+ if (!$prepare_perms) {
$config["auth_error"] = __("User not found in database
or incorrect password");
@@ -693,10 +689,220 @@ function ldap_process_user_login ($login, $password) {
}
}
- $dc = $config["ldap_base_dn"];
+ $correct_admin_bind = true;
+ if ($config['ldap_admin_login'] != "" && $config['ldap_admin_pass'] != "") {
+ if (!@ldap_bind($ds, io_safe_output($config['ldap_admin_login']), $config['ldap_admin_pass'])) {
+ $correct_admin_bind = false;
+ }
+ }
+
+ if (!$correct_admin_bind) {
+ $config["auth_error"] = 'Admin ldap connection fail';
+ @ldap_close ($ds);
+
+ return false;
+ }
+
+ $dc = io_safe_output($config["ldap_base_dn"]);
#Search group of this user it belong.
- $filter="(cn=" . io_safe_output($login) . ")";
+ $filter="(" . $config['ldap_login_attr'] . "=" . io_safe_output($login) . ")";
+ $justthese = array("objectclass=group");
+
+ $sr = ldap_search($ds, $dc, $filter, $justthese);
+
+ $memberof = ldap_get_entries($ds, $sr);
+
+ if ($memberof["count"] == 0 && !isset($memberof[0]["memberof"])) {
+ @ldap_close ($ds);
+ return false;
+ }
+ else {
+ $memberof = $memberof[0];
+ }
+
+ unset($memberof["count"]);
+
+ $ldap_base_dn = !empty($config["ldap_base_dn"]) ? "," . io_safe_output($config["ldap_base_dn"]) : '';
+
+ $correct = false;
+ if(!empty($ldap_base_dn)) {
+ if (strlen($password) != 0 && @ldap_bind($ds, io_safe_output($memberof['dn']), $password) ) {
+ $correct = true;
+ }
+ }
+ else {
+ if (strlen($password) != 0 && @ldap_bind($ds, io_safe_output($login), $password) ) {
+ $correct = true;
+ }
+ }
+
+ @ldap_close ($ds);
+
+ if ($correct) {
+ return true;
+ }
+ else {
+ $config["auth_error"] = 'User not found in database or incorrect password';
+
+ return false;
+ }
+}
+
+function get_ldap_login_attr ($login) {
+ global $config;
+
+ if (! function_exists ("ldap_connect")) {
+ $config["auth_error"] = __('Your installation of PHP does not support LDAP');
+
+ return false;
+ }
+
+ // Connect to the LDAP server
+ $ds = @ldap_connect ($config["ldap_server"], $config["ldap_port"]);
+
+ if (!$ds) {
+ $config["auth_error"] = 'Error connecting to LDAP server';
+
+ return false;
+ }
+
+ // Set the LDAP version
+ ldap_set_option ($ds, LDAP_OPT_PROTOCOL_VERSION, $config["ldap_version"]);
+
+ if ($config["ldap_start_tls"]) {
+ if (!@ldap_start_tls ($ds)) {
+ $config["auth_error"] = 'Could not start TLS for LDAP connection';
+ @ldap_close ($ds);
+
+ return false;
+ }
+ }
+
+ $id_user = $login;
+
+ switch ($config['ldap_login_user_attr']) {
+ case 'email':
+ $dc = io_safe_output($config["ldap_base_dn"]);
+
+ $correct_admin_bind = true;
+ if ($config['ldap_admin_login'] != "" && $config['ldap_admin_pass'] != "") {
+ if (!@ldap_bind($ds, io_safe_output($config['ldap_admin_login']), $config['ldap_admin_pass'])) {
+ $correct_admin_bind = false;
+ }
+ }
+
+ if (!$correct_admin_bind) {
+ $config["auth_error"] = 'Admin ldap connection fail';
+ @ldap_close ($ds);
+
+ return false;
+ }
+
+ $filter="(" . $config['ldap_login_attr'] . "=" . io_safe_output($id_user) . ")";
+ $justthese = array("mail");
+
+ $sr = ldap_search($ds, $dc, $filter, $justthese);
+
+ $info = ldap_get_entries($ds, $sr);
+
+ if ($info["count"] == 0 && !isset($info[0]["mail"])) {
+ @ldap_close ($ds);
+ return $id_user;
+ }
+ else {
+ $info = $info[0];
+ }
+
+ $id_user = $info['mail'][0];
+
+ @ldap_close ($ds);
+
+ break;
+ }
+
+ return $id_user;
+}
+
+/**
+ * Checks if a user is in the autocreate blacklist.
+ *
+ * @param string User
+ *
+ * @return bool True if the user is in the blacklist, false otherwise.
+ */
+function is_user_blacklisted ($user) {
+ global $config;
+
+ $blisted_users = explode (',', $config['autocreate_blacklist']);
+ foreach ($blisted_users as $blisted_user) {
+ if ($user == $blisted_user) {
+ return true;
+ }
+ }
+
+ return false;
+}
+
+/**
+ * Check permissions in LDAP for prepare to create user in Pandora.
+ *
+ * @param string Login
+ * @param string Password
+ * @param string User Info
+ * @param string check_permissions Check if change permissions
+ *
+ * @return bool True if the login succeeds, false otherwise
+ */
+function prepare_permissions_groups_of_user_ldap ($id_user, $password,
+ $user_info, $check_permissions = false, $syncronize = false) {
+
+ global $config;
+ include_once($config['homedir'] . "/include/functions_html.php");
+
+ if (! function_exists ("ldap_connect")) {
+ return false;
+ }
+
+ // Do not allow blank passwords
+ if ($password == "") {
+ return false;
+ }
+
+ // Connect to the LDAP server
+ $ds = @ldap_connect ($config["ldap_server"], $config["ldap_port"]);
+ if (!$ds) {
+ return false;
+ }
+
+ // Set the LDAP version
+ ldap_set_option ($ds, LDAP_OPT_PROTOCOL_VERSION, $config["ldap_version"]);
+
+ if ($config["ldap_start_tls"]) {
+ if (!@ldap_start_tls ($ds)) {
+ @ldap_close ($ds);
+ return false;
+ }
+ }
+
+ $dc = io_safe_output($config["ldap_base_dn"]);
+
+ $correct_admin_bind = true;
+ if ($config['ldap_admin_login'] != "" && $config['ldap_admin_pass'] != "") {
+ if (!@ldap_bind($ds, io_safe_output($config['ldap_admin_login']), $config['ldap_admin_pass'])) {
+ $correct_admin_bind = false;
+ }
+ }
+
+ if (!$correct_admin_bind) {
+ $config["auth_error"] = 'Admin ldap connection fail';
+ @ldap_close ($ds);
+
+ return false;
+ }
+
+ #Search group of this user it belong.
+ $filter="(" . $config['ldap_login_attr'] . "=" . io_safe_output($id_user) . ")";
$justthese = array("objectclass=group");
$sr = ldap_search($ds, $dc, $filter, $justthese);
@@ -727,36 +933,381 @@ function ldap_process_user_login ($login, $password) {
}
}
- @ldap_close ($ds);
+ if (!$correct) {
+ @ldap_close ($ds);
- if ($correct) {
- return true;
- }
- else {
- $config["auth_error"] = 'User not found in database or incorrect password';
-
return false;
}
+
+ $permissions = array();
+ $i = 0;
+ $count_total = 0;
+
+ $ldap_adv_perms = json_decode(io_safe_output($config['ldap_adv_perms']), true);
+
+ foreach ($ldap_adv_perms as $ldap_adv_perm) {
+ $groups = $ldap_adv_perm['groups_ldap'];
+
+ if ($groups[0] == '') {
+ $groups = array();
+ }
+ else {
+ $groups = $groups[0];
+ }
+
+ $count_ad_adv_perms = count(explode(",", $groups));
+
+ $tags_ids = array();
+ $tags = implode(",", $tags);
+ if ($tags == null) {
+ $tags = "";
+ }
+
+ foreach ($memberof as $member) {
+ $member_to_compare = str_replace($config['ldap_login_attr'] . "=", "", $member);
+ $member_to_compare = str_replace($id_user . ",", "", $member_to_compare);
+ $member_to_compare = str_replace("," . $dc, "", $member_to_compare);
+
+ if (($member_to_compare == $dc) && (empty($groups))) {
+ $count_total++;
+ }
+ else {
+ $member_to_compare = explode(",", $member_to_compare);
+ $groups = explode(",", $groups);
+ foreach ($groups as $g) {
+ if ($member_to_compare[0] == $g) {
+ $count_total++;
+ }
+ }
+ }
+ }
+
+ if ($count_total > 0) {
+ $profile_id = $ldap_adv_perm['profile'];
+ $id_grupos = $ldap_adv_perm['group'];
+
+ if (empty($profile_id)) {
+ @ldap_close ($ds);
+ return false;
+ }
+
+ $permissions[$i]["profile"] = $profile_id;
+ $permissions[$i]["groups"] = $id_grupos;
+ $permissions[$i]["tags"] = $tags;
+ }
+ $i++;
+ $count_total = 0;
+ $count_ad_adv_perms = 0;
+ }
+
+ if ( $check_permissions ) {
+ $result = check_permission_ldap ($id_user, $password, $user_info, $permissions, $syncronize);
+ @ldap_close ($ds);
+
+ return $result;
+ }
+
+ if (!is_user ($id_user)) {
+ if (($config['ldap_login_user_attr'] != 'name') && ($config['ldap_login_user_attr'] != null)) {
+ switch ($config['ldap_login_user_attr']) {
+ case 'email':
+ $filter="(" . $config['ldap_login_attr'] . "=" . io_safe_output($id_user) . ")";
+ $justthese = array("mail");
+
+ $sr = ldap_search($ds, $dc, $filter, $justthese);
+
+ $info = ldap_get_entries($ds, $sr);
+
+ if ($info["count"] == 0 && !isset($info[0]["mail"])) {
+ @ldap_close ($ds);
+ return false;
+ }
+ else {
+ $info = $info[0];
+ }
+
+ $id_user = $info['mail'][0];
+ $user_info['fullname'] = $id_user;
+
+ break;
+ }
+ }
+
+ $create_user = create_user_and_permisions_ldap($id_user, $password, $user_info, $permissions, $syncronize);
+ }
+
+ @ldap_close ($ds);
+
+ return $create_user;
}
/**
- * Checks if a user is in the autocreate blacklist.
+ * Create progile with data obtaint from AD
*
- * @param string User
+ * @param string Login
+ * @param string Password
+ * @param array user_info
+ * @param array permiisons
*
- * @return bool True if the user is in the blacklist, false otherwise.
+ * @return bool
*/
-function is_user_blacklisted ($user) {
+function create_user_and_permisions_ldap ($id_user, $password, $user_info,
+ $permissions, $syncronize = false) {
global $config;
- $blisted_users = explode (',', $config['autocreate_blacklist']);
- foreach ($blisted_users as $blisted_user) {
- if ($user == $blisted_user) {
- return true;
+ $values = $user_info;
+ $values["id_user"] = $id_user;
+
+ if ($config['ldap_save_password']) {
+ $values["password"] = md5 ($password);
+ }
+ $values["last_connect"] = 0;
+ $values["registered"] = get_system_time ();
+ if ( defined("METACONSOLE") && $syncronize )
+ $values['metaconsole_access_node'] = $config['ldap_adv_user_node'];
+ $user = (@db_process_sql_insert ("tusuario", $values)) !== false;
+
+ if ($user) {
+ if (!empty($permissions)) {
+ foreach ($permissions as $permission) {
+ $id_profile = $permission["profile"];
+ $id_groups = $permission["groups"];
+ $tags = $permission["tags"];
+
+ foreach ($id_groups as $id_group) {
+ $profile = profile_create_user_profile(
+ $id_user, $id_profile, $id_group, false, $tags);
+ }
+
+ if ( defined("METACONSOLE") && $syncronize ) {
+ enterprise_include_once('include/functions_metaconsole.php');
+
+ unset($values['metaconsole_access_node']);
+ $values['not_login'] = (int) !$config['ldap_adv_user_node'];
+
+ $servers = metaconsole_get_servers();
+ foreach ($servers as $server) {
+ $perfil_maestro = db_get_row('tperfil',
+ 'id_perfil', $permission["profile"]);
+
+ if (metaconsole_connect($server) == NOERR ) {
+
+ if (!profile_exist($perfil_maestro['name'])) {
+ unset($perfil_maestro['id_perfil']);
+ $id_profile = db_process_sql_insert('tperfil', $perfil_maestro);
+ }
+ else {
+ $id_profile = db_get_value('id_perfil', 'tperfil', 'name', $perfil_maestro['name']);
+ }
+
+ db_process_sql_insert ("tusuario", $values);
+ foreach ($id_groups as $id_group) {
+ $profile = profile_create_user_profile ($id_user,
+ $id_profile, $id_group, false, $tags);
+ }
+ }
+
+ metaconsole_restore_db();
+ }
+ }
+
+ if (!$profile)
+ return false;
+ }
+ }
+ else {
+ $profile = profile_create_user_profile(
+ $id_user, $config['default_remote_profile'], $config['default_remote_group'], false, $config['default_assign_tags']);
+
+ if (!$profile)
+ return false;
+ }
+ }
+ return true;
+}
+
+/**
+ * Check if user have right permission in pandora. This
+ * permission depend of ldap.
+ *
+ * @param string Login
+ * @param string Password
+ *
+ * @return string
+ */
+function check_permission_ldap ($id_user, $password, $user_info,
+ $permissions, $syncronize = false) {
+
+ global $config;
+ include_once($config['homedir'] . "/enterprise/include/functions_metaconsole.php");
+
+ $result_user = users_get_user_by_id($id_user);
+ $filter = array("id_usuario" => $id_user);
+ $profiles_user = array();
+ $user_profiles =
+ db_get_all_rows_filter ("tusuario_perfil", $filter);
+
+ foreach ($user_profiles as $user_profile) {
+ $profiles_user[$user_profile["id_up"]] =
+ $user_profile["id_perfil"];
+ }
+
+ $profiles_user_nodes = array();
+ $permissions_nodes = array();
+ if ( is_metaconsole() && $syncronize ) {
+ $servers = metaconsole_get_servers();
+ foreach ($servers as $server) {
+ if ( metaconsole_connect($server) == NOERR ) {
+ $user_profiles_nodes =
+ db_get_all_rows_filter ("tusuario_perfil", $filter);
+ foreach ($user_profiles_nodes as $user_profile_node) {
+ $profiles_user_nodes[$server['server_name']][$user_profile_node["id_up"]] =
+ $user_profile_node["id_perfil"];
+ }
+ }
+ metaconsole_restore_db();
+ }
+
+ foreach ($permissions as $key => $permission) {
+ $perfil_maestro = db_get_row('tperfil',
+ 'id_perfil', $permission['profile']);
+ foreach ($servers as $server) {
+ if (metaconsole_connect($server) == NOERR ) {
+ if (profile_exist($perfil_maestro['name'])) {
+ $id_profile = db_get_value('id_perfil', 'tperfil', 'name', $perfil_maestro['name']);
+ $permissions_nodes[$server['server_name']][$key] = $permission;
+ $permissions_nodes[$server['server_name']][$key]['profile'] = $id_profile;
+ }
+ }
+ metaconsole_restore_db();
+ }
}
}
- return false;
+ $no_found = array();
+ if ($result_user) {
+ foreach ($permissions as $permission) {
+ $id_profile = $permission["profile"];
+ $id_groups = $permission["groups"];
+ $tags = $permission["tags"];
+
+ foreach ($id_groups as $id_group) {
+ $filter = array("id_usuario" => $id_user,
+ "id_perfil"=>$id_profile,
+ "id_grupo" => $id_group);
+ //~ Find perfil with advance permissions in
+ //~ authentication menu. This data depends on
+ //~ groups where this user it belong.
+ $result_profiles =
+ db_get_row_filter ("tusuario_perfil", $filter);
+ if (!$result_profiles) {
+ #If not found save in array.
+ $no_found[] = array("id_perfil"=>$id_profile,
+ "id_grupo" => $id_group, "tags" =>$tags);
+ }
+ else {
+ #if profile is find, delete from array.
+ db_process_sql_update("tusuario_perfil",
+ array("tags" =>$tags),
+ array('id_usuario' => $id_user,
+ 'id_up' => $profiles_user[$id_profile]));
+
+ unset($profiles_user[$result_profiles["id_up"]]);
+ }
+ }
+ }
+
+ if (is_metaconsole() && $syncronize) {
+ $servers = metaconsole_get_servers();
+ foreach ($servers as $server) {
+ foreach ($permissions_nodes[$server['server_name']] as $permission_node) {
+
+ $id_profile = $permission_node["profile"];
+ $id_groups = $permission_node["groups"];
+ $tags = $permission_node["tags"];
+
+ foreach ($id_groups as $id_group) {
+
+ $filter = array("id_usuario" => $id_user,
+ "id_perfil"=>$id_profile,
+ "id_grupo" => $id_group);
+
+ if (metaconsole_connect($server) == NOERR ) {
+ $result_profiles =
+ db_get_row_filter ("tusuario_perfil", $filter);
+
+ if (!$result_profiles) {
+ #If not found save in array.
+ $no_found_server[$server['server_name']][] = array("id_perfil" => $id_profile,
+ "id_grupo" => $id_group, "tags" => $tags);
+ }
+ else {
+ #if profile is find, delete from array.
+ db_process_sql_update("tusuario_perfil",
+ array("tags" =>$tags),
+ array('id_usuario' => $id_user,
+ 'id_up' => $profiles_user_nodes[$server_name][$id_profile]));
+
+ unset($profiles_user_nodes[$server_name][$result_profiles["id_up"]]);
+ }
+ }
+ }
+ }
+ metaconsole_restore_db();
+ }
+ }
+
+ if ( empty($profiles_user) && empty($no_found) ) {
+ #The permmisions of user not changed
+ return true;
+ }
+ else {
+ foreach ($profiles_user as $key => $profile_user) {
+ #The other profiles are deleted
+ profile_delete_user_profile ($id_user, $key);
+ }
+
+ if ( is_metaconsole() && $syncronize ) {
+ foreach ($profiles_user_nodes as $server_name => $profile_users) {
+ $server = metaconsole_get_connection($server_name);
+ foreach ($profile_users as $key => $profile_user) {
+ if ( metaconsole_connect($server) == NOERR ) {
+ profile_delete_user_profile ($id_user, $key);
+ }
+ }
+ metaconsole_restore_db();
+ }
+ }
+
+ foreach ($no_found as $new_profiles) {
+ #Add the missing permissions
+ profile_create_user_profile ($id_user,
+ $new_profiles["id_perfil"],
+ $new_profiles["id_grupo"], false,
+ $new_profiles["tags"]);
+ }
+
+ if ( is_metaconsole() && $syncronize ) {
+ $servers = metaconsole_get_servers();
+ foreach ($servers as $server) {
+ if ( metaconsole_connect($server) == NOERR ) {
+ foreach ($no_found_server[$server['server_name']] as $new_profiles) {
+ profile_create_user_profile ($id_user,
+ $new_profiles["id_perfil"],
+ $new_profiles["id_grupo"], false,
+ $new_profiles["tags"]);
+ }
+ }
+ metaconsole_restore_db();
+ }
+ }
+
+ return "permissions_changed";
+ }
+ }
+ else {
+ return "error_permissions";
+ }
}
/**
@@ -770,13 +1321,23 @@ function is_user_blacklisted ($user) {
function change_local_user_pass_ldap ($id_user, $password) {
$local_user_pass = db_get_value_filter('password', 'tusuario', array('id_user' => $id_user));
+ $return = false;
if (md5($password) !== $local_user_pass) {
$values_update = array();
$values_update['password'] = md5($password);
- db_process_sql_update('tusuario', $values_update, array('id_user' => $id_user));
+ $return = db_process_sql_update('tusuario', $values_update, array('id_user' => $id_user));
}
+ return $return;
+}
+
+function delete_user_pass_ldap ($id_user) {
+ $values_update = array();
+ $values_update['password'] = null;
+
+ $return = db_process_sql_update('tusuario', $values_update, array('id_user' => $id_user));
+
return;
}
diff --git a/pandora_console/include/class/Tree.class.php b/pandora_console/include/class/Tree.class.php
index 6dc52ea68d..52aa2dee5c 100644
--- a/pandora_console/include/class/Tree.class.php
+++ b/pandora_console/include/class/Tree.class.php
@@ -23,6 +23,7 @@ class Tree {
protected $filter = array();
protected $childrenMethod = "on_demand";
+ protected $userGroupsACL;
protected $userGroups;
protected $strictACL = false;
@@ -36,45 +37,54 @@ class Tree {
$this->id = $id;
$this->rootID = !empty($rootID) ? $rootID : $id;
$this->serverID = $serverID;
- $this->childrenMethod = $childrenMethod;
- $this->access = $access;
-
- $userGroups = users_get_groups(false, $this->access);
+ $this->childrenMethod = $childrenMethod;
+ $this->access = $access;
- if (empty($userGroups))
- $this->userGroups = false;
- else
- $this->userGroups = $userGroups;
+ $userGroupsACL = users_get_groups(false, $this->access);
+ $this->userGroupsACL = empty($userGroupsACL) ? false : $userGroupsACL;
+ $this->userGroups = $this->userGroupsACL;
global $config;
include_once($config['homedir']."/include/functions_servers.php");
include_once($config['homedir']."/include/functions_modules.php");
require_once($config['homedir']."/include/functions_tags.php");
- if (is_metaconsole())
- enterprise_include_once("meta/include/functions_ui_meta.php");
+ if (is_metaconsole()) enterprise_include_once("meta/include/functions_ui_meta.php");
$this->strictACL = (bool) db_get_value("strict_acl", "tusuario", "id_user", $config['id_user']);
$this->acltags = tags_get_user_module_and_tags($config['id_user'], $this->access);
}
- public function setType($type) {
- $this->type = $type;
- }
-
public function setFilter($filter) {
+ // Filter the user groups
+ if (!empty($filter['groupID'])) {
+ $group_id = $filter['groupID'];
+ $this->userGroups = isset($this->userGroupsACL[$group_id])
+ ? array($group_id => $this->userGroupsACL[$group_id])
+ : array();
+ }
+ else if (!empty($filter['searchGroup'])) {
+ $groups = db_get_all_rows_filter('tgrupo', array('nombre' => '%' . $filter['searchGroup'] . '%'));
+
+ // Save the groups which intersect
+ $userGroupsACL = $this->userGroupsACL;
+ $this->userGroups = array_reduce($groups, function ($userGroups, $group) use ($userGroupsACL) {
+ $group_id = $group['id_grupo'];
+ if (isset($userGroupsACL[$group_id])) {
+ $userGroups[$group_id] = $userGroupsACL[$group_id];
+ }
+
+ return $userGroups;
+ }, array());
+ }
+ else {
+ $this->userGroups = $this->userGroupsACL;
+ }
+
$this->filter = $filter;
}
- public function isStrict () {
- return $this->strictACL;
- }
-
- public function setStrict ($value) {
- $this->strictACL = (bool) $value;
- }
-
protected function getAgentStatusFilter ($status = -1) {
if ($status == -1)
$status = $this->filter['statusAgent'];
@@ -323,7 +333,7 @@ class Tree {
case 'group':
// ACL Group
$user_groups_str = "-1";
- $group_acl = "";
+ $group_filter = "";
if (!$this->strictACL) {
if (empty($this->userGroups)) {
return;
@@ -338,7 +348,7 @@ class Tree {
// Asking for all groups.
else {
$user_groups_str = implode(",", array_keys($this->userGroups));
- $group_acl = "AND ta.id_grupo IN ($user_groups_str)";
+ $group_filter = "AND ta.id_grupo IN ($user_groups_str)";
}
}
else {
@@ -356,7 +366,7 @@ class Tree {
}
}
}
- $group_acl = "AND ta.id_grupo IN ($user_groups_str)";
+ $group_filter = "AND ta.id_grupo IN ($user_groups_str)";
}
switch ($type) {
@@ -390,7 +400,7 @@ class Tree {
$module_status_join
WHERE ta.disabled = 0
AND ta.id_grupo = $item_for_count
- $group_acl
+ $group_filter
$agent_search_filter
$agent_status_filter";
$sql = $this->getAgentCountersSql($agent_table);
@@ -411,7 +421,7 @@ class Tree {
FROM tmetaconsole_agent ta
WHERE ta.disabled = 0
AND ta.id_grupo = $item_for_count
- $group_acl
+ $group_filter
$agent_search_filter
$agent_status_filter";
$sql = $this->getAgentCountersSql($agent_table);
@@ -439,7 +449,7 @@ class Tree {
$module_status_join
WHERE ta.disabled = 0
AND ta.id_grupo = $rootID
- $group_acl
+ $group_filter
$agent_search_filter
$agent_status_filter
GROUP BY $group_by_fields
@@ -456,7 +466,7 @@ class Tree {
FROM tmetaconsole_agent ta
WHERE ta.disabled = 0
AND ta.id_grupo = $rootID
- $group_acl
+ $group_filter
$agent_search_filter
$agent_status_filter
ORDER BY $order_fields";
@@ -498,7 +508,7 @@ class Tree {
ON ta.disabled = 0
AND tam.id_agente = ta.id_agente
AND ta.id_grupo = $rootID
- $group_acl
+ $group_filter
$agent_search_filter
$agent_status_filter
WHERE tam.disabled = 0
@@ -1123,7 +1133,8 @@ class Tree {
if (empty($data))
return array();
- if ($this->type == 'agent') {
+ // [26/10/2017] It seems the module hierarchy should be only available into the tree by group
+ if ($this->rootType == 'group' && $this->type == 'agent') {
$data = $this->getProcessedModules($data);
}
diff --git a/pandora_console/include/config_process.php b/pandora_console/include/config_process.php
index 997b5b3955..609cde2096 100644
--- a/pandora_console/include/config_process.php
+++ b/pandora_console/include/config_process.php
@@ -22,8 +22,8 @@
/**
* Pandora build version and version
*/
-$build_version = 'PC171026';
-$pandora_version = 'v7.0NG.714';
+$build_version = 'PC171130';
+$pandora_version = 'v7.0NG.716';
// Do not overwrite default timezone set if defined.
$script_tz = @date_default_timezone_get();
diff --git a/pandora_console/include/constants.php b/pandora_console/include/constants.php
index f039a90504..901cff9eeb 100644
--- a/pandora_console/include/constants.php
+++ b/pandora_console/include/constants.php
@@ -197,6 +197,10 @@ define('SERVICE', 10); //Enterprise Item.
define('GROUP_ITEM', 11);
define('BOX_ITEM', 12);
define('LINE_ITEM', 13);
+define('CIRCULAR_PROGRESS_BAR', 15);
+define('CIRCULAR_INTERIOR_PROGRESS_BAR', 16);
+define('DONUT_GRAPH', 17);
+define('BARS_GRAPH', 18);
//Some styles
define('MIN_WIDTH', 300);
define('MIN_HEIGHT', 120);
@@ -458,7 +462,7 @@ define("STATWIN_DEFAULT_CHART_WIDTH", 555);
define("STATWIN_DEFAULT_CHART_HEIGHT", 245);
/* Dashboard */
-define("DASHBOARD_DEFAULT_COUNT_CELLS", 4);
+define("DASHBOARD_DEFAULT_COUNT_CELLS", 1);
define("OPTION_TEXT", 1);
define("OPTION_SINGLE_SELECT", 2);
diff --git a/pandora_console/include/functions.php b/pandora_console/include/functions.php
index f8edfd1d27..4edfe2c512 100644
--- a/pandora_console/include/functions.php
+++ b/pandora_console/include/functions.php
@@ -1594,7 +1594,7 @@ function get_snmpwalk($ip_target, $snmp_version, $snmp_community = '',
case '2c':
case '1':
default:
- $command_str = $snmpwalk_bin . ' -m ALL -Oa -v ' . escapeshellarg($snmp_version) . ' -c ' . escapeshellarg($snmp_community) . ' ' . escapeshellarg($ip_target) . ' ' . $base_oid . ' 2> ' . $error_redir_dir;
+ $command_str = $snmpwalk_bin . ' -m ALL -Oa -v ' . escapeshellarg($snmp_version) . ' -c ' . escapeshellarg(io_safe_output($snmp_community)) . ' ' . escapeshellarg($ip_target) . ' ' . $base_oid . ' 2> ' . $error_redir_dir;
break;
}
diff --git a/pandora_console/include/functions_agents.php b/pandora_console/include/functions_agents.php
index 838fb58d55..9c38157300 100644
--- a/pandora_console/include/functions_agents.php
+++ b/pandora_console/include/functions_agents.php
@@ -55,6 +55,17 @@ function agents_get_agent_id_by_module_id ($id_agente_modulo) {
'id_agente_modulo', $id_agente_modulo);
}
+/**
+ * Get agent id from an agent alias.
+ *
+ * @param string $alias Agent alias.
+ *
+ * @return int Id from the agent.
+ */
+function agents_get_agent_id_by_alias ($alias) {
+ return db_get_all_rows_sql ("SELECT id_agente FROM tagente WHERE upper(alias) LIKE upper('%$alias%')");
+}
+
/**
* Creates an agent
*
@@ -314,6 +325,13 @@ function agents_get_agents ($filter = false, $fields = false,
$search = '';
}
+ if (isset($filter['search_custom'])) {
+ $search_custom = $filter['search_custom'];
+ unset($filter['search_custom']);
+ } else {
+ $search_custom = '';
+ }
+
if (isset($filter['offset'])) {
$offset = $filter['offset'];
unset($filter['offset']);
@@ -450,8 +468,8 @@ function agents_get_agents ($filter = false, $fields = false,
$sql_extra, $where, $where_nogroup, $status_sql, $search, $disabled);
}
else {
- $where = sprintf('%s AND %s AND (%s) %s AND %s',
- $where, $where_nogroup, $status_sql, $search, $disabled);
+ $where = sprintf('%s AND %s AND (%s) %s AND %s %s',
+ $where, $where_nogroup, $status_sql, $search, $disabled, $search_custom);
}
$sql = sprintf('SELECT %s
FROM tagente
diff --git a/pandora_console/include/functions_alerts.php b/pandora_console/include/functions_alerts.php
index 8e87eee5b3..577dfe82f1 100644
--- a/pandora_console/include/functions_alerts.php
+++ b/pandora_console/include/functions_alerts.php
@@ -1039,14 +1039,16 @@ function alerts_delete_alert_agent_module ($id_alert_agent_module, $filter = fal
$filter = array ();
if ($id_alert_agent_module)
$filter['id'] = $id_alert_agent_module;
-
- // Get the modules of the fired alerts that will be deleted to update counts
- $filter_get = $filter;
-
- $filter_get['group'] = 'id_agent_module';
- $filter_get['times_fired'] = '>0';
-
- $fired_alert_modules = db_get_all_rows_filter('talert_template_modules', $filter_get, array('id_agent_module', 'COUNT(*) alerts'));
+
+ // Get the id agent to update the fired alert counts
+ $agent_id = false;
+ if (isset ($filter['id_agent_module'])){
+ $agent_id = modules_get_agentmodule_agent ($filter["id_agent_module"]);
+ }
+ else if (isset ($filter['id'])){
+ $alert = alerts_get_alert_agent_module($id_alert_agent_module);
+ $agent_id = modules_get_agentmodule_agent ($alert["id_agent_module"]);
+ }
/*
The deletion of actions from talert_template_module_actions,
@@ -1054,6 +1056,11 @@ function alerts_delete_alert_agent_module ($id_alert_agent_module, $filter = fal
a foreing key and delete on cascade.
*/
if (@db_process_sql_delete ('talert_template_modules', $filter) !== false) {
+ // Update fired alert count on the agent
+ // It will only occur if is specified the alert id or the id_agent_module
+ if ($agent_id !== false) {
+ db_process_sql(sprintf('UPDATE tagente SET update_alert_count=1 WHERE id_agente = %d', $agent_id));
+ }
return true;
}
diff --git a/pandora_console/include/functions_api.php b/pandora_console/include/functions_api.php
index 5ecac3a944..c1c7c9ca50 100644
--- a/pandora_console/include/functions_api.php
+++ b/pandora_console/include/functions_api.php
@@ -8531,7 +8531,7 @@ function api_set_enable_module ($agent_name, $module_name, $thrast3, $thrash4) {
* @param string $template_name Name of the alert template (for example, "Warning event")
* @param $thrash4 Don't use.
-// http://localhost/pandora_console/include/api.php?op=set&op2=disable_alert&id=garfio&id2=Status&other=Warning%20condition
+// http://localhost/pandora_console/include/api.php?op=set&op2=disable_alert&id=c2cea5860613e363e25f4ba185b54fe28f869ff8a5e8bb46343288337c903531&id2=Status&other=Warning%20condition
*/
function api_set_disable_alert ($agent_name, $module_name, $template_name, $thrash4) {
@@ -8543,11 +8543,53 @@ function api_set_disable_alert ($agent_name, $module_name, $template_name, $thra
$id_agent_module = db_get_value_filter('id_agente_modulo', 'tagente_modulo', array('id_agente' => $id_agent, 'nombre' => $module_name));
$id_template = db_get_value_filter('id', 'talert_templates', array('name' => $template_name["data"]));
- db_process_sql("UPDATE talert_template_modules
+ $result = db_process_sql("UPDATE talert_template_modules
SET disabled = 1
WHERE id_agent_module = $id_agent_module AND id_alert_template = $id_template");
- returnData('string', array('type' => 'string', 'data' => "Correct alert disable"));
+ if ($result) {
+ returnData('string', array('type' => 'string', 'data' => "Correct alert disable"));
+ } else {
+ returnData('string', array('type' => 'string', 'data' => __('Error alert disable')));
+ }
+}
+
+
+/**
+ * Disable an alert with alias
+ *
+ * @param string $agent_alias Alias of agent (for example "myagent")
+ * @param string $module_name Name of the module (for example "Host alive")
+ * @param string $template_name Name of the alert template (for example, "Warning event")
+ * @param $thrash4 Don't use.
+
+// http://localhost/pandora_console/include/api.php?op=set&op2=disable_alert_alias&id=garfio&id2=Status&other=Warning%20condition
+ */
+
+function api_set_disable_alert_alias ($agent_alias, $module_name, $template_name, $thrash4) {
+ if (defined ('METACONSOLE')) {
+ return;
+ }
+
+ $agent_id = agents_get_agent_id_by_alias($agent_alias);
+ $result = false;
+ foreach ($agent_id as $key => $id_agent) {
+ $id_agent_module = db_get_value_filter('id_agente_modulo', 'tagente_modulo', array('id_agente' => $id_agent['id_agente'], 'nombre' => $module_name));
+ $id_template = db_get_value_filter('id', 'talert_templates', array('name' => $template_name["data"]));
+
+ $result = db_process_sql("UPDATE talert_template_modules
+ SET disabled = 1
+ WHERE id_agent_module = $id_agent_module AND id_alert_template = $id_template");
+
+ if ($result) {
+ returnData('string', array('type' => 'string', 'data' => "Correct alert disable"));
+ return;
+ }
+ }
+
+ if(!$result){
+ returnData('string', array('type' => 'string', 'data' => __('Error alert disable')));
+ }
}
/**
diff --git a/pandora_console/include/functions_config.php b/pandora_console/include/functions_config.php
index 06f0d090b5..30078c5685 100644
--- a/pandora_console/include/functions_config.php
+++ b/pandora_console/include/functions_config.php
@@ -343,9 +343,23 @@ function config_update_config () {
$error_update[] = __('Base DN');
if (!config_update_value ('ldap_login_attr', get_parameter ('ldap_login_attr')))
$error_update[] = __('Login attribute');
+ if (!config_update_value ('ldap_admin_login', get_parameter ('ldap_admin_login')))
+ $error_update[] = __('Admin LDAP login');
+ if (!config_update_value ('ldap_admin_pass', get_parameter ('ldap_admin_pass')))
+ $error_update[] = __('Admin LDAP password');
if (!config_update_value ('fallback_local_auth', get_parameter ('fallback_local_auth')))
$error_update[] = __('Fallback to local authentication');
-
+ if (!config_update_value ('ldap_login_user_attr', get_parameter ('ldap_login_user_attr')))
+ $error_update[] = __('Login user attribute');
+
+ if (isset($config['fallback_local_auth']) && $config['fallback_local_auth'] == 0) {
+ if (!config_update_value ('ldap_save_password', get_parameter ('ldap_save_password')))
+ $error_update[] = __('Save Password');
+ }
+ else if (isset($config['fallback_local_auth']) && $config['fallback_local_auth'] == 1) {
+ config_update_value ('ldap_save_password', 1);
+ }
+
if (!config_update_value ('rpandora_server', get_parameter ('rpandora_server')))
$error_update[] = __('MySQL host');
if (!config_update_value ('rpandora_port', get_parameter ('rpandora_port')))
@@ -1348,6 +1362,14 @@ function config_process_config () {
if (!isset ($config['ldap_login_attr'])) {
config_update_value ( 'ldap_login_attr', 'uid');
}
+
+ if (!isset ($config['ldap_admin_login'])) {
+ config_update_value ( 'ldap_admin_login', '');
+ }
+
+ if (!isset ($config['ldap_admin_pass'])) {
+ config_update_value ( 'ldap_admin_pass', '');
+ }
if (!isset ($config['fallback_local_auth'])) {
config_update_value ( 'fallback_local_auth', '0');
diff --git a/pandora_console/include/functions_cron.php b/pandora_console/include/functions_cron.php
index cf131eac8e..efa5f2f342 100644
--- a/pandora_console/include/functions_cron.php
+++ b/pandora_console/include/functions_cron.php
@@ -30,24 +30,30 @@ function cron_update_module_interval ($module_id, $cron) {
$module_interval = db_get_value_filter('module_interval','tagente_modulo',array("id_agente_modulo" => $module_id));
return db_process_sql ('UPDATE tagente_estado SET current_interval = ' . $module_interval . ' WHERE id_agente_modulo = ' . (int) $module_id);
} else {
- return db_process_sql ('UPDATE tagente_estado SET current_interval = ' . cron_next_execution ($cron) . ' WHERE id_agente_modulo = ' . (int) $module_id);
+ return db_process_sql (
+ 'UPDATE tagente_estado SET current_interval = ' .
+ cron_next_execution ($cron, $module_interval, $module_id) .
+ ' WHERE id_agente_modulo = ' .
+ (int) $module_id)
+ ;
}
}
// Get the number of seconds left to the next execution of the given cron entry.
-function cron_next_execution ($cron) {
+function cron_next_execution ($cron, $module_interval, $module_id) {
// Get day of the week and month from cron config
list ($minute, $hour, $mday, $month, $wday) = explode (" ", $cron);
- // Get current time
- $cur_time = time();
+ // Get last execution time
+ $last_execution = db_get_value('utimestamp', 'tagente_estado', 'id_agente_modulo', $module_id);
+ $cur_time = ($last_execution !== false) ? $last_execution : time();
// Any day of the way
if ($wday == '*') {
- $nex_time = cron_next_execution_date ($cron, $cur_time);
+ $nex_time = cron_next_execution_date ($cron, $cur_time, $module_interval);
return $nex_time - $cur_time;
}
@@ -55,7 +61,7 @@ function cron_next_execution ($cron) {
$count = 0;
$nex_time = $cur_time;
do {
- $nex_time = cron_next_execution_date ($cron, $nex_time);
+ $nex_time = cron_next_execution_date ($cron, $nex_time, $module_interval);
$nex_time_wd = $nex_time;
list ($nex_mon, $nex_wday) = explode (" ", date ("m w", $nex_time_wd));
@@ -80,90 +86,202 @@ function cron_next_execution ($cron) {
}
// Get the next execution date for the given cron entry in seconds since epoch.
-function cron_next_execution_date ($cron, $cur_time = false) {
+function cron_next_execution_date ($cron, $cur_time = false, $module_interval = 300) {
// Get cron configuration
- list ($min, $hour, $mday, $mon, $wday) = explode (" ", $cron);
-
+ $cron_array = explode (" ", $cron);
// Months start from 0
- if ($mon != '*') {
- $mon -= 1;
+ if ($cron_array[3] != '*') {
+ $mon_s = cron_get_interval ($cron_array[3]);
+ if ($mon_s['up'] !== false) {
+ $cron_array[3] = $mon_s['down'] - 1 . "-" . $mon_s['up'] - 1;
+ } else {
+ $cron_array[3] = $mon_s['down'] - 1;
+ }
}
// Get current time
- if ($cur_time === false) {
- $cur_time = time();
- }
- list ($cur_min, $cur_hour, $cur_mday, $cur_mon, $cur_year) = explode (" ", date ("i H d m Y", $cur_time));
+ if ($cur_time === false) $cur_time = time();
+
+ $nex_time = $cur_time + $module_interval;
+ $nex_time_array = explode (" ", date ("i H d m Y", $nex_time));
+ if (cron_is_in_cron($cron_array, $nex_time_array)) return $nex_time;
- // Get first next date candidate from cron configuration
- $nex_min = $min;
- $nex_hour = $hour;
- $nex_mday = $mday;
- $nex_mon = $mon;
- $nex_year = $cur_year;
+ // Get first next date candidate from next cron configuration
+ // Initialize some vars
+ $prev_ovfl = false;
+
+ // Update minutes
+ $min_s = cron_get_interval ($cron_array[0]);
+ $nex_time_array[0] = ($min_s['down'] == '*') ? 0 : $min_s['down'];
- // Replace wildcards
- if ($min == '*') {
- if ($hour != '*' || $mday != '*' || $wday != '*' || $mon != '*') {
- $nex_min = 0;
- }
- else {
- $nex_min = $cur_min;
+ $nex_time = cron_valid_date($nex_time_array);
+ if ($nex_time >= $cur_time) {
+ if (cron_is_in_cron($cron_array, $nex_time_array) && $nex_time) {
+ return $nex_time;
}
}
- if ($hour == '*') {
- if ($mday != '*' || $wday != '*' ||$mon != '*') {
- $nex_hour = 0;
- }
- else {
- $nex_hour = $cur_hour;
- }
- }
- if ($mday == '*') {
- if ($mon != '*') {
- $nex_mday = 1;
- }
- else {
- $nex_mday = $cur_mday;
- }
- }
- if ($mon == '*') {
- $nex_mon = $cur_mon;
- }
-
- // Find the next execution date
- $count = 0;
- do {
- $next_time = mktime($nex_hour, $nex_min, 0, $nex_mon, $nex_mday, $nex_year);
- if ($next_time > $cur_time) {
- return $next_time;
- }
- if ($min == '*' && $hour == '*' && $wday == '*' && $mday == '*' && $mon == '*') {
- list ($nex_min, $nex_hour, $nex_mday, $nex_mon, $nex_year) = explode (" ", date ("i H d m Y", $next_time + SECONDS_1MINUTE));
- }
- else if ($hour == '*' && $wday == '*' && $mday == '*' && $mon == '*') {
- list ($nex_min, $nex_hour, $nex_mday, $nex_mon, $nex_year) = explode (" ", date ("i H d m Y", $next_time + SECONDS_1HOUR));
- }
- else if ($mday == '*' && $mon == '*') {
- list ($nex_min, $nex_hour, $nex_mday, $nex_mon, $nex_year) = explode (" ", date ("i H d m Y", $next_time + SECONDS_1DAY));
- }
- else if ($mon == '*') {
- $nex_mon = $nex_mon + 1;
- if ($nex_mon > 11) {
- $nex_mon = 0;
- $nex_year++;
+
+ // Check if next hour is in cron
+ $nex_time_array[1]++;
+ $nex_time = cron_valid_date($nex_time_array);
+
+ if ($nex_time === false) {
+ // Update the month day if overflow
+ $prev_ovfl = true;
+ $nex_time_array[1] = 0;
+ $nex_time_array[2]++;
+ $nex_time = cron_valid_date($nex_time_array);
+ if ($nex_time === false) {
+ // Update the month if overflow
+ $nex_time_array[2] = 1;
+ $nex_time_array[3]++;
+ $nex_time = cron_valid_date($nex_time_array);
+ if ($nex_time === false) {
+ #Update the year if overflow
+ $nex_time_array[3] = 0;
+ $nex_time_array[4]++;
+ $nex_time = cron_valid_date($nex_time_array);
}
}
- else {
- $nex_year++;
- }
- $count++;
}
- while ($count < SECONDS_1DAY);
+ // Check the hour
+ if (cron_is_in_cron($cron_array, $nex_time_array) && $nex_time) {
+ return $nex_time;
+ }
+
+ // Update the hour if fails
+ $hour_s = cron_get_interval ($cron_array[1]);
+ $nex_time_array[1] = ($hour_s['down'] == '*') ? 0 : $hour_s['down'];
+
+ // When an overflow is passed check the hour update again
+ if ($prev_ovfl) {
+ $nex_time = cron_valid_date($nex_time_array);
+ if (cron_is_in_cron($cron_array, $nex_time_array) && $nex_time) {
+ return $nex_time;
+ }
+ }
+ $prev_ovfl = false;
+
+ // Check if next day is in cron
+ $nex_time_array[2]++;
+ $nex_time = cron_valid_date($nex_time_array);
+ if ($nex_time === false) {
+ // Update the month if overflow
+ $prev_ovfl = true;
+ $nex_time_array[2] = 1;
+ $nex_time_array[3]++;
+ $nex_time = cron_valid_date($nex_time_array);
+ if ($nex_time === false) {
+ // Update the year if overflow
+ $nex_time_array[3] = 0;
+ $nex_time_array[4]++;
+ $nex_time = cron_valid_date($nex_time_array);
+ }
+ }
+ // Check the day
+ if (cron_is_in_cron($cron_array, $nex_time_array) && $nex_time) {
+ return $nex_time;
+ }
+
+ // Update the day if fails
+ $mday_s = cron_get_interval ($cron_array[2]);
+ $nex_time_array[2] = ($mday_s['down'] == '*') ? 1 : $mday_s['down'];
+
+ // When an overflow is passed check the hour update in the next execution
+ if ($prev_ovfl) {
+ $nex_time = cron_valid_date($nex_time_array);
+ if (cron_is_in_cron($cron_array, $nex_time_array) && $nex_time) {
+ return $nex_time;
+ }
+ }
+ $prev_ovfl = false;
+
+ // Check if next month is in cron
+ $nex_time_array[3]++;
+ $nex_time = cron_valid_date($nex_time_array);
+ if ($nex_time === false) {
+ #Update the year if overflow
+ $prev_ovfl = true;
+ $nex_time_array[3]++;
+ $nex_time = cron_valid_date($nex_time_array);
+ }
+
+ // Check the month
+ if (cron_is_in_cron($cron_array, $nex_time_array) && $nex_time) {
+ return $nex_time;
+ }
+
+ // Update the month if fails
+ $mon_s = cron_get_interval ($cron_array[3]);
+ $nex_time_array[3] = ($mon_s['down'] == '*') ? 0 : $mon_s['down'];
+
+ // When an overflow is passed check the hour update in the next execution
+ if ($prev_ovfl) {
+ $nex_time = cron_valid_date($nex_time_array);
+ if (cron_is_in_cron($cron_array, $nex_time_array) && $nex_time) {
+ return $nex_time;
+ }
+ }
+
+ // Update the year
+ $nex_time_array[4]++;
+ $nex_time = cron_valid_date($nex_time_array);
+
+ return ($nex_time !== false) ? $nex_time : $module_interval;
+}
+
+// Get an array with the cron interval
+function cron_get_interval ($element) {
+ # Not a range
+ if (!preg_match('/(\d+)\-(\d+)/', $element, $capture)) {
+ return array(
+ 'down' => $element,
+ 'up' => false
+ );
+ }
+ return array(
+ 'down' => $capture[1],
+ 'up' => $capture[2]
+ );
+}
+
+// Returns if a date is in a cron. Recursive.
+function cron_is_in_cron($elems_cron, $elems_curr_time) {
- // Something went wrong, default to 5 minutes
- return $cur_time + SECONDS_5MINUTES;
+ $elem_cron = array_shift($elems_cron);
+ $elem_curr_time = array_shift($elems_curr_time);
+
+ // If there is no elements means that is in cron
+ if ($elem_cron === null || $elem_curr_time === null) return true;
+
+ // Go to last element if current is a wild card
+ if ($elem_cron != '*') {
+ $elem_s = cron_get_interval($elem_cron);
+ // Check if there is no a range
+ if (($elem_s['up'] === false) && ($elem_s['down'] != $elem_curr_time)) {
+ return false;
+ }
+ // Check if there is on the range
+ if ($elem_s['up'] !== false) {
+ if ($elem_s['down'] < $elem_s['up']) {
+ if ($elem_curr_time < $elem_s['down'] || $elem_curr_time > $elem_s['up']){
+ return false;
+ }
+ } else {
+ if ($elem_curr_time > $elem_s['down'] || $elem_curr_time < $elem_s['up']){
+ return false;
+ }
+ }
+ }
+ }
+ return cron_is_in_cron($elems_cron, $elems_curr_time);
+}
+
+function cron_valid_date ($da) {
+ $st = sprintf("%04d:%02d:%02d %02d:%02d:00", $da[4], $da[3], $da[2], $da[1], $da[0]);
+ $time = strtotime($st);
+ return $time;
}
// Check if cron is properly constructed
diff --git a/pandora_console/include/functions_db.php b/pandora_console/include/functions_db.php
index 06c85ef194..70395cb205 100644
--- a/pandora_console/include/functions_db.php
+++ b/pandora_console/include/functions_db.php
@@ -81,7 +81,7 @@ function db_connect($host = null, $db = null, $user = null, $pass = null, $port
$ownDir = dirname(__FILE__) . DIRECTORY_SEPARATOR;
$config['homedir'] = $ownDir;
$login_screen = 'error_authconfig';
- require($config['homedir'] . '/general/error_screen.php');
+ require($config['homedir'] . '../general/error_screen.php');
exit;
}
else if ($error == 0) {
diff --git a/pandora_console/include/functions_events.php b/pandora_console/include/functions_events.php
index 763f246bdf..58c11b1cc9 100644
--- a/pandora_console/include/functions_events.php
+++ b/pandora_console/include/functions_events.php
@@ -2080,7 +2080,7 @@ function events_page_details ($event, $server = "") {
}
else {
$module_group = db_get_value('name', 'tmodule_group', 'id_mg', $id_module_group);
- $data[1] = '';
+ $data[1] = ' ';
$data[1] .= $module_group;
$data[1] .= ' ';
}
diff --git a/pandora_console/include/functions_filemanager.php b/pandora_console/include/functions_filemanager.php
index 5e0ef6c718..a27d7d2ec2 100644
--- a/pandora_console/include/functions_filemanager.php
+++ b/pandora_console/include/functions_filemanager.php
@@ -151,7 +151,7 @@ if ($upload_file) {
check_login ();
- if (! check_acl ($config['id_user'], 0, "PM")) {
+ if (! check_acl ($config['id_user'], 0, "AW")) {
db_pandora_audit("ACL Violation", "Trying to access File manager");
require ("general/noaccess.php");
return;
@@ -219,7 +219,7 @@ if ($create_text_file) {
check_login ();
- if (! check_acl ($config['id_user'], 0, "PM")) {
+ if (! check_acl ($config['id_user'], 0, "AW")) {
db_pandora_audit("ACL Violation", "Trying to access File manager");
require ("general/noaccess.php");
return;
@@ -279,7 +279,7 @@ if ($upload_zip) {
check_login ();
- if (! check_acl ($config['id_user'], 0, "PM")) {
+ if (! check_acl ($config['id_user'], 0, "AW")) {
db_pandora_audit("ACL Violation", "Trying to access File manager");
require ("general/noaccess.php");
return;
@@ -720,6 +720,17 @@ function filemanager_file_explorer($real_directory, $relative_directory,
$hash = md5($relative_path . $config['dbpass']);
$data[1] = ''.$fileinfo['name'].' ';
}
+
+ // Notice that uploaded php files could be dangerous
+ if (pathinfo($fileinfo['realpath'], PATHINFO_EXTENSION) == 'php' &&
+ (is_readable($fileinfo['realpath']) || is_executable($fileinfo['realpath']))) {
+ $error_message = __('This file could be executed by any user');
+ $error_message .= '. ' . __('Make sure it can\'t perform dangerous tasks');
+ $data[1] = ''
+ . $data[1]
+ . ' ';
+ }
+
$data[2] = ui_print_timestamp ($fileinfo['last_modified'], true,
array ('prominent' => true));
if ($fileinfo['is_dir']) {
diff --git a/pandora_console/include/functions_graph.php b/pandora_console/include/functions_graph.php
index 9d66670864..3a063da403 100644
--- a/pandora_console/include/functions_graph.php
+++ b/pandora_console/include/functions_graph.php
@@ -232,8 +232,8 @@ function grafico_modulo_sparse_data_chart (&$chart, &$chart_data_extra, &$long_i
$projection, $avg_only = false, $uncompressed_module = false,
$show_events = false, $show_alerts = false, $show_unknown = false, $baseline = false,
$baseline_data = array(), $events = array(), $series_suffix = '', $start_unknown = false,
- $percentil = null, $fullscale = false) {
-
+ $percentil = null, $fullscale = false, $force_interval = false,$time_interval = 300,
+ $max_only = 0, $min_only = 0) {
global $config;
global $chart_extra_data;
global $series_type;
@@ -413,10 +413,17 @@ function grafico_modulo_sparse_data_chart (&$chart, &$chart_data_extra, &$long_i
}
if ($count > 0) {
+
if ($avg_only) {
$chart[$timestamp]['sum'.$series_suffix] = $total;
}
- else {
+ else if($max_only){
+ $chart[$timestamp]['max'.$series_suffix] = $interval_max;
+ }
+ else if($min_only){
+ $chart[$timestamp]['min'.$series_suffix] = $interval_min;
+ }
+ else{
$chart[$timestamp]['max'.$series_suffix] = $interval_max;
$chart[$timestamp]['sum'.$series_suffix] = $total;
$chart[$timestamp]['min'.$series_suffix] = $interval_min;
@@ -428,7 +435,13 @@ function grafico_modulo_sparse_data_chart (&$chart, &$chart_data_extra, &$long_i
if ($avg_only) {
$chart[$timestamp]['sum'.$series_suffix] = 0;
}
- else {
+ else if($max_only){
+ $chart[$timestamp]['max'.$series_suffix] = 0;
+ }
+ else if($min_only){
+ $chart[$timestamp]['min'.$series_suffix] = 0;
+ }
+ else{
$chart[$timestamp]['max'.$series_suffix] = 0;
$chart[$timestamp]['sum'.$series_suffix] = 0;
$chart[$timestamp]['min'.$series_suffix] = 0;
@@ -438,6 +451,12 @@ function grafico_modulo_sparse_data_chart (&$chart, &$chart_data_extra, &$long_i
if ($avg_only) {
$chart[$timestamp]['sum'.$series_suffix] = $last_known;
}
+ else if ($max_only) {
+ $chart[$timestamp]['max'.$series_suffix] = $last_known;
+ }
+ else if ($min_only) {
+ $chart[$timestamp]['min'.$series_suffix] = $last_known;
+ }
else {
$chart[$timestamp]['max'.$series_suffix] = $last_known;
$chart[$timestamp]['sum'.$series_suffix] = $last_known;
@@ -502,8 +521,9 @@ function grafico_modulo_sparse_data ($agent_module_id, $period, $show_events,
$baseline = 0, $return_data = 0, $show_title = true, $projection = false,
$adapt_key = '', $compare = false, $series_suffix = '', $series_suffix_str = '',
$show_unknown = false, $percentil = null, $dashboard = false, $vconsole = false,
- $type_graph='area', $fullscale = false, $flash_chart = false) {
-
+ $type_graph='area', $fullscale = false, $flash_chart = false, $force_interval = false,$time_interval = 300,
+ $max_only = 0, $min_only = 0) {
+
global $config;
global $chart;
global $color;
@@ -529,8 +549,23 @@ function grafico_modulo_sparse_data ($agent_module_id, $period, $show_events,
if ($date == 0) $date = get_system_time();
$datelimit = $date - $period;
$search_in_history_db = db_search_in_history_db($datelimit);
- $resolution = $config['graph_res'] * 50; //Number of points of the graph
- $interval = (int) ($period / $resolution);
+
+
+
+ if($force_interval){
+ $resolution = $period/$time_interval;
+ }
+ else{
+ $resolution = $config['graph_res'] * 50; //Number of points of the graph
+ }
+
+ if($force_interval){
+ $interval = $time_interval;
+ }
+ else{
+ $interval = (int) ($period / $resolution);
+ }
+
$agent_name = modules_get_agentmodule_agent_name ($agent_module_id);
$agent_id = agents_get_agent_id ($agent_name);
$module_name = modules_get_agentmodule_name ($agent_module_id);
@@ -718,7 +753,8 @@ function grafico_modulo_sparse_data ($agent_module_id, $period, $show_events,
$projection, $avg_only, $uncompressed_module,
$show_events, $show_alerts, $show_unknown, $baseline,
$baseline_data, $events, $series_suffix, $start_unknown,
- $percentil, $fullscale);
+ $percentil, $fullscale, $force_interval, $time_interval,
+ $max_only, $min_only);
}
// Return chart data and don't draw
@@ -843,6 +879,19 @@ function grafico_modulo_sparse_data ($agent_module_id, $period, $show_events,
$legend['percentil'.$series_suffix] = __('Percentile %dº', $percentil) .$series_suffix_str . " (" . $percentil_value . " " . $unit . ") ";
$chart_extra_data['legend_percentil'] = $legend['percentil'.$series_suffix_str];
}
+
+ if($force_interval){
+ $legend = array();
+ if($avg_only){
+ $legend['sum'.$series_suffix] = __('Avg');
+ }
+ elseif ($max_only) {
+ $legend['min'.$series_suffix] = __('Max');
+ }
+ elseif ($min_only) {
+ $legend['max'.$series_suffix] = __('Min');
+ }
+ }
}
function grafico_modulo_sparse ($agent_module_id, $period, $show_events,
@@ -853,8 +902,10 @@ function grafico_modulo_sparse ($agent_module_id, $period, $show_events,
$adapt_key = '', $compare = false, $show_unknown = false,
$menu = true, $backgroundColor = 'white', $percentil = null,
$dashboard = false, $vconsole = false, $type_graph = 'area', $fullscale = false,
- $id_widget_dashboard = false) {
-
+ $id_widget_dashboard = false,$force_interval = 0,$time_interval = 300,
+ $max_only = 0, $min_only = 0) {
+
+
global $config;
global $graphic_type;
@@ -884,7 +935,7 @@ function grafico_modulo_sparse ($agent_module_id, $period, $show_events,
$return_data, $show_title, $projection, $adapt_key,
$compare, $series_suffix, $series_suffix_str,
$show_unknown, $percentil, $dashboard, $vconsole,$type_graph,
- $fullscale, $flash_chart);
+ $fullscale, $flash_chart,$force_interval,$time_interval,$max_only,$min_only);
switch ($compare) {
case 'separated':
@@ -917,7 +968,9 @@ function grafico_modulo_sparse ($agent_module_id, $period, $show_events,
$show_alerts, $avg_only,
$date, $unit, $baseline, $return_data, $show_title,
$projection, $adapt_key, $compare, '', '', $show_unknown,
- $percentil, $dashboard, $vconsole, $type_graph, $fullscale, $flash_chart);
+ $percentil, $dashboard, $vconsole, $type_graph, $fullscale,$flash_chart,
+ $force_interval,$time_interval,$max_only,$min_only);
+
if ($return_data) {
return $data_returned;
}
@@ -1069,6 +1122,7 @@ function graphic_combined_module ($module_list, $weight_list, $period,
if(!$fullscale){
$time_format_2 = '';
$temp_range = $period;
+ $unit_list_aux = array();
if ($projection != false) {
if ($period < $prediction_period)
@@ -1317,6 +1371,10 @@ function graphic_combined_module ($module_list, $weight_list, $period,
$agent_id = agents_get_agent_id ($agent_name);
+ if(empty($unit_list)){
+ $unit_aux = modules_get_unit($agent_module_id);
+ array_push($unit_list_aux,$unit_aux);
+ }
//Get and process module name
$module_name = io_safe_output(
modules_get_agentmodule_name ($agent_module_id));
@@ -1500,6 +1558,8 @@ function graphic_combined_module ($module_list, $weight_list, $period,
if (!empty($unit_list) && $units_number == $module_number && isset($unit_list[$i])) {
$unit = $unit_list[$i];
+ }else{
+ $unit = $unit_list_aux[$i];
}
if ($projection == false or ($projection != false and $i == 0)) {
@@ -2107,19 +2167,19 @@ function graphic_combined_module ($module_list, $weight_list, $period,
$width, $height, $color, $module_name_list, $long_index,
ui_get_full_url("images/image_problem_area_small.png", false, false, false),
"", "", $water_mark, $config['fontpath'], $fixed_font_size,
- "", $ttl, $homeurl, $background_color);
+ "", $ttl, $homeurl, $background_color, 'black');
break;
case CUSTOM_GRAPH_VBARS:
return vbar_graph($flash_charts, $graph_values,
$width, $height, $color, $module_name_list, $long_index,
ui_get_full_url("images/image_problem_area_small.png", false, false, false),
"", "", $water_mark, $config['fontpath'], $fixed_font_size,
- "", $ttl, $homeurl, $background_color, true);
+ "", $ttl, $homeurl, $background_color, true, false, "black");
break;
case CUSTOM_GRAPH_PIE:
return ring_graph($flash_charts, $graph_values, $width, $height,
$others_str, $homeurl, $water_mark, $config['fontpath'],
- ($config['font_size']+1), $ttl, false, $color, false);
+ ($config['font_size']+1), $ttl, false, $color, false,$background_color);
break;
}
}
@@ -2457,10 +2517,10 @@ function progress_bar($progress, $width, $height, $title = '', $mode = 1, $value
require_once("include_graph_dependencies.php");
include_graphs_dependencies($config['homedir'].'/');
$src = ui_get_full_url(
- "/include/graphs/fgraph.php?homeurl=../../&graph_type=progressbar" .
- "&width=".$width."&homedir=".$config['homedir']."&height=".$height."&progress=".$progress.
+ "/include/graphs/fgraph.php?graph_type=progressbar" .
+ "&width=".$width."&height=".$height."&progress=".$progress.
"&mode=" . $mode . "&out_of_lim_str=".$out_of_lim_str .
- "&title=".$title."&font=".$config['fontpath']."&value_text=". $value_text .
+ "&title=".$title."&value_text=". $value_text .
"&colorRGB=". $colorRGB, false, false, false
);
@@ -2492,10 +2552,10 @@ function progress_bubble($progress, $width, $height, $title = '', $mode = 1, $va
include_graphs_dependencies($config['homedir'].'/');
return " ";
}
@@ -2779,7 +2839,9 @@ function grafico_db_agentes_paquetes($width = 380, $height = 300) {
return hbar_graph($config['flash_charts'], $data, $width, $height, array(),
$legend, "", "", true, "", $water_mark,
- $config['fontpath'], $config['font_size'], false);
+ $config['fontpath'], $config['font_size'], false, 1, $config['homeurl'],
+ 'white',
+ 'black');
}
/**
@@ -2846,7 +2908,9 @@ function graph_db_agentes_modulos($width, $height) {
$data, $width, $height, array(),
array(), "", "", true, "",
$water_mark,
- $config['fontpath'], $config['font_size'], false);
+ $config['fontpath'], $config['font_size'], false, 1, $config['homeurl'],
+ 'white',
+ 'black');
}
/**
@@ -3621,12 +3685,14 @@ function graph_custom_sql_graph ($id, $width, $height,
case 'sql_graph_vbar': // vertical bar
return vbar_graph($flash_charts, $data, $width, $height, array(),
array(), "", "", $homeurl, $water_mark,
- $config['fontpath'], $config['font_size'], false, $ttl);
+ $config['fontpath'], $config['font_size'], false, $ttl, "", "white", false, false, "black");
break;
case 'sql_graph_hbar': // horizontal bar
return hbar_graph($flash_charts, $data, $width, $height, array(),
array(), "", "", true, $homeurl, $water_mark,
- $config['fontpath'], $config['font_size'], false, $ttl);
+ $config['fontpath'], $config['font_size'], false, $ttl,$config['homeurl'],
+ 'white',
+ 'black');
break;
case 'sql_graph_pie': // Pie
return pie3d_graph($flash_charts, $data, $width, $height, __("other"), $homeurl,
@@ -5743,17 +5809,40 @@ function graph_monitor_wheel ($width = 550, $height = 600, $filter = false) {
$filter_module_group = (!empty($filter) && !empty($filter['module_group'])) ? $filter['module_group'] : false;
- $groups = users_get_groups(false, "AR", false, true, (!empty($filter) && isset($filter['group']) ? $filter['group'] : null));
+ if ($filter['group'] != 0) {
+ $groups = db_get_all_rows_sql ("SELECT * FROM tgrupo where id_grupo = " . $filter['group'] . " || parent = " . $filter['group']);
+ $groups_ax = array();
+ foreach ($groups as $g) {
+ $groups_ax[$g['id_grupo']] = $g;
+ }
+
+ $groups = $groups_ax;
+ }
+ else {
+ $groups = users_get_groups(false, "AR", false, true, (!empty($filter) && isset($filter['group']) ? $filter['group'] : null));
+ }
+
$data_groups = array();
if (!empty($groups)) {
$groups_aux = $groups;
- $data_groups = groups_get_tree($groups);
+
+ //$data_groups = groups_get_tree($groups);
+
+ $childrens = array();
+ $data_groups = groups_get_tree_good($groups, false, $childrens);
+ foreach ($childrens as $id_c) {
+ unset($data_groups[$id_c]);
+ }
+ $data_groups_keys = array();
+ groups_get_tree_keys($data_groups, $data_groups_keys);
+
$groups_aux = null;
}
if (!empty($data_groups)) {
- $filter = array('id_grupo' => array_keys($data_groups));
+ $filter = array('id_grupo' => array_keys($data_groups_keys));
+
$fields = array('id_agente', 'id_parent', 'id_grupo', 'alias');
$agents = agents_get_agents($filter, $fields);
@@ -5970,7 +6059,6 @@ function graph_monitor_wheel ($width = 550, $height = 600, $filter = false) {
}
function iterate_group_array ($groups, &$data_agents) {
-
$data = array();
foreach ($groups as $id => $group) {
@@ -6007,8 +6095,8 @@ function graph_monitor_wheel ($width = 550, $height = 600, $filter = false) {
$tooltip_content = html_print_image("images/groups_small/" . $group['icon'] . ".png", true) . " " . __('Group') . ": " . $group_aux['name'] . " ";
$group_aux['tooltip_content'] = $tooltip_content;
- if (!isset($group['children']))
- $group_aux['children'] = array();
+ $group_aux['children'] = array();
+
if (!empty($group['children']))
$group_aux['children'] = iterate_group_array($group['children'], $data_agents);
@@ -6016,7 +6104,7 @@ function graph_monitor_wheel ($width = 550, $height = 600, $filter = false) {
if (!empty($agents))
$group_aux['children'] = array_merge($group_aux['children'], $agents);
-
+
$data[] = $group_aux;
}
@@ -6031,6 +6119,7 @@ function graph_monitor_wheel ($width = 550, $height = 600, $filter = false) {
unset($agents[$id]);
}
}
+
if (!empty($valid_agents))
return $valid_agents;
else
@@ -6038,7 +6127,7 @@ function graph_monitor_wheel ($width = 550, $height = 600, $filter = false) {
}
$graph_data = array('name' => __('Main node'), 'children' => iterate_group_array($data_groups, $data_agents), 'color' => '#3F3F3F');
-
+
if (empty($graph_data['children']))
return fs_error_image();
diff --git a/pandora_console/include/functions_groups.php b/pandora_console/include/functions_groups.php
index 757e5014d5..db046c09be 100644
--- a/pandora_console/include/functions_groups.php
+++ b/pandora_console/include/functions_groups.php
@@ -2241,6 +2241,9 @@ function groups_get_tree(&$groups, $parent = false) {
if (!empty($children)) {
$return[$id]['children'] = $children;
}
+ else {
+ $return[$id]['children'] = array();
+ }
}
else if ($parent && isset($group['parent']) && $group['parent'] == $parent) {
$return[$id] = $group;
@@ -2250,6 +2253,9 @@ function groups_get_tree(&$groups, $parent = false) {
if (!empty($children)) {
$return[$id]['children'] = $children;
}
+ else {
+ $return[$id]['children'] = array();
+ }
}
else {
continue;
@@ -2258,6 +2264,55 @@ function groups_get_tree(&$groups, $parent = false) {
return $return;
}
+
+function groups_get_tree_good (&$groups, $parent = false, &$childs) {
+ $return = array();
+
+ foreach ($groups as $id => $group) {
+ if ($group['parent'] != 0) {
+ $childs[$id] = $id;
+ }
+ if ($parent === false && (!isset($group['parent']) || $group['parent'] == 0 || !in_array($group['parent'], $groups))) {
+ $return[$id] = $group;
+ //unset($groups[$id]);
+ $children = groups_get_tree_good($groups, $id);
+
+ if (!empty($children)) {
+ $return[$id]['children'] = $children;
+ }
+ else {
+ $return[$id]['children'] = array();
+ }
+ }
+ else if ($parent && isset($group['parent']) && $group['parent'] == $parent) {
+ $return[$id] = $group;
+ //unset($groups[$id]);
+ $children = groups_get_tree_good($groups, $id);
+
+ if (!empty($children)) {
+ $return[$id]['children'] = $children;
+ }
+ else {
+ $return[$id]['children'] = array();
+ }
+ }
+ else {
+ continue;
+ }
+ }
+
+ return $return;
+}
+
+function groups_get_tree_keys ($groups, &$group_keys) {
+ foreach ($groups as $id => $group) {
+ $group_keys[$id] = $id;
+ if (isset($group['children'])) {
+ groups_get_tree_keys($groups[$id]['children'], $group_keys);
+ }
+ }
+}
+
function groups_get_all_hierarchy_group ($id_group, $hierarchy = array()) {
global $config;
@@ -2289,6 +2344,8 @@ function groups_get_all_hierarchy_group ($id_group, $hierarchy = array()) {
return $hierarchy;
}
+
+
function group_get_data ($id_user = false, $user_strict = false, $acltags, $returnAllGroup = false, $mode = 'group', $agent_filter = array(), $module_filter = array()) {
global $config;
if ($id_user == false) {
@@ -3036,4 +3093,5 @@ function groups_get_group_deep ($id_group) {
return $deep;
}
+
?>
diff --git a/pandora_console/include/functions_modules.php b/pandora_console/include/functions_modules.php
index bcdeb6819c..e46334dbef 100755
--- a/pandora_console/include/functions_modules.php
+++ b/pandora_console/include/functions_modules.php
@@ -987,6 +987,28 @@ function modules_is_string($id_agentmodule) {
return modules_is_string_type($id_type);
}
+
+/**
+ * Know if a module type is a boolean or not
+ *
+ * @param int $id_type Type id
+ *
+ * @return bool true if boolean. false if not
+ */
+function modules_is_boolean_type ($id_type) {
+ $type_name = modules_get_type_name($id_type);
+
+ return (bool)preg_match('/_proc$/', $type_name);
+}
+
+function modules_is_boolean($id_agentmodule) {
+ $id_type = db_get_value('id_tipo_modulo',
+ 'tagente_modulo', 'id_agente_modulo',
+ (int) $id_agentmodule);
+
+ return modules_is_boolean_type($id_type);
+}
+
/**
* Get the icon of a module type
*
@@ -1716,11 +1738,19 @@ function modules_get_next_data ($id_agent_module, $utimestamp = 0, $string = 0)
* @param int Agent module id
* @param int Period of time to check (in seconds)
* @param int Top date to check the values. Default current time.
+ * @param
+ * @param
+ * @param string 'ASC' od 'DESC'
+ * @param string with a json with parameters to filter data
+ * string object:
+ * value: Text to search
+ * exact: Boolean. True if search exact phrase or false to content
*
* @return array The module value and the timestamp
*/
function modules_get_agentmodule_data ($id_agent_module, $period,
- $date = 0, $trash=false, $conexion = false, $order = 'ASC') {
+ $date = 0, $trash=false, $conexion = false, $order = 'ASC',
+ $freesearch = '') {
global $config;
$module = db_get_row('tagente_modulo', 'id_agente_modulo',
@@ -1742,12 +1772,28 @@ function modules_get_agentmodule_data ($id_agent_module, $period,
case 17:
//async_string
case 23:
- $sql = sprintf ("SELECT datos AS data, utimestamp
- FROM tagente_datos_string
- WHERE id_agente_modulo = %d
- AND utimestamp > %d AND utimestamp <= %d
- ORDER BY utimestamp %s",
- $id_agent_module, $datelimit, $date, $order);
+ // Free search is a json with value and exact modifier
+ $freesearch = json_decode($freesearch, true);
+ $freesearch_sql = '';
+ if (isset($freesearch['value']) && !empty($freesearch['value'])) {
+ $freesearch_sql = " AND datos ";
+ if ($freesearch['exact']){
+ $freesearch_sql .= "='" . $freesearch['value'] . "' ";
+ } else {
+ $freesearch_sql .= " LIKE '%" . $freesearch['value'] . "%' ";
+ }
+ }
+ $sql = sprintf (
+ "SELECT datos AS data, utimestamp FROM tagente_datos_string
+ WHERE id_agente_modulo = %d
+ %s
+ AND utimestamp > %d AND utimestamp <= %d
+ ORDER BY utimestamp %s",
+ $id_agent_module,
+ $freesearch_sql,
+ $datelimit, $date,
+ $order
+ );
break;
//log4x
case 24:
diff --git a/pandora_console/include/functions_networkmap.php b/pandora_console/include/functions_networkmap.php
index e1417ceec1..b88fb07510 100644
--- a/pandora_console/include/functions_networkmap.php
+++ b/pandora_console/include/functions_networkmap.php
@@ -254,7 +254,7 @@ function networkmap_generate_dot ($pandora_name, $group = 0,
$id_networkmap = 0, $show_snmp_modules = 0, $cut_names = true,
$relative = false, $text_filter = '', $ip_mask = null,
$dont_show_subgroups = false, $strict_user = false, $size_canvas = null,
- $old_mode = false) {
+ $old_mode = false, $map_filter = array()) {
global $config;
$nooverlap = 1;
@@ -361,7 +361,7 @@ function networkmap_generate_dot ($pandora_name, $group = 0,
// Open Graph
$graph = networkmap_open_graph ($layout, $nooverlap, $pure, $zoom,
- $ranksep, $font_size, $size_canvas);
+ $ranksep, $font_size, $size_canvas, $map_filter);
// Parse agents
$nodes = array ();
@@ -1111,7 +1111,7 @@ function networkmap_create_agent_node ($agent, $simple = 0, $font_size = 10, $cu
}
$node = "\n" . $agent['id_node'].' [ parent="' . $agent['id_parent'] . '", color="'.$status_color.'", fontsize='.$font_size.', style="filled", fixedsize=true, width=0.40, height=0.40, label=<' . $img_node . '
- '.io_safe_output($name).'
>,
+ '.io_safe_input($name).' >,
shape="doublecircle", URL="'.$url.'",
tooltip="' . $url_tooltip . '"];' . "\n";
}
@@ -1396,7 +1396,7 @@ function networkmap_close_group () {
// Opens a graph definition
function networkmap_open_graph ($layout, $nooverlap, $pure, $zoom,
- $ranksep, $font_size, $size_canvas) {
+ $ranksep, $font_size, $size_canvas, $map_filter = array()) {
global $config;
@@ -1412,42 +1412,79 @@ function networkmap_open_graph ($layout, $nooverlap, $pure, $zoom,
$size = '';
}
-
- if ($layout == 'radial') {
- $overlap = 'true';
- }
-
- if ($layout == 'flat' || $layout == 'radial' || $layout == 'spring1' || $layout == "spring2") {
- if ($nooverlap != '') {
- $overlap = 'scalexy';
- }
- }
-
if ($zoom > 0) {
$size_x *= $zoom;
$size_y *= $zoom;
}
+
$size = $size_x . ',' . $size_y;
if (!is_null($size_canvas)) {
$size = ($size_canvas['x'] / 100) . "," . ($size_canvas['y'] / 100);
}
-
+
+ // Graphviz custom values
+ if (isset($map_filter['node_sep'])) {
+ $node_sep = $map_filter['node_sep'];
+ }
+ else {
+ $node_sep = 0.25;
+ }
+ if (isset($map_filter['rank_sep'])) {
+ $rank_sep = $map_filter['rank_sep'];
+ }
+ else {
+ if ($layout == "radial") {
+ $rank_sep = 1.0;
+ }
+ else {
+ $rank_sep = 0.5;
+ }
+ }
+ if (isset($map_filter['mindist'])) {
+ $mindist = $map_filter['mindist'];
+ }
+ else {
+ $mindist = 1.0;
+ }
+ if (isset($map_filter['kval'])) {
+ $kval = $map_filter['kval'];
+ }
+ else {
+ $kval = 0.3;
+ }
+
// BEWARE: graphwiz DONT use single ('), you need double (")
$head = "graph networkmap { dpi=100; bgcolor=\"transparent\"; labeljust=l; margin=0; pad=\"0.75,0.75\";";
if ($nooverlap != '') {
- $head .= "overlap=\"$overlap\";";
- $head .= "ranksep=\"$ranksep\";";
+ $head .= "overlap=\"false\";";
$head .= "outputorder=edgesfirst;";
}
+
+ if ($layout == 'flat' || $layout == 'spring1' || $layout == "spring2") {
+ if ($nooverlap != '') {
+ $head .= "overlap=\"scalexy\";";
+ }
+ if ($layout == 'flat') {
+ $head .= "ranksep=\"$rank_sep\";";
+ }
+ if ($layout == 'spring2') {
+ $head .= "K=\"$kval\";";
+ }
+ }
+ if ($layout == 'radial') {
+ $head .= "ranksep=\"$rank_sep\";";
+ }
+ if ($layout == 'circular') {
+ $head .= "mindist=\"$mindist\";";
+ }
$head .= "ratio=fill;";
$head .= "root=0;";
- $head .= "nodesep=\"0.02\";";
+ $head .= "nodesep=\"$node_sep\";";
$head .= "size=\"$size\";";
$head .= "\n";
-
return $head;
}
diff --git a/pandora_console/include/functions_pandora_networkmap.php b/pandora_console/include/functions_pandora_networkmap.php
index 0bbb4dd124..4058294bbe 100644
--- a/pandora_console/include/functions_pandora_networkmap.php
+++ b/pandora_console/include/functions_pandora_networkmap.php
@@ -43,7 +43,7 @@ function networkmap_process_networkmap($id = 0) {
$networkmap = db_get_row_filter('tmap',
array('id' => $id));
- $filter = json_decode($networkmap['filter'], true);
+ $map_filter = json_decode($networkmap['filter'], true);
$pure = (int)get_parameter('pure', 0);
@@ -95,181 +95,316 @@ function networkmap_process_networkmap($id = 0) {
}
$nodes_and_relations = array();
-
+
if (enterprise_installed() && ($numNodes > 0)) {
$nodes_and_relations = get_structure_nodes($id);
}
else {
- // Generate dot file
- $graph = networkmap_generate_dot (__('Pandora FMS'),
- $id_group,
- $simple,
- $font_size,
- $layout,
- $nooverlap,
- $zoom,
- $ranksep,
- $center,
- $regen,
- $pure,
- $id,
- $show_snmp_modules,
- false, //cut_names
- true, // relative
- '',
- $ip_mask,
- $dont_show_subgroups,
- false,
- null,
- $old_mode);
-
- switch (PHP_OS) {
- case "WIN32":
- case "WINNT":
- case "Windows":
- $filename_dot = sys_get_temp_dir() . "\\networkmap_" . $filter;
- break;
- default:
- $filename_dot = sys_get_temp_dir() . "/networkmap_" . $filter;
- break;
- }
-
- if ($simple) {
- $filename_dot .= "_simple";
- }
- if ($nooverlap) {
- $filename_dot .= "_nooverlap";
- }
- $filename_dot .= "_" . $id . ".dot";
+ if ($map_filter['empty_map']) {
+ // Open Graph
+ $graph = networkmap_open_graph ($layout, $nooverlap, $pure, $zoom,
+ $ranksep, $font_size, null);
+ $graph .= networkmap_create_pandora_node (__('Pandora FMS'), $font_size, $simple);
+ $graph .= networkmap_close_graph ();
- file_put_contents($filename_dot, $graph);
+ switch (PHP_OS) {
+ case "WIN32":
+ case "WINNT":
+ case "Windows":
+ $filename_dot = sys_get_temp_dir() . "\\networkmap_" . $filter;
+ break;
+ default:
+ $filename_dot = sys_get_temp_dir() . "/networkmap_" . $filter;
+ break;
+ }
+
+ if ($simple) {
+ $filename_dot .= "_simple";
+ }
+ if ($nooverlap) {
+ $filename_dot .= "_nooverlap";
+ }
+ $filename_dot .= "_" . $id . ".dot";
- switch (PHP_OS) {
- case "WIN32":
- case "WINNT":
- case "Windows":
- $filename_plain = sys_get_temp_dir() . "\\plain.txt";
-
- $cmd = io_safe_output($config['graphviz_bin_dir'] . "\\$filter.exe -Tplain -o " . $filename_plain . " " .
- $filename_dot);
- break;
- default:
- $filename_plain = sys_get_temp_dir() . "/plain.txt";
+ file_put_contents($filename_dot, $graph);
- $cmd = "$filter -Tplain -o " . $filename_plain . " " .
- $filename_dot;
- break;
- }
+ switch (PHP_OS) {
+ case "WIN32":
+ case "WINNT":
+ case "Windows":
+ $filename_plain = sys_get_temp_dir() . "\\plain.txt";
+
+ $cmd = io_safe_output($config['graphviz_bin_dir'] . "\\$filter.exe -Tplain -o " . $filename_plain . " " .
+ $filename_dot);
+ break;
+ default:
+ $filename_plain = sys_get_temp_dir() . "/plain.txt";
- system ($cmd);
-
- unlink($filename_dot);
-
- $nodes = networkmap_loadfile($id, $filename_plain,
- $relation_nodes, $graph);
-
- unlink($filename_plain);
+ $cmd = "$filter -Tplain -o " . $filename_plain . " " .
+ $filename_dot;
+ break;
+ }
- //Set the position of modules
- foreach ($nodes as $key => $node) {
- if ($node['type'] == 'module') {
- //Search the agent of this module for to get the
- //position
- foreach ($nodes as $key2 => $node2) {
- if ($node2['id_agent'] != 0 && $node2['type'] == 'agent') {
- if ($node2['id_agent'] == $node['id_agent']) {
- $nodes[$key]['coords'][0] =
- $nodes[$key2]['coords'][0] + $node['height'] / 2;
- $nodes[$key]['coords'][1] =
- $nodes[$key2]['coords'][1] + $node['width'] / 2;
+ system ($cmd);
+
+ unlink($filename_dot);
+
+ $nodes = networkmap_loadfile($id, $filename_plain,
+ $relation_nodes, $graph);
+
+ unlink($filename_plain);
+
+ //Set the position of modules
+ foreach ($nodes as $key => $node) {
+ if ($node['type'] == 'module') {
+ //Search the agent of this module for to get the
+ //position
+ foreach ($nodes as $key2 => $node2) {
+ if ($node2['id_agent'] != 0 && $node2['type'] == 'agent') {
+ if ($node2['id_agent'] == $node['id_agent']) {
+ $nodes[$key]['coords'][0] =
+ $nodes[$key2]['coords'][0] + $node['height'] / 2;
+ $nodes[$key]['coords'][1] =
+ $nodes[$key2]['coords'][1] + $node['width'] / 2;
+ }
}
}
}
}
+
+ $nodes_and_relations['nodes'] = array();
+ $index = 0;
+ foreach ($nodes as $key => $node) {
+ $nodes_and_relations['nodes'][$index]['id_map'] = $id;
+
+ $nodes_and_relations['nodes'][$index]['x'] = (int)$node['coords'][0];
+ $nodes_and_relations['nodes'][$index]['y'] = (int)$node['coords'][1];
+
+ if (($node['type'] == 'agent') || ($node['type'] == '')) {
+ $nodes_and_relations['nodes'][$index]['source_data'] = $node['id_agent'];
+ $nodes_and_relations['nodes'][$index]['type'] = 0;
+ }
+ else {
+ $nodes_and_relations['nodes'][$index]['source_data'] = $node['id_module'];
+ $nodes_and_relations['nodes'][$index]['id_agent'] = $node['id_agent'];
+ $nodes_and_relations['nodes'][$index]['type'] = 1;
+ }
+
+ $style = array();
+ $style['shape'] = 'circle';
+ $style['image'] = $node['image'];
+ $style['width'] = $node['width'];
+ $style['height'] = $node['height'];
+ $style['label'] = $node['text'];
+ $style['id_networkmap'] = $node['networkmap'];
+ $nodes_and_relations['nodes'][$index]['style'] = json_encode($style);
+
+ $index++;
+ }
+
+ $nodes_and_relations['relations'] = array();
+
+ if (enterprise_installed()) {
+ enterprise_include_once("include/functions_pandora_networkmap.php");
+ save_generate_nodes($id, $nodes_and_relations);
+ }
+ }
+ else {
+ // Generate dot file
+ $graph = networkmap_generate_dot (__('Pandora FMS'),
+ $id_group,
+ $simple,
+ $font_size,
+ $layout,
+ $nooverlap,
+ $zoom,
+ $ranksep,
+ $center,
+ $regen,
+ $pure,
+ $id,
+ $show_snmp_modules,
+ false, //cut_names
+ true, // relative
+ '',
+ $ip_mask,
+ $dont_show_subgroups,
+ false,
+ null,
+ $old_mode,
+ $map_filter);
+
+ switch (PHP_OS) {
+ case "WIN32":
+ case "WINNT":
+ case "Windows":
+ $filename_dot = sys_get_temp_dir() . "\\networkmap_" . $filter;
+ break;
+ default:
+ $filename_dot = sys_get_temp_dir() . "/networkmap_" . $filter;
+ break;
+ }
+
+ if ($simple) {
+ $filename_dot .= "_simple";
+ }
+ if ($nooverlap) {
+ $filename_dot .= "_nooverlap";
+ }
+ $filename_dot .= "_" . $id . ".dot";
+
+ file_put_contents($filename_dot, $graph);
+
+ switch (PHP_OS) {
+ case "WIN32":
+ case "WINNT":
+ case "Windows":
+ $filename_plain = sys_get_temp_dir() . "\\plain.txt";
+
+ $cmd = io_safe_output($config['graphviz_bin_dir'] . "\\$filter.exe -Tplain -o " . $filename_plain . " " .
+ $filename_dot);
+ break;
+ default:
+ $filename_plain = sys_get_temp_dir() . "/plain.txt";
+
+ $cmd = "$filter -Tplain -o " . $filename_plain . " " .
+ $filename_dot;
+ break;
+ }
+
+ system ($cmd);
+
+ unlink($filename_dot);
+
+ $nodes = networkmap_loadfile($id, $filename_plain,
+ $relation_nodes, $graph);
+
+ unlink($filename_plain);
+
+ //Set the position of modules
+ foreach ($nodes as $key => $node) {
+ if ($node['type'] == 'module') {
+ //Search the agent of this module for to get the
+ //position
+ foreach ($nodes as $key2 => $node2) {
+ if ($node2['id_agent'] != 0 && $node2['type'] == 'agent') {
+ if ($node2['id_agent'] == $node['id_agent']) {
+ $nodes[$key]['coords'][0] =
+ $nodes[$key2]['coords'][0] + $node['height'] / 2;
+ $nodes[$key]['coords'][1] =
+ $nodes[$key2]['coords'][1] + $node['width'] / 2;
+ }
+ }
+ }
+ }
+ }
+
+ $nodes_and_relations['nodes'] = array();
+ $index = 0;
+ $node_center = array();
+ foreach ($nodes as $key => $node) {
+ $nodes_and_relations['nodes'][$index]['id_map'] = $id;
+
+ $children_count = 0;
+ foreach ($relation_nodes as $relation) {
+ if (($relation['parent_type'] == 'agent') || ($relation['parent_type'] == '')) {
+ if ($nodes[$relation['id_parent']]['id_agent'] == $node['id_agent']) {
+ $children_count++;
+ }
+ }
+ else if ($relation['parent_type'] == 'module') {
+ if ($nodes[$relation['id_parent']]['id_module'] == $node['id_module']) {
+ $children_count++;
+ }
+ }
+
+ }
+
+ if (empty($node_center) || $node_center['counter'] < $children_count) {
+ $node_center['x'] = (int)$node['coords'][0];
+ $node_center['y'] = (int)$node['coords'][1];
+ $node_center['counter'] = $children_count;
+ }
+
+ $nodes_and_relations['nodes'][$index]['x'] = (int)$node['coords'][0];
+ $nodes_and_relations['nodes'][$index]['y'] = (int)$node['coords'][1];
+
+ if (($node['type'] == 'agent') || ($node['type'] == '')) {
+ $nodes_and_relations['nodes'][$index]['source_data'] = $node['id_agent'];
+ $nodes_and_relations['nodes'][$index]['type'] = 0;
+ }
+ else {
+ $nodes_and_relations['nodes'][$index]['source_data'] = $node['id_module'];
+ $nodes_and_relations['nodes'][$index]['id_agent'] = $node['id_agent'];
+ $nodes_and_relations['nodes'][$index]['type'] = 1;
+ }
+
+ $style = array();
+ $style['shape'] = 'circle';
+ $style['image'] = $node['image'];
+ $style['width'] = $node['width'];
+ $style['height'] = $node['height'];
+ $style['label'] = $node['text'];
+ $nodes_and_relations['nodes'][$index]['style'] = json_encode($style);
+
+ $index++;
+ }
+
+ $nodes_and_relations['relations'] = array();
+ $index = 0;
+ foreach ($relation_nodes as $relation) {
+ $nodes_and_relations['relations'][$index]['id_map'] = $id;
+
+ if (($relation['parent_type'] == 'agent') || ($relation['parent_type'] == '')) {
+ $nodes_and_relations['relations'][$index]['id_parent'] = $relation['id_parent'];
+ $nodes_and_relations['relations'][$index]['id_parent_source_data'] = $nodes[$relation['id_parent']]['id_agent'];
+ $nodes_and_relations['relations'][$index]['parent_type'] = 0;
+ }
+ else if ($relation['parent_type'] == 'module') {
+ $nodes_and_relations['relations'][$index]['id_parent'] = $relation['id_parent'];
+ $nodes_and_relations['relations'][$index]['id_parent_source_data'] = $nodes[$relation['id_parent']]['id_module'];
+ $nodes_and_relations['relations'][$index]['parent_type'] = 1;
+ }
+ else {
+ $nodes_and_relations['relations'][$index]['id_parent'] = $relation['id_parent'];
+ $nodes_and_relations['relations'][$index]['id_child_source_data'] = -2;
+ $nodes_and_relations['relations'][$index]['parent_type'] = 3;
+ }
+
+ if (($relation['child_type'] == 'agent') || ($relation['child_type'] == '')) {
+ $nodes_and_relations['relations'][$index]['id_child'] = $relation['id_child'];
+ $nodes_and_relations['relations'][$index]['id_child_source_data'] = $nodes[$relation['id_child']]['id_agent'];
+ $nodes_and_relations['relations'][$index]['child_type'] = 0;
+ }
+ else if ($relation['child_type'] == 'module') {
+ $nodes_and_relations['relations'][$index]['id_child'] = $relation['id_child'];
+ $nodes_and_relations['relations'][$index]['id_child_source_data'] = $nodes[$relation['id_child']]['id_module'];
+ $nodes_and_relations['relations'][$index]['child_type'] = 1;
+ }
+ else {
+ $nodes_and_relations['relations'][$index]['id_child'] = $relation['id_child'];
+ $nodes_and_relations['relations'][$index]['id_child_source_data'] = -2;
+ $nodes_and_relations['relations'][$index]['child_type'] = 3;
+ }
+
+ $index++;
+ }
+
+ if (enterprise_installed()) {
+ enterprise_include_once("include/functions_pandora_networkmap.php");
+ save_generate_nodes($id, $nodes_and_relations);
+ }
+
+ $pandorafms_node = $nodes_and_relations['nodes'][0];
+ $center = array('x' => $node_center['x'], 'y' => $node_center['y']);
+
+ $networkmap['center_x'] = $center['x'];
+ $networkmap['center_y'] = $center['y'];
+ db_process_sql_update('tmap',
+ array('center_x' => $networkmap['center_x'], 'center_y' => $networkmap['center_y']),
+ array('id' => $id));
}
- $nodes_and_relations['nodes'] = array();
- $index = 0;
- foreach ($nodes as $key => $node) {
- $nodes_and_relations['nodes'][$index]['id_map'] = $id;
-
- $nodes_and_relations['nodes'][$index]['x'] = (int)$node['coords'][0];
- $nodes_and_relations['nodes'][$index]['y'] = (int)$node['coords'][1];
-
- if (($node['type'] == 'agent') || ($node['type'] == '')) {
- $nodes_and_relations['nodes'][$index]['source_data'] = $node['id_agent'];
- $nodes_and_relations['nodes'][$index]['type'] = 0;
- }
- else {
- $nodes_and_relations['nodes'][$index]['source_data'] = $node['id_module'];
- $nodes_and_relations['nodes'][$index]['id_agent'] = $node['id_agent'];
- $nodes_and_relations['nodes'][$index]['type'] = 1;
- }
-
- $style = array();
- $style['shape'] = 'circle';
- $style['image'] = $node['image'];
- $style['width'] = $node['width'];
- $style['height'] = $node['height'];
- $style['label'] = $node['text'];
- $nodes_and_relations['nodes'][$index]['style'] = json_encode($style);
-
- $index++;
- }
-
- $nodes_and_relations['relations'] = array();
- $index = 0;
- foreach ($relation_nodes as $relation) {
- $nodes_and_relations['relations'][$index]['id_map'] = $id;
-
- if (($relation['parent_type'] == 'agent') || ($relation['parent_type'] == '')) {
- $nodes_and_relations['relations'][$index]['id_parent'] = $relation['id_parent'];
- $nodes_and_relations['relations'][$index]['id_parent_source_data'] = $nodes[$relation['id_parent']]['id_agent'];
- $nodes_and_relations['relations'][$index]['parent_type'] = 0;
- }
- else if ($relation['parent_type'] == 'module') {
- $nodes_and_relations['relations'][$index]['id_parent'] = $relation['id_parent'];
- $nodes_and_relations['relations'][$index]['id_parent_source_data'] = $nodes[$relation['id_parent']]['id_module'];
- $nodes_and_relations['relations'][$index]['parent_type'] = 1;
- }
- else {
- $nodes_and_relations['relations'][$index]['id_parent'] = $relation['id_parent'];
- $nodes_and_relations['relations'][$index]['id_child_source_data'] = -2;
- $nodes_and_relations['relations'][$index]['parent_type'] = 3;
- }
-
- if (($relation['child_type'] == 'agent') || ($relation['child_type'] == '')) {
- $nodes_and_relations['relations'][$index]['id_child'] = $relation['id_child'];
- $nodes_and_relations['relations'][$index]['id_child_source_data'] = $nodes[$relation['id_child']]['id_agent'];
- $nodes_and_relations['relations'][$index]['child_type'] = 0;
- }
- else if ($relation['child_type'] == 'module') {
- $nodes_and_relations['relations'][$index]['id_child'] = $relation['id_child'];
- $nodes_and_relations['relations'][$index]['id_child_source_data'] = $nodes[$relation['id_child']]['id_module'];
- $nodes_and_relations['relations'][$index]['child_type'] = 1;
- }
- else {
- $nodes_and_relations['relations'][$index]['id_child'] = $relation['id_child'];
- $nodes_and_relations['relations'][$index]['id_child_source_data'] = -2;
- $nodes_and_relations['relations'][$index]['child_type'] = 3;
- }
-
- $index++;
- }
-
- if (enterprise_installed()) {
- enterprise_include_once("include/functions_pandora_networkmap.php");
- save_generate_nodes($id, $nodes_and_relations);
- }
-
- $pandorafms_node = $nodes_and_relations['nodes'][0];
- $center = array('x' => $pandorafms_node['x'], 'y' => $pandorafms_node['y']);
-
- $networkmap['center_x'] = $center['x'];
- $networkmap['center_y'] = $center['y'];
- db_process_sql_update('tmap',
- array('center_x' => $networkmap['center_x'], 'center_y' => $networkmap['center_y']),
- array('id' => $id));
}
return $nodes_and_relations;
@@ -342,6 +477,7 @@ function networkmap_db_node_to_js_node($node, &$count, &$count_item_holding_area
$item['py'] = (int)$node['y'];
$item['z'] = (int)$node['z'];
$item['state'] = $node['state'];
+ $item['deleted'] = $node['deleted'];
if ($item['state'] == 'holding_area') {
//40 = DEFAULT NODE RADIUS
//30 = for to align
@@ -374,6 +510,7 @@ function networkmap_db_node_to_js_node($node, &$count, &$count_item_holding_area
$item['image_width'] = (int)$image_size[0];
$item['image_height'] = (int)$image_size[1];
}
+ $item['raw_text'] = $node['style']['label'];
$item['text'] = io_safe_output($node['style']['label']);
$item['shape'] = $node['style']['shape'];
switch ($node['type']) {
@@ -398,6 +535,13 @@ function networkmap_db_node_to_js_node($node, &$count, &$count_item_holding_area
if (isset($node['id_map'])) {
$item['map_id'] = $node['id_map'];
}
+
+ if (!isset($node['style']['id_networkmap']) || $node['style']['id_networkmap'] == '' || $node['style']['id_networkmap'] == 0) {
+ $item['networkmap_id'] = 0;
+ }
+ else {
+ $item['networkmap_id'] = $node['style']['id_networkmap'];
+ }
$count++;
@@ -517,8 +661,10 @@ function networkmap_links_to_js_links($relations, $nodes_graph) {
$item['id_agent_start'] = (int)$id_source_agent;
$item['id_module_end'] = 0;
$item['id_agent_end'] = (int)$id_target_agent;
+ $item['link_color'] = "#999";
$item['target'] = -1;
$item['source'] = -1;
+ $item['deleted'] = $relation['deleted'];
if (enterprise_installed()) {
$target_and_source = array();
@@ -548,7 +694,7 @@ function networkmap_links_to_js_links($relations, $nodes_graph) {
$item['arrow_end'] = 'module';
$item['status_end'] = modules_get_agentmodule_status((int)$id_target_module, false, false, null);
$item['id_module_end'] = (int)$id_target_module;
- $text_end = io_safe_output(modules_get_agentmodule_name((int)$id_target_module));
+ $text_end = modules_get_agentmodule_name((int)$id_target_module);
if (preg_match ("/(.+)_ifOperStatus$/" , (string)$text_end, $matches)) {
if ($matches[1]) {
$item['text_end'] = $matches[1];
@@ -559,7 +705,7 @@ function networkmap_links_to_js_links($relations, $nodes_graph) {
$item['arrow_start'] = 'module';
$item['status_start'] = modules_get_agentmodule_status((int)$id_source_module, false, false, null);
$item['id_module_start'] = (int)$id_source_module;
- $text_start = io_safe_output(modules_get_agentmodule_name((int)$id_source_module));
+ $text_start = modules_get_agentmodule_name((int)$id_source_module);
if (preg_match ("/(.+)_ifOperStatus$/" , (string)$text_start, $matches)) {
if ($matches[1]) {
$item['text_start'] = $matches[1];
@@ -571,14 +717,42 @@ function networkmap_links_to_js_links($relations, $nodes_graph) {
$agent2 = 0;
if (($relation['parent_type'] == 1) && ($relation['child_type'] == 1)) {
+ $mod1_status = db_get_value_filter('estado', 'tagente_estado', array('id_agente_modulo' => $relation['id_parent_source_data']));
+ $mod2_status = db_get_value_filter('estado', 'tagente_estado', array('id_agente_modulo' => $relation['id_child_source_data']));
+
+ if (($mod1_status == AGENT_MODULE_STATUS_CRITICAL_BAD) || ($mod2_status == AGENT_MODULE_STATUS_CRITICAL_BAD)) {
+ $item['link_color'] = "#FC4444";
+ }
+ else if (($mod1_status == AGENT_MODULE_STATUS_WARNING) || ($mod2_status == AGENT_MODULE_STATUS_WARNING)) {
+ $item['link_color'] = "#FAD403";
+ }
+
$agent = agents_get_agent_id_by_module_id($relation['id_parent_source_data']);
$agent2 = agents_get_agent_id_by_module_id($relation['id_child_source_data']);
}
else if ($relation['child_type'] == 1) {
+ $mod1_status = db_get_value_filter('estado', 'tagente_estado', array('id_agente_modulo' => $relation['id_child_source_data']));
+
+ if ($mod1_status == AGENT_MODULE_STATUS_CRITICAL_BAD) {
+ $item['link_color'] = "#FC4444";
+ }
+ else if ($mod1_status == AGENT_MODULE_STATUS_WARNING) {
+ $item['link_color'] = "#FAD403";
+ }
+
$agent = $relation['id_parent_source_data'];
$agent2 = agents_get_agent_id_by_module_id($relation['id_child_source_data']);
}
else if ($relation['parent_type'] == 1) {
+ $mod1_status = db_get_value_filter('estado', 'tagente_estado', array('id_agente_modulo' => $relation['id_parent_source_data']));
+
+ if ($mod1_status == AGENT_MODULE_STATUS_CRITICAL_BAD) {
+ $item['link_color'] = "#FC4444";
+ }
+ else if ($mod1_status == AGENT_MODULE_STATUS_WARNING) {
+ $item['link_color'] = "#FAD403";
+ }
+
$agent = agents_get_agent_id_by_module_id($relation['id_parent_source_data']);
$agent2 = $relation['id_child_source_data'];
}
@@ -716,7 +890,9 @@ function networkmap_write_js_array($id, $nodes_and_relations = array(), $map_das
$item = networkmap_db_node_to_js_node(
$node, $count, $count_item_holding_area);
-
+ if ($item['deleted']) {
+ continue;
+ }
echo "networkmap.nodes.push(" . json_encode($item) . ");\n";
$nodes_graph[$item['id']] = $item;
}
@@ -732,6 +908,9 @@ function networkmap_write_js_array($id, $nodes_and_relations = array(), $map_das
$links_js = networkmap_links_to_js_links($relations, $nodes_graph);
foreach ($links_js as $link_js) {
+ if ($link_js['deleted']) {
+ continue;
+ }
if ($link_js['target'] == -1)
continue;
if ($link_js['source'] == -1)
@@ -789,6 +968,12 @@ function networkmap_write_js_array($id, $nodes_and_relations = array(), $map_das
echo "var set_center_menu = '" . __('Set center') . "';\n";
echo "var refresh_menu = '" . __('Refresh') . "';\n";
echo "var refresh_holding_area_menu = '" . __('Refresh Holding area') . "';\n";
+ echo "var ok_button = '" . __('Proceed') . "';\n";
+ echo "var message_to_confirm = '" . __('Resetting the map will delete all customizations you have done, including manual relationships between elements, new items, etc.') . "';\n";
+ echo "var warning_message = '" . __('WARNING') . "';\n";
+ echo "var ok_button = '" . __('Proceed') . "';\n";
+ echo "var cancel_button = '" . __('Cancel') . "';\n";
+ echo "var restart_map_menu = '" . __('Restart map') . "';\n";
echo "var abort_relationship_interface = '" . __('Abort the interface relationship') . "';\n";
echo "var abort_relationship_menu = '" . __('Abort the action of set relationship') . "';\n";
@@ -874,7 +1059,6 @@ function networkmap_loadfile($id = 0, $file = '',
modules_get_agentmodule_agent($ids[$node_id]['id_module']);
$text = modules_get_agentmodule_name($data['id_module']);
- $text = io_safe_output($text);
$text = ui_print_truncate_text($text,
'agent_medium', false, true, false,
'...', false);
@@ -885,7 +1069,6 @@ function networkmap_loadfile($id = 0, $file = '',
$data['id_agent'] = $ids[$node_id]['id_agent'];
$text = agents_get_alias($ids[$node_id]['id_agent']);
- $text = io_safe_output($text);
$text = ui_print_truncate_text($text,
'agent_medium', false, true, false,
'...', false);
@@ -975,7 +1158,7 @@ function duplicate_networkmap($id) {
$values = db_get_row('tmap', 'id', $id);
unset($values['id']);
$free_name = false;
- $values['name'] = io_safe_input(__('Copy of ') . io_safe_output($values['name']));
+ $values['name'] = io_safe_input(__('Copy of ')) . $values['name'];
$count = 1;
while (!$free_name) {
$exist = db_get_row_filter('tmap', array('name' => $values['name']));
@@ -1336,7 +1519,6 @@ function show_networkmap($id = 0, $user_readonly = false, $nodes_and_relations =
}
.link {
- stroke: #999;
stroke-opacity: .6;
}
diff --git a/pandora_console/include/functions_reporting.php b/pandora_console/include/functions_reporting.php
index 72ab847d48..c058d94188 100644
--- a/pandora_console/include/functions_reporting.php
+++ b/pandora_console/include/functions_reporting.php
@@ -190,6 +190,9 @@ function reporting_make_reporting_data($report = null, $id_report,
$items_label['id_agent_module'] = $content['id_agent_module'];
$items_label['modules'] = $modules_to_macro;
$items_label['agents'] = $agents_to_macro;
+ $items_label['visual_format'] = $visual_format;
+ $metaconsole_on = is_metaconsole();
+ $server_name = $content['server_name'];
//Metaconsole connection
if ($metaconsole_on && $server_name != '') {
@@ -232,6 +235,12 @@ function reporting_make_reporting_data($report = null, $id_report,
$report,
$content);
break;
+ case 'increment':
+ $report['contents'][] =
+ reporting_increment(
+ $report,
+ $content);
+ break;
case 'general':
$report['contents'][] =
reporting_general(
@@ -290,19 +299,19 @@ function reporting_make_reporting_data($report = null, $id_report,
$report['contents'][] = reporting_value(
$report,
$content,
- 'max');
+ 'max',$pdf);
break;
case 'avg_value':
$report['contents'][] = reporting_value(
$report,
$content,
- 'avg');
+ 'avg',$pdf);
break;
case 'min_value':
$report['contents'][] = reporting_value(
$report,
$content,
- 'min');
+ 'min',$pdf);
break;
case 'sumatory':
$report['contents'][] = reporting_value(
@@ -776,8 +785,8 @@ function reporting_SLA($report, $content, $type = 'dinamic',
}
$data = array();
- $data['agent'] = modules_get_agentmodule_agent_alias($sla['id_agent_module']);
- $data['module'] = modules_get_agentmodule_name($sla['id_agent_module']);
+ $data['agent'] = io_safe_output(modules_get_agentmodule_agent_alias($sla['id_agent_module']));
+ $data['module'] = io_safe_output(modules_get_agentmodule_name($sla['id_agent_module']));
$data['max'] = $sla['sla_max'];
$data['min'] = $sla['sla_min'];
$data['sla_limit'] = $sla['sla_limit'];
@@ -886,8 +895,8 @@ function reporting_SLA($report, $content, $type = 'dinamic',
// Slice graphs calculation
if ($show_graphs) {
$dataslice = array();
- $dataslice['agent'] = modules_get_agentmodule_agent_alias ($sla['id_agent_module']);
- $dataslice['module'] = modules_get_agentmodule_name ($sla['id_agent_module']);
+ $dataslice['agent'] = io_safe_output(modules_get_agentmodule_agent_alias ($sla['id_agent_module']));
+ $dataslice['module'] = io_safe_output(modules_get_agentmodule_name ($sla['id_agent_module']));
$dataslice['sla_value'] = $data['sla_value'];
$dataslice['order'] = $data['sla_value'];
@@ -1295,7 +1304,9 @@ function reporting_event_top_n($report, $content, $type = 'dinamic',
$config['font_size'],
true,
$ttl,
- $config['homeurl']);
+ $config['homeurl'],
+ 'white',
+ 'black');
}
$return['resume'] = null;
@@ -3752,7 +3763,7 @@ function reporting_agent_configuration($report, $content) {
return reporting_check_structure_content($return);
}
-function reporting_value($report, $content, $type) {
+function reporting_value($report, $content, $type,$pdf) {
global $config;
$return = array();
@@ -3837,8 +3848,14 @@ function reporting_value($report, $content, $type) {
$return['agent_name'] = $agent_name;
$return['module_name'] = $module_name;
+ if($pdf){
+ $only_image = 1;
+ }
+
switch ($type) {
case 'max':
+ if($content['lapse_calc'] == 0){
+
$value = reporting_get_agentmodule_data_max(
$content['id_agent_module'], $content['period'], $report["datetime"]);
if (!$config['simple_module_value']) {
@@ -3847,18 +3864,286 @@ function reporting_value($report, $content, $type) {
else {
$formated_value = format_for_graph($value, $config['graph_precision']) . " " . $unit;
}
- break;
+
+ }
+ else{
+
+ $value = '
+
+
+ ';
+
+ if($content['visual_format'] == 1 || $content['visual_format'] == 2 || $content['visual_format'] == 3){
+
+ $value .= '
+
+
+
+ '.__("Agent").'
+
+
+ '.__("Module").'
+
+
+ '.__("Maximum").'
+
+
+
+ '.$agent_name.'
+
+
+ '.$module_name.'
+
+
+ '.format_for_graph(reporting_get_agentmodule_data_max(
+ $content['id_agent_module'], $content['period'], $report["datetime"]), $config['graph_precision']) . ' ' . $unit.'
+
+
+
';
+
+ }
+
+ $value .= '
+
+
+
+ ';
+
+ if($content['visual_format'] == 2 || $content['visual_format'] == 3){
+ $value .=
+ grafico_modulo_sparse(
+ $content['id_agent_module'],
+ $content['period'],
+ false,
+ 600,
+ 300,
+ '',
+ '',
+ false,
+ 0,
+ true,
+ $report["datetime"],
+ '',
+ 0,
+ 0,
+ true,
+ $only_image,
+ ui_get_full_url(false, false, false, false),
+ 2,
+ false,
+ '',
+ $time_compare_overlapped,
+ true,
+ true,
+ 'white',
+ ($content['style']['percentil'] == 1) ? $config['percentil'] : null,
+ false,
+ false,
+ $config['type_module_charts'],
+ false,
+ false,
+ $content['lapse_calc'],
+ $content['lapse'],
+ 1);
+ }
+
+ $value .= '
+
+
+
+
+ ';
+
+ if($content['visual_format'] == 1 || $content['visual_format'] == 3){
+
+ $value .= '
+
+
+
+ '.__("Lapse").'
+
+
+ '.__("Maximum").'
+
+
+ ';
+ $time_begin = db_get_row_sql('select utimestamp from tagente_datos where id_agente_modulo ='.$content['id_agent_module']);
+ $date_reference = getdate();
+
+ for ($i=$date_reference[0]; $i > ($date_reference[0]-$content["period"]); $i -= $content["lapse"]) {
+
+ $value .= ' '. date("Y-m-d H:i:s", ($i-$content["lapse"]+1)).' to '.date("Y-m-d H:i:s",$i).' ';
+
+ if($i>$time_begin['utimestamp']){
+ $value .= format_for_graph(reporting_get_agentmodule_data_max(
+ $content['id_agent_module'], $content["lapse"], $i), $config['graph_precision']) . ' ' . $unit.' ';
+ }
+ else{
+ $value .= 'N/A';
+ }
+
+ }
+
+ $value .='
';
+ }
+
+ $value .= '
+
+
+
+
';
+
+ $formated_value = $value;
+ }
+
+ break;
case 'min':
- $value = reporting_get_agentmodule_data_min(
- $content['id_agent_module'], $content['period'], $report["datetime"]);
- if (!$config['simple_module_value']) {
+ if($content['lapse_calc'] == 0){
+ $value = reporting_get_agentmodule_data_min(
+ $content['id_agent_module'], $content['period'], $report["datetime"]);
+
+ if (!$config['simple_module_value']) {
+ $formated_value = $value;
+ }
+ else {
+ $formated_value = format_for_graph($value, $config['graph_precision']) . " " . $unit;
+ }
+
+ }
+ else{
+
+ $value = '
+
+
+ ';
+
+ if($content['visual_format'] == 1 || $content['visual_format'] == 2 || $content['visual_format'] == 3){
+
+ $value .= '
+
+
+
+ '.__("Agent").'
+
+
+ '.__("Module").'
+
+
+ '.__("Minimum").'
+
+
+
+ '.$agent_name.'
+
+
+ '.$module_name.'
+
+
+ '.format_for_graph(reporting_get_agentmodule_data_min(
+ $content['id_agent_module'], $content['period'], $report["datetime"]), $config['graph_precision']) . ' ' . $unit.'
+
+
+
';
+
+ }
+
+ $value .= '
+
+
+
+ ';
+
+ if($content['visual_format'] == 2 || $content['visual_format'] == 3){
+ $value .=
+ grafico_modulo_sparse(
+ $content['id_agent_module'],
+ $content['period'],
+ false,
+ 600,
+ 300,
+ '',
+ '',
+ false,
+ 0,
+ true,
+ $report["datetime"],
+ '',
+ 0,
+ 0,
+ true,
+ $only_image,
+ ui_get_full_url(false, false, false, false),
+ 2,
+ false,
+ '',
+ $time_compare_overlapped,
+ true,
+ true,
+ 'white',
+ ($content['style']['percentil'] == 1) ? $config['percentil'] : null,
+ false,
+ false,
+ $config['type_module_charts'],
+ false,
+ false,
+ $content['lapse_calc'],
+ $content['lapse'],
+ 0,
+ 1);
+ }
+
+ $value .= '
+
+
+
+
+ ';
+
+ if($content['visual_format'] == 1 || $content['visual_format'] == 3){
+
+ $value .= '
+
+
+
+ '.__("Lapse").'
+
+
+ '.__("Minimum").'
+
+
+ ';
+ $time_begin = db_get_row_sql('select utimestamp from tagente_datos where id_agente_modulo ='.$content['id_agent_module']);
+ $date_reference = getdate();
+
+ for ($i=$date_reference[0]; $i > ($date_reference[0]-$content["period"]); $i -= $content["lapse"]) {
+
+ $value .= ' '. date("Y-m-d H:i:s", ($i-$content["lapse"]+1)).' to '.date("Y-m-d H:i:s",$i).' ';
+
+ if($i>$time_begin['utimestamp']){
+ $value .= format_for_graph(reporting_get_agentmodule_data_min(
+ $content['id_agent_module'], $content["lapse"], $i), $config['graph_precision']) . ' ' . $unit.' ';
+ }
+ else{
+ $value .= 'N/A';
+ }
+
+ }
+
+ $value .='
';
+ }
+
+ $value .= '
+
+
+
+
';
+
$formated_value = $value;
}
- else {
- $formated_value = format_for_graph($value, $config['graph_precision']) . " " . $unit;
- }
+
break;
case 'avg':
+ if($content['lapse_calc'] == 0){
$value = reporting_get_agentmodule_data_average(
$content['id_agent_module'], $content['period'], $report["datetime"]);
if (!$config['simple_module_value']) {
@@ -3867,7 +4152,138 @@ function reporting_value($report, $content, $type) {
else {
$formated_value = format_for_graph($value, $config['graph_precision']) . " " . $unit;
}
- break;
+ }
+ else{
+ $value = '
+
+
+ ';
+
+ if($content['visual_format'] == 1 || $content['visual_format'] == 2 || $content['visual_format'] == 3){
+
+ $value .= '
+
+
+
+ '.__("Agent").'
+
+
+ '.__("Module").'
+
+
+ '.__("Average").'
+
+
+
+ '.$agent_name.'
+
+
+ '.$module_name.'
+
+
+ '.format_for_graph(reporting_get_agentmodule_data_average(
+ $content['id_agent_module'], $content['period'], $report["datetime"]), $config['graph_precision']) . ' ' . $unit.'
+
+
+
';
+
+ }
+
+ $value .= '
+
+
+
+ ';
+
+ if($content['visual_format'] == 2 || $content['visual_format'] == 3){
+ $value .=
+ grafico_modulo_sparse(
+ $content['id_agent_module'],
+ $content['period'],
+ false,
+ 600,
+ 300,
+ '',
+ '',
+ false,
+ 1,
+ true,
+ $report["datetime"],
+ '',
+ 0,
+ 0,
+ true,
+ $only_image,
+ ui_get_full_url(false, false, false, false),
+ 2,
+ false,
+ '',
+ $time_compare_overlapped,
+ true,
+ true,
+ 'white',
+ ($content['style']['percentil'] == 1) ? $config['percentil'] : null,
+ false,
+ false,
+ $config['type_module_charts'],
+ false,
+ false,
+ $content['lapse_calc'],
+ $content['lapse']
+ );
+ }
+
+ $value .= '
+
+
+
+
+ ';
+
+ if($content['visual_format'] == 1 || $content['visual_format'] == 3){
+
+ $value .= '
+
+
+
+ '.__("Lapse").'
+
+
+ '.__("Average").'
+
+
+ ';
+ $time_begin = db_get_row_sql('select utimestamp from tagente_datos where id_agente_modulo ='.$content['id_agent_module']);
+ $date_reference = getdate();
+
+ for ($i=$date_reference[0]; $i > ($date_reference[0]-$content["period"]); $i -= $content["lapse"]) {
+
+ $value .= ' '. date("Y-m-d H:i:s", ($i-$content["lapse"]+1)).' to '.date("Y-m-d H:i:s",$i).' ';
+
+ if($i>$time_begin['utimestamp']){
+ $value .= format_for_graph(reporting_get_agentmodule_data_average(
+ $content['id_agent_module'], $content["lapse"], $i), $config['graph_precision']) . ' ' . $unit.' ';
+ }
+ else{
+ $value .= 'N/A';
+ }
+
+ }
+
+ $value .='
';
+ }
+
+ $value .= '
+
+
+
+
';
+
+ $formated_value = $value;
+
+ }
+ break;
+
case 'sum':
$value = reporting_get_agentmodule_data_sum(
$content['id_agent_module'], $content['period'], $report["datetime"]);
@@ -5571,6 +5987,101 @@ function reporting_availability_graph($report, $content, $pdf=false) {
return reporting_check_structure_content($return);
}
+/**
+ * reporting_increment
+ *
+ * Generates a structure the report.
+ *
+ */
+function reporting_increment ($report, $content) {
+ global $config;
+
+ $return = array();
+ $return['type'] = 'increment';
+ if (empty($content['name'])) {
+ $content['name'] = __('Increment');
+ }
+
+ $return['title'] = $content['name'];
+ $return["description"] = $content["description"];
+ $return["id_agent_module"] = $content["id_agent_module"];
+ $return["id_agent"] = $content["id_agent"];
+
+ $id_agent_module = $content['id_agent_module'];
+ $period = (int)$content['period'];
+
+ $return["from"] = time() - $period;
+ $return["to"] = time();
+
+ $return["data"] = array();
+
+ if (defined('METACONSOLE')) {
+ $sql1 = 'SELECT datos FROM tagente_datos WHERE id_agente_modulo = ' . $id_agent_module . '
+ AND utimestamp <= ' . (time() - $period) . ' ORDER BY utimestamp DESC';
+ $sql2 = 'SELECT datos FROM tagente_datos WHERE id_agente_modulo = ' . $id_agent_module . ' ORDER BY utimestamp DESC';
+
+ $servers = db_get_all_rows_sql ('SELECT *
+ FROM tmetaconsole_setup
+ WHERE disabled = 0');
+
+ if ($servers === false)
+ $servers = array();
+
+ $result = array();
+ $count_modules = 0;
+ foreach ($servers as $server) {
+ // If connection was good then retrieve all data server
+ if (metaconsole_connect($server) == NOERR)
+ $connection = true;
+ else
+ $connection = false;
+
+ $old_data = db_get_value_sql ($sql1);
+
+ $last_data = db_get_value_sql ($sql2);
+ }
+ }
+ else {
+ $old_data = db_get_value_sql('SELECT datos FROM tagente_datos WHERE id_agente_modulo = ' . $id_agent_module . '
+ AND utimestamp <= ' . (time() - $period) . ' ORDER BY utimestamp DESC');
+
+ $last_data = db_get_value_sql('SELECT datos FROM tagente_datos WHERE id_agente_modulo = ' . $id_agent_module . ' ORDER BY utimestamp DESC');
+ }
+
+ if (!defined('METACONSOLE')) {
+
+ }
+
+ if ($old_data === false || $last_data === false) {
+ $return["data"]['message'] = __('The monitor have no data in this range of dates or monitor type is not numeric');
+ $return["data"]['error'] = true;
+ }
+ else if (is_numeric($old_data) && is_numeric($last_data)) {
+ $return["data"]['old'] = $old_data;
+ $return["data"]['now'] = $last_data;
+ $increment = $old_data - $last_data;
+
+ if ($increment < 0) {
+ $return["data"]['inc'] = 'positive';
+ $return["data"]["inc_data"] = $last_data - $old_data;
+ }
+ else if ($increment == 0) {
+ $return["data"]['inc'] = 'neutral';
+ $return["data"]["inc_data"] = 0;
+ }
+ else {
+ $return["data"]['inc'] = 'negative';
+ $return["data"]["inc_data"] = $old_data - $last_data;
+ }
+ }
+ else {
+ $return["data"]['message'] = __('The monitor type is not numeric');
+ $return["data"]['error'] = true;
+ }
+
+ return reporting_check_structure_content($return);
+}
+
/**
* reporting_general
*
@@ -7249,19 +7760,19 @@ function reporting_get_stats_modules_status($data, $graph_width = 250, $graph_he
if ($links === false) {
$urls = array();
$urls['monitor_critical'] = "index.php?" .
- "sec=estado&sec2=operation/agentes/status_monitor&" .
+ "sec=view&sec2=operation/agentes/status_monitor&" .
"refr=60&status=" . AGENT_MODULE_STATUS_CRITICAL_BAD . "&pure=" . $config['pure'];
$urls['monitor_warning'] = "index.php?" .
- "sec=estado&sec2=operation/agentes/status_monitor&" .
+ "sec=view&sec2=operation/agentes/status_monitor&" .
"refr=60&status=" . AGENT_MODULE_STATUS_WARNING . "&pure=" . $config['pure'];
$urls['monitor_ok'] = "index.php?" .
- "sec=estado&sec2=operation/agentes/status_monitor&" .
+ "sec=view&sec2=operation/agentes/status_monitor&" .
"refr=60&status=" . AGENT_MODULE_STATUS_NORMAL . "&pure=" . $config['pure'];
$urls['monitor_unknown'] = "index.php?" .
- "sec=estado&sec2=operation/agentes/status_monitor&" .
+ "sec=view&sec2=operation/agentes/status_monitor&" .
"refr=60&status=" . AGENT_MODULE_STATUS_UNKNOWN . "&pure=" . $config['pure'];
$urls['monitor_not_init'] = "index.php?" .
- "sec=estado&sec2=operation/agentes/status_monitor&" .
+ "sec=view&sec2=operation/agentes/status_monitor&" .
"refr=60&status=" . AGENT_MODULE_STATUS_NOT_INIT . "&pure=" . $config['pure'];
}
else {
@@ -7361,7 +7872,7 @@ function reporting_get_stats_agents_monitors($data) {
else {
$urls = array();
$urls['total_agents'] = "index.php?sec=estado&sec2=operation/agentes/estado_agente&refr=60";
- $urls['monitor_checks'] = "index.php?sec=estado&sec2=operation/agentes/status_monitor&refr=60&status=-1";
+ $urls['monitor_checks'] = "index.php?sec=view&sec2=operation/agentes/status_monitor&refr=60&status=-1";
}
// Agents and modules table
diff --git a/pandora_console/include/functions_reporting_html.php b/pandora_console/include/functions_reporting_html.php
index cb29812686..eca001e288 100644
--- a/pandora_console/include/functions_reporting_html.php
+++ b/pandora_console/include/functions_reporting_html.php
@@ -208,6 +208,9 @@ function reporting_html_print_report($report, $mini = false, $report_info = 1) {
case 'avg_value':
reporting_html_avg_value($table, $item, $mini);
break;
+ case 'increment':
+ reporting_html_increment($table, $item);
+ break;
case 'min_value':
reporting_html_min_value($table, $item, $mini);
break;
@@ -2213,6 +2216,69 @@ function reporting_html_value(&$table, $item, $mini, $only_value = false, $check
$table->data['data']['cell'] .= '
';
}
+function reporting_html_increment(&$table, $item) {
+ global $config;
+
+ if (isset($item["data"]['error'])) {
+ $table->colspan['error']['cell'] = 3;
+ $table->data['error']['cell'] = $item["data"]['message'];
+ }
+ else {
+ $table1 = new stdClass();
+ $table1->width = '99%';
+ $table1->data = array ();
+
+ $table1->head = array ();
+ $table1->head[0] = __('Agent');
+ $table1->head[1] = __('Module');
+ $table1->head[2] = __('From');
+ $table1->head[3] = __('To');
+ $table1->head[4] = __('From data');
+ $table1->head[5] = __('To data');
+ $table1->head[6] = __('Increment');
+
+ $table1->headstyle = array();
+ $table1->headstyle[0] = 'text-align: left';
+ $table1->headstyle[1] = 'text-align: left';
+ $table1->headstyle[2] = 'text-align: left';
+ $table1->headstyle[3] = 'text-align: left';
+ $table1->headstyle[4] = 'text-align: right';
+ $table1->headstyle[5] = 'text-align: right';
+ $table1->headstyle[6] = 'text-align: right';
+
+ $table1->style[0] = 'text-align: left';
+ $table1->style[1] = 'text-align: left';
+ $table1->style[2] = 'text-align: left';
+ $table1->style[3] = 'text-align: left';
+ $table1->style[4] = 'text-align: right';
+ $table1->style[5] = 'text-align: right';
+ $table1->style[6] = 'text-align: right';
+
+ $table1_row = array();
+ $table1_row[0] = agents_get_alias($item['id_agent']);
+ $table1_row[1] = modules_get_agentmodule_name($item['id_agent_module']);
+ $table1_row[2] = date("F j, Y, G:i", $item['from']);
+ $table1_row[3] = date("F j, Y, G:i", $item['to']);
+ $table1_row[4] = $item["data"]['old'];
+ $table1_row[5] = $item["data"]['now'];
+ if ($item["data"]['inc'] == 'negative') {
+ $table1_row[6] = __('Negative increase: ') . $item["data"]["inc_data"];
+ }
+ else if ($item["data"]['inc'] == 'positive') {
+ $table1_row[6] = __('Positive increase: ') . $item["data"]["inc_data"];
+ }
+ else {
+ $table1_row[6] = __('Neutral increase: ') . $item["data"]["inc_data"];
+ }
+
+ $table1->data[] = $table1_row;
+
+ $data = array();
+ $data[0] = html_print_table($table1, true);
+ array_push ($table->data, $data);
+ }
+}
+
function reporting_html_url(&$table, $item, $key) {
$table->colspan['data']['cell'] = 3;
$table->cellstyle['data']['cell'] = 'text-align: left;';
diff --git a/pandora_console/include/functions_reports.php b/pandora_console/include/functions_reports.php
index 9282be345b..dfa3d3d490 100755
--- a/pandora_console/include/functions_reports.php
+++ b/pandora_console/include/functions_reports.php
@@ -574,7 +574,8 @@ function reports_get_report_types ($template = false, $not_editor = false) {
'name' => __('Summatory'));
$types['historical_data'] = array('optgroup' => __('Modules'),
'name' => __('Historical Data'));
-
+ $types['increment'] = array('optgroup' => __('Modules'),
+ 'name' => __('Increment'));
$types['general'] = array('optgroup' => __('Grouped'),
diff --git a/pandora_console/include/functions_snmp_browser.php b/pandora_console/include/functions_snmp_browser.php
index b98d66789b..390d6ec151 100644
--- a/pandora_console/include/functions_snmp_browser.php
+++ b/pandora_console/include/functions_snmp_browser.php
@@ -196,7 +196,7 @@ function snmp_browser_get_tree ($target_ip, $community, $starting_oid = '.', $ve
}
}
else {
- $command = $snmpwalk_bin . " -m ALL -M +" . escapeshellarg($config['homedir'] . "/attachment/mibs") . " -Cc -c " . escapeshellarg($community) . " -v " . escapeshellarg($version) . " " . escapeshellarg($target_ip) . " " . escapeshellarg($starting_oid) . " 2> " . $error_redir_dir;
+ $command = $snmpwalk_bin . " -m ALL -M +" . escapeshellarg($config['homedir'] . "/attachment/mibs") . " -Cc -c " . escapeshellarg(io_safe_output($community)) . " -v " . escapeshellarg($version) . " " . escapeshellarg($target_ip) . " " . escapeshellarg($starting_oid) . " 2> " . $error_redir_dir;
}
exec("ssh pandora_exec_proxy@" . $server_data['ip_address'] . " \"" . $command . "\"", $output, $rc);
}
@@ -216,7 +216,7 @@ function snmp_browser_get_tree ($target_ip, $community, $starting_oid = '.', $ve
}
}
else {
- exec ($snmpwalk_bin . ' -m ALL -M +' . escapeshellarg($config['homedir'] . '/attachment/mibs') . ' -Cc -c ' . escapeshellarg($community) . ' -v ' . escapeshellarg($version) . ' ' . escapeshellarg($target_ip) . ' ' . escapeshellarg($starting_oid) . ' 2> ' . $error_redir_dir, $output, $rc);
+ exec ($snmpwalk_bin . ' -m ALL -M +' . escapeshellarg($config['homedir'] . '/attachment/mibs') . ' -Cc -c ' . escapeshellarg(io_safe_output($community)) . ' -v ' . escapeshellarg($version) . ' ' . escapeshellarg($target_ip) . ' ' . escapeshellarg($starting_oid) . ' 2> ' . $error_redir_dir, $output, $rc);
}
}
}
@@ -236,7 +236,7 @@ function snmp_browser_get_tree ($target_ip, $community, $starting_oid = '.', $ve
}
}
else {
- exec ($snmpwalk_bin . ' -m ALL -M +' . escapeshellarg($config['homedir'] . '/attachment/mibs') . ' -Cc -c ' . escapeshellarg($community) . ' -v ' . escapeshellarg($version) . ' ' . escapeshellarg($target_ip) . ' ' . escapeshellarg($starting_oid) . ' 2> ' . $error_redir_dir, $output, $rc);
+ exec ($snmpwalk_bin . ' -m ALL -M +' . escapeshellarg($config['homedir'] . '/attachment/mibs') . ' -Cc -c ' . escapeshellarg(io_safe_output($community)) . ' -v ' . escapeshellarg($version) . ' ' . escapeshellarg($target_ip) . ' ' . escapeshellarg($starting_oid) . ' 2> ' . $error_redir_dir, $output, $rc);
}
}
@@ -348,7 +348,7 @@ function snmp_browser_get_oid ($target_ip, $community, $target_oid, $version = '
exec ($snmpget_bin . ' -m ALL -v 3 -u ' . escapeshellarg($snmp3_auth_user) . ' -A ' . escapeshellarg($snmp3_auth_pass) . ' -l ' . escapeshellarg($snmp3_security_level) . ' -a ' . escapeshellarg($snmp3_auth_method) . ' -x ' . escapeshellarg($snmp3_privacy_method) . ' -X ' . escapeshellarg($snmp3_privacy_pass) . ' ' . escapeshellarg($target_ip) . ' ' . escapeshellarg($target_oid) . ' 2> ' . $error_redir_dir, $output, $rc);
}
else {
- exec ($snmpget_bin . ' -m ALL -M +' . escapeshellarg($config['homedir'] . '/attachment/mibs') . ' -On -c ' . escapeshellarg($community) . ' -v ' . escapeshellarg($version) . ' ' . escapeshellarg($target_ip) . ' ' . escapeshellarg($target_oid) . ' 2> ' . $error_redir_dir, $output, $rc);
+ exec ($snmpget_bin . ' -m ALL -M +' . escapeshellarg($config['homedir'] . '/attachment/mibs') . ' -On -c ' . escapeshellarg(io_safe_output($community)) . ' -v ' . escapeshellarg($version) . ' ' . escapeshellarg($target_ip) . ' ' . escapeshellarg($target_oid) . ' 2> ' . $error_redir_dir, $output, $rc);
}
if ($rc != 0) {
@@ -725,35 +725,38 @@ function snmp_browser_print_container ($return = false, $width = '100%', $height
});
// Prepare the AJAX call
- var params = [
- "target_ip=" + target_ip,
- "community=" + community,
- "oids=" + oids,
- "snmp_browser_version=" + snmp_version,
- "snmp3_browser_auth_user=" + snmp3_auth_user,
- "snmp3_browser_security_level=" + snmp3_security_level,
- "snmp3_browser_auth_method=" + snmp3_auth_method,
- "snmp3_browser_auth_pass=" + snmp3_auth_pass,
- "snmp3_browser_privacy_method=" + snmp3_privacy_method,
- "snmp3_browser_privacy_pass=" + snmp3_privacy_pass,
- "action=" + "create_modules_snmp",
- "custom_action=" + custom_action,
- "page=include/ajax/snmp_browser.ajax"
- ];
+ var params = {};
+ params["target_ip"] = target_ip;
+ params["community"] = community;
+ params["oids"] = oids;
+ params["snmp_browser_version"] = snmp_version;
+ params["snmp3_browser_auth_user"] = snmp3_auth_user;
+ params["snmp3_browser_security_level"] = snmp3_security_level;
+ params["snmp3_browser_auth_method"] = snmp3_auth_method;
+ params["snmp3_browser_auth_pass"] = snmp3_auth_pass;
+ params["snmp3_browser_privacy_method"] = snmp3_privacy_method;
+ params["snmp3_browser_privacy_pass"] = snmp3_privacy_pass;
+ params["action"] = "create_modules_snmp";
+ params["custom_action"] = custom_action;
+ params["page"] = "include/ajax/snmp_browser.ajax";
$.ajax({
type: "GET",
url: "ajax.php",
- data: params.join ("&"),
- dataType: "json",
+ data: params,
+ dataType: "html",
success: function(data) {
+
+ var dato = data.replace(/[^]+(?=\[)/,"");
$('input[name*=create_network_component]').removeClass("sub spinn");
$('input[name*=create_network_component]').addClass("sub add");
- if(data.length !== 0){
+ dato = JSON.parse(dato);
+
+ if(dato.length !== 0){
$('#error_text').text("");
- data.forEach( function(valor, indice, array) {
- console.log(valor);
+
+ dato.forEach( function(valor, indice, array) {
$('#error_text').append(' '+ valor );
});
$("#dialog_error")
diff --git a/pandora_console/include/functions_ui.php b/pandora_console/include/functions_ui.php
index de10fcaf91..e76ba9399f 100755
--- a/pandora_console/include/functions_ui.php
+++ b/pandora_console/include/functions_ui.php
@@ -94,22 +94,27 @@ function ui_print_truncate_text($text, $numChars = GENERIC_SIZE_TEXT, $showTextI
}
}
- $text = io_safe_output($text);
- if (mb_strlen($text, "UTF-8") > ($numChars)) {
+ $text_html_decoded = io_safe_output($text);
+ $text_has_entities = $text != $text_html_decoded;
+
+ if (mb_strlen($text_html_decoded, "UTF-8") > ($numChars)) {
// '/2' because [...] is in the middle of the word.
$half_length = intval(($numChars - 3) / 2);
// Depending on the strange behavior of mb_strimwidth() itself,
// the 3rd parameter is not to be $numChars but the length of
// original text (just means 'large enough').
- $truncateText2 = mb_strimwidth($text,
- (mb_strlen($text, "UTF-8") - $half_length),
- mb_strlen($text, "UTF-8"), "", "UTF-8" );
+ $truncateText2 = mb_strimwidth($text_html_decoded,
+ (mb_strlen($text_html_decoded, "UTF-8") - $half_length),
+ mb_strlen($text_html_decoded, "UTF-8"), "", "UTF-8" );
- $truncateText = mb_strimwidth($text, 0,
- ($numChars - $half_length), "", "UTF-8") . $suffix;
+ $truncateText = mb_strimwidth($text_html_decoded, 0,
+ ($numChars - $half_length), "", "UTF-8");
- $truncateText = $truncateText . $truncateText2;
+ // Recover the html entities to avoid XSS attacks
+ $truncateText = ($text_has_entities)
+ ? io_safe_input($truncateText) . $suffix . io_safe_input($truncateText2)
+ : $truncateText . $suffix . $truncateText2;
if ($showTextInTitle) {
if ($style === null) {
@@ -2968,6 +2973,11 @@ function ui_print_agent_autocomplete_input($parameters) {
else
$metaconsole_enabled = false;
}
+
+ $get_only_string_modules = false;
+ if (isset($parameters['get_only_string_modules'])) {
+ $get_only_string_modules = true;
+ }
$spinner_image = html_print_image('images/spinner.gif', true, false, true);
if (isset($parameters['spinner_image'])) {
@@ -3029,7 +3039,10 @@ function ui_print_agent_autocomplete_input($parameters) {
$javascript = $parameters['javascript'];
}
-
+ $get_order_json = false;
+ if (isset($parameters['get_order_json'])) {
+ $get_order_json = true;
+ }
$javascript_is_function_select = false; //Default value
if (isset($parameters['javascript_is_function_select'])) {
@@ -3116,6 +3129,14 @@ function ui_print_agent_autocomplete_input($parameters) {
if (' . ((int) !$metaconsole_enabled) . ') {
inputs.push ("force_local_modules=1");
}
+
+ if (' . ((int) $get_order_json) . ') {
+ inputs.push ("get_order_json=1");
+ }
+
+ if (' . ((int) $get_only_string_modules) . ') {
+ inputs.push ("get_only_string_modules=1");
+ }
if (' . ((int)$metaconsole_enabled) . ') {
if ((' . ((int)$use_input_server) . ')
diff --git a/pandora_console/include/functions_update_manager.php b/pandora_console/include/functions_update_manager.php
index 607b108e42..ba6508fa19 100755
--- a/pandora_console/include/functions_update_manager.php
+++ b/pandora_console/include/functions_update_manager.php
@@ -358,7 +358,14 @@ function update_manager_check_online_free_packages ($is_ajax=true) {
var text1_mr_file = "\n";
var text2_mr_file = "\n";
var text3_mr_file = "\n";
- var text4_mr_file = "\n";
+ var text4_mr_file = "'.__('About minor release update').' ';
+ }
+ else{
+ echo __(' to this process').''.__('About minor release update').' ';
+ }
+ ?>";
var text1_package_file = "\n";
var text2_package_file = "\n";
var applying_mr = "\n";
diff --git a/pandora_console/include/functions_users.php b/pandora_console/include/functions_users.php
index 8e3eac823b..957c8c569e 100755
--- a/pandora_console/include/functions_users.php
+++ b/pandora_console/include/functions_users.php
@@ -152,6 +152,8 @@ function users_get_groups_for_select($id_user, $privilege = "AR", $returnAllGro
* @return array A list of the groups the user has certain privileges.
*/
function users_get_groups ($id_user = false, $privilege = "AR", $returnAllGroup = true, $returnAllColumns = false, $id_groups = null, $keys_field = 'id_grupo') {
+ static $group_cache = array();
+
if (empty ($id_user)) {
global $config;
diff --git a/pandora_console/include/functions_visual_map.php b/pandora_console/include/functions_visual_map.php
index 2ce0e32e08..2085e9d56d 100755
--- a/pandora_console/include/functions_visual_map.php
+++ b/pandora_console/include/functions_visual_map.php
@@ -31,6 +31,7 @@ require_once ($config['homedir'].'/include/functions_agents.php');
require_once ($config['homedir'].'/include/functions_modules.php');
require_once ($config['homedir'].'/include/functions_users.php');
require_once ($config['homedir'].'/include/functions.php');
+require_once ($config['homedir'].'/include/graphs/functions_d3.php');
function visual_map_print_item_toolbox($idDiv, $text, $float) {
if ($float == 'left') {
@@ -110,6 +111,14 @@ function visual_map_print_item($mode = "read", $layoutData,
$border_color = $layoutData['border_color'];
$fill_color = $layoutData['fill_color'];
$label_position = $layoutData['label_position'];
+ $show_on_top = $layoutData['show_on_top'];
+
+ if($show_on_top){
+ $show_on_top_index = 10;
+ }
+ else{
+ $show_on_top_index = '';
+ }
$sizeStyle = '';
$borderStyle = '';
@@ -303,6 +312,8 @@ function visual_map_print_item($mode = "read", $layoutData,
break;
case PERCENTILE_BAR:
case PERCENTILE_BUBBLE:
+ case CIRCULAR_PROGRESS_BAR:
+ case CIRCULAR_INTERIOR_PROGRESS_BAR:
if (!empty($layoutData['id_agent'])
&& empty($layoutData['id_layout_linked'])) {
@@ -375,10 +386,16 @@ function visual_map_print_item($mode = "read", $layoutData,
$link = true;
}
+ break;
+ case BARS_GRAPH:
+ $link = true;
break;
case AUTO_SLA_GRAPH:
$link = true;
break;
+ case DONUT_GRAPH:
+ $link = true;
+ break;
default:
if (!empty($element_enterprise)) {
$link = $element_enterprise['link'];
@@ -421,7 +438,7 @@ function visual_map_print_item($mode = "read", $layoutData,
}
}
else if ($is_a_link_to_other_visualconsole) {
- if (empty($layoutData['id_metaconsole'])) {
+ if (empty($layout_data['id_metaconsole'])) {
$url = $config['homeurl'] . "index.php?sec=reporting&sec2=operation/visual_console/render_view&pure=" . $config["pure"] . "&id=" . $layoutData["id_layout_linked"];
}
else {
@@ -433,7 +450,7 @@ function visual_map_print_item($mode = "read", $layoutData,
// Link to an module
if (empty($layoutData['id_metaconsole'])) {
$url = $config['homeurl'] .
- 'index.php?sec=estado&sec2=operation/agentes/status_monitor&id_module=' . $layoutData['id_agente_modulo'];
+ 'index.php?sec=view&sec2=operation/agentes/status_monitor&id_module=' . $layoutData['id_agente_modulo'];
}
else {
$url = ui_meta_get_url_console_child(
@@ -487,6 +504,29 @@ function visual_map_print_item($mode = "read", $layoutData,
"&date_to=" . $date_to . "&time_to=" . $time_to . "&status=-1";
}
break;
+
+ case DONUT_GRAPH:
+ if (empty($layout_data['id_metaconsole'])) {
+ $url = $config['homeurl'] . "index.php?sec=gagente&sec2=godmode/agentes/configurar_agente&id_agente=" . $layoutData['id_agent'] .
+ "&tab=module&edit_module=1&id_agent_module=" . $layoutData['id_agente_modulo'];
+ }
+ else {
+ $url = "index.php?sec=gagente&sec2=godmode/agentes/configurar_agente&id_agente=" . $layoutData['id_agent'] .
+ "&tab=module&edit_module=1&id_agent_module=" . $layoutData['id_agente_modulo'];
+ }
+ break;
+
+ case BARS_GRAPH:
+ if (empty($layout_data['id_metaconsole'])) {
+ $url = $config['homeurl'] . "index.php?sec=gagente&sec2=godmode/agentes/configurar_agente&id_agente=" . $layoutData['id_agent'] .
+ "&tab=module&edit_module=1&id_agent_module=" . $layoutData['id_agente_modulo'];
+ }
+ else {
+ $url = "index.php?sec=gagente&sec2=godmode/agentes/configurar_agente&id_agente=" . $layoutData['id_agent'] .
+ "&tab=module&edit_module=1&id_agent_module=" . $layoutData['id_agente_modulo'];
+ }
+ break;
+
case GROUP_ITEM:
$is_a_link_to_other_visualconsole = false;
if ($layoutData['id_layout_linked'] != 0) {
@@ -510,20 +550,15 @@ function visual_map_print_item($mode = "read", $layoutData,
case LABEL:
if ($layoutData['id_layout_linked'] != 0) {
// Link to a map
- if ($layoutData['id_metaconsole'] == 0) {
- $url = $config['homeurl'] .
- 'index.php?sec=reporting&sec2=operation/visual_console/render_view&pure='.$config["pure"].'&id='.$layoutData["id_layout_linked"];
- }
- else{
- $url = "index.php?sec=screen&sec2=screens/screens&action=visualmap&pure=0&id_visualmap=" . $layoutData["id_layout_linked"] . "&refr=0";
- }
+ $url = $config['homeurl'] .
+ 'index.php?sec=reporting&sec2=operation/visual_console/render_view&pure='.$config["pure"].'&id='.$layoutData["id_layout_linked"];
}
break;
case ICON:
$url_icon = "";
if ($layoutData['id_layout_linked'] != 0) {
// Link to a map
- if ($layoutData['id_metaconsole'] == 0) {
+ if (empty($layoutData['id_metaconsole'])) {
$url = 'index.php?sec=reporting&sec2=operation/visual_console/render_view&pure='.$config["pure"].'&id='.$layoutData["id_layout_linked"];
}
else {
@@ -586,7 +621,7 @@ function visual_map_print_item($mode = "read", $layoutData,
// Link to an module
if (empty($layoutData['id_metaconsole'])) {
$url = $config['homeurl'] .
- 'index.php?sec=estado&sec2=operation/agentes/status_monitor&id_module=' . $layoutData['id_agente_modulo'];
+ 'index.php?sec=view&sec2=operation/agentes/status_monitor&id_module=' . $layoutData['id_agente_modulo'];
}
else {
$url = ui_meta_get_url_console_child(
@@ -597,6 +632,8 @@ function visual_map_print_item($mode = "read", $layoutData,
break;
case PERCENTILE_BAR:
case PERCENTILE_BUBBLE:
+ case CIRCULAR_PROGRESS_BAR:
+ case CIRCULAR_INTERIOR_PROGRESS_BAR:
if (!empty($layoutData['id_agent'])) {
//Extract id service if it is a prediction module.
@@ -633,11 +670,11 @@ function visual_map_print_item($mode = "read", $layoutData,
$url =
$server["server_url"] .
- '/index.php?sec=estado&sec2=operation/agentes/status_monitor&id_module=' . $layoutData['id_agente_modulo'];
+ '/index.php?sec=view&sec2=operation/agentes/status_monitor&id_module=' . $layoutData['id_agente_modulo'];
}
else {
$url =
- $config['homeurl'].'/index.php?sec=estado&sec2=operation/agentes/status_monitor&id_module=' . $layoutData['id_agente_modulo'];
+ $config['homeurl'].'/index.php?sec=view&sec2=operation/agentes/status_monitor&id_module=' . $layoutData['id_agente_modulo'];
}
}
else {
@@ -701,7 +738,7 @@ function visual_map_print_item($mode = "read", $layoutData,
else {
if (empty($layoutData['id_metaconsole'])) {
$url = $config['homeurl'] .
- '/index.php?sec=estado&sec2=operation/agentes/status_monitor&id_module=' . $layoutData['id_agente_modulo'];
+ '/index.php?sec=view&sec2=operation/agentes/status_monitor&id_module=' . $layoutData['id_agente_modulo'];
}
else {
$url = ui_meta_get_url_console_child(
@@ -816,6 +853,8 @@ function visual_map_print_item($mode = "read", $layoutData,
break;
case PERCENTILE_BAR:
case PERCENTILE_BUBBLE:
+ case CIRCULAR_PROGRESS_BAR:
+ case CIRCULAR_INTERIOR_PROGRESS_BAR:
//Metaconsole db connection
if ($layoutData['id_metaconsole'] != 0) {
$connection = db_get_row_filter ('tmetaconsole_setup',
@@ -930,14 +969,14 @@ function visual_map_print_item($mode = "read", $layoutData,
else {
if ($width == 0 || $height == 0) {
if ($layoutData['label_position']=='left') {
- $img = ''.custom_graphs_print(
+ $img = '
'.custom_graphs_print(
$layoutData['id_custom_graph'], 180, 480,
$period, null, true, 0, $only_image, $layoutData['image'],
array(), '', array(), array(), true,
false, false, true, 1, false, true).'
';
}
elseif ($layoutData['label_position']=='right') {
- $img = '
'.custom_graphs_print(
+ $img = '
'.custom_graphs_print(
$layoutData['id_custom_graph'], 180, 480,
$period, null, true, 0, $only_image, $layoutData['image'],
array(), '', array(), array(), true,
@@ -957,14 +996,14 @@ function visual_map_print_item($mode = "read", $layoutData,
}
else {
if ($layoutData['label_position']=='left') {
- $img = '
'.custom_graphs_print(
+ $img = '
'.custom_graphs_print(
$layoutData['id_custom_graph'], $height, $width,
$period, null, true, 0, $only_image, $layoutData['image'],
array(), '', array(), array(), true,
false, false, true, 1, false, true).'
';
}
elseif($layoutData['label_position']=='right') {
- $img = '
'.custom_graphs_print(
+ $img = '
'.custom_graphs_print(
$layoutData['id_custom_graph'], $height, $width,
$period, null, true, 0, $only_image, $layoutData['image'],
array(), '', array(), array(), true,
@@ -1010,7 +1049,7 @@ function visual_map_print_item($mode = "read", $layoutData,
if ($width == 0 || $height == 0) {
if ($layoutData['label_position']=='left') {
- $img = '
'.
+ $img = '
'.
grafico_modulo_sparse($id_module, $period,
0, 300, 180, modules_get_agentmodule_name($id_module),null, false, 1, false, 0,
modules_get_unit($id_module), 0, 0, true, $only_image, '', 1, false, '',
@@ -1018,7 +1057,7 @@ function visual_map_print_item($mode = "read", $layoutData,
null, true, false, $type_graph) . '
';
}
elseif($layoutData['label_position']=='right') {
- $img = '
' .
+ $img = '
' .
grafico_modulo_sparse($id_module,
$period, 0, 300, 180, modules_get_agentmodule_name($id_module),null, false,
1, false, 0, modules_get_unit($id_module), 0, 0, true, $only_image, '',
@@ -1036,7 +1075,7 @@ function visual_map_print_item($mode = "read", $layoutData,
}
else{
if ($layoutData['label_position']=='left') {
- $img = '
' .
+ $img = '
' .
grafico_modulo_sparse($id_module, $period,
0, $width, $height, modules_get_agentmodule_name($id_module), null, false, 1,
false, 0, modules_get_unit($id_module), 0, 0, true, $only_image, '',
@@ -1045,7 +1084,7 @@ function visual_map_print_item($mode = "read", $layoutData,
false, $type_graph) . '
';
}
elseif ($layoutData['label_position']=='right') {
- $img = '
' .
+ $img = '
' .
grafico_modulo_sparse($id_module, $period,
0, $width, $height, modules_get_agentmodule_name($id_module), null, false, 1,
false, 0, modules_get_unit($id_module), 0, 0, true, $only_image,
@@ -1071,6 +1110,312 @@ function visual_map_print_item($mode = "read", $layoutData,
}
break;
+
+ case BARS_GRAPH:
+
+ $imgpos = '';
+
+ if($layoutData['label_position']=='left'){
+ $imgpos = 'float:right';
+ }
+ else if($layoutData['label_position']=='right'){
+ $imgpos = 'float:left';
+ }
+
+ if (!empty($proportion)) {
+ $width =
+ ((integer)($proportion['proportion_width'] * $width));
+ $height =
+ ((integer)($proportion['proportion_height'] * $height));
+ }
+ //Metaconsole db connection
+ if ($layoutData['id_metaconsole'] != 0) {
+ $connection = db_get_row_filter ('tmetaconsole_setup',
+ array('id' => $layoutData['id_metaconsole']));
+ if (metaconsole_load_external_db($connection) != NOERR) {
+ continue;
+ }
+ }
+
+ if ($isExternalLink)
+ $homeurl = $config['homeurl'];
+ else
+ $homeurl = '';
+
+ $is_string = db_get_value_filter ('id_tipo_modulo', 'tagente_modulo',
+ array ('id_agente' => $layoutData['id_agent'],
+ 'id_agente_modulo' => $id_module));
+
+ if ( (get_parameter('action') == 'edit') || (get_parameter('operation') == 'edit_visualmap') ) {
+ if($width == 0){
+ if ($layoutData['id_metaconsole'] != 0) {
+ $img = '
';
+ }
+ else{
+ $img = '
';
+ }
+ }
+ else{
+ if ($layoutData['id_metaconsole'] != 0) {
+ $img = '
';
+ }
+ else{
+ $img = '
';
+ }
+ }
+ }
+ else {
+ $color = array();
+
+ $color[0] = array('border' => '#000000',
+ 'color' => $config['graph_color1'],
+ 'alpha' => CHART_DEFAULT_ALPHA);
+ $color[1] = array('border' => '#000000',
+ 'color' => $config['graph_color2'],
+ 'alpha' => CHART_DEFAULT_ALPHA);
+ $color[2] = array('border' => '#000000',
+ 'color' => $config['graph_color3'],
+ 'alpha' => CHART_DEFAULT_ALPHA);
+ $color[3] = array('border' => '#000000',
+ 'color' => $config['graph_color4'],
+ 'alpha' => CHART_DEFAULT_ALPHA);
+ $color[4] = array('border' => '#000000',
+ 'color' => $config['graph_color5'],
+ 'alpha' => CHART_DEFAULT_ALPHA);
+ $color[5] = array('border' => '#000000',
+ 'color' => $config['graph_color6'],
+ 'alpha' => CHART_DEFAULT_ALPHA);
+ $color[6] = array('border' => '#000000',
+ 'color' => $config['graph_color7'],
+ 'alpha' => CHART_DEFAULT_ALPHA);
+ $color[7] = array('border' => '#000000',
+ 'color' => $config['graph_color8'],
+ 'alpha' => CHART_DEFAULT_ALPHA);
+ $color[8] = array('border' => '#000000',
+ 'color' => $config['graph_color9'],
+ 'alpha' => CHART_DEFAULT_ALPHA);
+ $color[9] = array('border' => '#000000',
+ 'color' => $config['graph_color10'],
+ 'alpha' => CHART_DEFAULT_ALPHA);
+ $color[11] = array('border' => '#000000',
+ 'color' => COL_GRAPH9,
+ 'alpha' => CHART_DEFAULT_ALPHA);
+ $color[12] = array('border' => '#000000',
+ 'color' => COL_GRAPH10,
+ 'alpha' => CHART_DEFAULT_ALPHA);
+ $color[13] = array('border' => '#000000',
+ 'color' => COL_GRAPH11,
+ 'alpha' => CHART_DEFAULT_ALPHA);
+ $color[14] = array('border' => '#000000',
+ 'color' => COL_GRAPH12,
+ 'alpha' => CHART_DEFAULT_ALPHA);
+ $color[15] = array('border' => '#000000',
+ 'color' => COL_GRAPH13,
+ 'alpha' => CHART_DEFAULT_ALPHA);
+
+ $module_data = get_bars_module_data($id_module);
+ $water_mark = array('file' => '/var/www/html/pandora_console/images/logo_vertical_water.png',
+ 'url' => 'http://localhost/pandora_console/images/logo_vertical_water.png');
+
+ if ($width == 0 && $height == 0) {
+ if ($layoutData['label_position']=='left') {
+ if ($layoutData['type_graph'] == 'horizontal') {
+ $img = '
'.
+ hbar_graph(true, $module_data,
+ 400, 400, $color, array(), array(),
+ ui_get_full_url("images/image_problem.opaque.png", false, false, false),
+ "", "", $water_mark, $config['fontpath'], 6,
+ "", 0, $config['homeurl'], $layoutData['image'], $layoutData['border_color']) . '
';
+ }
+ else {
+ $img = '
'.
+ vbar_graph(true, $module_data,
+ 400, 400, $color, array(), array(),
+ ui_get_full_url("images/image_problem.opaque.png", false, false, false),
+ "", "", $water_mark, $config['fontpath'], 6,
+ "", 0, $config['homeurl'], $layoutData['image'], true, false, $layoutData['border_color']) . '
';
+ }
+ }
+ elseif($layoutData['label_position']=='right') {
+ if ($layoutData['type_graph'] == 'horizontal') {
+ $img = '
'.
+ hbar_graph(true, $module_data,
+ 400, 400, $color, array(), array(),
+ ui_get_full_url("images/image_problem.opaque.png", false, false, false),
+ "", "", $water_mark, $config['fontpath'], 6,
+ "", 0, $config['homeurl'], $layoutData['image'], $layoutData['border_color']) . '
';
+ }
+ else {
+ $img = '
'.
+ vbar_graph(true, $module_data,
+ 400, 400, $color, array(), array(),
+ ui_get_full_url("images/image_problem.opaque.png", false, false, false),
+ "", "", $water_mark, $config['fontpath'], 6,
+ "", 0, $config['homeurl'], $layoutData['image'], true, false, $layoutData['border_color']) . '
';
+ }
+ }
+ else {
+ if ($layoutData['type_graph'] == 'horizontal') {
+ $img = hbar_graph(true, $module_data,
+ 400, 400, $color, array(), array(),
+ ui_get_full_url("images/image_problem.opaque.png", false, false, false),
+ "", "", $water_mark, $config['fontpath'], 6,
+ "", 0, $config['homeurl'], $layoutData['image'], $layoutData['border_color']);
+ }
+ else {
+ $img = vbar_graph(true, $module_data,
+ 400, 400, $color, array(), array(),
+ ui_get_full_url("images/image_problem.opaque.png", false, false, false),
+ "", "", $water_mark, $config['fontpath'], 6,
+ "", 0, $config['homeurl'], $layoutData['image'], true, false, $layoutData['border_color']);
+ }
+ }
+ }
+ else{
+ if ($layoutData['label_position']=='left') {
+ if ($layoutData['type_graph'] == 'horizontal') {
+ $img = '
'.
+ hbar_graph(true, $module_data,
+ $width, $height, $color, array(), array(),
+ ui_get_full_url("images/image_problem.opaque.png", false, false, false),
+ "", "", $water_mark, $config['fontpath'], 6,
+ "", 0, $config['homeurl'], $layoutData['image'], $layoutData['border_color']) . '
';
+ }
+ else {
+ $img = '
'.
+ vbar_graph(true, $module_data,
+ $width, $height, $color, array(), array(),
+ ui_get_full_url("images/image_problem.opaque.png", false, false, false),
+ "", "", $water_mark, $config['fontpath'], 6,
+ "", 0, $config['homeurl'], $layoutData['image'], true, false, $layoutData['border_color']) . '
';
+ }
+ }
+ elseif($layoutData['label_position']=='right') {
+ if ($layoutData['type_graph'] == 'horizontal') {
+ $img = '
'.
+ hbar_graph(true, $module_data,
+ $width, $height, $color, array(), array(),
+ ui_get_full_url("images/image_problem.opaque.png", false, false, false),
+ "", "", $water_mark, $config['fontpath'], 6,
+ "", 0, $config['homeurl'], $layoutData['image'], $layoutData['border_color']) . '
';
+ }
+ else {
+ $img = '
'.
+ vbar_graph(true, $module_data,
+ $width, $height, $color, array(), array(),
+ ui_get_full_url("images/image_problem.opaque.png", false, false, false),
+ "", "", $water_mark, $config['fontpath'], 6,
+ "", 0, $config['homeurl'], $layoutData['image'], true, false, $layoutData['border_color']) . '
';
+ }
+ }
+ else {
+ if ($layoutData['type_graph'] == 'horizontal') {
+ $img = hbar_graph(true, $module_data,
+ $width, $height, $color, array(), array(),
+ ui_get_full_url("images/image_problem.opaque.png", false, false, false),
+ "", "", $water_mark, $config['fontpath'], 6,
+ "", 0, $config['homeurl'], $layoutData['image'], $layoutData['border_color']);
+ }
+ else {
+ $img = vbar_graph(true, $module_data,
+ $width, $height, $color, array(), array(),
+ ui_get_full_url("images/image_problem.opaque.png", false, false, false),
+ "", "", $water_mark, $config['fontpath'], 6,
+ "", 0, $config['homeurl'], $layoutData['image'], true, false, $layoutData['border_color']);
+ }
+ }
+ }
+ }
+
+ //Restore db connection
+ if ($layoutData['id_metaconsole'] != 0) {
+ metaconsole_restore_db();
+ }
+
+ break;
+
+ case DONUT_GRAPH:
+ if (!empty($id_metaconsole)) {
+ $connection = db_get_row_filter ('tmetaconsole_setup', $id_metaconsole);
+ if (metaconsole_load_external_db($connection) != NOERR) {
+ continue;
+ }
+ }
+
+
+ $is_string = db_get_value_filter ('id_tipo_modulo', 'tagente_modulo',
+ array ('id_agente' => $layoutData['id_agent'],
+ 'id_agente_modulo' => $id_module));
+
+ if (!empty($id_metaconsole)) {
+ metaconsole_restore_db();
+ }
+
+ if (($is_string == 17) || ($is_string == 23) || ($is_string == 3) ||
+ ($is_string == 10) || ($is_string == 33)) {
+ $no_data = false;
+ }
+ else {
+ $no_data = true;
+ }
+
+ if ($no_data) {
+ if($width == 0){
+ if ($layoutData['id_metaconsole'] != 0) {
+ $img = '
';
+ }
+ else{
+ $img = '
';
+ }
+ }
+ else{
+ if ($layoutData['id_metaconsole'] != 0) {
+ $img = '
';
+ }
+ else{
+ $img = '
';
+ }
+ }
+ }
+ else {
+ $donut_data = get_donut_module_data($layoutData['id_agente_modulo']);
+
+ if ((get_parameter('action') == 'edit') || (get_parameter('operation') == 'edit_visualmap')) {
+ if($width == 0){
+ if ($layoutData['id_metaconsole'] != 0) {
+ $img = '
';
+ }
+ else{
+ $img = '
';
+ }
+ }
+ else{
+ if ($layoutData['id_metaconsole'] != 0) {
+ $img = '
';
+ }
+ else{
+ $img = '
';
+ }
+ }
+ }
+ else {
+ if ($width == 0) {
+ $img = d3_donut_graph ($layoutData['id'], 300, 300, $donut_data, $layoutData['border_color']);
+ }
+ else{
+ $img = d3_donut_graph ($layoutData['id'], $width, $width, $donut_data, $layoutData['border_color']);
+ }
+ }
+ }
+
+ //Restore db connection
+ if ($layoutData['id_metaconsole'] != 0) {
+ metaconsole_restore_db();
+ }
+
+ $z_index = 2 + 1;
+ break;
+
case LABEL:
$z_index = 4 + 1;
break;
@@ -1081,10 +1426,10 @@ function visual_map_print_item($mode = "read", $layoutData,
if ((get_parameter('action') == 'edit') || (get_parameter('operation') == 'edit_visualmap')) {
if($width == 0 || $height == 0){
if ($layoutData['id_metaconsole'] != 0) {
- $img = '
';
+ $img = '
';
}
else{
- $img = '
';
+ $img = '
';
}
}
else{
@@ -1099,10 +1444,10 @@ function visual_map_print_item($mode = "read", $layoutData,
else {
if ($width == 0 || $height == 0) {
if ($layoutData['label_position']=='left') {
- $img = '
' .graph_graphic_moduleevents ($layoutData['id_agent'], $layoutData['id_agente_modulo'], 500, 50, $layoutData['period'], '', true).'
';
+ $img = '
' .graph_graphic_moduleevents ($layoutData['id_agent'], $layoutData['id_agente_modulo'], 500, 50, $layoutData['period'], '', true).'
';
}
elseif ($layoutData['label_position']=='right') {
- $img = '
' . graph_graphic_moduleevents ($layoutData['id_agent'], $layoutData['id_agente_modulo'], 500, 50, $layoutData['period'], '', true).'
';
+ $img = '
' . graph_graphic_moduleevents ($layoutData['id_agent'], $layoutData['id_agente_modulo'], 500, 50, $layoutData['period'], '', true).'
';
}
else {
$img = graph_graphic_moduleevents ($layoutData['id_agent'], $layoutData['id_agente_modulo'], 500, 50, $layoutData['period'], '', true);
@@ -1110,10 +1455,10 @@ function visual_map_print_item($mode = "read", $layoutData,
}
else{
if ($layoutData['label_position']=='left') {
- $img = '
' . graph_graphic_moduleevents ($layoutData['id_agent'], $layoutData['id_agente_modulo'], $width, $height, $layoutData['period'], '', true).'
';
+ $img = '
' . graph_graphic_moduleevents ($layoutData['id_agent'], $layoutData['id_agente_modulo'], $width, $height, $layoutData['period'], '', true).'
';
}
elseif ($layoutData['label_position']=='right') {
- $img = '
' .graph_graphic_moduleevents ($layoutData['id_agent'], $layoutData['id_agente_modulo'], $width, $height, $layoutData['period'], '', true).'
';
+ $img = '
' .graph_graphic_moduleevents ($layoutData['id_agent'], $layoutData['id_agente_modulo'], $width, $height, $layoutData['period'], '', true).'
';
}
else {
$img = graph_graphic_moduleevents ($layoutData['id_agent'], $layoutData['id_agente_modulo'], $width, $height, $layoutData['period'], '', true);
@@ -1141,13 +1486,21 @@ function visual_map_print_item($mode = "read", $layoutData,
case GROUP_ITEM:
$class .= "group_item";
break;
+ case DONUT_GRAPH:
+ $class .= "donut_graph";
+ break;
case PERCENTILE_BAR:
case PERCENTILE_BUBBLE:
+ case CIRCULAR_PROGRESS_BAR:
+ case CIRCULAR_INTERIOR_PROGRESS_BAR:
$class .= "percentile_item";
break;
case MODULE_GRAPH:
$class .= "module_graph";
break;
+ case BARS_GRAPH:
+ $class .= "bars_graph";
+ break;
case SIMPLE_VALUE:
case SIMPLE_VALUE_MAX:
case SIMPLE_VALUE_MIN:
@@ -1170,6 +1523,10 @@ function visual_map_print_item($mode = "read", $layoutData,
break;
}
+ if($show_on_top){
+ $z_index = 10;
+ }
+
echo '
";
}
- //for clean link text from bbdd
- if (get_parameter('action') == 'edit' || get_parameter('operation') == 'edit_visualmap') {
- $text = preg_replace("/<\/*a.*?>/", '', $text);
- }
+ //for clean link text from bbdd only edit_visualmap
+ if (get_parameter('action') == 'edit' || get_parameter('operation') == 'edit_visualmap') {
+ $text = preg_replace("/<\/*a.*?>/", '', $text);
+ }
switch ($type) {
case BOX_ITEM:
@@ -1196,7 +1553,7 @@ function visual_map_print_item($mode = "read", $layoutData,
$style .= "border-width: " . $border_width . "px; ";
$style .= "border-color: " . $border_color . "; ";
$style .= "background-color: " . $fill_color . "; ";
- echo "
";
+ echo "
";
}
else {
if (!empty($proportion)) {
@@ -1207,7 +1564,7 @@ function visual_map_print_item($mode = "read", $layoutData,
$style .= "border-width: " . $border_width . "px; ";
$style .= "border-color: " . $border_color . "; ";
$style .= "background-color: " . $fill_color . "; ";
- echo "
";
+ echo "
";
}
else {
$style = "";
@@ -1217,13 +1574,14 @@ function visual_map_print_item($mode = "read", $layoutData,
$style .= "border-width: " . $border_width . "px; ";
$style .= "border-color: " . $border_color . "; ";
$style .= "background-color: " . $fill_color . "; ";
- echo "
";
+ echo "
";
}
}
break;
case STATIC_GRAPH:
case GROUP_ITEM:
- if ($layoutData['image'] != null || $layoutData['show_statistics'] == 1) {
+
+ if (($layoutData['image'] != null && $layoutData['image'] != 'none') || $layoutData['show_statistics'] == 1) {
$img_style_title = strip_tags($label);
@@ -1242,8 +1600,12 @@ function visual_map_print_item($mode = "read", $layoutData,
if (!empty($unit_text))
$value .= " " . $unit_text;
- $img_style_title .= "
" . __("Last value: ") .
- $value;
+ // Hide value on boolean modules
+ if (!modules_is_boolean($layoutData['id_agente_modulo'])) {
+ $img_style_title .=
+ "
" . __("Last value: ")
+ . $value;
+ }
}
if(get_parameter('action') == 'edit'){
@@ -1278,12 +1640,9 @@ function visual_map_print_item($mode = "read", $layoutData,
$imgpos = 'float:left';
}
- if ($layoutData['id_metaconsole'] != 0) {
- $img = "../../" . $img;
- }
-
$varsize = getimagesize($img);
+
if($layoutData['show_statistics'] == 1){
if (get_parameter('action') == 'edit') {
@@ -1377,35 +1736,34 @@ function visual_map_print_item($mode = "read", $layoutData,
else{
if ($width == 0 || $height == 0) {
-
if($varsize[0] > 150 || $varsize[1] > 150){
echo html_print_image($img, true,
- array("class" => "image",
- "id" => "image_" . $id,
- "width" => "70px",
- "height" => "70px",
- "title" => $img_style_title,
- "style" => $borderStyle.$imgpos), false,
- false, false, $isExternalLink);
+ array("class" => "image",
+ "id" => "image_" . $id,
+ "width" => "70px",
+ "height" => "70px",
+ "title" => $img_style_title,
+ "style" => $borderStyle.$imgpos), false,
+ false, false, $isExternalLink);
}
else{
echo html_print_image($img, true,
- array("class" => "image",
- "id" => "image_" . $id,
- "title" => $img_style_title,
- "style" => $borderStyle.$imgpos), false,
- false, false, $isExternalLink);
+ array("class" => "image",
+ "id" => "image_" . $id,
+ "title" => $img_style_title,
+ "style" => $borderStyle.$imgpos), false,
+ false, false, $isExternalLink);
}
}
else{
- echo html_print_image($img, true,
- array("class" => "image",
- "id" => "image_" . $id,
- "width" => $width,
- "height" => $height,
- "title" => $img_style_title,
- "style" => $borderStyle.$imgpos), false,
- false, false, $isExternalLink);
+ echo html_print_image($img, true,
+ array("class" => "image",
+ "id" => "image_" . $id,
+ "width" => $width,
+ "height" => $height,
+ "title" => $img_style_title,
+ "style" => $borderStyle.$imgpos), false,
+ false, false, $isExternalLink);
}
}
@@ -1422,145 +1780,173 @@ function visual_map_print_item($mode = "read", $layoutData,
break;
case PERCENTILE_BAR:
- $imgpos = '';
-
- if($layoutData['label_position']=='left'){
- $imgpos = 'float:right;';
- }
- else if($layoutData['label_position']=='right'){
- $imgpos = 'float:left;';
- }
-
- $progress_bar_heigh = 15;
- if (!empty($proportion)) {
- if ($width != 0) {
- $width = (integer)($proportion['proportion_width'] * $width);
- }
- else {
- $width = (integer)($proportion['proportion_width'] * $infoImage[0]);
- }
+ if (($layoutData['image'] == 'value') && ($value_text !== false)) {
+ $unit_text = db_get_sql ('SELECT unit
+ FROM tagente_modulo
+ WHERE id_agente_modulo = ' . $id_module);
+ $unit_text = trim(io_safe_output($unit_text));
- if ($height != 0) {
- $height = (integer)($proportion['proportion_height'] * $height);
- $progress_bar_heigh = $progress_bar_heigh * $proportion['proportion_height'];
- }
- else {
- $height = (integer)($proportion['proportion_height'] * $infoImage[1]);
- }
- }
-
- if($layoutData['label_position']=='up'){
- echo io_safe_output($text);
- }
-
- ob_start();
- if ($type == PERCENTILE_BUBBLE) {
- echo progress_bubble($percentile, $width, $width, '', 1, $value_text, $colorStatus,$imgpos);
+ $percentile = $value_text;
}
else {
- echo progress_bar($percentile, $width, $progress_bar_heigh, '', 1, $value_text, $colorStatus,$imgpos);
+ $unit_text = "%";
}
- $img = ob_get_clean();
- if (get_parameter('action') == 'edit') {
- if ($width == 0) {
- $img = '
';
+ if (get_parameter('action') == 'edit' || (get_parameter('operation') == 'edit_visualmap')) {
+ if($width == 0){
+ if ($layoutData['id_metaconsole'] != 0) {
+ $img = '
';
+ }
+ else{
+ $img = '
';
+ }
}
- else {
- $img = '
';
+ else{
+ if ($layoutData['id_metaconsole'] != 0) {
+ $img = '
';
+ }
+ else{
+ $img = '
';
+ }
}
}
else{
- $img = str_replace('>', 'class="image" style="height:'.$himg.'px;width:'.$wimg.'px;'.$imgpos.'" id="image_' . $id . '" />', $img);
+ $img = d3_progress_bar($id, $percentile, $width, 50, $border_color, $unit_text, io_safe_output($label), $fill_color);
}
- echo $img;
+ echo $img;
- if($layoutData['label_position']=='down'){
- echo io_safe_output($text);
- }
- else if($layoutData['label_position']=='left' || $layoutData['label_position']=='right'){
- echo io_safe_output($text);
- }
-
break;
-
case PERCENTILE_BUBBLE:
-
- $imgpos = '';
-
- if($layoutData['label_position']=='left'){
- $imgpos = 'float:right;';
+ if (($layoutData['image'] == 'value') && ($value_text !== false)) {
+ $unit_text = db_get_sql ('SELECT unit
+ FROM tagente_modulo
+ WHERE id_agente_modulo = ' . $id_module);
+ $unit_text = trim(io_safe_output($unit_text));
+
+ $percentile = $value_text;
}
- else if($layoutData['label_position']=='right'){
- $imgpos = 'float:left;';
+ else {
+ $unit_text = "%";
}
-
- $progress_bar_heigh = 15;
- if (!empty($proportion)) {
- if ($width != 0) {
- $width = (integer)($proportion['proportion_width'] * $width);
+
+ if(get_parameter('action') == 'edit' || (get_parameter('operation') == 'edit_visualmap')){
+ if($width == 0){
+ if ($layoutData['id_metaconsole'] != 0) {
+ $img = '
';
+ }
+ else{
+ $img = '
';
+ }
+ }
+ else{
+ if ($layoutData['id_metaconsole'] != 0) {
+ $img = '
';
+ }
+ else{
+ $img = '
';
+ }
+ }
+ }
+ else{
+ if($width == 0){
+ $img = d3_progress_bubble($id, $percentile, 200,200, $border_color, $unit_text, io_safe_output($label), $fill_color);
+ }
+ else{
+ $img = d3_progress_bubble($id, $percentile, $width, $width, $border_color, $unit_text, io_safe_output($label), $fill_color);
+ }
+ }
+
+ echo $img;
+
+ break;
+ case CIRCULAR_PROGRESS_BAR:
+ if(get_parameter('action') == 'edit' || (get_parameter('operation') == 'edit_visualmap')){
+ if($width == 0){
+ if ($layoutData['id_metaconsole'] != 0) {
+ $img = '
';
+ }
+ else{
+ $img = '
';
+ }
+ }
+ else{
+ if ($layoutData['id_metaconsole'] != 0) {
+ $img = '
';
+ }
+ else{
+ $img = '
';
+ }
+ }
+ }
+ else {
+ if (($layoutData['image'] == 'value') && ($value_text !== false)) {
+ $unit_text = db_get_sql ('SELECT unit
+ FROM tagente_modulo
+ WHERE id_agente_modulo = ' . $id_module);
+ $unit_text = trim(io_safe_output($unit_text));
+
+ $percentile = $value_text;
}
else {
- $width = (integer)($proportion['proportion_width'] * $infoImage[0]);
+ $unit_text = "%";
}
- if ($height != 0) {
- $height = (integer)($proportion['proportion_height'] * $height);
- $progress_bar_heigh = $progress_bar_heigh * $proportion['proportion_height'];
+ if($width == 0){
+ $img = progress_circular_bar($id, $percentile, 200,200, $border_color, $unit_text, io_safe_output($label), $fill_color);
}
- else {
- $height = (integer)($proportion['proportion_height'] * $infoImage[1]);
+ else{
+ $img = progress_circular_bar($id, $percentile, $width, $width, $border_color, $unit_text, io_safe_output($label), $fill_color);
}
}
+
+ echo $img;
- if($layoutData['label_position']=='up'){
- echo io_safe_output($text);
- }
-
- ob_start();
- if ($type == PERCENTILE_BUBBLE) {
+ break;
+ case CIRCULAR_INTERIOR_PROGRESS_BAR:
+ if(get_parameter('action') == 'edit' || (get_parameter('operation') == 'edit_visualmap')){
if($width == 0){
- echo progress_bubble($percentile, 100,100, '', 1, $value_text, $colorStatus,$s);
+ if ($layoutData['id_metaconsole'] != 0) {
+ $img = '
';
+ }
+ else{
+ $img = '
';
+ }
+ }
+ else{
+ if ($layoutData['id_metaconsole'] != 0) {
+ $img = '
';
+ }
+ else{
+ $img = '
';
+ }
+ }
+ }
+ else {
+ if (($layoutData['image'] == 'value') && ($value_text !== false)) {
+ $unit_text = db_get_sql ('SELECT unit
+ FROM tagente_modulo
+ WHERE id_agente_modulo = ' . $id_module);
+ $unit_text = trim(io_safe_output($unit_text));
+
+ $percentile = $value_text;
+ }
+ else {
+ $unit_text = "%";
+ }
+
+ if($width == 0){
+ $img = progress_circular_bar_interior($id, $percentile, 200,200, $border_color, $unit_text, io_safe_output($label), $fill_color);
}
else{
- echo progress_bubble($percentile, $width,$width, '', 1, $value_text, $colorStatus);
+ $img = progress_circular_bar_interior($id, $percentile, $width, $width, $border_color, $unit_text, io_safe_output($label), $fill_color);
}
}
- else {
- echo progress_bar($percentile, $width, $progress_bar_heigh, '', 1, $value_text, $colorStatus);
- }
- $img = ob_get_clean();
-
- if(get_parameter('action') == 'edit'){
-
- if($width == 0){
- $img = '
';
- }
- else{
- $img = '
';
- }
-
- }
- else{
-
- $img = str_replace('>', 'class="image" style="width:'.$wimg.'px;height:'.$himg.'px;'.$imgpos.'" id="image_' . $id . '" />', $img);
-
- }
-
- echo $img;
-
- if($layoutData['label_position']=='down'){
- echo io_safe_output($text);
- }
- else if($layoutData['label_position']=='left' || $layoutData['label_position']=='right'){
- echo io_safe_output($text);
- }
+ echo $img;
break;
-
case MODULE_GRAPH:
if ($layoutData['label_position']=='up') {
echo io_safe_output($text);
@@ -1568,6 +1954,20 @@ function visual_map_print_item($mode = "read", $layoutData,
echo $img;
+ if ($layoutData['label_position']=='down') {
+ echo io_safe_output($text);
+ }
+ elseif($layoutData['label_position']=='left' || $layoutData['label_position']=='right') {
+ echo io_safe_output($text);
+ }
+ break;
+ case BARS_GRAPH:
+ if ($layoutData['label_position']=='up') {
+ echo io_safe_output($text);
+ }
+
+ echo $img;
+
if ($layoutData['label_position']=='down') {
echo io_safe_output($text);
}
@@ -1589,6 +1989,10 @@ function visual_map_print_item($mode = "read", $layoutData,
echo io_safe_output($text);
}
break;
+ case DONUT_GRAPH:
+ echo $img;
+ break;
+
case SIMPLE_VALUE:
case SIMPLE_VALUE_MAX:
case SIMPLE_VALUE_MIN:
@@ -1618,39 +2022,25 @@ function visual_map_print_item($mode = "read", $layoutData,
global $config;
- if ($type == SIMPLE_VALUE) {
- //~ $returnValue_value = explode(' ', $value);
-
- //~ if ($returnValue_value[1] != "") {
- //~ $value = remove_right_zeros(number_format($returnValue_value[0], $config['graph_precision'])) . " " . $returnValue_value[1];
- //~ }
- //~ else {
- //~ $value = remove_right_zeros(number_format($returnValue_value[0], $config['graph_precision']));
- //~ }
-
- }
- else {
- // If the value is a string, dont format it
- if (!is_string($value)) {
- //~ $value = remove_right_zeros(format_for_graph($value, $config['graph_precision']));
- }
- }
-
- if(get_parameter('action') == 'edit'){
- if( (strip_tags($io_safe_output_text) != '_VALUE_') || (strip_tags($io_safe_output_text) != '(_VALUE_)') ) {
+ $is_image = get_if_module_is_image($layoutData['id_agente_modulo']);
+ if(get_parameter('action') == 'edit') {
+ if(!$is_image) {
echo $io_safe_output_text;
}
else {
echo "
";
}
- } else {
- if(strrpos(strip_tags($io_safe_output_text),'(_VALUE_)') !== false || (strip_tags($io_safe_output_text) == '(_VALUE_)')) {
- echo str_replace(array("(_VALUE_)","(_value_)"), $value, $io_safe_output_text);
+ }
+ else {
+ if(!$is_image) {
+ $new_text = str_replace(array("(_VALUE_)","(_value_)"), $value, $io_safe_output_text);
+ $new_text = str_replace(array('_VALUE_','_value_'), $value, $new_text);
+
+ echo $new_text;
}
- elseif(strrpos(strip_tags($io_safe_output_text),'_VALUE_') !== false || (strip_tags($io_safe_output_text) == '_VALUE_')) {
- echo str_replace(array('_VALUE_','_value_'), $value, $io_safe_output_text);
- } else {
- echo str_replace('>', ' style="width:'.$layoutData['width'].'px">',$value);
+ else {
+ $simple_value_img = str_replace('>', ' style="width:'.$layoutData['width'].'px">', $value);
+ echo $simple_value_img;
}
}
@@ -1740,6 +2130,43 @@ function visual_map_print_item($mode = "read", $layoutData,
}
}
+function get_if_module_is_image ($id_module) {
+ $sql = 'SELECT datos FROM tagente_estado WHERE id_agente_modulo = ' . $id_module;
+
+ $result = db_get_sql($sql);
+ $image = strpos($result, 'data:image');
+
+ if($image === false){
+ return false;
+ }
+ else{
+ return true;
+ }
+}
+
+function get_bars_module_data ($id_module) {
+ $mod_values = db_get_value_filter('datos', 'tagente_estado', array('id_agente_modulo' => $id_module));
+
+ if (preg_match("/\r\n/", $mod_values)) {
+ $values = explode("\r\n", $mod_values);
+ }
+ elseif (preg_match("/\n/", $mod_values)) {
+ $values = explode("\n", $mod_values);
+ }
+
+ $values_to_return = array();
+ $index = 0;
+ $color_index = 0;
+ $total = 0;
+ foreach ($values as $val) {
+ $data = explode(",", $val);
+ $values_to_return[$data[0]] = array('g' =>$data[1]);
+ }
+
+ return $values_to_return;
+}
+
+
/**
* The function to get simple value type from the value of process type in the form
*
@@ -1903,11 +2330,19 @@ function visual_map_process_wizard_add ($id_agents, $image, $id_layout, $range,
switch ($type) {
case PERCENTILE_BAR:
case PERCENTILE_BUBBLE:
+ case CIRCULAR_PROGRESS_BAR:
+ case CIRCULAR_INTERIOR_PROGRESS_BAR:
$value_height = $max_value;
$value_image = $value_show;
if ($type_percentile == 'percentile') {
$value_type = PERCENTILE_BAR;
}
+ elseif ($type_percentile == 'interior_circular_progress_bar') {
+ $value_type = CIRCULAR_INTERIOR_PROGRESS_BAR;
+ }
+ elseif ($type_percentile == 'circular_progress_bar') {
+ $value_type = CIRCULAR_PROGRESS_BAR;
+ }
else {
$value_type = PERCENTILE_BUBBLE;
}
@@ -2029,12 +2464,20 @@ function visual_map_process_wizard_add_modules ($id_modules, $image,
switch ($type) {
case PERCENTILE_BAR:
case PERCENTILE_BUBBLE:
+ case CIRCULAR_PROGRESS_BAR:
+ case CIRCULAR_INTERIOR_PROGRESS_BAR:
$value_height = $max_value;
$value_width = $percentileitem_width;
$value_image = $value_show;
if ($type_percentile == 'percentile') {
$value_type = PERCENTILE_BAR;
}
+ elseif ($type_percentile == 'interior_circular_progress_bar') {
+ $value_type = CIRCULAR_INTERIOR_PROGRESS_BAR;
+ }
+ elseif ($type_percentile == 'circular_progress_bar') {
+ $value_type = CIRCULAR_PROGRESS_BAR;
+ }
else {
$value_type = PERCENTILE_BUBBLE;
}
@@ -2092,6 +2535,88 @@ function visual_map_process_wizard_add_modules ($id_modules, $image,
return $return;
}
+function get_donut_module_data ($id_module) {
+ $mod_values = db_get_value_filter('datos', 'tagente_estado', array('id_agente_modulo' => $id_module));
+
+ if (preg_match("/\r\n/", $mod_values)) {
+ $values = explode("\r\n", $mod_values);
+ }
+ elseif (preg_match("/\n/", $mod_values)) {
+ $values = explode("\n", $mod_values);
+ }
+
+ $colors = array();
+ $colors[] = "#aa3333";
+ $colors[] = "#045FB4";
+ $colors[] = "#8181F7";
+ $colors[] = "#F78181";
+ $colors[] = "#D0A9F5";
+ $colors[] = "#BDBDBD";
+ $colors[] = "#6AB277";
+
+ $max_elements = 6;
+ $values_to_return = array();
+ $index = 0;
+ $total = 0;
+ foreach ($values as $val) {
+ if ($index < $max_elements) {
+ $data = explode(",", $val);
+ if ($data[1] == 0) {
+ $data[1] = __('No data');
+ }
+ $values_to_return[$index]['tag_name'] = $data[0] . ": " . $data[1];
+ $values_to_return[$index]['color'] = $colors[$index];
+ $values_to_return[$index]['value'] = (int)$data[1];
+ $total += (int)$data[1];
+ $index++;
+ }
+ else {
+ if ($data[1] == 0) {
+ $data[1] = __('No data');
+ }
+ $data = explode(",", $val);
+ $values_to_return[$index]['tag_name'] = __('Others') . ": " . $data[1];
+ $values_to_return[$index]['color'] = $colors[$index];
+ $values_to_return[$index]['value'] += (int)$data[1];
+ $total += (int)$data[1];
+ }
+ }
+
+ foreach ($values_to_return as $ind => $donut_data) {
+ $values_to_return[$ind]['percent'] = ($donut_data['value'] * 100) / $total;
+ }
+
+ $new_values_to_return = array();
+ while (!empty($values_to_return)) {
+ $first = true;
+ $max_elem = 0;
+ $max_elem_array = array();
+ $index_to_del = 0;
+ foreach ($values_to_return as $i => $val) {
+ if ($first) {
+ $max_elem = $val['value'];
+ $max_elem_array = $val;
+ $index_to_del = $i;
+ $first = false;
+ }
+ else {
+ if ($val['value'] > $max_elem) {
+ $max_elem = $val['value'];
+ $max_elem_array = $val;
+ $index_to_del = $i;
+ }
+ }
+ }
+
+ $new_values_to_return[] = $max_elem_array;
+ unset($values_to_return[$index_to_del]);
+ }
+ $values_to_return = $new_values_to_return;
+
+ return $values_to_return;
+}
+
+
/**
* The function to save the new elements of agents make as wizard.
*
@@ -2157,12 +2682,20 @@ function visual_map_process_wizard_add_agents ($id_agents, $image,
switch ($type) {
case PERCENTILE_BAR:
case PERCENTILE_BUBBLE:
+ case CIRCULAR_PROGRESS_BAR:
+ case CIRCULAR_INTERIOR_PROGRESS_BAR:
$value_height = $max_value;
$value_width = $percentileitem_width;
$value_image = $value_show;
if ($type_percentile == 'percentile') {
$value_type = PERCENTILE_BAR;
}
+ elseif ($type_percentile == 'interior_circular_progress_bar') {
+ $value_type = CIRCULAR_INTERIOR_PROGRESS_BAR;
+ }
+ elseif ($type_percentile == 'circular_progress_bar') {
+ $value_type = CIRCULAR_PROGRESS_BAR;
+ }
else {
$value_type = PERCENTILE_BUBBLE;
}
@@ -2383,6 +2916,8 @@ function visual_map_get_image_status_element($layoutData, $status = false) {
* @return integer
*/
function visual_map_get_status_element($layoutData) {
+ global $config;
+
enterprise_include_once('include/functions_visual_map.php');
if (enterprise_installed()) {
$status = enterprise_visual_map_get_status_element($layoutData);
@@ -2400,7 +2935,34 @@ function visual_map_get_status_element($layoutData) {
//Linked to other layout ?? - Only if not module defined
if ($layoutData['id_layout_linked'] != 0) {
- $status = visual_map_get_layout_status ($layoutData['id_layout_linked']);
+ if ($layoutData['id_layout_linked_weight'] != 0) {
+ $calculate_weight = true;
+ }
+ else {
+ $calculate_weight = false;
+ }
+ $status = visual_map_get_layout_status ($layoutData['id_layout_linked'], 0, 0, $calculate_weight);
+
+ if ($layoutData['id_layout_linked_weight'] > 0) {
+ $elements_to_compare = db_get_all_rows_sql("SELECT id, element_group FROM tlayout_data WHERE type = 0 AND id_layout = " . $layoutData['id_layout_linked']);
+
+ $childs_group_acl = array();
+ foreach ($elements_to_compare as $c) {
+ if (check_acl ($config['id_user'], $c['element_group'], "VR")) {
+ $childs_group_acl[] = $c['id'];
+ }
+ }
+ $elements_to_compare = $childs_group_acl;
+
+ $aux_weight = ($status['elements_in_critical'] / count($elements_to_compare)) * 100;
+
+ if ($aux_weight >= $layoutData['id_layout_linked_weight']) {
+ $status = $status['temp_total'];
+ }
+ else {
+ $status = VISUAL_MAP_STATUS_NORMAL;
+ }
+ }
}
else {
switch ($layoutData["type"]) {
@@ -2469,6 +3031,8 @@ function visual_map_get_status_element($layoutData) {
case PERCENTILE_BAR:
case PERCENTILE_BUBBLE:
+ case CIRCULAR_PROGRESS_BAR:
+ case CIRCULAR_INTERIOR_PROGRESS_BAR:
if (empty($module_value) || $module_value == '') {
return VISUAL_MAP_STATUS_UNKNOWN;
@@ -2692,10 +3256,9 @@ function visual_map_print_visual_map ($id_layout, $show_links = true,
$mapWidth = $layout["width"];
$mapHeight = $layout["height"];
$backgroundImage = '';
- if ($layout["background"] != 'None.png' ){
+ if ($layout["background"] != 'None.png' )
$backgroundImage = $metaconsole_hack . 'images/console/background/' .
$layout["background"];
- }
}
if (defined('METACONSOLE')) {
@@ -2724,6 +3287,11 @@ function visual_map_print_visual_map ($id_layout, $show_links = true,
foreach ($layout_datas as $layout_data) {
+ $layout_group = $layout_data['element_group'];
+ if (!check_acl ($config['id_user'], $layout_group, "VR")) {
+ continue;
+ }
+
//Check the items are from disabled or pending delete modules
if ($layout_data['id_agente_modulo'] != 0 &&
(($layout_data['type'] != LABEL)
@@ -2751,7 +3319,7 @@ function visual_map_print_visual_map ($id_layout, $show_links = true,
'proportion_width' => $proportion_width);
}
- $layout_data['label'] = visual_map_macro($layout_data['label']);
+ $layout_data['label'] = visual_map_macro($layout_data['label'],$layout_data["id_agente_modulo"]);
switch ($layout_data['type']) {
case LINE_ITEM:
@@ -2798,25 +3366,25 @@ function visual_map_get_user_layouts ($id_user = 0, $only_names = false, $filter
unset($filter['name']);
}
}
-
- if ($returnAllGroup){
+
+ if ($returnAllGroup) {
$groups = users_get_groups ($id_user, 'VR');
} else {
- if(!empty($filter['group'])){
+ if(!empty($filter['group'])) {
$permissions_group = users_get_groups ($id_user, 'VR', false);
if(empty($permissions_group)){
$permissions_group = users_get_groups ($id_user, 'VM', false);
}
$groups = array_intersect_key($filter['group'], $permissions_group);
- unset($filter['group']);
} else {
$groups = users_get_groups ($id_user, 'VR', false);
- if(empty($groups)){
+ if(empty($groups)) {
$groups = users_get_groups ($id_user, 'VM', false);
}
}
+ unset($filter['group']);
}
-
+
if (!empty($groups)) {
if (empty($where))
$where = "";
@@ -2862,7 +3430,9 @@ function visual_map_get_user_layouts ($id_user = 0, $only_names = false, $filter
*
* @return bool The status of the given layout. True if it's OK, false if not.
*/
-function visual_map_get_layout_status ($id_layout = 0, $depth = 0) {
+function visual_map_get_layout_status ($id_layout = 0, $depth = 0, $elements_in_critical = 0, $calculate_weight = false) {
+ global $config;
+
$temp_status = VISUAL_MAP_STATUS_NORMAL;
$temp_total = VISUAL_MAP_STATUS_NORMAL;
$depth++; // For recursion depth checking
@@ -2882,11 +3452,20 @@ function visual_map_get_layout_status ($id_layout = 0, $depth = 0) {
'parent_item',
'id_layout_linked',
'id_agent',
- 'type'));
+ 'type',
+ 'id_layout_linked_weight',
+ 'id',
+ 'id_layout',
+ 'element_group'));
if ($result === false)
return VISUAL_MAP_STATUS_NORMAL;
foreach ($result as $data) {
+ $layout_group = $data['element_group'];
+ if (!check_acl ($config['id_user'], $layout_group, "VR")) {
+ continue;
+ }
+
switch ($data['type']) {
case GROUP_ITEM:
if ($data["id_layout_linked"] == 0) {
@@ -2924,12 +3503,39 @@ function visual_map_get_layout_status ($id_layout = 0, $depth = 0) {
// Other Layout (Recursive!)
if (($data["id_layout_linked"] != 0) && ($data["id_agente_modulo"] == 0)) {
- $status = visual_map_get_layout_status($data["id_layout_linked"], $depth);
+ if ($data['id_layout_linked_weight'] > 0) {
+ $calculate_weight_c = true;
+ }
+ else {
+ $calculate_weight_c = false;
+ }
+ $status = visual_map_get_layout_status($data["id_layout_linked"], $depth, 0, $calculate_weight_c);
+
+ $elements_in_child = db_get_all_rows_sql("SELECT id, element_group FROM tlayout_data WHERE type = 0 AND id_layout = " . $data['id_layout_linked']);
+ $layout_group = $data['element_group'];
+
+ $childs_group_acl = array();
+ foreach ($elements_in_child as $c) {
+ if (check_acl ($config['id_user'], $c['element_group'], "VR")) {
+ $childs_group_acl[] = $c['id'];
+ }
+ }
+ $elements_in_child = $childs_group_acl;
+
+ if ($calculate_weight_c) {
+ $aux_weight = ($status['elements_in_critical'] / count($elements_in_child)) * 100;
+
+ if ($aux_weight >= $data['id_layout_linked_weight']) {
+ $status = $status['temp_total'];
+ }
+ else {
+ $status = VISUAL_MAP_STATUS_NORMAL;
+ }
+ }
}
// Module
elseif ($data["id_agente_modulo"] != 0) {
$status = modules_get_agentmodule_status($data["id_agente_modulo"]);
-
}
// Agent
else {
@@ -2943,11 +3549,31 @@ function visual_map_get_layout_status ($id_layout = 0, $depth = 0) {
break;
}
- if ($status == VISUAL_MAP_STATUS_CRITICAL_BAD)
- return VISUAL_MAP_STATUS_CRITICAL_BAD;
+ if ($calculate_weight) {
+ if ($status == VISUAL_MAP_STATUS_CRITICAL_BAD || $status == VISUAL_MAP_STATUS_WARNING) {
+ $elements_in_critical++;
+ }
+ }
+ else {
+ if ($status == VISUAL_MAP_STATUS_CRITICAL_BAD) {
+ return VISUAL_MAP_STATUS_CRITICAL_BAD;
+ }
- if ($status > $temp_total)
+ }
+ if ($calculate_weight) {
+ if ($status == VISUAL_MAP_STATUS_CRITICAL_BAD) {
+ $temp_total = VISUAL_MAP_STATUS_CRITICAL_BAD;
+ }
+ else if ($status == VISUAL_MAP_STATUS_WARNING && $temp_total != VISUAL_MAP_STATUS_CRITICAL_BAD) {
+ $temp_total = VISUAL_MAP_STATUS_WARNING;
+ }
+ }
+ else if ($status > $temp_total) {
$temp_total = $status;
+ }
+ }
+ if ($calculate_weight) {
+ return array('elements_in_critical' => $elements_in_critical, 'temp_total' => $temp_total);
}
return $temp_total;
@@ -2981,6 +3607,10 @@ function visual_map_create_internal_name_item($label = null, $type, $image, $age
case MODULE_GRAPH:
$text = __('Module graph');
break;
+ case 'bars_graph':
+ case BARS_GRAPH:
+ $text = __('Bars graph');
+ break;
case 'auto_sla_graph':
case AUTO_SLA_GRAPH:
$text = __('Auto SLA Graph');
@@ -2989,6 +3619,14 @@ function visual_map_create_internal_name_item($label = null, $type, $image, $age
case PERCENTILE_BAR:
$text = __('Percentile bar');
break;
+ case 'circular_progress_bar':
+ case CIRCULAR_PROGRESS_BAR:
+ $text = __('Circular progress bar');
+ break;
+ case 'interior_circular_progress_bar':
+ case CIRCULAR_INTERIOR_PROGRESS_BAR:
+ $text = __('Circular progress bar (interior)');
+ break;
case 'static_graph':
case STATIC_GRAPH:
$text = __('Static graph') . " - " .
@@ -3093,9 +3731,18 @@ function visual_map_type_in_js($type) {
case PERCENTILE_BAR:
return 'percentile_item';
break;
+ case CIRCULAR_PROGRESS_BAR:
+ return 'percentile_item';
+ break;
+ case CIRCULAR_INTERIOR_PROGRESS_BAR:
+ return 'percentile_item';
+ break;
case MODULE_GRAPH:
return 'module_graph';
break;
+ case BARS_GRAPH:
+ return 'bars_graph';
+ break;
case AUTO_SLA_GRAPH:
return 'auto_sla_graph';
break;
@@ -3135,9 +3782,14 @@ function visual_map_type_in_js($type) {
}
}
-function visual_map_macro($label){
+function visual_map_macro($label,$module){
$label = str_replace('_date_',strftime("%x"),$label);
$label = str_replace('_time_',strftime("%T"),$label);
+ $label = str_replace('_agent_',agents_get_alias(modules_get_agentmodule_agent($module)),$label);
+ $label = str_replace('_module_',modules_get_agentmodule_name($module),$label);
+ $label = str_replace('_agentdescription_',agents_get_description(modules_get_agentmodule_agent($module)),$label);
+ $label = str_replace('_address_',agents_get_address(modules_get_agentmodule_agent($module)),$label);
+ $label = str_replace('_moduledescription_',modules_get_agentmodule_descripcion($module),$label);
return $label;
}
diff --git a/pandora_console/include/functions_visual_map_editor.php b/pandora_console/include/functions_visual_map_editor.php
index 7769f4d3e2..682b78d3e5 100755
--- a/pandora_console/include/functions_visual_map_editor.php
+++ b/pandora_console/include/functions_visual_map_editor.php
@@ -157,13 +157,12 @@ function visual_map_editor_print_item_palette($visualConsole_id, $background) {
$form_items['label_row'] = array();
$form_items['label_row']['items'] = array('label',
'static_graph',
- 'percentile_bar',
- 'percentile_item',
'module_graph',
'simple_value',
'datos',
'group_item',
- 'auto_sla_graph');
+ 'auto_sla_graph',
+ 'bars_graph');
$form_items['label_row']['html'] =
'
' . __('Label') . '
@@ -189,7 +188,7 @@ function visual_map_editor_print_item_palette($visualConsole_id, $background) {
' .
html_print_input_text('label', '', '', 20, 200, true) . '
- '.__("Click right mouse button to change the background color of the label editor").'
+ '.__("Scroll the mouse wheel over the label editor to change the background color").'
';
@@ -202,7 +201,7 @@ function visual_map_editor_print_item_palette($visualConsole_id, $background) {
$form_items['image_row']['html'] =
'
' . __('Image') . '
' .
- html_print_select ($images_list, 'image', '', 'showPreview(this.value);', 'None', '', true) .
+ html_print_select ($images_list, 'image', '', 'showPreview(this.value);', 'None', 'none', true) .
' ';
@@ -214,7 +213,8 @@ function visual_map_editor_print_item_palette($visualConsole_id, $background) {
'module_graph',
'simple_value',
'datos',
- 'icon');
+ 'icon',
+ 'bars_graph');
if (!is_metaconsole())
$form_items['enable_link_row']['items'][] = 'group_item';
@@ -222,7 +222,7 @@ function visual_map_editor_print_item_palette($visualConsole_id, $background) {
$form_items['enable_link_row']['html'] =
'
' . __('Enable link') . '
' .
- html_print_checkbox('enable_link', '', 1, true) . ' ';
+ html_print_checkbox('enable_link', '', !is_metaconsole(), true) . '';
$form_items['preview_row'] = array();
@@ -237,7 +237,8 @@ function visual_map_editor_print_item_palette($visualConsole_id, $background) {
$form_items['background_color'] = array();
$form_items['background_color']['items'] = array(
'module_graph',
- 'datos');
+ 'datos',
+ 'bars_graph');
$form_items['background_color']['html'] = '
' .
__('Background color') . '
'. html_print_select (
@@ -245,6 +246,18 @@ function visual_map_editor_print_item_palette($visualConsole_id, $background) {
'black' => __('Black'),
'transparent' => __('Transparent')),
'background_color', '', '', 0, 'white', true, false, false) . ' ';
+
+ $form_items['grid_color_row'] = array();
+ $form_items['grid_color_row']['items'] = array('bars_graph');
+ $form_items['grid_color_row']['html'] =
+ '
' .
+ __('Grid color') .
+ ' ' .
+ '
' .
+ html_print_input_text_extended ('grid_color',
+ '#000000', 'text-grid_color', '', 7, 7, false,
+ '', 'class="grid_color"', true) .
+ ' ';
$form_items['radio_choice_graph'] = array();
$form_items['radio_choice_graph']['items'] = array(
@@ -290,6 +303,7 @@ function visual_map_editor_print_item_palette($visualConsole_id, $background) {
$params['use_hidden_input_idagent'] = true;
$params['print_hidden_input_idagent'] = true;
$params['hidden_input_idagent_name'] = 'id_agent';
+ $params['get_order_json'] = true;
if (defined('METACONSOLE')) {
$params['javascript_ajax_page'] = '../../ajax.php';
$params['disabled_javascript_on_blur_function'] = true;
@@ -306,17 +320,62 @@ function visual_map_editor_print_item_palette($visualConsole_id, $background) {
$form_items['agent_row']['html'] .= '
' .
ui_print_agent_autocomplete_input($params) .
' ';
+
+ $form_items['agent_row_string'] = array();
+ $form_items['agent_row_string']['items'] = array('donut_graph', 'bars_graph');
+ $form_items['agent_row_string']['html'] = '
' .
+ __('Agent') . ' ';
+ $params = array();
+ $params['return'] = true;
+ $params['show_helptip'] = true;
+ $params['input_name'] = 'agent_string';
+ $params['size'] = 30;
+ $params['selectbox_id'] = 'module';
+ $params['javascript_is_function_select'] = true;
+ $params['use_hidden_input_idagent'] = true;
+ $params['print_hidden_input_idagent'] = true;
+ $params['hidden_input_idagent_name'] = 'id_agent_string';
+ $params['get_order_json'] = true;
+ $params['get_only_string_modules'] = true;
+ if (defined('METACONSOLE')) {
+ $params['javascript_ajax_page'] = '../../ajax.php';
+ $params['disabled_javascript_on_blur_function'] = true;
+
+ $params['print_input_server'] = true;
+ $params['print_input_id_server'] = true;
+ $params['input_server_id'] = 'id_server_name';
+ $params['input_id_server_name'] = 'id_server_metaconsole';
+ $params['input_server_value'] = '';
+ $params['use_input_id_server'] = true;
+ $params['metaconsole_enabled'] = true;
+ $params['print_hidden_input_idagent'] = true;
+ }
+ $form_items['agent_row_string']['html'] .= '
' .
+ ui_print_agent_autocomplete_input($params) .
+ ' ';
$form_items['module_row'] = array();
$form_items['module_row']['items'] = array('static_graph',
'percentile_bar', 'percentile_item', 'module_graph',
- 'simple_value', 'datos', 'auto_sla_graph');
+ 'simple_value', 'datos', 'auto_sla_graph', 'donut_graph', 'bars_graph');
$form_items['module_row']['html'] = '
' .
__('Module') . '
' .
html_print_select(array(), 'module', '', '', __('Any'), 0, true) . ''.__("Data image").': Off - Width:
';
+ $form_items['resume_color_row'] = array();
+ $form_items['resume_color_row']['items'] = array('donut_graph');
+ $form_items['resume_color_row']['html'] =
+ '
' .
+ __('Resume data color') .
+ ' ' .
+ '
' .
+ html_print_input_text_extended ('resume_color',
+ '#000000', 'text-resume_color', '', 7, 7, false,
+ '', 'class="resume_color"', true) .
+ ' ';
+
$event_times = array(86400 => __('24h'),
28800 => __('8h'),
7200 => __('2h'),
@@ -396,11 +455,16 @@ function visual_map_editor_print_item_palette($visualConsole_id, $background) {
$form_items['percentile_bar_row_1'] = array();
- $form_items['percentile_bar_row_1']['items'] = array('percentile_bar', 'percentile_item', 'datos');
+ $form_items['percentile_bar_row_1']['items'] = array('percentile_bar', 'percentile_item', 'datos', 'donut_graph', 'bars_graph');
$form_items['percentile_bar_row_1']['html'] = '
' .
__('Width') . '
' . html_print_input_text('width_percentile', 0, '', 3, 5, true) . ' ';
-
+
+ $form_items['height_bars_graph_row'] = array();
+ $form_items['height_bars_graph_row']['items'] = array('bars_graph');
+ $form_items['height_bars_graph_row']['html'] = '
' .
+ __('Height') . '
+
' . html_print_input_text('bars_graph_height', 0, '', 3, 5, true) . ' ';
$form_items['percentile_bar_row_2'] = array();
$form_items['percentile_bar_row_2']['items'] = array('percentile_bar', 'percentile_item', 'datos');
@@ -408,23 +472,22 @@ function visual_map_editor_print_item_palette($visualConsole_id, $background) {
__('Max value') . '
' . html_print_input_text('max_percentile', 0, '', 3, 5, true) . ' ';
+ $percentile_type = array('percentile' => __('Percentile'), 'bubble' => __('Bubble'), 'circular_progress_bar' => __('Circular porgress bar'), 'interior_circular_progress_bar' => __('Circular progress bar (interior)'));
+ $percentile_value = array('percent' => __('Percent'), 'value' => __('Value'));
if (is_metaconsole()){
$form_items['percentile_item_row_3'] = array();
$form_items['percentile_item_row_3']['items'] = array('percentile_bar', 'percentile_item', 'datos');
$form_items['percentile_item_row_3']['html'] = '
' .
__('Type') . '
' .
- html_print_radio_button_extended('type_percentile', 'percentile', ('Percentile'), 'percentile', false, '', 'style="float: left;"', true) .
- html_print_radio_button_extended('type_percentile', 'bubble', ('Bubble'), 'percentile', false, '', 'style="float: left;"', true) .
+ html_print_select($percentile_type, 'type_percentile', 'percentile', '', '', '', true, false, false, '', false, 'style="float: left;"') .
' ';
-
$form_items['percentile_item_row_4'] = array();
$form_items['percentile_item_row_4']['items'] = array('percentile_bar', 'percentile_item', 'datos');
$form_items['percentile_item_row_4']['html'] = '
' . __('Value to show') . '
' .
- html_print_radio_button_extended('value_show', 'percent', ('Percent'), 'value', false, '', 'style="float: left;"', true) .
- html_print_radio_button_extended('value_show', 'value', ('Value'), 'value', false, '', 'style="float: left;"', true) .
+ html_print_select($percentile_value, 'value_show', 'percent', '', '', '', true, false, false, '', false, 'style="float: left;"') .
' ';
}
else{
@@ -433,20 +496,40 @@ function visual_map_editor_print_item_palette($visualConsole_id, $background) {
$form_items['percentile_item_row_3']['html'] = '
' .
__('Type') . '
' .
- html_print_radio_button_extended('type_percentile', 'percentile', ('Percentile'), 'percentile', false, '', '', true) .
- html_print_radio_button_extended('type_percentile', 'bubble', ('Bubble'), 'percentile', false, '', '', true) .
+ html_print_select($percentile_type, 'type_percentile', 'percentile', '', '', '', true) .
' ';
-
$form_items['percentile_item_row_4'] = array();
$form_items['percentile_item_row_4']['items'] = array('percentile_bar', 'percentile_item', 'datos');
$form_items['percentile_item_row_4']['html'] = '
' . __('Value to show') . '
' .
- html_print_radio_button_extended('value_show', 'percent', ('Percent'), 'value', false, '', '', true) .
- html_print_radio_button_extended('value_show', 'value', ('Value'), 'value', false, '', '', true) .
+ html_print_select($percentile_value, 'value_show', 'percent', '', '', '', true) .
' ';
}
+ $form_items['percentile_item_row_5'] = array();
+ $form_items['percentile_item_row_5']['items'] = array('percentile_bar', 'percentile_item', 'datos');
+ $form_items['percentile_item_row_5']['html'] = '
' . __('Element color') . '
+
' .
+ html_print_input_text_extended ('percentile_color', '#ffffff',
+ 'text-percentile_color', '', 7, 7, false, '',
+ 'class="percentile_color"', true) .
+ ' ';
+
+ $form_items['percentile_item_row_6'] = array();
+ $form_items['percentile_item_row_6']['items'] = array('percentile_bar', 'percentile_item', 'datos');
+ $form_items['percentile_item_row_6']['html'] = '
' . __('Label color') . '
+
' .
+ html_print_input_text_extended ('percentile_label_color', '#ffffff',
+ 'text-percentile_label_color', '', 7, 7, false, '',
+ 'class="percentile_label_color"', true) .
+ ' ';
+
+ $form_items['percentile_bar_row_7'] = array();
+ $form_items['percentile_bar_row_7']['items'] = array('percentile_bar', 'percentile_item', 'datos');
+ $form_items['percentile_bar_row_7']['html'] = '
' .
+ __('Label') . '
+
' . html_print_input_text('percentile_label', '', '', 30, 100, true) . ' ';
$form_items['period_row'] = array();
$form_items['period_row']['items'] = array('module_graph', 'simple_value', 'datos');
@@ -459,7 +542,13 @@ function visual_map_editor_print_item_palette($visualConsole_id, $background) {
'
' . __('Show statistics') . '
' .
html_print_checkbox('show_statistics', 1, '', true) . ' ';
-
+
+ $form_items['show_on_top_row'] = array();
+ $form_items['show_on_top_row']['items'] = array('group_item');
+ $form_items['show_on_top_row']['html'] =
+ '
' . __('Always show on top') . '
+
' .
+ html_print_checkbox('show_on_top', 1, '', true) . ' ';
$form_items['module_graph_size_row'] = array();
$form_items['module_graph_size_row']['items'] = array('module_graph', 'datos');
@@ -472,6 +561,13 @@ function visual_map_editor_print_item_palette($visualConsole_id, $background) {
'
1 '.
'
item/s
';
+
+ $bars_graph_types = array('vertical' => __('Vertical'), 'horizontal' => __('Horizontal'));
+ $form_items['bars_graph_type'] = array();
+ $form_items['bars_graph_type']['items'] = array('bars_graph');
+ $form_items['bars_graph_type']['html'] = '
' .
+ __('Type') . '
+
' . html_print_select($bars_graph_types, 'bars_graph_type', 'vertical', '', '', '', true) . ' ';
//Insert and modify before the buttons to create or update.
@@ -518,7 +614,7 @@ function visual_map_editor_print_item_palette($visualConsole_id, $background) {
$form_items_advance['position_row']['items'] = array('static_graph',
'percentile_bar', 'percentile_item', 'module_graph',
'simple_value', 'label', 'icon', 'datos', 'box_item',
- 'auto_sla_graph');
+ 'auto_sla_graph', 'bars_graph');
$form_items_advance['position_row']['html'] = '
' . __('Position') . '
(' . html_print_input_text('left', '0', '', 3, 5, true) .
@@ -547,7 +643,8 @@ function visual_map_editor_print_item_palette($visualConsole_id, $background) {
$form_items_advance['parent_row']['items'] = array(
'group_item', 'static_graph',
'percentile_bar', 'percentile_item', 'module_graph',
- 'simple_value', 'label', 'icon', 'datos', 'auto_sla_graph');
+ 'simple_value', 'label', 'icon', 'datos', 'auto_sla_graph',
+ 'bars_graph');
$form_items_advance['parent_row']['html'] = ' ' .
__('Parent') . '
' .
@@ -556,21 +653,52 @@ function visual_map_editor_print_item_palette($visualConsole_id, $background) {
' ';
$form_items_advance['map_linked_row'] = array();
- $form_items_advance['map_linked_row']['items'] = array('static_graph', 'label', 'icon');
+ $form_items_advance['map_linked_row']['items'] = array(
+ 'group_item', 'static_graph', 'percentile_bar',
+ 'percentile_item', 'module_graph', 'simple_value',
+ 'icon', 'label', 'datos');
$form_items_advance['map_linked_row']['html'] = '
'.
- __('Map linked') . ui_print_help_tip (
- __("If a parent visual console is selected here, an agent or module cannot be selected and will be removed if a previous selection was done."), true) .
- ' ' .
+ __('Map linked') . '' .
'
' . html_print_select_from_sql (
'SELECT id, name
FROM tlayout
WHERE id != ' . $visualConsole_id, 'map_linked', '', '', 'None', '0', true) .
' ';
+ $form_items_advance['map_linked_weight'] = array();
+ $form_items_advance['map_linked_weight']['items'] = array('static_graph');
+ $form_items_advance['map_linked_weight']['html'] = '
'.
+ __('Map linked weight') . ' ' .
+ '
' . html_print_select(array('10' => '10%',
+ '20' => '20%',
+ '30' => '30%',
+ '40' => '40%',
+ '50' => '50%',
+ '60' => '60%',
+ '70' => '70%',
+ '80' => '80%',
+ '90' => '90%',
+ '100' => '100%'),
+ 'map_linked_weight', '', '', __('By default'), 0, true) .
+ ui_print_help_icon ("linked_map_weight", true) .
+ ' ';
+
$form_items_advance['line_case']['items'] = array('line_item');
$form_items_advance['line_case']['html'] = '
' . __('Lines haven\'t advanced options') . ' ';
+ $user_groups = users_get_groups($config['id_user']);
+ $form_items_advance['element_group_row'] = array();
+ $form_items_advance['element_group_row']['items'] = array(
+ 'group_item', 'static_graph', 'percentile_bar',
+ 'percentile_item', 'module_graph', 'simple_value',
+ 'icon', 'label', 'datos');
+ $form_items_advance['element_group_row']['html'] = '
'.
+ __('Restrict access to group') . ' ' .
+ '
' . html_print_select($user_groups, 'element_group', '', '', '', 0, true) .
+ ui_print_help_tip (
+ __("If selected, restrict visualization of this item in the visual console to users who have access to selected group. This is also used on calculating child visual consoles."), true) .
+ ' ';
//Insert and modify before the buttons to create or update.
if (enterprise_installed()) {
@@ -613,6 +741,10 @@ function visual_map_editor_print_item_palette($visualConsole_id, $background) {
$(".border_color").attachColorPicker();
$(".fill_color").attachColorPicker();
$(".line_color").attachColorPicker();
+ $(".percentile_color").attachColorPicker();
+ $(".percentile_label_color").attachColorPicker();
+ $(".resume_color").attachColorPicker();
+ $(".grid_color").attachColorPicker();
$("input[name=radio_choice]").change(function(){
$('#count_items').html(1);
@@ -673,6 +805,8 @@ function visual_map_editor_print_toolbox() {
visual_map_print_button_editor('static_graph', __('Static Graph'), 'left', false, 'camera_min', true);
visual_map_print_button_editor('percentile_item', __('Percentile Item'), 'left', false, 'percentile_item_min', true);
visual_map_print_button_editor('module_graph', __('Module Graph'), 'left', false, 'graph_min', true);
+ visual_map_print_button_editor('donut_graph', __('Serialized pie graph'), 'left', false, 'donut_graph_min', true);
+ visual_map_print_button_editor('bars_graph', __('Bars Graph'), 'left', false, 'bars_graph_min', true);
visual_map_print_button_editor('auto_sla_graph', __('Auto SLA Graph'), 'left', false, 'auto_sla_graph_min', true);
visual_map_print_button_editor('simple_value', __('Simple Value'), 'left', false, 'binary_min', true);
visual_map_print_button_editor('label', __('Label'), 'left', false, 'label_min', true);
@@ -734,6 +868,8 @@ function visual_map_editor_print_hack_translate_strings() {
__('No Max value defined.') .'';
echo '
' .
__('No width defined.') .' ';
+ echo '
' .
+ __('No height defined.') .' ';
echo '
' .
__('No period defined.') .' ';
echo '
' .
@@ -760,4 +896,4 @@ $(document).ready (function () {
.html(""));
})
});
-
\ No newline at end of file
+
diff --git a/pandora_console/include/graphs/fgraph.php b/pandora_console/include/graphs/fgraph.php
index ed12555593..ba88a64434 100644
--- a/pandora_console/include/graphs/fgraph.php
+++ b/pandora_console/include/graphs/fgraph.php
@@ -10,48 +10,29 @@
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
-$ttl = 1;
-$homeurl = '';
-
-if (isset($_GET['homeurl'])) {
- $homeurl = $_GET['homeurl'];
-}
-else $homeurl = '';
-
-$homeurl = ((bool)filter_var($homeurl, FILTER_VALIDATE_URL) == 1) ? '' : $homeurl;
-
-if (isset($_GET['ttl'])) {
- $ttl = $_GET['ttl'];
-}
-else $ttl_param = 1;
-
-if (isset($_GET['graph_type'])) {
- $graph_type = $_GET['graph_type'];
-}
-else $graph_type = '';
-
-//$graph_type = get_parameter('graph_type', '');
-//$ttl_param = get_parameter('ttl', 1);
-//$homeurl_param = get_parameter('homeurl', '');
-
// Turn on output buffering.
// The entire buffer will be discarded later so that any accidental output
// does not corrupt images generated by fgraph.
-ob_start ();
+ob_start();
+
+global $config;
+
+if (empty($config['homedir'])) {
+ require_once ('../../include/config.php');
+ global $config;
+}
+
+include_once($config['homedir'] . '/include/functions.php');
+
+$ttl = get_parameter('ttl', 1);
+$graph_type = get_parameter('graph_type', '');
if (!empty($graph_type)) {
- $homedir = $_GET['homedir'];
- if ($homedir != null) {
- $config['homedir'] = $homedir;
- }
-
- include_once($homeurl . 'include/functions.php');
- include_once($homeurl . 'include/functions_html.php');
-
- include_once($homeurl . 'include/graphs/functions_gd.php');
- include_once($homeurl . 'include/graphs/functions_utils.php');
- include_once($homeurl . 'include/graphs/functions_d3.php');
- include_once($homeurl . 'include/graphs/functions_flot.php');
+ include_once($config['homedir'] . '/include/functions_html.php');
+ include_once($config['homedir'] . '/include/graphs/functions_gd.php');
+ include_once($config['homedir'] . '/include/graphs/functions_utils.php');
+ include_once($config['homedir'] . '/include/graphs/functions_d3.php');
+ include_once($config['homedir'] . '/include/graphs/functions_flot.php');
}
// Clean the output buffer and turn off output buffering
@@ -61,13 +42,12 @@ switch($graph_type) {
case 'histogram':
$width = get_parameter('width');
$height = get_parameter('height');
- $font = get_parameter('font');
$data = json_decode(io_safe_output(get_parameter('data')), true);
$max = get_parameter('max');
$title = get_parameter('title');
$mode = get_parameter ('mode', 1);
- gd_histogram ($width, $height, $mode, $data, $max, $font, $title);
+ gd_histogram ($width, $height, $mode, $data, $max, $config['fontpath'], $title);
break;
case 'progressbar':
$width = get_parameter('width');
@@ -77,7 +57,6 @@ switch($graph_type) {
$out_of_lim_str = io_safe_output(get_parameter('out_of_lim_str', false));
$out_of_lim_image = get_parameter('out_of_lim_image', false);
- $font = get_parameter('font');
$title = get_parameter('title');
$mode = get_parameter('mode', 1);
@@ -87,7 +66,7 @@ switch($graph_type) {
$value_text = get_parameter('value_text', '');
$colorRGB = get_parameter('colorRGB', '');
- gd_progress_bar ($width, $height, $progress, $title, $font,
+ gd_progress_bar ($width, $height, $progress, $title, $config['fontpath'],
$out_of_lim_str, $out_of_lim_image, $mode, $fontsize,
$value_text, $colorRGB);
break;
@@ -99,7 +78,6 @@ switch($graph_type) {
$out_of_lim_str = io_safe_output(get_parameter('out_of_lim_str', false));
$out_of_lim_image = get_parameter('out_of_lim_image', false);
- $font = get_parameter('font');
$title = get_parameter('title');
$mode = get_parameter('mode', 1);
@@ -109,7 +87,7 @@ switch($graph_type) {
$value_text = get_parameter('value_text', '');
$colorRGB = get_parameter('colorRGB', '');
- gd_progress_bubble ($width, $height, $progress, $title, $font,
+ gd_progress_bubble ($width, $height, $progress, $title, $config['fontpath'],
$out_of_lim_str, $out_of_lim_image, $mode, $fontsize,
$value_text, $colorRGB);
break;
@@ -178,7 +156,7 @@ function vbar_graph($flash_chart, $chart_data, $width, $height,
$color, $legend, $long_index, $no_data_image, $xaxisname = "",
$yaxisname = "", $water_mark = "", $font = '', $font_size = '',
$unit = '', $ttl = 1, $homeurl = '', $backgroundColor = 'white',
- $from_ux = false, $from_wux = false) {
+ $from_ux = false, $from_wux = false, $tick_color = 'white') {
setup_watermark($water_mark, $water_mark_file, $water_mark_url);
if (empty($chart_data)) {
@@ -188,11 +166,12 @@ function vbar_graph($flash_chart, $chart_data, $width, $height,
if ($flash_chart) {
return flot_vcolumn_chart ($chart_data, $width, $height, $color,
$legend, $long_index, $homeurl, $unit, $water_mark_url,
- $homedir,$font,$font_size, $from_ux, $from_wux);
+ $homedir,$font,$font_size, $from_ux, $from_wux, $backgroundColor,
+ $tick_color);
}
else {
foreach ($chart_data as $key => $value) {
- if(strlen($key) > 25){
+ if(strlen($key) > 20){
if(strpos($key, ' - ') != -1){
$key_temp = explode(" - ",$key);
@@ -642,7 +621,8 @@ function polar_graph($flash_chart, $chart_data, $width, $height,
function hbar_graph($flash_chart, $chart_data, $width, $height,
$color, $legend, $long_index, $no_data_image, $xaxisname = "",
$yaxisname = "", $water_mark = "", $font = '', $font_size = '',
- $unit = '', $ttl = 1, $homeurl = '', $backgroundColor = 'white') {
+ $unit = '', $ttl = 1, $homeurl = '', $backgroundColor = 'white',
+ $tick_color = "white") {
setup_watermark($water_mark, $water_mark_file, $water_mark_url);
@@ -652,7 +632,7 @@ function hbar_graph($flash_chart, $chart_data, $width, $height,
if ($flash_chart) {
return flot_hcolumn_chart(
- $chart_data, $width, $height, $water_mark_url, $font, $font_size);
+ $chart_data, $width, $height, $water_mark_url, $font, $font_size, $backgroundColor, $tick_color);
}
else {
@@ -784,7 +764,7 @@ function pie_graph($graph_type, $flash_chart, $chart_data, $width,
function ring_graph($flash_chart, $chart_data, $width,
$height, $others_str = "other", $homedir="", $water_mark = "",
$font = '', $font_size = '', $ttl = 1, $legend_position = false,
- $colors = '', $hide_labels = false) {
+ $colors = '', $hide_labels = false,$background_color = 'white') {
if (empty($chart_data)) {
return graph_nodata_image($width, $height, 'pie');
@@ -800,7 +780,7 @@ function ring_graph($flash_chart, $chart_data, $width,
return flot_custom_pie_chart ($flash_chart, $chart_data,
$width, $height, $colors, $module_name_list, $long_index,
$no_data, false, '', $water_mark, $font, $font_size,
- $unit, $ttl, $homeurl, $background_color, $legend_position);
+ $unit, $ttl, $homeurl, $background_color, $legend_position,$background_color);
}
else {
$total_modules = $chart_data['total_modules'];
diff --git a/pandora_console/include/graphs/flot/pandora.flot.js b/pandora_console/include/graphs/flot/pandora.flot.js
index e036a9855e..6fe97ae606 100644
--- a/pandora_console/include/graphs/flot/pandora.flot.js
+++ b/pandora_console/include/graphs/flot/pandora.flot.js
@@ -119,7 +119,8 @@ function pandoraFlotPie(graph_id, values, labels, nseries, width, font_size, wat
function pandoraFlotPieCustom(graph_id, values, labels, width,
font_size, font, water_mark, separator, legend_position, height,
- colors,legend) {
+ colors,legend,background_color) {
+
font = font.split("/").pop().split(".").shift();
var labels = labels.split(separator);
var legend = legend.split(separator);
@@ -211,8 +212,24 @@ function pandoraFlotPieCustom(graph_id, values, labels, width,
$('.legend>table').css('right',($('.legend>div').height()*-1));
}
//$('.legend>table').css('border',"1px solid #E2E2E2");
- $('.legend>table').css('background-color',"transparent");
+ if(background_color == 'transparent'){
+ $('.legend>table').css('background-color',"");
+ $('.legend>div').css('background-color',"");
+ $('.legend>table').css('color',"#aaa");
+ }
+ else if (background_color == 'white') {
+ $('.legend>table').css('background-color',"white");
+ $('.legend>table').css('color',"black");
+ }
+ else if (background_color == 'black') {
+ $('.legend>table').css('background-color',"black");
+ $('.legend>table').css('color',"#aaa");
+ }
+
+ $('.legend').over(function(){
+ return false;
+ });
var pielegends = $('#'+graph_id+' .pieLabelBackground');
pielegends.each(function () {
@@ -309,7 +326,8 @@ function pandoraFlotPieCustom(graph_id, values, labels, width,
}
function pandoraFlotHBars(graph_id, values, labels, water_mark,
- maxvalue, water_mark, separator, separator2, font, font_size) {
+ maxvalue, water_mark, separator, separator2, font, font_size, background_color,
+ tick_color) {
var colors_data = ['#FC4444','#FFA631','#FAD403','#5BB6E5','#F2919D','#80BA27'];
values = values.split(separator2);
@@ -330,8 +348,6 @@ function pandoraFlotHBars(graph_id, values, labels, water_mark,
};
}
-
-
var labels_total=new Array();
labels = labels.split(separator);
i = 0;
@@ -355,20 +371,22 @@ function pandoraFlotHBars(graph_id, values, labels, water_mark,
grid: {
hoverable: true,
borderWidth: 1,
- backgroundColor: { colors: ["#FFF", "#FFF"] }
+ tickColor: tick_color,
+ backgroundColor: { colors: [background_color, background_color] }
},
xaxis: {
+ color: tick_color,
axisLabelUseCanvas: true,
axisLabelFontSizePixels: font_size,
axisLabelFontFamily: font+'Font',
tickFormatter: xFormatter,
},
yaxis: {
+ color: tick_color,
axisLabelUseCanvas: true,
axisLabelFontSizePixels: font_size,
axisLabelFontFamily: font+'Font',
ticks: yFormatter,
- color: '',
},
legend: {
show: false
@@ -494,7 +512,7 @@ function showTooltip(x, y, color, contents) {
}).appendTo("body").fadeIn(200);
}
-function pandoraFlotVBars(graph_id, values, labels, labels_long, legend, colors, water_mark, maxvalue, water_mark, separator, separator2, font, font_size , from_ux, from_wux) {
+function pandoraFlotVBars(graph_id, values, labels, labels_long, legend, colors, water_mark, maxvalue, water_mark, separator, separator2, font, font_size , from_ux, from_wux, background_color, tick_color) {
values = values.split(separator2);
legend = legend.split(separator);
font = font.split("/").pop().split(".").shift();
@@ -548,6 +566,7 @@ function pandoraFlotVBars(graph_id, values, labels, labels_long, legend, colors,
}
},
xaxis: {
+ color:tick_color,
axisLabelUseCanvas: true,
axisLabelFontSizePixels: font_size,
axisLabelFontFamily: font+'Font',
@@ -557,6 +576,7 @@ function pandoraFlotVBars(graph_id, values, labels, labels_long, legend, colors,
labelHeight: 50,
},
yaxis: {
+ color:tick_color,
axisLabelUseCanvas: true,
axisLabelFontSizePixels: font_size,
axisLabelFontFamily: font+'Font',
@@ -585,7 +605,8 @@ function pandoraFlotVBars(graph_id, values, labels, labels_long, legend, colors,
grid: {
hoverable: true,
borderWidth: 1,
- backgroundColor: { colors: ["#FFF", "#FFF"] }
+ tickColor: tick_color,
+ backgroundColor: { colors: [background_color, background_color] }
}
};
@@ -608,16 +629,7 @@ function pandoraFlotVBars(graph_id, values, labels, labels_long, legend, colors,
$('#' + graph_id).VUseTooltip();
$('#' + graph_id).css("margin-left","auto");
$('#' + graph_id).css("margin-right","auto");
- //~ $('#' + graph_id).find('div.legend-tooltip').tooltip({ track: true });
- /*
- $('#'+graph_id+' .xAxis .tickLabel')
- .css('transform', 'rotate(-45deg)')
- .css('max-width','100px')
- .find('div')
- .css('position', 'relative')
- .css('top', '+10px')
- .css('left', '-30px');
- */
+
if (/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent))
$('#'+graph_id+' .xAxis .tickLabel')
.find('div')
@@ -638,7 +650,7 @@ function pandoraFlotVBars(graph_id, values, labels, labels_long, legend, colors,
}
format.push([i,
- ''
+ '
'
+ label
+ '
']);
}
diff --git a/pandora_console/include/graphs/functions_d3.php b/pandora_console/include/graphs/functions_d3.php
index f181492b7a..3a1cf73bbd 100644
--- a/pandora_console/include/graphs/functions_d3.php
+++ b/pandora_console/include/graphs/functions_d3.php
@@ -24,10 +24,16 @@ function include_javascript_d3 ($return = false) {
if (!$is_include_javascript) {
$is_include_javascript = true;
- $output .= '';
- $output .= '';
-
+ if (is_metaconsole()) {
+ $output .= '';
+ $output .= '';
+ }
+ else {
+ $output .= '';
+ $output .= '';
+ }
}
+
if (!$return)
echo $output;
@@ -309,4 +315,97 @@ function ux_console_phases_donut ($phases, $id, $return = false) {
return $output;
}
+
+function d3_progress_bar ($id, $percentile, $width, $height, $color, $unit = "%", $text = "", $fill_color = "#FFFFFF") {
+ global $config;
+
+ $recipient_name = "progress_bar_" . $id;
+ $recipient_name_to_js = "#progress_bar_" . $id;
+
+ $output = "";
+
+ $output .= "
";
+ $output .= include_javascript_d3(true);
+ $output .= "";
+
+ return $output;
+}
+
+function d3_progress_bubble ($id, $percentile, $width, $height, $color, $unit = "%", $text = "", $fill_color = "#FFFFFF") {
+ global $config;
+
+ $recipient_name = "progress_bubble_" . $id;
+ $recipient_name_to_js = "#progress_bubble_" . $id;
+
+ $output = "";
+
+ $output .= "
";
+ $output .= include_javascript_d3(true);
+ $output .= "";
+
+ return $output;
+}
+
+function progress_circular_bar ($id, $percentile, $width, $height, $color, $unit = "%", $text = "", $fill_color = "#FFFFFF") {
+ global $config;
+
+ $recipient_name = "circular_progress_bar_" . $id;
+ $recipient_name_to_js = "#circular_progress_bar_" . $id;
+
+ $output = "";
+
+ $output .= "
";
+ $output .= include_javascript_d3(true);
+ $output .= "";
+
+ return $output;
+}
+
+function progress_circular_bar_interior ($id, $percentile, $width, $height, $color, $unit = "%", $text = "", $fill_color = "#FFFFFF") {
+ global $config;
+
+ $recipient_name = "circular_progress_bar_interior_" . $id;
+ $recipient_name_to_js = "#circular_progress_bar_interior_" . $id;
+
+ $output = "";
+
+ $output .= "
";
+ $output .= include_javascript_d3(true);
+ $output .= "";
+
+ return $output;
+}
+
+function d3_donut_graph ($id, $width, $height, $module_data, $resume_color) {
+ global $config;
+
+ $module_data = json_encode($module_data);
+
+ $recipient_name = "donut_graph_" . $id;
+ $recipient_name_to_js = "#donut_graph_" . $id;
+
+ $output = "
";
+ $output .= include_javascript_d3(true);
+ $output .= "";
+
+ $output .= "";
+
+ return $output;
+}
+
?>
diff --git a/pandora_console/include/graphs/functions_flot.php b/pandora_console/include/graphs/functions_flot.php
index 7e30d49215..4f8943ed8f 100644
--- a/pandora_console/include/graphs/functions_flot.php
+++ b/pandora_console/include/graphs/functions_flot.php
@@ -666,7 +666,7 @@ function flot_custom_pie_chart ($flash_charts, $graph_values,
$return .= "pandoraFlotPieCustom('$graph_id', '$values', '$labels',
'$width', $font_size, '$fontpath', $water_mark,
- '$separator', '$legend_position', '$height', '$colors','$legend')";
+ '$separator', '$legend_position', '$height', '$colors','$legend','$background_color')";
$return .= "";
@@ -674,7 +674,7 @@ function flot_custom_pie_chart ($flash_charts, $graph_values,
}
// Returns a 3D column chart
-function flot_hcolumn_chart ($graph_data, $width, $height, $water_mark, $font = '', $font_size = 7) {
+function flot_hcolumn_chart ($graph_data, $width, $height, $water_mark, $font = '', $font_size = 7, $background_color = "white", $tick_color = "white") {
global $config;
include_javascript_dependencies_flot_graph();
@@ -755,7 +755,7 @@ function flot_hcolumn_chart ($graph_data, $width, $height, $water_mark, $font =
$return .= "";
@@ -763,7 +763,7 @@ function flot_hcolumn_chart ($graph_data, $width, $height, $water_mark, $font =
}
// Returns a 3D column chart
-function flot_vcolumn_chart ($graph_data, $width, $height, $color, $legend, $long_index, $homeurl, $unit, $water_mark, $homedir, $font, $font_size, $from_ux, $from_wux) {
+function flot_vcolumn_chart ($graph_data, $width, $height, $color, $legend, $long_index, $homeurl, $unit, $water_mark, $homedir, $font, $font_size, $from_ux, $from_wux, $background_color = 'white', $tick_color = 'white') {
global $config;
include_javascript_dependencies_flot_graph();
@@ -847,14 +847,14 @@ function flot_vcolumn_chart ($graph_data, $width, $height, $color, $legend, $lon
if ($from_ux) {
if($from_wux){
- $return .= "pandoraFlotVBars('$graph_id', '$values', '$labels', '$labels', '$legend', '$colors', false, $max, '$water_mark', '$separator', '$separator2','$font',$font_size, true, true)";
+ $return .= "pandoraFlotVBars('$graph_id', '$values', '$labels', '$labels', '$legend', '$colors', false, $max, '$water_mark', '$separator', '$separator2','$font',$font_size, true, true, '$background_color', '$tick_color')";
}
else{
- $return .= "pandoraFlotVBars('$graph_id', '$values', '$labels', '$labels', '$legend', '$colors', false, $max, '$water_mark', '$separator', '$separator2','$font',$font_size, true, false)";
+ $return .= "pandoraFlotVBars('$graph_id', '$values', '$labels', '$labels', '$legend', '$colors', false, $max, '$water_mark', '$separator', '$separator2','$font',$font_size, true, false, '$background_color', '$tick_color')";
}
}
else {
- $return .= "pandoraFlotVBars('$graph_id', '$values', '$labels', '$labels', '$legend', '$colors', false, $max, '$water_mark', '$separator', '$separator2','$font',$font_size, false, false)";
+ $return .= "pandoraFlotVBars('$graph_id', '$values', '$labels', '$labels', '$legend', '$colors', false, $max, '$water_mark', '$separator', '$separator2','$font',$font_size, false, false, '$background_color', '$tick_color')";
}
$return .= "";
diff --git a/pandora_console/include/graphs/functions_pchart.php b/pandora_console/include/graphs/functions_pchart.php
index 929a6d2fba..fcbd67f00a 100644
--- a/pandora_console/include/graphs/functions_pchart.php
+++ b/pandora_console/include/graphs/functions_pchart.php
@@ -737,7 +737,7 @@ function pch_bar_graph ($graph_type, $index, $data, $width, $height, $font,
$margin_left = 40+50;
$margin_right = 90;
$margin_top = 10;
- $margin_bottom = (3 * $max_chars)+40;
+ $margin_bottom = (3 * $max_chars)+80;
break;
case "hbar":
$scaleSettings = array("GridR"=>1000,"GridG"=>1000,"GridB"=>1000,"DrawSubTicks"=>TRUE,
@@ -754,13 +754,7 @@ function pch_bar_graph ($graph_type, $index, $data, $width, $height, $font,
$myPicture->setGraphArea($margin_left, $margin_top, $width - $margin_right, $height - $margin_bottom);
$myPicture->drawScale($scaleSettings);
- /*
- if (isset($legend)) {
- /* Write the chart legend
- $size = $myPicture->getLegendSize(array("Style"=>LEGEND_NOBORDER,"Mode"=>LEGEND_HORIZONTAL));
- $myPicture->drawLegend($width-$size['Width'],0,array("Style"=>LEGEND_NOBORDER,"Mode"=>LEGEND_HORIZONTAL, "BoxWidth"=>10, "BoxHeight"=>10));
- }
- */
+
/* Turn on shadow computing */
$myPicture->setShadow(TRUE,array("X"=>0,"Y"=>1,"R"=>0,"G"=>0,"B"=>0,"Alpha"=>10));
diff --git a/pandora_console/include/graphs/pandora.d3.js b/pandora_console/include/graphs/pandora.d3.js
index 67e421881d..b315fae318 100644
--- a/pandora_console/include/graphs/pandora.d3.js
+++ b/pandora_console/include/graphs/pandora.d3.js
@@ -724,12 +724,13 @@ function sunburst (recipient, data, width, height) {
.on("mousemove", move_tooltip);
function computeTextRotation(d) {
- var angle = x(d.x + d.dx / 2) - Math.PI / 2;
- return angle / Math.PI * 180;
+ var ang = (x(d.x + d.dx / 2) - Math.PI / 2) / Math.PI * 180;
+ return (ang > 90) ? 180 + ang : ang;
}
var text = g.append("text")
- .attr("x", function(d) { return y(d.y); })
+ .attr("transform", function(d) { return "translate(" + arc.centroid(d) + ")rotate(" + computeTextRotation(d) + ")"; })
+ .attr("x", function (d) { return computeTextRotation(d) > 180 ? -40 : -30; })
.attr("dx", "6") // margin
.attr("dy", ".35em") // vertical-align
.attr("opacity", function(d) {
@@ -741,7 +742,6 @@ function sunburst (recipient, data, width, height) {
.text(function(d) {
return d.name;
})
- .attr("transform", function(d) { return "rotate(" + computeTextRotation(d) + ")"; })
.style("font-size", "10px")
// Makes svg elements invisible to events
.style("pointer-events", "none");
@@ -768,8 +768,8 @@ function sunburst (recipient, data, width, height) {
var arcText = d3.select(this.parentNode).select("text");
// fade in the text element and recalculate positions
arcText
- .attr("transform", function() { return "rotate(" + computeTextRotation(e) + ")" })
- .attr("x", function(d) { return y(d.y); })
+ .attr("transform", function(d) { return "translate(" + arc.centroid(d) + ")rotate(" + computeTextRotation(d) + ")"; })
+ .attr("x", function (d) { return computeTextRotation(d) > 180 ? -40 : -30; })
.transition().duration(250)
.attr("opacity", 1);
}
@@ -1037,19 +1037,19 @@ function createGauges(data, width, height, font_size, no_data_image, font) {
label = label.replace(/(/g,'\(');
label = label.replace(/)/g,'\)');
- minimun_warning = parseFloat( data[key].min_warning );
- maximun_warning = parseFloat( data[key].max_warning );
- minimun_critical = parseFloat( data[key].min_critical );
- maximun_critical = parseFloat( data[key].max_critical );
+ minimun_warning = round_with_decimals(parseFloat( data[key].min_warning ));
+ maximun_warning = round_with_decimals(parseFloat( data[key].max_warning ));
+ minimun_critical = round_with_decimals(parseFloat( data[key].min_critical ));
+ maximun_critical = round_with_decimals(parseFloat( data[key].max_critical ));
- mininum = parseFloat(data[key].min);
- maxinum = parseFloat(data[key].max);
+ mininum = round_with_decimals(parseFloat(data[key].min));
+ maxinum = round_with_decimals(parseFloat(data[key].max));
critical_inverse = parseInt(data[key].critical_inverse);
warning_inverse = parseInt(data[key].warning_inverse);
- valor = parseFloat(data[key].value);
-
+ valor = round_with_decimals(data[key].value);
+
if (isNaN(valor))
valor = null;
createGauge(nombre, label, valor, mininum, maxinum,
@@ -1281,7 +1281,7 @@ function Gauge(placeholderName, configuration, font)
{
var pointerContainer = this.body.select(".pointerContainer");
- pointerContainer.selectAll("text").text(Math.round(value));
+ pointerContainer.selectAll("text").text(round_with_decimals(value));
var pointer = pointerContainer.selectAll("path");
pointer.transition()
@@ -1492,4 +1492,601 @@ function print_phases_donut (recipient, phases) {
polyline.exit()
.remove();
}
+}
+
+function round_with_decimals (value, multiplier = 1) {
+ if ((value * multiplier) == 0) return 0;
+ if ((value * multiplier) >= 1) {
+ return Math.round(value * multiplier) / multiplier;
+ }
+ return round_with_decimals (value, multiplier * 10);
+}
+
+function progress_bar_d3 (recipient, percentile, width, height, color, unit, label, label_color) {
+ var startPercent = 0;
+ var endPercent = parseInt(percentile) / 100;
+ var count = Math.abs((endPercent - startPercent) / 0.01);
+ var step = endPercent < startPercent ? -0.01 : 0.01;
+
+ var circle = d3.select(recipient)
+ .append("svg")
+ .attr("width", width)
+ .attr("height", height);
+
+ var progress_back = circle.append('rect')
+ .attr('fill', '#000000')
+ .attr('fill-opacity', 0.5)
+ .attr('height', 20)
+ .attr('width', width)
+ .attr('rx', 10)
+ .attr('ry', 10)
+ .attr('x', 0);
+
+ var progress_front = circle.append('rect')
+ .attr('fill', color)
+ .attr('fill-opacity', 1)
+ .attr('height', 20)
+ .attr('width', 0)
+ .attr('rx', 10)
+ .attr('ry', 10)
+ .attr('x', 0);
+
+ var labelText = circle.append("text")
+ .attr("transform", "translate(" + (width/2) + ", " + (height/2) + ")")
+ .attr('fill', label_color)
+ .style("font-family", "arial")
+ .style("font-weight", "bold")
+ .style("font-size", 20)
+ .html(label)
+ .attr('dy', '15')
+ .attr('text-anchor', 'middle');
+
+ var numberText = circle.append("text")
+ .attr("transform", "translate(" + (width/2) + ", " + (height/2) + ")")
+ .attr('fill', '#FFFFFF')
+ .style("font-family", "arial")
+ .style("font-weight", "bold")
+ .style("font-size", 14)
+ .attr('text-anchor', 'middle')
+ .attr('dy', '-10');
+
+ function updateProgress(bar_progress) {
+ var percent_value = Number(bar_progress * 100);
+ numberText.text(percent_value.toFixed() + " " + unit);
+ progress_front.attr('width', (width * bar_progress));
+ }
+
+ var bar_progress = startPercent;
+
+ (function loops() {
+ updateProgress(bar_progress);
+
+ if (count > 0) {
+ count--;
+ bar_progress += step;
+ setTimeout(loops, 30);
+ }
+ })();
+}
+
+function progress_bubble_d3 (recipient, percentile, width, height, color, unit, label, label_color) {
+ var startPercent = 0;
+ var endPercent = parseInt(percentile) / 100;
+ var count = Math.abs((endPercent - startPercent) / 0.01);
+ var step = endPercent < startPercent ? -0.01 : 0.01;
+
+ var numberSize = 0;
+ var textSize = 0;
+ var unitSize = 0;
+ var yPosText = 0;
+ var yPosNumber = 0;
+ if (width >= 500) {
+ numberSize = 100;
+ textSize = 50;
+ unitSize = 50;
+ yPosNumber = '15';
+ yPosText = '-100';
+ }
+ else if (width >= 400) {
+ numberSize = 80;
+ textSize = 40;
+ unitSize = 40;
+ yPosNumber = '15';
+ yPosText = '-80';
+ }
+ else if (width >= 300) {
+ numberSize = 60;
+ textSize = 30;
+ unitSize = 30;
+ yPosNumber = '15';
+ yPosText = '-45';
+ }
+ else if (width >= 200) {
+ numberSize = 40;
+ textSize = 20;
+ unitSize = 20;
+ yPosNumber = '50';
+ yPosText = '-30';
+ }
+ else if (width >= 100) {
+ numberSize = 20;
+ textSize = 10;
+ unitSize = 10;
+ yPosNumber = '5';
+ yPosText = '-20';
+ }
+ else {
+ numberSize = 10;
+ textSize = 8;
+ unitSize = 8;
+ yPosNumber = '5';
+ yPosText = '-10';
+ }
+
+ var circle = d3.select(recipient)
+ .append("svg")
+ .attr("width", width)
+ .attr("height", height);
+
+ var progress_back = circle.append('circle')
+ .attr("transform", "translate(" + (width/2) + ", " + (height/2) + ")")
+ .attr('fill', '#000000')
+ .attr('fill-opacity', 0)
+ .attr('r', width/2);
+
+ var progress_front = circle.append('circle')
+ .attr("transform", "translate(" + (width/2) + ", " + (height/2) + ")")
+ .attr('fill', color)
+ .attr('fill-opacity', 1)
+ .attr('r', 0);
+
+ var labelText = circle.append("text")
+ .attr("transform", "translate(" + (width/2) + ", " + (height/2) + ")")
+ .attr('fill', label_color)
+ .style("font-family", "arial")
+ .style("font-weight", "bold")
+ .style("font-size", textSize)
+ .html(label)
+ .attr('dy', -(width/3))
+ .attr('text-anchor', 'middle');
+
+ var numberText = circle.append("text")
+ .attr("transform", "translate(" + (width/2) + ", " + (height/2) + ")")
+ .attr('fill', label_color)
+ .style("font-family", "arial")
+ .style("font-weight", "bold")
+ .style("font-size", numberSize)
+ .attr('text-anchor', 'middle')
+ .attr('dy', width/3);
+
+ function updateProgress(bar_progress) {
+ var percent_value = Number(bar_progress * 100);
+ numberText.text(percent_value.toFixed() + " " + unit);
+ progress_front.attr('r', ((width/2) * bar_progress));
+ }
+
+ var bar_progress = startPercent;
+
+ (function loops() {
+ updateProgress(bar_progress);
+
+ if (count > 0) {
+ count--;
+ bar_progress += step;
+ setTimeout(loops, 30);
+ }
+ })();
+}
+
+function print_circular_progress_bar (recipient, percentile, width, height, color, unit, label, label_color) {
+ var twoPi = Math.PI * 2;
+ var radius = (width / 2);
+ var border = 20;
+ var startPercent = 0;
+ var endPercent = parseInt(percentile) / 100;
+ var count = Math.abs((endPercent - startPercent) / 0.01);
+ var step = endPercent < startPercent ? -0.01 : 0.01;
+
+ var numberSize = 0;
+ var textSize = 0;
+ var unitSize = 0;
+ var yPosText = 0;
+ var yPosUnit = 0;
+ var yPosNumber = 0;
+ if (width >= 500) {
+ numberSize = 100;
+ textSize = 50;
+ unitSize = 50;
+ yPosNumber = '15';
+ yPosText = '-100';
+ yPosUnit = '100';
+ }
+ else if (width >= 400) {
+ numberSize = 80;
+ textSize = 40;
+ unitSize = 40;
+ yPosNumber = '15';
+ yPosText = '-80';
+ yPosUnit = '80';
+ }
+ else if (width >= 300) {
+ numberSize = 60;
+ textSize = 30;
+ unitSize = 30;
+ yPosNumber = '15';
+ yPosText = '-45';
+ yPosUnit = '60';
+ }
+ else if (width >= 200) {
+ numberSize = 40;
+ textSize = 20;
+ unitSize = 20;
+ yPosNumber = '10';
+ yPosText = '-30';
+ yPosUnit = '40';
+ }
+ else if (width >= 100) {
+ numberSize = 20;
+ textSize = 10;
+ unitSize = 10;
+ yPosNumber = '5';
+ yPosText = '-15';
+ yPosUnit = '20';
+ }
+ else {
+ numberSize = 8;
+ textSize = 4;
+ unitSize = 4;
+ yPosNumber = '2';
+ yPosText = '-5';
+ yPosUnit = '5';
+ }
+
+ var arc = d3.svg.arc()
+ .startAngle(0)
+ .innerRadius(radius)
+ .outerRadius(radius - border);
+
+ var circle = d3.select(recipient)
+ .append("svg")
+ .attr("width", width)
+ .attr("height", height)
+ .append("g")
+ .attr("transform", "translate(" + (width/2) + ", " + (height/2) + ")");
+
+ var meter = circle.append("g")
+ .attr('class', 'progress-meter');
+
+ meter.append("path")
+ .attr('fill', '#000000')
+ .attr('fill-opacity', 0.5)
+ .attr('d', arc.endAngle(twoPi));
+
+ var foreground = circle.append("path")
+ .attr('fill', color)
+ .attr('fill-opacity', 1)
+ .attr('stroke', color)
+ .attr('stroke-opacity', 1);
+
+ var front = circle.append("path")
+ .attr('fill', color)
+ .attr('fill-opacity', 1);
+
+ var labelText = circle.append("text")
+ .attr('fill', label_color)
+ .style("font-family", "arial")
+ .style("font-weight", "bold")
+ .style("font-size", textSize)
+ .html(label)
+ .attr('text-anchor', 'middle')
+ .attr('dy', yPosText);
+
+ var numberText = circle.append("text")
+ .attr('fill', label_color)
+ .style("font-family", "arial")
+ .style("font-weight", "bold")
+ .style("font-size", numberSize)
+ .attr('text-anchor', 'middle')
+ .attr('dy', yPosNumber);
+
+ var percentText = circle.append("text")
+ .attr('fill', label_color)
+ .style("font-family", "arial")
+ .style("font-weight", "bold")
+ .style("font-size", unitSize)
+ .text(unit)
+ .attr('text-anchor', 'middle')
+ .attr('dy', yPosUnit);
+
+ function updateProgress(progress) {
+ foreground.attr('d', arc.endAngle(twoPi * progress));
+ front.attr('d', arc.endAngle(twoPi * progress));
+ var percent_value = Number(progress * 100);
+ numberText.text(percent_value.toFixed());
+ }
+
+ var progress = startPercent;
+
+ (function loops() {
+ updateProgress(progress);
+
+ if (count > 0) {
+ count--;
+ progress += step;
+ setTimeout(loops, 30);
+ }
+ })();
+}
+
+function print_interior_circular_progress_bar (recipient, percentile, width, height, color, unit, label, label_color) {
+ var twoPi = Math.PI * 2;
+ var radius = (width / 2) - 20;
+ var radius2 = (width / 2);
+ var border = 20;
+ var startPercent = 0;
+ var endPercent = parseInt(percentile) / 100;
+ var count = Math.abs((endPercent - startPercent) / 0.01);
+ var step = endPercent < startPercent ? -0.01 : 0.01;
+
+ var numberSize = 0;
+ var textSize = 0;
+ var unitSize = 0;
+ var yPosText = 0;
+ var yPosUnit = 0;
+ var yPosNumber = 0;
+ if (width >= 500) {
+ numberSize = 100;
+ textSize = 50;
+ unitSize = 50;
+ yPosNumber = '15';
+ yPosText = '-100';
+ yPosUnit = '100';
+ }
+ else if (width >= 400) {
+ numberSize = 80;
+ textSize = 40;
+ unitSize = 40;
+ yPosNumber = '15';
+ yPosText = '-80';
+ yPosUnit = '80';
+ }
+ else if (width >= 300) {
+ numberSize = 60;
+ textSize = 30;
+ unitSize = 30;
+ yPosNumber = '15';
+ yPosText = '-45';
+ yPosUnit = '60';
+ }
+ else if (width >= 200) {
+ numberSize = 40;
+ textSize = 20;
+ unitSize = 20;
+ yPosNumber = '10';
+ yPosText = '-30';
+ yPosUnit = '40';
+ }
+ else if (width >= 100) {
+ numberSize = 20;
+ textSize = 10;
+ unitSize = 10;
+ yPosNumber = '5';
+ yPosText = '-15';
+ yPosUnit = '20';
+ }
+ else {
+ numberSize = 8;
+ textSize = 4;
+ unitSize = 4;
+ yPosNumber = '2';
+ yPosText = '-5';
+ yPosUnit = '5';
+ }
+
+ var arc = d3.svg.arc()
+ .startAngle(0)
+ .innerRadius(radius)
+ .outerRadius(radius - border);
+
+ var arc2 = d3.svg.arc()
+ .startAngle(0)
+ .innerRadius(radius2)
+ .outerRadius(radius2 - border);
+
+ var circle = d3.select(recipient)
+ .append("svg")
+ .attr("width", width)
+ .attr("height", height)
+ .append("g")
+ .attr("transform", "translate(" + (width/2) + ", " + (height/2) + ")");
+
+ var meter = circle.append("g")
+ .attr('class', 'progress-meter');
+
+ meter.append("path")
+ .attr('fill', '#000000')
+ .attr('fill-opacity', 0.5)
+ .attr('d', arc.endAngle(twoPi));
+
+ var meter = circle.append("g")
+ .attr('class', 'progress-meter');
+
+ meter.append("path")
+ .attr('fill', color)
+ .attr('fill-opacity', 1)
+ .attr('d', arc2.endAngle(twoPi));
+
+ var foreground = circle.append("path")
+ .attr('fill', color)
+ .attr('fill-opacity', 1)
+ .attr('stroke', color)
+ .attr('stroke-opacity', 1);
+
+ var front = circle.append("path")
+ .attr('fill', color)
+ .attr('fill-opacity', 1);
+
+ var labelText = circle.append("text")
+ .attr('fill', label_color)
+ .style("font-family", "arial")
+ .style("font-weight", "bold")
+ .style("font-size", textSize)
+ .html(label)
+ .attr('text-anchor', 'middle')
+ .attr('dy', yPosText);
+
+ var numberText = circle.append("text")
+ .attr('fill', label_color)
+ .style("font-family", "arial")
+ .style("font-weight", "bold")
+ .style("font-size", numberSize)
+ .attr('text-anchor', 'middle')
+ .attr('dy', yPosNumber);
+
+ var percentText = circle.append("text")
+ .attr('fill', label_color)
+ .style("font-family", "arial")
+ .style("font-weight", "bold")
+ .style("font-size", unitSize)
+ .text(unit)
+ .attr('text-anchor', 'middle')
+ .attr('dy', yPosUnit);
+
+ function updateProgress(progress) {
+ foreground.attr('d', arc.endAngle(twoPi * progress));
+ front.attr('d', arc.endAngle(twoPi * progress));
+ var percent_value = Number(progress * 100);
+ numberText.text(percent_value.toFixed());
+ }
+
+ var progress = startPercent;
+
+ (function loops() {
+ updateProgress(progress);
+
+ if (count > 0) {
+ count--;
+ progress += step;
+ setTimeout(loops, 30);
+ }
+ })();
+}
+
+function print_donut_graph (recipient, width, height, module_data, resume_color) {
+ var svg = d3.select(recipient)
+ .append("svg")
+ .attr("width", width)
+ .attr("height", height)
+ .append("g");
+
+ svg.append("g")
+ .attr("class", "slices");
+
+ var radius = 120;
+ var increment_y = 60;
+ var increment_y_padding = 25;
+ var decrement_x_padding = 150;
+ if (width >= 500) {
+ radius = 180;
+ increment_y = 60;
+ increment_y_padding = 20;
+ decrement_x_padding = 40;
+ }
+ else if (width >= 400) {
+ radius = 140;
+ increment_y = 40;
+ increment_y_padding = 20;
+ decrement_x_padding = 40;
+ }
+ else if (width >= 300) {
+ radius = 100;
+ increment_y = 40;
+ increment_y_padding = 15;
+ decrement_x_padding = 40;
+ }
+ else if (width >= 200) {
+ radius = 50;
+ increment_y = 40;
+ increment_y_padding = 15;
+ decrement_x_padding = 25;
+ }
+ else if (width >= 100) {
+ radius = 20;
+ increment_y = 20;
+ increment_y_padding = 8;
+ decrement_x_padding = 25;
+ }
+ else {
+ radius = 10;
+ increment_y = 10;
+ increment_y_padding = 3;
+ decrement_x_padding = 5;
+ }
+
+ var arc = d3.svg.arc()
+ .outerRadius(radius * 0.8)
+ .innerRadius(radius * 0.4);
+
+ var key = function(d){ return d.data.label; };
+
+ var pie = d3.layout.pie()
+ .sort(null)
+ .value(function(d) {
+ return parseFloat(d.percent);
+ });
+
+ jQuery.each(module_data, function (key, m_d) {
+ svg.append("g")
+ .append("rect")
+ .attr("transform", "translate(" + (((width / 2) - (radius + decrement_x_padding))) + "," + (((height / 2) - radius) - increment_y) + ")")
+ .attr('fill', m_d.color)
+ .attr('x', -20)
+ .attr('y', -10)
+ .attr('width', 20)
+ .attr('height', 10);
+
+ svg.append("g")
+ .append("text")
+ .attr('fill', resume_color)
+ .attr("transform", "translate(" + (((width / 2) - (radius + decrement_x_padding)) + 10) + "," + (((height / 2) - radius) - increment_y) + ")")
+ .text(m_d.tag_name)
+ .style("font-family", "smallfontFont")
+ .style("font-size", "7pt");
+
+ increment_y -= increment_y_padding;
+ });
+
+ function donutData (){
+ return module_data.map(function(m_data){
+ return { label: m_data.tag_name, percent: m_data.percent, color : m_data.color}
+ });
+ }
+
+ print_phases(donutData());
+
+ function print_phases(data) {
+ var slice = svg.select(".slices").selectAll("path.slice")
+ .data(pie(data), key);
+
+ slice.enter()
+ .insert("path")
+ .style("fill", function(d) {
+ return d.data.color;
+ })
+ .attr("class", "slice")
+ .attr("transform", "translate(" + width / 2 + "," + (height - radius) + ")");
+
+ slice.transition()
+ .duration(0)
+ .attrTween("d", function(d) {
+ this._current = this._current || d;
+ var interpolate = d3.interpolate(this._current, d);
+ this._current = interpolate(0);
+ return function(t) {
+ return arc(interpolate(t));
+ };
+ });
+
+ slice.exit().remove();
+ }
}
\ No newline at end of file
diff --git a/pandora_console/include/help/en/help_alert_macros.php b/pandora_console/include/help/en/help_alert_macros.php
index c305fa3730..013809a932 100644
--- a/pandora_console/include/help/en/help_alert_macros.php
+++ b/pandora_console/include/help/en/help_alert_macros.php
@@ -8,67 +8,67 @@
Besides the defined module macros, the following macros are available:
-
-_address_: Address of the agent that triggered the alert.
-_address_n_ : The address of the agent that corresponds to the position indicated in "n" e.g: address_1_ , address_2__
-_agent_: Name of the agent that triggered the alert.
-_agentcustomfield_n_: Agent custom field number n (eg. _agentcustomfield_9_).
-_agentcustomid_: Agent custom ID.
-_agentdescription_: Description of the agent that triggered the alert.
-_agentgroup_ : Agent group name.
-_agentos_: Agent's operative system.
-_agentstatus_ : Current status of the agent.
-_alert_critical_instructions_: Instructions for CRITICAL status contained in the module.
-_alert_description_: Alert description.
-_alert_name_: Alert name.
-_alert_priority_: Alert’s numeric priority.
-_alert_text_severity_: Priority level, in text, for the alert (Maintenance, Informational, Normal Minor, Major, Critical).
-_alert_threshold_: Alert threshold.
-_alert_times_fired_: Number of times the alert has been triggered.
-_alert_unknown_instructions_: Instructions for UNKNOWN status contained in the module.
-_alert_warning_instructions_: Instructions for WARNING status contained in the module.
-_all_address_ : All address of the agent that fired the alert.
-_data_: Module data that caused the alert to fire.
-_email_tag_: Emails associated to the module’s tags.
-_event_id_: (Only event alerts) ID of the event that triggered the alert.
-_event_text_severity_: (Only event alerts) event text (that triggered the alert) severity (Maintenance, Informational, Normal Minor, Warning, Major, Critical).
-_field1_: User defined field 1.
-_field2_: User defined field 2.
-_field3_: User defined field 3.
-_field4_: User defined field 4.
-_field5_: User defined field 5.
-_field6_: User defined field 6.
-_field7_: User defined field 7.
-_field8_: User defined field 8.
-_field9_: User defined field 9.
-_field10_: User defined field 10.
-_groupcontact_: Group’s contact information. Configured when the group is created.
-_groupcustomid_: Group’s custom ID.
-_groupother_: Other information about the group. Configured when the group is created.
-_homeurl_ : It is a link of the public URL this must be configured in the general options of the setup.
-_id_agent_: Agent’s ID, useful for building a direct URL that redirects to a Pandora FMS console webpage.
-_id_alert_: Alert’s numeric ID (unique), used to correlate the alert with third party software.
-_id_group_ : Agent group ID.
-_id_module_: The module's ID.
-_interval_: Module’s execution interval.
-_module_: Module name.
-_modulecustomid_: Module custom ID.
-_moduledata_X_: Last data of module X (module name, cannot have white spaces).
-_moduledescription_: Description of the module that triggered the alert.
-_modulegraph_nh_: (>=6.0) (Only for alerts that use the command eMail) Returns an image encoded in base64 of a module’s graph with a period of n hours (eg. _modulegraph_24h_). A correct setup of the connection between the server and the console's API is required. This setup is done on the server's configuration file.
-_modulegraphth_nh_:Same operation as the previous macro only with the critical and warning thresholds of the module provided they are defined.
-_modulegroup_: Module’s group name.
-_modulestatus_: Module status.
-_moduletags_: URLs asociadas a los tags de módulos.
-_name_tag_: Names of the tags related to the module.
-_phone_tag_: Phone numbers related to the module’s tags.
-_plugin_parameters_: Module’s Plugin parameters.
-_policy_: Name of the policy that the module belongs to (if applies).
-_prevdata_ : Module data previus the alert to fire.
-_target_ip_: IP address for the module’s target.
-_target_port_: Port number for the module’s target.
-_timestamp_: Time and date on which the alert was triggered (yy-mm-dd hh:mm:ss).
-_timezone_: Timezone that is represented on _timestamp_.
+
+_address_: Address of the agent that triggered the alert.
+_address_n_ : The address of the agent that corresponds to the position indicated in "n" e.g: address_1_ , address_2__
+_agent_: Name of the agent that triggered the alert.
+_agentcustomfield_n_: Agent custom field number n (eg. _agentcustomfield_9_).
+_agentcustomid_: Agent custom ID.
+_agentdescription_: Description of the agent that triggered the alert.
+_agentgroup_ : Agent group name.
+_agentos_: Agent's operative system.
+_agentstatus_ : Current status of the agent.
+_alert_critical_instructions_: Instructions for CRITICAL status contained in the module.
+_alert_description_: Alert description.
+_alert_name_: Alert name.
+_alert_priority_: Alert’s numeric priority.
+_alert_text_severity_: Priority level, in text, for the alert (Maintenance, Informational, Normal Minor, Major, Critical).
+_alert_threshold_: Alert threshold.
+_alert_times_fired_: Number of times the alert has been triggered.
+_alert_unknown_instructions_: Instructions for UNKNOWN status contained in the module.
+_alert_warning_instructions_: Instructions for WARNING status contained in the module.
+_all_address_ : All address of the agent that fired the alert.
+_data_: Module data that caused the alert to fire.
+_email_tag_: Emails associated to the module’s tags.
+_event_id_: (Only event alerts) ID of the event that triggered the alert.
+_event_text_severity_: (Only event alerts) event text (that triggered the alert) severity (Maintenance, Informational, Normal Minor, Warning, Major, Critical).
+_field1_: User defined field 1.
+_field2_: User defined field 2.
+_field3_: User defined field 3.
+_field4_: User defined field 4.
+_field5_: User defined field 5.
+_field6_: User defined field 6.
+_field7_: User defined field 7.
+_field8_: User defined field 8.
+_field9_: User defined field 9.
+_field10_: User defined field 10.
+_groupcontact_: Group’s contact information. Configured when the group is created.
+_groupcustomid_: Group’s custom ID.
+_groupother_: Other information about the group. Configured when the group is created.
+_homeurl_ : It is a link of the public URL this must be configured in the general options of the setup.
+_id_agent_: Agent’s ID, useful for building a direct URL that redirects to a Pandora FMS console webpage.
+_id_alert_: Alert’s numeric ID (unique), used to correlate the alert with third party software.
+_id_group_ : Agent group ID.
+_id_module_: The module's ID.
+_interval_: Module’s execution interval.
+_module_: Module name.
+_modulecustomid_: Module custom ID.
+_moduledata_X_: Last data of module X (module name, cannot have white spaces).
+_moduledescription_: Description of the module that triggered the alert.
+_modulegraph_nh_: (>=6.0) (Only for alerts that use the command eMail) Returns an image encoded in base64 of a module’s graph with a period of n hours (eg. _modulegraph_24h_). A correct setup of the connection between the server and the console's API is required. This setup is done on the server's configuration file.
+_modulegraphth_nh_:Same operation as the previous macro only with the critical and warning thresholds of the module provided they are defined.
+_modulegroup_: Module’s group name.
+_modulestatus_: Module status.
+_moduletags_: URLs asociadas a los tags de módulos.
+_name_tag_: Names of the tags related to the module.
+_phone_tag_: Phone numbers related to the module’s tags.
+_plugin_parameters_: Module’s Plugin parameters.
+_policy_: Name of the policy that the module belongs to (if applies).
+_prevdata_ : Module data previus the alert to fire.
+_target_ip_: IP address for the module’s target.
+_target_port_: Port number for the module’s target.
+_timestamp_: Time and date on which the alert was triggered (yy-mm-dd hh:mm:ss).
+_timezone_: Timezone that is represented on _timestamp_.
diff --git a/pandora_console/include/help/en/help_cron.php b/pandora_console/include/help/en/help_cron.php
new file mode 100644
index 0000000000..a1e235d06e
--- /dev/null
+++ b/pandora_console/include/help/en/help_cron.php
@@ -0,0 +1,45 @@
+
+Cron for server modules
+
+Using the configuration parameter sets Cron from and Cron to makes
+it possible for a module to run only for certain periods of time.
+The way in which it is configured is similar to the syntax of
+cron .
+Just as they appear in the Pandora console, each one of the parameters
+has three options.
+
+Cron from: any
+
+The module will not have restrictions in that parameter. Whatever the value is
+will be executed, and it is equivalent to the asterisk (*) in the cron nomenclature. In this
+case Cron to is ignored.
+
+Cron from: different from any. Cron to: any
+
+The module will run only during the time in which the date matches that
+parameter. It is equivalent to writingjust one number in cron nomenclature.
+
+Cron from: different from any. Cron to: different from any
+
+The module will run only during the time specified between Cron from and Cron to .
+It is equivalent to writing number dash number (n-n) in cron nomenclature.
+
+Agent interval
+
+As long as cron conditions are met, the agent will run following
+its execution interval.
+
+Examples
+
+
+ * * * * * : No cron configured.
+ 15 20 * * * : It will run every day at 20:15.
+ * 20 * * * : It will run every day during the hour 20, that is, from 20:00 to 20:59.
+ * 8-19 * * * : It will run everyday from 8:00 to 19:59.
+ 15-45 * 1-16 * * : It will run every first 16 days of the month every hour, from quarter past to quarter to.
+ * * * 5 * : It will run only in May.
+
diff --git a/pandora_console/include/help/en/help_linked_map_weight.php b/pandora_console/include/help/en/help_linked_map_weight.php
new file mode 100644
index 0000000000..aff63a93c4
--- /dev/null
+++ b/pandora_console/include/help/en/help_linked_map_weight.php
@@ -0,0 +1,19 @@
+
+Associated map status weight
+
+
+Only "static image" type elements can have this option. Through it we establish a percentage of elements in a status other than the normal one so that our element linked to that map picks up its status.
+
+
+For example:
+
+
+If we have a map 1 with a "static image" type element that points to map 2 and has its weight set at 50%, you will only see its status modified if at least half of the elements (items that must return a status from an agent, module or other linked console) of map 2 are not in normal status.
+
+
+We can also have an element linked to a console with 10 elements that return a status, which in turn can have elements linked to other consoles. If our element from the first console has a weight of 20%, it is because we want it to show a critical (or warning) status if at least 2 of the 10 elements of the second console have a critical (or warning) status. Similarly, if the weight is 80%, 8 out of 10 elements must be in a non-normal status.
+
\ No newline at end of file
diff --git a/pandora_console/include/help/en/help_module_definition.php b/pandora_console/include/help/en/help_module_definition.php
index 8173a8093b..81bdaf95ea 100644
--- a/pandora_console/include/help/en/help_module_definition.php
+++ b/pandora_console/include/help/en/help_module_definition.php
@@ -5,11 +5,12 @@
?>
Module definition
-There are two modes for an agent:
+There are three modes for an agent:
- Learning mode: all the modules sent by the agent are accepted. If modules are not defined, they will be automatically defined by the system. It is recommended to activate the agents in this mode and change it once the user is familiar with Pandora FMS. From version 4.0.3, in this mode, Pandora console collect all the configuration specified by the agent configuration file the first time and thereafter any changes should be made through console, will not catch changes in config file.
-
+ Learning mode: All the modules sent by the agent are accepted. If modules are not defined, they will be automatically defined by the system. It is recommended to activate the agents in this mode and change it once the user is familiar with Pandora FMS. From version 4.0.3, in this mode, Pandora console collect all the configuration specified by the agent configuration file the first time and thereafter any changes should be made through console, will not catch changes in config file.
- Normal mode: the modules in this mode must be configured manually. The self definition of the modules is not allowed in this mode.
+ Normal mode: The modules in this mode must be configured manually. The self definition of the modules is not allowed in this mode.
+
+ Autodisable mode: It behaves exactly the same as an agent in learning mode: when the first XML reaches it, the first agent is created and, on each report, if there are new modules they can also be added automatically. Nevertheless, when all modules from an agent that are in autodisable mode are also marked as unknown, the agent is automatically disabled. In any case, if the agent reports again, it gets enabled again on its own.
diff --git a/pandora_console/include/help/es/help_cron.php b/pandora_console/include/help/es/help_cron.php
new file mode 100644
index 0000000000..2902c81928
--- /dev/null
+++ b/pandora_console/include/help/es/help_cron.php
@@ -0,0 +1,46 @@
+
+Cron para módulos de servidor
+
+Mediante los grupos de parámetros de configuración Cron desde y Cron hasta se
+puede hacer que un módulo solo se ejecute durante ciertos periodos de tiempo. El
+modo en el que se configura es parecido a la sintaxis de
+cron .
+Tal y como aparecen en la consola de Pandora, cada uno de los parámetros
+tiene tres opciones.
+
+Cron desde: cualquiera
+
+El módulo no tendrá restricciones en ese parámetro. Se ejecutará cualquiera que
+que sea el valor y equivale al asterisco (*) en la nomenclatura de cron. En este
+caso se ignora Cron desde .
+
+Cron desde: distinto de cualquiera. Cron hasta: cualquiera
+
+El módulo se ejecutará solamente el tiempo en el que la fecha coincida con ese
+parámetro. Equivale a escribir solamente un número en la nomenclatura de cron.
+
+Cron desde: distinto de cualquiera. Cron hasta: distinto de cualquiera
+
+El módulo se ejecutará entre el tiempo indicado en el Cron desde y el Cron hasta .
+Equivale a escribir el número guión número (n-n) en la nomenclatura de cron.
+
+Intervalo del agente
+
+Mientras que se cumplan las condiciones de cron, el agente se ejecutará siguiendo
+su intervalo de ejecución.
+
+Ejemplos
+
+
+ * * * * * : No hay cron configurado.
+ 15 20 * * * : Se ejecutará todos los días a las 20:15.
+ * 20 * * * : Se ejecutará todos los días durante las 20 horas, es decir, entre las 20:00 y las 20:59.
+ * 8-19 * * * : Se ejecutará todos los días entre las 8:00 y las 19:59.
+ 15-45 * 1-16 * * : Se ejecutará todos los primeros 16 días del mes a todas horas entre y cuarto y menos cuarto.
+ * * * 5 * : Se ejecutará solamente en mayo.
+
+
diff --git a/pandora_console/include/help/es/help_linked_map_weight.php b/pandora_console/include/help/es/help_linked_map_weight.php
new file mode 100644
index 0000000000..430179c134
--- /dev/null
+++ b/pandora_console/include/help/es/help_linked_map_weight.php
@@ -0,0 +1,19 @@
+
+Peso de estado del mapa asociado
+
+
+Solo los elementos de tipo "imagen estática" pueden llevar esta opción. Mediante ella establecemos un porcentaje de elementos en un estado diferente al normal para que nuestro elemento enlazado a ese mapa recoja su estado.
+
+
+Por ejemplo:
+
+
+Si tenemos un mapa 1 con un elemento de tipo "imagen estática" que apunta a un mapa 2 y tiene su peso establecido en un 50%, solo verá modificado su estado si al menos la mitad de los elementos (elementos que deben devolver un estado tanto de agente, de módulo o de otra consola enlazada) del mapa 2 no están en un estado normal.
+
+
+También podemos tener un elemento enlazado a una consola con 10 elementos que devuelvan un estado, que a su vez pueden tener elementos enlazados a otras consolas. Si nuestro elemento de la primera consola tiene establecido un peso del 20% es porque queremos que nos muestre un estado crítico (o de advertencia) si al menos 2 de los 10 elementos de la segunda consola tienen un estado crítico (o de advertencia). Del mismo modo si el peso fuese del 80%, se tendrán que tener 8 elementos de 10 en un estado no normal.
+
\ No newline at end of file
diff --git a/pandora_console/include/help/es/help_module_definition.php b/pandora_console/include/help/es/help_module_definition.php
index e31ac65d6c..ff85f8b326 100644
--- a/pandora_console/include/help/es/help_module_definition.php
+++ b/pandora_console/include/help/es/help_module_definition.php
@@ -6,10 +6,12 @@
Definición de módulo
-Existen dos modos para un agente:
+Existen tres modos para un agente:
- Modo aprendizaje: todos los módulos enviados por el agente se aceptan. Si los módulos no están definidos, el sistema los creará automáticamente. Se recomienda activar los agentes en este modo y cambiarlo una vez que se el operador se ha familiarizado con Pandora FMS. A partir de la versión 4.0.3, en este modo Pandora recogerá en consola toda la configuración indicada por el fichero de configuración del agente la primera vez y a partir de entonces todas las modificaciones se deberán realizar a través de consola, no cogerá cambios en el fichero de configuración.
+ Modo aprendizaje: Si el XML recibido del agente software contiene nuevos módulos, éstos serán automáticamente creados. Este es el comportamiento por defecto.
- Modo normal: los módulos en este modo se deben configurar manualmente. No se permite la definición automática en este modo.
+ Modo normal: No se crearán nuevos módulos que lleguen en el XML si no han sido declarados previamente en la consola.
+
+ Modo auto deshabilitado: Similar al modo aprendizaje, en este modo, además, si todos los módulos pasan a estado desconocido el agente se deshabilitará automáticamente, pasando a habilitarse de nuevo si recibe nueva información.
diff --git a/pandora_console/include/help/ja/help_alert_config.php b/pandora_console/include/help/ja/help_alert_config.php
index 592ed64ee3..c0e6dd87f5 100644
--- a/pandora_console/include/help/ja/help_alert_config.php
+++ b/pandora_console/include/help/ja/help_alert_config.php
@@ -53,6 +53,7 @@ email アクションを設定するには、_field1_ (送信先アドレス)、
_alert_text_severity_ : テキストでのアラートの重要度 (Maintenance, Informational, Normal Minor, Warning, Major, Critical)
_event_text_severity_ : (イベントアラートのみ) イベント(アラートの発生元)のテキストでの重要度 (Maintenance, Informational, Normal Minor, Warning, Major, Critical)
_event_id_ : (イベントアラートのみ) アラート発生元のイベントID
+_event_cfX_ : (Only event alerts) Key of the event custom field that fired the alert.
_id_agent_ : エージェントのID / Webコンソールへのリンクを生成するのに便利です
_id_group_ : エージェントグループのID
_id_module_ : モジュールID
@@ -62,6 +63,8 @@ email アクションを設定するには、_field1_ (送信先アドレス)、
_target_ip_ : モジュールの対象IPアドレス
_target_port_ : モジュールの対象ポート
_plugin_parameters_ : モジュールのプラグインパラメータ
+_server_ip_ : Ip of server assigned to agent.
+_server_name_ : Name of server assigned to agent.
_groupcontact_ : グループコンタクト情報。グループの作成時に設定されます。
_groupother_ : グループに関するその他情報。グループの作成時に設定されます。
_email_tag_ : モジュールタグに関連付けられた Email。
diff --git a/pandora_console/include/help/ja/help_alert_macros.php b/pandora_console/include/help/ja/help_alert_macros.php
index c9729e6bfd..44efb37b8c 100644
--- a/pandora_console/include/help/ja/help_alert_macros.php
+++ b/pandora_console/include/help/ja/help_alert_macros.php
@@ -45,6 +45,7 @@
_alert_text_severity_ : テキストでのアラートの重要度 (Maintenance, Informational, Normal Minor, Warning, Major, Critical)
_event_text_severity_ : (イベントアラートのみ) イベント(アラートの発生元)のテキストでの重要度 (Maintenance, Informational, Normal Minor, Warning, Major, Critical)
_event_id_ : (イベントアラートのみ) アラート発生元のイベントID
+_event_cfX_ : (Only event alerts) Key of the event custom field that fired the alert.
_id_agent_ : エージェントのID / Webコンソールへのリンクを生成するのに便利です
_id_group_ : エージェントグループのID
_id_module_ : モジュール ID
@@ -54,6 +55,8 @@
_target_ip_ : モジュールの対象IPアドレス
_target_port_ : モジュールの対象ポート
_plugin_parameters_ : モジュールのプラグインパラメータ
+_server_ip_ : Ip of server assigned to agent.
+_server_name_ : Name of server assigned to agent.
_groupcontact_ : グループコンタクト情報。グループの作成時に設定されます。
_groupcustomid_: グループカスタムID
_groupother_ : グループに関するその他情報。グループの作成時に設定されます。
diff --git a/pandora_console/include/help/ja/help_cron.php b/pandora_console/include/help/ja/help_cron.php
new file mode 100644
index 0000000000..6608ae60cf
--- /dev/null
+++ b/pandora_console/include/help/ja/help_cron.php
@@ -0,0 +1,46 @@
+
+Cron for server modules
+
+Using the configuration parameter sets Cron from and Cron to makes
+it possible for a module to run only for certain periods of time.
+The way in which it is configured is similar to the syntax of
+cron .
+Just as they appear in the Pandora console, each one of the parameters
+has three options.
+
+Cron from: any
+
+The module will not have restrictions in that parameter. Whatever the value is
+will be executed, and it is equivalent to the asterisk (*) in the cron nomenclature. In this
+case Cron to is ignored.
+
+Cron from: different from any. Cron to: any
+
+The module will run only during the time in which the date matches that
+parameter. It is equivalent to writingjust one number in cron nomenclature.
+
+Cron from: different from any. Cron to: different from any
+
+The module will run only during the time specified between Cron from and Cron to .
+It is equivalent to writing number dash number (n-n) in cron nomenclature.
+
+Agent interval
+
+As long as cron conditions are met, the agent will run following
+its execution interval.
+
+Examples
+
+
+ * * * * * : No cron configured.
+ 15 20 * * * : It will run every day at 20:15.
+ * 20 * * * : It will run every day during the hour 20, that is, from 20:00 to 20:59.
+ * 8-19 * * * : It will run everyday from 8:00 to 19:59.
+ 15-45 * 1-16 * * : It will run every first 16 days of the month every hour, from quarter past to quarter to.
+ * * * 5 * : It will run only in May.
+
+
diff --git a/pandora_console/include/help/ja/help_module_definition.php b/pandora_console/include/help/ja/help_module_definition.php
index e7e4055d18..570c7cd236 100644
--- a/pandora_console/include/help/ja/help_module_definition.php
+++ b/pandora_console/include/help/ja/help_module_definition.php
@@ -11,4 +11,6 @@
通常モード: このモードでは、モジュール設定を手動で実施する必要があります。自動設定は行われません。
+
+ Autodisable mode: In terms of creating agents and modules it behaves exactly the same as an agent in learning mode: when the first XML reaches it, the first agent is created and, on each report, if there are new modules they can also be added automatically. Nevertheless, when all modules from an agent that are in autodisable mode are also marked as unknown, the agent is automatically disabled. In any case, if the agent reports again, it gets enabled again on its own.
diff --git a/pandora_console/include/javascript/functions_pandora_networkmap.js b/pandora_console/include/javascript/functions_pandora_networkmap.js
index a9c36700a8..016732d213 100644
--- a/pandora_console/include/javascript/functions_pandora_networkmap.js
+++ b/pandora_console/include/javascript/functions_pandora_networkmap.js
@@ -240,10 +240,11 @@ function update_node_name(id_db_node) {
jQuery.each(graph.nodes, function (i, element) {
if (element.id_db == id_db_node) {
- graph.nodes[i].text = name;
+ graph.nodes[i]['text'] = data['text'];
+ graph.nodes[i]['raw_text'] = data['raw_text'];
- $("#id_node_" + i + networkmap_id + " title").html(name);
- $("#id_node_" + i + networkmap_id + " tspan").html(name);
+ $("#id_node_" + i + networkmap_id + " title").html(data['raw_text']);
+ $("#id_node_" + i + networkmap_id + " tspan").html(data['raw_text']);
}
});
@@ -307,7 +308,12 @@ function change_shape(id_db_node) {
})
.on("click", selected_node)
.on("dblclick", function (d) {
- edit_node(d, true);
+ if (d.type == 3) {
+ move_to_networkmap(d);
+ }
+ else {
+ edit_node(d, true);
+ }
})
.on("contextmenu", function (d) { show_menu("node", d); });
@@ -342,7 +348,13 @@ function change_shape(id_db_node) {
})
.on("click", selected_node)
.on("dblclick", function (d) {
- edit_node(d, true);
+ if (d.type == 3) {
+ move_to_networkmap(d);
+ }
+ else {
+ edit_node(d, true);
+ }
+
})
.on("contextmenu", function (d) { show_menu("node", d); });
@@ -365,7 +377,13 @@ function change_shape(id_db_node) {
})
.on("click", selected_node)
.on("dblclick", function (d) {
- edit_node(d, true);
+ if (d.type == 3) {
+ move_to_networkmap(d);
+ }
+ else {
+ edit_node(d, true);
+ }
+
})
.on("contextmenu", function (d) { show_menu("node", d); });
@@ -400,7 +418,13 @@ function change_shape(id_db_node) {
})
.on("click", selected_node)
.on("dblclick", function (d) {
- edit_node(d, true);
+ if (d.type == 3) {
+ move_to_networkmap(d);
+ }
+ else {
+ edit_node(d, true);
+ }
+
})
.on("contextmenu", function (d) { show_menu("node", d); });
@@ -425,7 +449,13 @@ function change_shape(id_db_node) {
})
.on("click", selected_node)
.on("dblclick", function (d) {
- edit_node(d, true);
+ if (d.type == 3) {
+ move_to_networkmap(d);
+ }
+ else {
+ edit_node(d, true);
+ }
+
})
.on("contextmenu", function (d) { show_menu("node", d); });
@@ -460,7 +490,13 @@ function change_shape(id_db_node) {
})
.on("click", selected_node)
.on("dblclick", function (d) {
- edit_node(d, true);
+ if (d.type == 3) {
+ move_to_networkmap(d);
+ }
+ else {
+ edit_node(d, true);
+ }
+
})
.on("contextmenu", function (d) { show_menu("node", d); });
}
@@ -618,6 +654,30 @@ function add_new_link(new_link) {
graph.links.push(new_link);
}
+function move_to_networkmap (node) {
+ var params = [];
+ params.push("get_networkmap_from_fictional=1");
+ params.push("id=" + node.id_db);
+ params.push("id_map=" + node.map_id);
+ params.push("page=enterprise/operation/agentes/pandora_networkmap.view");
+
+ jQuery.ajax ({
+ data: params.join ("&"),
+ dataType: 'json',
+ type: 'POST',
+ url: action="ajax.php",
+ success: function (data) {
+ if (data['correct']) {
+ window.location="index.php?sec=network&sec2=operation/agentes/pandora_networkmap&tab=view&id_networkmap=" + data['id_networkmap'];
+ }
+ else {
+ edit_node(node, true);
+ }
+ }
+ });
+}
+
+
function edit_node(data_node, dblClick) {
if (enterprise_installed) {
var flag_edit_node = true;
@@ -664,7 +724,6 @@ function edit_node(data_node, dblClick) {
$("#node_options-node_name-2 input")
.attr("onclick", "update_node_name(" + node_selected.id_db + ");");
- $("#node_details-0-1").html('' + node_selected["text"] + ' ');
var params = [];
params.push("get_agent_info=1");
params.push("id_agent=" + node_selected["id_agent"]);
@@ -676,11 +735,19 @@ function edit_node(data_node, dblClick) {
type: 'POST',
url: action = "ajax.php",
success: function (data) {
- var adressess = "";
- for (adress in data['adressess']) {
- adressess += adress + " ";
+ $("#node_details-0-1").html('' + data['alias'] + ' ');
+
+ var addresses = "";
+ if (data['adressess'] instanceof Array) {
+ for (var i; i < data['adressess'].length; i++) {
+ addresses += data['adressess'][i] + " ";
+ }
+ } else {
+ for (address in data['adressess']) {
+ addresses += address + " ";
+ }
}
- $("#node_details-1-1").html(adressess);
+ $("#node_details-1-1").html(addresses);
$("#node_details-2-1").html(data["os"]);
$("#node_details-3-1").html(data["group"]);
@@ -693,7 +760,7 @@ function edit_node(data_node, dblClick) {
$("#dialog_node_edit")
.dialog("option", "title",
- dialog_node_edit_title.replace("%s", node_selected.text));
+ dialog_node_edit_title.replace("%s", node_selected['text'])); // It doesn't eval the possible XSS so it's ok
$("#dialog_node_edit").dialog("open");
if (node_selected.id_agent == undefined || node_selected.id_agent == -2) {
@@ -701,7 +768,7 @@ function edit_node(data_node, dblClick) {
$("#node_options-fictional_node_name")
.css("display", "");
$("input[name='edit_name_fictional_node']")
- .val(node_selected.text);
+ .val(node_selected.text); // It doesn't eval the possible XSS so it's ok
$("#node_options-fictional_node_networkmap_link")
.css("display", "");
$("#edit_networkmap_to_link")
@@ -715,7 +782,7 @@ function edit_node(data_node, dblClick) {
}
else {
$("input[name='edit_name_node']")
- .val(node_selected.text);
+ .val(node_selected.text); // It doesn't eval the possible XSS so it's ok
$("#node_options-fictional_node_name")
.css("display", "none");
$("#node_options-fictional_node_networkmap_link")
@@ -754,6 +821,12 @@ function get_interface_data_to_table(node_selected, selected_links) {
}
else {
jQuery.each(data, function (j, interface) {
+ if (interface['graph'] == "") {
+ var interf_graph = "--";
+ }
+ else {
+ var interf_graph = interface['graph'];
+ }
$("#interface_information").find('tbody')
.append($('')
.append($('')
@@ -763,7 +836,7 @@ function get_interface_data_to_table(node_selected, selected_links) {
.html(interface['status'])
)
.append($(' ')
- .html(interface['graph'])
+ .html(interf_graph)
)
.append($(' ')
.html(interface['ip'])
@@ -866,9 +939,9 @@ function load_interfaces(selected_links) {
});
$("#relations_table-template_row-node_source", template_relation_row)
- .html(link_each.source.text);
+ .html(link_each.source['raw_text']);
$("#relations_table-template_row-node_target", template_relation_row)
- .html(link_each.target.text);
+ .html(link_each.target['raw_text']);
$("#relations_table-template_row-edit", template_relation_row)
.attr("align", "center");
$("#relations_table-template_row-edit .delete_icon", template_relation_row)
@@ -1833,6 +1906,21 @@ function show_menu(item, data) {
refresh_holding_area();
}
};
+ items_list["restart_map"] = {
+ name: restart_map_menu,
+ icon: "restart_map",
+ disabled: function () {
+ if (enterprise_installed) {
+ return false;
+ }
+ else {
+ return true;
+ }
+ },
+ "callback": function (key, options) {
+ restart_map(networkmap_id);
+ }
+ };
if (flag_setting_relationship_running) {
items_list["cancel_set_parent"] = {
@@ -2073,6 +2161,7 @@ function refresh_holding_area() {
temp_node['image_url'] = node['image_url'];
temp_node['image_width'] = node['image_width'];
temp_node['image_height'] = node['image_width'];
+ temp_node['deleted'] = false;
graph.nodes.push(temp_node);
});
@@ -2143,6 +2232,123 @@ function refresh_holding_area() {
}
}
+function restart_map (map_id) {
+ $("
").dialog ({
+ resizable: true,
+ draggable: true,
+ modal: true,
+ overlay: {
+ opacity: 0.5,
+ background: 'black'
+ },
+ width: 600,
+ height: 250,
+ buttons: [
+ {
+ text: ok_button,
+ click: function () {
+ $(this).dialog("close");
+ proceed_to_restart_map(map_id);
+ }
+ },
+ {
+ text:cancel_button,
+ click: function () {
+ $(this).dialog("close");
+ }
+ }
+ ]
+ });
+
+ var dialog_confirm_text = "";
+ dialog_confirm_text = dialog_confirm_text + "
";
+ dialog_confirm_text = dialog_confirm_text + "
" + warning_message + " ";
+ dialog_confirm_text = dialog_confirm_text + "
" + message_to_confirm + "
";
+ dialog_confirm_text = dialog_confirm_text + "
";
+
+ $('#restart_map_confirm').html(dialog_confirm_text);
+ $('#restart_map_confirm').dialog('open');
+}
+
+function proceed_to_restart_map (map_id) {
+ $("
").dialog ({
+ resizable: true,
+ draggable: true,
+ modal: true,
+ overlay: {
+ opacity: 0.5,
+ background: 'black'
+ },
+ width: 600,
+ height: 450,
+ buttons: [
+ {
+ text: ok_button,
+ click: function () {
+ $(this).dialog("close");
+ var new_elements = [];
+ new_elements[0] = $("#text-name").val();
+ new_elements[1] = $("#id_group").val();
+ new_elements[2] = $("#text-node_radius").val();
+ new_elements[3] = $("#textarea_description").val();
+ new_elements[4] = $("input[name=source]:checked").val();
+ if (new_elements[4] == 'group') {
+ new_elements[5] = $("#checkbox-dont_show_subgroups").is(':checked');
+ }
+ else if (new_elements[4] == 'recon_task') {
+ new_elements[5] = $("#recon_task_id").val();
+ }
+ else {
+ new_elements[5] = $("#text-ip_mask").val();
+ }
+ new_elements[6] = $("#method").val();
+ reset_map_from_form(map_id, new_elements);
+ }
+ },
+ {
+ text:cancel_button,
+ click: function () {
+ $(this).dialog("close");
+ }
+ }
+ ]
+ });
+
+ var params = [];
+ params.push("get_reset_map_form=1");
+ params.push("map_id=" + map_id);
+ params.push("page=enterprise/operation/agentes/pandora_networkmap.view");
+ jQuery.ajax({
+ data: params.join("&"),
+ dataType: 'html',
+ type: 'POST',
+ url: action = "ajax.php",
+ success: function (data) {
+ $('#restart_map_form').html(data);
+ $('#restart_map_form').dialog('open');
+ }
+ });
+}
+
+function reset_map_from_form (map_id, new_elements) {
+ var params = [];
+ params.push("reset_map=1");
+ params.push("map_id=" + map_id);
+ params.push("elems[]=" + new_elements)
+ params.push("page=enterprise/operation/agentes/pandora_networkmap.view");
+ jQuery.ajax({
+ data: params.join("&"),
+ dataType: 'json',
+ type: 'POST',
+ url: action = "ajax.php",
+ success: function (data) {
+ if (!data['error']) {
+ location.reload(true);
+ }
+ }
+ });
+}
+
function set_parent(parent_data) {
if (enterprise_installed) {
var selection = d3.selectAll('.node_children');
@@ -2950,9 +3156,18 @@ function myMouseoutRhombusFunction(node_id) {
}
function draw_elements_graph() {
- link = link.data(force.links(), function (d) {
- return d.source.id + networkmap_id + "-" + d.target.id + networkmap_id + Math.random();
+ link = link.data(force.links().filter(function(d, i) {
+ if (d['deleted']) {
+ return false;
+ }
+ else {
+ return true;
+ }
+ }),
+ function (d) {
+ return d.source.id + networkmap_id + "-" + d.target.id + networkmap_id + Math.random();
});
+
link_temp = link.enter()
.append("g")
@@ -2996,6 +3211,7 @@ function draw_elements_graph() {
"id_module_start_" + d.id_module_start + " " +
"id_module_end_" + d.id_module_end;
})
+ .attr("stroke", function (d) { return d.link_color; })
.attr("stroke-width", 3)
.attr("d", null)
.attr('marker-start', function (d) {
@@ -3134,7 +3350,14 @@ function draw_elements_graph() {
return (Array(25).join(" ")) + text_link;
});
- node = node.data(force.nodes(), function (d) { return d.id; });
+ node = node.data(force.nodes().filter(function(d, i) {
+ if (d['deleted']) {
+ return false;
+ }
+ else {
+ return true;
+ }
+ }), function (d) { return d.id; });
node_temp = node.enter()
.append("g")
@@ -3173,7 +3396,13 @@ function draw_elements_graph() {
})
.on("click", selected_node)
.on("dblclick", function (d) {
- edit_node(d, true);
+ if (d.type == 3) {
+ move_to_networkmap(d);
+ }
+ else {
+ edit_node(d, true);
+ }
+
})
.on("contextmenu", function (d) { show_menu("node", d); });
@@ -3207,7 +3436,13 @@ function draw_elements_graph() {
})
.on("click", selected_node)
.on("dblclick", function (d) {
- edit_node(d, true);
+ if (d.type == 3) {
+ move_to_networkmap(d);
+ }
+ else {
+ edit_node(d, true);
+ }
+
})
.on("contextmenu", function (d) { show_menu("node", d); });
@@ -3235,7 +3470,13 @@ function draw_elements_graph() {
})
.on("click", selected_node)
.on("dblclick", function (d) {
- edit_node(d, true);
+ if (d.type == 3) {
+ move_to_networkmap(d);
+ }
+ else {
+ edit_node(d, true);
+ }
+
})
.on("contextmenu", function (d) { show_menu("node", d); });
@@ -3273,7 +3514,13 @@ function draw_elements_graph() {
})
.on("click", selected_node)
.on("dblclick", function (d) {
- edit_node(d, true);
+ if (d.type == 3) {
+ move_to_networkmap(d);
+ }
+ else {
+ edit_node(d, true);
+ }
+
})
.on("contextmenu", function (d) { show_menu("node", d); });
@@ -3303,7 +3550,13 @@ function draw_elements_graph() {
})
.on("click", selected_node)
.on("dblclick", function (d) {
- edit_node(d, true);
+ if (d.type == 3) {
+ move_to_networkmap(d);
+ }
+ else {
+ edit_node(d, true);
+ }
+
})
.on("contextmenu", function (d) { show_menu("node", d); });
@@ -3341,7 +3594,13 @@ function draw_elements_graph() {
})
.on("click", selected_node)
.on("dblclick", function (d) {
- edit_node(d, true);
+ if (d.type == 3) {
+ move_to_networkmap(d);
+ }
+ else {
+ edit_node(d, true);
+ }
+
})
.on("contextmenu", function (d) { show_menu("node", d); });
diff --git a/pandora_console/include/javascript/jquery.contextMenu.css b/pandora_console/include/javascript/jquery.contextMenu.css
index 3a844d4a7e..b0b04223bf 100644
--- a/pandora_console/include/javascript/jquery.contextMenu.css
+++ b/pandora_console/include/javascript/jquery.contextMenu.css
@@ -117,6 +117,7 @@
.context-menu-item.icon-set_parent { background-image: url(../../images/father.png); }
.context-menu-item.icon-add_node { background-image: url(../../images/add.png); }
.context-menu-item.icon-refresh_holding_area { background-image: url(../../images/refresh_holding_area.png); }
+.context-menu-item.icon-restart_map { background-image: url(../../images/reset.png); }
.context-menu-item.icon-interface_link_children { background-image: url(../../images/icono_link_hijo.png); }
.context-menu-item.icon-interface_link_parent { background-image: url(../../images/icono_link_padre.png); }
.context-menu-item.icon-interface_link_cancel { background-image: url(../../images/link_abortar.png); }
diff --git a/pandora_console/include/javascript/pandora_snmp_browser.js b/pandora_console/include/javascript/pandora_snmp_browser.js
index 12f2f62296..fd202ad4dc 100644
--- a/pandora_console/include/javascript/pandora_snmp_browser.js
+++ b/pandora_console/include/javascript/pandora_snmp_browser.js
@@ -29,25 +29,25 @@ function snmpBrowse () {
var ajax_url = $('#hidden-ajax_url').val();
// Prepare the AJAX call
- var params = [
- "target_ip=" + target_ip,
- "community=" + community,
- "starting_oid=" + starting_oid,
- "snmp_browser_version=" + snmp_version,
- "server_to_exec=" + server_to_exec,
- "snmp3_browser_auth_user=" + snmp3_auth_user,
- "snmp3_browser_security_level=" + snmp3_security_level,
- "snmp3_browser_auth_method=" + snmp3_auth_method,
- "snmp3_browser_auth_pass=" + snmp3_auth_pass,
- "snmp3_browser_privacy_method=" + snmp3_privacy_method,
- "snmp3_browser_privacy_pass=" + snmp3_privacy_pass,
- "action=" + "snmptree",
- "page=operation/snmpconsole/snmp_browser"
- ];
+
+ var params = {};
+ params["target_ip"] = target_ip;
+ params["community"] = community;
+ params["starting_oid"] = starting_oid;
+ params["snmp_browser_version"] = snmp_version;
+ params["server_to_exec"] = server_to_exec;
+ params["snmp3_browser_auth_user"] = snmp3_auth_user;
+ params["snmp3_browser_security_level"] = snmp3_security_level;
+ params["snmp3_browser_auth_method"] = snmp3_auth_method;
+ params["snmp3_browser_auth_pass"] = snmp3_auth_pass;
+ params["snmp3_browser_privacy_method"] = snmp3_privacy_method;
+ params["snmp3_browser_privacy_pass"] = snmp3_privacy_pass;
+ params["action"] = "snmptree";
+ params["page"] = "operation/snmpconsole/snmp_browser";
// Browse!
jQuery.ajax ({
- data: params.join ("&"),
+ data: params,
type: 'POST',
url: action= ajax_url,
async: true,
diff --git a/pandora_console/include/javascript/tree/TreeController.js b/pandora_console/include/javascript/tree/TreeController.js
index 271bd75f05..75acddc3f6 100644
--- a/pandora_console/include/javascript/tree/TreeController.js
+++ b/pandora_console/include/javascript/tree/TreeController.js
@@ -572,6 +572,12 @@ var TreeController = {
});
}
}
+ // Get hash and user.
+ var public_hash = $("#hidden-publi_dash_tree_view_hash" ).val();
+ if (typeof(public_hash) === 'undefined') public_hash = 0;
+ var public_user = $("#hidden-publi_dash_tree_view_id_user" ).val();
+ if (typeof(public_user) === 'undefined') public_user = 0;
+
if (typeof element.searchChildren != 'undefined' && element.searchChildren) {
$node
.removeClass("leaf-empty")
@@ -598,7 +604,9 @@ var TreeController = {
rootID: element.rootID,
serverID: element.serverID,
rootType: element.rootType,
- filter: controller.filter
+ filter: controller.filter,
+ hash: public_hash,
+ id_user: public_user
},
complete: function(xhr, textStatus) {
$node.removeClass("leaf-loading");
diff --git a/pandora_console/include/styles/install.css b/pandora_console/include/styles/install.css
index 59b1fb98cc..6c558fdcba 100644
--- a/pandora_console/include/styles/install.css
+++ b/pandora_console/include/styles/install.css
@@ -192,6 +192,7 @@ div.installation_step {
-o-transition-property: background-color, color;
-o-transition-duration: 1s;
color:#82b92e;
+ font-family: Sans, Arial, sans;
}
.btn_install_next:hover .btn_install_next_text {
transition-property: background-color, color;
diff --git a/pandora_console/include/styles/pandora.css b/pandora_console/include/styles/pandora.css
index fcf084085b..beb53d61d7 100644
--- a/pandora_console/include/styles/pandora.css
+++ b/pandora_console/include/styles/pandora.css
@@ -769,6 +769,12 @@ input.graph_min {
input.graph_min[disabled] {
background: #fefefe url(../../images/chart_curve.disabled.png) no-repeat center !important;
}
+input.bars_graph_min {
+ background: #fefefe url(../../images/icono-barras-arriba.png) no-repeat center !important;
+}
+input.bars_graph_min[disabled] {
+ background: #fefefe url(../../images/icono-barras-arriba.disabled.png) no-repeat center !important;
+}
input.percentile_min {
background: #fefefe url(../../images/chart_bar.png) no-repeat center !important;
}
@@ -787,6 +793,12 @@ input.auto_sla_graph_min {
input.auto_sla_graph_min[disabled] {
background: #fefefe url(../../images/auto_sla_graph.disabled.png) no-repeat center !important;
}
+input.donut_graph_min {
+ background: #fefefe url(../../images/icono-quesito.png) no-repeat center !important;
+}
+input.donut_graph_min[disabled] {
+ background: #fefefe url(../../images/icono-quesito.disabled.png) no-repeat center !important;
+}
input.binary_min {
background: #fefefe url(../../images/binary.png) no-repeat center !important;
}
@@ -2399,29 +2411,61 @@ span#plugin_description {
font-size: 14pt !important;
line-height: 14pt;
}
+.visual_font_size_18pt, .visual_font_size_18pt > em , .visual_font_size_18pt > strong, .visual_font_size_18pt > strong > span, .visual_font_size_18pt > span, .visual_font_size_18pt > strong > em, .visual_font_size_18pt > em > strong, .visual_font_size_18pt em span, .visual_font_size_18pt span em {
+ font-size: 18pt !important;
+ line-height: 18pt;
+}
+
.visual_font_size_24pt, .visual_font_size_24pt > em, .visual_font_size_24pt > strong, .visual_font_size_24pt > strong > span , .visual_font_size_24pt > span, .visual_font_size_24pt > strong > em, .visual_font_size_24pt > em > strong, .visual_font_size_24pt em span, .visual_font_size_24pt span em {
font-size: 24pt !important;
line-height: 24pt;
}
+.visual_font_size_28pt, .visual_font_size_28pt > em, .visual_font_size_28pt > strong, .visual_font_size_28pt > strong > span , .visual_font_size_28pt > span, .visual_font_size_28pt > strong > em, .visual_font_size_28pt > em > strong, .visual_font_size_28pt em span, .visual_font_size_28pt span em {
+ font-size: 28pt !important;
+ line-height: 28pt;
+}
.visual_font_size_36pt, .visual_font_size_36pt > em, .visual_font_size_36pt > strong, .visual_font_size_36pt > strong > span, .visual_font_size_36pt > span, .visual_font_size_36pt > strong > em, .visual_font_size_36pt > em > strong, .visual_font_size_36pt em span, .visual_font_size_36pt span em {
font-size: 36pt !important;
line-height: 36pt;
}
+.visual_font_size_48pt, .visual_font_size_48pt > em, .visual_font_size_48pt > strong, .visual_font_size_48pt > strong > span, .visual_font_size_48pt > span, .visual_font_size_48pt > strong > em, .visual_font_size_48pt > em > strong, .visual_font_size_48pt em span, .visual_font_size_48pt span em {
+ font-size: 48pt !important;
+ line-height: 48pt;
+}
+.visual_font_size_60pt, .visual_font_size_60pt > em, .visual_font_size_60pt > strong, .visual_font_size_60pt > strong > span, .visual_font_size_60pt > span, .visual_font_size_60pt > strong > em, .visual_font_size_60pt > em > strong, .visual_font_size_60pt em span, .visual_font_size_60pt span em {
+ font-size: 60pt !important;
+ line-height: 60pt;
+}
.visual_font_size_72pt, .visual_font_size_72pt > em, .visual_font_size_72pt > strong, .visual_font_size_72pt > strong > span, .visual_font_size_72pt > span, .visual_font_size_72pt > strong > em, .visual_font_size_72pt > em > strong, .visual_font_size_72pt em span, .visual_font_size_72pt span em {
font-size: 72pt !important;
line-height: 72pt;
}
+.visual_font_size_84pt, .visual_font_size_84pt > em, .visual_font_size_84pt > strong, .visual_font_size_84pt > strong > span, .visual_font_size_84pt > span, .visual_font_size_84pt > strong > em, .visual_font_size_84pt > em > strong, .visual_font_size_84pt em span, .visual_font_size_84pt span em {
+ font-size: 84pt !important;
+ line-height: 84pt;
+}
+
.visual_font_size_96pt, .visual_font_size_96pt > em, .visual_font_size_96pt > strong, .visual_font_size_96pt > strong > span, .visual_font_size_96pt > span, .visual_font_size_96pt > strong > em, .visual_font_size_96pt > em > strong, .visual_font_size_96pt em span, .visual_font_size_96pt span em {
font-size: 96pt !important;
line-height: 96pt;
}
+.visual_font_size_116pt, .visual_font_size_116pt > em, .visual_font_size_116pt > strong, .visual_font_size_116pt > strong > span, .visual_font_size_116pt > span, .visual_font_size_116pt > strong > em, .visual_font_size_116pt > em > strong, .visual_font_size_116pt em span, .visual_font_size_116pt span em {
+ font-size: 116pt !important;
+ line-height: 116pt;
+}
+
.visual_font_size_128pt, .visual_font_size_128pt > em, .visual_font_size_128pt > strong, .visual_font_size_128pt > strong > span, .visual_font_size_128pt > span, .visual_font_size_128pt > strong > em, .visual_font_size_128pt > em > strong, .visual_font_size_128pt em span, .visual_font_size_128pt span em {
font-size: 128pt !important;
line-height: 128pt;
}
+.visual_font_size_140pt, .visual_font_size_140pt > em, .visual_font_size_140pt > strong, .visual_font_size_140pt > strong > span, .visual_font_size_140pt > span, .visual_font_size_140pt > strong > em, .visual_font_size_140pt > em > strong, .visual_font_size_140pt em span, .visual_font_size_140pt span em {
+ font-size: 140pt !important;
+ line-height: 140pt;
+}
+
.visual_font_size_154pt, .visual_font_size_154pt > em, .visual_font_size_154pt > strong, .visual_font_size_154pt > strong > span, .visual_font_size_154pt > span, .visual_font_size_154pt > strong > em, .visual_font_size_154pt > em > strong, .visual_font_size_154pt em span, .visual_font_size_154pt span em {
font-size: 154pt !important;
line-height: 154pt;
diff --git a/pandora_console/include/styles/pandora_black.css b/pandora_console/include/styles/pandora_black.css
index 9aeb56aca9..b7e4cec6ca 100644
--- a/pandora_console/include/styles/pandora_black.css
+++ b/pandora_console/include/styles/pandora_black.css
@@ -2457,29 +2457,59 @@ span#plugin_description {
font-size: 14pt !important;
line-height: 14pt;
}
+.visual_font_size_18pt, .visual_font_size_18pt > em , .visual_font_size_18pt > strong, .visual_font_size_18pt > strong > span, .visual_font_size_18pt > span, .visual_font_size_18pt > strong > em, .visual_font_size_18pt > em > strong, .visual_font_size_18pt em span, .visual_font_size_18pt span em {
+ font-size: 18pt !important;
+ line-height: 18pt;
+}
.visual_font_size_24pt, .visual_font_size_24pt > em, .visual_font_size_24pt > strong, .visual_font_size_24pt > strong > span , .visual_font_size_24pt > span, .visual_font_size_24pt > strong > em, .visual_font_size_24pt > em > strong, .visual_font_size_24pt em span, .visual_font_size_24pt span em {
font-size: 24pt !important;
line-height: 24pt;
}
+.visual_font_size_28pt, .visual_font_size_28pt > em, .visual_font_size_28pt > strong, .visual_font_size_28pt > strong > span , .visual_font_size_28pt > span, .visual_font_size_28pt > strong > em, .visual_font_size_28pt > em > strong, .visual_font_size_28pt em span, .visual_font_size_28pt span em {
+ font-size: 28pt !important;
+ line-height: 28pt;
+}
.visual_font_size_36pt, .visual_font_size_36pt > em, .visual_font_size_36pt > strong, .visual_font_size_36pt > strong > span, .visual_font_size_36pt > span, .visual_font_size_36pt > strong > em, .visual_font_size_36pt > em > strong, .visual_font_size_36pt em span, .visual_font_size_36pt span em {
font-size: 36pt !important;
line-height: 36pt;
}
+.visual_font_size_48pt, .visual_font_size_48pt > em, .visual_font_size_48pt > strong, .visual_font_size_48pt > strong > span, .visual_font_size_48pt > span, .visual_font_size_48pt > strong > em, .visual_font_size_48pt > em > strong, .visual_font_size_48pt em span, .visual_font_size_48pt span em {
+ font-size: 48pt !important;
+ line-height: 48pt;
+}
+.visual_font_size_60pt, .visual_font_size_60pt > em, .visual_font_size_60pt > strong, .visual_font_size_60pt > strong > span, .visual_font_size_60pt > span, .visual_font_size_60pt > strong > em, .visual_font_size_60pt > em > strong, .visual_font_size_60pt em span, .visual_font_size_60pt span em {
+ font-size: 60pt !important;
+ line-height: 60pt;
+}
.visual_font_size_72pt, .visual_font_size_72pt > em, .visual_font_size_72pt > strong, .visual_font_size_72pt > strong > span, .visual_font_size_72pt > span, .visual_font_size_72pt > strong > em, .visual_font_size_72pt > em > strong, .visual_font_size_72pt em span, .visual_font_size_72pt span em {
font-size: 72pt !important;
line-height: 72pt;
}
+.visual_font_size_84pt, .visual_font_size_84pt > em, .visual_font_size_84pt > strong, .visual_font_size_84pt > strong > span, .visual_font_size_84pt > span, .visual_font_size_84pt > strong > em, .visual_font_size_84pt > em > strong, .visual_font_size_84pt em span, .visual_font_size_84pt span em {
+ font-size: 84pt !important;
+ line-height: 84pt;
+}
.visual_font_size_96pt, .visual_font_size_96pt > em, .visual_font_size_96pt > strong, .visual_font_size_96pt > strong > span, .visual_font_size_96pt > span, .visual_font_size_96pt > strong > em, .visual_font_size_96pt > em > strong, .visual_font_size_96pt em span, .visual_font_size_96pt span em {
font-size: 96pt !important;
line-height: 96pt;
}
+.visual_font_size_116pt, .visual_font_size_116pt > em, .visual_font_size_116pt > strong, .visual_font_size_116pt > strong > span, .visual_font_size_116pt > span, .visual_font_size_116pt > strong > em, .visual_font_size_116pt > em > strong, .visual_font_size_116pt em span, .visual_font_size_116pt span em {
+ font-size: 116pt !important;
+ line-height: 116pt;
+}
+
.visual_font_size_128pt, .visual_font_size_128pt > em, .visual_font_size_128pt > strong, .visual_font_size_128pt > strong > span, .visual_font_size_128pt > span, .visual_font_size_128pt > strong > em, .visual_font_size_128pt > em > strong, .visual_font_size_128pt em span, .visual_font_size_128pt span em {
font-size: 128pt !important;
line-height: 128pt;
}
+.visual_font_size_140pt, .visual_font_size_140pt > em, .visual_font_size_140pt > strong, .visual_font_size_140pt > strong > span, .visual_font_size_140pt > span, .visual_font_size_140pt > strong > em, .visual_font_size_140pt > em > strong, .visual_font_size_140pt em span, .visual_font_size_140pt span em {
+ font-size: 140pt !important;
+ line-height: 140pt;
+}
+
.visual_font_size_154pt, .visual_font_size_154pt > em, .visual_font_size_154pt > strong, .visual_font_size_154pt > strong > span, .visual_font_size_154pt > span, .visual_font_size_154pt > strong > em, .visual_font_size_154pt > em > strong, .visual_font_size_154pt em span, .visual_font_size_154pt span em {
font-size: 154pt !important;
line-height: 154pt;
@@ -2487,7 +2517,7 @@ span#plugin_description {
.visual_font_size_196pt, .visual_font_size_196pt > em, .visual_font_size_196pt > strong, .visual_font_size_196pt > strong > span, .visual_font_size_196pt > span, .visual_font_size_196pt > strong > em, .visual_font_size_196pt > em > strong, .visual_font_size_196pt em span, .visual_font_size_196pt span em {
font-size: 196pt !important;
- line-height: 196pt;
+ line-height: 196pt;
}
@@ -3441,10 +3471,10 @@ color:#82b92e;font-family:Nunito;font-size:10pt;position:relative;top:6px;
}
.rowPair:hover, .rowOdd:hover{
- background-color: #3f3f3f;
+ background-color: #6E6E6E;
}
.databox.data > tbody > tr:hover{
- background-color: #3f3f3f;
+ background-color: #6E6E6E;
}
.checkselected{
background-color: #eee;
@@ -3516,11 +3546,14 @@ div.icon_message_alert img{
}
div.content_message_alert{
-
width: 75%;
float: right;
}
+div.content_message_alert *{
+ color: black;
+}
+
div.text_message_alert{
width: 100%;
margin-top: 10px;
@@ -3807,9 +3840,17 @@ div.img_banner_login img{
}
}
-.new_task p, .new_task h3, .new_task h2, .new_task a{
+.new_task p, .new_task h3, .new_task h2, .new_task a, .new_task strong{
color: #222222;
}
.item p {
color: #222222;
-}
\ No newline at end of file
+}
+
+.item span {
+ color: #222222;
+}
+
+.widget_config_advice, .widget_config_advice *{
+ color: black;
+}
diff --git a/pandora_console/include/styles/pandora_green_old.css b/pandora_console/include/styles/pandora_green_old.css
index e983e6047d..a99a9a275d 100644
--- a/pandora_console/include/styles/pandora_green_old.css
+++ b/pandora_console/include/styles/pandora_green_old.css
@@ -2435,53 +2435,97 @@ span#plugin_description {
#tinymce {
text-align: left;
}
+
.visual_font_size_4pt, .visual_font_size_4pt > em, .visual_font_size_4pt > strong, .visual_font_size_4pt > strong > span, .visual_font_size_4pt > span, .visual_font_size_4pt > strong > em, .visual_font_size_4pt > em > strong, .visual_font_size_4pt em span, .visual_font_size_4pt span em {
font-size: 4pt !important;
line-height: 4pt;
}
+
.visual_font_size_6pt, .visual_font_size_6pt > em, .visual_font_size_6pt > strong, .visual_font_size_6pt > strong > span, .visual_font_size_6pt > span, .visual_font_size_6pt > strong > em, .visual_font_size_6pt > em > strong, .visual_font_size_6pt em span, .visual_font_size_6pt span em {
font-size: 6pt !important;
line-height: 6pt;
}
+
.visual_font_size_8pt, .visual_font_size_8pt > em, .visual_font_size_8pt > strong, .visual_font_size_8pt > strong > span , .visual_font_size_8pt > span, .visual_font_size_8pt > strong > em, .visual_font_size_8pt > em > strong, .visual_font_size_8pt em span, .visual_font_size_8pt span em {
font-size: 8pt !important;
line-height: 8pt;
}
+
.visual_font_size_10pt, .visual_font_size_10pt > em , .visual_font_size_10pt > strong, .visual_font_size_10pt > strong > em, .visual_font_size_10pt > em > strong, .visual_font_size_10pt em span, .visual_font_size_10pt span em {
font-size: 10pt !important;
line-height: 10pt;
}
+
.visual_font_size_12pt, .visual_font_size_12pt > em , .visual_font_size_12pt > strong, .visual_font_size_12pt > strong > em, .visual_font_size_12pt > em > strong, .visual_font_size_12pt em span, .visual_font_size_12pt span em {
font-size: 12pt !important;
line-height: 12pt;
}
+
.visual_font_size_14pt, .visual_font_size_14pt > em , .visual_font_size_14pt > strong, .visual_font_size_14pt > strong > span, .visual_font_size_14pt > span, .visual_font_size_14pt > strong > em, .visual_font_size_14pt > em > strong, .visual_font_size_14pt em span, .visual_font_size_14pt span em {
font-size: 14pt !important;
line-height: 14pt;
}
+
+.visual_font_size_18pt, .visual_font_size_18pt > em , .visual_font_size_18pt > strong, .visual_font_size_18pt > strong > span, .visual_font_size_18pt > span, .visual_font_size_18pt > strong > em, .visual_font_size_18pt > em > strong, .visual_font_size_18pt em span, .visual_font_size_18pt span em {
+ font-size: 18pt !important;
+ line-height: 18pt;
+}
+
.visual_font_size_24pt, .visual_font_size_24pt > em, .visual_font_size_24pt > strong, .visual_font_size_24pt > strong > span , .visual_font_size_24pt > span, .visual_font_size_24pt > strong > em, .visual_font_size_24pt > em > strong, .visual_font_size_24pt em span, .visual_font_size_24pt span em {
font-size: 24pt !important;
line-height: 24pt;
}
+
+.visual_font_size_28pt, .visual_font_size_28pt > em, .visual_font_size_28pt > strong, .visual_font_size_28pt > strong > span , .visual_font_size_28pt > span, .visual_font_size_28pt > strong > em, .visual_font_size_28pt > em > strong, .visual_font_size_28pt em span, .visual_font_size_28pt span em {
+ font-size: 28pt !important;
+ line-height: 28pt;
+}
+
.visual_font_size_36pt, .visual_font_size_36pt > em, .visual_font_size_36pt > strong, .visual_font_size_36pt > strong > span, .visual_font_size_36pt > span, .visual_font_size_36pt > strong > em, .visual_font_size_36pt > em > strong, .visual_font_size_36pt em span, .visual_font_size_36pt span em {
font-size: 36pt !important;
line-height: 36pt;
}
+
+.visual_font_size_48pt, .visual_font_size_48pt > em, .visual_font_size_48pt > strong, .visual_font_size_48pt > strong > span, .visual_font_size_48pt > span, .visual_font_size_48pt > strong > em, .visual_font_size_48pt > em > strong, .visual_font_size_48pt em span, .visual_font_size_48pt span em {
+ font-size: 48pt !important;
+ line-height: 48pt;
+}
+
+.visual_font_size_60pt, .visual_font_size_60pt > em, .visual_font_size_60pt > strong, .visual_font_size_60pt > strong > span, .visual_font_size_60pt > span, .visual_font_size_60pt > strong > em, .visual_font_size_60pt > em > strong, .visual_font_size_60pt em span, .visual_font_size_60pt span em {
+ font-size: 60pt !important;
+ line-height: 60pt;
+}
+
.visual_font_size_72pt, .visual_font_size_72pt > em, .visual_font_size_72pt > strong, .visual_font_size_72pt > strong > span, .visual_font_size_72pt > span, .visual_font_size_72pt > strong > em, .visual_font_size_72pt > em > strong, .visual_font_size_72pt em span, .visual_font_size_72pt span em {
font-size: 72pt !important;
line-height: 72pt;
}
+.visual_font_size_84pt, .visual_font_size_84pt > em, .visual_font_size_84pt > strong, .visual_font_size_84pt > strong > span, .visual_font_size_84pt > span, .visual_font_size_84pt > strong > em, .visual_font_size_84pt > em > strong, .visual_font_size_84pt em span, .visual_font_size_84pt span em {
+ font-size: 84pt !important;
+ line-height: 84pt;
+}
+
.visual_font_size_96pt, .visual_font_size_96pt > em, .visual_font_size_96pt > strong, .visual_font_size_96pt > strong > span, .visual_font_size_96pt > span, .visual_font_size_96pt > strong > em, .visual_font_size_96pt > em > strong, .visual_font_size_96pt em span, .visual_font_size_96pt span em {
font-size: 96pt !important;
line-height: 96pt;
}
+.visual_font_size_116pt, .visual_font_size_116pt > em, .visual_font_size_116pt > strong, .visual_font_size_116pt > strong > span, .visual_font_size_116pt > span, .visual_font_size_116pt > strong > em, .visual_font_size_116pt > em > strong, .visual_font_size_116pt em span, .visual_font_size_116pt span em {
+ font-size: 116pt !important;
+ line-height: 116pt;
+}
+
.visual_font_size_128pt, .visual_font_size_128pt > em, .visual_font_size_128pt > strong, .visual_font_size_128pt > strong > span, .visual_font_size_128pt > span, .visual_font_size_128pt > strong > em, .visual_font_size_128pt > em > strong, .visual_font_size_128pt em span, .visual_font_size_128pt span em {
font-size: 128pt !important;
line-height: 128pt;
}
+.visual_font_size_140pt, .visual_font_size_140pt > em, .visual_font_size_140pt > strong, .visual_font_size_140pt > strong > span, .visual_font_size_140pt > span, .visual_font_size_140pt > strong > em, .visual_font_size_140pt > em > strong, .visual_font_size_140pt em span, .visual_font_size_140pt span em {
+ font-size: 140pt !important;
+ line-height: 140pt;
+}
+
.visual_font_size_154pt, .visual_font_size_154pt > em, .visual_font_size_154pt > strong, .visual_font_size_154pt > strong > span, .visual_font_size_154pt > span, .visual_font_size_154pt > strong > em, .visual_font_size_154pt > em > strong, .visual_font_size_154pt em span, .visual_font_size_154pt span em {
font-size: 154pt !important;
line-height: 154pt;
diff --git a/pandora_console/install.php b/pandora_console/install.php
index b97816035e..b4ccf7cadf 100755
--- a/pandora_console/install.php
+++ b/pandora_console/install.php
@@ -70,8 +70,8 @@
';
echo __('Search') . ' ';
-html_print_input_text ("search", $search, '', 12);
+html_print_input_text ("search", $search, '', 15);
echo ' ';
@@ -222,6 +223,11 @@ html_print_select ($fields, "status", $status, 'this.form.submit()', __('All'),
echo ' ';
+echo __('Search in custom fields') . ' ';
+html_print_input_text ("search_custom", $search_custom, '', 15);
+
+echo ' ';
+
html_print_submit_button (__('Search'), "srcbutton", '',
array ("class" => "sub search"));
@@ -384,7 +390,6 @@ switch ($sortField) {
$search_sql = '';
if ($search != "") {
- //$search_sql = " AND ( nombre " . $order_collation . " LIKE '%$search%' OR direccion LIKE '%$search%' OR comentarios LIKE '%$search%') ";
$sql = "SELECT DISTINCT taddress_agent.id_agent FROM taddress
INNER JOIN taddress_agent ON
taddress.id_a = taddress_agent.id_a
@@ -409,6 +414,14 @@ if ($search != "") {
}
}
+
+if(!empty($search_custom)){
+ $search_sql_custom = " AND EXISTS (SELECT * FROM tagent_custom_data
+ WHERE id_agent = id_agente AND description LIKE '%$search_custom%')";
+} else {
+ $search_sql_custom = "";
+}
+
// Show only selected groups
if ($group_id > 0) {
$groups = array($group_id);
@@ -464,6 +477,7 @@ else {
'disabled' => 0,
'id_grupo' => $groups,
'search' => $search_sql,
+ 'search_custom' => $search_sql_custom,
'status' => $status),
array ('COUNT(*) as total'), $access, false);
$total_agents = isset ($total_agents[0]['total']) ?
@@ -474,6 +488,7 @@ else {
'id_grupo' => $groups,
'disabled' => 0,
'status' => $status,
+ 'search_custom' => $search_sql_custom,
'search' => $search_sql,
'offset' => (int) get_parameter ('offset'),
'limit' => (int) $config['block_size']),
diff --git a/pandora_console/operation/agentes/estado_generalagente.php b/pandora_console/operation/agentes/estado_generalagente.php
index 78f3dd06a4..ae7bcef432 100755
--- a/pandora_console/operation/agentes/estado_generalagente.php
+++ b/pandora_console/operation/agentes/estado_generalagente.php
@@ -625,7 +625,7 @@ $data[0][0] .=
__('Events (24h)') .
' ' .
' ' .
- graph_graphic_agentevents ($id_agente, 450, 15, SECONDS_1DAY, '', true, true) .
+ graph_graphic_agentevents ($id_agente, 450, 40, SECONDS_1DAY, '', true, true) .
' ' .
'';
diff --git a/pandora_console/operation/agentes/estado_monitores.php b/pandora_console/operation/agentes/estado_monitores.php
index f5c870dc83..3fceedda4e 100755
--- a/pandora_console/operation/agentes/estado_monitores.php
+++ b/pandora_console/operation/agentes/estado_monitores.php
@@ -364,6 +364,19 @@ ui_require_jquery_file("ui.datepicker-" . get_user_language(), "include/javascri
extra_parameters = '&selection_mode=' + selection_mode + '&date_from=' + date_from + '&date_to=' + date_to + '&time_from=' + time_from + '&time_to=' + time_to;
}
+
+ // Get the free text in both options
+ var freesearch = $('#text-freesearch').val();
+ if (freesearch != null && freesearch !== '') {
+ var free_checkbox = $('input[name=free_checkbox]:checked').val();
+ extra_parameters += '&freesearch=' + freesearch;
+ if (free_checkbox == 1) {
+ extra_parameters += '&free_checkbox=1';
+ } else {
+ extra_parameters += '&free_checkbox=0';
+ }
+ }
+
title = ;
$.ajax({
type: "POST",
diff --git a/pandora_console/operation/agentes/graphs.php b/pandora_console/operation/agentes/graphs.php
index ff1d7bf9e3..e33d499fe8 100644
--- a/pandora_console/operation/agentes/graphs.php
+++ b/pandora_console/operation/agentes/graphs.php
@@ -38,8 +38,8 @@ $start_date = get_parameter ("start_date", date("Y-m-d"));
$draw_events = get_parameter ("draw_events", 0);
$modules = get_parameter('modules', array());
$filter = get_parameter('filter', 0);
-$combined = (bool)get_parameter('combined', 1);
-
+$combined = get_parameter('combined', 1);
+$option_type = get_parameter('option_type', 0);
//----------------------------------------------------------------------
// Get modules of agent sorted as:
@@ -159,7 +159,6 @@ $table->data[0][1] = html_print_select($list_modules, 'modules[]',
$table->rowspan[2][0] = 7;
$table->data[2][0] = "";
-
$table->data[2][1] = __('Begin date');
$table->data[2][2] = html_print_input_text ("start_date", substr ($start_date, 0, 10),'', 10, 40, true);
$table->data[2][2] .= html_print_image ("images/calendar_view_day.png", true, array ("onclick" => "scwShow(scwID('text-start_date'),this);"));
@@ -174,12 +173,17 @@ $table->data[5][2] = __('Show alerts') .
ui_print_help_tip(__('the combined graph does not show the alerts into this graph'), true);
$table->data[5][3] = html_print_checkbox ("draw_alerts", 1, (bool) $draw_alerts, true);
$table->data[6][2] = __('Show as one combined graph');
-$table->data[6][3] =
- html_print_radio_button('combined', 1, __('one combined graph'),
- $combined, true);
-$table->data[6][3] .=
- html_print_radio_button('combined', 0, __('several graphs for each module'),
- $combined, true);
+$graph_option_one_or_several = array(0 => __('several graphs for each module'), 1 => __('One combined graph'));
+$table->data[6][3] = html_print_select($graph_option_one_or_several, 'combined', $combined, '', '', 1, true);
+
+$table->data[7][2] = __('Chart type');
+if ($combined == 1) {
+ $graph_option_type = array(0 => __('Area'), 1 => __('Area stack'), 2 => __('Line'), 3 => __('Line stack'));
+}
+else {
+ $graph_option_type = array(0 => __('Area'), 2 => __('Line'));
+}
+$table->data[7][3] = html_print_select($graph_option_type, 'option_type', $option_type, '', '', 1, true);
$htmlForm = ' ";
// Load graphs
$(document).ready(function() {
+ $('#combined').change(function () {
+ if ($('#combined').val() == 1) {
+ $('#option_type').empty();
+ $('#option_type').append($('', {
+ value: 0,
+ text: ""
+ }));
+ $('#option_type').append($(' ', {
+ value: 1,
+ text: ""
+ }));
+ $('#option_type').append($(' ', {
+ value: 2,
+ text: ""
+ }));
+ $('#option_type').append($(' ', {
+ value: 3,
+ text: ""
+ }));
+ }
+ else {
+ $('#option_type').empty();
+ $('#option_type').append($(' ', {
+ value: 0,
+ text: ""
+ }));
+ $('#option_type').append($(' ', {
+ value: 2,
+ text: ""
+ }));
+ }
+ });
+
var getModulesPHP = function () {
return ;
}
@@ -353,7 +390,7 @@ echo " ";
});
}
- var requestSparseGraph = function (moduleId, period, showEvents, width, height, title, showAlerts, avgOnly, date, unit) {
+ var requestSparseGraph = function (moduleId, period, showEvents, width, height, title, showAlerts, avgOnly, date, unit, type_g) {
return requestGraph('sparse', {
page: 'include/ajax/graph.ajax',
print_sparse_graph: 1,
@@ -366,7 +403,8 @@ echo "
";
show_alerts: showAlerts,
avg_only: avgOnly,
date: date,
- unit: unit
+ unit: unit,
+ type_g: type_g
});
}
@@ -380,15 +418,23 @@ echo "
";
var $container = $(element);
var $errorMessage = $('div#graph-error-message');
var period = $container.data('period');
- var conf_stacked = '';
+ var conf_stacked = parseInt($("#option_type").val());
+
switch (conf_stacked) {
- case 'area':
+ case 0:
var stacked = 0;
break;
- case 'line':
+ case 1:
+ var stacked = 1;
+ break;
+ case 2:
var stacked = 2;
break;
+ case 3:
+ var stacked = 3;
+ break;
}
+
var date = $container.data('date');
var height = $container.data('height');
@@ -426,6 +472,16 @@ echo "
";
var unit = $container.data('unit');
var date = $container.data('date');
var height = $container.data('height');
+ var conf_stacked = parseInt($("#option_type").val());
+
+ switch (conf_stacked) {
+ case 0:
+ var type_g = 'area';
+ break;
+ case 2:
+ var type_g = 'line';
+ break;
+ }
var width = $container.width() - 20;
@@ -435,8 +491,8 @@ echo "
";
var handleError = function (xhr, textStatus, errorThrown) {
$container.html($errorMessage.html());
}
-
- requestSparseGraph(moduleId, period, showEvents, width, height, title, showAlerts, avgOnly, date, unit)
+
+ requestSparseGraph(moduleId, period, showEvents, width, height, title, showAlerts, avgOnly, date, unit, type_g)
.done(handleSuccess)
.fail(handleError);
}
diff --git a/pandora_console/operation/agentes/networkmap.dinamic.php b/pandora_console/operation/agentes/networkmap.dinamic.php
index c2fdf605a2..11e4874b3a 100644
--- a/pandora_console/operation/agentes/networkmap.dinamic.php
+++ b/pandora_console/operation/agentes/networkmap.dinamic.php
@@ -18,7 +18,13 @@
global $config;
check_login ();
-$id = get_parameter('id_networkmap', true);
+if (_id_ != "_id_") {
+ $id = _id_;
+}
+else {
+ $id = get_parameter('id_networkmap', true);
+}
+
$activeTab = get_parameter('activeTab', true);
if (enterprise_installed()) {
@@ -31,6 +37,11 @@ if (enterprise_installed()) {
}
}
+if (_activeTab_ != "_activeTab_") {
+ $activeTab = _activeTab_;
+ $tab = $activeTab;
+}
+
// Networkmap id required
if (!isset($id)) {
db_pandora_audit("ACL Violation",
@@ -107,6 +118,11 @@ ui_print_page_header(io_safe_output($networkmap['name']),
global $width;
global $height;
+if (_id_ != "_id_") {
+ $width = array();
+ $height = array();
+}
+
if (empty($width)) {
$width = 600;
}
@@ -120,8 +136,9 @@ if ($activeTab == "radial_dynamic") {
echo "
";
$filter = array();
- if (!empty($group))
- $filter['group'] = $group;
+ if ($networkmap['source'] == 0) {
+ $filter['group'] = $networkmap['source_data'];
+ }
if (!empty($module_group))
$filter['module_group'] = $module_group;
diff --git a/pandora_console/operation/agentes/pandora_networkmap.editor.php b/pandora_console/operation/agentes/pandora_networkmap.editor.php
index eea978db77..6549c63cb3 100644
--- a/pandora_console/operation/agentes/pandora_networkmap.editor.php
+++ b/pandora_console/operation/agentes/pandora_networkmap.editor.php
@@ -38,6 +38,13 @@ if ($new_networkmap) {
$source = 'group';
$ip_mask = '';
$dont_show_subgroups = false;
+ $offset_x = "";
+ $offset_y = "";
+ $scale_z = 0.5;
+ $node_sep = 0.25;
+ $rank_sep = 1.0;
+ $mindist = 1.0;
+ $kval = 0.3;
}
$disabled_generation_method_select = false;
@@ -75,6 +82,40 @@ if ($edit_networkmap) {
$description = $values['description'];
$filter = json_decode($values['filter'], true);
+
+ $offset_x = $filter['x_offs'];
+ $offset_y = $filter['y_offs'];
+ $scale_z = $filter['z_dash'];
+
+ if (isset($filter['node_sep'])) {
+ $node_sep = $filter['node_sep'];
+ }
+ else {
+ $node_sep = 0.25;
+ }
+ if (isset($filter['rank_sep'])) {
+ $rank_sep = $filter['rank_sep'];
+ }
+ else {
+ if ($values['generation_method'] == "twopi") {
+ $rank_sep = 1.0;
+ }
+ else {
+ $rank_sep = 0.5;
+ }
+ }
+ if (isset($filter['mindist'])) {
+ $mindist = $filter['mindist'];
+ }
+ else {
+ $mindist = 1.0;
+ }
+ if (isset($filter['kval'])) {
+ $kval = $filter['kval'];
+ }
+ else {
+ $kval = 0.3;
+ }
$node_radius = $filter['node_radius'];
@@ -190,6 +231,17 @@ else {
$table->data[3][0] = __('Description');
$table->data[3][1] = html_print_textarea ('description', 7, 25, $description, '', true);
+
+ $table->data[4][0] = __('Position X');
+ $table->data[4][1] = html_print_input_text ('pos_x', $offset_x, '', 2, 10,true);
+ $table->data[5][0] = __('Position Y');
+ $table->data[5][1] = html_print_input_text ('pos_y', $offset_y, '', 2, 10,true);
+
+ $table->data[6][0] = __('Zoom scale');
+ if ($scale_z == "") {
+ $scale_z = 0.5;
+ }
+ $table->data[6][1] = html_print_input_text ('scale_z', $scale_z, '', 2, 10,true) . ui_print_help_tip (__('Introduce zoom level. 1 = Highest resolution. Figures may include decimals'), true);
$table->data['source'][0] = __('Source');
$table->data['source'][1] =
@@ -222,11 +274,23 @@ else {
'radial_dinamic' => 'radial dinamic'
);
- $table->data[4][0] = __('Method generation networkmap');
- $table->data[4][1] = html_print_select($methods, 'method', $method,
+ $table->data[7][0] = __('Method generation networkmap');
+ $table->data[7][1] = html_print_select($methods, 'method', $method,
'', '', 'twopi', true, false, true, '',
$disabled_generation_method_select);
+
+ $table->data['nodesep'][0] = __('Node separation');
+ $table->data['nodesep'][1] = html_print_input_text ('node_sep', $node_sep, '', 5, 10,true, $disabled_source) . ui_print_help_tip (__('Separation between nodes. By default 0.25'), true);
+ $table->data['ranksep'][0] = __('Rank separation');
+ $table->data['ranksep'][1] = html_print_input_text ('rank_sep', $rank_sep, '', 5, 10,true, $disabled_source) . ui_print_help_tip (__('Only flat and radial. Separation between arrows. By default 0.5 in flat and 1.0 in radial'), true);
+
+ $table->data['mindist'][0] = __('Min nodes dist');
+ $table->data['mindist'][1] = html_print_input_text ('mindist', $mindist, '', 5, 10,true, $disabled_source) . ui_print_help_tip (__('Only circular. Minimum separation between all nodes. By default 1.0'), true);
+
+ $table->data['kval'][0] = __('Default ideal node separation');
+ $table->data['kval'][1] = html_print_input_text ('kval', $kval, '', 5, 10,true, $disabled_source) . ui_print_help_tip (__('Only fdp. Default ideal node separation in the layout. By default 0.3'), true);
+
echo '";
echo "
";
+
+ if (enterprise_installed()) {
+ echo "
";
+ echo '";
+ echo "
";
+ }
}
break;
diff --git a/pandora_console/operation/agentes/pandora_networkmap.view.php b/pandora_console/operation/agentes/pandora_networkmap.view.php
index 5c5d2969c4..d2a7830f83 100644
--- a/pandora_console/operation/agentes/pandora_networkmap.view.php
+++ b/pandora_console/operation/agentes/pandora_networkmap.view.php
@@ -13,13 +13,29 @@
// Load global variables
global $config;
-// Check user credentials
-check_login();
-
require_once ('include/functions_pandora_networkmap.php');
enterprise_include_once('include/functions_policies.php');
+enterprise_include_once('include/functions_dashboard.php');
require_once ('include/functions_modules.php');
+$public_hash = get_parameter('hash', false);
+
+// Try to authenticate by hash on public dashboards
+if ($public_hash === false) {
+ // Login check
+ check_login();
+} else {
+ $validate_hash = enterprise_hook(
+ 'dasboard_validate_public_hash',
+ array($public_hash, get_parameter('networkmap_id'), 'network_map')
+ );
+ if ($validate_hash === false || $validate_hash === ENTERPRISE_NOT_HOOK) {
+ db_pandora_audit("Invalid public hash", "Trying to access report builder");
+ require ("general/noaccess.php");
+ exit;
+ }
+}
+
//--------------INIT AJAX-----------------------------------------------
if (is_ajax ()) {
$update_refresh_state = (bool)get_parameter('update_refresh_state',false);
@@ -72,7 +88,7 @@ if (is_ajax ()) {
if ($update_fictional_point) {
$id_node = (int)get_parameter('id_node', 0);
- $name = io_safe_output(get_parameter('name', ''));
+ $name = get_parameter('name', '');
$shape = get_parameter('shape', 0);
$radious = (int)get_parameter('radious', 20);
$color = get_parameter('color', 0);
@@ -123,7 +139,7 @@ if (is_ajax ()) {
$id = (int)get_parameter('id', 0);
$x = (int)get_parameter('x', 0);
$y = (int)get_parameter('y', 0);
- $id_agents = io_safe_output(get_parameter('id_agents', ''));
+ $id_agents = get_parameter('id_agents', '');
$id_agents = json_decode($id_agents, true);
if ($id_agents === null)
@@ -426,7 +442,7 @@ if (is_ajax ()) {
if ($get_agent_pos_search) {
$id = (int)get_parameter('id', 0);
- $name = io_safe_output((string)get_parameter('name', 0));
+ $name = (string)get_parameter('name');
$return = array();
$return['correct'] = true;
@@ -447,7 +463,7 @@ if (is_ajax ()) {
$id = (int)get_parameter('id', 0);
/* q is what autocomplete plugin gives */
- $string = io_safe_output((string) get_parameter ('q'));
+ $string = (string) get_parameter('q');
$agents = db_get_all_rows_filter('titem',
array('id_map' => $id,
@@ -459,7 +475,7 @@ if (is_ajax ()) {
$data = array();
foreach ($agents as $agent) {
$style = json_decode($agent['style'], true);
- $data[] = array('name' => io_safe_output($style['label']));
+ $data[] = array('name' => $style['label']);
}
echo json_encode($data);
@@ -677,10 +693,16 @@ if (is_ajax ()) {
}
}
//--------------END AJAX------------------------------------------------
-$id = (int) get_parameter('id_networkmap', 0);
+if (_id_ != "_id_") {
+ $id = _id_;
+}
+else {
+ $id = (int) get_parameter('id_networkmap', 0);
+}
+
$dash_mode = 0;
$map_dash_details = array();
-
+$networkmap = db_get_row('tmap', 'id', $id);
if (enterprise_installed()) {
include_once("enterprise/dashboard/widgets/network_map.php");
if ($id_networkmap) {
@@ -692,11 +714,32 @@ if (enterprise_installed()) {
$map_dash_details['x_offs'] = $x_offs;
$map_dash_details['y_offs'] = $y_offs;
$map_dash_details['z_dash'] = $z_dash;
+
+ $networkmap = db_get_row('tmap', 'id', $id);
+ }
+ else {
+ $networkmap_filter = json_decode($networkmap['filter'], true);
+ if ($networkmap_filter['x_offs'] != null) {
+ $map_dash_details['x_offs'] = $networkmap_filter['x_offs'];
+ }
+ else {
+ $map_dash_details['x_offs'] = 0;
+ }
+ if ($networkmap_filter['y_offs'] != null) {
+ $map_dash_details['y_offs'] = $networkmap_filter['y_offs'];
+ }
+ else {
+ $map_dash_details['y_offs'] = 0;
+ }
+ if ($networkmap_filter['z_dash'] != null) {
+ $map_dash_details['z_dash'] = $networkmap_filter['z_dash'];
+ }
+ else {
+ $map_dash_details['z_dash'] = 0;
+ }
}
}
-$networkmap = db_get_row('tmap', 'id', $id);
-
if ($networkmap === false) {
ui_print_page_header(__('Networkmap'),
"images/bricks.png", false, "network_map_enterprise", false);
@@ -750,7 +793,7 @@ else {
}
if (!$dash_mode) {
- ui_print_page_header(io_safe_output($networkmap['name']),
+ ui_print_page_header($networkmap['name'],
"images/bricks.png", false, "network_map_enterprise",
false, $buttons, false, '', $config['item_title_size_text']);
}
diff --git a/pandora_console/operation/agentes/status_monitor.php b/pandora_console/operation/agentes/status_monitor.php
index 27baeced96..480dc6b354 100644
--- a/pandora_console/operation/agentes/status_monitor.php
+++ b/pandora_console/operation/agentes/status_monitor.php
@@ -365,6 +365,9 @@ else {
$prediction_available = db_get_sql ("SELECT count(*)
FROM tserver
WHERE server_type = 5"); //POSTGRESQL AND ORACLE COMPATIBLE
+ $wux_available = db_get_sql ("SELECT count(*)
+ FROM tserver
+ WHERE server_type = 17"); //POSTGRESQL AND ORACLE COMPATIBLE
// Development mode to use all servers
if ($develop_bypass) {
@@ -386,6 +389,9 @@ else {
$typemodules[5] = __('Prediction server module');
if (enterprise_installed()) {
$typemodules[7] = __('Web server module');
+ if ($wux_available) {
+ $typemodules[8] = __('Wux server module');
+ }
}
@@ -443,6 +449,11 @@ else {
FROM ttipo_modulo
WHERE categoria = 0');
break;
+ case 8:
+ $sql = sprintf ('SELECT id_tipo, descripcion
+ FROM ttipo_modulo
+ WHERE nombre = \'web_analysis\'');
+ break;
case '':
$sql = sprintf ('SELECT id_tipo, descripcion
FROM ttipo_modulo');
@@ -516,7 +527,7 @@ foreach ($custom_fields as $custom_field) {
}
-$filters = '
';
@@ -787,8 +784,6 @@ elseif ($group_rep == 2) {
$history);
}
-
-
// Active filter tag view call (only enterprise version)
// It is required to pass some references to enterprise function
// to translate the active filters
@@ -803,87 +798,6 @@ enterprise_hook('print_event_tags_active_filters',
)
);
-if (!empty($result)) {
- if ($group_rep == 0) {
- $sql = "SELECT COUNT(id_evento)
- FROM $event_table
- WHERE 1=1 " . $sql_post;
- }
- elseif ($group_rep == 1) {
- switch ($config["dbtype"]) {
- case "mysql":
- case "postgresql":
- $sql = "SELECT COUNT(1)
- FROM (SELECT 1
- FROM $event_table
- WHERE 1=1 " . $sql_post . "
- GROUP BY evento, id_agentmodule) t";
- break;
- case "oracle":
- $sql = "SELECT COUNT(1)
- FROM (SELECT 1
- FROM $event_table
- WHERE 1=1 " . $sql_post . "
- GROUP BY to_char(evento), id_agentmodule) t";
- break;
- }
- }
- elseif ($group_rep == 2) {
-
- }
- $limit = (int) db_get_sql ($sql);
-
- if ($group_rep == 0) {
- switch ($config["dbtype"]) {
- case "mysql":
- $sql = "SELECT *, 1 event_rep
- FROM $event_table
- WHERE 1=1 " . $sql_post . "
- ORDER BY utimestamp DESC LIMIT 0,".$limit;
- break;
- case "postgresql":
- $sql = "SELECT *, 1 event_rep
- FROM $event_table
- WHERE 1=1 " . $sql_post . "
- ORDER BY utimestamp DESC LIMIT ".$limit." OFFSET 0";
- break;
- case "oracle":
- $set = array();
- $set['limit'] = $pagination;
- $set['offset'] = $offset;
- $sql = "SELECT $event_table.*, 1 event_rep
- FROM $event_table
- WHERE 1=1 " . $sql_post . "
- ORDER BY utimestamp DESC";
- $sql = oracle_recode_query ($sql, $set);
- break;
- }
-
- //Extract the events by filter (or not) from db
- $results_graph = db_get_all_rows_sql ($sql);
- }
- elseif ($group_rep == 1) {
- $results_graph = events_get_events_grouped($sql_post,
- 0,
- $limit,
- $meta,
- $history);
- }
- elseif ($group_rep == 2) {
-
- }
-
- if (($group_rep == 1) OR ($group_rep == 0)) {
- $graph = '
' .
- grafico_eventos_agente(350, 185,
- $results_graph, $meta, $history, $tags_acls_condition,$limit) .
- '
';
- html_print_div(array('id' => 'events_graph',
- 'hidden' => true, 'content' => $graph));
- }
-}
-
-
if (!empty($result)) {
//~ Checking the event tags exactly. The event query filters approximated tags to keep events
//~ with several tags
@@ -986,11 +900,6 @@ $(document).ready( function() {
$("#text-date_from, #text-date_to").datepicker({dateFormat: ""});
- // If the events are not charged, dont show graphs link
- if ($('#events_graph').val() == undefined) {
- $('#events_graph_link').hide();
- }
-
// Don't collapse filter if update button has been pushed
if ($("#hidden-open_filter").val() == 'true') {
$("#event_control").toggle();
@@ -1658,23 +1567,6 @@ function reorder_tags_inputs() {
}
}
-// Show the modal window of an module
-function show_events_graph_dialog() {
- $("#events_graph").hide ()
- .dialog ({
- resizable: true,
- draggable: true,
- title: '',
- modal: true,
- overlay: {
- opacity: 0.5,
- background: "black"
- },
- width: 450,
- height: 380
- })
- .show ();
-}
/* ]]> */
//function datetime
diff --git a/pandora_console/operation/menu.php b/pandora_console/operation/menu.php
index 6c27ce428d..b7c57882a8 100644
--- a/pandora_console/operation/menu.php
+++ b/pandora_console/operation/menu.php
@@ -59,6 +59,8 @@ if (check_acl ($config['id_user'], 0, "AR")) {
$sub2["operation/agentes/status_monitor"]["text"] = __('Monitor detail');
$sub2["operation/agentes/status_monitor"]["refr"] = 0;
+ enterprise_hook ('tag_view_submenu');
+
$sub2["operation/agentes/alerts_status"]["text"] = __('Alert detail');
$sub2["operation/agentes/alerts_status"]["refr"] = 0;
diff --git a/pandora_console/operation/snmpconsole/snmp_browser.php b/pandora_console/operation/snmpconsole/snmp_browser.php
index 0a8204208e..3f005cf063 100644
--- a/pandora_console/operation/snmpconsole/snmp_browser.php
+++ b/pandora_console/operation/snmpconsole/snmp_browser.php
@@ -28,12 +28,12 @@ if (is_ajax()) {
$community = (string) get_parameter ("community", '');
$snmp_version = (string) get_parameter ("snmp_browser_version", '');
$server_to_exec = (int) get_parameter ("server_to_exec", 0);
- $snmp3_auth_user = get_parameter('snmp3_browser_auth_user');
+ $snmp3_auth_user = io_safe_output(get_parameter('snmp3_browser_auth_user'));
$snmp3_security_level = get_parameter('snmp3_browser_security_level');
$snmp3_auth_method = get_parameter('snmp3_browser_auth_method');
- $snmp3_auth_pass = get_parameter('snmp3_browser_auth_pass');
+ $snmp3_auth_pass = io_safe_output(get_parameter('snmp3_browser_auth_pass'));
$snmp3_privacy_method = get_parameter('snmp3_browser_privacy_method');
- $snmp3_privacy_pass = get_parameter('snmp3_browser_privacy_pass');
+ $snmp3_privacy_pass = io_safe_output(get_parameter('snmp3_browser_privacy_pass'));
// SNMP browser
if ($action == "snmptree") {
diff --git a/pandora_console/operation/tree.php b/pandora_console/operation/tree.php
index c7a23fb0fd..993f95c4fe 100755
--- a/pandora_console/operation/tree.php
+++ b/pandora_console/operation/tree.php
@@ -18,6 +18,7 @@ global $config;
$pure = get_parameter('pure', 0);
$tab = get_parameter('tab', 'group');
+$search_group = get_parameter('searchGroup', '');
$search_agent = get_parameter('searchAgent', '');
$status_agent = get_parameter('statusAgent', AGENT_STATUS_ALL);
$search_module = get_parameter('searchModule', '');
@@ -135,13 +136,16 @@ $agent_status_arr[AGENT_STATUS_UNKNOWN] = __('Unknown');
$agent_status_arr[AGENT_STATUS_NOT_INIT] = __('Not init');
$row = array();
+$row[] = __('Search group');
+$row[] = html_print_input_text("search_group", $search_group, '', is_metaconsole() ? 70 : 40, 30, true);
+
+$table->data[] = $row;
+
+$row = array();
+$row[] = __('Search agent');
+$row[] = html_print_input_text("search_agent", $search_agent, '', is_metaconsole() ? 70 : 40, 30, true);
$row[] = __('Agent status');
$row[] = html_print_select($agent_status_arr, "status_agent", $status_agent, '', '', 0, true);
-$row[] = __('Search agent');
-if (is_metaconsole())
- $row[] = html_print_input_text("search_agent", $search_agent, '', 70, 30, true);
-else
- $row[] = html_print_input_text("search_agent", $search_agent, '', 40, 30, true);
// Button
$row[] = html_print_submit_button(__('Filter'), "uptbutton", false, 'class="sub search"', true);
@@ -160,10 +164,10 @@ if (!is_metaconsole()) {
$module_status_arr[AGENT_MODULE_STATUS_NOT_INIT] = __('Not init');
$row = array();
- $row[] = __('Module status');
- $row[] = html_print_select($module_status_arr, "status_module", $status_module, '', '', 0, true);
$row[] = __('Search module');
$row[] = html_print_input_text("search_module", $search_module, '', 40, 30, true);
+ $row[] = __('Module status');
+ $row[] = html_print_select($module_status_arr, "status_module", $status_module, '', '', 0, true);
$table->data[] = $row;
}
@@ -240,8 +244,9 @@ enterprise_hook('close_meta_frame');
var parameters = {};
parameters['page'] = "include/ajax/tree.ajax";
parameters['getChildren'] = 1;
- parameters['filter'] = {};
parameters['type'] = "";
+ parameters['filter'] = {};
+ parameters['filter']['searchGroup'] = $("input#text-search_group").val();
parameters['filter']['searchAgent'] = $("input#text-search_agent").val();
parameters['filter']['statusAgent'] = $("select#status_agent").val();
parameters['filter']['searchModule'] = $("input#text-search_module").val();
diff --git a/pandora_console/operation/users/user_edit.php b/pandora_console/operation/users/user_edit.php
index 4e76d32899..47f52d0cd8 100644
--- a/pandora_console/operation/users/user_edit.php
+++ b/pandora_console/operation/users/user_edit.php
@@ -99,6 +99,8 @@ if (isset ($_GET["modified"]) && !$view_mode) {
else{
$upd_info['autorefresh_white_list'] = json_encode($autorefresh_list);
}
+
+ $upd_info['time_autorefresh'] = (int) get_parameter ("time_autorefresh", 0);
$is_admin = db_get_value('is_admin', 'tusuario', 'id_user', $id);
@@ -439,10 +441,13 @@ $table_ichanges = '
';
$data[0] .= $table_ichanges;
+//time autorefresh
+$times = get_refresh_time_array();
+$data[1] = '
'.__('Time autorefresh').' ';
+$data[1] .= $jump . '
'. html_print_select ($times, 'time_autorefresh', $user_info["time_autorefresh"], '', '', '', true,false,false).' ';
$table->rowclass[] = '';
-$table->colspan[count($table->data)][0] = 3;
-$table->rowstyle[] = 'font-weight: bold;';
+$table->rowstyle[] = 'font-weight: bold;vertical-align: top';
$table->data[] = $data;
$data = array();
diff --git a/pandora_console/operation/visual_console/public_console.php b/pandora_console/operation/visual_console/public_console.php
index 6b77dd4798..21bf94fe65 100755
--- a/pandora_console/operation/visual_console/public_console.php
+++ b/pandora_console/operation/visual_console/public_console.php
@@ -208,51 +208,57 @@ $ignored_params['refr'] = '';
$(".overlay").removeClass("overlay").addClass("overlaydisabled");
- $('.item:not(.icon) img').each(function(){
-
-
- if($(this).css('float')=='left' || $(this).css('float')=='right'){
-
-
- $(this).css('margin-top',(parseInt($(this).parent().parent().css('height'))/2-parseInt($(this).css('height'))/2)+'px');
- $(this).css('margin-left','');
-
+ // Start the map fetch
+ //~ fetchMap();
+ });
+
+ $(window).load (function () {
+ $('.item:not(.icon) img:not(.b64img)').each( function() {
+ if ($(this).css('float')=='left' || $(this).css('float')=='right') {
+ if( $(this).parent()[0].tagName == 'DIV'){
+ $(this).css('margin-top',(parseInt($(this).parent().css('height'))/2-parseInt($(this).css('height'))/2)+'px');
+ }
+ else if ( $(this).parent()[0].tagName == 'A') {
+ $(this).css('margin-top',(parseInt($(this).parent().parent().css('height'))/2-parseInt($(this).css('height'))/2)+'px');
+ }
+ $(this).css('margin-left','');
}
- else{
- $(this).css('margin-left',(parseInt($(this).parent().parent().css('width'))/2-parseInt($(this).css('width'))/2)+'px');
- $(this).css('margin-top','');
+ else {
+ if(parseInt($(this).parent().parent().css('width'))/2-parseInt($(this).css('width'))/2 < 0){
+ $(this).css('margin-left','');
+ $(this).css('margin-top','');
+ } else {
+ if( $(this).parent()[0].tagName == 'DIV'){
+ $(this).css('margin-left',(parseInt($(this).parent().css('width'))/2-parseInt($(this).css('width'))/2)+'px');
+ }
+ else if ( $(this).parent()[0].tagName == 'A') {
+ $(this).css('margin-left',(parseInt($(this).parent().parent().css('width'))/2-parseInt($(this).css('width'))/2)+'px');
+ }
+ $(this).css('margin-top','');
+ }
}
-
});
- $('.item > div').each(function(){
- if($(this).css('float')=='left' || $(this).css('float')=='right'){
-
-
- $(this).css('margin-top',(parseInt($(this).parent().css('height'))/2-parseInt($(this).css('height'))/2-15)+'px');
- $(this).css('margin-left','');
-
+ $('.item > div').each( function() {
+ if ($(this).css('float')=='left' || $(this).css('float')=='right') {
+ $(this).css('margin-top',(parseInt($(this).parent().css('height'))/2-parseInt($(this).css('height'))/2-15)+'px');
+ $(this).css('margin-left','');
}
- else{
+ else {
$(this).css('margin-left',(parseInt($(this).parent().css('width'))/2-parseInt($(this).css('width'))/2)+'px');
$(this).css('margin-top','');
}
-
});
- $('.item > a > div').each(function(){
- if($(this).css('float')=='left' || $(this).css('float')=='right'){
-
-
- $(this).css('margin-top',(parseInt($(this).parent().parent().css('height'))/2-parseInt($(this).css('height'))/2-5)+'px');
- $(this).css('margin-left','');
-
+ $('.item > a > div').each( function() {
+ if ($(this).css('float')=='left' || $(this).css('float')=='right') {
+ $(this).css('margin-top',(parseInt($(this).parent().parent().css('height'))/2-parseInt($(this).css('height'))/2-5)+'px');
+ $(this).css('margin-left','');
}
- else{
+ else {
$(this).css('margin-left',(parseInt($(this).parent().parent().css('width'))/2-parseInt($(this).css('width'))/2)+'px');
$(this).css('margin-top','');
}
-
});
$(".graph:not([class~='noresizevc'])").each(function(){
diff --git a/pandora_console/operation/visual_console/pure_ajax.php b/pandora_console/operation/visual_console/pure_ajax.php
index 08b5460067..58e920550f 100644
--- a/pandora_console/operation/visual_console/pure_ajax.php
+++ b/pandora_console/operation/visual_console/pure_ajax.php
@@ -183,7 +183,10 @@ $ignored_params['refr'] = '';
});
$(".overlay").removeClass("overlay").addClass("overlaydisabled");
-
+
+ });
+
+ $(window).load (function () {
$('.item:not(.icon) img').each(function(){
diff --git a/pandora_console/operation/visual_console/render_view.php b/pandora_console/operation/visual_console/render_view.php
index 261205818b..0f2a2b9750 100755
--- a/pandora_console/operation/visual_console/render_view.php
+++ b/pandora_console/operation/visual_console/render_view.php
@@ -244,10 +244,11 @@ $ignored_params['refr'] = '';
$('div.vc-countdown').countdown('destroy');
//cb();
url = js_html_entity_decode( href ) + duration;
- //$(document).attr ("location", url);
- $.post(window.location.href.replace("refr=300","refr="+new_count), function(respuestaSolicitud){
+ $(document).attr ("location", url);
+ /*$.post(window.location.href.replace("refr=300","refr="+new_count), function(respuestaSolicitud){
$('#background_').html(respuestaSolicitud);
});
+ */
$("#main_pure").css('background-color','');
}
@@ -279,7 +280,10 @@ $ignored_params['refr'] = '';
});
$(".overlay").removeClass("overlay").addClass("overlaydisabled");
-
+
+ });
+
+ $(window).load (function () {
$('.item:not(.icon) img:not(.b64img)').each( function() {
if ($(this).css('float')=='left' || $(this).css('float')=='right') {
if( $(this).parent()[0].tagName == 'DIV'){
@@ -332,6 +336,6 @@ $ignored_params['refr'] = '';
height = parseInt($(this).css("height")) - 30;
$(this).css('height', height);
});
-
+
});
\ No newline at end of file
diff --git a/pandora_console/pandora_console.redhat.spec b/pandora_console/pandora_console.redhat.spec
index 7d89c58a93..89d14e6341 100644
--- a/pandora_console/pandora_console.redhat.spec
+++ b/pandora_console/pandora_console.redhat.spec
@@ -2,8 +2,8 @@
# Pandora FMS Console
#
%define name pandorafms_console
-%define version 7.0NG.714
-%define release 171026
+%define version 7.0NG.716
+%define release 171130
# User and Group under which Apache is running
%define httpd_name httpd
diff --git a/pandora_console/pandora_console.spec b/pandora_console/pandora_console.spec
index 706ff87235..02cfb81e0f 100644
--- a/pandora_console/pandora_console.spec
+++ b/pandora_console/pandora_console.spec
@@ -2,8 +2,8 @@
# Pandora FMS Console
#
%define name pandorafms_console
-%define version 7.0NG.714
-%define release 171026
+%define version 7.0NG.716
+%define release 171130
%define httpd_name httpd
# User and Group under which Apache is running
%define httpd_name apache2
diff --git a/pandora_console/pandora_console_install b/pandora_console/pandora_console_install
index 3f357b2ea5..2ffb7db4e2 100644
--- a/pandora_console/pandora_console_install
+++ b/pandora_console/pandora_console_install
@@ -9,7 +9,7 @@
# This code is licensed under GPL 2.0 license.
# **********************************************************************
-PI_VERSION="7.0NG.714"
+PI_VERSION="7.0NG.716"
FORCE=0
DESTDIR=""
LOG_TIMESTAMP=`date +"%Y/%m/%d %H:%M:%S"`
diff --git a/pandora_console/pandoradb.sql b/pandora_console/pandoradb.sql
index 0d749db694..fd9aa8c60a 100644
--- a/pandora_console/pandoradb.sql
+++ b/pandora_console/pandoradb.sql
@@ -85,6 +85,7 @@ CREATE TABLE IF NOT EXISTS `tagente` (
`alias` varchar(600) BINARY NOT NULL default '',
`transactional_agent` tinyint(1) NOT NULL default '0',
`alias_as_name` tinyint(2) NOT NULL default '0',
+ `safe_mode_module` int(10) unsigned NOT NULL default '0',
PRIMARY KEY (`id_agente`),
KEY `nombre` (`nombre`(255)),
KEY `direccion` (`direccion`),
@@ -99,7 +100,7 @@ CREATE TABLE IF NOT EXISTS `tagente_datos` (
`id_agente_modulo` int(10) unsigned NOT NULL default '0',
`datos` double(22,5) default NULL,
`utimestamp` bigint(20) default '0',
- KEY `data_index1` (`id_agente_modulo`),
+ KEY `data_index1` (`id_agente_modulo`, `utimestamp`),
KEY `idx_utimestamp` USING BTREE (`utimestamp`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ;
@@ -120,7 +121,7 @@ CREATE TABLE IF NOT EXISTS `tagente_datos_string` (
`id_agente_modulo` int(10) unsigned NOT NULL default '0',
`datos` mediumtext NOT NULL,
`utimestamp` int(20) unsigned NOT NULL default 0,
- KEY `data_string_index_1` (`id_agente_modulo`),
+ KEY `data_string_index_1` (`id_agente_modulo`, `utimestamp`),
KEY `idx_utimestamp` USING BTREE (`utimestamp`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
@@ -1114,6 +1115,7 @@ CREATE TABLE IF NOT EXISTS `tusuario` (
`session_time` int(10) signed NOT NULL default 0,
`default_event_filter` int(10) unsigned NOT NULL default 0,
`autorefresh_white_list` text not null default '',
+ `time_autorefresh` int(5) unsigned NOT NULL default '30',
CONSTRAINT `fk_filter_id` FOREIGN KEY (`id_filter`) REFERENCES tevent_filter (`id_filter`) ON DELETE SET NULL,
UNIQUE KEY `id_user` (`id_user`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
@@ -1188,6 +1190,8 @@ CREATE TABLE IF NOT EXISTS `tgraph` (
`id_group` mediumint(8) unsigned NULL default 0,
`id_graph_template` int(11) NOT NULL default 0,
`percentil` tinyint(1) UNSIGNED NOT NULL default 0,
+ `summatory_series` tinyint(1) UNSIGNED NOT NULL default 0,
+ `average_series` tinyint(1) UNSIGNED NOT NULL default 0,
PRIMARY KEY(`id_graph`)
) ENGINE = InnoDB DEFAULT CHARSET=utf8;
@@ -1269,6 +1273,9 @@ CREATE TABLE IF NOT EXISTS `treport_content` (
`id_module_group` INT (10) unsigned NOT NULL DEFAULT 0,
`server_name` text,
`historical_db` tinyint(1) UNSIGNED NOT NULL default 0,
+ `lapse_calc` tinyint(1) UNSIGNED NOT NULL default '0',
+ `lapse` int(11) UNSIGNED NOT NULL default '300',
+ `visual_format` tinyint(1) UNSIGNED NOT NULL default '0',
PRIMARY KEY(`id_rc`),
FOREIGN KEY (`id_report`) REFERENCES treport(`id_report`)
ON UPDATE CASCADE ON DELETE CASCADE
@@ -1356,6 +1363,9 @@ CREATE TABLE IF NOT EXISTS `tlayout_data` (
`border_color` varchar(200) DEFAULT "",
`fill_color` varchar(200) DEFAULT "",
`show_statistics` tinyint(2) NOT NULL default '0',
+ `id_layout_linked_weight` int(10) NOT NULL default '0',
+ `element_group` int(10) NOT NULL default '0',
+ `show_on_top` tinyint(1) NOT NULL default '0',
PRIMARY KEY(`id`)
) ENGINE = InnoDB DEFAULT CHARSET=utf8;
@@ -1707,6 +1717,7 @@ CREATE TABLE IF NOT EXISTS `tsnmp_filter` (
`id_snmp_filter` int(10) unsigned NOT NULL auto_increment,
`description` varchar(255) default '',
`filter` varchar(255) default '',
+ `unified_filters_id` int(10) not null default 0,
PRIMARY KEY (`id_snmp_filter`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
@@ -2206,6 +2217,7 @@ CREATE TABLE IF NOT EXISTS `tdashboard` (
`id_group` int(10) NOT NULL default 0,
`active` tinyint(1) NOT NULL default 0,
`cells` int(10) unsigned default 0,
+ `cells_slideshow` TINYINT(1) NOT NULL default 0,
PRIMARY KEY (`id`)
) ENGINE = InnoDB DEFAULT CHARSET=utf8;
@@ -2726,6 +2738,9 @@ CREATE TABLE IF NOT EXISTS `treport_content_template` (
`module_free_text` TEXT,
`each_agent` tinyint(1) default 1,
`historical_db` tinyint(1) UNSIGNED NOT NULL default 0,
+ `lapse_calc` tinyint(1) UNSIGNED NOT NULL default '0',
+ `lapse` int(11) UNSIGNED NOT NULL default '300',
+ `visual_format` tinyint(1) UNSIGNED NOT NULL default '0',
PRIMARY KEY(`id_rc`)
) ENGINE = InnoDB DEFAULT CHARSET=utf8;
@@ -2957,6 +2972,7 @@ CREATE TABLE IF NOT EXISTS `tmetaconsole_agent` (
`transactional_agent` tinyint(1) NOT NULL default '0',
`alias` varchar(600) BINARY NOT NULL default '',
`alias_as_name` tinyint(2) NOT NULL default '0',
+ `safe_mode_module` int(10) unsigned NOT NULL default '0',
PRIMARY KEY (`id_agente`),
KEY `nombre` (`nombre`(255)),
KEY `direccion` (`direccion`),
diff --git a/pandora_console/pandoradb_data.sql b/pandora_console/pandoradb_data.sql
index f46fe33524..476750758f 100644
--- a/pandora_console/pandoradb_data.sql
+++ b/pandora_console/pandoradb_data.sql
@@ -12,7 +12,7 @@
-- Dumping data for table `talert_commands`
--
-INSERT INTO `talert_commands` (`id`, `name`, `command`, `description`, `internal`, `fields_descriptions`, `fields_values`) VALUES (1,'eMail','Internal type','This alert send an email using internal Pandora FMS Server SMTP capabilities (defined in each server, using:
_field1_ as destination email address, and
_field2_ as subject for message.
_field3_ as text of message.',1,'[\"Destination address\",\"Subject\",\"Text\",\"\",\"\",\"\",\"\",\"\",\"\",\"\"]','[\"\",\"\",\"_html_editor_\",\"\",\"\",\"\",\"\",\"\",\"\",\"\"]');
+INSERT INTO `talert_commands` (`id`, `name`, `command`, `description`, `internal`, `fields_descriptions`, `fields_values`) VALUES (1,'eMail','Internal type','This alert send an email using internal Pandora FMS Server SMTP capabilities (defined in each server, using:
_field1_ as destination email address, and
_field2_ as subject for message.
_field3_ as text of message.
_field4_ as content type (plain/text or html/text).',1,'[\"Destination address\",\"Subject\",\"Text\",\"Content Type\",\"\",\"\",\"\",\"\",\"\",\"\"]','[\"\",\"\",\"_html_editor_\",\"_content_type_\",\"\",\"\",\"\",\"\",\"\",\"\"]');
INSERT INTO `talert_commands` (`id`, `name`, `command`, `description`, `internal`, `fields_descriptions`, `fields_values`) VALUES (2,'Internal Audit','Internal type','This alert save alert in Pandora internal audit system. Fields are static and only _field1_ is used.',1,'[\"Description\",\"\",\"\",\"\",\"\",\"\",\"\",\"\",\"\",\"\"]','[\"\",\"\",\"\",\"\",\"\",\"\",\"\",\"\",\"\",\"\"]');
INSERT INTO `talert_commands` (`id`, `name`, `command`, `description`, `internal`, `fields_descriptions`, `fields_values`) VALUES (3,'Pandora FMS Event','Internal type','This alert create an special event into Pandora FMS event manager.',1,'[\"Event text\",\"Event type\",\"Source\",\"Agent name or _agent_\",\"Event criticity\",\"ID extra\",\"Tags separated by commas\",\"Comments\",\"\",\"\"]','[\"\",\"alert_ceased,Alert ceased;alert_fired,Alert fired;alert_manual_validation,Alert manual validation;alert_recovered,Alert recovered;configuration_change,Configuration change ;error,Error;critical,Monitor Critical;normal,Monitor Normal;going_unknown,Monitor\",\"\",\"\",\"4,Critical;1,Informational;0,Maintenance;6,Major;5,Minor;2,Normal;3,Warning\",\"\",\"\",\"\",\"\",\"\"]');
INSERT INTO `talert_commands` (`id`, `name`, `command`, `description`, `internal`, `fields_descriptions`, `fields_values`) VALUES (4,'Pandora FMS Alertlog','echo _timestamp_ pandora _agent_ _data_ _field1_ _field2_ >> /var/log/pandora/pandora_alert.log','This is a default alert to write alerts in a standard ASCII plaintext log file in /var/log/pandora/pandora_alert.log
',0,'[\"Log Info 1\",\"Log Info 2\",\"\",\"\",\"\",\"\",\"\",\"\",\"\",\"\"]','[\"\",\"\",\"\",\"\",\"\",\"\",\"\",\"\",\"\",\"\"]');
@@ -109,10 +109,10 @@ INSERT INTO `tconfig` (`token`, `value`) VALUES
('custom_report_front_logo', 'images/pandora_logo_white.jpg'),
('custom_report_front_header', ''),
('custom_report_front_footer', ''),
-('MR', 7),
+('MR', 9),
('identification_reminder', 1),
('identification_reminder_timestamp', 0),
-('current_package_enterprise', '714'),
+('current_package_enterprise', '716'),
('post_process_custom_values', '{"0.00000038580247":"Seconds to months","0.00000165343915":"Seconds to weeks","0.00001157407407":"Seconds to days","0.01666666666667":"Seconds to minutes","0.00000000093132":"Bytes to Gigabytes","0.00000095367432":"Bytes to Megabytes","0.0009765625":"Bytes to Kilobytes","0.00000001653439":"Timeticks to weeks","0.00000011574074":"Timeticks to days"}');
UNLOCK TABLES;
@@ -1105,7 +1105,7 @@ INSERT INTO `talert_commands` (`id`, `name`, `command`, `description`, `internal
-- alert actions (default)
INSERT INTO `talert_actions` (`id`, `name`, `id_alert_command`, `field1`, `field2`, `field3`, `field4`, `field5`, `field6`, `field7`, `field8`, `field9`, `field10`, `id_group`, `action_threshold`, `field1_recovery`, `field2_recovery`, `field3_recovery`, `field4_recovery`, `field5_recovery`, `field6_recovery`, `field7_recovery`, `field8_recovery`, `field9_recovery`, `field10_recovery`) VALUES
-(1,'Mail to Admin',1,'yourmail@domain.es','[PANDORA] Alert from agent _agent_ on module _module_','<style type="text/css">
/* Take care of image borders and formatting */
img {
max-width: 600px;
outline: none;
text-decoration: none;
-ms-interpolation-mode: bicubic;
}
a {
border: 0;
outline: none;
}
a img {
border: none;
}
/* General styling */
td, h1, h2, h3 {
font-family: Helvetica, Arial, sans-serif;
font-weight: 400;
}
td {
font-size: 14px;
line-height: 150%;
text-align: left;
}
body {
-webkit-font-smoothing:antialiased;
-webkit-text-size-adjust:none;
width: 100%;
height: 100%;
color: #37302d;
background: #ffffff;
}
table {
border-collapse: collapse !important;
}
h1, h2, h3 {
padding: 0;
margin: 0;
color: #444444;
font-weight: 400;
line-height: 110%;
}
h1 {
font-size: 35px;
}
h2 {
font-size: 30px;
}
h3 {
font-size: 24px;
}
h4 {
font-size: 18px;
font-weight: normal;
}
.important-font {
color: #21BEB4;
font-weight: bold;
}
.hide {
display: none !important;
}
.force-full-width {
width: 100% !important;
}
</style>
<style type="text/css" media="screen">
@media screen {
@import url(http://fonts.googleapis.com/css?family=Open+Sans:400);
/* Thanks Outlook 2013! */
td, h1, h2, h3 {
font-family: 'Open Sans', 'Helvetica Neue', Arial, sans-serif !important;
}
}
</style>
<style type="text/css" media="only screen and (max-width: 600px)">
/* Mobile styles */
@media only screen and (max-width: 600px) {
table[class="w320"] {
width: 320px !important;
}
table[class="w300"] {
width: 300px !important;
}
table[class="w290"] {
width: 290px !important;
}
td[class="w320"] {
width: 320px !important;
}
td[class~="mobile-padding"] {
padding-left: 14px !important;
padding-right: 14px !important;
}
td[class*="mobile-padding-left"] {
padding-left: 14px !important;
}
td[class*="mobile-padding-right"] {
padding-right: 14px !important;
}
td[class*="mobile-block"] {
display: block !important;
width: 100% !important;
text-align: left !important;
padding-left: 0 !important;
padding-right: 0 !important;
padding-bottom: 15px !important;
}
td[class*="mobile-no-padding-bottom"] {
padding-bottom: 0 !important;
}
td[class~="mobile-center"] {
text-align: center !important;
}
table[class*="mobile-center-block"] {
float: none !important;
margin: 0 auto !important;
}
*[class*="mobile-hide"] {
display: none !important;
width: 0 !important;
height: 0 !important;
line-height: 0 !important;
font-size: 0 !important;
}
td[class*="mobile-border"] {
border: 0 !important;
}
}
</style>
<table style="width: 100%;" cellspacing="0" cellpadding="0" align="center">
<tbody>
<tr>
<td align="center" valign="top" bgcolor="#ffffff" width="100%">
<table style="width: 100%;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="background: #1f1f1f; height: 70px;" width="100%"><center>
<table class="w320" style="width: 600px;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="mobile-block mobile-no-padding-bottom mobile-center" style="background: #1f1f1f; padding: 10px 10px 10px 20px;" valign="top" width="270"><a style="text-decoration: none;" href="#"> <img src="https://pandorafms.com/images/logo_pandora_email.png" alt="Your Logo" width="200"> </a></td>
<td class="mobile-block mobile-center" style="background: #1f1f1f; padding: 17px 15px 10px 10px;" valign="top" width="270"> </td>
</tr>
</tbody>
</table>
</center></td>
</tr>
<tr>
<td style="border-bottom: 1px solid #e7e7e7;"><center style="padding-bottom: 20px;">
<table class="w320" style="width: 600px;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="mobile-padding" style="padding: 20px;" align="left"><br class="mobile-hide">
<h2>Pandora FMS alert system</h2>
<br> Dear customer,<br><br> We have <strong>bad news</strong> for you. Something is on <strong>CRITICAL</strong> status!<br> <br>
<table style="width: 100%;" cellspacing="0" cellpadding="0" bgcolor="#ffffff">
<tbody>
<tr>
<td style="width: 100px; background: #D84A38;">
<div><!--[if mso]>
<v:rect xmlns:v="urn:schemas-microsoft-com:vml" xmlns:w="urn:schemas-microsoft-com:office:word" href="#" style="height:33px;v-text-anchor:middle;width:100px;" stroke="f" fillcolor="#D84A38">
<w:anchorlock/>
<center>
<![endif]--> <a style="background-color: #1f1f1f; color: whitesmoke; display: inline-block; font-family: sans-serif; font-size: 13px; font-weight: bold; line-height: 33px; text-align: center; text-decoration: none; width: 250px; -webkit-text-size-adjust: none;" href="_homeurl_">Go to Pandora FMS Console</a> <!--[if mso]>
</center>
</v:rect>
<![endif]--></div>
</td>
<td style="background-color: #ffffff; font-size: 0; line-height: 0;" width="281"> </td>
</tr>
</tbody>
</table>
</td>
<td class="mobile-hide" style="padding-top: 20px; padding-bottom: 0; vertical-align: bottom;" valign="bottom">
<table style="width: 100%;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="padding-bottom: 0px; vertical-align: bottom;" align="right" valign="bottom"><img style="vertical-align: bottom; padding-bottom: 10px;" src="https://pandorafms.com/images/alerta_roja.png" alt="" width="130"></td>
</tr>
</tbody>
</table>
</td>
</tr>
</tbody>
</table>
</center></td>
</tr>
<tr>
<td style="background-color: #f8f8f8; border-bottom: 1px solid #e7e7e7; padding-top: 10px;" valign="top"><center>
<table class="w320" style="height: 100%; width: 600px;" border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="mobile-padding" style="padding: 20px;" valign="top">
<table style="width: 100%;" border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="padding-right: 20px;" colspan="2"><strong>Monitoring details</strong></td>
</tr>
<tr>
<td style="padding-top: 25px; width: 150px; border-top: 1px solid #E7E7E7; vertical-align: top;"><strong>Data</strong></td>
<td style="padding-top: 25px; padding-right: 20px; border-top: 1px solid #E7E7E7; vertical-align: top;">_data_ <em>(_modulestatus_)</em></td>
</tr>
<tr>
<td><strong>Agent</strong></td>
<td>_agent_ <em>_address_</em></td>
</tr>
<tr>
<td><strong>Module</strong></td>
<td>_module_ <em>_moduledescription_ </em></td>
</tr>
<tr>
<td><strong>Timestamp</strong></td>
<td>_timestamp_</td>
</tr>
</tbody>
</table>
<table style="width: 100%;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="padding-top: 20px;">
<table style="width: 100%;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="vertical-align: top;" width="350">This is a graph of latest 24hr data for this module: <br><br> _modulegraph_24h_</td>
</tr>
</tbody>
</table>
</td>
</tr>
</tbody>
</table>
</td>
</tr>
</tbody>
</table>
</center></td>
</tr>
<tr>
<td style="background-color: #1f1f1f;"><center>
<table class="w320" style="height: 100%; color: #ffffff; width: 600px;" border="0" cellspacing="0" cellpadding="0" bgcolor="#1f1f1f">
<tbody>
<tr>
<td class="mobile-padding" style="font-size: 12px; padding: 20px; background-color: #1f1f1f; color: #ffffff; text-align: center;" align="right" valign="middle"><a style="color: #ffffff;" href="https://pandorafms.com/company/contact/">Contact Us</a> | <a style="color: #ffffff;" href="https://forums.pandorafms.com/">Support</a> | <a style="color: #ffffff;" href="https://wiki.pandorafms.com">Docs</a> | </td>
</tr>
</tbody>
</table>
</center></td>
</tr>
</tbody>
</table>
</td>
</tr>
</tbody>
</table>','','','','','','','',0,0,'','','<style type="text/css"><!--
/* Take care of image borders and formatting */
img {
max-width: 600px;
outline: none;
text-decoration: none;
-ms-interpolation-mode: bicubic;
}
a {
border: 0;
outline: none;
}
a img {
border: none;
}
/* General styling */
td, h1, h2, h3 {
font-family: Helvetica, Arial, sans-serif;
font-weight: 400;
}
td {
font-size: 14px;
line-height: 150%;
text-align: left;
}
body {
-webkit-font-smoothing:antialiased;
-webkit-text-size-adjust:none;
width: 100%;
height: 100%;
color: #37302d;
background: #ffffff;
}
table {
border-collapse: collapse !important;
}
h1, h2, h3 {
padding: 0;
margin: 0;
color: #444444;
font-weight: 400;
line-height: 110%;
}
h1 {
font-size: 35px;
}
h2 {
font-size: 30px;
}
h3 {
font-size: 24px;
}
h4 {
font-size: 18px;
font-weight: normal;
}
.important-font {
color: #21BEB4;
font-weight: bold;
}
.hide {
display: none !important;
}
.force-full-width {
width: 100% !important;
}
--></style>
<style type="text/css" media="screen"><!--
@media screen {
@import url(http://fonts.googleapis.com/css?family=Open+Sans:400);
/* Thanks Outlook 2013! */
td, h1, h2, h3 {
font-family: 'Open Sans', 'Helvetica Neue', Arial, sans-serif !important;
}
}
--></style>
<style type="text/css" media="only screen and (max-width: 600px)"><!--
/* Mobile styles */
@media only screen and (max-width: 600px) {
table[class="w320"] {
width: 320px !important;
}
table[class="w300"] {
width: 300px !important;
}
table[class="w290"] {
width: 290px !important;
}
td[class="w320"] {
width: 320px !important;
}
td[class~="mobile-padding"] {
padding-left: 14px !important;
padding-right: 14px !important;
}
td[class*="mobile-padding-left"] {
padding-left: 14px !important;
}
td[class*="mobile-padding-right"] {
padding-right: 14px !important;
}
td[class*="mobile-block"] {
display: block !important;
width: 100% !important;
text-align: left !important;
padding-left: 0 !important;
padding-right: 0 !important;
padding-bottom: 15px !important;
}
td[class*="mobile-no-padding-bottom"] {
padding-bottom: 0 !important;
}
td[class~="mobile-center"] {
text-align: center !important;
}
table[class*="mobile-center-block"] {
float: none !important;
margin: 0 auto !important;
}
*[class*="mobile-hide"] {
display: none !important;
width: 0 !important;
height: 0 !important;
line-height: 0 !important;
font-size: 0 !important;
}
td[class*="mobile-border"] {
border: 0 !important;
}
}
--></style>
<table style="width: 100%;" cellspacing="0" cellpadding="0" align="center">
<tbody>
<tr>
<td align="center" valign="top" bgcolor="#ffffff" width="100%">
<table style="width: 100%;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="background: #1f1f1f; height: 70px;" width="100%"><center>
<table class="w320" style="width: 600px;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="mobile-block mobile-no-padding-bottom mobile-center" style="background: #1f1f1f; padding: 10px 10px 10px 20px;" valign="top" width="270"><a style="text-decoration: none;" href="#"> <img src="https://pandorafms.com/images/logo_pandora_email.png" alt="Your Logo" width="200"> </a></td>
<td class="mobile-block mobile-center" style="background: #1f1f1f; padding: 17px 15px 10px 10px;" valign="top" width="270"> </td>
</tr>
</tbody>
</table>
</center></td>
</tr>
<tr>
<td style="border-bottom: 1px solid #e7e7e7;"><center style="padding-bottom: 20px;">
<table class="w320" style="width: 600px;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="mobile-padding" style="padding: 20px;" align="left"><br class="mobile-hide">
<h2>Pandora FMS alert system</h2>
<br> Dear customer,<br><br> We have <strong>good news</strong> for you. Alert has been <strong>RECOVERED</strong> status!<br> <br>
<table style="width: 100%;" cellspacing="0" cellpadding="0" bgcolor="#ffffff">
<tbody>
<tr>
<td style="width: 100px; background: #D84A38;">
<div><!--[if mso]>
<v:rect xmlns:v="urn:schemas-microsoft-com:vml" xmlns:w="urn:schemas-microsoft-com:office:word" href="#" style="height:33px;v-text-anchor:middle;width:100px;" stroke="f" fillcolor="#D84A38">
<w:anchorlock/>
<center>
<![endif]--> <a style="background-color: #1f1f1f; color: whitesmoke; display: inline-block; font-family: sans-serif; font-size: 13px; font-weight: bold; line-height: 33px; text-align: center; text-decoration: none; width: 250px; -webkit-text-size-adjust: none;" href="_homeurl_">Go to Pandora FMS Console</a> <!--[if mso]>
</center>
</v:rect>
<![endif]--></div>
</td>
<td style="background-color: #ffffff; font-size: 0; line-height: 0;" width="281"> </td>
</tr>
</tbody>
</table>
</td>
<td class="mobile-hide" style="padding-top: 20px; padding-bottom: 0; vertical-align: bottom;" valign="bottom">
<table style="width: 100%;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="padding-bottom: 0px; vertical-align: bottom;" align="right" valign="bottom"><img style="vertical-align: bottom; padding-bottom: 10px;" src="https://pandorafms.com/images/alerta_verde.png" alt="" width="130"></td>
</tr>
</tbody>
</table>
</td>
</tr>
</tbody>
</table>
</center></td>
</tr>
<tr>
<td style="background-color: #f8f8f8; border-bottom: 1px solid #e7e7e7; padding-top: 10px;" valign="top"><center>
<table class="w320" style="height: 100%; width: 600px;" border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="mobile-padding" style="padding: 20px;" valign="top">
<table style="width: 100%;" border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="padding-right: 20px;" colspan="2"><strong>Monitoring details</strong></td>
</tr>
<tr>
<td style="padding-top: 25px; width: 150px; border-top: 1px solid #E7E7E7; vertical-align: top;"><strong>Data</strong></td>
<td style="padding-top: 25px; padding-right: 20px; border-top: 1px solid #E7E7E7; vertical-align: top;">_data_ <em>(_modulestatus_)</em></td>
</tr>
<tr>
<td><strong>Agent</strong></td>
<td>_agent_ <em>_address_</em></td>
</tr>
<tr>
<td><strong>Module</strong></td>
<td>_module_ <em>_moduledescription_ </em></td>
</tr>
<tr>
<td><strong>Timestamp</strong></td>
<td>_timestamp_</td>
</tr>
</tbody>
</table>
<table style="width: 100%;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="padding-top: 20px;">
<table style="width: 100%;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="vertical-align: top;" width="350">This is a graph of latest 24hr data for this module: <br><br> _modulegraph_24h_</td>
</tr>
</tbody>
</table>
</td>
</tr>
</tbody>
</table>
</td>
</tr>
</tbody>
</table>
</center></td>
</tr>
<tr>
<td style="background-color: #1f1f1f;"><center>
<table class="w320" style="height: 100%; color: #ffffff; width: 600px;" border="0" cellspacing="0" cellpadding="0" bgcolor="#1f1f1f">
<tbody>
<tr>
<td class="mobile-padding" style="font-size: 12px; padding: 20px; background-color: #1f1f1f; color: #ffffff; text-align: center;" align="right" valign="middle"><a style="color: #ffffff;" href="https://pandorafms.com/company/contact/">Contact Us</a> | <a style="color: #ffffff;" href="https://forums.pandorafms.com/">Support</a> | <a style="color: #ffffff;" href="https://wiki.pandorafms.com">Docs</a> | </td>
</tr>
</tbody>
</table>
</center></td>
</tr>
</tbody>
</table>
</td>
</tr>
</tbody>
</table>','','','','','','','');
+(1,'Mail to Admin',1,'yourmail@domain.es','[PANDORA] Alert from agent _agent_ on module _module_','<style type="text/css">
/* Take care of image borders and formatting */
img {
max-width: 600px;
outline: none;
text-decoration: none;
-ms-interpolation-mode: bicubic;
}
a {
border: 0;
outline: none;
}
a img {
border: none;
}
/* General styling */
td, h1, h2, h3 {
font-family: Helvetica, Arial, sans-serif;
font-weight: 400;
}
td {
font-size: 14px;
line-height: 150%;
text-align: left;
}
body {
-webkit-font-smoothing:antialiased;
-webkit-text-size-adjust:none;
width: 100%;
height: 100%;
color: #37302d;
background: #ffffff;
}
table {
border-collapse: collapse !important;
}
h1, h2, h3 {
padding: 0;
margin: 0;
color: #444444;
font-weight: 400;
line-height: 110%;
}
h1 {
font-size: 35px;
}
h2 {
font-size: 30px;
}
h3 {
font-size: 24px;
}
h4 {
font-size: 18px;
font-weight: normal;
}
.important-font {
color: #21BEB4;
font-weight: bold;
}
.hide {
display: none !important;
}
.force-full-width {
width: 100% !important;
}
</style>
<style type="text/css" media="screen">
@media screen {
@import url(http://fonts.googleapis.com/css?family=Open+Sans:400);
/* Thanks Outlook 2013! */
td, h1, h2, h3 {
font-family: 'Open Sans', 'Helvetica Neue', Arial, sans-serif !important;
}
}
</style>
<style type="text/css" media="only screen and (max-width: 600px)">
/* Mobile styles */
@media only screen and (max-width: 600px) {
table[class="w320"] {
width: 320px !important;
}
table[class="w300"] {
width: 300px !important;
}
table[class="w290"] {
width: 290px !important;
}
td[class="w320"] {
width: 320px !important;
}
td[class~="mobile-padding"] {
padding-left: 14px !important;
padding-right: 14px !important;
}
td[class*="mobile-padding-left"] {
padding-left: 14px !important;
}
td[class*="mobile-padding-right"] {
padding-right: 14px !important;
}
td[class*="mobile-block"] {
display: block !important;
width: 100% !important;
text-align: left !important;
padding-left: 0 !important;
padding-right: 0 !important;
padding-bottom: 15px !important;
}
td[class*="mobile-no-padding-bottom"] {
padding-bottom: 0 !important;
}
td[class~="mobile-center"] {
text-align: center !important;
}
table[class*="mobile-center-block"] {
float: none !important;
margin: 0 auto !important;
}
*[class*="mobile-hide"] {
display: none !important;
width: 0 !important;
height: 0 !important;
line-height: 0 !important;
font-size: 0 !important;
}
td[class*="mobile-border"] {
border: 0 !important;
}
}
</style>
<table style="width: 100%;" cellspacing="0" cellpadding="0" align="center">
<tbody>
<tr>
<td align="center" valign="top" bgcolor="#ffffff" width="100%">
<table style="width: 100%;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="background: #1f1f1f; height: 70px;" width="100%"><center>
<table class="w320" style="width: 600px;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="mobile-block mobile-no-padding-bottom mobile-center" style="background: #1f1f1f; padding: 10px 10px 10px 20px;" valign="top" width="270"><a style="text-decoration: none;" href="#"> <img src="https://pandorafms.com/images/logo_pandora_email.png" alt="Your Logo" width="200"> </a></td>
<td class="mobile-block mobile-center" style="background: #1f1f1f; padding: 17px 15px 10px 10px;" valign="top" width="270"> </td>
</tr>
</tbody>
</table>
</center></td>
</tr>
<tr>
<td style="border-bottom: 1px solid #e7e7e7;"><center style="padding-bottom: 20px;">
<table class="w320" style="width: 600px;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="mobile-padding" style="padding: 20px;" align="left"><br class="mobile-hide">
<h2>Pandora FMS alert system</h2>
<br> Dear customer,<br><br> We have <strong>bad news</strong> for you. Something is on <strong>CRITICAL</strong> status!<br> <br>
<table style="width: 100%;" cellspacing="0" cellpadding="0" bgcolor="#ffffff">
<tbody>
<tr>
<td style="width: 100px; background: #D84A38;">
<div><!--[if mso]>
<v:rect xmlns:v="urn:schemas-microsoft-com:vml" xmlns:w="urn:schemas-microsoft-com:office:word" href="#" style="height:33px;v-text-anchor:middle;width:100px;" stroke="f" fillcolor="#D84A38">
<w:anchorlock/>
<center>
<![endif]--> <a style="background-color: #1f1f1f; color: whitesmoke; display: inline-block; font-family: sans-serif; font-size: 13px; font-weight: bold; line-height: 33px; text-align: center; text-decoration: none; width: 250px; -webkit-text-size-adjust: none;" href="_homeurl_">Go to Pandora FMS Console</a> <!--[if mso]>
</center>
</v:rect>
<![endif]--></div>
</td>
<td style="background-color: #ffffff; font-size: 0; line-height: 0;" width="281"> </td>
</tr>
</tbody>
</table>
</td>
<td class="mobile-hide" style="padding-top: 20px; padding-bottom: 0; vertical-align: bottom;" valign="bottom">
<table style="width: 100%;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="padding-bottom: 0px; vertical-align: bottom;" align="right" valign="bottom"><img style="vertical-align: bottom; padding-bottom: 10px;" src="https://pandorafms.com/images/alerta_roja.png" alt="" width="130"></td>
</tr>
</tbody>
</table>
</td>
</tr>
</tbody>
</table>
</center></td>
</tr>
<tr>
<td style="background-color: #f8f8f8; border-bottom: 1px solid #e7e7e7; padding-top: 10px;" valign="top"><center>
<table class="w320" style="height: 100%; width: 600px;" border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="mobile-padding" style="padding: 20px;" valign="top">
<table style="width: 100%;" border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="padding-right: 20px;" colspan="2"><strong>Monitoring details</strong></td>
</tr>
<tr>
<td style="padding-top: 25px; width: 150px; border-top: 1px solid #E7E7E7; vertical-align: top;"><strong>Data</strong></td>
<td style="padding-top: 25px; padding-right: 20px; border-top: 1px solid #E7E7E7; vertical-align: top;">_data_ <em>(_modulestatus_)</em></td>
</tr>
<tr>
<td><strong>Agent</strong></td>
<td>_agent_ <em>_address_</em></td>
</tr>
<tr>
<td><strong>Module</strong></td>
<td>_module_ <em>_moduledescription_ </em></td>
</tr>
<tr>
<td><strong>Timestamp</strong></td>
<td>_timestamp_</td>
</tr>
</tbody>
</table>
<table style="width: 100%;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="padding-top: 20px;">
<table style="width: 100%;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="vertical-align: top;" width="350">This is a graph of latest 24hr data for this module: <br><br> _modulegraph_24h_</td>
</tr>
</tbody>
</table>
</td>
</tr>
</tbody>
</table>
</td>
</tr>
</tbody>
</table>
</center></td>
</tr>
<tr>
<td style="background-color: #1f1f1f;"><center>
<table class="w320" style="height: 100%; color: #ffffff; width: 600px;" border="0" cellspacing="0" cellpadding="0" bgcolor="#1f1f1f">
<tbody>
<tr>
<td class="mobile-padding" style="font-size: 12px; padding: 20px; background-color: #1f1f1f; color: #ffffff; text-align: center;" align="right" valign="middle"><a style="color: #ffffff;" href="https://pandorafms.com/company/contact/">Contact Us</a> | <a style="color: #ffffff;" href="https://forums.pandorafms.com/">Support</a> | <a style="color: #ffffff;" href="https://wiki.pandorafms.com">Docs</a> | </td>
</tr>
</tbody>
</table>
</center></td>
</tr>
</tbody>
</table>
</td>
</tr>
</tbody>
</table>','','','','','','','',0,0,'','','<style type="text/css"><!--
/* Take care of image borders and formatting */
img {
max-width: 600px;
outline: none;
text-decoration: none;
-ms-interpolation-mode: bicubic;
}
a {
border: 0;
outline: none;
}
a img {
border: none;
}
/* General styling */
td, h1, h2, h3 {
font-family: Helvetica, Arial, sans-serif;
font-weight: 400;
}
td {
font-size: 14px;
line-height: 150%;
text-align: left;
}
body {
-webkit-font-smoothing:antialiased;
-webkit-text-size-adjust:none;
width: 100%;
height: 100%;
color: #37302d;
background: #ffffff;
}
table {
border-collapse: collapse !important;
}
h1, h2, h3 {
padding: 0;
margin: 0;
color: #444444;
font-weight: 400;
line-height: 110%;
}
h1 {
font-size: 35px;
}
h2 {
font-size: 30px;
}
h3 {
font-size: 24px;
}
h4 {
font-size: 18px;
font-weight: normal;
}
.important-font {
color: #21BEB4;
font-weight: bold;
}
.hide {
display: none !important;
}
.force-full-width {
width: 100% !important;
}
--></style>
<style type="text/css" media="screen"><!--
@media screen {
@import url(http://fonts.googleapis.com/css?family=Open+Sans:400);
/* Thanks Outlook 2013! */
td, h1, h2, h3 {
font-family: 'Open Sans', 'Helvetica Neue', Arial, sans-serif !important;
}
}
--></style>
<style type="text/css" media="only screen and (max-width: 600px)"><!--
/* Mobile styles */
@media only screen and (max-width: 600px) {
table[class="w320"] {
width: 320px !important;
}
table[class="w300"] {
width: 300px !important;
}
table[class="w290"] {
width: 290px !important;
}
td[class="w320"] {
width: 320px !important;
}
td[class~="mobile-padding"] {
padding-left: 14px !important;
padding-right: 14px !important;
}
td[class*="mobile-padding-left"] {
padding-left: 14px !important;
}
td[class*="mobile-padding-right"] {
padding-right: 14px !important;
}
td[class*="mobile-block"] {
display: block !important;
width: 100% !important;
text-align: left !important;
padding-left: 0 !important;
padding-right: 0 !important;
padding-bottom: 15px !important;
}
td[class*="mobile-no-padding-bottom"] {
padding-bottom: 0 !important;
}
td[class~="mobile-center"] {
text-align: center !important;
}
table[class*="mobile-center-block"] {
float: none !important;
margin: 0 auto !important;
}
*[class*="mobile-hide"] {
display: none !important;
width: 0 !important;
height: 0 !important;
line-height: 0 !important;
font-size: 0 !important;
}
td[class*="mobile-border"] {
border: 0 !important;
}
}
--></style>
<table style="width: 100%;" cellspacing="0" cellpadding="0" align="center">
<tbody>
<tr>
<td align="center" valign="top" bgcolor="#ffffff" width="100%">
<table style="width: 100%;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="background: #1f1f1f; height: 70px;" width="100%"><center>
<table class="w320" style="width: 600px;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="mobile-block mobile-no-padding-bottom mobile-center" style="background: #1f1f1f; padding: 10px 10px 10px 20px;" valign="top" width="270"><a style="text-decoration: none;" href="#"> <img src="https://pandorafms.com/images/logo_pandora_email.png" alt="Your Logo" width="200"> </a></td>
<td class="mobile-block mobile-center" style="background: #1f1f1f; padding: 17px 15px 10px 10px;" valign="top" width="270"> </td>
</tr>
</tbody>
</table>
</center></td>
</tr>
<tr>
<td style="border-bottom: 1px solid #e7e7e7;"><center style="padding-bottom: 20px;">
<table class="w320" style="width: 600px;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="mobile-padding" style="padding: 20px;" align="left"><br class="mobile-hide">
<h2>Pandora FMS alert system</h2>
<br> Dear customer,<br><br> We have <strong>good news</strong> for you. Alert has been <strong>RECOVERED</strong> status!<br> <br>
<table style="width: 100%;" cellspacing="0" cellpadding="0" bgcolor="#ffffff">
<tbody>
<tr>
<td style="width: 100px; background: #D84A38;">
<div><!--[if mso]>
<v:rect xmlns:v="urn:schemas-microsoft-com:vml" xmlns:w="urn:schemas-microsoft-com:office:word" href="#" style="height:33px;v-text-anchor:middle;width:100px;" stroke="f" fillcolor="#D84A38">
<w:anchorlock/>
<center>
<![endif]--> <a style="background-color: #1f1f1f; color: whitesmoke; display: inline-block; font-family: sans-serif; font-size: 13px; font-weight: bold; line-height: 33px; text-align: center; text-decoration: none; width: 250px; -webkit-text-size-adjust: none;" href="_homeurl_">Go to Pandora FMS Console</a> <!--[if mso]>
</center>
</v:rect>
<![endif]--></div>
</td>
<td style="background-color: #ffffff; font-size: 0; line-height: 0;" width="281"> </td>
</tr>
</tbody>
</table>
</td>
<td class="mobile-hide" style="padding-top: 20px; padding-bottom: 0; vertical-align: bottom;" valign="bottom">
<table style="width: 100%;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="padding-bottom: 0px; vertical-align: bottom;" align="right" valign="bottom"><img style="vertical-align: bottom; padding-bottom: 10px;" src="https://pandorafms.com/images/alerta_verde.png" alt="" width="130"></td>
</tr>
</tbody>
</table>
</td>
</tr>
</tbody>
</table>
</center></td>
</tr>
<tr>
<td style="background-color: #f8f8f8; border-bottom: 1px solid #e7e7e7; padding-top: 10px;" valign="top"><center>
<table class="w320" style="height: 100%; width: 600px;" border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td class="mobile-padding" style="padding: 20px;" valign="top">
<table style="width: 100%;" border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="padding-right: 20px;" colspan="2"><strong>Monitoring details</strong></td>
</tr>
<tr>
<td style="padding-top: 25px; width: 150px; border-top: 1px solid #E7E7E7; vertical-align: top;"><strong>Data</strong></td>
<td style="padding-top: 25px; padding-right: 20px; border-top: 1px solid #E7E7E7; vertical-align: top;">_data_ <em>(_modulestatus_)</em></td>
</tr>
<tr>
<td><strong>Agent</strong></td>
<td>_agent_ <em>_address_</em></td>
</tr>
<tr>
<td><strong>Module</strong></td>
<td>_module_ <em>_moduledescription_ </em></td>
</tr>
<tr>
<td><strong>Timestamp</strong></td>
<td>_timestamp_</td>
</tr>
</tbody>
</table>
<table style="width: 100%;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="padding-top: 20px;">
<table style="width: 100%;" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td style="vertical-align: top;" width="350">This is a graph of latest 24hr data for this module: <br><br> _modulegraph_24h_</td>
</tr>
</tbody>
</table>
</td>
</tr>
</tbody>
</table>
</td>
</tr>
</tbody>
</table>
</center></td>
</tr>
<tr>
<td style="background-color: #1f1f1f;"><center>
<table class="w320" style="height: 100%; color: #ffffff; width: 600px;" border="0" cellspacing="0" cellpadding="0" bgcolor="#1f1f1f">
<tbody>
<tr>
<td class="mobile-padding" style="font-size: 12px; padding: 20px; background-color: #1f1f1f; color: #ffffff; text-align: center;" align="right" valign="middle"><a style="color: #ffffff;" href="https://pandorafms.com/company/contact/">Contact Us</a> | <a style="color: #ffffff;" href="https://forums.pandorafms.com/">Support</a> | <a style="color: #ffffff;" href="https://wiki.pandorafms.com">Docs</a> | </td>
</tr>
</tbody>
</table>
</center></td>
</tr>
</tbody>
</table>
</td>
</tr>
</tbody>
</table>','text/html','','','','','','');
INSERT INTO `talert_actions` (`id`, `name`, `id_alert_command`, `field1`, `field2`, `field3`, `field4`, `field5`, `field6`, `field7`, `field8`, `field9`, `field10`, `id_group`, `action_threshold`, `field1_recovery`, `field2_recovery`, `field3_recovery`, `field4_recovery`, `field5_recovery`, `field6_recovery`, `field7_recovery`, `field8_recovery`, `field9_recovery`, `field10_recovery`) VALUES
(2,'Restart agent',12,'REFRESH AGENT *','','','','','','','','','',0,0,'','','','','','','','','','');
INSERT INTO `talert_actions` (`id`, `name`, `id_alert_command`, `field1`, `field2`, `field3`, `field4`, `field5`, `field6`, `field7`, `field8`, `field9`, `field10`, `id_group`, `action_threshold`, `field1_recovery`, `field2_recovery`, `field3_recovery`, `field4_recovery`, `field5_recovery`, `field6_recovery`, `field7_recovery`, `field8_recovery`, `field9_recovery`, `field10_recovery`) VALUES
diff --git a/pandora_server/DEBIAN/control b/pandora_server/DEBIAN/control
index 6415e64c41..737178fb8a 100644
--- a/pandora_server/DEBIAN/control
+++ b/pandora_server/DEBIAN/control
@@ -1,5 +1,5 @@
package: pandorafms-server
-Version: 7.0NG.714-171026
+Version: 7.0NG.716-171130
Architecture: all
Priority: optional
Section: admin
diff --git a/pandora_server/DEBIAN/make_deb_package.sh b/pandora_server/DEBIAN/make_deb_package.sh
index e51fa16f16..11a1afba0e 100644
--- a/pandora_server/DEBIAN/make_deb_package.sh
+++ b/pandora_server/DEBIAN/make_deb_package.sh
@@ -14,7 +14,7 @@
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
-pandora_version="7.0NG.714-171026"
+pandora_version="7.0NG.716-171130"
package_cpan=0
package_pandora=1
diff --git a/pandora_server/conf/pandora_server.conf.new b/pandora_server/conf/pandora_server.conf.new
index 3182f359e0..28b8e8aead 100644
--- a/pandora_server/conf/pandora_server.conf.new
+++ b/pandora_server/conf/pandora_server.conf.new
@@ -1,7 +1,7 @@
#############################################################################
# Pandora FMS Server Parameters
# Pandora FMS, the Flexible Monitoring System.
-# Version 7.0NG.714
+# Version 7.0NG.716
# Licensed under GPL license v2,
# (c) 2003-2017 Artica Soluciones Tecnologicas
# http://www.pandorafms.com
@@ -161,10 +161,10 @@ network_threads 4
# that ping should be 1 to report 1. Setting this to 1 will make all icmp montioring faster but
# with more probability of failure.
-icmp_checks 3
+icmp_checks 1
# Number of ICMP packets to send per request.
-icmp_packets 1
+icmp_packets 2
# tcp specific options :
# tcp_checks: number of tcp retries if first attempt fails.
diff --git a/pandora_server/conf/pandora_server.conf.windows b/pandora_server/conf/pandora_server.conf.windows
index 94b764de40..a1429970b1 100644
--- a/pandora_server/conf/pandora_server.conf.windows
+++ b/pandora_server/conf/pandora_server.conf.windows
@@ -164,10 +164,10 @@ network_threads 5
# that ping should be 1 to report 1. Lower value have better performance, but more probability
# of false positives
-icmp_checks 3
+icmp_checks 1
# Number of ICMP packets to send per request.
-icmp_packets 1
+icmp_packets 2
# tcp specific options :
# tcp_checks: number of tcp retries if first attempt fails.
diff --git a/pandora_server/lib/PandoraFMS/Config.pm b/pandora_server/lib/PandoraFMS/Config.pm
index 6255b0fc25..51d9f463c7 100644
--- a/pandora_server/lib/PandoraFMS/Config.pm
+++ b/pandora_server/lib/PandoraFMS/Config.pm
@@ -42,8 +42,8 @@ our @EXPORT = qw(
);
# version: Defines actual version of Pandora Server for this module only
-my $pandora_version = "7.0NG.714";
-my $pandora_build = "171026";
+my $pandora_version = "7.0NG.716";
+my $pandora_build = "171130";
our $VERSION = $pandora_version." ".$pandora_build;
# Setup hash
diff --git a/pandora_server/lib/PandoraFMS/Core.pm b/pandora_server/lib/PandoraFMS/Core.pm
index 7bff8272f9..bcb8534fc8 100644
--- a/pandora_server/lib/PandoraFMS/Core.pm
+++ b/pandora_server/lib/PandoraFMS/Core.pm
@@ -525,7 +525,7 @@ Process an alert given the status returned by pandora_evaluate_alert.
##########################################################################
sub pandora_process_alert ($$$$$$$$;$) {
my ($pa_config, $data, $agent, $module, $alert, $rc, $dbh, $timestamp, $extra_macros) = @_;
-
+
if (defined ($agent)) {
logger ($pa_config, "Processing alert '" . safe_output($alert->{'name'}) . "' for agent '" . safe_output($agent->{'nombre'}) . "': " . (defined ($AlertStatus[$rc]) ? $AlertStatus[$rc] : 'Unknown status') . ".", 10);
}
@@ -565,12 +565,12 @@ sub pandora_process_alert ($$$$$$$$;$) {
# Generate an event
if ($table eq 'tevent_alert') {
pandora_event ($pa_config, "Alert ceased (" .
- $alert->{'name'} . ")", 0, 0, $alert->{'priority'}, $id,
+ safe_output($alert->{'name'}) . ")", 0, 0, $alert->{'priority'}, $id,
(defined ($alert->{'id_agent_module'}) ? $alert->{'id_agent_module'} : 0),
"alert_ceased", 0, $dbh, 'Pandora', '', '', '', '', $critical_instructions, $warning_instructions, $unknown_instructions);
} else {
pandora_event ($pa_config, "Alert ceased (" .
- $alert->{'name'} . ")", $agent->{'id_grupo'},
+ safe_output($alert->{'name'}) . ")", $agent->{'id_grupo'},
$agent->{'id_agente'}, $alert->{'priority'}, $id,
(defined ($alert->{'id_agent_module'}) ? $alert->{'id_agent_module'} : 0),
"alert_ceased", 0, $dbh, 'Pandora', '', '', '', '', $critical_instructions, $warning_instructions, $unknown_instructions);
@@ -1014,6 +1014,8 @@ sub pandora_execute_action ($$$$$$$$$;$) {
_id_group_ => (defined ($group)) ? $group->{'id_grupo'} : '',
_id_alert_ => (defined ($alert->{'id_template_module'})) ? $alert->{'id_template_module'} : '',
_interval_ => (defined ($module) && $module->{'module_interval'} != 0) ? $module->{'module_interval'} : (defined ($agent)) ? $agent->{'intervalo'} : '',
+ _server_ip_ => (defined ($agent)) ? get_db_value($dbh, "SELECT ip_address FROM tserver WHERE name = ?", $agent->{'server_name'}) : '',
+ _server_name_ => (defined ($agent)) ? $agent->{'server_name'} : '',
_target_ip_ => (defined ($module)) ? $module->{'ip_target'} : '',
_target_port_ => (defined ($module)) ? $module->{'tcp_port'} : '',
_policy_ => undef,
@@ -1108,6 +1110,12 @@ sub pandora_execute_action ($$$$$$$$$;$) {
$field2 = subst_alert_macros ($field2, \%macros, $pa_config, $dbh, $agent, $module);
# Message
$field3 = subst_alert_macros ($field3, \%macros, $pa_config, $dbh, $agent, $module);
+ # Content
+ $field4 = subst_alert_macros ($field4, \%macros, $pa_config, $dbh, $agent, $module);
+
+ if($field4 eq ""){
+ $field4 = "text/html";
+ }
# Check for _module_graph_Xh_ macros
# Check for _module_graph_Xh_ macros and _module_graphth_Xh_
@@ -1165,13 +1173,13 @@ sub pandora_execute_action ($$$$$$$$$;$) {
};
# Default content type
- my $content_type = 'text/html; charset="iso-8859-1"';
+ my $content_type = $field4 . '; charset="iso-8859-1"';
# Check if message has non-ascii chars.
# non-ascii chars should be encoded in UTF-8.
if ($field3 =~ /[^[:ascii:]]/o) {
$field3 = encode("UTF-8", $field3);
- $content_type = 'text/html; charset="UTF-8"';
+ $content_type = $field4 . '; charset="UTF-8"';
}
@@ -1522,6 +1530,11 @@ sub pandora_process_module ($$$$$$$$$;$) {
# Update module status count.
$mark_for_update = 1;
+
+ # Safe mode execution.
+ if ($agent->{'safe_mode_module'} == $module->{'id_agente_modulo'}) {
+ safe_mode($pa_config, $agent, $module, $new_status, $known_status, $dbh);
+ }
}
# Set not-init modules to normal status even if min_ff_event is not matched the first time they receive data.
# if critical or warning status, just pass through here and wait the time min_ff_event will be matched.
@@ -1614,9 +1627,8 @@ sub pandora_planned_downtime_disabled_once_stop($$) {
db_do($dbh, 'UPDATE tplanned_downtime
SET executed = 0
WHERE id = ?', $downtime->{'id'});
-
pandora_event ($pa_config,
- '(Created by ' . $downtime->{'id_user'} . ') Server ' . $pa_config->{'servername'} . ' stopped planned downtime: ' . $downtime->{'name'}, 0, 0, 1, 0, 0, 'system', 0, $dbh);
+ '(Created by ' . $downtime->{'id_user'} . ') Server ' . $pa_config->{'servername'} . ' stopped planned downtime: ' . safe_output($downtime->{'name'}), 0, 0, 1, 0, 0, 'system', 0, $dbh);
pandora_planned_downtime_unset_disabled_elements($pa_config,
$dbh, $downtime);
@@ -1661,8 +1673,9 @@ sub pandora_planned_downtime_disabled_once_start($$) {
SET executed = 1
WHERE id = ?', $downtime->{'id'});
+ print"pandora_planned_downtime_disabled_once_start\n";
pandora_event ($pa_config,
- "(Created by " . $downtime->{'id_user'} . ") Server ".$pa_config->{'servername'}." started planned downtime: ".$downtime->{'name'}, 0, 0, 1, 0, 0, 'system', 0, $dbh);
+ "(Created by " . $downtime->{'id_user'} . ") Server ".$pa_config->{'servername'}." started planned downtime: ".safe_output($downtime->{'name'}), 0, 0, 1, 0, 0, 'system', 0, $dbh);
pandora_planned_downtime_set_disabled_elements($pa_config,
$dbh, $downtime);
@@ -1852,7 +1865,7 @@ sub pandora_planned_downtime_quiet_once_stop($$) {
SET executed = 0
WHERE id = ?', $downtime->{'id'});
pandora_event ($pa_config,
- "(Created by " . $downtime->{'id_user'} . ") Server ".$pa_config->{'servername'}." stopped planned downtime: ".$downtime->{'name'}, 0, 0, 1, 0, 0, 'system', 0, $dbh);
+ "(Created by " . $downtime->{'id_user'} . ") Server ".$pa_config->{'servername'}." stopped planned downtime: ".safe_output($downtime->{'name'}), 0, 0, 1, 0, 0, 'system', 0, $dbh);
pandora_planned_downtime_unset_quiet_elements($pa_config,
$dbh, $downtime->{'id'});
@@ -1893,8 +1906,9 @@ sub pandora_planned_downtime_quiet_once_start($$) {
db_do($dbh, 'UPDATE tplanned_downtime
SET executed = 1
WHERE id = ?', $downtime->{'id'});
+ print"pandora_planned_downtime_quiet_once_start\n";
pandora_event ($pa_config,
- "(Created by " . $downtime->{'id_user'} . ") Server ".$pa_config->{'servername'}." started planned downtime: ".$downtime->{'name'}, 0, 0, 1, 0, 0, 'system', 0, $dbh);
+ "(Created by " . $downtime->{'id_user'} . ") Server ".$pa_config->{'servername'}." started planned downtime: ".safe_output($downtime->{'name'}), 0, 0, 1, 0, 0, 'system', 0, $dbh);
pandora_planned_downtime_set_quiet_elements($pa_config,
$dbh, $downtime->{'id'});
@@ -1947,8 +1961,9 @@ sub pandora_planned_downtime_monthly_start($$) {
db_do($dbh, 'UPDATE tplanned_downtime
SET executed = 1
WHERE id = ?', $downtime->{'id'});
+ print"pandora_planned_downtime_monthly_start\n";
pandora_event ($pa_config,
- "Server ".$pa_config->{'servername'}." started planned downtime: ".$downtime->{'name'}, 0, 0, 1, 0, 0, 'system', 0, $dbh);
+ "Server ".$pa_config->{'servername'}." started planned downtime: ".safe_output($downtime->{'name'}), 0, 0, 1, 0, 0, 'system', 0, $dbh);
if ($downtime->{'type_downtime'} eq "quiet") {
@@ -2023,8 +2038,9 @@ sub pandora_planned_downtime_monthly_stop($$) {
db_do($dbh, 'UPDATE tplanned_downtime
SET executed = 0
WHERE id = ?', $downtime->{'id'});
+ print"pandora_planned_downtime_monthly_stop\n";
pandora_event ($pa_config,
- "Server ".$pa_config->{'servername'}." stopped planned downtime: ".$downtime->{'name'}, 0, 0, 1, 0, 0, 'system', 0, $dbh);
+ "Server ".$pa_config->{'servername'}." stopped planned downtime: ".safe_output($downtime->{'name'}), 0, 0, 1, 0, 0, 'system', 0, $dbh);
if ($downtime->{'type_downtime'} eq "quiet") {
pandora_planned_downtime_unset_quiet_elements($pa_config,
@@ -2132,8 +2148,9 @@ sub pandora_planned_downtime_weekly_start($$) {
db_do($dbh, 'UPDATE tplanned_downtime
SET executed = 1
WHERE id = ?', $downtime->{'id'});
+ print"pandora_planned_downtime_weekly_start\n";
pandora_event ($pa_config,
- "Server ".$pa_config->{'servername'}." started planned downtime: ".$downtime->{'name'}, 0, 0, 1, 0, 0, 'system', 0, $dbh);
+ "Server ".$pa_config->{'servername'}." started planned downtime: ".safe_output($downtime->{'name'}), 0, 0, 1, 0, 0, 'system', 0, $dbh);
if ($downtime->{'type_downtime'} eq "quiet") {
pandora_planned_downtime_set_quiet_elements($pa_config,
@@ -2246,8 +2263,10 @@ sub pandora_planned_downtime_weekly_stop($$) {
db_do($dbh, 'UPDATE tplanned_downtime
SET executed = 0
WHERE id = ?', $downtime->{'id'});
+
+ print"pandora_planned_downtime_weekly_stop\n";
pandora_event ($pa_config,
- "Server ".$pa_config->{'servername'}." stopped planned downtime: ".$downtime->{'name'}, 0, 0, 1, 0, 0, 'system', 0, $dbh);
+ "Server ".$pa_config->{'servername'}." stopped planned downtime: ".safe_output($downtime->{'name'}), 0, 0, 1, 0, 0, 'system', 0, $dbh);
if ($downtime->{'type_downtime'} eq "quiet") {
pandora_planned_downtime_unset_quiet_elements($pa_config,
@@ -2977,7 +2996,7 @@ sub pandora_create_agent ($$$$$$$$$$;$$$$$$$$$) {
}
logger ($pa_config, "Server '$server_name' CREATED agent '$agent_name' address '$address'.", 10);
- pandora_event ($pa_config, "Agent [$alias] created by $server_name", $group_id, $agent_id, 2, 0, 0, 'new_agent', 0, $dbh);
+ pandora_event ($pa_config, "Agent [" . safe_output($alias) . "] created by $server_name", $group_id, $agent_id, 2, 0, 0, 'new_agent', 0, $dbh);
return $agent_id;
}
@@ -4705,23 +4724,29 @@ sub pandora_self_monitoring ($$) {
$xml_output .="
$agents_unknown ";
$xml_output .=" ";
- $xml_output .="
";
- $xml_output .=" System_Load_AVG ";
- $xml_output .=" generic_data ";
- $xml_output .=" $load_average ";
- $xml_output .=" ";
+ if (defined($load_average)) {
+ $xml_output .="
";
+ $xml_output .=" System_Load_AVG ";
+ $xml_output .=" generic_data ";
+ $xml_output .=" $load_average ";
+ $xml_output .=" ";
+ }
- $xml_output .="
";
- $xml_output .=" Free_RAM ";
- $xml_output .=" generic_data ";
- $xml_output .=" $free_mem ";
- $xml_output .=" ";
+ if (defined($free_mem)) {
+ $xml_output .="
";
+ $xml_output .=" Free_RAM ";
+ $xml_output .=" generic_data ";
+ $xml_output .=" $free_mem ";
+ $xml_output .=" ";
+ }
- $xml_output .="
";
- $xml_output .=" FreeDisk_SpoolDir ";
- $xml_output .=" generic_data ";
- $xml_output .=" $free_disk_spool ";
- $xml_output .=" ";
+ if (defined($free_disk_spool)) {
+ $xml_output .="
";
+ $xml_output .=" FreeDisk_SpoolDir ";
+ $xml_output .=" generic_data ";
+ $xml_output .=" $free_disk_spool ";
+ $xml_output .=" ";
+ }
$xml_output .= "";
@@ -5459,6 +5484,30 @@ sub pandora_output_password($$) {
return $decrypted_password;
}
+##########################################################################
+=head2 C<< safe_mode (I<$pa_config>, I<$agent>, I<$module>, I<$new_status>, I<$known_status>, I<$dbh>) >>
+
+Execute safe mode for the given agent based on the status of the given module.
+
+=cut
+##########################################################################
+sub safe_mode($$$$$$) {
+ my ($pa_config, $agent, $module, $new_status, $known_status, $dbh) = @_;
+
+ return unless $agent->{'safe_mode_module'} > 0;
+
+ # Going to critical. Disable the rest of the modules.
+ if ($new_status == MODULE_CRITICAL) {
+ logger($pa_config, "Enabling safe mode for agent " . $agent->{'nombre'}, 10);
+ db_do($dbh, 'UPDATE tagente_modulo SET disabled=1 WHERE id_agente=? AND id_agente_modulo!=?', $agent->{'id_agente'}, $module->{'id_agente_modulo'});
+ }
+ # Coming back from critical. Enable the rest of the modules.
+ elsif ($known_status == MODULE_CRITICAL) {
+ logger($pa_config, "Disabling safe mode for agent " . $agent->{'nombre'}, 10);
+ db_do($dbh, 'UPDATE tagente_modulo SET disabled=0 WHERE id_agente=? AND id_agente_modulo!=?', $agent->{'id_agente'}, $module->{'id_agente_modulo'});
+ }
+}
+
# End of function declaration
# End of defined Code
diff --git a/pandora_server/lib/PandoraFMS/DataServer.pm b/pandora_server/lib/PandoraFMS/DataServer.pm
index ebd8f860ee..dab25b57e6 100644
--- a/pandora_server/lib/PandoraFMS/DataServer.pm
+++ b/pandora_server/lib/PandoraFMS/DataServer.pm
@@ -186,6 +186,7 @@ sub data_consumer ($$) {
for (0..1) {
eval {
threads->yield;
+
$xml_data = XMLin ($file_name, forcearray => 'module');
};
@@ -333,19 +334,22 @@ sub process_xml_data ($$$$$) {
if (defined ($data->{'group_id'}) && $data->{'group_id'} ne '') {
$group_id = $data->{'group_id'};
if (! defined (get_group_name ($dbh, $group_id))) {
- pandora_event ($pa_config, "Unable to create agent '$agent_name': group ID '" . $group_id . "' does not exist.", 0, 0, 0, 0, 0, 'error', 0, $dbh);
+ print "UNABLE GROUP ID\n";
+ pandora_event ($pa_config, "Unable to create agent '" . safe_output($agent_name) . "': group ID '" . $group_id . "' does not exist.", 0, 0, 0, 0, 0, 'error', 0, $dbh);
logger($pa_config, "Group ID " . $group_id . " does not exist.", 3);
return;
}
} elsif (defined ($data->{'group'}) && $data->{'group'} ne '') {
$group_id = get_group_id ($dbh, $data->{'group'});
if (! defined (get_group_name ($dbh, $group_id))) {
- pandora_event ($pa_config, "Unable to create agent '$agent_name': group '" . $data->{'group'} . "' does not exist.", 0, 0, 0, 0, 0, 'error', 0, $dbh);
+ print "UNABLE GROUP\n";
+ pandora_event ($pa_config, "Unable to create agent '" . safe_output($agent_name) . "': group '" . safe_output($data->{'group'}) . "' does not exist.", 0, 0, 0, 0, 0, 'error', 0, $dbh);
logger($pa_config, "Group " . $data->{'group'} . " does not exist.", 3);
return;
}
} else {
- pandora_event ($pa_config, "Unable to create agent '$agent_name': autocreate_group $group_id does not exist. Edit the pandora_server.conf file and change it.", 0, 0, 0, 0, 0, 'error', 0, $dbh);
+ print "UNABLE AUTOCREATE\n";
+ pandora_event ($pa_config, "Unable to create agent '" . safe_output($agent_name) . "': autocreate_group $group_id does not exist. Edit the pandora_server.conf file and change it.", 0, 0, 0, 0, 0, 'error', 0, $dbh);
logger($pa_config, "Group id $group_id does not exist (check autocreate_group config token).", 3);
return;
}
@@ -527,7 +531,7 @@ sub process_xml_data ($$$$$) {
# Single data
if (! defined ($module_data->{'datalist'})) {
my $data_timestamp = get_tag_value ($module_data, 'timestamp', $timestamp);
- process_module_data ($pa_config, $module_data, $server_id, $agent_name, $module_name, $module_type, $interval, $data_timestamp, $dbh, $new_agent);
+ process_module_data ($pa_config, $module_data, $server_id, $agent, $module_name, $module_type, $interval, $data_timestamp, $dbh, $new_agent);
next;
}
@@ -544,7 +548,7 @@ sub process_xml_data ($$$$$) {
$module_data->{'data'} = $data->{'value'};
my $data_timestamp = get_tag_value ($data, 'timestamp', $timestamp);
- process_module_data ($pa_config, $module_data, $server_id, $agent_name, $module_name,
+ process_module_data ($pa_config, $module_data, $server_id, $agent, $module_name,
$module_type, $interval, $data_timestamp, $dbh, $new_agent);
}
}
@@ -584,16 +588,16 @@ sub process_xml_data ($$$$$) {
# Process module data, creating module if necessary.
##########################################################################
sub process_module_data ($$$$$$$$$$) {
- my ($pa_config, $data, $server_id, $agent_name,
+ my ($pa_config, $data, $server_id, $agent,
$module_name, $module_type, $interval, $timestamp,
$dbh, $force_processing) = @_;
# Get agent data
- my $agent = get_db_single_row ($dbh, 'SELECT * FROM tagente WHERE nombre = ?', safe_input($agent_name));
if (! defined ($agent)) {
- logger($pa_config, "Invalid agent '$agent_name' for module '$module_name'.", 3);
+ logger($pa_config, "Invalid agent for module '$module_name'.", 3);
return;
}
+ my $agent_name = $agent->{'nombre'};
# Get module parameters, matching column names in tagente_modulo
my $module_conf;
diff --git a/pandora_server/lib/PandoraFMS/NetworkServer.pm b/pandora_server/lib/PandoraFMS/NetworkServer.pm
index ea433ad9ec..f52b6e8a72 100644
--- a/pandora_server/lib/PandoraFMS/NetworkServer.pm
+++ b/pandora_server/lib/PandoraFMS/NetworkServer.pm
@@ -344,10 +344,10 @@ sub pandora_query_snmp ($$$$) {
my $snmp_version = $module->{"tcp_send"}; # (1, 2, 2c or 3)
my $snmp3_privacy_method = $module->{"custom_string_1"}; # DES/AES
- my $snmp3_privacy_pass = pandora_output_password($pa_config, $module->{"custom_string_2"});
+ my $snmp3_privacy_pass = safe_output(pandora_output_password($pa_config, $module->{"custom_string_2"}));
my $snmp3_security_level = $module->{"custom_string_3"}; # noAuthNoPriv|authNoPriv|authPriv
- my $snmp3_auth_user = $module->{"plugin_user"};
- my $snmp3_auth_pass = pandora_output_password($pa_config, $module->{"plugin_pass"});
+ my $snmp3_auth_user = safe_output($module->{"plugin_user"});
+ my $snmp3_auth_pass = safe_output(pandora_output_password($pa_config, $module->{"plugin_pass"}));
my $snmp3_auth_method = $module->{"plugin_parameter"}; #MD5/SHA1
my $snmp_community = $module->{"snmp_community"};
my $snmp_target = $ip_target;
@@ -400,19 +400,19 @@ sub pandora_query_snmp ($$$$) {
# SNMP v3 no authentication and no privacy
if ($snmp3_security_level eq "noAuthNoPriv"){
- $snmp3_extra = " -u $snmp3_auth_user ";
+ $snmp3_extra = " -u '$snmp3_auth_user' ";
}
# SNMP v3 authentication only
if ($snmp3_security_level eq "authNoPriv"){
- $snmp3_extra = " -a $snmp3_auth_method -u $snmp3_auth_user -A $snmp3_auth_pass ";
+ $snmp3_extra = " -a $snmp3_auth_method -u '$snmp3_auth_user' -A '$snmp3_auth_pass' ";
}
# SNMP v3 privacy AND authentication
if ($snmp3_security_level eq "authPriv"){
- $snmp3_extra = " -a $snmp3_auth_method -u $snmp3_auth_user -A $snmp3_auth_pass -x $snmp3_privacy_method -X $snmp3_privacy_pass ";
+ $snmp3_extra = " -a $snmp3_auth_method -u '$snmp3_auth_user' -A '$snmp3_auth_pass' -x $snmp3_privacy_method -X '$snmp3_privacy_pass' ";
}
-
+
$output = pandora_snmp_get_command ($snmpget_cmd, $snmp_version, $snmp_retries, $snmp_timeout, $snmp_community, $snmp_target, $snmp_oid, $snmp3_security_level, $snmp3_extra, $snmp_port, $pa_config);
if (defined ($output) && $output ne ""){
$module_result = 0;
diff --git a/pandora_server/lib/PandoraFMS/ReconServer.pm b/pandora_server/lib/PandoraFMS/ReconServer.pm
index b25c222bf7..3261729569 100644
--- a/pandora_server/lib/PandoraFMS/ReconServer.pm
+++ b/pandora_server/lib/PandoraFMS/ReconServer.pm
@@ -421,7 +421,7 @@ sub PandoraFMS::Recon::Base::create_agent($$) {
$agent_id = pandora_create_agent($self->{'pa_config'}, $self->{'pa_config'}->{'servername'}, $host_name, $device, $self->{'group_id'}, 0, $id_os, '', 300, $self->{'dbh'});
return undef unless defined ($agent_id) and ($agent_id > 0);
- pandora_event($self->{'pa_config'}, "[RECON] New " . $self->get_device_type($device) . " found (" . join(',', $self->get_addresses($device)) . ").", $self->{'group_id'}, $agent_id, 2, 0, 0, 'recon_host_detected', 0, $self->{'dbh'});
+ pandora_event($self->{'pa_config'}, "[RECON] New " . safe_output($self->get_device_type($device)) . " found (" . join(',', safe_output($self->get_addresses($device))) . ").", $self->{'group_id'}, $agent_id, 2, 0, 0, 'recon_host_detected', 0, $self->{'dbh'});
$agent_learning = 1;
# Create network profile modules for the agent
diff --git a/pandora_server/lib/PandoraFMS/SNMPServer.pm b/pandora_server/lib/PandoraFMS/SNMPServer.pm
index bc7b3a708a..9328f56c68 100644
--- a/pandora_server/lib/PandoraFMS/SNMPServer.pm
+++ b/pandora_server/lib/PandoraFMS/SNMPServer.pm
@@ -196,10 +196,10 @@ sub pandora_snmptrapd {
my ($pa_config, $line, $server_id, $dbh) = @_;
(my $trap_ver, $line) = split(/\[\*\*\]/, $line, 2);
-
+print STDERR "ANTES";
# Process SNMP filter
next if (matches_filter ($dbh, $pa_config, $line) == 1);
-
+print STDERR "DESPUES";
logger($pa_config, "Reading trap '$line'", 10);
my ($date, $time, $source, $oid, $type, $type_desc, $value, $data) = ('', '', '', '', '', '', '', '');
@@ -345,22 +345,34 @@ sub pandora_snmptrapd {
sub matches_filter ($$$) {
my ($dbh, $pa_config, $string) = @_;
- # Get filters
- my @filters = get_db_rows ($dbh, 'SELECT filter FROM tsnmp_filter');
- foreach my $filter (@filters) {
- my $regexp = safe_output($filter->{'filter'}) ;
- my $eval_result;
+ my @filter_unique_functions = get_db_rows ($dbh, 'SELECT DISTINCT(unified_filters_id) FROM tsnmp_filter ORDER BY unified_filters_id');
+
+ foreach my $filter_unique_func (@filter_unique_functions) {
+ # Get filters
+ my @filters = get_db_rows ($dbh, 'SELECT filter FROM tsnmp_filter WHERE unified_filters_id = ' . $filter_unique_func->{'unified_filters_id'});
+
+ my $eval_acum = 1;
+ foreach my $filter (@filters) {
+ my $regexp = safe_output($filter->{'filter'}) ;
+ my $eval_result;
- # eval protects against server down (by invalid regular expressions)
- $eval_result = eval {
- $string =~ m/$regexp/i ;
- };
-
- if ($eval_result) {
- logger($pa_config, "Trap '$string' matches filter '$regexp'. Discarding...", 10);
- return 1;
- }
+ # eval protects against server down (by invalid regular expressions)
+ $eval_result = eval {
+ $string =~ m/$regexp/i ;
+ };
+ if ($eval_result && $eval_acum) {
+ $eval_acum = 1;
+ }
+ else {
+ $eval_acum = 0;
+ last;
+ }
+ }
+
+ if ($eval_acum) {
+ return 1;
+ }
}
return 0;
diff --git a/pandora_server/lib/PandoraFMS/Tools.pm b/pandora_server/lib/PandoraFMS/Tools.pm
index c69691cc66..2a3af2783e 100755
--- a/pandora_server/lib/PandoraFMS/Tools.pm
+++ b/pandora_server/lib/PandoraFMS/Tools.pm
@@ -68,6 +68,11 @@ our @EXPORT = qw(
$OS_VERSION
RECOVERED_ALERT
FIRED_ALERT
+ MODULE_NORMAL
+ MODULE_CRITICAL
+ MODULE_WARNING
+ MODULE_UNKNOWN
+ MODULE_NOTINIT
cron_get_closest_in_range
cron_next_execution
cron_next_execution_date
@@ -127,6 +132,13 @@ use constant MFSERVER => 15;
use constant SYNCSERVER => 16;
use constant WUXSERVER => 17;
+# Module status
+use constant MODULE_NORMAL => 0;
+use constant MODULE_CRITICAL => 1;
+use constant MODULE_WARNING => 2;
+use constant MODULE_UNKNOWN => 3;
+use constant MODULE_NOTINIT => 4;
+
# Value for a metaconsole license type
use constant METACONSOLE_LICENSE => 0x01;
@@ -151,6 +163,141 @@ if ($OS eq 'linux') {
}
chomp($OS_VERSION);
+# Entity to character mapping. Contains a few tweaks to make it backward compatible with the previous safe_input implementation.
+my %ENT2CHR = (
+ '#x00' => chr(0),
+ '#x01' => chr(1),
+ '#x02' => chr(2),
+ '#x03' => chr(3),
+ '#x04' => chr(4),
+ '#x05' => chr(5),
+ '#x06' => chr(6),
+ '#x07' => chr(7),
+ '#x08' => chr(8),
+ '#x09' => chr(9),
+ '#x0a' => chr(10),
+ '#x0b' => chr(11),
+ '#x0c' => chr(12),
+ '#x0d' => chr(13),
+ '#x0e' => chr(14),
+ '#x0f' => chr(15),
+ '#x10' => chr(16),
+ '#x11' => chr(17),
+ '#x12' => chr(18),
+ '#x13' => chr(19),
+ '#x14' => chr(20),
+ '#x15' => chr(21),
+ '#x16' => chr(22),
+ '#x17' => chr(23),
+ '#x18' => chr(24),
+ '#x19' => chr(25),
+ '#x1a' => chr(26),
+ '#x1b' => chr(27),
+ '#x1c' => chr(28),
+ '#x1d' => chr(29),
+ '#x1e' => chr(30),
+ '#x1f' => chr(31),
+ '#x20' => chr(32),
+ 'quot' => chr(34),
+ 'amp' => chr(38),
+ '#039' => chr(39),
+ '#40' => chr(40),
+ '#41' => chr(41),
+ 'lt' => chr(60),
+ 'gt' => chr(62),
+ '#92' => chr(92),
+ '#x80' => chr(128),
+ '#x81' => chr(129),
+ '#x82' => chr(130),
+ '#x83' => chr(131),
+ '#x84' => chr(132),
+ '#x85' => chr(133),
+ '#x86' => chr(134),
+ '#x87' => chr(135),
+ '#x88' => chr(136),
+ '#x89' => chr(137),
+ '#x8a' => chr(138),
+ '#x8b' => chr(139),
+ '#x8c' => chr(140),
+ '#x8d' => chr(141),
+ '#x8e' => chr(142),
+ '#x8f' => chr(143),
+ '#x90' => chr(144),
+ '#x91' => chr(145),
+ '#x92' => chr(146),
+ '#x93' => chr(147),
+ '#x94' => chr(148),
+ '#x95' => chr(149),
+ '#x96' => chr(150),
+ '#x97' => chr(151),
+ '#x98' => chr(152),
+ '#x99' => chr(153),
+ '#x9a' => chr(154),
+ '#x9b' => chr(155),
+ '#x9c' => chr(156),
+ '#x9d' => chr(157),
+ '#x9e' => chr(158),
+ '#x9f' => chr(159),
+ '#xa0' => chr(160),
+ '#xa1' => chr(161),
+ '#xa2' => chr(162),
+ '#xa3' => chr(163),
+ '#xa4' => chr(164),
+ '#xa5' => chr(165),
+ '#xa6' => chr(166),
+ '#xa7' => chr(167),
+ '#xa8' => chr(168),
+ '#xa9' => chr(169),
+ '#xaa' => chr(170),
+ '#xab' => chr(171),
+ '#xac' => chr(172),
+ '#xad' => chr(173),
+ '#xae' => chr(174),
+ '#xaf' => chr(175),
+ '#xb0' => chr(176),
+ '#xb1' => chr(177),
+ '#xb2' => chr(178),
+ '#xb3' => chr(179),
+ '#xb4' => chr(180),
+ '#xb5' => chr(181),
+ '#xb6' => chr(182),
+ '#xb7' => chr(183),
+ '#xb8' => chr(184),
+ '#xb9' => chr(185),
+ '#xba' => chr(186),
+ '#xbb' => chr(187),
+ '#xbc' => chr(188),
+ '#xbd' => chr(189),
+ '#xbe' => chr(190),
+ 'Aacute' => chr(193),
+ 'Auml' => chr(196),
+ 'Eacute' => chr(201),
+ 'Euml' => chr(203),
+ 'Iacute' => chr(205),
+ 'Iuml' => chr(207),
+ 'Ntilde' => chr(209),
+ 'Oacute' => chr(211),
+ 'Ouml' => chr(214),
+ 'Uacute' => chr(218),
+ 'Uuml' => chr(220),
+ 'aacute' => chr(225),
+ 'auml' => chr(228),
+ 'eacute' => chr(233),
+ 'euml' => chr(235),
+ 'iacute' => chr(237),
+ 'iuml' => chr(239),
+ 'ntilde' => chr(241),
+ 'oacute' => chr(243),
+ 'ouml' => chr(246),
+ 'uacute' => chr(250),
+ 'uuml' => chr(252),
+);
+
+# Construct the character to entity mapping.
+my %CHR2ENT;
+while (my ($ent, $chr) = each(%ENT2CHR)) {
+ $CHR2ENT{$chr} = "&" . $ent . ";";
+}
###############################################################################
# Sets user:group owner for the given file
@@ -201,49 +348,7 @@ sub pandora_trash_ascii {
sub safe_input($) {
my $value = shift;
- $value = encode_entities ($value, "<>&");
-
- #//Replace the character '\' for the equivalent html entitie
- $value =~ s/\\/\/gi;
-
- #// First attempt to avoid SQL Injection based on SQL comments
- #// Specific for MySQL.
- $value =~ s/\/\*//*/gi;
- $value =~ s/\*\//*//gi;
-
- #//Replace ' for the html entitie
- $value =~ s/\"/"/gi;
-
- #//Replace ' for the html entitie
- $value =~ s/\'/'/gi;
-
- #//Replace ( for the html entitie
- $value =~ s/\(/(/gi;
-
- #//Replace ( for the html entitie
- $value =~ s/\)/)/gi;
-
- #//Replace some characteres for html entities
- for (my $i=0;$i<33;$i++) {
- my $pattern = chr($i);
- my $hex = ascii_to_html($i);
- $value =~ s/$pattern/$hex/gi;
- }
-
- for (my $i=128;$i<191;$i++) {
- my $pattern = chr($i);
- my $hex = ascii_to_html($i);
- $value =~ s/$pattern/$hex/gi;
- }
-
- #//Replace characteres for tildes and others
- my $trans = get_html_entities();
-
- foreach(keys(%$trans))
- {
- my $pattern = chr($_);
- $value =~ s/$pattern/$trans->{$_}/g;
- }
+ $value =~ s/([\x00-\xFF])/$CHR2ENT{$1}||$1/ge;
return $value;
}
@@ -254,99 +359,11 @@ sub safe_input($) {
sub safe_output($) {
my $value = shift;
- $value = decode_entities ($value);
-
- #//Replace the character '\' for the equivalent html entitie
- $value =~ s/\/\\/gi;
-
- #// First attempt to avoid SQL Injection based on SQL comments
- #// Specific for MySQL.
- $value =~ s//*/\/\*/gi;
- $value =~ s/*//\*\//gi;
-
- #//Replace ( for the html entitie
- $value =~ s/(/\(/gi;
-
- #//Replace ( for the html entitie
- $value =~ s/)/\)/gi;
-
- #//Replace ' for the html entitie
- $value =~ s/'/')/gi;
-
- #//Replace " for the html entitie
- $value =~ s/"/")/gi;
-
- #//Replace some characteres for html entities
- for (my $i=0;$i<33;$i++) {
- my $pattern = chr($i);
- my $hex = ascii_to_html($i);
- $value =~ s/$hex/$pattern/gi;
- }
-
- for (my $i=128;$i<191;$i++) {
- my $pattern = chr($i);
- my $hex = ascii_to_html($i);
- $value =~ s/$hex/$pattern/gi;
- }
-
- #//Replace characteres for tildes and others
- my $trans = get_html_entities();
-
- foreach(keys(%$trans))
- {
- my $pattern = chr($_);
- $value =~ s/$trans->{$_}/$pattern/g;
- }
-
+ _decode_entities ($value, \%ENT2CHR);
+
return $value;
}
-##########################################################################
-# SUB get_html_entities
-# Returns a hash table with the acute and special html entities
-# Usefull for future chars addition:
-# http://cpansearch.perl.org/src/GAAS/HTML-Parser-3.68/lib/HTML/Entities.pm
-##########################################################################
-
-sub get_html_entities {
- my %trans = (
- 225 => 'á',
- 233 => 'é',
- 237 => 'í',
- 243 => 'ó',
- 250 => 'ú',
- 193 => 'Á',
- 201 => 'É',
- 205 => 'Í',
- 211 => 'Ó',
- 218 => 'Ú',
- 228 => 'ä',
- 235 => 'ë',
- 239 => 'ï',
- 246 => 'ö',
- 252 => 'ü',
- 196 => 'Ä',
- 203 => 'Ë',
- 207 => 'Ï',
- 214 => 'Ö',
- 220 => 'Ü',
- 241 => 'ñ',
- 209 => 'Ñ'
- );
-
- return \%trans;
-}
-########################################################################
-# SUB ascii_to_html (string)
-# Convert an ascii string to hexadecimal
-########################################################################
-
-sub ascii_to_html($) {
- my $ascii = shift;
-
- return "".substr(unpack("H*", pack("N", $ascii)),6,3).";";
-}
-
########################################################################
# Sub daemonize ()
# Put program in background (for daemon mode)
@@ -861,6 +878,24 @@ sub dateTimeToTimestamp {
sub disk_free ($) {
my $target = $_[0];
+ my $OSNAME = $^O;
+
+ # Get the free disk on data_in folder unit
+ if ($OSNAME eq "MSWin32") {
+ # Check relative path
+ my $unit;
+ if ($target =~ m/^([a-zA-Z]):/gi) {
+ $unit = $1/(1024*1024);
+ } else {
+ return;
+ }
+ # Get the free space of unit found
+ my $all_disk_info = `wmic logicaldisk get caption, freespace`;
+ if ($all_disk_info =~ m/$unit:\D*(\d+)/gmi){
+ return $1;
+ }
+ return;
+ }
# Try to use df command with Posix parameters...
my $command = "df -k -P ".$target." | tail -1 | awk '{ print \$4/1024}'";
my $output = `$command`;
@@ -874,6 +909,9 @@ sub load_average {
if ($OSNAME eq "freebsd"){
$load_average = ((split(/\s+/, `/sbin/sysctl -n vm.loadavg`))[1]);
+ } elsif ($OSNAME eq "MSWin32") {
+ # Windows hasn't got load average.
+ $load_average = undef;
}
# by default LINUX calls
else {
@@ -896,6 +934,14 @@ sub free_mem {
elsif ($OSNAME eq "netbsd"){
$free_mem = `cat /proc/meminfo | grep MemFree | awk '{ print \$2 }'`;
}
+ elsif ($OSNAME eq "MSWin32"){
+ $free_mem = `wmic OS get FreePhysicalMemory /Value`;
+ if ($free_mem =~ m/=(.*)$/gm) {
+ $free_mem = $1;
+ } else {
+ $free_mem = undef;
+ }
+ }
# by default LINUX calls
else {
$free_mem = `free | grep Mem | awk '{ print \$4 }'`;
@@ -1323,7 +1369,12 @@ sub cron_next_execution_date {
# Months start from 0
if($mon ne '*') {
- $mon -= 1;
+ my ($mon_down, $mon_up) = cron_get_interval ($mon);
+ if (defined($mon_up)) {
+ $mon = $mon_down - 1 . "-" . $mon_up - 1;
+ } else {
+ $mon = $mon_down - 1;
+ }
}
# Get current time
@@ -1338,76 +1389,113 @@ sub cron_next_execution_date {
my @cron_array = ($min, $hour, $mday, $mon);
my @curr_time_array = ($cur_min, $cur_hour, $cur_mday, $cur_mon);
return ($nex_time) if cron_is_in_cron(\@cron_array, \@curr_time_array) == 1;
-
- # Parse intervals
- ($min, undef) = cron_get_interval ($min);
- ($hour, undef) = cron_get_interval ($hour);
- ($mday, undef) = cron_get_interval ($mday);
- ($mon, undef) = cron_get_interval ($mon);
- # Get first next date candidate from cron configuration
- my ($nex_min, $nex_hour, $nex_mday, $nex_mon, $nex_year)
- = ($min, $hour, $mday, $mon, $cur_year);
+ # Get first next date candidate from next cron configuration
+ # Initialize some vars
+ my @nex_time_array = @curr_time_array;
+ my $prev_ovfl = 0;
- # Replace wildcards
- if ($min eq '*') {
- if ($hour ne '*' || $mday ne '*' || $wday ne '*' || $mon ne '*') {
- $nex_min = 0;
- }
- else {
- $nex_min = $cur_min;
- }
- }
- if ($hour eq '*') {
- if ($mday ne '*' || $wday ne '*' ||$mon ne '*') {
- $nex_hour = 0;
- }
- else {
- $nex_hour = $cur_hour;
- }
- }
- if ($mday eq '*') {
- if ($mon ne '*') {
- $nex_mday = 1;
- }
- else {
- $nex_mday = $cur_mday;
- }
- }
- if ($mon eq '*') {
- $nex_mon = $cur_mon;
+ # Update minutes
+ my ($min_down, undef) = cron_get_interval ($min);
+ $nex_time_array[0] = ($min_down eq '*') ? 0 : $min_down;
+
+ $nex_time = cron_valid_date(@nex_time_array, $cur_year);
+ if ($nex_time >= $cur_time) {
+ return $nex_time if cron_is_in_cron(\@cron_array, \@nex_time_array);
}
- # Find the next execution date
- my $count = 0;
- do {
- my $next_time = timelocal(0, $nex_min, $nex_hour, $nex_mday, $nex_mon, $nex_year);
- if ($next_time > $cur_time) {
- return $next_time;
- }
- if ($min eq '*' && $hour eq '*' && $wday eq '*' && $mday eq '*' && $mon eq '*') {
- ($nex_min, $nex_hour, $nex_mday, $nex_mon, $nex_year) = (localtime ($next_time + 60))[1, 2, 3, 4, 5];
- }
- elsif ($hour eq '*' && $wday eq '*' && $mday eq '*' && $mon eq '*') {
- ($nex_min, $nex_hour, $nex_mday, $nex_mon, $nex_year) = (localtime ($next_time + 3600))[1, 2, 3, 4, 5];
- }
- elsif ($mday eq '*' && $mon eq '*') {
- ($nex_min, $nex_hour, $nex_mday, $nex_mon, $nex_year) = (localtime ($next_time + 86400))[1, 2, 3, 4, 5];
- }
- elsif ($mon eq '*') {
- $nex_mon = $nex_mon + 1;
- if ($nex_mon > 11) {
- $nex_mon = 0;
- $nex_year++;
+ # Check if next hour is in cron
+ $nex_time_array[1]++;
+ $nex_time = cron_valid_date(@nex_time_array, $cur_year);
+
+ if ($nex_time == 0) {
+ #Update the month day if overflow
+ $prev_ovfl = 1;
+ $nex_time_array[1] = 0;
+ $nex_time_array[2]++;
+ $nex_time = cron_valid_date(@nex_time_array, $cur_year);
+ if ($nex_time == 0) {
+ #Update the month if overflow
+ $nex_time_array[2] = 1;
+ $nex_time_array[3]++;
+ $nex_time = cron_valid_date(@nex_time_array, $cur_year);
+ if ($nex_time == 0) {
+ #Update the year if overflow
+ $cur_year++;
+ $nex_time_array[3] = 0;
+ $nex_time = cron_valid_date(@nex_time_array, $cur_year);
}
}
- else {
- $nex_year++;
+ }
+ #Check the hour
+ return $nex_time if cron_is_in_cron(\@cron_array, \@nex_time_array);
+
+ #Update the hour if fails
+ my ($hour_down, undef) = cron_get_interval ($hour);
+ $nex_time_array[1] = ($hour_down eq '*') ? 0 : $hour_down;
+
+ # When an overflow is passed check the hour update again
+ if ($prev_ovfl) {
+ $nex_time = cron_valid_date(@nex_time_array, $cur_year);
+ return $nex_time if cron_is_in_cron(\@cron_array, \@nex_time_array);
+ }
+ $prev_ovfl = 0;
+
+ # Check if next day is in cron
+ $nex_time_array[2]++;
+ $nex_time = cron_valid_date(@nex_time_array, $cur_year);
+ if ($nex_time == 0) {
+ #Update the month if overflow
+ $prev_ovfl = 1;
+ $nex_time_array[2] = 1;
+ $nex_time_array[3]++;
+ $nex_time = cron_valid_date(@nex_time_array, $cur_year);
+ if ($nex_time == 0) {
+ #Update the year if overflow
+ $nex_time_array[3] = 0;
+ $cur_year++;
+ $nex_time = cron_valid_date(@nex_time_array, $cur_year);
}
- $count++;
- } while ($count < 60);
+ }
+ #Check the day
+ return $nex_time if cron_is_in_cron(\@cron_array, \@nex_time_array);
- # Something went wrong, default to 5 minutes
+ #Update the day if fails
+ my ($mday_down, undef) = cron_get_interval ($mday);
+ $nex_time_array[2] = ($mday_down eq '*') ? 1 : $mday_down;
+
+ # When an overflow is passed check the hour update in the next execution
+ if ($prev_ovfl) {
+ $nex_time = cron_valid_date(@nex_time_array, $cur_year);
+ return $nex_time if cron_is_in_cron(\@cron_array, \@nex_time_array);
+ }
+ $prev_ovfl = 0;
+
+ # Check if next month is in cron
+ $nex_time_array[3]++;
+ $nex_time = cron_valid_date(@nex_time_array, $cur_year);
+ if ($nex_time == 0) {
+ #Update the year if overflow
+ $prev_ovfl = 1;
+ $cur_year++;
+ $nex_time = cron_valid_date(@nex_time_array, $cur_year);
+ }
+
+ #Check the month
+ return $nex_time if cron_is_in_cron(\@cron_array, \@nex_time_array);
+
+ #Update the month if fails
+ my ($mon_down, undef) = cron_get_interval ($mon);
+ $nex_time_array[3] = ($mday_down eq '*') ? 0 : $mday_down;
+
+ # When an overflow is passed check the hour update in the next execution
+ if ($prev_ovfl) {
+ $nex_time = cron_valid_date(@nex_time_array, $cur_year);
+ return $nex_time if cron_is_in_cron(\@cron_array, \@nex_time_array);
+ }
+
+ $nex_time = cron_valid_date(@nex_time_array, $cur_year + 1);
+
return $nex_time;
}
###############################################################################
@@ -1417,9 +1505,12 @@ sub cron_next_execution_date {
###############################################################################
sub cron_is_in_cron {
my ($elems_cron, $elems_curr_time) = @_;
+
+ my @deref_elems_cron = @$elems_cron;
+ my @deref_elems_curr_time = @$elems_curr_time;
- my $elem_cron = shift(@$elems_cron);
- my $elem_curr_time = shift (@$elems_curr_time);
+ my $elem_cron = shift(@deref_elems_cron);
+ my $elem_curr_time = shift (@deref_elems_curr_time);
#If there is no elements means that is in cron
return 1 unless (defined($elem_cron) || defined($elem_curr_time));
@@ -1428,15 +1519,17 @@ sub cron_is_in_cron {
if ($elem_cron ne '*') {
my ($down, $up) = cron_get_interval($elem_cron);
# Check if there is no a range
- return 0 if (!defined($up) && ($down != $cron));
+ return 0 if (!defined($up) && ($down != $elem_curr_time));
# Check if there is on the range
- if ($down < $up) {
- return 0 if ($elem_curr_time < $down || $elem_curr_time > $up);
- } else {
- return 0 if ($elem_curr_time > $down || $elem_curr_time < $up);
+ if (defined($up)) {
+ if ($down < $up) {
+ return 0 if ($elem_curr_time < $down || $elem_curr_time > $up);
+ } else {
+ return 0 if ($elem_curr_time > $down || $elem_curr_time < $up);
+ }
}
}
- return cron_is_in_cron($elems_cron, $elems_curr_time);
+ return cron_is_in_cron(\@deref_elems_cron, \@deref_elems_curr_time);
}
###############################################################################
# Returns the interval of a cron element. If there is not a range,
@@ -1478,6 +1571,22 @@ sub cron_get_closest_in_range ($$) {
return $target;
}
+###############################################################################
+# Check if a date is valid to get timelocal
+###############################################################################
+sub cron_valid_date {
+ my ($min, $hour, $mday, $month, $year) = @_;
+ my $utime;
+ eval {
+ local $SIG{__DIE__} = sub {};
+ $utime = timelocal(0, $min, $hour, $mday, $month, $year);
+ };
+ if ($@) {
+ return 0;
+ }
+ return $utime;
+}
+
###############################################################################
# Attempt to resolve the given hostname.
###############################################################################
diff --git a/pandora_server/pandora_server.redhat.spec b/pandora_server/pandora_server.redhat.spec
index 66e70b3677..937f088aa0 100644
--- a/pandora_server/pandora_server.redhat.spec
+++ b/pandora_server/pandora_server.redhat.spec
@@ -2,8 +2,8 @@
# Pandora FMS Server
#
%define name pandorafms_server
-%define version 7.0NG.714
-%define release 171026
+%define version 7.0NG.716
+%define release 171130
Summary: Pandora FMS Server
Name: %{name}
diff --git a/pandora_server/pandora_server.spec b/pandora_server/pandora_server.spec
index 295529612b..d2ecac53a2 100644
--- a/pandora_server/pandora_server.spec
+++ b/pandora_server/pandora_server.spec
@@ -2,8 +2,8 @@
# Pandora FMS Server
#
%define name pandorafms_server
-%define version 7.0NG.714
-%define release 171026
+%define version 7.0NG.716
+%define release 171130
Summary: Pandora FMS Server
Name: %{name}
diff --git a/pandora_server/pandora_server_installer b/pandora_server/pandora_server_installer
index 88ce522133..1b2e016056 100755
--- a/pandora_server/pandora_server_installer
+++ b/pandora_server/pandora_server_installer
@@ -8,8 +8,8 @@
# This code is licensed under GPL 2.0 license.
# **********************************************************************
-PI_VERSION="7.0NG.714"
-PI_BUILD="171026"
+PI_VERSION="7.0NG.716"
+PI_BUILD="171130"
MODE=$1
if [ $# -gt 1 ]; then
diff --git a/pandora_server/util/pandora_db.pl b/pandora_server/util/pandora_db.pl
index 709180b7d0..ce7d59b791 100644
--- a/pandora_server/util/pandora_db.pl
+++ b/pandora_server/util/pandora_db.pl
@@ -33,7 +33,7 @@ use PandoraFMS::Tools;
use PandoraFMS::DB;
# version: define current version
-my $version = "7.0NG.714 PS171026";
+my $version = "7.0NG.716 PS171130";
# Pandora server configuration
my %conf;
diff --git a/pandora_server/util/pandora_manage.pl b/pandora_server/util/pandora_manage.pl
index 31ab30b672..e8a2b003a1 100644
--- a/pandora_server/util/pandora_manage.pl
+++ b/pandora_server/util/pandora_manage.pl
@@ -36,7 +36,7 @@ use Encode::Locale;
Encode::Locale::decode_argv;
# version: define current version
-my $version = "7.0NG.714 PS171026";
+my $version = "7.0NG.716 PS171130";
# save program name for logging
my $progname = basename($0);
@@ -4824,9 +4824,13 @@ sub cli_create_visual_console() {
my $label_position = $elem->{'label_position'};
my $border_color = $elem->{'border_color'};
my $fill_color = $elem->{'fill_color'};
+ my $show_statistics = $elem->{'fill_color'};
+ my $id_layout_linked_weight = $elem->{'id_layout_linked_weight'};
+ my $element_group = $elem->{'element_group'};
+ my $show_on_top = $elem->{'show_on_top'};
- my $elem_id = db_insert ($dbh, 'id', 'INSERT INTO tlayout_data (id_layout, pos_x, pos_y, height, width, label, image, type, period, id_agente_modulo, id_agent, id_layout_linked, parent_item, enable_link, id_metaconsole, id_group, id_custom_graph, border_width, type_graph, label_position, border_color, fill_color, show_statistics)
- VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)', $vc_id, $pos_x, $pos_y, $height, $width, $label, $image, $type, $period, $id_agente_modulo, $id_agent, $id_layout_linked, $parent_item, $enable_link, $id_metaconsole, $id_group, $id_custom_graph, $border_width, $type_graph, $label_position, $border_color, $fill_color, 0);
+ my $elem_id = db_insert ($dbh, 'id', 'INSERT INTO tlayout_data (id_layout, pos_x, pos_y, height, width, label, image, type, period, id_agente_modulo, id_agent, id_layout_linked, parent_item, enable_link, id_metaconsole, id_group, id_custom_graph, border_width, type_graph, label_position, border_color, fill_color, show_statistics, id_layout_linked_weight, element_group, show_on_top)
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)', $vc_id, $pos_x, $pos_y, $height, $width, $label, $image, $type, $period, $id_agente_modulo, $id_agent, $id_layout_linked, $parent_item, $enable_link, $id_metaconsole, $id_group, $id_custom_graph, $border_width, $type_graph, $label_position, $border_color, $fill_color, 0, $id_layout_linked_weight, $element_group, $show_on_top);
print_log "[INFO] The element id in position $elem_count is '$elem_id' \n\n";
@@ -4893,9 +4897,13 @@ sub cli_create_visual_console() {
my $label_position = $elem->{'label_position'};
my $border_color = $elem->{'border_color'};
my $fill_color = $elem->{'fill_color'};
+ my $id_layout_linked_weight = $elem->{'id_layout_linked_weight'};
+ my $element_group = $elem->{'element_group'};
+ my $show_on_top = $elem->{'show_on_top'};
+
- my $elem_id = db_insert ($dbh, 'id', 'INSERT INTO tlayout_data (id_layout, pos_x, pos_y, height, width, label, image, type, period, id_agente_modulo, id_agent, id_layout_linked, parent_item, enable_link, id_metaconsole, id_group, id_custom_graph, border_width, type_graph, label_position, border_color, fill_color, show_statistics)
- VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)', $vc_id, $pos_x, $pos_y, $height, $width, $label, $image, $type, $period, $id_agente_modulo, $id_agent, $id_layout_linked, $parent_item, $enable_link, $id_metaconsole, $id_group, $id_custom_graph, $border_width, $type_graph, $label_position, $border_color, $fill_color, 0);
+ my $elem_id = db_insert ($dbh, 'id', 'INSERT INTO tlayout_data (id_layout, pos_x, pos_y, height, width, label, image, type, period, id_agente_modulo, id_agent, id_layout_linked, parent_item, enable_link, id_metaconsole, id_group, id_custom_graph, border_width, type_graph, label_position, border_color, fill_color, show_statistics, id_layout_linked_weight, element_group, show_on_top)
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)', $vc_id, $pos_x, $pos_y, $height, $width, $label, $image, $type, $period, $id_agente_modulo, $id_agent, $id_layout_linked, $parent_item, $enable_link, $id_metaconsole, $id_group, $id_custom_graph, $border_width, $type_graph, $label_position, $border_color, $fill_color, 0, $id_layout_linked_weight, $element_group, $show_on_top);
print_log "[INFO] The element id in position $elem_count is '$elem_id' \n\n";
@@ -5001,6 +5009,9 @@ sub cli_edit_visual_console() {
my $new_label_position = $element_in_db->{'label_position'};
my $new_border_color = $element_in_db->{'border_color'};
my $new_fill_color = $element_in_db->{'fill_color'};
+ my $new_id_layout_linked_weight = $elem->{'id_layout_linked_weight'};
+ my $new_element_group = $elem->{'element_group'};
+ my $new_show_on_top = $elem->{'show_on_top'};
if(defined($elem->{'pos_x'})) {
$new_pos_x = $elem->{'pos_x'};
@@ -5065,6 +5076,15 @@ sub cli_edit_visual_console() {
if(defined($elem->{'fill_color'})) {
$new_fill_color = $elem->{'fill_color'};
}
+ if(defined($elem->{'id_layout_linked_weight'})) {
+ $new_id_layout_linked_weight = $elem->{'id_layout_linked_weight'};
+ }
+ if(defined($elem->{'element_group'})) {
+ $new_element_group = $elem->{'element_group'};
+ }
+ if(defined($elem->{'show_on_top'})) {
+ $new_show_on_top = $elem->{'show_on_top'};
+ }
db_update ($dbh, "UPDATE tlayout_data SET pos_x = " . $new_pos_x . ", pos_y = " . $new_pos_y . ", width = " . $new_width .
", height = " . $new_height . ", label = '" . $new_label . "', image = '" . $new_image .
@@ -5073,6 +5093,7 @@ sub cli_edit_visual_console() {
", enable_link = " . $new_enable_link . ", id_metaconsole = " . $new_id_metaconsole . ", id_group = " . $new_id_group .
", id_custom_graph = " . $new_id_custom_graph . ", border_width = " . $new_border_width . ", type_graph = '" . $new_type_graph .
"', label_position = '" . $new_label_position . "', border_color = '" . $new_border_color . "', fill_color = '" . $new_fill_color .
+ "', id_layout_linked_weight = '" . $new_id_layout_linked_weight . "', element_group = '" . $new_element_group . "', show_on_top = '" . $new_show_on_top .
"' WHERE id = " . $elem->{'id'});
print_log "[INFO] Element with id " . $elem->{'id'} . " has been updated \n\n";
@@ -5099,9 +5120,12 @@ sub cli_edit_visual_console() {
my $label_position = $elem->{'label_position'};
my $border_color = $elem->{'border_color'};
my $fill_color = $elem->{'fill_color'};
+ my $id_layout_linked_weight = $elem->{'id_layout_linked_weight'};
+ my $element_group = $elem->{'element_group'};
+ my $show_on_top = $elem->{'show_on_top'};
- my $new_elem_id = db_insert ($dbh, 'id', 'INSERT INTO tlayout_data (id_layout, pos_x, pos_y, height, width, label, image, type, period, id_agente_modulo, id_agent, id_layout_linked, parent_item, enable_link, id_metaconsole, id_group, id_custom_graph, border_width, type_graph, label_position, border_color, fill_color, show_statistics)
- VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)', $id, $pos_x, $pos_y, $height, $width, $label, $image, $type, $period, $id_agente_modulo, $id_agent, $id_layout_linked, $parent_item, $enable_link, $id_metaconsole, $id_group, $id_custom_graph, $border_width, $type_graph, $label_position, $border_color, $fill_color, 0);
+ my $new_elem_id = db_insert ($dbh, 'id', 'INSERT INTO tlayout_data (id_layout, pos_x, pos_y, height, width, label, image, type, period, id_agente_modulo, id_agent, id_layout_linked, parent_item, enable_link, id_metaconsole, id_group, id_custom_graph, border_width, type_graph, label_position, border_color, fill_color, show_statistics, id_layout_linked_weight, element_group, show_on_top)
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)', $id, $pos_x, $pos_y, $height, $width, $label, $image, $type, $period, $id_agente_modulo, $id_agent, $id_layout_linked, $parent_item, $enable_link, $id_metaconsole, $id_group, $id_custom_graph, $border_width, $type_graph, $label_position, $border_color, $fill_color, 0, $id_layout_linked_weight, $element_group, $show_on_top);
print_log "[INFO] New element with id $new_elem_id has been created \n\n";
}
@@ -5142,6 +5166,9 @@ sub cli_edit_visual_console() {
my $new_label_position = $element_in_db->{'label_position'};
my $new_border_color = $element_in_db->{'border_color'};
my $new_fill_color = $element_in_db->{'fill_color'};
+ my $new_id_layout_linked_weight = $elem->{'id_layout_linked_weight'};
+ my $new_element_group = $elem->{'element_group'};
+ my $new_show_on_top = $elem->{'show_on_top'};
if(defined($elem->{'width'})) {
$new_width = $elem->{'width'};
@@ -5200,6 +5227,15 @@ sub cli_edit_visual_console() {
if(defined($elem->{'fill_color'})) {
$new_fill_color = $elem->{'fill_color'};
}
+ if(defined($elem->{'id_layout_linked_weight'})) {
+ $new_id_layout_linked_weight = $elem->{'id_layout_linked_weight'};
+ }
+ if(defined($elem->{'element_group'})) {
+ $new_element_group = $elem->{'element_group'};
+ }
+ if(defined($elem->{'show_on_top'})) {
+ $new_show_on_top = $elem->{'show_on_top'};
+ }
db_update ($dbh, "UPDATE tlayout_data SET pos_x = " . $new_pos_x . ", pos_y = " . $new_pos_y . ", width = " . $new_width .
", height = " . $new_height . ", label = '" . $new_label . "', image = '" . $new_image .
@@ -5208,6 +5244,7 @@ sub cli_edit_visual_console() {
", enable_link = " . $new_enable_link . ", id_metaconsole = " . $new_id_metaconsole . ", id_group = " . $new_id_group .
", id_custom_graph = " . $new_id_custom_graph . ", border_width = " . $new_border_width . ", type_graph = '" . $new_type_graph .
"', label_position = '" . $new_label_position . "', border_color = '" . $new_border_color . "', fill_color = '" . $new_fill_color .
+ "', id_layout_linked_weight = '" . $new_id_layout_linked_weight . "', element_group = '" . $new_element_group . "', show_on_top = '" . $new_show_on_top .
"' WHERE id = " . $elem->{'id'});
print_log "[INFO] Element with id " . $elem->{'id'} . " has been updated \n\n";
@@ -5234,9 +5271,12 @@ sub cli_edit_visual_console() {
my $label_position = $elem->{'label_position'};
my $border_color = $elem->{'border_color'};
my $fill_color = $elem->{'fill_color'};
+ my $id_layout_linked_weight = $elem->{'id_layout_linked_weight'};
+ my $element_group = $elem->{'element_group'};
+ my $show_on_top = $elem->{'show_on_top'};
- my $new_elem_id = db_insert ($dbh, 'id', 'INSERT INTO tlayout_data (id_layout, pos_x, pos_y, height, width, label, image, type, period, id_agente_modulo, id_agent, id_layout_linked, parent_item, enable_link, id_metaconsole, id_group, id_custom_graph, border_width, type_graph, label_position, border_color, fill_color, show_statistics)
- VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)', $id, $pos_x, $pos_y, $height, $width, $label, $image, $type, $period, $id_agente_modulo, $id_agent, $id_layout_linked, $parent_item, $enable_link, $id_metaconsole, $id_group, $id_custom_graph, $border_width, $type_graph, $label_position, $border_color, $fill_color, 0);
+ my $new_elem_id = db_insert ($dbh, 'id', 'INSERT INTO tlayout_data (id_layout, pos_x, pos_y, height, width, label, image, type, period, id_agente_modulo, id_agent, id_layout_linked, parent_item, enable_link, id_metaconsole, id_group, id_custom_graph, border_width, type_graph, label_position, border_color, fill_color, show_statistics, id_layout_linked_weight, element_group, show_on_top)
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)', $id, $pos_x, $pos_y, $height, $width, $label, $image, $type, $period, $id_agente_modulo, $id_agent, $id_layout_linked, $parent_item, $enable_link, $id_metaconsole, $id_group, $id_custom_graph, $border_width, $type_graph, $label_position, $border_color, $fill_color, 0, $id_layout_linked_weight, $element_group, $show_on_top);
print_log "[INFO] New element with id $new_elem_id has been created \n\n";
}
@@ -5441,9 +5481,12 @@ sub cli_duplicate_visual_console () {
my $label_position = $element->{'label_position'};
my $border_color = $element->{'border_color'};
my $fill_color = $element->{'fill_color'};
+ my $id_layout_linked_weight = $element->{'id_layout_linked_weight'};
+ my $element_group = $element->{'element_group'};
+ my $show_on_top = $element->{'show_on_top'};
- my $element_id = db_insert ($dbh, 'id', 'INSERT INTO tlayout_data (id_layout, pos_x, pos_y, height, width, label, image, type, period, id_agente_modulo, id_agent, id_layout_linked, parent_item, enable_link, id_metaconsole, id_group, id_custom_graph, border_width, type_graph, label_position, border_color, fill_color, show_statistics)
- VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)', $new_console_id, $pos_x, $pos_y, $height, $width, $label, $image, $type, $period, $id_agente_modulo, $id_agent, $id_layout_linked, $parent_item, $enable_link, $id_metaconsole, $id_group, $id_custom_graph, $border_width, $type_graph, $label_position, $border_color, $fill_color, 0);
+ my $element_id = db_insert ($dbh, 'id', 'INSERT INTO tlayout_data (id_layout, pos_x, pos_y, height, width, label, image, type, period, id_agente_modulo, id_agent, id_layout_linked, parent_item, enable_link, id_metaconsole, id_group, id_custom_graph, border_width, type_graph, label_position, border_color, fill_color, show_statistics, id_layout_linked_weight, element_group, show_on_top)
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)', $new_console_id, $pos_x, $pos_y, $height, $width, $label, $image, $type, $period, $id_agente_modulo, $id_agent, $id_layout_linked, $parent_item, $enable_link, $id_metaconsole, $id_group, $id_custom_graph, $border_width, $type_graph, $label_position, $border_color, $fill_color, 0, $id_layout_linked_weight, $element_group, $show_on_top);
print_log "[INFO] Element with ID " . $element->{"id"} . " has been duplicated to the new console \n\n";
}
@@ -5509,6 +5552,9 @@ sub cli_export_visual_console() {
my $label_position = $element->{'label_position'};
my $border_color = $element->{'border_color'};
my $fill_color = $element->{'fill_color'};
+ my $id_layout_linked_weight = $element->{'id_layout_linked_weight'};
+ my $element_group = $element->{'element_group'};
+ my $show_on_top = $element->{'show_on_top'};
if ($first == 0) {
$data_to_json .= ','
@@ -5546,6 +5592,9 @@ sub cli_export_visual_console() {
$data_to_json .= ',"label_position":"' . $label_position . '"';
$data_to_json .= ',"border_color":"' . $border_color . '"';
$data_to_json .= ',"fill_color":"' . $fill_color . '"';
+ $data_to_json .= ',"id_layout_linked_weight":' . $id_layout_linked_weight;
+ $data_to_json .= ',"element_group":' . $element_group;
+ $data_to_json .= ',"show_on_top":' . $show_on_top;
$data_to_json .= '}';
}
diff --git a/pandora_server/util/pwrd/install_pwrd.sh b/pandora_server/util/pwrd/install_pwrd.sh
index 66cb0a9795..2de6b11e3d 100644
--- a/pandora_server/util/pwrd/install_pwrd.sh
+++ b/pandora_server/util/pwrd/install_pwrd.sh
@@ -45,7 +45,7 @@ ln -s $PWR_FIREFOX_INSTALLDIR/firefox/firefox /usr/bin/firefox
# Generate logrotate configuration
-echo <
/etc/logrotate.d/pwrd
+cat > /etc/logrotate.d/pwrd <