mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
289 lines
11 KiB
PHP
289 lines
11 KiB
PHP
<?php
|
|
|
|
require 'includes/javascript-interfacepicker.inc.php';
|
|
|
|
// This needs more verification. Is it already added? Does it exist?
|
|
// Calculation to extract MB/GB/TB of Kbps/Mbps/Gbps
|
|
$base = $config['billing']['base'];
|
|
|
|
if ($bill_data['bill_type'] == 'quota') {
|
|
$data = $bill_data['bill_quota'];
|
|
$tmp['mb'] = ($data / $base / $base);
|
|
$tmp['gb'] = ($data / $base / $base / $base);
|
|
$tmp['tb'] = ($data / $base / $base / $base / $base);
|
|
if ($tmp['tb'] >= 1) {
|
|
$quota = array(
|
|
'type' => 'tb',
|
|
'select_tb' => ' selected',
|
|
'data' => $tmp['tb'],
|
|
);
|
|
}
|
|
else if (($tmp['gb'] >= 1) and ($tmp['gb'] < $base)) {
|
|
$quota = array(
|
|
'type' => 'gb',
|
|
'select_gb' => ' selected',
|
|
'data' => $tmp['gb'],
|
|
);
|
|
}
|
|
else if (($tmp['mb'] >= 1) and ($tmp['mb'] < $base)) {
|
|
$quota = array(
|
|
'type' => 'mb',
|
|
'select_mb' => ' selected',
|
|
'data' => $tmp['mb'],
|
|
);
|
|
}
|
|
}//end if
|
|
|
|
if ($bill_data['bill_type'] == 'cdr') {
|
|
$data = $bill_data['bill_cdr'];
|
|
$tmp['kbps'] = ($data / $base);
|
|
$tmp['mbps'] = ($data / $base / $base);
|
|
$tmp['gbps'] = ($data / $base / $base / $base);
|
|
if ($tmp['gbps'] >= 1) {
|
|
$cdr = array(
|
|
'type' => 'gbps',
|
|
'select_gbps' => ' selected',
|
|
'data' => $tmp['gbps'],
|
|
);
|
|
}
|
|
else if (($tmp['mbps'] >= 1) and ($tmp['mbps'] < $base)) {
|
|
$cdr = array(
|
|
'type' => 'mbps',
|
|
'select_mbps' => ' selected',
|
|
'data' => $tmp['mbps'],
|
|
);
|
|
}
|
|
else if (($tmp['kbps'] >= 1) and ($tmp['kbps'] < $base)) {
|
|
$cdr = array(
|
|
'type' => 'kbps',
|
|
'select_kbps' => ' selected',
|
|
'data' => $tmp['kbps'],
|
|
);
|
|
}
|
|
}//end if
|
|
|
|
?>
|
|
|
|
<form id="edit" name="edit" method="post" action="" class="form-horizontal" role="form">
|
|
<input type=hidden name="action" value="update_bill">
|
|
<script type="text/javascript">
|
|
function billType() {
|
|
$('#cdrDiv').toggle();
|
|
$('#quotaDiv').toggle();
|
|
}
|
|
</script>
|
|
<h3>Bill Properties</h3>
|
|
<div class="form-group">
|
|
<label class="col-sm-2 control-label" for="bill_name"><strong>Description</strong></label>
|
|
<div class="col-sm-4">
|
|
<input class="form-control input-sm" name="bill_name" value="<?php echo $bill_data['bill_name']; ?>" />
|
|
</div>
|
|
<div class="col-sm-6">
|
|
</div>
|
|
</div>
|
|
<div class="form-group">
|
|
<label class="col-sm-2 control-label" for="bill_type"><strong>Billing Type</strong></label>
|
|
<div class="col-sm-10">
|
|
<div class="radio">
|
|
<label>
|
|
<input type="radio" name="bill_type" value="cdr" onchange="javascript: billType();"
|
|
<?php
|
|
if ($bill_data['bill_type'] == 'cdr') {
|
|
echo 'checked ';
|
|
};
|
|
?>
|
|
/> CDR 95th
|
|
</label>
|
|
</div>
|
|
<div class="radio">
|
|
<label>
|
|
<input type="radio" name="bill_type" value="quota" onchange="javascript: billType();"
|
|
<?php
|
|
if ($bill_data['bill_type'] == 'quota') {
|
|
echo 'checked ';
|
|
};
|
|
?>
|
|
/> Quota
|
|
</label>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div id="cdrDiv"
|
|
<?php
|
|
if ($bill_data['bill_type'] == 'quota') {
|
|
echo ' style="display: none"';
|
|
};
|
|
?>
|
|
>
|
|
<div class="form-group">
|
|
<div class="col-sm-2">
|
|
</div>
|
|
<div class="col-sm-2">
|
|
<input class="form-control input-sm" type="text" name="bill_cdr" value="<?php echo $cdr['data']; ?>">
|
|
</div>
|
|
<div class="col-sm-3">
|
|
<select name="bill_cdr_type" class="form-control input-sm">
|
|
<option value="Kbps"<?php echo $cdr['select_kbps']; ?>>Kilobits per second (Kbps)</option>
|
|
<option value="Mbps"<?php echo $cdr['select_mbps']; ?>>Megabits per second (Mbps)</option>
|
|
<option value="Gbps"<?php echo $cdr['select_gbps']; ?>>Gigabits per second (Gbps)</option>
|
|
</select>
|
|
</div>
|
|
<div class="col-sm-5">
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div id="quotaDiv"
|
|
<?php
|
|
if ($bill_data['bill_type'] == 'cdr') {
|
|
echo ' style="display: none"';
|
|
};
|
|
?>
|
|
>
|
|
<div class="form-group">
|
|
<div class="col-sm-2">
|
|
</div>
|
|
<div class="col-sm-2">
|
|
<input class="form-control input-sm" type="text" name="bill_quota" value="<?php echo $quota['data']; ?>">
|
|
</div>
|
|
<div class="col-sm-2">
|
|
<select name="bill_quota_type" class="form-control input-sm">
|
|
<option value="MB"<?php echo $quota['select_mb']; ?>>Megabytes (MB)</option>
|
|
<option value="GB"<?php echo $quota['select_gb']; ?>>Gigabytes (GB)</option>
|
|
<option value="TB"<?php echo $quota['select_tb']; ?>>Terabytes (TB)</option>
|
|
</select>
|
|
</div>
|
|
<div class="col-sm-6">
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="form-group">
|
|
<label class="col-sm-2 control-label" for="bill_day"><strong>Billing Day</strong></label>
|
|
<div class="col-sm-2">
|
|
<select name="bill_day" class="form-control input">
|
|
<?php
|
|
for ($x = 1; $x < 32; $x++) {
|
|
$select = (($bill_data['bill_day'] == $x) ? ' selected' : '');
|
|
echo ' <option value="'.$x.'"'.$select.'>'.$x."</option>\n";
|
|
}
|
|
|
|
?>
|
|
</select>
|
|
</div>
|
|
</div>
|
|
<h3>Optional Information</h3>
|
|
<div class="form-group">
|
|
<label class="col-sm-2 control-label" for="bill_custid"><strong>Customer Reference</strong></label>
|
|
<div class="col-sm-4">
|
|
<input class="form-control input-sm" type="text" name="bill_custid" value="<?php echo $bill_data['bill_custid']; ?>" />
|
|
</div>
|
|
<div class="col-sm-6">
|
|
</div>
|
|
</div>
|
|
<div class="form-group">
|
|
<label class="col-sm-2 control-label" for="bill_ref"><strong>Billing Reference</strong></label>
|
|
<div class="col-sm-4">
|
|
<input class="form-control input-sm" type="text" name="bill_ref" value="<?php echo $bill_data['bill_ref']; ?>" />
|
|
</div>
|
|
<div class="col-sm-6">
|
|
</div>
|
|
</div>
|
|
<div class="form-group">
|
|
<label class="col-sm-2 control-label" for="bill_notes"><strong>Notes</strong></label>
|
|
<div class="col-sm-4">
|
|
<textarea rows="3" class="form-control input-sm" name="bill_notes" value="<?php echo $bill_data['bill_notes']; ?>"></textarea>
|
|
</div>
|
|
</div>
|
|
<button type="submit" class="btn btn-success" name="Submit" value="Save" /><i class="icon-ok icon-white"></i> <strong>Save Properties</strong></button>
|
|
</form>
|
|
|
|
<h3>Billed Ports</h3>
|
|
<div class="form-group">
|
|
<?php
|
|
$ports = dbFetchRows(
|
|
'SELECT * FROM `bill_ports` AS B, `ports` AS P, `devices` AS D
|
|
WHERE B.bill_id = ? AND P.port_id = B.port_id
|
|
AND D.device_id = P.device_id ORDER BY D.device_id',
|
|
array($bill_data['bill_id'])
|
|
);
|
|
|
|
if (is_array($ports)) {
|
|
foreach ($ports as $port) {
|
|
$emptyCheck = true;
|
|
$devicebtn = str_replace('list-device', 'btn', generate_device_link($port));
|
|
$devicebtn = str_replace("overlib('", "overlib('<div style=\'border: 5px solid #e5e5e5; background: #fff; padding: 10px;\'>", $devicebtn);
|
|
$devicebtn = str_replace("<div>',;", "</div></div>',", $devicebtn);
|
|
$portbtn = str_replace('interface-upup', 'btn', generate_port_link($port));
|
|
$portbtn = str_replace('interface-updown', 'btn btn-warning', $portbtn);
|
|
$portbtn = str_replace('interface-downdown', 'btn btn-warning', $portbtn);
|
|
$portbtn = str_replace('interface-admindown', 'btn btn-warning disabled', $portbtn);
|
|
$portbtn = str_replace("overlib('", "overlib('<div style=\'border: 5px solid #e5e5e5; background: #fff; padding: 10px;\'>", $portbtn);
|
|
$portbtn = str_replace("<div>',;", "</div></div>',", $portbtn);
|
|
$portalias = (empty($port['ifAlias']) ? '' : ' - '.$port['ifAlias'].'');
|
|
$devicebtn = str_replace('">'.$port['hostname'], '" style="color: #000;"><i class="glyphicon glyphicon-asterisk"></i> '.$port['hostname'], $devicebtn);
|
|
$portbtn = str_replace('">'.strtolower($port['ifName']), '" style="color: #000;"><i class="glyphicon glyphicon-random"></i> '.$port['ifName'].''.$portalias, $portbtn);
|
|
echo ' <form action="" class="form-inline" method="post" name="delete'.$port['port_id']."\" style=\"display: none;\">\n";
|
|
echo " <input type=\"hidden\" name=\"action\" value=\"delete_bill_port\" />\n";
|
|
echo ' <input type="hidden" name="port_id" value="'.$port['port_id']."\" />\n";
|
|
echo " </form>\n";
|
|
echo " <div class=\"btn-toolbar\">\n";
|
|
echo " <div class=\"btn-group\" style=\"width: 600px;\">\n";
|
|
// echo(" <a class=\"btn btn-danger\" href=\"javascript:;\" onclick=\"document.delete".$port['port_id'].".submit();\" style=\"color: #fff;\"><i class=\"icon-trash icon-white\"></i></a>\n");
|
|
echo ' '.$devicebtn."\n";
|
|
echo ' '.$portbtn."\n";
|
|
echo " </div>\n";
|
|
echo " <div class=\"btn-group\">\n";
|
|
echo ' <a class="btn btn-danger btn-mini" href="javascript:;" onclick="document.delete'.$port['port_id'].".submit();\" style=\"color: #fff;\"><i class=\"icon-minus-sign icon-white\"></i> <strong>Remove Interface</strong></a>\n";
|
|
echo " </div>\n";
|
|
echo " </div>\n";
|
|
}//end foreach
|
|
|
|
if (!$emptyCheck) {
|
|
echo " <div class=\"alert alert-info\">\n";
|
|
echo " <i class=\"icon-info-sign\"></i> <strong>There are no ports assigned to this bill</strong>\n";
|
|
echo " </div>\n";
|
|
}
|
|
}//end if
|
|
?>
|
|
</div>
|
|
</fieldset>
|
|
<form action="" method="post" class="form-horizontal" role="form">
|
|
<input type="hidden" name="action" value="add_bill_port" />
|
|
<input type="hidden" name="bill_id" value="<?php echo $bill_id; ?>" />
|
|
<h3>Add Port</h3>
|
|
<div class="form-group">
|
|
<label class="col-sm-2 control-label" for="device"><strong>Device</strong></label>
|
|
<div class="col-sm-4">
|
|
<select class="form-control input-sm" id="device" name="device" onchange="getInterfaceList(this)">
|
|
<option value=''>Select a device</option>
|
|
<?php
|
|
$devices = dbFetchRows('SELECT * FROM `devices` ORDER BY hostname');
|
|
foreach ($devices as $device) {
|
|
unset($done);
|
|
foreach ($access_list as $ac) {
|
|
if ($ac == $device['device_id']) {
|
|
$done = 1;
|
|
}
|
|
}
|
|
|
|
if (!$done) {
|
|
echo " <option value='".$device['device_id']."'>".$device['hostname']."</option>\n";
|
|
}
|
|
}
|
|
|
|
?>
|
|
</select>
|
|
</div>
|
|
<div class="col-sm-6">
|
|
</div>
|
|
</div>
|
|
<div class="form-group">
|
|
<label class="col-sm-2 control-label" for="port_id"><strong>Interface</strong></label>
|
|
<div class="col-sm-4">
|
|
<select class="form-control input-sm" id="port_id" name="port_id"></select>
|
|
</div>
|
|
<div class="col-sm-6">
|
|
<div>
|
|
</div>
|
|
<button type="submit" class="btn btn-primary" name="Submit" value=" Add " /><i class="icon-plus-sign icon-white"></i> <strong>Add Interface</strong></button>
|
|
</form>
|