Beispiel #1
0
 /**
  * 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);
     }
 }
Beispiel #2
0
 /**
  * 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));
 }
Beispiel #3
0
 /**
  * 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);
     }
 }
Beispiel #5
0
 /**
  * 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";
 }
Beispiel #6
0
 /**
  * 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));
 }
Beispiel #7
0
 /**
  * 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);
     }
 }
Beispiel #8
0
 /**
  * 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);
     }
 }
Beispiel #10
0
 /**
  * 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'));
     }
 }