Fixed problems with create syntethic module with API.

(cherry picked from commit 3315b732f8)
This commit is contained in:
m-lopez-f 2016-02-09 10:20:42 +01:00
parent 60218d5616
commit 3fa8f99f33
1 changed files with 62 additions and 8 deletions

View File

@ -2200,13 +2200,15 @@ function api_set_create_synthetic_module($id, $thrash1, $other, $thrash3) {
$name = io_safe_output($other['data'][0]); $name = io_safe_output($other['data'][0]);
$name = io_safe_input($name); $name = io_safe_input($name);
$id_tipo_modulo = db_get_row_sql ("SELECT id_tipo FROM ttipo_modulo WHERE nombre = 'generic_data'");
$values = array( $values = array(
'id_agente' => $idAgent, 'id_agente' => $idAgent,
'id_modulo' => 5, 'id_modulo' => 5,
'custom_integer_1' => 0, 'custom_integer_1' => 0,
'custom_integer_2' => 0, 'custom_integer_2' => 0,
'prediction_module' => 3, 'prediction_module' => 3,
'id_tipo_modulo' => $id_tipo_modulo['id_tipo']
); );
if ( ! $values['descripcion'] ) { 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"); 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]); $data_module = array("",$operator,$split_data[1]);
$text_data = implode('_',$data_module); $text_data = implode('_',$data_module);
@ -2249,15 +2251,17 @@ function api_set_create_synthetic_module($id, $thrash1, $other, $thrash3) {
array_push($filterdata,$text_data); array_push($filterdata,$text_data);
} }
else { 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"); 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' ) { 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"); 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); $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]); $data_module = array($idAgent,$operator,$split_data[2]);
$text_data = implode('_',$data_module); $text_data = implode('_',$data_module);
array_push($filterdata,$text_data); array_push($filterdata,$text_data);
@ -2272,14 +2276,64 @@ function api_set_create_synthetic_module($id, $thrash1, $other, $thrash3) {
array($idModule, $serialize_ops)); array($idModule, $serialize_ops));
if ($synthetic === ENTERPRISE_NOT_HOOK) { 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; return;
} }
else { 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
} }
} }