public function successAction()
 {
     $oMail = new \Application\Mail($this->getServiceLocator());
     $oUserSessionContainer = new UserSessionContainer();
     $nUserId = $oUserSessionContainer->getUserId();
     if ($nUserId) {
         $nCartId = $this->getCartTable()->findRow(array('user_id' => $nUserId));
         if ($nCartId) {
             $this->getCartItemTable()->deleteRow(array('cart_id' => $nCartId));
         }
         $oUserSessionContainer->clear();
     }
     $sOrderId = $this->params()->fromQuery('id');
     $sSessionId = $this->params()->fromQuery('session');
     if (isset($sOrderId) && isset($sSessionId)) {
         $oOrderPayment = $this->getOrderPaymentTable()->getRow(array('session_id' => $sSessionId, 'order_id' => $sOrderId));
         $nUserId = $oOrderPayment->user_id;
         if ($oOrderPayment && $nUserId) {
             $oUserStd = new \stdClass();
             $oUserParam = $this->getUserParamTable()->getRow(array('user_id' => $nUserId));
             foreach ($oUserParam as $sKey => $mValue) {
                 if (in_array($sKey, array('user_id'))) {
                     continue;
                 }
                 if (in_array($sKey, array('id'))) {
                     $sKey = 'user_param_id';
                 }
                 $oUserStd->{$sKey} = $mValue;
             }
             foreach ($oOrderPayment as $sKey => $mValue) {
                 if (in_array($sKey, array('user_id', 'first_name', 'last_name', 'e-mail address'))) {
                     continue;
                 }
                 if (in_array($sKey, array('id'))) {
                     $sKey = 'order_payment_id';
                 }
                 if (in_array($sKey, array('amount'))) {
                     $sKey = 'user_amount';
                     $mValue = (int) $mValue / 100;
                 }
                 $oUserStd->{$sKey} = $mValue;
             }
             $oUserStd->issue_user_date = $oOrderPayment->last_update_payment_status_date;
             $nPaymentStatus = 1;
             if ($oOrderPayment->payment_status) {
                 $nPaymentStatus = $oOrderPayment->payment_status;
             }
             $sMessage = $oMail->getMessage('sendPayUReport' . $nPaymentStatus, $oUserStd);
             $oBorrowerForm = $this->getServiceLocator()->get('BorrowerFormService');
             $aAllFine = array();
             $aAllowLocations = array();
             $oUserSessionContainer = new UserSessionContainer();
             $sBorrowerId = $oUserParam->borrower_hash;
             $oUserSessionContainer->setIsBorrower(1);
             $oUserSessionContainer->setBorrowerId($sBorrowerId);
             $oXServer = new XServer($sBorrowerId);
             $aBorrowerData = $oXServer->getBorrowerData();
             if (!isset($aBorrowerData['error'])) {
                 $aBorrower['key'] = $oUserSessionContainer->getPreIsInit();
                 $aBorrower['email_address'] = $oUserSessionContainer->getEmailAddress();
                 $aBorrower['is_borrower'] = 1;
                 $oBorrowerForm->setData($aBorrower);
                 $aExpirationItem = $oUserSessionContainer->getExpirationItem();
                 $aExpirationItemByLocation = $oUserSessionContainer->getExpirationItemByLocation();
                 $aBorrowerFine = $oUserSessionContainer->getBorrowerFine();
                 $aBorrowerFineByLocation = $oUserSessionContainer->getBorrowerFineByLocation();
                 $nCredit = $oUserSessionContainer->getCredit();
                 foreach ($aExpirationItemByLocation as $sLocationKey => $aFine) {
                     $aAllowLocations[$sLocationKey] = $this->translateLocation($sLocationKey);
                     if ($sLocationKey !== 'sum') {
                         $nSum = $aFine['sum'];
                         unset($aFine['sum']);
                         unset($aFine['translate_location']);
                         $aAllFine[$sLocationKey]['sum'] += $nSum;
                         $aAllFine[$sLocationKey]['expiration_item'] = $aFine;
                     }
                 }
                 foreach ($aBorrowerFineByLocation as $sLocationKey => $aFine) {
                     $aAllowLocations[$sLocationKey] = $this->translateLocation($sLocationKey);
                     if ($sLocationKey !== 'sum') {
                         $nSum = $aFine['sum'];
                         unset($aFine['sum']);
                         unset($aFine['translate_location']);
                         $aAllFine[$sLocationKey]['sum'] += $nSum;
                         $aAllFine[$sLocationKey]['borrower_fine'] = $aFine;
                     }
                 }
                 $bSuccess = true;
                 //$oUserSessionContainer->clear();
             } else {
                 $sErrorMessage = 'getfine - XServer response: ' . $aBorrowerData['error'];
             }
         }
     }
     return new ViewModel(array('message' => $sMessage, 'form' => $oBorrowerForm, 'expiration_item' => $aExpirationItem, 'expiration_item_by_location' => $aExpirationItemByLocation, 'borrower_fine' => $aBorrowerFine, 'borrower_fine_by_location' => $aBorrowerFineByLocation, 'all_fine' => $aAllFine, 'allow_locations' => $aAllowLocations, 'credit' => $nCredit, 'success' => $bSuccess, 'error_message' => $sErrorMessage));
 }
 public function pregetfineAction()
 {
     $oUserSessionContainer = new UserSessionContainer();
     $oRequest = new \Zend\Http\PhpEnvironment\Request();
     //$sReferer = $oRequest->getServer('HTTP_REFERER'); //TODO: ustawić odpowiedni parametr
     //$sBorrowerId = $this->checkCookie();
     $sBorrowerId = 1;
     if ($sBorrowerId) {
         $oUserSessionContainer->setIsBorrower(1);
         $oUserSessionContainer->setBorrowerId($sBorrowerId);
         $this->redirect()->toRoute('aleph_index/aleph_index_process', array('action' => 'getfine'), array());
         $this->stopPropagation();
     } else {
         header("Location: https://aleph.wat.edu.pl/pds?func=load-login&calling_system=libsmart&url=https://wplaty.bg.wat.edu.pl/wat/bor_id");
         exit;
     }
     /*
     $sBorrowerId = $this->params()->fromRoute('bor_id');
     if ($sBorrowerId) {
       $oUserSessionContainer->setIsBorrower(1);
       $oUserSessionContainer->setBorrowerId($sBorrowerId);
       $this->redirect()->toRoute('aleph_index/aleph_index_process', array('action' => 'getfine'), array());
       $this->stopPropagation();
     } else {
     }
     */
     return new ViewModel(array('success' => true));
 }