public function forgotPasswordAction() { $error = false; $message = ""; $old_pass = ""; if (isset($this->_params['email'])) { $u = $this->getUsers()->getByEmail($this->_params['email']); if (is_null($u)) { $u = $this->getCenters()->getByEmail($this->_params['email']); if (is_null($u)) { $error = true; $message = "Email dosen't exist !"; $this->view->assign("errorMessage", $message); } } if (!is_null($u)) { $new_pass = NL_Utils::randomPassword(); $md5_new_pass = Table_Abstract::encryptPassword($new_pass); $email = new NL_HtmlMailer(); if (!$email->sendForgot($new_pass, $this->_params['email'])) { $error = true; $message = "Service not available, please contact us to fix this !"; $this->view->assign("errorMessage", $message); } else { $u->setPassword($md5_new_pass); $u->setFirstTime(0); if ($u->save()) { $this->view->assign("successMessage", 'Please check your email to log in with your new password, please remember to change it after you loggedin'); } else { $this->view->assign("errorMessage", $message); } } } } }
public function obMultipleAction() { $identity = (array) Zend_Auth::getInstance()->getIdentity(); $params = $this->getRequest()->getParams(); $this->view->assign('type', $params['type']); $center = $this->getCenters()->getById($identity['center_id']); $center = !is_null($center) ? $center->toArray() : array(); $company = $this->getCompanies()->getById($identity['company_id']); $company = !is_null($company) ? $company->toArray() : array(); $toEmailCenter = $center['email']; $toEmailCompany = $company['email']; // Submited request if (isset($params['process_ob'])) { $uid = mt_rand(100000, 999999); $date_created = date('Y-m-d H:i:s'); $date_delivery = isset($params['date_delivery']) ? $params['date_delivery'] : date('d/m/Y'); $date_delivery = convertUKtoUSdate($date_delivery); $company_id = $identity['company_id']; $center_id = $identity['center_id']; $customer_id = $identity['customer_id']; $amount = null; $uk_amount = $params['total']; $created_user_id = $identity['id']; $payment_type = $params['payment_type']; $traveller_name = $params['traveller_name']; $comment = $params['comment']; $type = $params['type']; $is_multiple = 1; $status = $company['with_check'] ? Table_Abstract::STATUS_PENDING : Table_Abstract::STATUS_UNPROCESSED; $ob = $this->getOrders()->createRow(); $ob_id = $ob->setUid($uid)->setDateCreated($date_created)->setDateDelivery($date_delivery)->setCompanyId($company_id)->setCenterId($center_id)->setCustomerId($customer_id)->setAmount($amount)->setUkAmount($uk_amount)->setCreatedUserId($created_user_id)->setPaymentType($payment_type)->setTravellerName($traveller_name)->setComment($comment)->setType($type)->setIsMultiple($is_multiple)->setStatus($status)->save(); // add to ob multiple foreach ($params['rate_id'] as $k => $rate_id) { $rate = $params['rate'][$k]; $amount = $params['amount'][$k]; $uk_amount = $params['uk_amount'][$k]; $ob_multiple = $this->getObMultiple()->createRow(); $ob_multiple->setObId($ob_id)->setRateId($rate_id)->setRate($rate)->setPaymentType($payment_type)->setAmount($amount)->setUkAmount($uk_amount)->save(); } /** * Get order by uid * @var mixed */ $ob = $this->getOrders()->getByUid($uid); $join_in = array(array('customers', 'customer_id'), array('companies', 'company_id'), array('centers', 'center_id'), array('rates', 'rate_id'), array('users', 'created_user_id'), array('users', 'response_user_id')); $ob = $this->_buildJoinTbl(array($ob), $join_in); $ob = $ob[0]; $ob['company'] = $company; // Ob multiple $ob_multiple = array(); $_ob_multiple = $this->getObMultiple()->geByOrderId($ob['id'])->toArray(); foreach ($_ob_multiple as $obm) { $ob_multiple[$obm['id']] = $obm; $ob_multiple[$obm['id']]['rate_detail'] = $this->getRates()->getById($obm['rate_id'])->toArray(); } $ob['multiple'] = $ob_multiple; /** * Send mail to processing center with order * @var NL_HtmlMailer */ $is_error = false; $email = new NL_HtmlMailer(); $email->sendOb($ob, $toEmailCenter); /** @var Send mail to approvers $approversTable */ $approversTable = new Table_Approvers(); $approvers = $approversTable->getByCompanyId($company['id']); foreach ($approvers->toArray() as $approver) { if (!is_null($approver['email']) && !empty($approver['email'])) { $email->sendOb($ob, $approver['email']); } } /** send to company if with approve */ if ($company['with_check']) { $email->sendOb($ob, $toEmailCompany); } // MESSAGE if (!$is_error) { // Success promotional message include APPLICATION_PATH . DIRECTORY_SEPARATOR . 'controllers' . DIRECTORY_SEPARATOR . 'AjaxObController.php'; $out = AjaxObController::renderSuccessMessage($type, $uid, $payment_type, $is_multiple = true); } else { // error message $out = NL_Render::renderErrorMessage(); } echo $out; $this->view->assign('show_view', false); } else { $this->view->assign('show_view', true); } }
/** * The final step in which we save the order * and send email to processing center to deal with it */ public function obStep3Action() { $out = ''; $params = $this->getRequest()->getParams(); // Set params $identity = (array) Zend_Auth::getInstance()->getIdentity(); $created_user_id = $identity['id']; $type = $params['type']; $payment_type = $params['payment_type']; $rate_id = $params['rate_id']; $amount = $params['amount']; $uk_amount = $params['uk_amount']; $traveller_name = $params['traveller_name']; $comment = $params['comment']; $uid = mt_rand(100000, 999999); $date_created = date('Y-m-d H:i:s'); $date_delivery = isset($params['date_delivery']) ? $params['date_delivery'] : date('d/m/Y'); // format date_delivery $date_delivery = convertUKtoUSdate($date_delivery); $user = $this->getUsers()->getById($created_user_id); $user = !is_null($user) ? $user->toArray() : array(); if (!empty($user)) { $company = $this->getCompanies()->getById($user['company_id']); $company = !is_null($company) ? $company->toArray() : array(); } $ordersTable = new Table_Orders(); $o = $ordersTable->createRow(); // Save in db $o->setUid($uid)->setDateCreated($date_created)->setDateDelivery($date_delivery)->setAmount($amount)->setUkAmount($uk_amount)->setRateId($rate_id)->setCreatedUserId($created_user_id)->setPaymentType($payment_type)->setTravellerName($traveller_name)->setComment($comment)->setCompanyId($user['company_id'])->setCenterId($user['center_id'])->setCustomerId($user['customer_id'])->setType($type); if ($company['with_check'] == 1) { $o->setStatus(Table_Abstract::STATUS_PENDING); } // Get email in which to send $identity = (array) Zend_Auth::getInstance()->getIdentity(); $center = $this->getCenters()->getById($identity['center_id']); $center = !is_null($center) ? $center->toArray() : array(); $toEmailCenter = $center['email']; $toEmailCompany = $company['email']; // If saves the order in db $is_error = false; if ($o->save()) { $user = (array) Zend_Auth::getInstance()->getIdentity(); $company = $this->getCompanies()->getById($user['company_id']); $company = !is_null($company) ? $company->toArray() : array(); /** * Get order by uid * @var mixed */ $ob = $this->getOrders()->getByUid($uid); $join_in = array(array('customers', 'customer_id'), array('companies', 'company_id'), array('centers', 'center_id'), array('rates', 'rate_id'), array('users', 'created_user_id'), array('users', 'response_user_id')); $ob = $this->_buildJoinTbl(array($ob), $join_in); $ob = $ob[0]; $ob['margins'] = $this->getMargins()->getFeeByRateCode($ob['rate']['c_code']); $ob['company'] = $company; /** * Send mail to processing center with order * @var NL_HtmlMailer */ $is_error = false; $email = new NL_HtmlMailer(); $email->sendOb($ob, $toEmailCenter); /** send to company if with approve */ if ($company['with_check']) { $email->sendOb($ob, $toEmailCompany); } /** @var Send mail to approvers $approversTable */ $approversTable = new Table_Approvers(); $approvers = $approversTable->getByCompanyId($company['id']); foreach ($approvers->toArray() as $approver) { if (!is_null($approver['email']) && !empty($approver['email'])) { $email->sendOb($ob, $approver['email']); } } } else { $is_error = true; } // MESSAGE if (!$is_error) { // Success promotional message $out = self::renderSuccessMessage($type, $uid, $params['payment_type'], $is_multiple = false); } else { // error message $out = NL_Render::renderErrorMessage(); } echo $out; }
public function approveRejectObAction() { $type = ''; $status = ''; /* single approve */ if (isset($this->_params['single_uid'])) { $type = $this->_params['type']; $status = $this->_params['status']; /** @var do approval and email $ob */ $ob = $this->getOrders()->getByUidA($this->_params['uid']); $ob->setStatus($this->_params['status']); $ob->save(); $user_id = $ob->getCreatedUserId(); if (!is_null($user_id) && !empty($user_id)) { $user = $this->getUsers()->getById($user_id); $user = !is_null($user) ? $user->toArray() : array(); if (!is_null($user['email']) && !empty($user['email'])) { $email = new NL_HtmlMailer(); $email->sendObStatus($ob->toArray(), $user, $user['email']); } } /* Selected orders approved */ } elseif (isset($this->_params['order_approved'])) { $type = 'order'; $status = 'approved'; /* Selected order rejected */ } elseif (isset($this->_params['order_rejected'])) { $type = 'order'; $status = 'rejected'; /* Selected buybacks approved */ } elseif (isset($this->_params['buyback_approved'])) { $type = 'buyback'; $status = 'approved'; /* Selected buybacks rejected */ } elseif (isset($this->_params['buyback_rejected'])) { $type = 'buyback'; $status = 'rejected'; } /** @var do the multiple approve / reject */ if (isset($this->_params['order_approved']) || isset($this->_params['order_rejected']) || isset($this->_params['buyback_approved']) || isset($this->_params['buyback_rejected'])) { foreach ($this->_params['uid'] as $uid => $on) { $ob = $this->getOrders()->getByUidO($uid); foreach ($ob as $o) { /* set status */ $o->setStatus($status); $o->save(); /** @var send email $user_id */ $user_id = $o->getCreatedUserId(); if (!is_null($user_id) && !empty($user_id)) { $user = $this->getUsers()->getById($user_id); $user = !is_null($user) ? $user->toArray() : array(); if (!is_null($user['email']) && !empty($user['email'])) { $email = new NL_HtmlMailer(); $email->sendObStatus($o->toArray(), $user, $user['email']); } } } } } /** * send order status to user */ if (isset($this->_params['order_approved']) || isset($this->_params['order_rejected']) || isset($this->_params['buyback_approved']) || isset($this->_params['buyback_rejected']) || isset($this->_params['single_uid'])) { $this->redirect('/approve-reject-ob?type=' . $type . '&status=' . $status); } $filter = array(); if (isset($this->_params['status']) && !empty($this->_params['status'])) { $filter = array('status' => $this->_params['status']); } $type = isset($this->_params['type']) ? $this->_params['type'] : $type; $filter += array('type' => $type); $identity = (array) Zend_Auth::getInstance()->getIdentity(); if ($identity['role'] == 'approver') { $filter += array('company_id' => $identity['company_id']); } else { $filter += array('company_id' => $identity['id']); } $join_in = array(array('customers', 'customer_id'), array('companies', 'company_id'), array('centers', 'center_id'), array('rates', 'rate_id'), array('users', 'created_user_id'), array('users', 'response_user_id')); $_array = $this->getOrders()->getAll($filter)->toArray(); $array = $this->_buildJoinTbl($_array, $join_in); $this->view->assign('array', $array); }