function onPaymentNotification(&$statuses) { $this->pluginParams(); $configKey = $this->plugin_params->user_id . ':' . $this->plugin_params->project_id . ':' . $this->plugin_params->token; require_once dirname(__FILE__) . '/library/sofortLib.php'; $notification = new SofortLib_Notification(); $notification->getNotification(); echo $notification->getTime(); $transactionId = $notification->getTransactionId(); //$return_url = HIKASHOP_LIVE.'index.php?option=com_hikashop&ctrl=checkout&task=after_end&order_id='.$order_id.$this->url_itemid; // fetch some information for the transaction id retrieved above $transactionData = new SofortLib_TransactionData($configKey); $transactionData->setTransaction($transactionId); $transactionData->sendRequest(); $method_id = $transactionData->getUserVariable(1); $this->pluginParams($method_id); $this->payment_params =& $this->plugin_params; global $Itemid; $this->url_itemid = empty($Itemid) ? '' : '&Itemid=' . $Itemid; $cancel_url = HIKASHOP_LIVE . 'index.php?option=com_hikashop&ctrl=order&task=cancel_order' . $this->url_itemid; if (empty($this->payment_params)) { $this->redirect($cancel_url); return false; } $order_id = $transactionData->getUserVariable(0); echo $order_id; $dbOrder = $this->getOrder($order_id); if (empty($dbOrder)) { $this->redirect_url = $cancel_url; return false; } $history = new stdClass(); $history->history_data = 'TransactionId: ' . $transactionId; $history->notified = 0; if ($transactionData->getStatus() == 'pending') { $email = new stdClass(); $email->subject = JText::sprintf('PAYMENT_NOTIFICATION_FOR_ORDER', 'Sofort', $transactionData->getStatus(), $dbOrder->order_number); $email->body = str_replace('<br/>', "\r\n", JText::sprintf('PAYMENT_NOTIFICATION_STATUS', 'Sofort', $transactionData->getStatus())) . "\r\n\r\n" . $transactionData->getStatusReason(); $action = false; $order_status = $this->payment_params->pending_status; $this->modifyOrder($order_id, $order_status, $history, $email); return false; } if ($transactionData->getStatus() != 'received') { $order_status = 'created'; $email = new stdClass(); $email->body = str_replace('<br/>', "\r\n", JText::sprintf('PAYMENT_NOTIFICATION_STATUS', 'Sofort', $order_status)) . ' ' . JText::_('STATUS_NOT_CHANGED') . "\r\n\r\n" . $transactionData->getStatusReason(); $email->subject = JText::sprintf('PAYMENT_NOTIFICATION_FOR_ORDER', 'Sofort', $order_status, $dbOrder->order_number); $this->modifyOrder($order_id, $order_status, $history, $email); return false; } $order_status = $this->payment_params->verified_status; $history->history_data = 'TransactionId: ' . $transactionId; $history->notified = 1; $email = new stdClass(); $email->subject = JText::sprintf('PAYMENT_NOTIFICATION_FOR_ORDER', 'Sofort', $transactionData->getStatus(), $dbOrder->order_number); $email->body = str_replace('<br/>', "\r\n", JText::sprintf('PAYMENT_NOTIFICATION_STATUS', 'Sofort', $order_status)) . ' ' . JText::sprintf('ORDER_STATUS_CHANGED', $order_status) . "\r\n\r\n" . $transactionData->getStatusReason(); $this->modifyOrder($order_id, $order_status, $history, $email); return true; }