From 3fa8f99f3390416503d6fe23eaa5cada8bc00f0f Mon Sep 17 00:00:00 2001 From: m-lopez-f Date: Tue, 9 Feb 2016 10:20:42 +0100 Subject: [PATCH] Fixed problems with create syntethic module with API. (cherry picked from commit 3315b732f891b83c4fc26cdebb5d2d14a139e9eb) --- pandora_console/include/functions_api.php | 70 ++++++++++++++++++++--- 1 file changed, 62 insertions(+), 8 deletions(-) diff --git a/pandora_console/include/functions_api.php b/pandora_console/include/functions_api.php index e717d5025d..b56e96451e 100644 --- a/pandora_console/include/functions_api.php +++ b/pandora_console/include/functions_api.php @@ -2200,13 +2200,15 @@ function api_set_create_synthetic_module($id, $thrash1, $other, $thrash3) { $name = io_safe_output($other['data'][0]); $name = io_safe_input($name); + $id_tipo_modulo = db_get_row_sql ("SELECT id_tipo FROM ttipo_modulo WHERE nombre = 'generic_data'"); $values = array( 'id_agente' => $idAgent, 'id_modulo' => 5, 'custom_integer_1' => 0, 'custom_integer_2' => 0, - 'prediction_module' => 3, + 'prediction_module' => 3, + 'id_tipo_modulo' => $id_tipo_modulo['id_tipo'] ); if ( ! $values['descripcion'] ) { @@ -2235,7 +2237,7 @@ function api_set_create_synthetic_module($id, $thrash1, $other, $thrash3) { returnError("","[ERROR] With this type: $synthetic_type only be allow use this operator: 'x' \n\n"); } - $operator = $split_data[0] == 'x' ? 'avg' : $split_data[0]; + $operator = strtolower($split_data[0]); $data_module = array("",$operator,$split_data[1]); $text_data = implode('_',$data_module); @@ -2249,15 +2251,17 @@ function api_set_create_synthetic_module($id, $thrash1, $other, $thrash3) { array_push($filterdata,$text_data); } else { - if (strlen($split_data[1]) > 1 ) { + if (strlen($split_data[1]) > 1 && $synthetic_type != 'average' ) { returnError("","[ERROR] You can only use +, -, *, / or x, and you use this: @split_data[1] \n\n"); + return; } if ( preg_match("/[\/|+|*|-]/",$split_data[1]) && $synthetic_type === 'average' ) { returnError("","[ERROR] With this type: $synthetic_type only be allow use this operator: 'x' \n\n"); + return; } $idAgent = agents_get_agent_id(io_safe_output($split_data[0]),true); - $operator = $split_data[1] == 'x' ? 'avg' : $split_data[1]; + $operator = strtolower($split_data[1]); $data_module = array($idAgent,$operator,$split_data[2]); $text_data = implode('_',$data_module); array_push($filterdata,$text_data); @@ -2272,14 +2276,64 @@ function api_set_create_synthetic_module($id, $thrash1, $other, $thrash3) { array($idModule, $serialize_ops)); if ($synthetic === ENTERPRISE_NOT_HOOK) { - returnError('error_policy_modules', 'Error Synthetic modules.'); + returnError('error_synthetic_modules', 'Error Synthetic modules.'); + db_process_sql_delete ('tagente_modulo', + array ('id_agente_modulo' => $idModule)); return; } else { - returnData('string', array('type' => 'string', 'data' => __('Synthetic module created ID: ' . $idModule))); + $status = AGENT_MODULE_STATUS_NO_DATA; + switch ($config["dbtype"]) { + case "mysql": + $result = db_process_sql_insert ('tagente_estado', + array ('id_agente_modulo' => $idModule, + 'datos' => 0, + 'timestamp' => '01-01-1970 00:00:00', + 'estado' => $status, + 'id_agente' => (int) $idAgent, + 'utimestamp' => 0, + 'status_changes' => 0, + 'last_status' => $status, + 'last_known_status' => $status + )); + break; + case "postgresql": + $result = db_process_sql_insert ('tagente_estado', + array ('id_agente_modulo' => $idModule, + 'datos' => 0, + 'timestamp' => null, + 'estado' => $status, + 'id_agente' => (int) $idAgent, + 'utimestamp' => 0, + 'status_changes' => 0, + 'last_status' => $status, + 'last_known_status' => $status + )); + break; + case "oracle": + $result = db_process_sql_insert ('tagente_estado', + array ('id_agente_modulo' => $idModule, + 'datos' => 0, + 'timestamp' => '#to_date(\'1970-01-01 00:00:00\', \'YYYY-MM-DD HH24:MI:SS\')', + 'estado' => $status, + 'id_agente' => (int) $idAgent, + 'utimestamp' => 0, + 'status_changes' => 0, + 'last_status' => $status, + 'last_known_status' => $status + )); + break; + } + if ($result === false) { + db_process_sql_delete ('tagente_modulo', + array ('id_agente_modulo' => $idModule)); + returnError('error_synthetic_modules', 'Error Synthetic modules.'); + } + else { + db_process_sql ('UPDATE tagente SET total_count=total_count+1, notinit_count=notinit_count+1 WHERE id_agente=' . (int)$idAgent); + returnData('string', array('type' => 'string', 'data' => __('Synthetic module created ID: ' . $idModule))); + } } - - //enterprise } }