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 getfineAction() { $oUserSessionContainer = new UserSessionContainer(); $oBorrowerForm = $this->getServiceLocator()->get('BorrowerFormService'); $aExpirationItem = null; $aBorrowerFine = null; $bSuccess = false; $sIsBorrower = $oUserSessionContainer->getIsBorrower(); $sBorrowerId = $oUserSessionContainer->getBorrowerId(); if ($sIsBorrower === 1 && $sBorrowerId) { if ($this->getRequest()->isPost()) { $oBorrowerForm->setData($this->getRequest()->getPost()); if ($oBorrowerForm->isValid()) { try { $this->getUserTable()->beginTransaction(); $oUserEntity = new UserEntity(); $oUserParamEntity = new UserParamEntity(); $oCartEntity = new CartEntity(); $oCartItemEntity = new CartItemEntity(); $oItemEntity = new ItemEntity(); $aValidatedData = $oBorrowerForm->getData(); \Zend\Debug\Debug::dump($oUserSessionContainer->getPreIsInit() === $aValidatedData['key']); if ($oUserSessionContainer->getPreIsInit() === $aValidatedData['key']) { $oTempUserData = new \ArrayObject($oUserSessionContainer->getArrayCopy()); $oTempUserData->offsetSet('user_category_id', $this->getUserCategoryTable()->findRow(array('name' => 'borrower'))); $oTempUserData->offsetSet('active', 0); $oTempUserData->offsetSet('user_id', $this->getUserTable()->addRow($oUserEntity->setOptions($oTempUserData))); if ($oTempUserData->offsetGet('user_id')) { $oTempUserData->offsetSet('user_param_id', $this->getUserParamTable()->addRow($oUserParamEntity->setOptions($oTempUserData))); } if ($oTempUserData->offsetGet('user_id') && $oTempUserData->offsetGet('user_param_id')) { $oUserSessionContainer->setUserId($oTempUserData->offsetGet('user_id')); } else { throw new \Exception(); } $nUserId = $oUserSessionContainer->getUserId(); $nCartId = $this->getCartTable()->findRow(array('user_id' => $nUserId)); if (!$nCartId) { $nCartId = $this->getCartTable()->addRow($oCartEntity->setOptions(new \ArrayObject(array('user_id' => $nUserId)))); } if ($oUserSessionContainer->getExpirationItemSum()) { $sName = 'expiration_item'; foreach ($oUserSessionContainer->getExpirationItem() as $nKey => $aItem) { if (is_numeric($nKey)) { $oItemData = new \ArrayObject(array('name' => $sName, 'fine_id' => $aItem['loan_id'], 'fine_sequence' => '-- brak danych --', 'item_sequence' => '-- brak danych --', 'doc_number' => '-- brak danych --', 'call_no' => '-- brak danych --', 'item_barcode' => $aItem['barcode'], 'title' => $aItem['title'], 'price_net' => $aItem['loan_fine'], 'price_gross' => $aItem['loan_fine'], 'due_date' => $aItem['due_date'])); $nItemId = $this->getItemTable()->addRow($oItemEntity->setOptions($oItemData)); $oCartItemData = new \ArrayObject(array('cart_id' => $nCartId, 'item_id' => $nItemId, 'user_id' => $nUserId)); $this->getCartItemTable()->addRow($oCartItemEntity->setOptions($oCartItemData)); } } } if ($oUserSessionContainer->getBorrowerFineSum()) { $sName = 'borrower_fine'; foreach ($oUserSessionContainer->getBorrowerFine() as $nKey => $aFine) { if (is_numeric($nKey)) { $oItemData = new \ArrayObject(array('name' => $sName, 'fine_id' => $aFine['fee_id'], 'fine_sequence' => '-- brak danych --', 'item_sequence' => '-- brak danych --', 'doc_number' => '-- brak danych --', 'call_no' => '-- brak danych --', 'item_barcode' => $aFine['barcode'], 'title' => $aFine['comment'], 'price_net' => $aFine['balance'], 'price_gross' => $aFine['balance'], 'due_date' => null)); $nItemId = $this->getItemTable()->addRow($oItemEntity->setOptions($oItemData)); $oCartItemData = new \ArrayObject(array('cart_id' => $nCartId, 'item_id' => $nItemId, 'user_id' => $nUserId)); $this->getCartItemTable()->addRow($oCartItemEntity->setOptions($oCartItemData)); } } } $this->getUserTable()->commit(); $this->redirect()->toRoute('shop_cart/shop_cart_process', array('action' => 'items'), array()); } } catch (\Exception $e) { $this->getUserTable()->rollBack(); \Zend\Debug\Debug::dump($e->getMessage()); exit; } } } else { $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(); $aBorrowerFine = $oUserSessionContainer->getBorrowerFine(); $nCredit = $oUserSessionContainer->getCredit(); $bSuccess = true; } else { $sErrorMessage = 'getfine - XServer response: ' . $aBorrowerData['error']; } } } else { $sErrorMessage = 'getfine - podaj identyfikator czytelnika'; $oUserSessionContainer->clear(); } return new ViewModel(array('form' => $oBorrowerForm, 'expiration_item' => $aExpirationItem, 'borrower_fine' => $aBorrowerFine, 'credit' => $nCredit, 'success' => $bSuccess, 'error_message' => $sErrorMessage)); }