2019-02-15 18:05:59 +01:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Extension to schedule tasks on Pandora FMS Console
|
|
|
|
*
|
|
|
|
* @category Wizard
|
|
|
|
* @package Pandora FMS
|
|
|
|
* @subpackage Host&Devices
|
|
|
|
* @version 1.0.0
|
|
|
|
* @license See below
|
|
|
|
*
|
|
|
|
* ______ ___ _______ _______ ________
|
2023-06-08 12:42:10 +02:00
|
|
|
* | __ \.-----.--.--.--| |.-----.----.-----. | ___| | | __|
|
|
|
|
* | __/| _ | | _ || _ | _| _ | | ___| |__ |
|
2019-02-15 18:05:59 +01:00
|
|
|
* |___| |___._|__|__|_____||_____|__| |___._| |___| |__|_|__|_______|
|
|
|
|
*
|
|
|
|
* ============================================================================
|
2023-06-08 11:53:13 +02:00
|
|
|
* Copyright (c) 2005-2023 Pandora FMS
|
2023-06-08 13:19:01 +02:00
|
|
|
* Please see https://pandorafms.com/community/ for full contribution list
|
2019-02-15 18:05:59 +01:00
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation for version 2.
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
* ============================================================================
|
|
|
|
*/
|
|
|
|
|
2020-03-16 23:52:20 +01:00
|
|
|
global $config;
|
|
|
|
|
|
|
|
require_once $config['homedir'].'/include/class/HTML.class.php';
|
2019-02-15 18:05:59 +01:00
|
|
|
require_once $config['homedir'].'/include/functions_users.php';
|
2019-02-22 12:53:35 +01:00
|
|
|
require_once $config['homedir'].'/include/functions_reports.php';
|
|
|
|
require_once $config['homedir'].'/include/functions_cron.php';
|
2023-08-09 14:40:56 +02:00
|
|
|
require_once $config['homedir'].'/godmode/wizards/Wizard.main.php';
|
|
|
|
|
2019-03-01 15:26:05 +01:00
|
|
|
enterprise_include_once('include/functions_tasklist.php');
|
|
|
|
enterprise_include_once('include/functions_cron.php');
|
2019-02-15 18:05:59 +01:00
|
|
|
|
2019-03-07 14:45:26 +01:00
|
|
|
ui_require_css_file('task_list');
|
2020-03-16 23:52:20 +01:00
|
|
|
ui_require_css_file('simTree');
|
|
|
|
ui_require_javascript_file('simTree');
|
2019-03-07 14:45:26 +01:00
|
|
|
|
2019-02-15 18:05:59 +01:00
|
|
|
/**
|
|
|
|
* Defined as wizard to guide user to explore running tasks.
|
|
|
|
*/
|
2020-03-16 23:52:20 +01:00
|
|
|
class DiscoveryTaskList extends HTML
|
2019-02-15 18:05:59 +01:00
|
|
|
{
|
|
|
|
|
2024-01-17 12:25:57 +01:00
|
|
|
/**
|
|
|
|
* Task properties.
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
public $task;
|
|
|
|
|
2019-02-15 18:05:59 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructor.
|
|
|
|
*
|
|
|
|
* @param integer $page Start page, by default 0.
|
|
|
|
* @param string $msg Custom default mesage.
|
|
|
|
* @param string $icon Custom icon.
|
|
|
|
* @param string $label Custom label.
|
|
|
|
*
|
|
|
|
* @return class HostDevices
|
|
|
|
*/
|
|
|
|
public function __construct(
|
|
|
|
int $page=0,
|
|
|
|
string $msg='Default message. Not set.',
|
2019-02-21 13:05:48 +01:00
|
|
|
string $icon='images/wizard/tasklist.png',
|
2019-02-15 18:05:59 +01:00
|
|
|
string $label='Task list'
|
|
|
|
) {
|
|
|
|
$this->setBreadcrum([]);
|
|
|
|
|
|
|
|
$this->task = [];
|
|
|
|
$this->msg = $msg;
|
|
|
|
$this->icon = $icon;
|
|
|
|
$this->label = __($label);
|
|
|
|
$this->page = $page;
|
|
|
|
$this->url = ui_get_full_url(
|
|
|
|
'index.php?sec=gservers&sec2=godmode/servers/discovery&wiz=tasklist'
|
|
|
|
);
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Implements run method.
|
|
|
|
*
|
2019-02-26 20:00:41 +01:00
|
|
|
* @param string $message Redirected input.
|
|
|
|
* @param boolean $status Redirected input.
|
|
|
|
*
|
2019-02-15 18:05:59 +01:00
|
|
|
* @return mixed Returns null if wizard is ongoing. Result if done.
|
|
|
|
*/
|
2019-02-23 12:13:54 +01:00
|
|
|
public function run($message='', $status=null)
|
2019-02-15 18:05:59 +01:00
|
|
|
{
|
2019-02-22 13:45:59 +01:00
|
|
|
global $config;
|
2019-02-15 18:05:59 +01:00
|
|
|
// Load styles.
|
|
|
|
parent::run();
|
2019-02-15 18:35:35 +01:00
|
|
|
|
2024-03-01 10:26:10 +01:00
|
|
|
$deploymentCenter = new DeploymentCenter();
|
|
|
|
echo $deploymentCenter->loadJS();
|
|
|
|
ui_require_css_file('deployment_list');
|
|
|
|
|
|
|
|
html_print_div(
|
|
|
|
[
|
|
|
|
'content' => '',
|
|
|
|
'id' => 'modal_add_target',
|
|
|
|
'class' => 'invisible',
|
|
|
|
]
|
|
|
|
);
|
|
|
|
|
|
|
|
html_print_div(
|
|
|
|
[
|
|
|
|
'content' => '',
|
|
|
|
'id' => 'modal_deploy_targets',
|
|
|
|
'class' => 'invisible',
|
|
|
|
]
|
|
|
|
);
|
|
|
|
|
2019-02-23 12:13:54 +01:00
|
|
|
$this->prepareBreadcrum(
|
|
|
|
[
|
|
|
|
[
|
|
|
|
'link' => 'index.php?sec=gservers&sec2=godmode/servers/discovery',
|
|
|
|
'label' => 'Discovery',
|
|
|
|
],
|
|
|
|
]
|
|
|
|
);
|
|
|
|
|
2019-04-05 10:41:37 +02:00
|
|
|
// Header.
|
|
|
|
ui_print_page_header(
|
|
|
|
__('Task list'),
|
|
|
|
'',
|
|
|
|
false,
|
|
|
|
'',
|
|
|
|
true,
|
|
|
|
'',
|
|
|
|
false,
|
|
|
|
'',
|
|
|
|
GENERIC_SIZE_TEXT,
|
|
|
|
'',
|
|
|
|
$this->printHeader(true)
|
|
|
|
);
|
2019-02-23 12:13:54 +01:00
|
|
|
|
2024-03-21 16:11:22 +01:00
|
|
|
// Div neccesary for modal map task.
|
|
|
|
echo '<div id="map_task" class="invisible"></div>';
|
|
|
|
echo '<div id="task_review" class="invisible"></div>';
|
|
|
|
echo '<div id="msg" class="invisible"></div>';
|
|
|
|
echo '<input type="hidden" id="ajax-url" value="'.ui_get_full_url('ajax.php').'"/>';
|
|
|
|
echo '<input type="hidden" id="success-str" value="'.__('Success').'"/>';
|
|
|
|
echo '<input type="hidden" id="failed-str" value="'.__('Failed').'"/>';
|
|
|
|
|
2019-02-23 12:13:54 +01:00
|
|
|
// Show redirected messages from discovery.php.
|
|
|
|
if ($status === 0) {
|
|
|
|
ui_print_success_message($message);
|
|
|
|
} else if ($status !== null) {
|
|
|
|
ui_print_error_message($message);
|
|
|
|
}
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
$force_run = (bool) get_parameter('force_run');
|
2020-03-17 18:34:30 +01:00
|
|
|
$force = (bool) get_parameter('force');
|
|
|
|
if ($force_run === true || $force === true) {
|
|
|
|
return $this->forceTask();
|
2019-02-22 12:53:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
$delete_console_task = (bool) get_parameter('delete_console_task');
|
2023-05-10 08:43:29 +02:00
|
|
|
$report_task = (bool) get_parameter('report_task', 0);
|
|
|
|
if ($report_task === true) {
|
|
|
|
$this->url = ui_get_full_url('index.php?sec=reporting&sec2=godmode/reporting/reporting_builder');
|
|
|
|
}
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
if ($delete_console_task === true) {
|
|
|
|
return $this->deleteConsoleTask();
|
|
|
|
}
|
2019-02-15 18:35:35 +01:00
|
|
|
|
2022-03-23 11:47:34 +01:00
|
|
|
$toggle_console_task = (int) get_parameter('toggle_console_task', -1);
|
|
|
|
if ($toggle_console_task === 1 || $toggle_console_task === 0) {
|
|
|
|
return $this->toggleConsoleTask($toggle_console_task);
|
|
|
|
}
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
$delete = (bool) get_parameter('delete', false);
|
|
|
|
if ($delete === true) {
|
2019-02-15 18:35:35 +01:00
|
|
|
return $this->deleteTask();
|
|
|
|
}
|
|
|
|
|
2021-01-25 13:56:04 +01:00
|
|
|
$disable = (bool) get_parameter('disabled', false);
|
|
|
|
if ($disable === true) {
|
|
|
|
return $this->disableTask();
|
|
|
|
}
|
|
|
|
|
|
|
|
$enable = (bool) get_parameter('enabled', false);
|
|
|
|
if ($enable === true) {
|
|
|
|
return $this->enableTask();
|
|
|
|
}
|
|
|
|
|
2023-09-27 11:35:57 +02:00
|
|
|
enterprise_hook('tasklist_checkrunning');
|
2019-02-25 11:29:39 +01:00
|
|
|
|
2023-09-27 11:35:57 +02:00
|
|
|
if (enterprise_installed()) {
|
2019-02-26 20:00:41 +01:00
|
|
|
$ret = $this->showListConsoleTask();
|
|
|
|
} else {
|
|
|
|
$ret = false;
|
2019-02-25 11:29:39 +01:00
|
|
|
}
|
|
|
|
|
2022-07-08 13:40:20 +02:00
|
|
|
if (is_reporting_console_node() === false) {
|
2024-03-01 10:26:10 +01:00
|
|
|
$ret2 = $this->showList(__('Host & devices tasks'), [0, 1, 9]);
|
2023-06-14 11:09:08 +02:00
|
|
|
$ret2 .= $this->showList(__('Applications tasks'), [3, 4, 5, 10, 11, 12], 'app');
|
|
|
|
$ret2 .= $this->showList(__('Cloud tasks'), [6, 7, 8, 13, 14], 'cloud');
|
|
|
|
$ret2 .= $this->showList(__('Custom tasks'), [-1], 'custom');
|
2022-07-08 13:40:20 +02:00
|
|
|
}
|
2019-02-22 13:45:59 +01:00
|
|
|
|
|
|
|
if ($ret === false && $ret2 === false) {
|
2019-11-21 18:21:46 +01:00
|
|
|
include_once $config['homedir'].'/general/first_task/recon_view.php';
|
2019-02-26 20:00:41 +01:00
|
|
|
} else {
|
|
|
|
$form = [
|
|
|
|
'form' => [
|
|
|
|
'method' => 'POST',
|
|
|
|
'action' => ui_get_full_url(
|
|
|
|
'index.php?sec=gservers&sec2=godmode/servers/discovery'
|
|
|
|
),
|
2023-03-06 16:21:10 +01:00
|
|
|
'class' => 'flex_center',
|
2019-02-26 20:00:41 +01:00
|
|
|
],
|
|
|
|
'inputs' => [
|
|
|
|
[
|
|
|
|
'arguments' => [
|
|
|
|
'name' => 'submit',
|
|
|
|
'label' => __('Go back'),
|
|
|
|
'type' => 'submit',
|
2023-03-06 16:21:10 +01:00
|
|
|
'attributes' => [
|
|
|
|
'icon' => 'back',
|
|
|
|
'mode' => 'secondary',
|
|
|
|
],
|
2019-02-26 20:00:41 +01:00
|
|
|
'return' => true,
|
|
|
|
],
|
2021-10-26 14:21:40 +02:00
|
|
|
],
|
|
|
|
[
|
2020-04-14 11:57:18 +02:00
|
|
|
'arguments' => [
|
|
|
|
'name' => 'refresh',
|
|
|
|
'label' => __('Refresh'),
|
|
|
|
'type' => 'button',
|
2022-10-28 15:01:00 +02:00
|
|
|
'attributes' => [ 'icon' => 'cog'],
|
2020-04-14 11:57:18 +02:00
|
|
|
'return' => true,
|
2023-03-06 16:21:10 +01:00
|
|
|
'script' => 'location.href = "'.$this->url.'";',
|
2020-04-14 11:57:18 +02:00
|
|
|
],
|
2019-02-26 20:00:41 +01:00
|
|
|
],
|
|
|
|
],
|
|
|
|
];
|
2019-02-22 13:45:59 +01:00
|
|
|
|
2023-03-06 16:21:10 +01:00
|
|
|
html_print_action_buttons($this->printForm($form, true));
|
2019-02-26 20:23:52 +01:00
|
|
|
}
|
2019-02-26 20:00:41 +01:00
|
|
|
|
2019-02-22 13:45:59 +01:00
|
|
|
return $ret;
|
2019-02-15 18:05:59 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Implements load method.
|
|
|
|
*
|
|
|
|
* @return mixed Skeleton for button.
|
|
|
|
*/
|
|
|
|
public function load()
|
|
|
|
{
|
|
|
|
return [
|
|
|
|
'icon' => $this->icon,
|
|
|
|
'label' => $this->label,
|
|
|
|
'url' => $this->url,
|
|
|
|
|
|
|
|
];
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-02-15 18:35:35 +01:00
|
|
|
/**
|
|
|
|
* Delete a recon task.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function deleteTask()
|
|
|
|
{
|
|
|
|
global $config;
|
|
|
|
|
2019-10-09 15:45:02 +02:00
|
|
|
if (! check_acl($config['id_user'], 0, 'AW')) {
|
2019-02-15 18:35:35 +01:00
|
|
|
db_pandora_audit(
|
2022-01-20 10:55:23 +01:00
|
|
|
AUDIT_LOG_ACL_VIOLATION,
|
2019-02-15 18:35:35 +01:00
|
|
|
'Trying to access recon task viewer'
|
|
|
|
);
|
|
|
|
include 'general/noaccess.php';
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$task = get_parameter('task', null);
|
|
|
|
|
|
|
|
if ($task !== null) {
|
2023-04-17 15:43:35 +02:00
|
|
|
$result = db_process_sql_delete(
|
|
|
|
'trecon_task',
|
|
|
|
['id_rt' => $task]
|
|
|
|
);
|
2023-04-03 17:18:20 +02:00
|
|
|
|
2023-04-17 15:43:35 +02:00
|
|
|
if ($result == 1) {
|
|
|
|
return [
|
|
|
|
'result' => 0,
|
|
|
|
'msg' => __('Task successfully deleted'),
|
|
|
|
'id' => false,
|
|
|
|
];
|
2019-02-21 18:00:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Trick to avoid double execution.
|
|
|
|
header('Location: '.$this->url);
|
2019-02-15 18:35:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
/**
|
|
|
|
* Force console task.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2020-03-17 18:34:30 +01:00
|
|
|
public function forceTask()
|
2019-02-22 12:53:35 +01:00
|
|
|
{
|
|
|
|
global $config;
|
|
|
|
|
2019-10-09 15:45:02 +02:00
|
|
|
if (!$this->aclMulticheck('RR|RW|RM|PM')) {
|
2019-02-22 12:53:35 +01:00
|
|
|
db_pandora_audit(
|
2022-01-20 10:55:23 +01:00
|
|
|
AUDIT_LOG_ACL_VIOLATION,
|
2019-02-22 12:53:35 +01:00
|
|
|
'Trying to access recon task viewer'
|
|
|
|
);
|
|
|
|
include 'general/noaccess.php';
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$id_console_task = (int) get_parameter('id_console_task');
|
2023-05-10 08:43:29 +02:00
|
|
|
$report_task = (bool) get_parameter('report_task', 0);
|
|
|
|
if ($report_task === true) {
|
|
|
|
$this->url = ui_get_full_url('index.php?sec=reporting&sec2=godmode/reporting/reporting_builder');
|
|
|
|
}
|
2019-02-22 12:53:35 +01:00
|
|
|
|
2020-03-17 18:34:30 +01:00
|
|
|
if ($id_console_task != null) {
|
|
|
|
// --------------------------------
|
|
|
|
// FORCE A CONSOLE TASK
|
|
|
|
// --------------------------------
|
2019-03-12 10:47:28 +01:00
|
|
|
enterprise_hook('cron_task_run', [$id_console_task, true]);
|
2019-02-22 12:53:35 +01:00
|
|
|
// Trick to avoid double execution.
|
|
|
|
header('Location: '.$this->url);
|
2020-03-17 18:34:30 +01:00
|
|
|
} else {
|
|
|
|
// --------------------------------
|
|
|
|
// FORCE A RECON TASK
|
|
|
|
// --------------------------------
|
|
|
|
if (check_acl($config['id_user'], 0, 'AW')) {
|
|
|
|
if (isset($_GET['force'])) {
|
|
|
|
$id = (int) get_parameter_get('force', 0);
|
|
|
|
// Schedule execution.
|
2020-03-25 18:02:58 +01:00
|
|
|
$review_mode = db_get_value(
|
|
|
|
'review_mode',
|
2020-03-17 18:34:30 +01:00
|
|
|
'trecon_task',
|
|
|
|
'id_rt',
|
|
|
|
$id
|
|
|
|
);
|
|
|
|
|
2020-03-25 18:02:58 +01:00
|
|
|
if ($review_mode != DISCOVERY_STANDARD) {
|
2020-03-17 18:34:30 +01:00
|
|
|
// Force re-scan for supervised tasks.
|
2020-03-25 18:02:58 +01:00
|
|
|
$review_mode = DISCOVERY_REVIEW;
|
2020-03-17 18:34:30 +01:00
|
|
|
}
|
2019-02-22 12:53:35 +01:00
|
|
|
|
2020-03-17 18:34:30 +01:00
|
|
|
db_process_sql_update(
|
|
|
|
'trecon_task',
|
|
|
|
[
|
2020-03-25 18:02:58 +01:00
|
|
|
'utimestamp' => 0,
|
|
|
|
'status' => 1,
|
|
|
|
'review_mode' => $review_mode,
|
2020-03-17 18:34:30 +01:00
|
|
|
],
|
|
|
|
['id_rt' => $id]
|
|
|
|
);
|
|
|
|
header('Location: '.$this->url);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2019-02-22 12:53:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-03-23 11:47:34 +01:00
|
|
|
/**
|
|
|
|
* Toggle enable/disable status of selected Console Task.
|
|
|
|
*
|
|
|
|
* @param integer $enable If 1 enable the console task.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function toggleConsoleTask(int $enable)
|
|
|
|
{
|
|
|
|
global $config;
|
|
|
|
|
|
|
|
if ((bool) check_acl($config['id_user'], 0, 'RM') === false) {
|
|
|
|
db_pandora_audit(
|
|
|
|
AUDIT_LOG_ACL_VIOLATION,
|
|
|
|
'Trying to access recon task viewer'
|
|
|
|
);
|
|
|
|
include 'general/noaccess.php';
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$id_console_task = (int) get_parameter('id_console_task');
|
2023-05-10 08:43:29 +02:00
|
|
|
$report_task = (bool) get_parameter('report_task', 0);
|
|
|
|
if ($report_task === true) {
|
|
|
|
$this->url = ui_get_full_url('index.php?sec=reporting&sec2=godmode/reporting/reporting_builder');
|
|
|
|
}
|
2022-03-23 11:47:34 +01:00
|
|
|
|
|
|
|
if ($id_console_task > 0) {
|
|
|
|
$result = db_process_sql_update(
|
|
|
|
'tuser_task_scheduled',
|
|
|
|
['enabled' => $enable],
|
|
|
|
['id' => $id_console_task]
|
|
|
|
);
|
|
|
|
|
|
|
|
if ((int) $result === 1) {
|
|
|
|
return [
|
|
|
|
'result' => 0,
|
|
|
|
'msg' => ((bool) $enable === true) ? __('Task successfully enabled') : __('Task succesfully disabled'),
|
|
|
|
'id' => false,
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
// Trick to avoid double execution.
|
|
|
|
header('Location: '.$this->url);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-02-22 12:53:35 +01:00
|
|
|
/**
|
|
|
|
* Delete a Console task.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function deleteConsoleTask()
|
|
|
|
{
|
|
|
|
global $config;
|
|
|
|
|
2019-10-09 15:45:02 +02:00
|
|
|
if (! check_acl($config['id_user'], 0, 'RM')) {
|
2019-02-22 12:53:35 +01:00
|
|
|
db_pandora_audit(
|
2022-01-20 10:55:23 +01:00
|
|
|
AUDIT_LOG_ACL_VIOLATION,
|
2019-02-22 12:53:35 +01:00
|
|
|
'Trying to access recon task viewer'
|
|
|
|
);
|
|
|
|
include 'general/noaccess.php';
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$id_console_task = (int) get_parameter('id_console_task');
|
|
|
|
|
|
|
|
if ($id_console_task !== null) {
|
|
|
|
$result = db_process_sql_delete(
|
|
|
|
'tuser_task_scheduled',
|
|
|
|
['id' => $id_console_task]
|
|
|
|
);
|
|
|
|
|
|
|
|
if ($result == 1) {
|
|
|
|
return [
|
|
|
|
'result' => 0,
|
|
|
|
'msg' => __('Console Task successfully deleted'),
|
|
|
|
'id' => false,
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
// Trick to avoid double execution.
|
|
|
|
header('Location: '.$this->url);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2021-01-25 13:56:04 +01:00
|
|
|
/**
|
|
|
|
* Disable a recon task.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function disableTask()
|
|
|
|
{
|
|
|
|
global $config;
|
|
|
|
|
|
|
|
if (! check_acl($config['id_user'], 0, 'AW')) {
|
|
|
|
db_pandora_audit(
|
2022-01-20 10:55:23 +01:00
|
|
|
AUDIT_LOG_ACL_VIOLATION,
|
2021-01-25 13:56:04 +01:00
|
|
|
'Trying to access recon task viewer'
|
|
|
|
);
|
|
|
|
include 'general/noaccess.php';
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$task = get_parameter('task', null);
|
|
|
|
|
|
|
|
if ($task !== null) {
|
2023-04-17 15:43:35 +02:00
|
|
|
$result = db_process_sql_update(
|
|
|
|
'trecon_task',
|
|
|
|
['disabled' => 1],
|
|
|
|
['id_rt' => $task]
|
|
|
|
);
|
2023-04-03 17:18:20 +02:00
|
|
|
|
2023-04-17 15:43:35 +02:00
|
|
|
if ($result == 1) {
|
|
|
|
return [
|
|
|
|
'result' => 0,
|
|
|
|
'msg' => __('Task successfully disabled'),
|
|
|
|
'id' => false,
|
|
|
|
];
|
2021-01-25 13:56:04 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Trick to avoid double execution.
|
|
|
|
header('Location: '.$this->url);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Enable a recon task.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function enableTask()
|
|
|
|
{
|
|
|
|
global $config;
|
|
|
|
|
|
|
|
if (! check_acl($config['id_user'], 0, 'AW')) {
|
|
|
|
db_pandora_audit(
|
2022-01-20 10:55:23 +01:00
|
|
|
AUDIT_LOG_ACL_VIOLATION,
|
2021-01-25 13:56:04 +01:00
|
|
|
'Trying to access recon task viewer'
|
|
|
|
);
|
|
|
|
include 'general/noaccess.php';
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$task = get_parameter('task', null);
|
|
|
|
|
|
|
|
if ($task !== null) {
|
2023-04-17 15:43:35 +02:00
|
|
|
$result = db_process_sql_update(
|
|
|
|
'trecon_task',
|
|
|
|
[
|
|
|
|
'disabled' => 0,
|
|
|
|
'status' => 0,
|
|
|
|
],
|
|
|
|
['id_rt' => $task]
|
|
|
|
);
|
2023-04-03 17:18:20 +02:00
|
|
|
|
2023-04-17 15:43:35 +02:00
|
|
|
if ($result == 1) {
|
|
|
|
return [
|
|
|
|
'result' => 0,
|
|
|
|
'msg' => __('Task successfully enabled'),
|
|
|
|
'id' => false,
|
|
|
|
];
|
2021-01-25 13:56:04 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Trick to avoid double execution.
|
|
|
|
header('Location: '.$this->url);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-02-15 18:05:59 +01:00
|
|
|
/**
|
|
|
|
* Show complete list of running tasks.
|
|
|
|
*
|
2023-04-18 10:57:42 +02:00
|
|
|
* @param string $titleTable Title of section.
|
|
|
|
* @param array $filter Ids array from apps for filter.
|
|
|
|
* @param boolean $extension_section Extension to add in table.
|
|
|
|
*
|
2019-02-15 18:05:59 +01:00
|
|
|
* @return boolean Success or not.
|
|
|
|
*/
|
2023-04-18 10:57:42 +02:00
|
|
|
public function showList($titleTable, $filter, $extension_section=false)
|
2019-02-15 18:05:59 +01:00
|
|
|
{
|
|
|
|
global $config;
|
|
|
|
|
|
|
|
check_login();
|
|
|
|
|
2019-10-09 15:45:02 +02:00
|
|
|
if (!$this->aclMulticheck('AR|AW|AM')) {
|
|
|
|
// Tasklist are allowed only of agent managers.
|
|
|
|
return '';
|
2019-02-15 18:05:59 +01:00
|
|
|
}
|
|
|
|
|
2019-02-28 12:00:43 +01:00
|
|
|
// Get all discovery servers.
|
2019-02-15 18:05:59 +01:00
|
|
|
$servers = db_get_all_rows_sql('SELECT * FROM tserver WHERE server_type = 3');
|
|
|
|
if ($servers === false) {
|
|
|
|
$servers = [];
|
|
|
|
ui_print_error_message(__('Discovery Server is disabled'));
|
2019-02-26 20:23:52 +01:00
|
|
|
$check = db_get_all_rows_sql('SELECT * FROM trecon_task');
|
|
|
|
return (bool) $check;
|
2019-02-15 18:05:59 +01:00
|
|
|
} else {
|
2019-02-26 20:00:41 +01:00
|
|
|
include_once $config['homedir'].'/include/functions_graph.php';
|
|
|
|
include_once $config['homedir'].'/include/functions_servers.php';
|
|
|
|
include_once $config['homedir'].'/include/functions_network_profiles.php';
|
|
|
|
|
2021-01-05 11:42:34 +01:00
|
|
|
if (users_is_admin()) {
|
2023-04-18 10:57:42 +02:00
|
|
|
$recon_tasks = db_get_all_rows_sql(
|
|
|
|
sprintf(
|
|
|
|
'SELECT tasks.*, apps.section AS section, apps.short_name AS short_name
|
|
|
|
FROM trecon_task tasks
|
|
|
|
LEFT JOIN tdiscovery_apps apps ON tasks.id_app = apps.id_app
|
|
|
|
WHERE type IN (%s) OR section = "%s"',
|
|
|
|
implode(',', $filter),
|
|
|
|
$extension_section
|
|
|
|
)
|
|
|
|
);
|
2021-01-05 11:42:34 +01:00
|
|
|
} else {
|
|
|
|
$user_groups = implode(
|
|
|
|
',',
|
|
|
|
array_keys(users_get_groups())
|
|
|
|
);
|
|
|
|
$recon_tasks = db_get_all_rows_sql(
|
|
|
|
sprintf(
|
2023-04-18 10:57:42 +02:00
|
|
|
'SELECT tasks.*, apps.section AS section, apps.short_name AS short_name
|
2023-08-16 13:46:19 +02:00
|
|
|
FROM trecon_task tasks
|
2023-04-18 10:57:42 +02:00
|
|
|
LEFT JOIN tdiscovery_apps apps ON tasks.id_app = apps.id_app
|
|
|
|
WHERE id_group IN (%s) AND
|
|
|
|
(type IN (%s) OR section = "%s")',
|
|
|
|
$user_groups,
|
|
|
|
implode(',', $filter),
|
|
|
|
$extension_section
|
2021-01-05 11:42:34 +01:00
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2019-03-01 11:08:49 +01:00
|
|
|
// Show network tasks for Recon Server.
|
2019-02-28 12:00:43 +01:00
|
|
|
if ($recon_tasks === false) {
|
|
|
|
$recon_tasks = [];
|
|
|
|
}
|
2019-02-15 18:05:59 +01:00
|
|
|
|
2019-05-28 10:57:36 +02:00
|
|
|
$url_ajax = $config['homeurl'].'ajax.php';
|
|
|
|
|
|
|
|
$table = new StdClass();
|
|
|
|
$table->cellpadding = 0;
|
|
|
|
$table->cellspacing = 0;
|
|
|
|
$table->width = '100%';
|
|
|
|
$table->class = 'info_table';
|
|
|
|
$table->head = [];
|
|
|
|
$table->data = [];
|
|
|
|
$table->align = [];
|
|
|
|
$table->headstyle = [];
|
2020-04-13 19:34:36 +02:00
|
|
|
$table->style = [];
|
|
|
|
$table->style[4] = 'word-break: break-word;';
|
2019-02-28 12:00:43 +01:00
|
|
|
for ($i = 0; $i < 9; $i++) {
|
|
|
|
$table->headstyle[$i] = 'text-align: left;';
|
|
|
|
}
|
2019-02-15 18:05:59 +01:00
|
|
|
|
2020-10-07 10:29:43 +02:00
|
|
|
// Task name.
|
2021-03-25 11:49:32 +01:00
|
|
|
$table->headstyle[1] .= 'min-width: 170px; width: 300px;';
|
|
|
|
// Server Name.
|
|
|
|
$table->headstyle[2] .= 'min-width: 130px; width: 400px;';
|
2020-04-13 19:34:36 +02:00
|
|
|
// Name.
|
2021-03-29 09:58:23 +02:00
|
|
|
$table->headstyle[4] .= 'min-width: 100px; width: 350px;';
|
2019-05-28 10:57:36 +02:00
|
|
|
// Status.
|
2021-03-25 11:49:32 +01:00
|
|
|
$table->headstyle[5] .= 'min-width: 70px; width: 190px;';
|
2019-05-29 12:09:45 +02:00
|
|
|
// Task type.
|
2021-03-25 11:49:32 +01:00
|
|
|
$table->headstyle[6] .= 'min-width: 190px; width: 200px;';
|
2019-05-28 10:57:36 +02:00
|
|
|
// Progress.
|
2021-03-25 11:49:32 +01:00
|
|
|
$table->headstyle[7] .= 'min-width: 60px; width: 150px;';
|
2019-05-28 10:57:36 +02:00
|
|
|
// Updated at.
|
2020-04-13 19:34:36 +02:00
|
|
|
$table->headstyle[8] .= 'min-width: 50px; width: 150px;';
|
2019-05-28 10:57:36 +02:00
|
|
|
// Operations.
|
2024-02-12 17:59:27 +01:00
|
|
|
$table->headstyle[9] = 'min-width: 150px; width: 250px;';
|
2019-02-15 18:05:59 +01:00
|
|
|
|
2019-10-09 15:45:02 +02:00
|
|
|
if (check_acl($config['id_user'], 0, 'AW')) {
|
|
|
|
$table->head[0] = __('Force');
|
|
|
|
$table->align[0] = 'left';
|
|
|
|
}
|
2019-02-15 18:05:59 +01:00
|
|
|
|
2019-05-28 10:57:36 +02:00
|
|
|
$table->head[1] = __('Task name');
|
|
|
|
$table->align[1] = 'left';
|
2019-02-22 12:53:35 +01:00
|
|
|
|
2019-05-28 10:57:36 +02:00
|
|
|
$table->head[2] = __('Server name');
|
|
|
|
$table->align[2] = 'left';
|
2019-02-22 12:53:35 +01:00
|
|
|
|
2019-05-28 10:57:36 +02:00
|
|
|
$table->head[3] = __('Interval');
|
|
|
|
$table->align[3] = 'left';
|
2019-02-22 12:53:35 +01:00
|
|
|
|
2019-05-28 10:57:36 +02:00
|
|
|
$table->head[4] = __('Network');
|
|
|
|
$table->align[4] = 'left';
|
2019-02-22 12:53:35 +01:00
|
|
|
|
2019-05-28 10:57:36 +02:00
|
|
|
$table->head[5] = __('Status');
|
|
|
|
$table->align[5] = 'left';
|
2019-02-22 12:53:35 +01:00
|
|
|
|
2019-05-28 10:57:36 +02:00
|
|
|
$table->head[6] = __('Task type');
|
|
|
|
$table->align[6] = 'left';
|
2019-02-22 12:53:35 +01:00
|
|
|
|
2019-05-28 10:57:36 +02:00
|
|
|
$table->head[7] = __('Progress');
|
|
|
|
$table->align[7] = 'left';
|
2019-02-22 12:53:35 +01:00
|
|
|
|
2019-05-28 10:57:36 +02:00
|
|
|
$table->head[8] = __('Updated at');
|
|
|
|
$table->align[8] = 'left';
|
|
|
|
|
|
|
|
$table->head[9] = __('Operations');
|
|
|
|
$table->align[9] = 'left';
|
2019-02-28 12:00:43 +01:00
|
|
|
|
|
|
|
foreach ($recon_tasks as $task) {
|
2020-11-16 18:30:23 +01:00
|
|
|
if ($this->aclMulticheck('AR|AW|AM', $task['id_group']) === false) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2019-07-17 17:17:54 +02:00
|
|
|
$no_operations = false;
|
2019-02-28 12:00:43 +01:00
|
|
|
$data = [];
|
|
|
|
$server_name = servers_get_name($task['id_recon_server']);
|
|
|
|
|
|
|
|
// By default.
|
|
|
|
$subnet = $task['subnet'];
|
|
|
|
|
|
|
|
// Exceptions: IPAM.
|
|
|
|
$ipam = false;
|
|
|
|
if ($task['id_recon_script'] != null) {
|
2019-04-24 10:10:08 +02:00
|
|
|
$recon_script_data = db_get_row(
|
|
|
|
'trecon_script',
|
|
|
|
'id_recon_script',
|
|
|
|
$task['id_recon_script']
|
|
|
|
);
|
|
|
|
if ($recon_script_data !== false) {
|
|
|
|
$recon_script_name = $recon_script_data['name'];
|
|
|
|
if (io_safe_output($recon_script_name) == 'IPAM Recon'
|
|
|
|
&& enterprise_installed()
|
|
|
|
) {
|
|
|
|
$subnet_obj = json_decode($task['macros'], true);
|
|
|
|
$subnet = $subnet_obj['1']['value'];
|
|
|
|
$tipam_task_id = db_get_value(
|
|
|
|
'id',
|
|
|
|
'tipam_network',
|
|
|
|
'id_recon_task',
|
|
|
|
$task['id_rt']
|
|
|
|
);
|
|
|
|
$ipam = true;
|
|
|
|
}
|
2019-02-26 20:00:41 +01:00
|
|
|
}
|
2019-04-24 10:10:08 +02:00
|
|
|
} else {
|
|
|
|
$recon_script_data = false;
|
|
|
|
$recon_script_name = false;
|
2019-02-28 12:00:43 +01:00
|
|
|
}
|
2019-02-22 12:53:35 +01:00
|
|
|
|
2023-04-27 10:35:09 +02:00
|
|
|
if (($task['disabled'] == 0 && $server_name !== '' && (int) $task['type'] !== DISCOVERY_EXTENSION)
|
|
|
|
|| ((int) $task['type'] === DISCOVERY_EXTENSION && (int) $task['setup_complete'] === 1)
|
|
|
|
) {
|
2019-10-09 15:45:02 +02:00
|
|
|
if (check_acl($config['id_user'], 0, 'AW')) {
|
2020-03-16 23:52:20 +01:00
|
|
|
$data[0] = '<span class="link" onclick="force_task(\'';
|
|
|
|
$data[0] .= ui_get_full_url(
|
2021-01-20 17:55:11 +01:00
|
|
|
'index.php?sec=gservers&sec2=godmode/servers/discovery&wiz=tasklist&server_id='.$task['id_recon_server'].'&force='.$task['id_rt']
|
2020-03-16 23:52:20 +01:00
|
|
|
);
|
|
|
|
$data[0] .= '\'';
|
|
|
|
if ($task['type'] == DISCOVERY_HOSTDEVICES) {
|
|
|
|
$title = __('Are you sure?');
|
2022-06-20 10:37:25 +02:00
|
|
|
$message = __('This action will rescan the target networks.');
|
2020-03-16 23:52:20 +01:00
|
|
|
$data[0] .= ', {title: \''.$title.'\', message: \''.$message.'\'}';
|
|
|
|
}
|
|
|
|
|
|
|
|
$data[0] .= ');" >';
|
2021-03-11 15:40:23 +01:00
|
|
|
$data[0] .= html_print_image(
|
2023-03-30 08:43:23 +02:00
|
|
|
'images/force@svg.svg',
|
2021-03-11 15:40:23 +01:00
|
|
|
true,
|
|
|
|
[
|
|
|
|
'title' => __('Force'),
|
2023-03-09 23:31:40 +01:00
|
|
|
'class' => 'main_menu_icon invert_filter',
|
2021-03-11 15:40:23 +01:00
|
|
|
]
|
|
|
|
);
|
2020-03-16 23:52:20 +01:00
|
|
|
$data[0] .= '</span>';
|
2019-10-09 15:45:02 +02:00
|
|
|
}
|
2023-04-27 10:35:09 +02:00
|
|
|
} else if ($task['disabled'] == 2
|
|
|
|
|| ((int) $task['type'] === DISCOVERY_EXTENSION && (int) $task['setup_complete'] === 0)
|
|
|
|
) {
|
2019-02-28 12:00:43 +01:00
|
|
|
$data[0] = ui_print_help_tip(
|
|
|
|
__('This task has not been completely defined, please edit it'),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
$data[0] = '';
|
|
|
|
}
|
2019-02-22 12:53:35 +01:00
|
|
|
|
2019-03-07 14:45:26 +01:00
|
|
|
// Name task.
|
|
|
|
$data[1] = '';
|
|
|
|
if ($task['disabled'] != 2) {
|
2020-03-16 23:52:20 +01:00
|
|
|
$data[1] .= '<span class="link" onclick="progress_task_list('.$task['id_rt'].',\''.$task['name'].'\')">';
|
2019-03-07 14:45:26 +01:00
|
|
|
}
|
|
|
|
|
2021-01-25 13:56:04 +01:00
|
|
|
if ($task['disabled'] == 1) {
|
|
|
|
$data[1] .= '<b><em>'.$task['name'].'</em></b>';
|
|
|
|
} else {
|
|
|
|
$data[1] .= '<b>'.$task['name'].'</b>';
|
|
|
|
}
|
|
|
|
|
2019-03-07 14:45:26 +01:00
|
|
|
if ($task['disabled'] != 2) {
|
2020-03-16 23:52:20 +01:00
|
|
|
$data[1] .= '</span>';
|
2019-03-07 14:45:26 +01:00
|
|
|
}
|
2019-02-22 12:53:35 +01:00
|
|
|
|
2019-02-28 12:00:43 +01:00
|
|
|
$data[2] = $server_name;
|
2019-02-22 12:53:35 +01:00
|
|
|
|
2023-04-17 15:43:35 +02:00
|
|
|
if ($task['interval_sweep'] > 0) {
|
|
|
|
$data[3] = human_time_description_raw(
|
|
|
|
$task['interval_sweep']
|
|
|
|
);
|
2019-02-28 12:00:43 +01:00
|
|
|
} else {
|
|
|
|
$data[3] = __('Manual');
|
|
|
|
}
|
2019-02-22 12:53:35 +01:00
|
|
|
|
2023-10-10 10:40:37 +02:00
|
|
|
if (($task['id_recon_script'] == 0 || $ipam === true) && (int) $task['type'] !== DISCOVERY_EXTENSION) {
|
2022-05-05 13:01:06 +02:00
|
|
|
$data[4] = ui_print_truncate_text($subnet, 50, true, true, true, '[…]');
|
2019-02-28 12:00:43 +01:00
|
|
|
} else {
|
|
|
|
$data[4] = '-';
|
|
|
|
}
|
2019-02-22 12:53:35 +01:00
|
|
|
|
2021-01-07 13:48:57 +01:00
|
|
|
$_rs = $this->getStatusMessage($task);
|
|
|
|
$can_be_reviewed = $_rs['can_be_reviewed'];
|
|
|
|
$data[5] = $_rs['message'];
|
2019-02-26 20:00:41 +01:00
|
|
|
|
2019-07-09 12:02:29 +02:00
|
|
|
switch ($task['type']) {
|
|
|
|
case DISCOVERY_CLOUD_AZURE_COMPUTE:
|
|
|
|
// Discovery Applications MySQL.
|
|
|
|
$data[6] = html_print_image(
|
2023-03-14 08:35:05 +01:00
|
|
|
'images/plugins@svg.svg',
|
2019-07-09 12:02:29 +02:00
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('Discovery Cloud Azure Compute'),
|
2023-03-09 23:31:40 +01:00
|
|
|
'class' => 'main_menu_icon invert_filter',
|
2021-03-11 15:40:23 +01:00
|
|
|
]
|
2019-07-09 12:02:29 +02:00
|
|
|
).' ';
|
2023-08-09 14:40:56 +02:00
|
|
|
$data[6] .= __('Cloud.Azure.Compute (legacy)');
|
2019-07-09 12:02:29 +02:00
|
|
|
break;
|
|
|
|
|
|
|
|
case DISCOVERY_CLOUD_AWS_EC2:
|
|
|
|
// Discovery Applications MySQL.
|
|
|
|
$data[6] = html_print_image(
|
2023-03-14 08:35:05 +01:00
|
|
|
'images/plugins@svg.svg',
|
2019-07-09 12:02:29 +02:00
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('Discovery Cloud AWS EC2'),
|
2023-03-09 23:31:40 +01:00
|
|
|
'class' => 'main_menu_icon invert_filter',
|
2021-03-11 15:40:23 +01:00
|
|
|
]
|
2019-07-09 12:02:29 +02:00
|
|
|
).' ';
|
2023-08-09 14:40:56 +02:00
|
|
|
$data[6] .= __('Cloud.AWS.EC2 (legacy)');
|
2019-07-09 12:02:29 +02:00
|
|
|
break;
|
|
|
|
|
|
|
|
case DISCOVERY_CLOUD_AWS_RDS:
|
|
|
|
// Discovery Cloud RDS.
|
|
|
|
$data[6] = html_print_image(
|
2023-03-09 23:31:40 +01:00
|
|
|
'images/cluster@os.svg',
|
2019-07-09 12:02:29 +02:00
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('Discovery Cloud RDS'),
|
2023-03-09 23:31:40 +01:00
|
|
|
'class' => 'main_menu_icon invert_filter',
|
2021-03-11 15:40:23 +01:00
|
|
|
]
|
2019-07-09 12:02:29 +02:00
|
|
|
).' ';
|
2023-08-09 14:40:56 +02:00
|
|
|
$data[6] .= __('Discovery.Cloud.Aws.RDS (legacy)');
|
2019-07-09 12:02:29 +02:00
|
|
|
break;
|
|
|
|
|
2021-03-22 19:21:05 +01:00
|
|
|
case DISCOVERY_CLOUD_AWS_S3:
|
|
|
|
// Discovery Cloud S3.
|
|
|
|
$data[6] = html_print_image(
|
2023-03-09 23:31:40 +01:00
|
|
|
'images/cluster@os.svg',
|
2021-03-22 19:21:05 +01:00
|
|
|
true,
|
|
|
|
[
|
|
|
|
'title' => __('Discovery Cloud S3'),
|
2023-03-09 23:31:40 +01:00
|
|
|
'class' => 'main_menu_icon invert_filter',
|
2021-03-22 19:21:05 +01:00
|
|
|
]
|
|
|
|
).' ';
|
2023-08-09 14:40:56 +02:00
|
|
|
$data[6] .= __('Discovery.Cloud.Aws.S3 (legacy)');
|
2021-03-22 19:21:05 +01:00
|
|
|
break;
|
|
|
|
|
2019-07-09 12:02:29 +02:00
|
|
|
case DISCOVERY_APP_MYSQL:
|
|
|
|
// Discovery Applications MySQL.
|
|
|
|
$data[6] = html_print_image(
|
2023-03-09 23:31:40 +01:00
|
|
|
'images/cluster@os.svg',
|
2019-07-09 12:02:29 +02:00
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('Discovery Applications MySQL'),
|
2023-03-09 23:31:40 +01:00
|
|
|
'class' => 'main_menu_icon invert_filter',
|
2021-03-11 15:40:23 +01:00
|
|
|
]
|
2019-07-09 12:02:29 +02:00
|
|
|
).' ';
|
2023-08-09 14:40:56 +02:00
|
|
|
$data[6] .= __('Discovery.App.MySQL (legacy)');
|
2019-07-09 12:02:29 +02:00
|
|
|
break;
|
|
|
|
|
|
|
|
case DISCOVERY_APP_ORACLE:
|
|
|
|
// Discovery Applications Oracle.
|
|
|
|
$data[6] = html_print_image(
|
2023-03-09 23:31:40 +01:00
|
|
|
'images/cluster@os.svg',
|
2019-07-09 12:02:29 +02:00
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('Discovery Applications Oracle'),
|
2023-03-09 23:31:40 +01:00
|
|
|
'class' => 'main_menu_icon invert_filter',
|
2021-03-11 15:40:23 +01:00
|
|
|
]
|
2019-07-09 12:02:29 +02:00
|
|
|
).' ';
|
2023-08-09 14:40:56 +02:00
|
|
|
$data[6] .= __('Discovery.App.Oracle (legacy)');
|
2019-07-09 12:02:29 +02:00
|
|
|
break;
|
|
|
|
|
2020-06-11 14:53:34 +02:00
|
|
|
case DISCOVERY_APP_DB2:
|
|
|
|
// Discovery Applications DB2.
|
|
|
|
$data[6] = html_print_image(
|
2023-03-09 23:31:40 +01:00
|
|
|
'images/cluster@os.svg',
|
2020-06-11 14:53:34 +02:00
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('Discovery Applications DB2'),
|
2023-03-09 23:31:40 +01:00
|
|
|
'class' => 'main_menu_icon invert_filter',
|
2021-03-11 15:40:23 +01:00
|
|
|
]
|
2020-06-11 14:53:34 +02:00
|
|
|
).' ';
|
2023-08-09 14:40:56 +02:00
|
|
|
$data[6] .= __('Discovery.App.DB2 (legacy)');
|
2020-06-11 14:53:34 +02:00
|
|
|
break;
|
|
|
|
|
2019-07-16 20:56:47 +02:00
|
|
|
case DISCOVERY_DEPLOY_AGENTS:
|
|
|
|
$data[6] = html_print_image(
|
2023-03-09 23:31:40 +01:00
|
|
|
'images/osx-terminal@groups.svg',
|
2019-07-16 20:56:47 +02:00
|
|
|
true,
|
|
|
|
['title' => __('Agent deployment')]
|
|
|
|
).' ';
|
2024-03-01 10:26:10 +01:00
|
|
|
$data[6] .= __('Discovery.Agent.Deployment');
|
2019-07-16 20:56:47 +02:00
|
|
|
break;
|
|
|
|
|
2020-02-12 11:47:43 +01:00
|
|
|
case DISCOVERY_APP_MICROSOFT_SQL_SERVER:
|
|
|
|
// Discovery Applications Oracle.
|
|
|
|
$data[6] = html_print_image(
|
2023-03-09 23:31:40 +01:00
|
|
|
'images/cluster@os.svg',
|
2020-02-12 11:47:43 +01:00
|
|
|
true,
|
2023-03-17 08:10:19 +01:00
|
|
|
[
|
|
|
|
'title' => __('Discovery Applications Microsoft SQL Server'),
|
|
|
|
'class' => 'main_menu_icon invert_filter',
|
|
|
|
]
|
2020-02-12 11:47:43 +01:00
|
|
|
).' ';
|
2023-08-09 14:40:56 +02:00
|
|
|
$data[6] .= __('Discovery.App.Microsoft SQL Server (legacy)');
|
2020-02-12 11:47:43 +01:00
|
|
|
break;
|
|
|
|
|
2023-04-18 10:57:42 +02:00
|
|
|
case DISCOVERY_EXTENSION:
|
|
|
|
// Discovery NetScan.
|
|
|
|
$data[6] = html_print_image(
|
|
|
|
'images/cluster@os.svg',
|
|
|
|
true,
|
|
|
|
[
|
|
|
|
'title' => $task['short_name'],
|
|
|
|
'class' => 'main_menu_icon invert_filter',
|
|
|
|
]
|
|
|
|
).' ';
|
|
|
|
$data[6] .= $task['short_name'];
|
|
|
|
break;
|
|
|
|
|
2019-07-09 12:02:29 +02:00
|
|
|
case DISCOVERY_HOSTDEVICES:
|
|
|
|
default:
|
2023-04-17 15:43:35 +02:00
|
|
|
if ($task['id_recon_script'] == 0) {
|
2019-04-03 18:13:19 +02:00
|
|
|
// Discovery NetScan.
|
|
|
|
$data[6] = html_print_image(
|
2023-03-09 23:31:40 +01:00
|
|
|
'images/cluster@os.svg',
|
2019-04-03 18:13:19 +02:00
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('Discovery NetScan'),
|
2023-03-09 23:31:40 +01:00
|
|
|
'class' => 'main_menu_icon invert_filter',
|
2021-03-11 15:40:23 +01:00
|
|
|
]
|
2019-04-03 18:13:19 +02:00
|
|
|
).' ';
|
2023-09-05 11:19:34 +02:00
|
|
|
$data[6] .= __('Discovery.NetScan');
|
2019-07-09 12:02:29 +02:00
|
|
|
} else {
|
|
|
|
// APP or external script recon task.
|
|
|
|
$data[6] = html_print_image(
|
2023-03-14 08:35:05 +01:00
|
|
|
'images/plugins@svg.svg',
|
2021-03-11 15:40:23 +01:00
|
|
|
true,
|
2023-03-09 23:31:40 +01:00
|
|
|
['class' => 'main_menu_icon invert_filter']
|
2019-07-09 12:02:29 +02:00
|
|
|
).' ';
|
2023-09-05 11:19:34 +02:00
|
|
|
$data[6] .= $recon_script_name;
|
2019-07-09 12:02:29 +02:00
|
|
|
}
|
|
|
|
break;
|
2019-02-28 12:00:43 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($task['status'] <= 0 || $task['status'] > 100) {
|
|
|
|
$data[7] = '-';
|
|
|
|
} else {
|
2020-03-16 23:52:20 +01:00
|
|
|
$data[7] = ui_progress(
|
|
|
|
$task['status'],
|
|
|
|
'100%',
|
2023-03-21 18:12:02 +01:00
|
|
|
1.2,
|
2020-03-16 23:52:20 +01:00
|
|
|
// Color.
|
2023-03-13 15:44:55 +01:00
|
|
|
'#ececec',
|
2020-03-16 23:52:20 +01:00
|
|
|
// Return.
|
|
|
|
true,
|
|
|
|
// Text.
|
|
|
|
'',
|
|
|
|
// Ajax.
|
|
|
|
[
|
|
|
|
'page' => 'godmode/servers/discovery',
|
|
|
|
'interval' => 10,
|
|
|
|
'simple' => 1,
|
|
|
|
'data' => [
|
|
|
|
'wiz' => 'tasklist',
|
|
|
|
'id' => $task['id_rt'],
|
2020-03-17 18:34:30 +01:00
|
|
|
'method' => 'taskProgress',
|
2020-03-16 23:52:20 +01:00
|
|
|
],
|
2023-03-21 18:12:02 +01:00
|
|
|
],
|
|
|
|
''
|
2020-03-16 23:52:20 +01:00
|
|
|
);
|
2019-02-28 12:00:43 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($task['utimestamp'] > 0) {
|
|
|
|
$data[8] = ui_print_timestamp(
|
|
|
|
$task['utimestamp'],
|
|
|
|
true
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
$data[8] = __('Not executed yet');
|
|
|
|
}
|
|
|
|
|
2019-07-16 20:56:47 +02:00
|
|
|
if (!$no_operations) {
|
|
|
|
if ($task['disabled'] != 2) {
|
2020-04-07 18:50:56 +02:00
|
|
|
$data[9] = '';
|
|
|
|
if ($can_be_reviewed) {
|
|
|
|
$data[9] .= '<a href="#" onclick="show_review('.$task['id_rt'].',\''.$task['name'].'\')">';
|
|
|
|
$data[9] .= html_print_image(
|
|
|
|
'images/expand.png',
|
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('Review results'),
|
2023-03-09 23:31:40 +01:00
|
|
|
'class' => 'main_menu_icon invert_filter',
|
2021-03-11 15:40:23 +01:00
|
|
|
]
|
2020-04-07 18:50:56 +02:00
|
|
|
);
|
|
|
|
$data[9] .= '</a>';
|
|
|
|
}
|
|
|
|
|
2023-04-24 15:28:54 +02:00
|
|
|
$data[9] .= '<a href="#" onclick="progress_task_list('.$task['id_rt'].',\''.$task['name'].'\')">';
|
|
|
|
$data[9] .= html_print_image(
|
|
|
|
'images/details.svg',
|
|
|
|
true,
|
|
|
|
[
|
|
|
|
'title' => __('View summary'),
|
|
|
|
'class' => 'main_menu_icon invert_filter',
|
|
|
|
]
|
|
|
|
);
|
|
|
|
$data[9] .= '</a>';
|
2019-07-16 20:56:47 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($task['disabled'] != 2 && $task['utimestamp'] > 0
|
|
|
|
&& $task['type'] != DISCOVERY_APP_MYSQL
|
|
|
|
&& $task['type'] != DISCOVERY_APP_ORACLE
|
2020-06-11 14:53:34 +02:00
|
|
|
&& $task['type'] != DISCOVERY_APP_DB2
|
|
|
|
&& $task['type'] != DISCOVERY_APP_SAP
|
2019-07-16 20:56:47 +02:00
|
|
|
&& $task['type'] != DISCOVERY_CLOUD_AWS_RDS
|
2021-03-22 19:21:05 +01:00
|
|
|
&& $task['type'] != DISCOVERY_CLOUD_AWS_S3
|
2024-03-01 10:26:10 +01:00
|
|
|
&& $task['type'] != DISCOVERY_DEPLOY_AGENTS
|
2019-07-16 20:56:47 +02:00
|
|
|
) {
|
2023-10-10 10:40:37 +02:00
|
|
|
if (check_acl($config['id_user'], 0, 'MR') && (int) $task['type'] !== DISCOVERY_EXTENSION) {
|
2019-10-09 15:45:02 +02:00
|
|
|
$data[9] .= '<a href="#" onclick="show_map('.$task['id_rt'].',\''.$task['name'].'\')">';
|
|
|
|
$data[9] .= html_print_image(
|
2023-03-09 23:31:40 +01:00
|
|
|
'images/web@groups.svg',
|
2020-04-07 18:50:56 +02:00
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('View map'),
|
2023-03-09 23:31:40 +01:00
|
|
|
'class' => 'main_menu_icon invert_filter',
|
2021-03-11 15:40:23 +01:00
|
|
|
]
|
2019-10-09 15:45:02 +02:00
|
|
|
);
|
|
|
|
$data[9] .= '</a>';
|
|
|
|
}
|
2019-07-16 20:56:47 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if (check_acl(
|
|
|
|
$config['id_user'],
|
|
|
|
$task['id_group'],
|
2019-10-09 15:45:02 +02:00
|
|
|
'AW'
|
2019-07-16 20:56:47 +02:00
|
|
|
)
|
|
|
|
) {
|
|
|
|
if ($ipam === true) {
|
2023-02-27 16:15:34 +01:00
|
|
|
if (empty($tipam_task_id) === false) {
|
|
|
|
$data[9] .= '<a href="'.ui_get_full_url(
|
|
|
|
sprintf(
|
|
|
|
'index.php?sec=gextensions&sec2=enterprise/tools/ipam/ipam&action=edit&id=%d',
|
|
|
|
$tipam_task_id
|
|
|
|
)
|
|
|
|
).'">'.html_print_image(
|
2023-03-09 23:31:40 +01:00
|
|
|
'images/edit.svg',
|
2023-02-27 16:15:34 +01:00
|
|
|
true,
|
|
|
|
[
|
|
|
|
'title' => __('Edit task'),
|
2023-03-09 23:31:40 +01:00
|
|
|
'class' => 'main_menu_icon invert_filter',
|
2023-02-27 16:15:34 +01:00
|
|
|
]
|
|
|
|
).'</a>';
|
|
|
|
$data[9] .= '<a href="'.ui_get_full_url(
|
|
|
|
'index.php?sec=gextensions&sec2=enterprise/tools/ipam/ipam&action=delete&id='.$tipam_task_id
|
|
|
|
).'" onClick="if (!confirm(\' '.__('Are you sure?').'\')) return false;">'.html_print_image(
|
2023-03-09 23:31:40 +01:00
|
|
|
'images/delete.svg',
|
2023-02-27 16:15:34 +01:00
|
|
|
true,
|
|
|
|
[
|
|
|
|
'title' => __('Delete task'),
|
2023-03-09 23:31:40 +01:00
|
|
|
'class' => 'main_menu_icon invert_filter',
|
2023-02-27 16:15:34 +01:00
|
|
|
]
|
|
|
|
).'</a>';
|
|
|
|
} else {
|
|
|
|
$data[9] .= '<a href="'.ui_get_full_url(
|
|
|
|
'index.php?sec=gservers&sec2=godmode/servers/discovery&wiz=tasklist&delete=1&task='.$task['id_rt']
|
|
|
|
).'" onClick="if (!confirm(\' '.__('Are you sure?').'\')) return false;">'.html_print_image(
|
2023-03-09 23:31:40 +01:00
|
|
|
'images/delete.svg',
|
2023-02-27 16:15:34 +01:00
|
|
|
true,
|
|
|
|
[
|
|
|
|
'title' => __('Delete task'),
|
2023-03-09 23:31:40 +01:00
|
|
|
'class' => 'main_menu_icon invert_filter',
|
2023-02-27 16:15:34 +01:00
|
|
|
]
|
|
|
|
).'</a>';
|
|
|
|
}
|
2019-07-16 20:56:47 +02:00
|
|
|
} else {
|
2024-03-01 10:26:10 +01:00
|
|
|
// Create the url edit.
|
|
|
|
switch ((int) $task['type']) {
|
|
|
|
case DISCOVERY_EXTENSION:
|
|
|
|
$url_edit = ui_get_full_url(
|
|
|
|
sprintf(
|
|
|
|
'index.php?sec=gservers&sec2=godmode/servers/discovery&wiz=%s&mode=%s&id_task=%s',
|
|
|
|
$task['section'],
|
|
|
|
$task['short_name'],
|
|
|
|
$task['id_rt'],
|
|
|
|
)
|
|
|
|
);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case DISCOVERY_DEPLOY_AGENTS:
|
|
|
|
if (empty($task['field1']) === false) {
|
|
|
|
$url_edit = 'javascript:show_deploy_targets('.$task['id_rt'].')';
|
|
|
|
} else {
|
|
|
|
$url_edit = 'javascript:show_scan_targets('.$task['id_rt'].')';
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
$url_edit = ui_get_full_url(
|
|
|
|
sprintf(
|
|
|
|
'index.php?sec=gservers&sec2=godmode/servers/discovery&%s&task=%d',
|
|
|
|
$this->getTargetWiz($task, $recon_script_data),
|
|
|
|
$task['id_rt']
|
|
|
|
)
|
|
|
|
);
|
|
|
|
break;
|
2023-04-18 10:57:42 +02:00
|
|
|
}
|
|
|
|
|
2019-07-16 20:56:47 +02:00
|
|
|
// Check if is a H&D, Cloud or Application or IPAM.
|
2024-03-01 10:26:10 +01:00
|
|
|
$data[9] .= '<a href="'.$url_edit.'">'.html_print_image(
|
2023-03-09 23:31:40 +01:00
|
|
|
'images/edit.svg',
|
2020-04-07 18:50:56 +02:00
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('Edit task'),
|
2023-03-09 23:31:40 +01:00
|
|
|
'class' => 'main_menu_icon invert_filter',
|
2021-03-11 15:40:23 +01:00
|
|
|
]
|
2019-07-16 20:56:47 +02:00
|
|
|
).'</a>';
|
|
|
|
$data[9] .= '<a href="'.ui_get_full_url(
|
|
|
|
'index.php?sec=gservers&sec2=godmode/servers/discovery&wiz=tasklist&delete=1&task='.$task['id_rt']
|
|
|
|
).'" onClick="if (!confirm(\' '.__('Are you sure?').'\')) return false;">'.html_print_image(
|
2023-03-09 23:31:40 +01:00
|
|
|
'images/delete.svg',
|
2020-04-07 18:50:56 +02:00
|
|
|
true,
|
2021-03-11 15:40:23 +01:00
|
|
|
[
|
|
|
|
'title' => __('Delete task'),
|
2023-03-09 23:31:40 +01:00
|
|
|
'class' => 'main_menu_icon invert_filter',
|
2021-03-11 15:40:23 +01:00
|
|
|
]
|
2019-07-16 20:56:47 +02:00
|
|
|
).'</a>';
|
|
|
|
}
|
2021-01-25 13:56:04 +01:00
|
|
|
|
|
|
|
if ($task['disabled'] == 1) {
|
|
|
|
$data[9] .= '<a href="'.ui_get_full_url(
|
2023-04-17 15:43:35 +02:00
|
|
|
'index.php?sec=gservers&sec2=godmode/servers/discovery&enabled=1&wiz=tasklist&task='.$task['id_rt']
|
2021-01-25 13:56:04 +01:00
|
|
|
).'" onClick="if (!confirm(\' '.__('Are you sure?').'\')) return false;">'.html_print_image(
|
|
|
|
'images/lightbulb_off.png',
|
|
|
|
true,
|
2021-10-07 09:56:17 +02:00
|
|
|
[
|
|
|
|
'title' => __('enable task'),
|
|
|
|
'class' => 'filter_none',
|
|
|
|
]
|
2021-01-25 13:56:04 +01:00
|
|
|
).'</a>';
|
|
|
|
} else if ($task['disabled'] == 0) {
|
|
|
|
$data[9] .= '<a href="'.ui_get_full_url(
|
2023-04-17 15:43:35 +02:00
|
|
|
'index.php?sec=gservers&sec2=godmode/servers/discovery&disabled=1&wiz=tasklist&task='.$task['id_rt']
|
2021-01-25 13:56:04 +01:00
|
|
|
).'" onClick="if (!confirm(\' '.__('Are you sure?').'\')) return false;">'.html_print_image(
|
|
|
|
'images/lightbulb.png',
|
|
|
|
true,
|
|
|
|
['title' => __('Disable task')]
|
|
|
|
).'</a>';
|
|
|
|
}
|
2019-02-26 20:00:41 +01:00
|
|
|
} else {
|
2019-07-16 20:56:47 +02:00
|
|
|
$data[9] = '';
|
2019-02-22 12:53:35 +01:00
|
|
|
}
|
2019-02-28 12:00:43 +01:00
|
|
|
} else {
|
2019-07-16 20:56:47 +02:00
|
|
|
$data[9] = '-';
|
2019-02-22 12:53:35 +01:00
|
|
|
}
|
|
|
|
|
2022-11-30 10:14:42 +01:00
|
|
|
$table->cellclass[][9] = 'table_action_buttons';
|
2019-04-05 13:18:38 +02:00
|
|
|
|
2019-03-26 15:38:47 +01:00
|
|
|
// Div neccesary for modal progress task.
|
2021-03-11 15:40:23 +01:00
|
|
|
echo '<div id="progress_task_'.$task['id_rt'].'" class="invisible"></div>';
|
2019-03-26 15:38:47 +01:00
|
|
|
|
2019-02-28 12:00:43 +01:00
|
|
|
array_push($table->data, $data);
|
|
|
|
}
|
|
|
|
|
2024-02-12 17:59:27 +01:00
|
|
|
if (isset($server_name) === false) {
|
|
|
|
$server_name = '';
|
|
|
|
}
|
|
|
|
|
2019-02-28 12:00:43 +01:00
|
|
|
if (empty($table->data)) {
|
2019-06-04 13:57:55 +02:00
|
|
|
$content = '<div class="nf">'.__('Server').' '.$server_name.' '.__('has no discovery tasks assigned').'</div>';
|
|
|
|
$return = false;
|
2019-02-28 12:00:43 +01:00
|
|
|
} else {
|
2019-06-04 13:57:55 +02:00
|
|
|
$content = html_print_table($table, true);
|
|
|
|
$return = true;
|
2019-02-28 12:00:43 +01:00
|
|
|
}
|
2019-02-22 12:53:35 +01:00
|
|
|
|
2023-04-18 10:57:42 +02:00
|
|
|
ui_toggle($content, $titleTable, '', '', false);
|
2019-06-04 13:57:55 +02:00
|
|
|
|
2019-03-07 14:45:26 +01:00
|
|
|
unset($table);
|
|
|
|
|
2020-03-16 23:52:20 +01:00
|
|
|
ui_require_javascript_file('pandora_ui');
|
2019-03-07 14:45:26 +01:00
|
|
|
ui_require_javascript_file('pandora_taskList');
|
2019-06-04 13:57:55 +02:00
|
|
|
|
|
|
|
return $return;
|
2019-02-22 12:53:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-02-26 20:00:41 +01:00
|
|
|
/**
|
|
|
|
* Show complete list of running tasks.
|
|
|
|
*
|
|
|
|
* @return boolean Success or not.
|
|
|
|
*/
|
2023-07-24 10:06:43 +02:00
|
|
|
public function showListConsoleTask($report_task=false)
|
2019-02-26 20:00:41 +01:00
|
|
|
{
|
2023-07-24 10:06:43 +02:00
|
|
|
return enterprise_hook('tasklist_showListConsoleTask', [$this, $report_task]);
|
2019-02-26 20:00:41 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-02-19 20:27:05 +01:00
|
|
|
/**
|
|
|
|
* Return target url sub-string to edit target task.
|
|
|
|
*
|
2019-04-24 10:10:08 +02:00
|
|
|
* @param array $task With all data.
|
|
|
|
* @param array $script With all script data or false if undefined.
|
2019-02-19 20:27:05 +01:00
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2019-04-24 10:10:08 +02:00
|
|
|
public function getTargetWiz($task, $script=false)
|
2019-02-19 20:27:05 +01:00
|
|
|
{
|
2021-03-15 14:37:08 +01:00
|
|
|
if ($script !== false
|
|
|
|
|| (int) $task['type'] === DISCOVERY_HOSTDEVICES_CUSTOM
|
|
|
|
) {
|
2019-04-24 10:10:08 +02:00
|
|
|
switch ($script['type']) {
|
2019-10-09 15:45:02 +02:00
|
|
|
case DISCOVERY_SCRIPT_APP_VMWARE:
|
|
|
|
return 'wiz=app&mode=vmware&page=0';
|
|
|
|
|
|
|
|
case DISCOVERY_SCRIPT_IPAM_RECON:
|
|
|
|
return '';
|
|
|
|
|
|
|
|
case DISCOVERY_SCRIPT_IPMI_RECON:
|
|
|
|
default:
|
|
|
|
return 'wiz=hd&mode=customnetscan';
|
|
|
|
|
2019-04-24 10:10:08 +02:00
|
|
|
case DISCOVERY_SCRIPT_CLOUD_AWS:
|
2019-07-09 12:02:29 +02:00
|
|
|
switch ($task['type']) {
|
|
|
|
case DISCOVERY_CLOUD_AWS_EC2:
|
|
|
|
return 'wiz=cloud&mode=amazonws&ki='.$task['auth_strings'].'&page=1';
|
|
|
|
|
|
|
|
case DISCOVERY_CLOUD_AZURE_COMPUTE:
|
|
|
|
return 'wiz=cloud&mode=azure&ki='.$task['auth_strings'].'&sub=compute&page=0';
|
|
|
|
|
2021-03-24 11:52:47 +01:00
|
|
|
case DISCOVERY_CLOUD_AWS_S3:
|
|
|
|
return 'wiz=cloud&mode=amazonws&ki='.$task['auth_strings'].'&sub=s3&page=0';
|
|
|
|
|
2023-05-24 13:37:14 +02:00
|
|
|
case DISCOVERY_CLOUD_GCP_COMPUTE_ENGINE:
|
|
|
|
return 'wiz=cloud&mode=gcp&ki='.$task['auth_strings'].'&sub=compute&page=0';
|
|
|
|
|
2019-07-09 12:02:29 +02:00
|
|
|
default:
|
|
|
|
return 'wiz=cloud';
|
|
|
|
}
|
2019-04-24 10:10:08 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-03 18:13:19 +02:00
|
|
|
switch ($task['type']) {
|
|
|
|
case DISCOVERY_APP_MYSQL:
|
|
|
|
return 'wiz=app&mode=mysql&page=0';
|
|
|
|
|
2020-02-12 11:47:43 +01:00
|
|
|
case DISCOVERY_APP_MICROSOFT_SQL_SERVER:
|
|
|
|
return 'wiz=app&mode=MicrosoftSQLServer&page=0';
|
|
|
|
|
2019-04-05 10:41:09 +02:00
|
|
|
case DISCOVERY_APP_ORACLE:
|
|
|
|
return 'wiz=app&mode=oracle&page=0';
|
|
|
|
|
2020-06-11 14:53:34 +02:00
|
|
|
case DISCOVERY_APP_DB2:
|
|
|
|
return 'wiz=app&mode=DB2&page=0';
|
|
|
|
|
2019-04-03 18:13:19 +02:00
|
|
|
case DISCOVERY_CLOUD_AWS:
|
2019-04-24 10:10:08 +02:00
|
|
|
case DISCOVERY_CLOUD_AWS_EC2:
|
2019-06-22 13:11:35 +02:00
|
|
|
return 'wiz=cloud&mode=amazonws&ki='.$task['auth_strings'].'&page=1';
|
2019-02-19 20:27:05 +01:00
|
|
|
|
2019-04-10 20:40:03 +02:00
|
|
|
case DISCOVERY_CLOUD_AWS_RDS:
|
2019-06-26 19:34:34 +02:00
|
|
|
return 'wiz=cloud&mode=amazonws&ki='.$task['auth_strings'].'&sub=rds&page=0';
|
2019-04-10 20:40:03 +02:00
|
|
|
|
2019-11-21 18:21:46 +01:00
|
|
|
case DISCOVERY_APP_SAP:
|
|
|
|
return 'wiz=app&mode=SAP&page=0';
|
|
|
|
|
2019-02-19 20:27:05 +01:00
|
|
|
default:
|
2019-04-24 10:10:08 +02:00
|
|
|
if ($task['description'] == 'console_task') {
|
|
|
|
return 'wiz=ctask';
|
2019-03-06 17:14:32 +01:00
|
|
|
} else {
|
2019-04-24 10:10:08 +02:00
|
|
|
return 'wiz=hd&mode=netscan';
|
2019-03-06 17:14:32 +01:00
|
|
|
}
|
2019-03-07 14:45:26 +01:00
|
|
|
break;
|
2019-02-19 20:27:05 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-03-16 23:52:20 +01:00
|
|
|
/**
|
|
|
|
* Returns percent of completion of target task.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2020-03-17 18:34:30 +01:00
|
|
|
public function taskProgress()
|
2020-03-16 23:52:20 +01:00
|
|
|
{
|
|
|
|
if (!is_ajax()) {
|
2020-03-17 18:34:30 +01:00
|
|
|
echo json_encode(['error' => true]);
|
|
|
|
return;
|
2020-03-16 23:52:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
$id_task = get_parameter('id', 0);
|
|
|
|
|
|
|
|
if ($id_task <= 0) {
|
|
|
|
echo json_encode(['error' => true]);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$status = db_get_value('status', 'trecon_task', 'id_rt', $id_task);
|
|
|
|
if ($status < 0) {
|
2023-10-16 15:47:48 +02:00
|
|
|
$status = '100';
|
2020-03-16 23:52:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
echo json_encode($status);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Generates charts for progress popup.
|
|
|
|
*
|
|
|
|
* @param array $task Task.
|
|
|
|
*
|
|
|
|
* @return string Charts in HTML.
|
|
|
|
*/
|
2020-03-17 18:34:30 +01:00
|
|
|
private function progressTaskGraph($task)
|
2020-03-16 23:52:20 +01:00
|
|
|
{
|
2022-03-31 14:34:16 +02:00
|
|
|
$result = '<div class="flex">';
|
2020-03-17 18:34:30 +01:00
|
|
|
$result .= '<div class="subtitle">';
|
|
|
|
$result .= '<span>'._('Overall Progress').'</span>';
|
2021-03-11 15:40:23 +01:00
|
|
|
$result .= '<div class="mrgn_top_25px">';
|
2020-03-16 23:52:20 +01:00
|
|
|
$result .= progress_circular_bar(
|
|
|
|
$task['id_rt'],
|
|
|
|
($task['status'] < 0) ? 100 : $task['status'],
|
2023-03-13 15:44:55 +01:00
|
|
|
150,
|
|
|
|
150,
|
2023-04-27 10:35:09 +02:00
|
|
|
'#14524f',
|
2020-03-16 23:52:20 +01:00
|
|
|
'%',
|
|
|
|
'',
|
2023-03-13 15:44:55 +01:00
|
|
|
'#ececec',
|
2020-03-16 23:52:20 +01:00
|
|
|
0
|
|
|
|
);
|
|
|
|
|
|
|
|
$result .= '</div>';
|
|
|
|
if ($task['status'] > 0) {
|
|
|
|
switch ($task['stats']['step']) {
|
|
|
|
case STEP_SCANNING:
|
|
|
|
$str = __('Scanning network');
|
|
|
|
break;
|
|
|
|
|
2020-03-25 18:02:58 +01:00
|
|
|
case STEP_CAPABILITIES:
|
|
|
|
$str = __('Checking');
|
|
|
|
break;
|
|
|
|
|
2020-03-16 23:52:20 +01:00
|
|
|
case STEP_AFT:
|
|
|
|
$str = __('Finding AFT connectivity');
|
|
|
|
break;
|
|
|
|
|
|
|
|
case STEP_TRACEROUTE:
|
|
|
|
$str = __('Finding traceroute connectivity');
|
|
|
|
break;
|
|
|
|
|
|
|
|
case STEP_GATEWAY:
|
|
|
|
$str = __('Finding gateway connectivity');
|
|
|
|
break;
|
|
|
|
|
|
|
|
case STEP_STATISTICS:
|
|
|
|
$str = __('Searching for devices...');
|
|
|
|
break;
|
|
|
|
|
|
|
|
case STEP_APP_SCAN:
|
|
|
|
$str = __('Analyzing application...');
|
|
|
|
break;
|
|
|
|
|
|
|
|
case STEP_CUSTOM_QUERIES:
|
|
|
|
$str = __('Executing custom queries...');
|
|
|
|
break;
|
|
|
|
|
2020-03-19 18:33:04 +01:00
|
|
|
case STEP_MONITORING:
|
|
|
|
$str = __('Testing modules...');
|
|
|
|
break;
|
|
|
|
|
|
|
|
case STEP_PROCESSING:
|
|
|
|
$str = __('Processing results...');
|
|
|
|
break;
|
|
|
|
|
2020-03-16 23:52:20 +01:00
|
|
|
default:
|
2020-03-25 18:02:58 +01:00
|
|
|
$str = __('Processing...');
|
2020-03-16 23:52:20 +01:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
$result .= '</div>';
|
2020-03-17 18:34:30 +01:00
|
|
|
$result .= '<div class="subtitle">';
|
|
|
|
$result .= '<span>'.$str.' ';
|
2020-03-25 18:02:58 +01:00
|
|
|
if (empty($str) === false) {
|
2020-03-16 23:52:20 +01:00
|
|
|
$result .= $task['stats']['c_network_name'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$result .= '</span>';
|
|
|
|
|
2021-03-11 15:40:23 +01:00
|
|
|
$result .= '<div class="mrgn_top_25px">';
|
2020-03-16 23:52:20 +01:00
|
|
|
$result .= progress_circular_bar(
|
|
|
|
$task['id_rt'].'_detail',
|
|
|
|
$task['stats']['c_network_percent'],
|
2023-03-13 15:44:55 +01:00
|
|
|
150,
|
|
|
|
150,
|
2023-04-27 10:35:09 +02:00
|
|
|
'#14524f',
|
2020-03-16 23:52:20 +01:00
|
|
|
'%',
|
|
|
|
'',
|
2023-03-13 15:44:55 +01:00
|
|
|
'#ececec',
|
2020-03-16 23:52:20 +01:00
|
|
|
0
|
|
|
|
);
|
|
|
|
$result .= '</div></div>';
|
|
|
|
}
|
|
|
|
|
2020-03-25 18:02:58 +01:00
|
|
|
if ($task['review_mode'] == DISCOVERY_REVIEW) {
|
|
|
|
if ($task['status'] <= 0
|
|
|
|
&& empty($task['summary']) === false
|
|
|
|
) {
|
|
|
|
$result .= '<span class="link review" onclick="show_review('.$task['id_rt'].',\''.$task['name'].'\')">';
|
|
|
|
$result .= '»'.__('Review');
|
|
|
|
$result .= '</span>';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-03-16 23:52:20 +01:00
|
|
|
$result .= '</div></div>';
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Generates a summary table for given task.
|
|
|
|
*
|
|
|
|
* @param array $task Task.
|
|
|
|
*
|
2022-02-07 14:32:59 +01:00
|
|
|
* @return string HTML code. code with summary.
|
2020-03-16 23:52:20 +01:00
|
|
|
*/
|
2020-03-17 18:34:30 +01:00
|
|
|
private function progressTaskSummary($task)
|
2020-03-16 23:52:20 +01:00
|
|
|
{
|
|
|
|
global $config;
|
|
|
|
include_once $config['homedir'].'/include/graphs/functions_d3.php';
|
|
|
|
|
|
|
|
if (is_array($task) === false) {
|
|
|
|
return '';
|
|
|
|
}
|
|
|
|
|
|
|
|
$output = '';
|
|
|
|
|
2023-04-26 17:16:34 +02:00
|
|
|
if (is_array($task['stats']) === false && (int) $task['type'] !== DISCOVERY_EXTENSION) {
|
2023-05-08 10:51:25 +02:00
|
|
|
$task['stats'] = json_decode(io_safe_output($task['summary']), true);
|
2022-03-31 14:34:16 +02:00
|
|
|
if (json_last_error() !== JSON_ERROR_NONE) {
|
|
|
|
return $task['summary'];
|
|
|
|
}
|
2020-03-17 18:34:30 +01:00
|
|
|
}
|
|
|
|
|
2023-04-26 17:16:34 +02:00
|
|
|
if (is_array($task['stats']) || (int) $task['type'] === DISCOVERY_EXTENSION) {
|
2020-03-16 23:52:20 +01:00
|
|
|
$i = 0;
|
|
|
|
$table = new StdClasS();
|
|
|
|
$table->class = 'databox data';
|
|
|
|
$table->width = '75%';
|
2024-02-13 12:58:47 +01:00
|
|
|
$table->styleTable = 'margin: 2em auto 0;border: 1px solid #ddd;background: white; overflow-wrap: anywhere';
|
2020-03-16 23:52:20 +01:00
|
|
|
$table->rowid = [];
|
|
|
|
$table->data = [];
|
|
|
|
|
2023-11-28 09:56:51 +01:00
|
|
|
$countErrors = 1;
|
|
|
|
$tableErrors = new StdClasS();
|
|
|
|
$tableErrors->class = 'databox data';
|
|
|
|
$tableErrors->width = '75%';
|
2024-02-13 12:58:47 +01:00
|
|
|
$tableErrors->styleTable = 'margin: 2em auto 0;border: 1px solid #ddd;background: white; overflow-wrap: anywhere';
|
2023-11-28 09:56:51 +01:00
|
|
|
$tableErrors->rowid = [];
|
|
|
|
$tableErrors->data = [];
|
|
|
|
|
2020-04-06 12:05:03 +02:00
|
|
|
if ($task['review_mode'] == DISCOVERY_RESULTS) {
|
|
|
|
$agents_review = db_get_all_rows_filter(
|
|
|
|
'tdiscovery_tmp_agents',
|
|
|
|
['id_rt' => $task['id_rt']]
|
|
|
|
);
|
|
|
|
|
|
|
|
$agents = 0;
|
|
|
|
$total = 0;
|
|
|
|
if (is_array($agents_review)) {
|
|
|
|
foreach ($agents_review as $agent) {
|
|
|
|
$data = json_decode(base64_decode($agent['data']), true);
|
|
|
|
|
|
|
|
if (is_array($data) === false) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (is_array($data['agent']) === false) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Ensure agent_id really exists.
|
|
|
|
$agent_id = agents_get_agent_id(
|
|
|
|
$data['agent']['nombre'],
|
|
|
|
true
|
|
|
|
);
|
|
|
|
|
|
|
|
if ($agent_id > 0) {
|
|
|
|
$agents++;
|
|
|
|
}
|
|
|
|
|
|
|
|
$total++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Content.
|
|
|
|
$table->data[$i][0] = '<b>'.__('Host&devices total').'</b>';
|
|
|
|
$table->data[$i][1] = '<span id="discovered">';
|
|
|
|
$table->data[$i][1] .= $total;
|
2020-03-25 18:02:58 +01:00
|
|
|
$table->data[$i++][1] .= '</span>';
|
2020-03-16 23:52:20 +01:00
|
|
|
|
2020-04-06 12:05:03 +02:00
|
|
|
$table->data[$i][0] = '<b>'.__('Agents monitored').'</b>';
|
|
|
|
$table->data[$i][1] = '<span id="alive">';
|
|
|
|
$table->data[$i][1] .= $agents;
|
2020-03-25 18:02:58 +01:00
|
|
|
$table->data[$i++][1] .= '</span>';
|
2020-04-06 12:05:03 +02:00
|
|
|
|
|
|
|
$table->data[$i][0] = '<b>'.__('Agents pending').'</b>';
|
|
|
|
$table->data[$i][1] = '<span id="alive">';
|
|
|
|
$table->data[$i][1] .= ($total - $agents);
|
|
|
|
$table->data[$i++][1] .= '</span>';
|
2023-04-24 15:28:54 +02:00
|
|
|
} else if ((int) $task['type'] === DISCOVERY_EXTENSION) {
|
|
|
|
// Content.
|
2023-04-26 17:16:34 +02:00
|
|
|
$countSummary = 1;
|
2023-04-28 11:33:33 +02:00
|
|
|
if (is_array($task['stats']) === true && count(array_filter(array_keys($task['stats']), 'is_numeric')) === count($task['stats'])) {
|
2023-04-24 15:28:54 +02:00
|
|
|
foreach ($task['stats'] as $key => $summary) {
|
|
|
|
if (is_array($summary) === true) {
|
2023-11-28 09:34:10 +01:00
|
|
|
$table->data[$i][0] = '<b>'.__('Summary').' '.$countSummary.'</b>';
|
|
|
|
$table->data[$i][1] = '';
|
|
|
|
$countSummary++;
|
|
|
|
$i++;
|
2023-04-24 16:18:49 +02:00
|
|
|
if (empty($summary['summary']) === true && empty($summary['info']) === true) {
|
|
|
|
$table->data[$i][0] = json_encode($summary, JSON_PRETTY_PRINT);
|
|
|
|
$table->data[$i][1] = '';
|
|
|
|
$i++;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2023-04-28 11:33:33 +02:00
|
|
|
$unknownJson = $summary;
|
2023-04-24 15:28:54 +02:00
|
|
|
foreach ($summary as $k2 => $v) {
|
|
|
|
if (is_array($v) === true) {
|
|
|
|
if ($k2 === 'summary') {
|
|
|
|
foreach ($v as $k3 => $v2) {
|
|
|
|
$table->data[$i][0] = $k3;
|
|
|
|
$table->data[$i][1] = $v2;
|
|
|
|
$i++;
|
|
|
|
}
|
2023-04-28 11:33:33 +02:00
|
|
|
|
|
|
|
unset($unknownJson[$k2]);
|
2023-04-24 15:28:54 +02:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if ($k2 === 'info') {
|
2023-04-24 16:18:49 +02:00
|
|
|
$table->data[$i][0] = $v;
|
2023-04-24 15:28:54 +02:00
|
|
|
$table->data[$i][1] = '';
|
|
|
|
$i++;
|
2023-04-28 11:33:33 +02:00
|
|
|
|
|
|
|
unset($unknownJson[$k2]);
|
2023-04-24 15:28:54 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-04-28 11:33:33 +02:00
|
|
|
|
|
|
|
if (empty($unknownJson) === false) {
|
|
|
|
$table->data[$i][0] = json_encode($unknownJson, JSON_PRETTY_PRINT);
|
|
|
|
$table->data[$i][1] = '';
|
|
|
|
$i++;
|
|
|
|
}
|
2023-04-24 15:28:54 +02:00
|
|
|
} else {
|
2023-11-28 09:34:10 +01:00
|
|
|
$tableErrors->data[$i][0] = '<b>'.__('Error %s', $countErrors).'</b>';
|
|
|
|
$tableErrors->data[$i][1] = '';
|
|
|
|
$i++;
|
|
|
|
$tableErrors->data[$i][0] = $summary;
|
|
|
|
$tableErrors->data[$i][1] = '';
|
|
|
|
$countErrors++;
|
2023-04-24 15:28:54 +02:00
|
|
|
$i++;
|
|
|
|
}
|
|
|
|
}
|
2023-04-28 11:44:05 +02:00
|
|
|
} else {
|
|
|
|
$table->data[$i][0] = '<b>'.__('Summary').'</b>';
|
|
|
|
$table->data[$i][1] = '';
|
|
|
|
$i++;
|
|
|
|
$table->data[$i][0] = $task['summary'];
|
|
|
|
$table->data[$i][1] = '';
|
|
|
|
$i++;
|
2023-04-24 15:28:54 +02:00
|
|
|
}
|
2020-04-06 12:05:03 +02:00
|
|
|
} else {
|
|
|
|
// Content.
|
2022-03-31 14:34:16 +02:00
|
|
|
if (is_array($task['stats']['summary']) === true) {
|
|
|
|
$table->data[$i][0] = '<b>'.__('Hosts discovered').'</b>';
|
|
|
|
$table->data[$i][1] = '<span id="discovered">';
|
|
|
|
$table->data[$i][1] .= $task['stats']['summary']['discovered'];
|
|
|
|
$table->data[$i++][1] .= '</span>';
|
2020-04-06 12:05:03 +02:00
|
|
|
|
2022-03-31 14:34:16 +02:00
|
|
|
$table->data[$i][0] = '<b>'.__('Alive').'</b>';
|
|
|
|
$table->data[$i][1] = '<span id="alive">';
|
|
|
|
$table->data[$i][1] .= $task['stats']['summary']['alive'];
|
2020-04-06 12:05:03 +02:00
|
|
|
$table->data[$i++][1] .= '</span>';
|
|
|
|
|
2022-03-31 14:34:16 +02:00
|
|
|
$table->data[$i][0] = '<b>'.__('Not alive').'</b>';
|
|
|
|
$table->data[$i][1] = '<span id="not_alive">';
|
|
|
|
$table->data[$i][1] .= $task['stats']['summary']['not_alive'];
|
2020-04-06 12:05:03 +02:00
|
|
|
$table->data[$i++][1] .= '</span>';
|
2022-03-31 14:34:16 +02:00
|
|
|
|
|
|
|
if ($task['type'] == DISCOVERY_HOSTDEVICES) {
|
|
|
|
$table->data[$i][0] = '<b>'.__('Responding SNMP').'</b>';
|
|
|
|
$table->data[$i][1] = '<span id="SNMP">';
|
|
|
|
$table->data[$i][1] .= $task['stats']['summary']['SNMP'];
|
|
|
|
$table->data[$i++][1] .= '</span>';
|
|
|
|
|
|
|
|
$table->data[$i][0] = '<b>'.__('Responding WMI').'</b>';
|
|
|
|
$table->data[$i][1] = '<span id="WMI">';
|
|
|
|
$table->data[$i][1] .= $task['stats']['summary']['WMI'];
|
|
|
|
$table->data[$i++][1] .= '</span>';
|
|
|
|
}
|
|
|
|
} else {
|
2023-11-28 09:56:51 +01:00
|
|
|
$tableErrors->data[$i][0] = '<b>'.__('Error %s', $countErrors).'</b>';
|
|
|
|
$tableErrors->data[$i][1] = '';
|
|
|
|
$i++;
|
|
|
|
$tableErrors->data[$i][0] = $task['stats']['summary'];
|
|
|
|
$tableErrors->data[$i][1] = '';
|
|
|
|
$countErrors++;
|
|
|
|
$i++;
|
2020-04-06 12:05:03 +02:00
|
|
|
}
|
2020-03-25 18:02:58 +01:00
|
|
|
}
|
2020-03-16 23:52:20 +01:00
|
|
|
|
2020-03-17 18:34:30 +01:00
|
|
|
$output = '<div class="subtitle"><span>'.__('Summary').'</span></div>';
|
2023-11-28 09:34:10 +01:00
|
|
|
if (is_array($table->data) === true && count($table->data) > 0) {
|
|
|
|
$output .= html_print_table($table, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (is_array($tableErrors->data) === true && count($tableErrors->data) > 0) {
|
|
|
|
$output .= html_print_table($tableErrors, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
$output .= '</div>';
|
2020-03-16 23:52:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Content of modal 'task progress', ajax only.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2020-03-17 18:34:30 +01:00
|
|
|
public function progressTaskDiscovery()
|
2020-03-16 23:52:20 +01:00
|
|
|
{
|
|
|
|
if (!is_ajax()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$id_task = get_parameter('id', 0);
|
|
|
|
|
|
|
|
if ($id_task <= 0) {
|
|
|
|
echo json_encode(['error' => true]);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$task = db_get_row('trecon_task', 'id_rt', $id_task);
|
2023-05-08 10:51:25 +02:00
|
|
|
$task['stats'] = json_decode(io_safe_output($task['summary']), true);
|
2020-03-17 18:34:30 +01:00
|
|
|
$summary = $this->progressTaskSummary($task);
|
2020-03-16 23:52:20 +01:00
|
|
|
|
|
|
|
$output = '';
|
|
|
|
|
|
|
|
// Header information.
|
|
|
|
if ((int) $task['status'] <= 0 && empty($summary)) {
|
2022-12-05 14:09:12 +01:00
|
|
|
if ((int) $task['utimestamp'] !== 0) {
|
|
|
|
$output .= $this->progressTaskGraph($task);
|
2020-11-13 11:36:06 +01:00
|
|
|
} else {
|
|
|
|
$outputMessage = __('This task has never executed');
|
|
|
|
|
2022-12-05 14:09:12 +01:00
|
|
|
$output .= ui_print_info_message(
|
|
|
|
$outputMessage,
|
|
|
|
'',
|
|
|
|
true
|
|
|
|
);
|
|
|
|
}
|
2020-03-16 23:52:20 +01:00
|
|
|
} else if ($task['status'] == 1
|
|
|
|
|| ($task['utimestamp'] == 0 && $task['interval_sweep'])
|
|
|
|
) {
|
|
|
|
$output .= ui_print_info_message(
|
|
|
|
__('Task queued, please wait.'),
|
|
|
|
'',
|
|
|
|
true
|
|
|
|
).'</div>';
|
|
|
|
} else {
|
2020-03-17 18:34:30 +01:00
|
|
|
$output .= $this->progressTaskGraph($task);
|
2020-03-16 23:52:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
$output .= $summary;
|
|
|
|
|
|
|
|
echo json_encode(['html' => $output]);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get a map of target task.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2020-03-17 18:34:30 +01:00
|
|
|
public function taskShowmap()
|
2020-03-16 23:52:20 +01:00
|
|
|
{
|
|
|
|
global $config;
|
|
|
|
include_once $config['homedir'].'/include/class/NetworkMap.class.php';
|
|
|
|
$id_task = get_parameter('id', 0);
|
|
|
|
|
|
|
|
$map = new NetworkMap(
|
|
|
|
[
|
2020-04-13 18:28:56 +02:00
|
|
|
'id_task' => $id_task,
|
|
|
|
'pure' => 1,
|
|
|
|
'widget' => true,
|
|
|
|
'map_options' => [
|
|
|
|
'map_filter' => [
|
|
|
|
'x_offs' => 120,
|
|
|
|
'node_sep' => 10,
|
|
|
|
],
|
|
|
|
],
|
2020-03-16 23:52:20 +01:00
|
|
|
]
|
|
|
|
);
|
2020-12-09 12:23:49 +01:00
|
|
|
if (count($map->nodes) <= 1) {
|
|
|
|
// No nodes detected in current task definition.
|
|
|
|
$task = db_get_row('trecon_task', 'id_rt', $id_task);
|
|
|
|
|
|
|
|
if ((int) $task['type'] === DISCOVERY_CLOUD_GCP_COMPUTE_ENGINE) {
|
|
|
|
ui_print_info_message(
|
|
|
|
__('Please ensure instances or regions are being monitorized and \'scan and general monitoring\' is enabled.')
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-03-16 23:52:20 +01:00
|
|
|
$map->printMap();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Shows a modal to review results found by discovery task.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2020-03-17 18:34:30 +01:00
|
|
|
public function showTaskReview()
|
2020-03-16 23:52:20 +01:00
|
|
|
{
|
|
|
|
$id_task = get_parameter('id', 0);
|
|
|
|
if ($id_task <= 0) {
|
|
|
|
ui_print_error_message(__('Invalid task'));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-03-18 19:31:58 +01:00
|
|
|
$task_data = db_get_all_rows_filter(
|
|
|
|
'tdiscovery_tmp_agents',
|
|
|
|
['id_rt' => $id_task]
|
|
|
|
);
|
2020-03-17 18:34:30 +01:00
|
|
|
$task = db_get_row('trecon_task', 'id_rt', $id_task);
|
2020-03-16 23:52:20 +01:00
|
|
|
|
2020-03-18 19:31:58 +01:00
|
|
|
$simple_data = [];
|
2020-03-17 18:34:30 +01:00
|
|
|
if (is_array($task_data)) {
|
2020-03-18 19:31:58 +01:00
|
|
|
foreach ($task_data as $agent) {
|
|
|
|
$data = json_decode(base64_decode($agent['data']), true);
|
|
|
|
if (is_array($data) === false) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2020-03-25 18:02:58 +01:00
|
|
|
if (is_array($data['agent']) === false) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2020-03-18 19:31:58 +01:00
|
|
|
$id = $data['agent']['nombre'];
|
|
|
|
|
|
|
|
// Partial.
|
|
|
|
$tmp = [
|
|
|
|
'id' => $id,
|
|
|
|
'name' => $id,
|
|
|
|
'checked' => $data['agent']['checked'],
|
|
|
|
];
|
|
|
|
|
2020-03-23 19:09:22 +01:00
|
|
|
// Ensure agent_id really exists.
|
|
|
|
$agent_id = agents_get_agent_id($data['agent']['nombre'], true);
|
2020-03-18 19:31:58 +01:00
|
|
|
|
|
|
|
if ($agent_id > 0) {
|
|
|
|
$tmp['disabled'] = 1;
|
|
|
|
$tmp['agent_id'] = $agent_id;
|
2020-04-07 19:10:37 +02:00
|
|
|
$tmp['checked'] = 1;
|
2020-03-18 19:31:58 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Store.
|
|
|
|
$simple_data[] = $tmp;
|
|
|
|
|
|
|
|
if (is_array($data['modules'])) {
|
2021-03-15 15:16:49 +01:00
|
|
|
// Alphabetically sort.
|
2021-04-07 10:11:35 +02:00
|
|
|
ksort($data['modules'], (SORT_STRING | SORT_FLAG_CASE));
|
2021-03-15 15:16:49 +01:00
|
|
|
|
2020-03-18 19:31:58 +01:00
|
|
|
$simple_data = array_merge(
|
|
|
|
$simple_data,
|
|
|
|
array_reduce(
|
|
|
|
$data['modules'],
|
|
|
|
function ($carry, $item) use ($id, $agent_id) {
|
2020-03-19 18:33:04 +01:00
|
|
|
if (empty($item['name'])) {
|
|
|
|
$item['name'] = $item['nombre'];
|
|
|
|
}
|
|
|
|
|
2020-03-18 19:31:58 +01:00
|
|
|
if ($item['name'] == 'Host Alive') {
|
|
|
|
return $carry;
|
|
|
|
}
|
|
|
|
|
2020-03-23 19:09:22 +01:00
|
|
|
if (empty($item['name'])) {
|
|
|
|
$item['name'] = $item['nombre'];
|
|
|
|
}
|
|
|
|
|
2020-03-18 19:31:58 +01:00
|
|
|
$tmp = [
|
|
|
|
'name' => $item['name'],
|
|
|
|
'id' => $id.'-'.$item['name'],
|
|
|
|
'pid' => $id,
|
|
|
|
'checked' => $item['checked'],
|
|
|
|
];
|
|
|
|
|
2020-03-25 18:02:58 +01:00
|
|
|
$agentmodule_id = modules_get_agentmodule_id(
|
2020-03-23 19:09:22 +01:00
|
|
|
io_safe_input($item['name']),
|
|
|
|
$agent_id
|
|
|
|
);
|
2020-03-17 18:34:30 +01:00
|
|
|
|
|
|
|
if ($agentmodule_id > 0) {
|
|
|
|
$tmp['disabled'] = 1;
|
|
|
|
$tmp['checked'] = 1;
|
|
|
|
$tmp['module_id'] = $agentmodule_id;
|
|
|
|
}
|
|
|
|
|
2020-03-18 19:31:58 +01:00
|
|
|
$carry[] = $tmp;
|
|
|
|
return $carry;
|
|
|
|
},
|
|
|
|
[]
|
|
|
|
)
|
2020-03-16 23:52:20 +01:00
|
|
|
);
|
2020-03-18 19:31:58 +01:00
|
|
|
}
|
|
|
|
}
|
2020-04-07 18:50:56 +02:00
|
|
|
}
|
2020-03-16 23:52:20 +01:00
|
|
|
|
2020-04-07 18:50:56 +02:00
|
|
|
echo '<div>';
|
|
|
|
echo $this->progressTaskSummary($task);
|
|
|
|
echo '</div>';
|
|
|
|
|
|
|
|
if (count($simple_data) > 0) {
|
2020-03-17 18:34:30 +01:00
|
|
|
echo '<div class="subtitle">';
|
|
|
|
echo '<span>';
|
|
|
|
echo __('Please select devices to be monitored');
|
|
|
|
echo '</span><div class="manage">';
|
2020-04-06 13:00:09 +02:00
|
|
|
echo '<button onclick="$(\'.sim-tree li:not(.disabled) a\').each(function(){simTree_tree.doCheck($(this), false); simTree_tree.clickNode($(this));});">';
|
2020-03-17 18:34:30 +01:00
|
|
|
echo __('select all');
|
|
|
|
echo '</button>';
|
2020-04-06 13:00:09 +02:00
|
|
|
echo '<button onclick="$(\'.sim-tree li:not(.disabled) a\').each(function(){simTree_tree.doCheck($(this), true); simTree_tree.clickNode($(this));});">';
|
2020-03-17 18:34:30 +01:00
|
|
|
echo __('deselect all');
|
|
|
|
echo '</button>';
|
2020-03-30 12:51:52 +02:00
|
|
|
echo '<button onclick="$(\'.sim-tree-spread.sim-icon-r\').click();">';
|
|
|
|
echo __('expand all');
|
|
|
|
echo '</button>';
|
|
|
|
echo '<button onclick="$(\'.sim-tree-spread.sim-icon-d\').click();">';
|
|
|
|
echo __('collapse all');
|
|
|
|
echo '</button>';
|
2020-03-17 18:34:30 +01:00
|
|
|
echo '</div>';
|
|
|
|
echo '</div>';
|
|
|
|
echo '<form id="review">';
|
2020-03-16 23:52:20 +01:00
|
|
|
echo '<div id="tree"></div>';
|
2020-03-17 18:34:30 +01:00
|
|
|
echo parent::printTree(
|
|
|
|
'tree',
|
|
|
|
$simple_data
|
|
|
|
);
|
|
|
|
echo '</form>';
|
2020-04-07 18:50:56 +02:00
|
|
|
} else {
|
|
|
|
echo '<div class="subtitle">';
|
|
|
|
echo '<span>';
|
|
|
|
echo __('No devices found in temporary resources, please re-launch.');
|
|
|
|
echo '</span>';
|
|
|
|
echo '</div>';
|
2020-03-16 23:52:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Processes a review over temporary results found by discovery task.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
2020-03-17 18:34:30 +01:00
|
|
|
public function parseTaskReview()
|
2020-03-16 23:52:20 +01:00
|
|
|
{
|
|
|
|
$id_task = get_parameter('id', 0);
|
|
|
|
if ($id_task <= 0) {
|
|
|
|
echo $this->error(__('Invalid task'));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-03-18 19:31:58 +01:00
|
|
|
$ids = [];
|
2020-03-30 12:51:52 +02:00
|
|
|
$n_agents = 0;
|
2020-03-17 18:34:30 +01:00
|
|
|
$selection = io_safe_output(get_parameter('tree-data-tree', ''));
|
2020-03-18 19:31:58 +01:00
|
|
|
if (empty($selection) === false) {
|
2020-03-17 18:34:30 +01:00
|
|
|
$selection = json_decode($selection, true);
|
|
|
|
$ids = array_reduce(
|
|
|
|
$selection,
|
2020-03-30 12:51:52 +02:00
|
|
|
function ($carry, $item) use (&$n_agents) {
|
2020-04-06 13:42:39 +02:00
|
|
|
// String is agent-module.
|
|
|
|
$fields = explode('-', $item['id']);
|
|
|
|
$agent_name = $fields[0];
|
|
|
|
$module_name = $fields[1];
|
|
|
|
if ($module_name === null) {
|
|
|
|
// Do not count if already created.
|
|
|
|
if (db_get_value(
|
|
|
|
'id_agente',
|
|
|
|
'tagente',
|
|
|
|
'nombre',
|
|
|
|
io_safe_input($agent_name)
|
|
|
|
) === false
|
|
|
|
) {
|
|
|
|
$n_agents++;
|
|
|
|
}
|
2020-03-30 12:51:52 +02:00
|
|
|
}
|
|
|
|
|
2020-03-17 18:34:30 +01:00
|
|
|
$carry[] = $item['id'];
|
|
|
|
return $carry;
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2020-03-18 19:31:58 +01:00
|
|
|
$task_data = db_get_all_rows_filter(
|
|
|
|
'tdiscovery_tmp_agents',
|
|
|
|
['id_rt' => $id_task]
|
|
|
|
);
|
2020-03-17 18:34:30 +01:00
|
|
|
|
2020-03-30 12:51:52 +02:00
|
|
|
// License precheck.
|
|
|
|
$license = enterprise_hook('license_get_info');
|
|
|
|
|
|
|
|
if (is_array($license) === true
|
2021-10-05 11:26:29 +02:00
|
|
|
&& $n_agents > ($license['limit'] - $license['count_enabled'])
|
2020-03-30 12:51:52 +02:00
|
|
|
) {
|
2021-10-05 11:26:29 +02:00
|
|
|
$limit = ($license['limit'] - $license['count_enabled']);
|
2020-03-30 12:51:52 +02:00
|
|
|
echo json_encode(
|
|
|
|
[
|
|
|
|
'error' => __(
|
|
|
|
'Your selection exceeds the agents available on your license. Limit %d',
|
|
|
|
$limit
|
|
|
|
),
|
|
|
|
]
|
|
|
|
);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-03-17 18:34:30 +01:00
|
|
|
$summary = [];
|
2020-03-18 19:31:58 +01:00
|
|
|
if (is_array($ids)) {
|
|
|
|
foreach ($task_data as $row) {
|
|
|
|
$data = json_decode(base64_decode($row['data']), true);
|
|
|
|
|
|
|
|
if (is_array($data)) {
|
|
|
|
// Analize each agent.
|
|
|
|
$agent_name = $data['agent']['nombre'];
|
|
|
|
if (in_array($agent_name, $ids)) {
|
|
|
|
if ($data['agent']['checked'] != 1) {
|
|
|
|
$summary[] = '<li class="added">'.$agent_name.'</li>';
|
|
|
|
}
|
|
|
|
|
|
|
|
$data['agent']['checked'] = 1;
|
|
|
|
} else {
|
|
|
|
if ($data['agent']['checked'] == 1) {
|
|
|
|
$summary[] = '<li class="removed">'.__('Removed').' '.$agent_name.'</li>';
|
|
|
|
}
|
|
|
|
|
|
|
|
$data['agent']['checked'] = 0;
|
2020-03-17 18:34:30 +01:00
|
|
|
}
|
|
|
|
|
2020-03-18 19:31:58 +01:00
|
|
|
// Modules.
|
|
|
|
if (is_array($data['modules'])) {
|
|
|
|
$n_modules = count($data['modules']);
|
2020-03-19 18:33:04 +01:00
|
|
|
foreach ($data['modules'] as $module_name => $module) {
|
2020-03-18 19:31:58 +01:00
|
|
|
if (in_array($agent_name.'-'.$module_name, $ids)) {
|
2020-03-19 18:33:04 +01:00
|
|
|
if ($data['modules'][$module_name]['checked'] != 1) {
|
2020-03-18 19:31:58 +01:00
|
|
|
$summary[] = '<li class="added">'.$agent_name.' - '.$module_name.'</li>';
|
|
|
|
}
|
2020-03-17 18:34:30 +01:00
|
|
|
|
2020-03-19 18:33:04 +01:00
|
|
|
$data['modules'][$module_name]['checked'] = 1;
|
2020-03-18 19:31:58 +01:00
|
|
|
} else {
|
2020-03-19 18:33:04 +01:00
|
|
|
if ($data['modules'][$module_name]['checked'] == 1) {
|
2020-04-06 14:32:20 +02:00
|
|
|
if ($module_name != 'Host Alive') {
|
|
|
|
$summary[] = '<li class="removed">'.__('Removed').' '.$agent_name.' - '.$module_name.'</li>';
|
|
|
|
}
|
2020-03-18 19:31:58 +01:00
|
|
|
}
|
2020-03-17 18:34:30 +01:00
|
|
|
|
2020-03-19 18:33:04 +01:00
|
|
|
$data['modules'][$module_name]['checked'] = 0;
|
2020-03-18 19:31:58 +01:00
|
|
|
}
|
2020-03-17 18:34:30 +01:00
|
|
|
}
|
|
|
|
}
|
2020-03-18 19:31:58 +01:00
|
|
|
|
|
|
|
// Update data.
|
|
|
|
db_process_sql_update(
|
|
|
|
'tdiscovery_tmp_agents',
|
|
|
|
[
|
|
|
|
'data' => base64_encode(json_encode($data)),
|
|
|
|
'review_date' => date('Y-m-d H:i:s'),
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'id_rt' => $id_task,
|
|
|
|
'label' => $agent_name,
|
|
|
|
]
|
|
|
|
);
|
2020-03-17 18:34:30 +01:00
|
|
|
}
|
|
|
|
}
|
2020-03-18 19:31:58 +01:00
|
|
|
}
|
2020-03-17 18:34:30 +01:00
|
|
|
|
2020-03-23 19:09:22 +01:00
|
|
|
// Schedule execution.
|
|
|
|
db_process_sql_update(
|
|
|
|
'trecon_task',
|
|
|
|
[
|
2020-03-25 18:02:58 +01:00
|
|
|
'utimestamp' => 0,
|
|
|
|
'status' => 1,
|
|
|
|
'review_mode' => DISCOVERY_RESULTS,
|
2020-03-23 19:09:22 +01:00
|
|
|
],
|
|
|
|
['id_rt' => $id_task]
|
|
|
|
);
|
|
|
|
|
2020-03-18 19:31:58 +01:00
|
|
|
if (empty($summary)) {
|
2020-03-23 19:09:22 +01:00
|
|
|
$out .= __('No changes. Re-Scheduled');
|
2020-03-18 19:31:58 +01:00
|
|
|
} else {
|
2020-03-23 19:09:22 +01:00
|
|
|
$out .= __('Scheduled for creation');
|
2020-03-17 18:34:30 +01:00
|
|
|
$out .= '<ul>';
|
|
|
|
$out .= join('', $summary);
|
|
|
|
$out .= '</ul>';
|
|
|
|
}
|
2020-03-16 23:52:20 +01:00
|
|
|
|
|
|
|
echo json_encode(
|
|
|
|
['result' => $out]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2021-01-07 13:48:57 +01:00
|
|
|
/**
|
|
|
|
* Generates task status string for given task.
|
|
|
|
*
|
|
|
|
* @param array $task Discovery task (retrieved from DB).
|
|
|
|
*
|
|
|
|
* @return array Message to be displayed and review status.
|
|
|
|
*/
|
|
|
|
public function getStatusMessage(array $task)
|
|
|
|
{
|
|
|
|
$status = '';
|
|
|
|
$can_be_reviewed = false;
|
|
|
|
if (empty($task['summary']) === false
|
|
|
|
&& $task['summary'] == 'cancelled'
|
|
|
|
) {
|
|
|
|
$status = __('Cancelled').ui_print_help_tip(
|
|
|
|
__('Server has been restarted while executing this task, please retry.'),
|
|
|
|
true
|
|
|
|
);
|
|
|
|
} else if ($task['review_mode'] == DISCOVERY_STANDARD) {
|
|
|
|
if ($task['status'] <= 0
|
|
|
|
&& empty($task['summary']) === false
|
|
|
|
) {
|
2023-04-24 15:36:40 +02:00
|
|
|
if ($task['status'] == -2) {
|
|
|
|
$status = __('Failed');
|
|
|
|
} else {
|
2023-10-17 12:53:24 +02:00
|
|
|
$status = __('Done');
|
2023-04-24 15:36:40 +02:00
|
|
|
}
|
2021-01-07 13:48:57 +01:00
|
|
|
} else if ($task['utimestamp'] == 0
|
2023-10-17 12:53:24 +02:00
|
|
|
&& (bool) empty($task['summary']) === true
|
2021-01-07 13:48:57 +01:00
|
|
|
) {
|
|
|
|
$status = __('Not started');
|
|
|
|
} else {
|
|
|
|
$status = __('Pending');
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if ($task['status'] <= 0
|
|
|
|
&& empty($task['summary']) === false
|
|
|
|
) {
|
|
|
|
$can_be_reviewed = true;
|
|
|
|
$status = '<span class="link review" onclick="show_review('.$task['id_rt'].',\''.$task['name'].'\')">';
|
|
|
|
$status .= __('Review');
|
|
|
|
$status .= '</span>';
|
|
|
|
} else if ($task['utimestamp'] == 0
|
|
|
|
&& empty($task['summary'])
|
|
|
|
) {
|
|
|
|
$status = __('Not started');
|
|
|
|
} else {
|
|
|
|
if ($task['review_mode'] == DISCOVERY_RESULTS) {
|
|
|
|
$status = __('Processing');
|
|
|
|
} else {
|
|
|
|
$status = __('Searching');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return [
|
|
|
|
'message' => $status,
|
|
|
|
'can_be_reviewed' => $can_be_reviewed,
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2023-08-09 14:40:56 +02:00
|
|
|
/*
|
2023-08-08 15:02:31 +02:00
|
|
|
* Generates warning message.
|
|
|
|
*
|
|
|
|
* @return void Warning message.
|
2023-08-09 14:40:56 +02:00
|
|
|
|
|
|
|
public function getWarningMessage()
|
|
|
|
{
|
2023-08-08 15:02:31 +02:00
|
|
|
return ui_print_warning_message(
|
|
|
|
__(
|
|
|
|
'Starting with version 773, the new modular system of discovery 2.0 has been implemented. The current
|
|
|
|
discovery (1.0) and its defined tasks will continue to function normally until the next LTS version,
|
|
|
|
in which migration to the new system will be mandatory.
|
|
|
|
The tasks of the current discovery (1.0) will be marked as legacy although it will not affect their
|
|
|
|
operation, it will only be a visual indicator to identify and differentiate the tasks of discovery 1.0
|
|
|
|
from those of the new version 2.0.
|
|
|
|
In the intermediate versions between the 773 and the next LTS version, more applications of the new
|
|
|
|
discovery 2.0 will be added. Both new and those that will come to replace the applications of the
|
|
|
|
current discovery 1.0. In addition, an automatic migration tool for legacy (1.0) tasks to the new 2.0
|
|
|
|
model will be included.'
|
|
|
|
)
|
|
|
|
);
|
2023-08-09 14:40:56 +02:00
|
|
|
}*/
|
2023-08-08 15:02:31 +02:00
|
|
|
|
|
|
|
|
2019-02-15 18:05:59 +01:00
|
|
|
}
|