2021-11-17 19:23:55 -06:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Console\Commands;
|
|
|
|
|
|
|
|
use App\Console\LnmsCommand;
|
|
|
|
use App\Polling\Measure\MeasurementManager;
|
|
|
|
use Illuminate\Database\QueryException;
|
|
|
|
use LibreNMS\Config;
|
|
|
|
use LibreNMS\Poller;
|
|
|
|
use Symfony\Component\Console\Input\InputArgument;
|
|
|
|
use Symfony\Component\Console\Input\InputOption;
|
|
|
|
|
|
|
|
class DevicePoll extends LnmsCommand
|
|
|
|
{
|
|
|
|
protected $name = 'device:poll';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a new command instance.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function __construct()
|
|
|
|
{
|
|
|
|
parent::__construct();
|
|
|
|
$this->addArgument('device spec', InputArgument::REQUIRED);
|
|
|
|
$this->addOption('modules', 'm', InputOption::VALUE_REQUIRED);
|
|
|
|
$this->addOption('no-data', 'x', InputOption::VALUE_NONE);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function handle(MeasurementManager $measurements): int
|
|
|
|
{
|
|
|
|
$this->configureOutputOptions();
|
|
|
|
|
|
|
|
if ($this->option('no-data')) {
|
|
|
|
Config::set('rrd.enable', false);
|
|
|
|
Config::set('influxdb.enable', false);
|
2024-03-07 19:26:21 +01:00
|
|
|
Config::set('influxdbv2.enable', false);
|
2021-11-17 19:23:55 -06:00
|
|
|
Config::set('prometheus.enable', false);
|
|
|
|
Config::set('graphite.enable', false);
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
2022-07-22 16:31:27 -05:00
|
|
|
/** @var \LibreNMS\Poller $poller */
|
2023-10-07 21:39:16 -05:00
|
|
|
$poller = app(Poller::class, ['device_spec' => $this->argument('device spec'), 'module_override' => explode(',', $this->option('modules') ?? '')]);
|
2023-10-19 06:55:41 -05:00
|
|
|
$result = $poller->poll();
|
2021-11-17 19:23:55 -06:00
|
|
|
|
2023-10-19 06:55:41 -05:00
|
|
|
if ($result->hasAnyCompleted()) {
|
2021-11-17 19:23:55 -06:00
|
|
|
if (! $this->output->isQuiet()) {
|
2023-10-19 06:55:41 -05:00
|
|
|
if ($result->hasMultipleCompleted()) {
|
2021-11-17 19:23:55 -06:00
|
|
|
$this->output->newLine();
|
2022-07-22 16:31:27 -05:00
|
|
|
$time_spent = sprintf('%0.3fs', $measurements->getCategory('device')->getSummary('poll')->getDuration());
|
2023-10-19 06:55:41 -05:00
|
|
|
$this->line(trans('commands.device:poll.polled', ['count' => $result->getCompleted(), 'time' => $time_spent]));
|
2021-11-17 19:23:55 -06:00
|
|
|
}
|
|
|
|
$this->output->newLine();
|
|
|
|
$measurements->printStats();
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
2022-07-22 16:31:27 -05:00
|
|
|
|
|
|
|
// polled 0 devices, maybe there were none to poll
|
2023-10-19 06:55:41 -05:00
|
|
|
if ($result->hasNoAttempts()) {
|
2022-07-22 16:31:27 -05:00
|
|
|
$this->error(trans('commands.device:poll.errors.no_devices'));
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
}
|
2023-10-19 06:55:41 -05:00
|
|
|
|
|
|
|
// attempted some devices, but none were up.
|
|
|
|
if ($result->hasNoCompleted()) {
|
|
|
|
$this->line('<fg=red>' . trans_choice('commands.device:poll.errors.none_up', $result->getAttempted()) . '</>');
|
|
|
|
|
|
|
|
return 6;
|
|
|
|
}
|
2021-11-17 19:23:55 -06:00
|
|
|
} catch (QueryException $e) {
|
|
|
|
if ($e->getCode() == 2002) {
|
|
|
|
$this->error(trans('commands.device:poll.errors.db_connect'));
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
} elseif ($e->getCode() == 1045) {
|
|
|
|
// auth failed, don't need to include the query
|
|
|
|
$this->error(trans('commands.device:poll.errors.db_auth', ['error' => $e->getPrevious()->getMessage()]));
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->error($e->getMessage());
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2022-07-22 16:31:27 -05:00
|
|
|
$this->error(trans('commands.device:poll.errors.none_polled'));
|
|
|
|
|
2021-11-17 19:23:55 -06:00
|
|
|
return 1; // failed to poll
|
|
|
|
}
|
|
|
|
}
|