Files
librenms-librenms/app/Http/Controllers/Device/Tabs/VlansController.php
Peca Nesovanovic 2ff57286f0 [webui] sort ports in VLANs blade (#15960)
* [webui] vlans blade sort

sort ports in VLANs blade

before:
gi1/0/1,gi1/0/10,gi1/0/2,gi1/0/23,gi1/0/24,gi1/0/3,gi1/0/4,gi1/0/5,gi1/0/6,gi1/0/7,gi1/0/8,gi1/0/9,Po1,te1/0/2,te1/0/3,te1/0/4

after:
gi1/0/1,gi1/0/2,gi1/0/3,gi1/0/4,gi1/0/5,gi1/0/6,gi1/0/7,gi1/0/8,gi1/0/9,gi1/0/10,gi1/0/23,gi1/0/24,te1/0/2,te1/0/3,te1/0/4,Po1

Signed-off-by: Peca Nesovanovic <peca.nesovanovic@sattrakt.com>

* sort in controller

* sortby vlan,port

---------

Signed-off-by: Peca Nesovanovic <peca.nesovanovic@sattrakt.com>
2024-05-03 22:37:34 -05:00

94 lines
2.7 KiB
PHP

<?php
/**
* VlansController.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 <https://www.gnu.org/licenses/>.
*
* @link https://www.librenms.org
*
* @copyright 2020 Tony Murray
* @author Tony Murray <murraytony@gmail.com>
*/
namespace App\Http\Controllers\Device\Tabs;
use App\Models\Device;
use App\Models\PortVlan;
use LibreNMS\Interfaces\UI\DeviceTab;
class VlansController implements DeviceTab
{
public function visible(Device $device): bool
{
return $device->vlans()->exists();
}
public function slug(): string
{
return 'vlans';
}
public function icon(): string
{
return 'fa-tasks';
}
public function name(): string
{
return __('VLANs');
}
public function data(Device $device): array
{
return [
'vlans' => self::getVlans($device),
'submenu' => [
[
['name' => 'Basic', 'url' => ''],
],
'Graphs' => [
['name' => 'Bits', 'url' => 'bits'],
['name' => 'Unicast Packets', 'url' => 'upkts'],
['name' => 'Non-Unicast Packets', 'url' => 'nupkts'],
['name' => 'Errors', 'url' => 'errors'],
],
],
];
}
private static function getVlans(Device $device)
{
// port.device needed to prevent loading device multiple times
$portVlan = PortVlan::where('ports_vlans.device_id', $device->device_id)
->join('vlans', function ($join) {
$join
->on('ports_vlans.vlan', 'vlans.vlan_vlan')
->on('vlans.device_id', 'ports_vlans.device_id');
})
->join('ports', function ($join) {
$join
->on('ports_vlans.port_id', 'ports.port_id');
})
->with(['port.device'])
->select('ports_vlans.*', 'vlans.vlan_name')->orderBy('vlan_vlan')->orderBy('ports.ifName')->orderBy('ports.ifDescr')
->get()->sortBy(['vlan', 'port']);
$data = $portVlan->groupBy('vlan');
return $data;
}
}