/** * Persists the log entrie in the database * * @param String $source String describing the source of this log entry. * Can be either a classname or the term "Sofort Library" * @param String $message */ private function _logIntoDb($source, $message) { $helper = new Shopware_Plugins_Frontend_SofortPayment_Components_Helpers_Helper(); if ($helper->option()->isLogging()) { $moduleVersion = Shopware()->Plugins()->Frontend()->SofortPayment()->getVersion(); $helper->database()->insertLogEntry($moduleVersion, $source, $message); } }
/** * This Action loads the loggingdata from the datebase into the backendview */ public function loadStoreAction() { $start = intval($this->Request()->getParam("start")); $limit = intval($this->Request()->getParam("limit")); $helper = new Shopware_Plugins_Frontend_SofortPayment_Components_Helpers_Helper(); $store = $helper->database()->getLog($start, $limit); $total = $helper->database()->getLogCount(); $this->View()->assign(array("data" => $store, "total" => $total, "success" => true)); }
/** * This action handles the asynchronous callbacks * The sofortLib is used to obtain data about */ public function notifyAction() { $request = $this->Request()->getParams(); $helper = new Shopware_Plugins_Frontend_SofortPayment_Components_Helpers_Helper(); $logger = new Shopware_Plugins_Frontend_SofortPayment_Components_Services_Logger(); Shopware()->Plugins()->Controller()->ViewRenderer()->setNoRender(); $notificationPassword = $helper->option()->getNotificationPassword(); //Validate Notification if (!$this->_validateResponse($request, $notificationPassword)) { $logger->logManually("Ideal Notification", "Validationhash missmatch in Notification for Transaction " . $request['transaction']); return; } $logger->logManually("Ideal Notification", "Notification for Transaction " . $request['transaction'] . " received"); //Gather Data $transactionId = $request['transaction']; $status = $request['status']; $reason = $request['status_reason']; $orderId = $helper->database()->getOrderByTransactionId($transactionId); $ordernumber = $helper->database()->getOrdernumberByTransactionId($transactionId); $state = $this->convertLibState($status, $reason); //Change order state if ($state != 0) { $order = Shopware()->Modules()->Order(); $order->setPaymentStatus($orderId, $state, false); $order->setOrderStatus($orderId, 0, false); $logger->logManually("Ideal Notification", "Changing state of order {$ordernumber} to {$state}."); } }
/** * Public method called after the customer returns to the shop * * @param string $status * @param string $reason * @param string $transactionId */ public function createOrderAfterRedirect($status, $reason, $transactionId) { // workaround for missing session after creating order $orderVariables = unserialize(Shopware()->Session()->offsetGet('sofortMailVariables')); $user = $this->context->getUser(); $alreadySend = false; $result = false; if (!Shopware()->Session()->sofortOrderExsist) { Shopware()->Session()->sofortSendMail = true; //create Order $result = $this->saveOrder($transactionId, 0); $alreadySend = true; } else { $helper = new Shopware_Plugins_Frontend_SofortPayment_Components_Helpers_Helper(); $helper->database()->changeTransactionId($this->context->getOrderNumber(), $transactionId); $this->setOrderState($transactionId, 0); } $state = $this->context->convertLibState($status, $reason); if ($state !== 0) { $row = $this->getOrderInformation($transactionId); $order = Shopware()->Modules()->Order(); $order->setPaymentStatus($row['id'], $state, false); $this->logger->logManually(__CLASS__, 'Change PaymentStatus for Order #' . $row['ordernumber'] . '(' . $row['id'] . ') to ' . $state); } if (!$alreadySend) { //send Mail $this->sendMail($orderVariables, $user); } }
/** * Displays either banner or logo with text for a payment description. * * @param Enlight_Event_EventArgs $arguments * @param Shopware_Plugins_Frontend_SofortPayment_Bootstrap $bootstrap */ public function designPaymentMeanSelection(Enlight_Event_EventArgs $arguments, Shopware_Plugins_Frontend_SofortPayment_Bootstrap $bootstrap) { $view = $arguments->getSubject()->View(); $helper = new Shopware_Plugins_Frontend_SofortPayment_Components_Helpers_Helper(); $translator = new Shopware_Plugins_Frontend_SofortPayment_Components_Services_Translator(); $languageShortName = $translator->getLanguageShortName(); //Assign Sofortbanking template variables $view->sofortSofortbankingIsCustomerProtectionEnabled = $helper->option()->isCustomerProtectionEnabled(); $view->sofortSofortBankingLinkBannerLogo = "https://images.sofort.com/" . $languageShortName . "/su/landing.php"; $view->sofortSofortBankingLinkBannerCustomerProtection = $languageShortName === "de" ? "https://www.handelsbank.com/de/deutsche-handelsbank-kaeuferschutz/deutsche-handelsbank-kaeuferschutz.html" : "https://www.handelsbank.com/en/buyer-protection/information-for-buyers.html"; $view->sofortSofortbankingIsRecommended = $helper->option()->isRecommendedPayment("sofortbanking"); $view->sofortSofortbankingIsShowingBanner = $helper->option()->getFrontendDisplayType("sofortbanking") == 1; $view->sofortSofortbankingIsShowingLogo = $helper->option()->getFrontendDisplayType("sofortbanking") == 2; $view->sofortSofortbankingLogo = $translator->getSofortbankingLogo(); $view->sofortSofortbankingBanner = $translator->getSofortbankingBanner($customerProtection = false); $view->sofortSofortbankingBannerCp = $translator->getSofortbankingBanner($customerProtection = true); $view->sofortSofortbankingRecommendedText = $translator->getSnippetByNumber("1003", "(empfohlene Zahlart)"); $view->sofortSofortbankingAlt = $translator->getSnippetByNumber("1001", "SOFORT Überweisung"); $view->sofortSofortbankingLogoText = $translator->getSnippetByNumber("1004", "* Zahlungssystem mit TÜV-geprüftem Datenschutz <br />" . "* Keine Registrierung notwendig <br />" . "* Ware/Dienstleistung wird bei Verfügbarkeit SOFORT versendet <br />" . "* Bitte halten Sie Ihre Online-Banking-Daten (PIN/TAN) bereit"); $view->sofortSofortbankingLogoTextCp = $translator->getSnippetByNumber("1005", "* Bei Bezahlung mit SOFORT Überweisung genießen Sie Käuferschutz!" . " <a href='https://www.handelsbank.com/de/deutsche-handelsbank-kaeuferschutz/deutsche-handelsbank-kaeuferschutz.html'>" . "Mehr Informationen</a><br />"); //Assign Ideal template variables $configKey = $helper->option()->getConfigKey("ideal"); $password = $helper->option()->getPassword(); $sofort = $helper->library()->getIdealClassic($configKey, $password); $view->sofortIdealAlt = $translator->getSnippetByNumber("2001", "iDEAL"); $view->sofortIdealRecommendedText = $translator->getSnippetByNumber("1003", "(empfohlene Zahlart)"); $view->sofortIdealWelcomeMessage = $translator->getSnippetByNumber("2002", "Bitte wählen Sie Ihre Bank:"); $view->sofortIdealBanks = $sofort->getRelatedBanks(); //get all iDEAL-Banks $view->sofortIdealIsRecommended = $helper->option()->isRecommendedPayment("ideal"); $view->sofortIdealIsShowingBanner = $helper->option()->getFrontendDisplayType("ideal") == 1; $view->sofortIdealIsShowingLogo = $helper->option()->getFrontendDisplayType("ideal") == 2; $view->sofortIdealBanner = $translator->getIdealBanner(); $view->sofortIdealLogo = $translator->getIdealLogo(); $view->sofortIdealLink = "https://images.sofort.com/" . $languageShortName . "/ideal/landing.php"; }
/** * Deals with timeouts during transactions * * @todo set correct translationname */ public function timeoutAction() { $request = $this->Request()->getParams(); $helper = new Shopware_Plugins_Frontend_SofortPayment_Components_Helpers_Helper(); $translator = new Shopware_Plugins_Frontend_SofortPayment_Components_Services_Translator(); $logger = new Shopware_Plugins_Frontend_SofortPayment_Components_Services_Logger(); Shopware()->Session()->pigmbhErrorMessage = $translator->getSnippetByNumber("1202", "Die Zeit zur Durchführung der Zahlung ist aus Sicherheitsgründen abgelaufen. " . "Es wurde keine Transaktion durchgeführt. Bitte führen Sie die Zahlung erneut aus."); //Condemn order if appropriate $logger->logManually($this->_loggingSource, "Changing Orderstate to mark it as failed"); $order = Shopware()->Modules()->Order(); $helper->database()->changeTransactionId($this->getOrderNumber(), $request['transactionId']); $orderId = $helper->database()->getOrderByTransactionId($request['transactionId']); $order->setPaymentStatus($orderId, $this->convertLibState("payment_canceled", "unknown"), false); $this->restoreArtikleStock($orderId); $this->redirect(array("controller" => "account", "action" => "payment", "sTarget" => "checkout", "errorMessage" => 1, "forceSecure" => 1)); }
/** * Translates the payment description */ private function _translatePayments($languages) { $translator = new Shopware_Plugins_Frontend_SofortPayment_Components_Services_Translator(); $helper = new Shopware_Plugins_Frontend_SofortPayment_Components_Helpers_Helper(); $suKey = $helper->database()->getPaymentKey("sofortbanking"); $idealKey = $helper->database()->getPaymentKey("sofortideal"); //Add Translation foreach ($languages as $language) { $translator->setLanguage($language); $suDescription = $translator->getSnippetByNumber("1001"); $idealDescription = $translator->getSnippetByNumber("2001"); $translator->addPaymentTranslation($suKey, $suDescription); $translator->addPaymentTranslation($idealKey, $idealDescription); } }
/** * Adds a translation set for the payment with the given key * * @param String $key Key of the payment (numeric) * @param String $description * @param String $additionalDescription (optional) */ public function addPaymentTranslation($key, $description, $additionalDescription = "") { $translationObject = new Shopware_Components_Translation(); $helper = new Shopware_Plugins_Frontend_SofortPayment_Components_Helpers_Helper(); $data = array(); $data['description'] = $description; $data['additionalDescription'] = $additionalDescription; $languages = $helper->database()->getShopIds($this->_language); foreach ($languages as $language) { $translationObject->write($language['id'], "config_payment", $key, $data, 1); } }
/** * This action handles the asynchronous callbacks * The sofortLib is used to obtain data about */ public function notifyAction() { Shopware()->Plugins()->Controller()->ViewRenderer()->setNoRender(); $helper = new Shopware_Plugins_Frontend_SofortPayment_Components_Helpers_Helper(); $configKey = $helper->option()->getConfigKey("sofortbanking"); //Step 3: Handling Notifications about status changes $notification = $helper->library()->getNotificationInstance(); $notification->setLogger(new Shopware_Plugins_Frontend_SofortPayment_Components_Services_Logger()); $notification->setLogEnabled(); $notification->getNotification(); $transactionId = $notification->getTransactionId(); //Step 4: Inquire changed Transactiondata $transactionData = new SofortLib_TransactionData($configKey); $transactionData->setTransaction($transactionId); $transactionData->sendRequest(); //Step 5: Handling the Response to the Inquiry for changed Transaction Data $orderId = $helper->database()->getOrderByTransactionId($transactionId); $state = $this->convertLibState($transactionData->getStatus(), $transactionData->getStatusReason()); $order = Shopware()->Modules()->Order(); if ($state != 0) { $order->setPaymentStatus($orderId, $state, false); $order->setOrderStatus($orderId, 0, false); } }
/** * Handles bank selection for ideal payments * * @param Enlight_Hook_HookArgs $arguments */ public function onSavePayment(Enlight_Hook_HookArgs $arguments) { $helper = new Shopware_Plugins_Frontend_SofortPayment_Components_Helpers_Helper(); $params = Shopware()->Front()->Request()->getParams(); $ideal = $this->Payments()->findOneBy(array('name' => 'sofortideal')); if (!isset($params['payment'])) { $paymentId = $params['register']['payment']; } if ($ideal->getId() == $paymentId && isset($params['sofort_ideal_bank_select'])) { $helper->event()->saveBankId($params['sofort_ideal_bank_select'], Shopware()->Session()->offsetGet('sUserId')); } }