Esempio n. 1
0
 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);
                 }
             }
         }
     }
 }
Esempio n. 2
0
 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);
     }
 }
Esempio n. 3
0
 /**
  * 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;
 }
Esempio n. 4
0
 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);
 }