mirror of
				https://github.com/librenms/librenms.git
				synced 2024-10-07 16:52:45 +00:00 
			
		
		
		
	* refactor: Moved ifLabel -> cleanPort and updated the usage * added list of tags allowed * few updates as per comments from @murrant * Added simple unit tests * double display for javascript popover * Remove ifNameDescr() function Fix realtime port page * remove accidental temp code * Remove double display calls in ajax tables
		
			
				
	
	
		
			85 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
$row = 1;
 | 
						|
 | 
						|
$device_id = $_POST['device_id'];
 | 
						|
 | 
						|
$sql = 'FROM `ports` WHERE `device_id` = ?';
 | 
						|
$param = array($device_id);
 | 
						|
 | 
						|
if (isset($searchPhrase) && !empty($searchPhrase)) {
 | 
						|
    $sql .= " AND (`ifName` LIKE '%$searchPhrase%' OR `ifAlias` LIKE '%$searchPhrase%' OR `ifDescr` LIKE '%$searchPhrase%')";
 | 
						|
}
 | 
						|
 | 
						|
$count_sql = "SELECT COUNT(`port_id`) $sql";
 | 
						|
$total     = dbFetchCell($count_sql, $param);
 | 
						|
if (empty($total)) {
 | 
						|
    $total = 0;
 | 
						|
}
 | 
						|
 | 
						|
if (!isset($sort) || empty($sort)) {
 | 
						|
    $sort = '`ifIndex` ASC';
 | 
						|
}
 | 
						|
 | 
						|
$sql .= " ORDER BY $sort";
 | 
						|
 | 
						|
if (isset($current)) {
 | 
						|
    $limit_low  = (($current * $rowCount) - ($rowCount));
 | 
						|
    $limit_high = $rowCount;
 | 
						|
}
 | 
						|
 | 
						|
if ($rowCount != -1) {
 | 
						|
    $sql .= " LIMIT $limit_low,$limit_high";
 | 
						|
}
 | 
						|
 | 
						|
$sql = "SELECT * $sql";
 | 
						|
 | 
						|
$response[] = array(
 | 
						|
    'ifIndex' => "<button id='save-form' type='submit' value='Save' class='btn btn-success btn-sm' title='Save current port disable/ignore settings'>Save</button><button type='submit' value='Reset' class='btn btn-danger btn-sm' id='form-reset' title='Reset form to previously-saved settings'>Reset</button>",
 | 
						|
    'label' => '',
 | 
						|
    'ifAdminStatus' => '',
 | 
						|
    'ifOperStatus' => "<button type='submit' value='Alerted' class='btn btn-default btn-sm' id='alerted-toggle' title='Toggle alerting on all currently-alerted ports'>Alerted</button><button type='submit' value='Down' class='btn btn-default btn-sm' id='down-select' title='Disable alerting on all currently-down ports'>Down</button>",
 | 
						|
    'disabled' => "<button type='submit' value='Toggle' class='btn btn-default btn-sm' id='disable-toggle' title='Toggle polling for all ports'>Toggle</button><button type='submit' value='Select' class='btn btn-default btn-sm' id='disable-select' title='Disable polling on all ports'>Select All</button>",
 | 
						|
    'ignore' => "<button type='submit' value='Toggle' class='btn btn-default btn-sm' id='ignore-toggle' title='Toggle alerting for all ports'>Toggle</button><button type='submit' value='Select' class='btn btn-default btn-sm' id='ignore-select' title='Disable alerting on all ports'>Select All</button>",
 | 
						|
    'ifAlias' => ''
 | 
						|
);
 | 
						|
 | 
						|
foreach (dbFetchRows($sql, $param) as $port) {
 | 
						|
    $port = cleanPort($port);
 | 
						|
 | 
						|
    // Mark interfaces which are OperDown (but not AdminDown) yet not ignored or disabled, or up yet ignored or disabled
 | 
						|
    // - as to draw the attention to a possible problem.
 | 
						|
 | 
						|
 | 
						|
    $isportbad = ($port['ifOperStatus'] == 'down' && $port['ifAdminStatus'] != 'down') ? 1 : 0;
 | 
						|
    $dowecare  = ($port['ignore'] == 0 && $port['disabled'] == 0) ? $isportbad : !$isportbad;
 | 
						|
    $outofsync = $dowecare ? " class='red'" : '';
 | 
						|
    $checked = '';
 | 
						|
    $device['device_id'] = $device_id;
 | 
						|
    if (get_dev_attrib($device, 'ifName_tune:'.$port['ifName']) == "true") {
 | 
						|
        $checked = 'checked';
 | 
						|
    }
 | 
						|
 | 
						|
    $response[] = array(
 | 
						|
        'ifIndex'          => $port['ifIndex'],
 | 
						|
        'ifName'           => $port['label'],
 | 
						|
        'ifAdminStatus'    => $port['ifAdminStatus'],
 | 
						|
        'ifOperStatus'     => '<span name="operstatus_'.$port['port_id'].'"'.$outofsync.'>'.$port['ifOperStatus'].'</span>',
 | 
						|
        'disabled'         => '<input type="checkbox" class="disable-check" name="disabled_'.$port['port_id'].'"'.($port['disabled'] ? 'checked' : '').'>
 | 
						|
                               <input type="hidden" name="olddis_'.$port['port_id'].'" value="'.($port['disabled'] ? 1 : 0).'"">',
 | 
						|
        'ignore'           => '<input type="checkbox" class="ignore-check" name="ignore_'.$port['port_id'].'"'.($port['ignore'] ? 'checked' : '').'>
 | 
						|
                               <input type="hidden" name="oldign_'.$port['port_id'].'" value="'.($port['ignore'] ? 1 : 0).'"">',
 | 
						|
        'port_tune'        => '<input type="checkbox" id="override_config" name="override_config" data-attrib="ifName_tune:'.$port['ifName'].'" data-device_id="'.$port['device_id'].'" data-size="small" '.$checked.'>',
 | 
						|
        'ifAlias'          => '<div class="form-group"><input class="form-control input-sm" id="if-alias" name="if-alias" data-device_id="'.$port['device_id'].'" data-port_id="'.$port['port_id'].'" data-ifName="'.$port['ifName'].'" value="'.$port['ifAlias'].'"><span class="form-control-feedback"><i class="fa" aria-hidden="true"></i></span></div>',
 | 
						|
        'ifSpeed'          => '<div class="form-group has-feedback"><input type="text" pattern="[0-9]*" inputmode="numeric" class="form-control input-sm" id="if-speed" name="if-speed" data-device_id="'.$port['device_id'].'" data-port_id="'.$port['port_id'].'" data-ifName="'.$port['ifName'].'" value="'.$port['ifSpeed'].'"><span class="form-control-feedback"><i class="fa" aria-hidden="true"></i></span></div>',
 | 
						|
    );
 | 
						|
}//end foreach
 | 
						|
 | 
						|
$output = array(
 | 
						|
    'current'  => $current,
 | 
						|
    'rowCount' => $rowCount,
 | 
						|
    'rows'     => $response,
 | 
						|
    'total'    => $total,
 | 
						|
);
 | 
						|
echo _json_encode($output);
 |