'; } 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 (!Validator::Email($email)) { $msg .= 'Email is not Valid
'; } if ($password != $cpassword) { $msg .= $_L['PasswordsNotMatch'] . '
'; } if(!empty($config['sms_url'])){ $otpPath .= sha1($username.$db_password).".txt"; run_hook('validate_otp'); #HOOK //expired 10 minutes if(file_exists($otpPath) && time()-filemtime($otpPath)>1200){ unlink($otpPath); r2(U . 'register', 's', 'Verification code expired'); }else if(file_exists($otpPath)){ $code = file_get_contents($otpPath); if($code!=$otp_code){ $ui->assign('username', $username); $ui->assign('fullname', $fullname); $ui->assign('address', $address); $ui->assign('email', $email); $ui->assign('phonenumber', $phonenumber); $ui->assign('notify', 'Wrong Verification code'); $ui->assign('notify_t', 'd'); $ui->display('register-otp.tpl'); exit(); }else{ unlink($otpPath); } }else{ r2(U . 'register', 's', 'No Verification code'); } } $d = ORM::for_table('tbl_customers')->where('username', $username)->find_one(); if ($d) { $msg .= $_L['account_already_exist'] . '
'; } if ($msg == '') { run_hook('register_user'); #HOOK $d = ORM::for_table('tbl_customers')->create(); $d->username = alphanumeric($username,"+_."); $d->password = $password; $d->fullname = $fullname; $d->address = $address; $d->email = $email; $d->phonenumber = $phonenumber; if ($d->save()) { $user = $d->id(); r2(U . 'login', 's', $_L['Register_Success']); } else { $ui->assign('username', $username); $ui->assign('fullname', $fullname); $ui->assign('address', $address); $ui->assign('email', $email); $ui->assign('phonenumber', $phonenumber); $ui->assign('notify', 'Failed to register'); $ui->assign('notify_t', 'd'); run_hook('view_otp_register'); #HOOK $ui->display('register-rotp.tpl'); } } else { $ui->assign('username', $username); $ui->assign('fullname', $fullname); $ui->assign('address', $address); $ui->assign('email', $email); $ui->assign('phonenumber', $phonenumber); $ui->assign('notify', $msg); $ui->assign('notify_t', 'd'); $ui->display('register.tpl'); } break; default: if(!empty($config['sms_url'])){ $username = _post('username'); if(!empty($username)){ $d = ORM::for_table('tbl_customers')->where('username', $username)->find_one(); if ($d) { r2(U . 'register', 's', $_L['account_already_exist']); } if(!file_exists($otpPath)){ mkdir($otpPath); touch($otpPath.'index.html'); } $otpPath .= sha1($username.$db_password).".txt"; //expired 10 minutes if(file_exists($otpPath) && time()-filemtime($otpPath)<1200){ $ui->assign('username', $username); $ui->assign('notify', 'Please wait '.(1200-(time()-filemtime($otpPath))).' seconds before sending another SMS'); $ui->assign('notify_t', 'd'); $ui->display('register-otp.tpl'); }else{ $otp = rand(100000,999999); file_put_contents($otpPath, $otp); Message::sendSMS($username,$config['CompanyName']."\nYour Verification code are: $otp"); $ui->assign('username', $username); $ui->assign('notify', 'Verification code has been sent to your phone'); $ui->assign('notify_t', 's'); $ui->display('register-otp.tpl'); } }else{ run_hook('view_otp_register'); #HOOK $ui->display('register-rotp.tpl'); } }else{ $ui->assign('username', ""); $ui->assign('fullname', ""); $ui->assign('address', ""); $ui->assign('email', ""); $ui->assign('otp', false); run_hook('view_register'); #HOOK $ui->display('register.tpl'); } break; }