where('code', $code)->where('status', 0)->find_one(); if ($v1) { $msg = ''; if (Validator::Length($username, 35, 2) == false) { $msg .= 'Username should be between 3 to 55 characters' . '
'; } if (Validator::Length($fullname, 36, 2) == false) { $msg .= 'Full Name should be between 3 to 25 characters' . '
'; } if (!Validator::Length($password, 35, 2)) { $msg .= 'Password should be between 3 to 35 characters' . '
'; } if ($password != $cpassword) { $msg .= $_L['PasswordsNotMatch'] . '
'; } $d = ORM::for_table('tbl_customers')->where('username', $username)->find_one(); if ($d) { $msg .= $_L['account_already_exist'] . '
'; } if ($msg == '') { $d = ORM::for_table('tbl_customers')->create(); $d->username = $username; $d->password = $password; $d->fullname = $fullname; $d->address = $address; $d->phonenumber = $phonenumber; if ($d->save()) { $user = $d->id(); //check voucher plan $p = ORM::for_table('tbl_plans')->find_one($v1['id_plan']); $c = ORM::for_table('tbl_customers')->find_one($user); $p = ORM::for_table('tbl_plans')->find_one($v1['id_plan']); $date_now = date("Y-m-d H:i:s"); $date_only = date("Y-m-d"); $time = date("H:i:s"); $mikrotik = Router::_info($v1['routers']); $date_exp = date("Y-m-d", mktime(0, 0, 0, date("m"), date("d") + $p['validity'], date("Y"))); if ($v1['type'] == 'Hotspot') { try { $iport = explode(":", $mikrotik['ip_address']); $client = new RouterOS\Client($iport[0], $mikrotik['username'], $mikrotik['password'], ($iport[1]) ? $iport[1] : null); } catch (Exception $e) { die("Unable to connect to the router.
".$e->getMessage()); } /* iBNuX Added: * Time limit to Mikrotik * 'Time_Limit', 'Data_Limit', 'Both_Limit' */ $addRequest = new RouterOS\Request('/ip/hotspot/user/add'); if ($p['typebp'] == "Limited") { if ($p['limit_type'] == "Time_Limit") { if ($p['time_unit'] == 'Hrs') $timelimit = $p['time_limit'] . ":00:00"; else $timelimit = "00:" . $p['time_limit'] . ":00"; $client->sendSync( $addRequest ->setArgument('name', $c['username']) ->setArgument('profile', $p['name_plan']) ->setArgument('password', $c['password']) ->setArgument('limit-uptime', $timelimit) ); } else if ($p['limit_type'] == "Data_Limit") { if ($p['data_unit'] == 'GB') $datalimit = $p['data_limit'] . "000000000"; else $datalimit = $p['data_limit'] . "000000"; $client->sendSync( $addRequest ->setArgument('name', $c['username']) ->setArgument('profile', $p['name_plan']) ->setArgument('password', $c['password']) ->setArgument('limit-bytes-total', $datalimit) ); } else if ($p['limit_type'] == "Both_Limit") { if ($p['time_unit'] == 'Hrs') $timelimit = $p['time_limit'] . ":00:00"; else $timelimit = "00:" . $p['time_limit'] . ":00"; if ($p['data_unit'] == 'GB') $datalimit = $p['data_limit'] . "000000000"; else $datalimit = $p['data_limit'] . "000000"; $client->sendSync( $addRequest ->setArgument('name', $c['username']) ->setArgument('profile', $p['name_plan']) ->setArgument('password', $c['password']) ->setArgument('limit-uptime', $timelimit) ->setArgument('limit-bytes-total', $datalimit) ); } } else { $client->sendSync( $addRequest ->setArgument('name', $c['username']) ->setArgument('profile', $p['name_plan']) ->setArgument('password', $c['password']) ); } $d = ORM::for_table('tbl_user_recharges')->create(); $d->customer_id = $user; $d->username = $c['username']; $d->plan_id = $v1['id_plan']; $d->namebp = $p['name_plan']; $d->recharged_on = $date_only; $d->expiration = $date_exp; $d->time = $time; $d->status = "on"; $d->method = "voucher"; $d->routers = $v1['routers']; $d->type = "Hotspot"; $d->save(); // insert table transactions $t = ORM::for_table('tbl_transactions')->create(); $t->invoice = "INV-" . _raid(5); $t->username = $c['username']; $t->plan_name = $p['name_plan']; $t->price = $p['price']; $t->recharged_on = $date_only; $t->expiration = $date_exp; $t->time = $time; $t->method = "voucher"; $t->routers = $v1['routers']; $t->type = "Hotspot"; $t->save(); $v1->status = "1"; $v1->user = $c['username']; $v1->save(); } else { try { $iport = explode(":", $mikrotik['ip_address']); $client = new RouterOS\Client($iport[0], $mikrotik['username'], $mikrotik['password'], ($iport[1]) ? $iport[1] : null); } catch (Exception $e) { die("Unable to connect to the router.
".$e->getMessage()); } $addRequest = new RouterOS\Request('/ppp/secret/add'); $client->sendSync( $addRequest ->setArgument('name', $c['username']) ->setArgument('service', 'pppoe') ->setArgument('profile', $p['name_plan']) ->setArgument('password', $c['password']) ); $d = ORM::for_table('tbl_user_recharges')->create(); $d->customer_id = $user; $d->username = $c['username']; $d->plan_id = $v1['id_plan']; $d->namebp = $p['name_plan']; $d->recharged_on = $date_only; $d->expiration = $date_exp; $d->time = $time; $d->status = "on"; $d->method = "voucher"; $d->routers = $v1['routers']; $d->type = "PPPOE"; $d->save(); // insert table transactions $t = ORM::for_table('tbl_transactions')->create(); $t->invoice = "INV-" . _raid(5); $t->username = $c['username']; $t->plan_name = $p['name_plan']; $t->price = $p['price']; $t->recharged_on = $date_only; $t->expiration = $date_exp; $t->time = $time; $t->method = "voucher"; $t->routers = $v1['routers']; $t->type = "PPPOE"; $t->save(); $v1->status = "1"; $v1->user = $c['username']; $v1->save(); } r2(U . 'login', 's', $_L['Register_Success']); } else { $ui->assign('username', $username); $ui->assign('fullname', $fullname); $ui->assign('address', $address); $ui->assign('phonenumber', $phonenumber); $ui->assign('notify', '
Failed to register
'); $ui->display('register.tpl'); } //r2(U . 'register', 's', $_L['account_created_successfully']); } else { $ui->assign('username', $username); $ui->assign('fullname', $fullname); $ui->assign('address', $address); $ui->assign('phonenumber', $phonenumber); $ui->assign('notify', '
' . $msg . '
'); $ui->display('register.tpl'); } } else { $ui->assign('username', $username); $ui->assign('fullname', $fullname); $ui->assign('address', $address); $ui->assign('phonenumber', $phonenumber); $ui->assign('notify', '
' . $_L['Voucher_Not_Valid'] . '
'); $ui->display('register.tpl'); //r2(U . 'register', 'e', $_L['Voucher_Not_Valid']); } /*$password = _post('password'); if($username != '' AND $password != ''){ $d = ORM::for_table('tbl_customers')->where('username',$username)->find_one(); if($d){ $d_pass = $d['password']; if(Password::_uverify($password,$d_pass) == true){ $_SESSION['uid'] = $d['id']; $d->last_login = date('Y-m-d H:i:s'); $d->save(); _log($username .' '. $_L['Login_Successful'],'User',$d['id']); r2(U.'home'); }else{ _msglog('e',$_L['Invalid_Username_or_Password']); _log($username .' '. $_L['Failed_Login'],'User'); r2(U.'login'); } }else{ _msglog('e',$_L['Invalid_Username_or_Password']); r2(U.'login'); } }else{ _msglog('e',$_L['Invalid_Username_or_Password']); r2(U.'login'); }*/ break; default: $ui->assign('username', ""); $ui->assign('fullname', ""); $ui->assign('address', ""); $ui->assign('phonenumber', ""); $ui->display('register.tpl'); break; }