mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
Better services graphing support (#10185)
* Move services graph code from device to service and remove unused code * Add proper support for services to dashboard graph weidget * Fix phpdoc in ServiceController still pointing to MuninPluginController
This commit is contained in:
@@ -32,7 +32,7 @@ class Graph
|
|||||||
{
|
{
|
||||||
public static function getTypes()
|
public static function getTypes()
|
||||||
{
|
{
|
||||||
return ['device', 'port', 'application', 'munin'];
|
return ['device', 'port', 'application', 'munin', 'service'];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
55
app/Http/Controllers/Select/ServiceController.php
Normal file
55
app/Http/Controllers/Select/ServiceController.php
Normal file
@@ -0,0 +1,55 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* ServiceController.php
|
||||||
|
*
|
||||||
|
* -Description-
|
||||||
|
*
|
||||||
|
* 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, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
* @package LibreNMS
|
||||||
|
* @link http://librenms.org
|
||||||
|
* @copyright 2018 Tony Murray
|
||||||
|
* @author Tony Murray <murraytony@gmail.com>
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace App\Http\Controllers\Select;
|
||||||
|
|
||||||
|
use App\Models\Service;
|
||||||
|
|
||||||
|
class ServiceController extends SelectController
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Defines the base query for this resource
|
||||||
|
*
|
||||||
|
* @param \Illuminate\Http\Request $request
|
||||||
|
* @return \Illuminate\Database\Eloquent\Builder|\Illuminate\Database\Query\Builder
|
||||||
|
*/
|
||||||
|
protected function baseQuery($request)
|
||||||
|
{
|
||||||
|
return Service::hasAccess($request->user())
|
||||||
|
->with(['device' => function ($query) {
|
||||||
|
$query->select('device_id', 'hostname', 'sysName');
|
||||||
|
}])
|
||||||
|
->select('service_id', 'service_type', 'service_desc', 'device_id');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function formatItem($service)
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'id' => $service->service_id,
|
||||||
|
'text' => $service->device->shortDisplayName() . ' - ' . $service->service_type . ' (' . $service->service_desc . ')'
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -30,6 +30,7 @@ use App\Models\Bill;
|
|||||||
use App\Models\Device;
|
use App\Models\Device;
|
||||||
use App\Models\MuninPlugin;
|
use App\Models\MuninPlugin;
|
||||||
use App\Models\Port;
|
use App\Models\Port;
|
||||||
|
use App\Models\Service;
|
||||||
use App\Models\UserWidget;
|
use App\Models\UserWidget;
|
||||||
use Carbon\Carbon;
|
use Carbon\Carbon;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
@@ -50,6 +51,7 @@ class GraphController extends WidgetController
|
|||||||
'graph_port' => null,
|
'graph_port' => null,
|
||||||
'graph_application' => null,
|
'graph_application' => null,
|
||||||
'graph_munin' => null,
|
'graph_munin' => null,
|
||||||
|
'graph_service' => null,
|
||||||
'graph_ports' => [],
|
'graph_ports' => [],
|
||||||
'graph_custom' => [],
|
'graph_custom' => [],
|
||||||
'graph_manual' => null,
|
'graph_manual' => null,
|
||||||
@@ -87,6 +89,10 @@ class GraphController extends WidgetController
|
|||||||
if ($munin = MuninPlugin::find($settings['graph_munin'])) {
|
if ($munin = MuninPlugin::find($settings['graph_munin'])) {
|
||||||
return $munin->device->displayName() . ' / ' . $munin->mplug_type . ' / ' . $settings['graph_type'];
|
return $munin->device->displayName() . ' / ' . $munin->mplug_type . ' / ' . $settings['graph_type'];
|
||||||
}
|
}
|
||||||
|
} elseif ($type == 'service') {
|
||||||
|
if ($service = Service::find($settings['graph_service'])) {
|
||||||
|
return $service->device->displayName() . ' / ' . $service->service_type . ' (' . $service->service_desc . ')' . ' / ' . $settings['graph_type'];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// fall back for types where we couldn't find the item
|
// fall back for types where we couldn't find the item
|
||||||
@@ -133,6 +139,11 @@ class GraphController extends WidgetController
|
|||||||
}
|
}
|
||||||
$data['munin_text'] = isset($mplug) ? $mplug->device->displayName() . ' - ' . $mplug->mplug_type : __('Munin plugin does not exist');
|
$data['munin_text'] = isset($mplug) ? $mplug->device->displayName() . ' - ' . $mplug->mplug_type : __('Munin plugin does not exist');
|
||||||
|
|
||||||
|
if ($primary == 'service' && $data['graph_service']) {
|
||||||
|
$service = Service::with('device')->find($data['graph_service']);
|
||||||
|
}
|
||||||
|
$data['service_text'] = isset($service) ? $service->device->displayName() . ' - ' . $service->service_type . ' (' . $service->service_desc . ')' : __('Service does not exist');
|
||||||
|
|
||||||
$data['graph_ports'] = Port::whereIn('port_id', $data['graph_ports'])
|
$data['graph_ports'] = Port::whereIn('port_id', $data['graph_ports'])
|
||||||
->select('ports.device_id', 'port_id', 'ifAlias', 'ifName', 'ifDescr')
|
->select('ports.device_id', 'port_id', 'ifAlias', 'ifName', 'ifDescr')
|
||||||
->with(['device' => function ($query) {
|
->with(['device' => function ($query) {
|
||||||
@@ -171,6 +182,11 @@ class GraphController extends WidgetController
|
|||||||
$params[] = 'device='.$mplug->device_id;
|
$params[] = 'device='.$mplug->device_id;
|
||||||
$params[] = 'plugin='.$mplug->mplug_type;
|
$params[] = 'plugin='.$mplug->mplug_type;
|
||||||
}
|
}
|
||||||
|
} elseif ($type == 'service') {
|
||||||
|
if ($service = Service::find($settings['graph_service'])) {
|
||||||
|
$params[] = 'device='.$service->device_id;
|
||||||
|
$params[] = 'id='.$service->service_id;
|
||||||
|
}
|
||||||
} elseif ($type == 'aggregate') {
|
} elseif ($type == 'aggregate') {
|
||||||
$aggregate_type = $this->getGraphType(false);
|
$aggregate_type = $this->getGraphType(false);
|
||||||
if ($aggregate_type == 'custom') {
|
if ($aggregate_type == 'custom') {
|
||||||
@@ -255,6 +271,7 @@ class GraphController extends WidgetController
|
|||||||
$settings['graph_port'] = $this->convertLegacySettingId($settings['graph_port'], 'port_id');
|
$settings['graph_port'] = $this->convertLegacySettingId($settings['graph_port'], 'port_id');
|
||||||
$settings['graph_application'] = $this->convertLegacySettingId($settings['graph_application'], 'app_id');
|
$settings['graph_application'] = $this->convertLegacySettingId($settings['graph_application'], 'app_id');
|
||||||
$settings['graph_munin'] = $this->convertLegacySettingId($settings['graph_munin'], 'mplug_id');
|
$settings['graph_munin'] = $this->convertLegacySettingId($settings['graph_munin'], 'mplug_id');
|
||||||
|
$settings['graph_service'] = $this->convertLegacySettingId($settings['graph_service'], 'service_id');
|
||||||
$settings['graph_bill'] = $this->convertLegacySettingId($settings['graph_bill'], 'bill_id');
|
$settings['graph_bill'] = $this->convertLegacySettingId($settings['graph_bill'], 'bill_id');
|
||||||
|
|
||||||
$settings['graph_custom'] = (array)$settings['graph_custom'];
|
$settings['graph_custom'] = (array)$settings['graph_custom'];
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ if (is_numeric($vars['id'])) {
|
|||||||
$rrd_filename = rrd_name($device['hostname'], array('service', $service['service_type'], $service['service_id']));
|
$rrd_filename = rrd_name($device['hostname'], array('service', $service['service_type'], $service['service_id']));
|
||||||
|
|
||||||
$title = generate_device_link($device);
|
$title = generate_device_link($device);
|
||||||
$title .= ' :: Service :: '.htmlentities($service['service_type']);
|
$title .= ' :: Service :: '.htmlentities($service['service_type']).' - '.htmlentities($service['service_desc']);
|
||||||
$auth = true;
|
$auth = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,21 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
$scale_min = '0';
|
|
||||||
$scale_max = '1';
|
|
||||||
|
|
||||||
require 'includes/html/graphs/common.inc.php';
|
|
||||||
|
|
||||||
$service_text = substr(str_pad($service['service_type'], 28), 0, 28);
|
|
||||||
|
|
||||||
$rrd_options .= " COMMENT:' Cur Avail\\n'";
|
|
||||||
$rrd_options .= " DEF:status=$rrd_filename:status:AVERAGE";
|
|
||||||
$rrd_options .= ' CDEF:percent=status,100,*';
|
|
||||||
$rrd_options .= ' CDEF:down=status,1,LT,status,UNKN,IF';
|
|
||||||
$rrd_options .= ' CDEF:percentdown=down,100,*';
|
|
||||||
$rrd_options .= ' AREA:percent#CCFFCC';
|
|
||||||
$rrd_options .= ' AREA:percentdown#FFCCCC';
|
|
||||||
$rrd_options .= " LINE1.5:percent#009900:'".$service_text."'";
|
|
||||||
// Ugly hack :(
|
|
||||||
$rrd_options .= ' LINE1.5:percentdown#cc0000';
|
|
||||||
$rrd_options .= ' GPRINT:status:LAST:%3.0lf';
|
|
||||||
$rrd_options .= ' GPRINT:percent:AVERAGE:%3.5lf%%\l';
|
|
||||||
@@ -16,10 +16,10 @@ require_once 'includes/services.inc.php';
|
|||||||
$services = service_get($device['device_id']);
|
$services = service_get($device['device_id']);
|
||||||
|
|
||||||
// Determine which key is the service we want to show.
|
// Determine which key is the service we want to show.
|
||||||
if (isset($vars['service'])) {
|
if (isset($vars['id'])) {
|
||||||
// Service is set, find its key.
|
// Service is set, find its key.
|
||||||
foreach ($services as $key => $service) {
|
foreach ($services as $key => $service) {
|
||||||
if ($service['service_id'] == $vars['service']) {
|
if ($service['service_id'] == $vars['id']) {
|
||||||
// We have found the service we want.
|
// We have found the service we want.
|
||||||
$vars['service'] = $key;
|
$vars['service'] = $key;
|
||||||
}
|
}
|
||||||
@@ -113,8 +113,8 @@ if (count($services) > '0') {
|
|||||||
$graphs = json_decode($service['service_ds'], true);
|
$graphs = json_decode($service['service_ds'], true);
|
||||||
foreach ($graphs as $k => $v) {
|
foreach ($graphs as $k => $v) {
|
||||||
$graph_array['device'] = $device['device_id'];
|
$graph_array['device'] = $device['device_id'];
|
||||||
$graph_array['type'] = 'device_service';
|
$graph_array['type'] = 'service_graph';
|
||||||
$graph_array['service'] = $service['service_id'];
|
$graph_array['id'] = $service['service_id'];
|
||||||
$graph_array['ds'] = $k;
|
$graph_array['ds'] = $k;
|
||||||
|
|
||||||
echo '<tr>';
|
echo '<tr>';
|
||||||
|
|||||||
@@ -69,6 +69,14 @@
|
|||||||
@endif
|
@endif
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="form-group graph_select_extra-{{ $id }}" id="graph_select_service-{{ $id }}" style="display: none;">
|
||||||
|
<label for="graph_service-{{ $id }}" class="control-label">@lang('Service')</label>
|
||||||
|
<select class="form-control" id="graph_service-{{ $id }}" name="graph_service" data-placeholder="@lang('Select a service')">
|
||||||
|
@if($graph_service)
|
||||||
|
<option value="{{ $graph_service }}">{{ $service_text }}</option>
|
||||||
|
@endif
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
<div class="form-group graph_select_extra-{{ $id }}" id="graph_select_bill-{{ $id }}" style="display: none;">
|
<div class="form-group graph_select_extra-{{ $id }}" id="graph_select_bill-{{ $id }}" style="display: none;">
|
||||||
<label for="graph_bill-{{ $id }}" class="control-label">@lang('Bill')</label>
|
<label for="graph_bill-{{ $id }}" class="control-label">@lang('Bill')</label>
|
||||||
<select class="form-control" id="graph_bill-{{ $id }}" name="graph_bill" data-placeholder="@lang('Select a bill')">
|
<select class="form-control" id="graph_bill-{{ $id }}" name="graph_bill" data-placeholder="@lang('Select a bill')">
|
||||||
@@ -111,6 +119,7 @@
|
|||||||
};
|
};
|
||||||
}, '{{ $graph_application ?: '' }}');
|
}, '{{ $graph_application ?: '' }}');
|
||||||
init_select2('#graph_munin-{{ $id }}', 'munin', {limit: 100}, '{{ $graph_munin ?: '' }}');
|
init_select2('#graph_munin-{{ $id }}', 'munin', {limit: 100}, '{{ $graph_munin ?: '' }}');
|
||||||
|
init_select2('#graph_service-{{ $id }}', 'service', {limit: 100}, '{{ $graph_service ?: '' }}');
|
||||||
init_select2('#graph_bill-{{ $id }}', 'bill', {limit: 100}, '{{ $graph_bill ?: '' }}');
|
init_select2('#graph_bill-{{ $id }}', 'bill', {limit: 100}, '{{ $graph_bill ?: '' }}');
|
||||||
init_select2('#graph_custom-{{ $id }}', 'graph-aggregate', {}, false);
|
init_select2('#graph_custom-{{ $id }}', 'graph-aggregate', {}, false);
|
||||||
init_select2('#graph_ports-{{ $id }}', 'port', {limit: 100}, {{ $graph_port_ids }});
|
init_select2('#graph_ports-{{ $id }}', 'port', {limit: 100}, {{ $graph_port_ids }});
|
||||||
|
|||||||
@@ -72,6 +72,7 @@ Route::group(['middleware' => ['auth', '2fa'], 'guard' => 'auth'], function () {
|
|||||||
Route::get('syslog', 'SyslogController');
|
Route::get('syslog', 'SyslogController');
|
||||||
Route::get('location', 'LocationController');
|
Route::get('location', 'LocationController');
|
||||||
Route::get('munin', 'MuninPluginController');
|
Route::get('munin', 'MuninPluginController');
|
||||||
|
Route::get('service', 'ServiceController');
|
||||||
Route::get('port', 'PortController');
|
Route::get('port', 'PortController');
|
||||||
Route::get('port-field', 'PortFieldController');
|
Route::get('port-field', 'PortFieldController');
|
||||||
});
|
});
|
||||||
|
|||||||
Reference in New Issue
Block a user