Minor fixes Wiz.Discovery
Former-commit-id: 750cd3ab1902ed3eda9806aa9b505d5e4a1175be
This commit is contained in:
parent
6a43536b33
commit
ad3e2b88bf
|
@ -19,10 +19,11 @@ ui_print_page_header(__('Discover'), '', false, '', true);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Undocumented function
|
* Mask class names.
|
||||||
*
|
*
|
||||||
* @param [type] $str
|
* @param string $str Wiz parameter.
|
||||||
* @return void
|
*
|
||||||
|
* @return string Classname.
|
||||||
*/
|
*/
|
||||||
function get_wiz_class($str)
|
function get_wiz_class($str)
|
||||||
{
|
{
|
||||||
|
@ -39,6 +40,9 @@ function get_wiz_class($str)
|
||||||
case 'app':
|
case 'app':
|
||||||
return 'Applications';
|
return 'Applications';
|
||||||
|
|
||||||
|
case 'ctask':
|
||||||
|
return 'ConsoleTasks';
|
||||||
|
|
||||||
default:
|
default:
|
||||||
// Ignore.
|
// Ignore.
|
||||||
return null;
|
return null;
|
||||||
|
@ -46,6 +50,31 @@ function get_wiz_class($str)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Aux. function to compare classpath names.
|
||||||
|
*
|
||||||
|
* @param string $a Classpath A.
|
||||||
|
* @param string $b Classpath B.
|
||||||
|
*
|
||||||
|
* @return string Matching one.
|
||||||
|
*/
|
||||||
|
function cl_load_cmp($a, $b)
|
||||||
|
{
|
||||||
|
$str_a = basename($a, '.class.php');
|
||||||
|
$str_b = basename($b, '.class.php');
|
||||||
|
if ($str_a == $str_b) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($str_a < $str_b) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* CLASS LOADER.
|
* CLASS LOADER.
|
||||||
*/
|
*/
|
||||||
|
@ -79,8 +108,13 @@ if (enterprise_installed() === true) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Combine class paths.
|
||||||
$classes = array_merge($classes, $enterprise_classes);
|
$classes = array_merge($classes, $enterprise_classes);
|
||||||
|
|
||||||
|
// Sort output.
|
||||||
|
uasort($classes, 'cl_load_cmp');
|
||||||
|
|
||||||
|
// Check user action.
|
||||||
$wiz_in_use = get_parameter('wiz', null);
|
$wiz_in_use = get_parameter('wiz', null);
|
||||||
$page = get_parameter('page', 0);
|
$page = get_parameter('page', 0);
|
||||||
|
|
||||||
|
@ -110,7 +144,13 @@ if ($classname_selected === null) {
|
||||||
foreach ($classes as $classpath) {
|
foreach ($classes as $classpath) {
|
||||||
$classname = basename($classpath, '.class.php');
|
$classname = basename($classpath, '.class.php');
|
||||||
$obj = new $classname();
|
$obj = new $classname();
|
||||||
$wiz_data[] = $obj->load();
|
|
||||||
|
// DiscoveryTaskList must be first button.
|
||||||
|
if ($classname == 'DiscoveryTaskList') {
|
||||||
|
array_unshift($wiz_data, $obj->load());
|
||||||
|
} else {
|
||||||
|
$wiz_data[] = $obj->load();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Wizard::printBigButtonsList($wiz_data);
|
Wizard::printBigButtonsList($wiz_data);
|
||||||
|
|
|
@ -0,0 +1,133 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Extension to schedule tasks on Pandora FMS Console
|
||||||
|
*
|
||||||
|
* @category Wizard
|
||||||
|
* @package Pandora FMS
|
||||||
|
* @subpackage Host&Devices
|
||||||
|
* @version 1.0.0
|
||||||
|
* @license See below
|
||||||
|
*
|
||||||
|
* ______ ___ _______ _______ ________
|
||||||
|
* | __ \.-----.--.--.--| |.-----.----.-----. | ___| | | __|
|
||||||
|
* | __/| _ | | _ || _ | _| _ | | ___| |__ |
|
||||||
|
* |___| |___._|__|__|_____||_____|__| |___._| |___| |__|_|__|_______|
|
||||||
|
*
|
||||||
|
* ============================================================================
|
||||||
|
* Copyright (c) 2005-2019 Artica Soluciones Tecnologicas
|
||||||
|
* Please see http://pandorafms.org for full contribution list
|
||||||
|
* 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.
|
||||||
|
* ============================================================================
|
||||||
|
*/
|
||||||
|
|
||||||
|
require_once __DIR__.'/Wizard.main.php';
|
||||||
|
require_once $config['homedir'].'/include/functions_users.php';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Defined as wizard to guide user to explore running tasks.
|
||||||
|
*/
|
||||||
|
class ConsoleTasks extends Wizard
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Number of pages to control breadcrum.
|
||||||
|
*
|
||||||
|
* @var integer
|
||||||
|
*/
|
||||||
|
public $MAXPAGES = 1;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Labels for breadcrum.
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
public $pageLabels = ['Base'];
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 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.',
|
||||||
|
string $icon='images/wizard/csv_image.svg',
|
||||||
|
string $label='Console Tasks'
|
||||||
|
) {
|
||||||
|
$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=ctask'
|
||||||
|
);
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Implements run method.
|
||||||
|
*
|
||||||
|
* @return mixed Returns null if wizard is ongoing. Result if done.
|
||||||
|
*/
|
||||||
|
public function run()
|
||||||
|
{
|
||||||
|
global $config;
|
||||||
|
|
||||||
|
// Load styles.
|
||||||
|
parent::run();
|
||||||
|
echo 'hola';
|
||||||
|
|
||||||
|
for ($i = 0; $i < $this->MAXPAGES; $i++) {
|
||||||
|
$breadcrum[] = [
|
||||||
|
'link' => 'index.php?sec=gservers&sec2=godmode/servers/discovery&wiz=app&mode=vmware&page='.$i.'&task='.$this->task['id_rt'],
|
||||||
|
'label' => $this->label.' '.$this->pageLabels[$i],
|
||||||
|
'selected' => (($i == $this->page) ? 1 : 0),
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($this->page < $this->MAXPAGES) {
|
||||||
|
// Avoid to print header out of wizard.
|
||||||
|
$this->prepareBreadcrum($breadcrum);
|
||||||
|
$this->printHeader();
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->printGoBackButton();
|
||||||
|
return null;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Implements load method.
|
||||||
|
*
|
||||||
|
* @return mixed Skeleton for button.
|
||||||
|
*/
|
||||||
|
public function load()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'icon' => $this->icon,
|
||||||
|
'label' => $this->label,
|
||||||
|
'url' => $this->url,
|
||||||
|
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -38,6 +38,24 @@ enterprise_include('include/class/CSVImportAgents.class.php');
|
||||||
class HostDevices extends Wizard
|
class HostDevices extends Wizard
|
||||||
{
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Number of pages to control breadcrum.
|
||||||
|
*
|
||||||
|
* @var integer
|
||||||
|
*/
|
||||||
|
public $maxPagesNetScan = 2;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Labels for breadcrum.
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
public $pageLabelsNetScan = [
|
||||||
|
'NetScan definition',
|
||||||
|
'NetScan features',
|
||||||
|
|
||||||
|
];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Stores all needed parameters to create a recon task.
|
* Stores all needed parameters to create a recon task.
|
||||||
*
|
*
|
||||||
|
@ -92,16 +110,6 @@ class HostDevices extends Wizard
|
||||||
$mode = get_parameter('mode', null);
|
$mode = get_parameter('mode', null);
|
||||||
|
|
||||||
if ($mode === null) {
|
if ($mode === null) {
|
||||||
$this->prepareBreadcrum(
|
|
||||||
[
|
|
||||||
[
|
|
||||||
'link' => $this->url.'&wiz=hd',
|
|
||||||
'label' => __('    Host & devices'),
|
|
||||||
],
|
|
||||||
]
|
|
||||||
);
|
|
||||||
|
|
||||||
$this->printHeader();
|
|
||||||
$this->printBigButtonsList(
|
$this->printBigButtonsList(
|
||||||
[
|
[
|
||||||
[
|
[
|
||||||
|
@ -123,62 +131,12 @@ class HostDevices extends Wizard
|
||||||
|
|
||||||
if (enterprise_installed()) {
|
if (enterprise_installed()) {
|
||||||
if ($mode == 'importcsv') {
|
if ($mode == 'importcsv') {
|
||||||
$this->prepareBreadcrum(
|
|
||||||
[
|
|
||||||
[
|
|
||||||
'link' => $this->url.'&wiz=hd',
|
|
||||||
'label' => __('    Host & devices'),
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'link' => $this->url.'&wiz=hd&mode=importcsv',
|
|
||||||
'label' => __('      Import CSV'),
|
|
||||||
],
|
|
||||||
]
|
|
||||||
);
|
|
||||||
$this->printHeader();
|
|
||||||
$csv_importer = new CSVImportAgents($this->page, $this->breadcrum);
|
$csv_importer = new CSVImportAgents($this->page, $this->breadcrum);
|
||||||
return $csv_importer->runCSV();
|
return $csv_importer->runCSV();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($mode == 'netscan') {
|
if ($mode == 'netscan') {
|
||||||
if ($this->page != 2) {
|
|
||||||
// Do not paint breadcrum in last page. Redirected.
|
|
||||||
$this->prepareBreadcrum(
|
|
||||||
[
|
|
||||||
[
|
|
||||||
'link' => $this->url.'&wiz=hd',
|
|
||||||
'label' => __('    Host & devices'),
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'link' => $this->url.'&wiz=hd&mode=netscan',
|
|
||||||
'label' => __('      Net scan definition'),
|
|
||||||
],
|
|
||||||
]
|
|
||||||
);
|
|
||||||
|
|
||||||
if ($this->page == 1) {
|
|
||||||
$this->prepareBreadcrum(
|
|
||||||
[
|
|
||||||
[
|
|
||||||
'link' => $this->url.'&wiz=hd',
|
|
||||||
'label' => __('    Host & devices'),
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'link' => $this->url.'&wiz=hd&mode=netscan',
|
|
||||||
'label' => __('      Net scan definition'),
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'link' => $this->url.'&wiz=hd&mode=netscan&page=1',
|
|
||||||
'label' => __('      Net scan features'),
|
|
||||||
],
|
|
||||||
]
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
$this->printHeader();
|
|
||||||
}
|
|
||||||
|
|
||||||
return $this->runNetScan();
|
return $this->runNetScan();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -257,53 +215,77 @@ class HostDevices extends Wizard
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($this->task['id_rt']) === false) {
|
if ($task_id !== null
|
||||||
// Disabled 2 Implies wizard non finished.
|
&& $taskname == null
|
||||||
$this->task['disabled'] = 2;
|
&& $server_id == null
|
||||||
}
|
&& $id_group == null
|
||||||
|
&& $server == null
|
||||||
if ($taskname == '') {
|
&& $datacenter == ''
|
||||||
$this->msg = __('You must provide a task name.');
|
&& $user == ''
|
||||||
return false;
|
&& $pass == ''
|
||||||
}
|
&& $encrypt == null
|
||||||
|
&& $interval == 0
|
||||||
if ($server_id == '') {
|
) {
|
||||||
$this->msg = __('You must select a Discovery Server.');
|
// Default values, no data received.
|
||||||
return false;
|
// User is accesing directly to this page.
|
||||||
}
|
if (users_is_admin() !== true && check_acl(
|
||||||
|
$config['id_usuario'],
|
||||||
if ($network == '') {
|
$this->task['id_group'],
|
||||||
// XXX: Could be improved validating provided network.
|
'PM'
|
||||||
$this->msg = __('You must provide a valid network.');
|
) !== true
|
||||||
return false;
|
) {
|
||||||
}
|
$this->msg = __('You have no access to edit this task.');
|
||||||
|
return false;
|
||||||
if ($id_group == '') {
|
}
|
||||||
$this->msg = __('You must select a valid group.');
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Assign fields.
|
|
||||||
$this->task['name'] = $taskname;
|
|
||||||
$this->task['description'] = $comment;
|
|
||||||
$this->task['subnet'] = $network;
|
|
||||||
$this->task['id_recon_server'] = $server_id;
|
|
||||||
$this->task['id_group'] = $id_group;
|
|
||||||
$this->task['interval_sweep'] = $interval;
|
|
||||||
|
|
||||||
if (isset($this->task['id_rt']) === false) {
|
|
||||||
// Create.
|
|
||||||
$this->task['id_rt'] = db_process_sql_insert(
|
|
||||||
'trecon_task',
|
|
||||||
$this->task
|
|
||||||
);
|
|
||||||
} else {
|
} else {
|
||||||
// Update.
|
if (isset($this->task['id_rt']) === false) {
|
||||||
db_process_sql_update(
|
// Disabled 2 Implies wizard non finished.
|
||||||
'trecon_task',
|
$this->task['disabled'] = 2;
|
||||||
$this->task,
|
}
|
||||||
['id_rt' => $this->task['id_rt']]
|
|
||||||
);
|
if ($taskname == '') {
|
||||||
|
$this->msg = __('You must provide a task name.');
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($server_id == '') {
|
||||||
|
$this->msg = __('You must select a Discovery Server.');
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($network == '') {
|
||||||
|
// XXX: Could be improved validating provided network.
|
||||||
|
$this->msg = __('You must provide a valid network.');
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($id_group == '') {
|
||||||
|
$this->msg = __('You must select a valid group.');
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Assign fields.
|
||||||
|
$this->task['name'] = $taskname;
|
||||||
|
$this->task['description'] = $comment;
|
||||||
|
$this->task['subnet'] = $network;
|
||||||
|
$this->task['id_recon_server'] = $server_id;
|
||||||
|
$this->task['id_group'] = $id_group;
|
||||||
|
$this->task['interval_sweep'] = $interval;
|
||||||
|
|
||||||
|
if (isset($this->task['id_rt']) === false) {
|
||||||
|
// Create.
|
||||||
|
$this->task['id_rt'] = db_process_sql_insert(
|
||||||
|
'trecon_task',
|
||||||
|
$this->task
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
// Update.
|
||||||
|
db_process_sql_update(
|
||||||
|
'trecon_task',
|
||||||
|
$this->task,
|
||||||
|
['id_rt' => $this->task['id_rt']]
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
@ -408,7 +390,6 @@ class HostDevices extends Wizard
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -478,6 +459,25 @@ class HostDevices extends Wizard
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$task_url = '';
|
||||||
|
if (isset($this->task['id_rt'])) {
|
||||||
|
$task_url = '&task='.$this->task['id_rt'];
|
||||||
|
}
|
||||||
|
|
||||||
|
for ($i = 0; $i < $this->maxPagesNetScan; $i++) {
|
||||||
|
$breadcrum[] = [
|
||||||
|
'link' => 'index.php?sec=gservers&sec2=godmode/servers/discovery&wiz=hd&mode=netscan&page='.$i.$task_url,
|
||||||
|
'label' => $this->pageLabelsNetScan[$i],
|
||||||
|
'selected' => (($i == $this->page) ? 1 : 0),
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($this->page < $this->maxPagesNetScan) {
|
||||||
|
// Avoid to print header out of wizard.
|
||||||
|
$this->prepareBreadcrum($breadcrum);
|
||||||
|
$this->printHeader();
|
||||||
|
}
|
||||||
|
|
||||||
if (isset($this->page) === true
|
if (isset($this->page) === true
|
||||||
&& $this->page != 0
|
&& $this->page != 0
|
||||||
&& isset($this->task['id_rt']) === false
|
&& isset($this->task['id_rt']) === false
|
||||||
|
@ -698,7 +698,9 @@ $("select#interval_manual_defined").change(function() {
|
||||||
// XXX: Could be improved validating inputs before continue (JS)
|
// XXX: Could be improved validating inputs before continue (JS)
|
||||||
// Print NetScan page 0.
|
// Print NetScan page 0.
|
||||||
$this->printForm($form);
|
$this->printForm($form);
|
||||||
$this->printGoBackButton();
|
$this->printGoBackButton(
|
||||||
|
$this->url.'&page='.($this->page - 1).$task_url
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -94,3 +94,11 @@ div.data_container:hover {
|
||||||
.arrow_box.selected:before {
|
.arrow_box.selected:before {
|
||||||
border-left-color: #82b92e;
|
border-left-color: #82b92e;
|
||||||
}
|
}
|
||||||
|
.arrow_box {
|
||||||
|
display: inline-block;
|
||||||
|
position: relative;
|
||||||
|
padding: 14px;
|
||||||
|
margin-left: 20px;
|
||||||
|
margin-bottom: 10px;
|
||||||
|
padding-left: 3em;
|
||||||
|
}
|
||||||
|
|
|
@ -0,0 +1,3 @@
|
||||||
|
/*
|
||||||
|
* TODO: This may be at hostdevices.css
|
||||||
|
*/
|
Loading…
Reference in New Issue