";
$xml = sprintf(
$xmlTemplate,
io_safe_output(get_os_name($agent['id_os'])),
io_safe_output($agent['os_version']),
$agent['intervalo'],
io_safe_output($agent['agent_version']),
$time,
io_safe_output($agent['nombre']),
io_safe_output($agentModule['nombre']),
io_safe_output($agentModule['descripcion']),
modules_get_type_name($agentModule['id_tipo_modulo']),
$data
);
$file_name = $config['remote_config'].'/'.io_safe_output($agent['alias']).'.'.strtotime($time).'.data';
return (bool) @file_put_contents($file_name, $xml);
}
function mainInsertData()
{
global $config;
ui_print_standard_header(
__('Insert Data'),
'images/extensions.png',
false,
'',
true,
[],
[
[
'link' => '',
'label' => __('Resources'),
],
[
'link' => '',
'label' => __('Insert Data'),
],
]
);
if (! check_acl($config['id_user'], 0, 'AW') && ! is_user_admin($config['id_user'])) {
db_pandora_audit(
AUDIT_LOG_ACL_VIOLATION,
'Trying to access Setup Management'
);
include 'general/noaccess.php';
return;
}
$save = (bool) get_parameter('save');
$agent_id = (int) get_parameter('agent_id');
$agent_name = (string) get_parameter('agent_name');
$id_agent_module = (int) get_parameter('id_agent_module');
$data = (string) get_parameter('data');
$date = (string) get_parameter('date', date(DATE_FORMAT));
$time = (string) get_parameter('time', date(TIME_FORMAT));
if (isset($_FILES['csv'])) {
if ($_FILES['csv']['error'] != 4) {
$csv = $_FILES['csv'];
} else {
$csv = false;
}
} else {
$csv = false;
}
ui_print_warning_message(
sprintf(
__('Please check that the directory "%s" is writeable by the apache user.
The CSV file format is date;value<newline>date;value<newline>... The date in CSV is in format Y/m/d H:i:s.'),
$config['remote_config']
)
);
if ($save) {
if (!check_acl($config['id_user'], agents_get_agent_group($agent_id), 'AW')) {
ui_print_error_message(__('You haven\'t privileges for insert data in the agent.'));
} else {
$agent = db_get_row_filter('tagente', ['id_agente' => $agent_id]);
$agentModule = db_get_row_filter('tagente_modulo', ['id_agente_modulo' => $id_agent_module]);
$done = 0;
$errors = 0;
if ($csv !== false) {
$file = file($csv['tmp_name']);
foreach ($file as $line) {
$tokens = explode(';', $line);
$utimestamp = (strtotime(trim($tokens[0])) - get_fixed_offset());
$timestamp = date(DATE_FORMAT.' '.TIME_FORMAT, $utimestamp);
$result = createXMLData($agent, $agentModule, $timestamp, trim($tokens[1]));
if ($result) {
$done++;
} else {
$errors++;
}
}
} else {
$utimestamp = (strtotime($date.' '.$time) - get_fixed_offset());
$timestamp = date(DATE_FORMAT.' '.TIME_FORMAT, $utimestamp);
$result = createXMLData($agent, $agentModule, $timestamp, $data);
if ($result) {
$done++;
} else {
$errors++;
}
}
}
if ($errors > 0) {
$msg = sprintf(__('Can\'t save agent (%s), module (%s) data xml.'), $agent['alias'], $agentModule['nombre']);
if ($errors > 1) {
$msg .= " ($errors)";
}
ui_print_error_message($msg);
}
if ($done > 0) {
$msg = sprintf(__('Save agent (%s), module (%s) data xml.'), $agent['alias'], $agentModule['nombre']);
if ($done > 1) {
$msg .= " ($done)";
}
ui_print_success_message($msg);
}
}
$modules = [];
if ($agent_id > 0) {
$modules = agents_get_modules($agent_id, false, ['delete_pending' => 0]);
}
$table = new stdClass();
$table->class = 'databox filter-table-adv';
$table->style = [];
$table->cellstyle[0][0] = 'width: 0';
$table->cellstyle[0][1] = 'width: 0';
$table->data = [];
$table->data[0][0] = '';
$table->data[0][1] = '';
$table->data[0][2] = '';
$params = [];
$params['return'] = true;
$params['show_helptip'] = true;
$params['input_name'] = 'agent_name';
$params['value'] = ($save === true) ? '' : $agent_name;
$params['javascript_is_function_select'] = true;
$params['javascript_name_function_select'] = 'custom_select_function';
$params['javascript_code_function_select'] = '';
$params['use_hidden_input_idagent'] = true;
$params['print_hidden_input_idagent'] = true;
$params['hidden_input_idagent_id'] = 'hidden-autocomplete_id_agent';
$params['hidden_input_idagent_name'] = 'agent_id';
$params['hidden_input_idagent_value'] = $agent_id;
$table->data[1][0] = html_print_div(['class' => 'flex flex-items-center', 'content' => ui_print_agent_autocomplete_input($params)], true);
$table->data[1][1] = html_print_select(
$modules,
'id_agent_module',
($save === true) ? '' : $id_agent_module,
true,
__('Select'),
0,
true,
false,
true,
'',
empty($agent_id)
);
$table->data[1][2] = html_print_input_text('date', ($save === true) ? date(DATE_FORMAT) : $data, __('Data'), 10, 60, true);
$table->data[1][2] .= ' ';
$table->data[1][2] .= html_print_input_text('time', ($save === true) ? date(TIME_FORMAT) : $time, '', 10, 7, true);
$table->data[2][0] = '';
$table->data[2][1] = '';
$table->data[3][0] = html_print_input_text(
'data',
$data,
__('Data'),
40,
60,
true
);
$table->data[3][1] = html_print_div(
[
'class' => '',
'content' => html_print_input_file('csv', true),
],
true
);
echo "';
ui_require_css_file('datepicker');
ui_include_time_picker();
ui_require_jquery_file('ui.datepicker-'.get_user_language(), 'include/javascript/i18n/');
?>