sync hotspot to mikrotik
This commit is contained in:
parent
50ab20e68e
commit
f69885d358
@ -21,6 +21,68 @@ use PEAR2\Net\RouterOS;
|
|||||||
require_once 'system/autoload/PEAR2/Autoload.php';
|
require_once 'system/autoload/PEAR2/Autoload.php';
|
||||||
|
|
||||||
switch ($action) {
|
switch ($action) {
|
||||||
|
case 'sync':
|
||||||
|
set_time_limit(-1);
|
||||||
|
if ($routes['2'] == 'hotspot') {
|
||||||
|
$plans = ORM::for_table('tbl_bandwidth')->join('tbl_plans', array('tbl_bandwidth.id', '=', 'tbl_plans.id_bw'))->where('tbl_plans.type', 'Hotspot')->where('tbl_plans.enabled', '1')->find_many();
|
||||||
|
$log = '';
|
||||||
|
$router = '';
|
||||||
|
foreach ($plans as $plan) {
|
||||||
|
if ($router != $plan['routers']) {
|
||||||
|
$mikrotik = Mikrotik::info($plan['routers']);
|
||||||
|
$client = Mikrotik::getClient($mikrotik['ip_address'], $mikrotik['username'], $mikrotik['password']);
|
||||||
|
$router = $plan['routers'];
|
||||||
|
}
|
||||||
|
if ($plan['rate_down_unit'] == 'Kbps') {
|
||||||
|
$unitdown = 'K';
|
||||||
|
} else {
|
||||||
|
$unitdown = 'M';
|
||||||
|
}
|
||||||
|
if ($plan['rate_up_unit'] == 'Kbps') {
|
||||||
|
$unitup = 'K';
|
||||||
|
} else {
|
||||||
|
$unitup = 'M';
|
||||||
|
}
|
||||||
|
$rate = $plan['rate_up'] . $unitup . "/" . $plan['rate_down'] . $unitdown;
|
||||||
|
Mikrotik::addHotspotPlan($client, $plan['name_plan'], $plan['shared_users'], $rate);
|
||||||
|
$log .= "DONE : $plan[name_plan], $plan[shared_users], $rate<br>";
|
||||||
|
if (!empty($plan['pool_expired'])) {
|
||||||
|
Mikrotik::setHotspotExpiredPlan($client, 'EXPIRED NUXBILL ' . $plan['pool_expired'], $plan['pool_expired']);
|
||||||
|
$log .= "DONE Expired : EXPIRED NUXBILL $plan[pool_expired]<br>";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
r2(U . 'services/hotspot', 's', $log);
|
||||||
|
}else if ($routes['2'] == 'pppoe') {
|
||||||
|
$plans = ORM::for_table('tbl_bandwidth')->join('tbl_plans', array('tbl_bandwidth.id', '=', 'tbl_plans.id_bw'))->where('tbl_plans.type', 'PPPOE')->where('tbl_plans.enabled', '1')->find_many();
|
||||||
|
$log = '';
|
||||||
|
$router = '';
|
||||||
|
foreach ($plans as $plan) {
|
||||||
|
if ($router != $plan['routers']) {
|
||||||
|
$mikrotik = Mikrotik::info($plan['routers']);
|
||||||
|
$client = Mikrotik::getClient($mikrotik['ip_address'], $mikrotik['username'], $mikrotik['password']);
|
||||||
|
$router = $plan['routers'];
|
||||||
|
}
|
||||||
|
if ($plan['rate_down_unit'] == 'Kbps') {
|
||||||
|
$unitdown = 'K';
|
||||||
|
} else {
|
||||||
|
$unitdown = 'M';
|
||||||
|
}
|
||||||
|
if ($plan['rate_up_unit'] == 'Kbps') {
|
||||||
|
$unitup = 'K';
|
||||||
|
} else {
|
||||||
|
$unitup = 'M';
|
||||||
|
}
|
||||||
|
$rate = $plan['rate_up'] . $unitup . "/" . $plan['rate_down'] . $unitdown;
|
||||||
|
Mikrotik::addPpoePlan($client, $plan['name_plan'], $plan['pool'], $rate);
|
||||||
|
$log .= "DONE : $plan[name_plan], $plan[pool], $rate<br>";
|
||||||
|
if (!empty($plan['pool_expired'])) {
|
||||||
|
Mikrotik::setPpoePlan($client, 'EXPIRED NUXBILL ' . $plan['pool_expired'], $plan['pool_expired'], '512K/512K');
|
||||||
|
$log .= "DONE Expired : EXPIRED NUXBILL $plan[pool_expired]<br>";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
r2(U . 'services/pppoe', 's', $log);
|
||||||
|
}
|
||||||
|
r2(U . 'services/hotspot', 'w', 'Unknown command');
|
||||||
case 'hotspot':
|
case 'hotspot':
|
||||||
$ui->assign('xfooter', '<script type="text/javascript" src="ui/lib/c/hotspot.js"></script>');
|
$ui->assign('xfooter', '<script type="text/javascript" src="ui/lib/c/hotspot.js"></script>');
|
||||||
|
|
||||||
@ -135,8 +197,8 @@ switch ($action) {
|
|||||||
$mikrotik = Mikrotik::info($routers);
|
$mikrotik = Mikrotik::info($routers);
|
||||||
$client = Mikrotik::getClient($mikrotik['ip_address'], $mikrotik['username'], $mikrotik['password']);
|
$client = Mikrotik::getClient($mikrotik['ip_address'], $mikrotik['username'], $mikrotik['password']);
|
||||||
Mikrotik::addHotspotPlan($client, $name, $sharedusers, $rate);
|
Mikrotik::addHotspotPlan($client, $name, $sharedusers, $rate);
|
||||||
if(!empty($pool_expired)){
|
if (!empty($pool_expired)) {
|
||||||
Mikrotik::setHotspotExpiredPlan($client, 'EXPIRED NUXBILL '.$pool_expired, $pool_expired);
|
Mikrotik::setHotspotExpiredPlan($client, 'EXPIRED NUXBILL ' . $pool_expired, $pool_expired);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -220,8 +282,8 @@ switch ($action) {
|
|||||||
$mikrotik = Mikrotik::info($routers);
|
$mikrotik = Mikrotik::info($routers);
|
||||||
$client = Mikrotik::getClient($mikrotik['ip_address'], $mikrotik['username'], $mikrotik['password']);
|
$client = Mikrotik::getClient($mikrotik['ip_address'], $mikrotik['username'], $mikrotik['password']);
|
||||||
Mikrotik::setHotspotPlan($client, $name, $sharedusers, $rate);
|
Mikrotik::setHotspotPlan($client, $name, $sharedusers, $rate);
|
||||||
if(!empty($pool_expired)){
|
if (!empty($pool_expired)) {
|
||||||
Mikrotik::setHotspotExpiredPlan($client, 'EXPIRED NUXBILL '.$pool_expired, $pool_expired);
|
Mikrotik::setHotspotExpiredPlan($client, 'EXPIRED NUXBILL ' . $pool_expired, $pool_expired);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -358,8 +420,8 @@ switch ($action) {
|
|||||||
$mikrotik = Mikrotik::info($routers);
|
$mikrotik = Mikrotik::info($routers);
|
||||||
$client = Mikrotik::getClient($mikrotik['ip_address'], $mikrotik['username'], $mikrotik['password']);
|
$client = Mikrotik::getClient($mikrotik['ip_address'], $mikrotik['username'], $mikrotik['password']);
|
||||||
Mikrotik::addPpoePlan($client, $name, $pool, $rate);
|
Mikrotik::addPpoePlan($client, $name, $pool, $rate);
|
||||||
if(!empty($pool_expired)){
|
if (!empty($pool_expired)) {
|
||||||
Mikrotik::setPpoePlan($client, 'EXPIRED NUXBILL '.$pool_expired, $pool_expired, '512K/512K');
|
Mikrotik::setPpoePlan($client, 'EXPIRED NUXBILL ' . $pool_expired, $pool_expired, '512K/512K');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -429,8 +491,8 @@ switch ($action) {
|
|||||||
$mikrotik = Mikrotik::info($routers);
|
$mikrotik = Mikrotik::info($routers);
|
||||||
$client = Mikrotik::getClient($mikrotik['ip_address'], $mikrotik['username'], $mikrotik['password']);
|
$client = Mikrotik::getClient($mikrotik['ip_address'], $mikrotik['username'], $mikrotik['password']);
|
||||||
Mikrotik::setPpoePlan($client, $name, $pool, $rate);
|
Mikrotik::setPpoePlan($client, $name, $pool, $rate);
|
||||||
if(!empty($pool_expired)){
|
if (!empty($pool_expired)) {
|
||||||
Mikrotik::setPpoePlan($client, 'EXPIRED NUXBILL '.$pool_expired, $pool_expired, '512K/512K');
|
Mikrotik::setPpoePlan($client, 'EXPIRED NUXBILL ' . $pool_expired, $pool_expired, '512K/512K');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,9 +1,15 @@
|
|||||||
{include file="sections/header.tpl"}
|
{include file="sections/header.tpl"}
|
||||||
|
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-sm-12">
|
<div class="col-sm-12">
|
||||||
<div class="panel panel-hovered mb20 panel-primary">
|
<div class="panel panel-hovered mb20 panel-primary">
|
||||||
<div class="panel-heading">{$_L['Hotspot_Plans']}</div>
|
<div class="panel-heading">
|
||||||
|
<div class="btn-group pull-right">
|
||||||
|
<a class="btn btn-primary btn-xs" title="save" href="{$_url}services/sync/hotspot"
|
||||||
|
onclick="return confirm('This will sync/send hotspot plan to Mikrotik?')"><span
|
||||||
|
class="glyphicon glyphicon-refresh" aria-hidden="true"></span> sync</a>
|
||||||
|
</div>{$_L['Hotspot_Plans']}
|
||||||
|
</div>
|
||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
<div class="md-whiteframe-z1 mb20 text-center" style="padding: 15px">
|
<div class="md-whiteframe-z1 mb20 text-center" style="padding: 15px">
|
||||||
<div class="col-md-8">
|
<div class="col-md-8">
|
||||||
@ -12,7 +18,8 @@
|
|||||||
<div class="input-group-addon">
|
<div class="input-group-addon">
|
||||||
<span class="fa fa-search"></span>
|
<span class="fa fa-search"></span>
|
||||||
</div>
|
</div>
|
||||||
<input type="text" name="name" class="form-control" placeholder="{$_L['Search_by_Name']}...">
|
<input type="text" name="name" class="form-control"
|
||||||
|
placeholder="{$_L['Search_by_Name']}...">
|
||||||
<div class="input-group-btn">
|
<div class="input-group-btn">
|
||||||
<button class="btn btn-success" type="submit">{$_L['Search']}</button>
|
<button class="btn btn-success" type="submit">{$_L['Search']}</button>
|
||||||
</div>
|
</div>
|
||||||
@ -20,7 +27,8 @@
|
|||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-md-4">
|
<div class="col-md-4">
|
||||||
<a href="{$_url}services/add" class="btn btn-primary btn-block waves-effect"><i class="ion ion-android-add"> </i> {$_L['New_Plan']}</a>
|
<a href="{$_url}services/add" class="btn btn-primary btn-block waves-effect"><i
|
||||||
|
class="ion ion-android-add"> </i> {$_L['New_Plan']}</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="table-responsive">
|
<div class="table-responsive">
|
||||||
@ -41,7 +49,7 @@
|
|||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
{foreach $d as $ds}
|
{foreach $d as $ds}
|
||||||
<tr {if $ds['enabled'] != 1}class="danger" title="disabled"{/if}>
|
<tr {if $ds['enabled'] != 1}class="danger" title="disabled" {/if}>
|
||||||
<td>{$ds['name_plan']}</td>
|
<td>{$ds['name_plan']}</td>
|
||||||
<td>{$ds['typebp']}</td>
|
<td>{$ds['typebp']}</td>
|
||||||
<td>{$ds['name_bw']}</td>
|
<td>{$ds['name_bw']}</td>
|
||||||
@ -52,8 +60,11 @@
|
|||||||
<td>{$ds['routers']}</td>
|
<td>{$ds['routers']}</td>
|
||||||
<td>{$ds['pool_expired']}</td>
|
<td>{$ds['pool_expired']}</td>
|
||||||
<td>
|
<td>
|
||||||
<a href="{$_url}services/edit/{$ds['id']}" class="btn btn-info btn-xs">{$_L['Edit']}</a>
|
<a href="{$_url}services/edit/{$ds['id']}"
|
||||||
<a href="{$_url}services/delete/{$ds['id']}" id="{$ds['id']}" onclick="return confirm('{$_L['Delete']}?')" class="btn btn-danger btn-xs">{$_L['Delete']}</a>
|
class="btn btn-info btn-xs">{$_L['Edit']}</a>
|
||||||
|
<a href="{$_url}services/delete/{$ds['id']}" id="{$ds['id']}"
|
||||||
|
onclick="return confirm('{$_L['Delete']}?')"
|
||||||
|
class="btn btn-danger btn-xs">{$_L['Delete']}</a>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
{/foreach}
|
{/foreach}
|
||||||
@ -65,6 +76,6 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{include file="sections/footer.tpl"}
|
{include file="sections/footer.tpl"}
|
Loading…
x
Reference in New Issue
Block a user