diff --git a/da-DK.plg_vmpayment_quickpay.ini b/da-DK.plg_vmpayment_quickpay.ini new file mode 100644 index 0000000..cbf948b --- /dev/null +++ b/da-DK.plg_vmpayment_quickpay.ini @@ -0,0 +1,113 @@ +; @date : $Date$ +; @Id $Id$ +; @Revision : $Revision$ +; @author info@stokersoft.com +; @package VMPayment +; @subpackage VirtueMart payment Quickpay + +VMPAYMENT_QUICKPAY="Vm Payment plugin Quickpay" + +VMPAYMENT_QUICKPAY_PAYWINDOWLANGUAGE="da" + +VMPAYMENT_QUICKPAY_PARAMS="Quickpay Parameters" + +VMPAYMENT_QUICKPAY_MERCHANT="Merchant ID" +VMPAYMENT_QUICKPAY_MERCHANT_DESC="The Quickpay merchant number also called QuickpayId as listed under Settings.Merchant in the Quickpay Manager." + + +VMPAYMENT_AGREEMENT_ID="Agreement ID" +VMPAYMENT_AGREEMENT_ID_DESC="The agreement ID from Quickpay" + +VMPAYMENT_QUICKPAY_SUBSCRIPTION="Subscription" +VMPAYMENT_QUICKPAY_SUBSCRIPTION_DESC="Create a subscription instead of a standard payment" + +VMPAYMENT_QUICKPAY_STANDARD_PAYMENT="Standard Payment" + +VMPAYMENT_DESCRIPTION="Description" +VMPAYMENT_DESCRIPTION_DESC="A value by the merchant's own choise. Used for identifying a subscription payment. Note: Required when 'subscribe' is set" + +VMPAYMENT_METHOD="Payment Method" +VMPAYMENT_METHOD_DESC="Lock to some payment method(s). Multiple card types allowed by comma separation" + +VMPAYMENT_BRANDING_ID="Branding ID" +VMPAYMENT_BRANDING_ID_DESC="Use this branding. Overwrites the default branding" + +VMPAYMENT_GOOGLE_ANALYTICS_TRACKING_ID="Google Analytics Tracking ID" +VMPAYMENT_GOOGLE_ANALYTICS_TRACKING_ID_DESC="Your Google Analytics tracking ID" + +VMPAYMENT_GOOGLE_ANALYTICS_CLIENT_ID="Google Analytics Client ID" +VMPAYMENT_GOOGLE_ANALYTICS_CLIENT_ID_DESC="Your Google Analytics client ID" + +VMPAYMENT_PAII_PRODUCT_ID="Paii Product ID" +VMPAYMENT_PAII_PRODUCT_ID_DESC="The Paii product ID (P03 or P08 typcial)" + +VMPAYMENT_PAII_CATEGORY="Paii Category" +VMPAYMENT_PAII_CATEGORY_DESC="The category products are selled for" + + +VMPAYMENT_QUICKPAY_MD5="MD5 secret" +VMPAYMENT_QUICKPAY_MD5_DESC="The MD5 secret which can be found in the Quickpay Manager under Settings.MD5 secret." + +VMPAYMENT_QUICKPAY_PAYMENT_WINDOW_API_KEY="API Key" +VMPAYMENT_QUICKPAY_PAYMENT_WINDOW_API_KEY_DESC="The API key from Quickpay" + +VMPAYMENT_QUICKPAY_PAYMENT_WINDOW_PRIVATE_KEY="Private Key" +VMPAYMENT_QUICKPAY_PAYMENT_WINDOW_PRIVATE_KEY_DESC="Private Key from Quickpay" + +VMPAYMENT_QUICKPAY_AUTOCAPTURE="Autocapture" +VMPAYMENT_QUICKPAY_AUTOCAPTURE_DESC="If set, the payment will be captured automatically" + +VMPAYMENT_QUICKPAY_SPLITPAYMENT="Splitpayment" +VMPAYMENT_QUICKPAY_SPLITPAYMENT_DESC="Enable split payment on transaction" + +VMPAYMENT_QUICKPAY_AUTOFEE="Autofee" +VMPAYMENT_QUICKPAY_AUTOFEE_DESC="If set the fee charged by the acquirer will be calculated and added to the transaction amount" + +VMPAYMENT_QUICKPAY_CARDTYPELOCK="Cardtypelock" +VMPAYMENT_QUICKPAY_CARDTYPELOCK_DESC="Lock payment to one or more payment methods. In doubt leave blank, or look at http://quickpay.net/features/cardtypelock/" + +VMPAYMENT_QUICKPAY_STATUS_PENDING="Order Status for Pending transactions" +VMPAYMENT_QUICKPAY_STATUS_PENDING_DESC="Select an order status for Pending Quickpay transactions." +VMPAYMENT_QUICKPAY_STATUS_SUCCESS="Order Status for Successful transactions" +VMPAYMENT_QUICKPAY_STATUS_SUCCESS_DESC="Select the order status to which the actual order is set, if the transaction from Quickpay was successful. If using download selling options: select the status which enables the download (then the customer is instantly notified about the download via e-mail)." +VMPAYMENT_QUICKPAY_STATUS_FAILED="Order Status for Failed transactions" +VMPAYMENT_QUICKPAY_STATUS_FAILED_DESC="Select an order status for Failed Quickpay transactions." + +VMPAYMENT_QUICKPAY_TESTMODE="Testmode" +VMPAYMENT_QUICKPAY_TESTMODE_DESC="When enabled Quickpay will handle transactions as test only, even if Quickpay is in production mode." + + +VMPAYMENT_QUICKPAY_ERROR_EMAIL_SUBJECT="Error: No order id" +VMPAYMENT_QUICKPAY_UNKNOW_ORDER_ID="Unknown order id" + +VMPAYMENT_QUICKPAY_PAYMENT_CONFIRMED="Your payment for order %s has been confirmed by Quickpay" + +VMPAYMENT_PAYMENT_NAME="Payment name" +VMPAYMENT_QUICKPAY_TIME="Time" +VMPAYMENT_QUICKPAY_STATE="State" +VMPAYMENT_QUICKPAY_QPSTAT="Qpstat" +VMPAYMENT_QUICKPAY_QPSTATMSG="Qpstat message" +VMPAYMENT_QUICKPAY_CHSTAT="Chstat message" +VMPAYMENT_QUICKPAY_CHSTATMSG="Chstat message" +VMPAYMENT_QUICKPAY_TRANSACTION="Transaction" +VMPAYMENT_QUICKPAY_CARDTYPE="Cardtype" +VMPAYMENT_QUICKPAY_CARDNUMBER="Card number" +VMPAYMENT_QUICKPAY_FRAUDPROBABILITY="Fraud probability" +VMPAYMENT_QUICKPAY_FRAUDREMARKS="Fraud remarks" +VMPAYMENT_QUICKPAY_FRAUDREPORT="Fraud report" +VMPAYMENT_QUICKPAY_FEE="Fee" + +VMPAYMENT_QUICKPAY_PREFIX="Order Prefix" +VMPAYMENT_QUICKPAY_PREFIX_DESC="This prefix is appended to the beginning of the order id when it is sent to Quickpay." + +VMPAYMENT_QUICKPAY_THIRDPARTYAPI="Third party api url" +VMPAYMENT_QUICKPAY_THIRDPARTYAPI_DESC="Third party api url, on succesful payment data is forwarded to external http service, use tags [ORDER_NUMBER], [TRANSACTION_ID] and [PAYMENT_METHOD_ID]" + +VMPAYMENT_QUICKPAY_ROUNDORDER="Round order total" +VMPAYMENT_QUICKPAY_ROUNDORDER_DESC="Rounds the order total to nearest integer, can be used in combination with external systems, where rounding is different. If you are unsure, do not enable this function." + +VMPAYMENT_QUICKPAY_THIRDPARTYAPI="Third party api url" +VMPAYMENT_QUICKPAY_THIRDPARTYAPI_DESC="Third party api url, on succesful payment data is forwarded to external http service, use tags [ORDER_NUMBER], [TRANSACTION_ID] and [PAYMENT_METHOD_ID]. Leave field empty, if no integration is needed." + +VMPAYMENT_QUICKPAY_ROUNDORDER="Round order total" +VMPAYMENT_QUICKPAY_ROUNDORDER_DESC="Rounds the order total to nearest integer, can be used in combination with external systems, where rounding is different. If you are unsure, do not enable this function." diff --git a/da-GB.plg_vmpayment_quickpay.sys.ini b/da-GB.plg_vmpayment_quickpay.sys.ini new file mode 100644 index 0000000..b8f20b8 --- /dev/null +++ b/da-GB.plg_vmpayment_quickpay.sys.ini @@ -0,0 +1,8 @@ +; @date : $Date$ +; @Id $Id$ +; @Revision : $Revision$ +; @author info@stokersoft.com +; @package VMPayment +; @subpackage VirtueMart payment Quickpay + +VMPAYMENT_QUICKPAY="Vm Payment plugin Quickpay" \ No newline at end of file diff --git a/en-GB.plg_vmpayment_quickpay.ini b/en-GB.plg_vmpayment_quickpay.ini new file mode 100644 index 0000000..3f2fd84 --- /dev/null +++ b/en-GB.plg_vmpayment_quickpay.ini @@ -0,0 +1,111 @@ +; @date : $Date$ +; @Id $Id$ +; @Revision : $Revision$ +; @author info@stokersoft.com +; @package VMPayment +; @subpackage VirtueMart payment Quickpay + +VMPAYMENT_QUICKPAY="Vm Payment plugin Quickpay" + +VMPAYMENT_QUICKPAY_PAYWINDOWLANGUAGE="da" + +VMPAYMENT_QUICKPAY_PARAMS="Quickpay Parameters" + +VMPAYMENT_QUICKPAY_MERCHANT="Merchant ID" +VMPAYMENT_QUICKPAY_MERCHANT_DESC="The Quickpay merchant number also called QuickpayId as listed under Settings.Merchant in the Quickpay Manager." + + +VMPAYMENT_AGREEMENT_ID="Agreement ID" +VMPAYMENT_AGREEMENT_ID_DESC="The agreement ID from Quickpay" + +VMPAYMENT_QUICKPAY_SUBSCRIPTION="Subscription" +VMPAYMENT_QUICKPAY_SUBSCRIPTION_DESC="Create a subscription instead of a standard payment" + +VMPAYMENT_QUICKPAY_STANDARD_PAYMENT="Standard Payment" + +VMPAYMENT_DESCRIPTION="Description" +VMPAYMENT_DESCRIPTION_DESC="A value by the merchant's own choise. Used for identifying a subscription payment. Note: Required when 'subscribe' is set" + +VMPAYMENT_METHOD="Payment Method" +VMPAYMENT_METHOD_DESC="Lock to some payment method(s). Multiple card types allowed by comma separation" + +VMPAYMENT_BRANDING_ID="Branding ID" +VMPAYMENT_BRANDING_ID_DESC="Use this branding. Overwrites the default branding" + +VMPAYMENT_GOOGLE_ANALYTICS_TRACKING_ID="Google Analytics Tracking ID" +VMPAYMENT_GOOGLE_ANALYTICS_TRACKING_ID_DESC="Your Google Analytics tracking ID" + +VMPAYMENT_GOOGLE_ANALYTICS_CLIENT_ID="Google Analytics Client ID" +VMPAYMENT_GOOGLE_ANALYTICS_CLIENT_ID_DESC="Your Google Analytics client ID" + +VMPAYMENT_PAII_PRODUCT_ID="Paii Product ID" +VMPAYMENT_PAII_PRODUCT_ID_DESC="The Paii product ID (P03 or P08 typcial)" + +VMPAYMENT_PAII_CATEGORY="Paii Category" +VMPAYMENT_PAII_CATEGORY_DESC="The category products are selled for" + + +VMPAYMENT_QUICKPAY_MD5="MD5 secret" +VMPAYMENT_QUICKPAY_MD5_DESC="The MD5 secret which can be found in the Quickpay Manager under Settings.MD5 secret." + +VMPAYMENT_QUICKPAY_PAYMENT_WINDOW_API_KEY="API Key" +VMPAYMENT_QUICKPAY_PAYMENT_WINDOW_API_KEY_DESC="The API key from Quickpay" + +VMPAYMENT_QUICKPAY_PAYMENT_WINDOW_PRIVATE_KEY="Private Key" +VMPAYMENT_QUICKPAY_PAYMENT_WINDOW_PRIVATE_KEY_DESC="Private Key from Quickpay" + +VMPAYMENT_QUICKPAY_AUTOCAPTURE="Autocapture" +VMPAYMENT_QUICKPAY_AUTOCAPTURE_DESC="If set, the payment will be captured automatically" + +VMPAYMENT_QUICKPAY_SPLITPAYMENT="Splitpayment" +VMPAYMENT_QUICKPAY_SPLITPAYMENT_DESC="Enable split payment on transaction" + +VMPAYMENT_QUICKPAY_AUTOFEE="Autofee" +VMPAYMENT_QUICKPAY_AUTOFEE_DESC="If set the fee charged by the acquirer will be calculated and added to the transaction amount" + +VMPAYMENT_QUICKPAY_CARDTYPELOCK="Cardtypelock" +VMPAYMENT_QUICKPAY_CARDTYPELOCK_DESC="Lock payment to one or more payment methods. In doubt leave blank, or look at http://quickpay.net/features/cardtypelock/" + +VMPAYMENT_QUICKPAY_STATUS_PENDING="Order Status for Pending transactions" +VMPAYMENT_QUICKPAY_STATUS_PENDING_DESC="Select an order status for Pending Quickpay transactions." +VMPAYMENT_QUICKPAY_STATUS_SUCCESS="Order Status for Successful transactions" +VMPAYMENT_QUICKPAY_STATUS_SUCCESS_DESC="Select the order status to which the actual order is set, if the transaction from Quickpay was successful. If using download selling options: select the status which enables the download (then the customer is instantly notified about the download via e-mail)." +VMPAYMENT_QUICKPAY_STATUS_FAILED="Order Status for Failed transactions" +VMPAYMENT_QUICKPAY_STATUS_FAILED_DESC="Select an order status for Failed Quickpay transactions." + + +VMPAYMENT_QUICKPAY_TESTMODE="Testmode" +VMPAYMENT_QUICKPAY_TESTMODE_DESC="When enabled Quickpay will handle transactions as test only, even if Quickpay is in production mode." + + +VMPAYMENT_QUICKPAY_ERROR_EMAIL_SUBJECT="Error: No order id" +VMPAYMENT_QUICKPAY_UNKNOW_ORDER_ID="Unknown order id" + +VMPAYMENT_QUICKPAY_PAYMENT_CONFIRMED="Your payment for order %s has been confirmed by Quickpay" + +VMPAYMENT_PAYMENT_NAME="Payment name" +VMPAYMENT_QUICKPAY_TIME="Time" +VMPAYMENT_QUICKPAY_STATE="State" +VMPAYMENT_QUICKPAY_QPSTAT="Qpstat" +VMPAYMENT_QUICKPAY_QPSTATMSG="Qpstat message" +VMPAYMENT_QUICKPAY_CHSTAT="Chstat message" +VMPAYMENT_QUICKPAY_CHSTATMSG="Chstat message" +VMPAYMENT_QUICKPAY_TRANSACTION="Transaction" +VMPAYMENT_QUICKPAY_CARDTYPE="Cardtype" +VMPAYMENT_QUICKPAY_CARDNUMBER="Card number" +VMPAYMENT_QUICKPAY_FRAUDPROBABILITY="Fraud probability" +VMPAYMENT_QUICKPAY_FRAUDREMARKS="Fraud remarks" +VMPAYMENT_QUICKPAY_FRAUDREPORT="Fraud report" +VMPAYMENT_QUICKPAY_FEE="Fee" +VMPAYMENT_QUICKPAY_PAYMENT_ID="Payment ID" + +VMPAYMENT_QUICKPAY_PREFIX="Order Prefix" +VMPAYMENT_QUICKPAY_PREFIX_DESC="This prefix is appended to the beginning of the order id when it is sent to Quickpay." + +VMPAYMENT_QUICKPAY_THIRDPARTYAPI="Third party api url" +VMPAYMENT_QUICKPAY_THIRDPARTYAPI_DESC="Third party api url, on succesful payment data is forwarded to external http service, use tags [ORDER_NUMBER], [TRANSACTION_ID] and [PAYMENT_METHOD_ID]. Leave field empty, if no integration is needed." + +VMPAYMENT_QUICKPAY_ROUNDORDER="Round order total" +VMPAYMENT_QUICKPAY_ROUNDORDER_DESC="Rounds the order total to nearest integer, can be used in combination with external systems, where rounding is different. If you are unsure, do not enable this function." + + diff --git a/en-GB.plg_vmpayment_quickpay.sys.ini b/en-GB.plg_vmpayment_quickpay.sys.ini new file mode 100644 index 0000000..b8f20b8 --- /dev/null +++ b/en-GB.plg_vmpayment_quickpay.sys.ini @@ -0,0 +1,8 @@ +; @date : $Date$ +; @Id $Id$ +; @Revision : $Revision$ +; @author info@stokersoft.com +; @package VMPayment +; @subpackage VirtueMart payment Quickpay + +VMPAYMENT_QUICKPAY="Vm Payment plugin Quickpay" \ No newline at end of file diff --git a/quickpay.php b/quickpay.php new file mode 100644 index 0000000..f23d4a9 --- /dev/null +++ b/quickpay.php @@ -0,0 +1,813 @@ +_loggable = true; + $this->tableFields = array_keys($this->getTableSQLFields()); + $this->_tablepkey = 'id'; + $this->_tableId = 'id'; + $varsToPush = $this->getVarsToPush(); + $this->setConfigParameterable($this->_configTableFieldName, $varsToPush); + } + + function getTableSQLFields() + { + $SQLfields = array('id' => 'int(1) UNSIGNED NOT NULL AUTO_INCREMENT', + 'virtuemart_order_id' => 'int(1) UNSIGNED', 'order_number' => 'char(64)', + 'virtuemart_paymentmethod_id' => 'mediumint(1) UNSIGNED', 'payment_name' => + 'varchar(5000)', 'payment_order_total' => 'decimal(15,5) NOT NULL DEFAULT \'0.00000\'', + 'payment_currency' => 'char(3)', 'cost_per_transaction' => 'decimal(10,2)', + 'cost_percent_total' => 'decimal(10,2)', 'tax_id' => 'smallint(1)', + 'quickpay_time' => 'char(13)', 'quickpay_state' => 'char(10)', 'quickpay_qpstat' => + 'char(10)', 'quickpay_qpstatmsg' => 'char(50)', 'quickpay_chstat' => 'char(5)', + 'quickpay_chstatmsg' => 'char(50)', + 'quickpay_cardtype' => 'char(32)', + 'quickpay_payment_id' => 'char(32)', + 'quickpay_fraudprobability' => 'char(32)', 'quickpay_fraudremarks' => 'char(32)', + 'quickpay_fraudreport' => 'char(32)'); + return $SQLfields; + } + + function qpSign($params, $api_key) + { + ksort($params); + $base = ""; + foreach ($params as $key => $value) { + if ($key != 'checksum') { // Remove the checksum field from the hash calculation + $base .= $value . " "; + } + }; + $base = substr($base, 0, -1); + return hash_hmac("sha256", $base, $api_key); + } + + /** + * Prepare the quickpay payment link + * + * @param $cart + * @param $order + * @return mixed + */ + function plgVmConfirmedOrder($cart, $order) + { + if (!($method = $this->getVmPluginMethod($order['details']['BT']->virtuemart_paymentmethod_id))) { + return null; // Another method was selected, do nothing + } + if (!$this->selectedThisElement($method->payment_element)) { + return false; + } + $session = JFactory::getSession(); + $return_context = $session->getId(); + $this->_debug = $method->debug; + $this->logInfo('plgVmConfirmedOrder order number: ' . $order['details']['BT']-> + order_number, 'message'); + + if (!class_exists('VirtueMartModelOrders')) { + require(JPATH_VM_ADMINISTRATOR . DS . 'models' . DS . 'orders.php'); + } + + if (!class_exists('VirtueMartModelCurrency')) { + require(JPATH_VM_ADMINISTRATOR . DS . 'models' . DS . 'currency.php'); + } + + $new_status = ''; + + $vat_tax = $order['details']['BT']->order_tax; + + $vendorModel = new VirtueMartModelVendor(); + $vendorModel->setId(1); + $this->getPaymentCurrency($method); + $q = 'SELECT `currency_code_3` FROM `#__virtuemart_currencies` WHERE `virtuemart_currency_id`="' . $method->payment_currency . '" '; + $db = &JFactory::getDBO(); + $db->setQuery($q); + $currency_code_3 = $db->loadResult(); + + $paymentCurrency = CurrencyDisplay::getInstance($method->payment_currency); + $totalInPaymentCurrency = round($paymentCurrency->convertCurrencyTo($method->payment_currency, $order['details']['BT']->order_total, false), 2); + $cd = CurrencyDisplay::getInstance($cart->pricesCurrency); + + $prefix = $method->prefix; + if ($prefix) { + if (strlen($prefix.$order['details']['BT']->virtuemart_order_id) < 4) { + $order_number = $prefix . str_pad($order['details']['BT']->virtuemart_order_id, 4, '0', STR_PAD_LEFT); + } else { + $order_number = $prefix . $order['details']['BT']->virtuemart_order_id; + } + } else { + $order_number = str_pad($order['details']['BT']->virtuemart_order_id, 4, '0', STR_PAD_LEFT); + } + + // Now round the amount if requested from the configuration + if ($method->quickpay_round_order_amount == 1) { + $roundedAmount = 100 * round($totalInPaymentCurrency); + } else { + $roundedAmount = 100 * $totalInPaymentCurrency; + } + + // Keep the same language after payment/cancel + $lang = JFactory::getLanguage(); + $lang_code_explode = explode("-", $lang->getTag()); + $lang_code = strtolower($lang_code_explode[1]); + + $post_variables = Array( + 'agreement_id' => $method->quickpay_agreement_id, // Read from configuration + 'amount' => $roundedAmount, + 'continueurl' => JROUTE::_(JURI::root() . 'index.php?option=com_virtuemart&view=pluginresponse&task=pluginresponsereceived&pm=' . $order['details']['BT']->virtuemart_paymentmethod_id . '&ordernumber=' . $order['details']['BT']->order_number), + 'cancelurl' => JROUTE::_(JURI::root() . 'index.php?option=com_virtuemart&view=pluginresponse&task=pluginUserPaymentCancel&on=' . $order['details']['BT']->order_number . '&pm=' . $order['details']['BT']->virtuemart_paymentmethod_id . '&lang=' . $lang_code), + 'callbackurl' => JROUTE::_(JURI::root() . 'index.php?option=com_virtuemart&view=pluginresponse&task=pluginnotification&tmpl=component&sessionid=' . $session->getId() . '&pm=' . $order['details']['BT']->virtuemart_paymentmethod_id . '&lang=' . $lang_code), + 'language' => $this->resolveQuickpayLang(), + 'autocapture' => $method->quickpay_autocapture, + 'autofee' => $method->quickpay_autofee, + 'payment_methods' => $method->quickpay_cardtypelock, // read from configuration + 'branding_id' => $method->quickpay_branding_id, // Read from configuration + 'google_analytics_tracking_id' => $method->quickpay_google_analytics_tracking_id, // read from configuration + 'google_analytics_client_id' => $method->quickpay_google_analytics_client_id, // read from configuration + 'vat_amount' => 100 * $vat_tax, // paii... calculate it from order + 'product_id' => $method->quickpay_paii_product_id, // read from configuration + 'category' => $method->quickpay_paii_category, // read from configuration paii category + 'reference_title' => JURI::root() . '-' . $order_number, // read from configuration, paii related, see drupal module how we set this + ); + + $helper = new QuickpayHelper(); + $helper->setApiKey($method->quickpay_md5_key); + $id = $helper->qpCreatePayment($order_number, $currency_code_3); + $result = $helper->qpCreatePaymentLink($id->id, $post_variables); + $paymentUrl = $result->url; + + // Prepare data that should be stored in the database + $dbValues['order_number'] = $order['details']['BT']->order_number; + $dbValues['payment_name'] = $this->renderPluginName($method, $order); + $dbValues['virtuemart_paymentmethod_id'] = $cart->virtuemart_paymentmethod_id; + $dbValues['cost_per_transaction'] = $method->cost_per_transaction; + $dbValues['cost_percent_total'] = $method->cost_percent_total; + $dbValues['payment_currency'] = $method->payment_currency; + $dbValues['payment_order_total'] = $totalInPaymentCurrency; + $dbValues['tax_id'] = $method->tax_id; + $dbValues['quickpay_payment_id'] = $id->id; + $this->storePSPluginInternalData($dbValues); + + $html = ' '; + + // 2 = don't delete the cart, don't send email and don't redirect + return $this->processConfirmedOrderPaymentResponse(2, $cart, $order, $html, $new_status); + } + + /* + * Sign the parameters with api key using sha256 + */ + + function plgVmgetPaymentCurrency($virtuemart_paymentmethod_id, &$paymentCurrencyId) + { + if (!($method = $this->getVmPluginMethod($virtuemart_paymentmethod_id))) { + return null; // Another method was selected, do nothing + } + if (!$this->selectedThisElement($method->payment_element)) { + return false; + } + $this->getPaymentCurrency($method); + $paymentCurrencyId = $method->payment_currency; + } + + function plgVmOnPaymentResponseReceived(&$html) + { + // the payment itself should send the parameter needed. + $virtuemart_paymentmethod_id = JFactory::getApplication()->input->getInt('pm', 0); + + $vendorId = 0; + if (!($method = $this->getVmPluginMethod($virtuemart_paymentmethod_id))) { + return null; // Another method was selected, do nothing + } + if (!$this->selectedThisElement($method->payment_element)) { + return false; + } + + $payment_data = JFactory::getApplication()->input->get('get'); + vmdebug('plgVmOnPaymentResponseReceived', $payment_data); + $order_number = $payment_data['ordernumber']; + + if (!class_exists('VirtueMartModelOrders')) { + require(JPATH_VM_ADMINISTRATOR . DS . 'models' . DS . 'orders.php'); + } + + $payment_name = $this->renderPluginName($method); + $html = ""; // Here we could add some Quickpay status info, but we do not, but it can easily be extended, order is ready + + //We delete the old stuff + if (!class_exists('VirtueMartCart')) + require(JPATH_VM_SITE . DS . 'helpers' . DS . 'cart.php'); + $cart = VirtueMartCart::getCart(); + $cart->emptyCart(); + + return true; + } + + function plgVmOnUserPaymentCancel() + { + if (!class_exists('VirtueMartModelOrders')) { + require(JPATH_VM_ADMINISTRATOR . DS . 'models' . DS . 'orders.php'); + } + + $order_number = JFactory::getApplication()->input->getVar('on'); + if (!$order_number) { + return false; + } + $db = JFactory::getDBO(); + + $virtuemart_paymentmethod_id = JFactory::getApplication()->input->getInt('pm', 0); + if (!($method = $this->getVmPluginMethod($virtuemart_paymentmethod_id))) { + return null; // Another method was selected, do nothing + } + ////////////////////////////////////remove prefix from ordernumber/////////////////// + $prefix = $method->prefix; + if (preg_match('/' . $prefix . '/', $order_number)) { + $order_number = str_replace($prefix, '', $order_number); + } + $order_number = intval($order_number); + //////////////////////////////////////////////////////////////////////////// + + $query = 'SELECT ' . $this->_tablename . '.`virtuemart_order_id` FROM ' . $this-> + _tablename . " WHERE `order_number`= '" . $order_number . "'"; + + $db->setQuery($query); + $virtuemart_order_id = $db->loadResult(); + + if (!$virtuemart_order_id) { + return null; + } + $this->handlePaymentUserCancel($virtuemart_order_id); + + //JRequest::setVar('paymentResponse', $returnValue); + return true; + } + + /** + * Triggered by the Quickpay callback + * Return: + * Parameters: + * None + */ + function plgVmOnPaymentNotification() + { + if (!class_exists('VirtueMartModelOrders')) { + require(JPATH_VM_ADMINISTRATOR . DS . 'models' . DS . 'orders.php'); + } + $virtuemart_paymentmethod_id = JFactory::getApplication()->input->getInt('pm', 0); + if (!($method = $this->getVmPluginMethod($virtuemart_paymentmethod_id))) { + return null; // Another method was selected, do nothing + } + + $requestBody = file_get_contents("php://input"); + $callbackDataGet = JFactory::getApplication()->input->get('get'); + $request = json_decode($requestBody); + + // If someone calls us by accident, bail out + if (empty($request->operations)) { + return null; + } + + $operation = end($request->operations); + $order_number = $request->order_id; + + if ($operation->type != 'authorize') { + $this->logInfo('Not an authorize callback'); + return null; // Another method was selected or another callback than authorize triggered, do nothing + } + + // Check checksum + $key = $method->quickpay_private_key; + $checksum = hash_hmac("sha256", $requestBody, $key); + if ($checksum != $_SERVER["HTTP_QUICKPAY_CHECKSUM_SHA256"]) { + $this->logInfo('Bad callback checksum', 'ERROR'); + return null; + } + + // Remove prefix from ordernumber + $prefix = $method->prefix; + if (isset($prefix)) { + $order_number = substr($order_number, strlen($prefix)); + } + + $order_number = intval($order_number); + $virtuemart_order_id = $order_number; + + if (!$virtuemart_order_id) { + return; + } + + $vendorId = 0; + $payment = $this->getDataByOrderId($virtuemart_order_id); + + $method = $this->getVmPluginMethod($payment->virtuemart_paymentmethod_id); + if (!$this->selectedThisElement($method->payment_element)) { + return false; + } + + if (!$payment) { + $this->logInfo('getDataByOrderId payment not found: exit ', 'ERROR'); + return null; + } + + $post_msg = ''; + + $this->updateDbValues($virtuemart_order_id, $payment->virtuemart_paymentmethod_id, $request); + + + if ($request->accepted && $operation->qp_status_code == "20000") { + $new_status = $method->status_success; + $this->logInfo('process OK, status', 'message'); + + // Update any payment fee + $db = JFactory::getDbo(); + $query = $db->getQuery(true); + $query->select('order_total')->from($db->quoteName('#__virtuemart_orders'))->where($db->quoteName('virtuemart_order_id') . '=' . $virtuemart_order_id); + $db->setQuery($query); + $oldOrderTotal = $db->loadResult(); + $oldOrderTotal *= 100.0; + $fee = $operation->amount - $oldOrderTotal; + if ($fee > 0) { + $quickPayFee = $fee / 100.0; + $db = JFactory::getDBO(); + $query = "update #__virtuemart_orders SET order_payment=" . $quickPayFee . ",order_total = order_total+$quickPayFee WHERE virtuemart_order_id=" . $virtuemart_order_id . " AND order_payment = 0"; + $db->setQuery($query); + $db->query(); + } + } else { + $this->logInfo('process ERROR', 'ERROR'); + $new_status = $method->status_canceled; + } + + $this->logInfo('plgVmOnPaymentNotification return new_status:' . $new_status, 'message'); + $this->logInfo('plgVmOnPaymentNotification session:', $return_context); + + $modelOrder = VmModel::getModel('orders'); + $order = array(); + $order['order_status'] = $new_status; + $order['customer_notified'] = 1; + $modelOrder->updateStatusForOneOrder($virtuemart_order_id, $order, true); + + $this->logInfo('Notification, sentOrderConfirmedEmail ' . $order_number . ' ' . $new_status, 'message'); //// remove vmcart + $this->emptyCart($return_context); + + // Now notify any third party services + if ($method->quickpay_thirdpartyapi != '' && $request->accepted && $operation->qp_status_code == "20000") { + $apiurl = $method->quickpay_thirdpartyapi; + + $lang = JFactory::getLanguage(); + $lang_code_explode = explode("-", $lang->getTag()); + $lang_code = strtolower($lang_code_explode[1]); + + $apiurl = str_replace('[LANGUAGE]', $lang_code, $apiurl); + $apiurl = str_replace('[ORDER_ID]', $virtuemart_order_id, $apiurl); + $apiurl = str_replace('[TRANSACTION_ID]', $request->id, $apiurl); + $apiurl = str_replace('[PAYMENT_METHOD_ID]', $payment->virtuemart_paymentmethod_id, $apiurl); + + $ch = curl_init(); + curl_setopt($ch, CURLOPT_URL, $apiurl); + curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); // Important for HTTPS + curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); + $output = curl_exec($ch); + curl_close($ch); + } + } + + public function plgVmOnUpdateOrderPayment(&$order, $old_order_status) + { + if (!$this->selectedThisByMethodId($order->virtuemart_paymentmethod_id)) { + return null; // Another method was selected, do nothing + } + $method = $this->getVmPluginMethod($order->virtuemart_paymentmethod_id); + + if ($order->order_status == 'R') { + $db = JFactory::getDBO(); + $q = 'SELECT * FROM `' . $this->_tablename . '` ' . + 'WHERE `virtuemart_order_id` = ' . $order->virtuemart_order_id; + $db->setQuery($q); + if (!($paymentTable = $db->loadObject())) { + return ''; + } + if(!$paymentTable->quickpay_payment_id){ + return ''; + } + + $paymentCurrency = CurrencyDisplay::getInstance($method->payment_currency); + $totalInPaymentCurrency = round($paymentCurrency->convertCurrencyTo($method->payment_currency, $order->order_total, false), 2); + if ($method->quickpay_round_order_amount == 1) { + $roundedAmount = 100 * round($totalInPaymentCurrency); + } else { + $roundedAmount = 100 * $totalInPaymentCurrency; + } + $helper = new QuickpayHelper(); + $helper->setApiKey($method->quickpay_md5_key); + try { + $result = $helper->qpRefund($paymentTable->quickpay_payment_id, $roundedAmount); + $this->updateDbValues($order->virtuemart_order_id, $order->virtuemart_paymentmethod_id, $result); + } catch (Exception $e){ + + } + return true; + } else if(($order->order_status == 'S' || $order->order_status == 'F') && !$method->quickpay_autocapture){ + $db = JFactory::getDBO(); + $q = 'SELECT * FROM `' . $this->_tablename . '` ' . + 'WHERE `virtuemart_order_id` = ' . $order->virtuemart_order_id; + $db->setQuery($q); + if (!($paymentTable = $db->loadObject())) { + return ''; + } + if(!$paymentTable->quickpay_payment_id && $paymentTable->quickpay_state == 'new'){ + return ''; + } + $paymentCurrency = CurrencyDisplay::getInstance($method->payment_currency); + $totalInPaymentCurrency = round($paymentCurrency->convertCurrencyTo($method->payment_currency, $order->order_total, false), 2); + if ($method->quickpay_round_order_amount == 1) { + $roundedAmount = 100 * round($totalInPaymentCurrency); + } else { + $roundedAmount = 100 * $totalInPaymentCurrency; + } + $helper = new QuickpayHelper(); + $helper->setApiKey($method->quickpay_md5_key); + try { + $result = $helper->qpCapture($paymentTable->quickpay_payment_id, $roundedAmount); + $this->updateDbValues($order->virtuemart_order_id, $order->virtuemart_paymentmethod_id, $result); + } catch (Exception $e){ + + } + + return true; + } + return true; + } + + protected function updateDbValues($virtuemart_order_id, $virtuemart_paymentmethod_id, $resultData){ + $response_fields = []; + $response_fields['virtuemart_order_id'] = $virtuemart_order_id; + $response_fields['virtuemart_paymentmethod_id'] = $virtuemart_paymentmethod_id; + + $operation = end($resultData->operations); + + $response_fields['quickpay_qpstatmsg'] = $operation->qp_status_msg; + $response_fields['quickpay_qpstat'] = $operation->qp_status_code; + $response_fields['quickpay_time'] = date('h:i:s', strtotime($operation->created_at)); + $response_fields['quickpay_chstat'] = $operation->aq_status_code; + $response_fields['quickpay_chstatmsg'] = $operation->aq_status_msg; + $response_fields['quickpay_chstatmsg'] = $operation->aq_status_msg; + $response_fields['quickpay_state'] = ucfirst($resultData->state); + $response_fields['quickpay_cardtype'] = $resultData->metadata->brand; + $method = $this->getVmPluginMethod($virtuemart_paymentmethod_id); + $response_fields['payment_name'] = $this->renderPluginName($method); + $response_fields['quickpay_payment_id'] = $resultData->id; + $response_fields['quickpay_fraudprobability'] = $resultData->metadata->fraud_suspected; + + $this->storePSPluginInternalData($response_fields, 'virtuemart_order_id', 1); + } + + /** + * Display stored payment data for an order + * @see components/com_virtuemart/helpers/vmPSPlugin::plgVmOnShowOrderBEPayment() + */ + function plgVmOnShowOrderBEPayment($virtuemart_order_id, $payment_method_id) + { + if (!$this->selectedThisByMethodId($payment_method_id)) { + return null; // Another method was selected, do nothing + } + + $db = JFactory::getDBO(); + $q = 'SELECT * FROM `' . $this->_tablename . '` ' . + 'WHERE `virtuemart_order_id` = ' . $virtuemart_order_id; + $db->setQuery($q); + if (!($paymentTable = $db->loadObject())) { + return ''; + } + $this->getPaymentCurrency($paymentTable); + $q = 'SELECT `currency_code_3` FROM `#__virtuemart_currencies` WHERE `virtuemart_currency_id`="' . + $paymentTable->payment_currency . '" '; + $db = &JFactory::getDBO(); + $db->setQuery($q); + $currency_code_3 = $db->loadResult(); + $html = '