ogone_directlink_cc.php

来自「this the oscommerce 3.0 aplha 4」· PHP 代码 · 共 366 行 · 第 1/2 页

PHP
366
字号
      $Qorder = $osC_Database->query('select transaction_return_value from :table_orders_transactions_history where orders_id = :orders_id and transaction_code = 1 order by date_added limit 1');      $Qorder->bindTable(':table_orders_transactions_history', TABLE_ORDERS_TRANSACTIONS_HISTORY);      $Qorder->bindInt(':orders_id', $id);      $Qorder->execute();      if ($Qorder->numberOfRows() === 1) {        $osC_XML = new osC_XML($Qorder->value('transaction_return_value'));        $result_array = $osC_XML->toArray();        $params = array('PSPID' => MODULE_PAYMENT_OGONE_DIRECTLINK_CC_MERCHANT_ID,                        'PSWD' => MODULE_PAYMENT_OGONE_DIRECTLINK_CC_PASSWORD,                        'PAYID' => $result_array['ncresponse attr']['PAYID'],                        'OPERATION' => 'SAS');        if (osc_empty(MODULE_PAYMENT_OGONE_DIRECTLINK_CC_USER_ID) === false) {          $params['USERID'] = MODULE_PAYMENT_OGONE_DIRECTLINK_CC_USER_ID;        }        $post_string = '';        foreach ($params as $key => $value) {          $post_string .= $key . '=' . urlencode($value) . '&';        }        $post_string = substr($post_string, 0, -1);        $result = osC_Payment::sendTransactionToGateway($this->_maintenance_gateway_url, $post_string);        if (empty($result) === false) {          $osC_XML = new osC_XML($result);          $result_array = $osC_XML->toArray();          switch ($result_array['ncresponse attr']['STATUS']) {            case '':            case '0':              $transaction_return_status = '0';              break;            default:              $transaction_return_status = '1';              break;          }          $Qtransaction = $osC_Database->query('insert into :table_orders_transactions_history (orders_id, transaction_code, transaction_return_value, transaction_return_status, date_added) values (:orders_id, :transaction_code, :transaction_return_value, :transaction_return_status, now())');          $Qtransaction->bindTable(':table_orders_transactions_history', TABLE_ORDERS_TRANSACTIONS_HISTORY);          $Qtransaction->bindInt(':orders_id', $id);          $Qtransaction->bindInt(':transaction_code', 3);          $Qtransaction->bindValue(':transaction_return_value', $result);          $Qtransaction->bindInt(':transaction_return_status', $transaction_return_status);          $Qtransaction->execute();        }      }    }/** * Cancels the transaction at the gateway server * * @access public * @param $id The ID of the order */    function cancelTransaction($id) {      global $osC_Database;      $Qorder = $osC_Database->query('select transaction_return_value from :table_orders_transactions_history where orders_id = :orders_id and transaction_code = 1 order by date_added limit 1');      $Qorder->bindTable(':table_orders_transactions_history', TABLE_ORDERS_TRANSACTIONS_HISTORY);      $Qorder->bindInt(':orders_id', $id);      $Qorder->execute();      if ($Qorder->numberOfRows() === 1) {        $osC_XML = new osC_XML($Qorder->value('transaction_return_value'));        $result_array = $osC_XML->toArray();        $params = array('PSPID' => MODULE_PAYMENT_OGONE_DIRECTLINK_CC_MERCHANT_ID,                        'PSWD' => MODULE_PAYMENT_OGONE_DIRECTLINK_CC_PASSWORD,                        'PAYID' => $result_array['ncresponse attr']['PAYID'],                        'OPERATION' => 'DES');        if (osc_empty(MODULE_PAYMENT_OGONE_DIRECTLINK_CC_USER_ID) === false) {          $params['USERID'] = MODULE_PAYMENT_OGONE_DIRECTLINK_CC_USER_ID;        }        $post_string = '';        foreach ($params as $key => $value) {          $post_string .= $key . '=' . urlencode($value) . '&';        }        $post_string = substr($post_string, 0, -1);        $result = osC_Payment::sendTransactionToGateway($this->_maintenance_gateway_url, $post_string);        if (empty($result) === false) {          $osC_XML = new osC_XML($result);          $result_array = $osC_XML->toArray();          switch ($result_array['ncresponse attr']['STATUS']) {            case '':            case '0':              $transaction_return_status = '0';              break;            default:              $transaction_return_status = '1';              break;          }          $Qtransaction = $osC_Database->query('insert into :table_orders_transactions_history (orders_id, transaction_code, transaction_return_value, transaction_return_status, date_added) values (:orders_id, :transaction_code, :transaction_return_value, :transaction_return_status, now())');          $Qtransaction->bindTable(':table_orders_transactions_history', TABLE_ORDERS_TRANSACTIONS_HISTORY);          $Qtransaction->bindInt(':orders_id', $id);          $Qtransaction->bindInt(':transaction_code', 2);          $Qtransaction->bindValue(':transaction_return_value', $result);          $Qtransaction->bindInt(':transaction_return_status', $transaction_return_status);          $Qtransaction->execute();        }      }    }/** * Send a status enquiry of the transaction to the gateway server * * @access public * @param $id The ID of the order */    function inquiryTransaction($id) {      global $osC_Database;      $Qorder = $osC_Database->query('select transaction_return_value from :table_orders_transactions_history where orders_id = :orders_id and transaction_code = 1 order by date_added limit 1');      $Qorder->bindTable(':table_orders_transactions_history', TABLE_ORDERS_TRANSACTIONS_HISTORY);      $Qorder->bindInt(':orders_id', $id);      $Qorder->execute();      if ($Qorder->numberOfRows() === 1) {        $osC_XML = new osC_XML($Qorder->value('transaction_return_value'));        $result_array = $osC_XML->toArray();        $params = array('PSPID' => MODULE_PAYMENT_OGONE_DIRECTLINK_CC_MERCHANT_ID,                        'PSWD' => MODULE_PAYMENT_OGONE_DIRECTLINK_CC_PASSWORD,                        'PAYID' => $result_array['ncresponse attr']['PAYID']);        if (osc_empty(MODULE_PAYMENT_OGONE_DIRECTLINK_CC_USER_ID) === false) {          $params['USERID'] = MODULE_PAYMENT_OGONE_DIRECTLINK_CC_USER_ID;        }        $post_string = '';        foreach ($params as $key => $value) {          $post_string .= $key . '=' . urlencode($value) . '&';        }        $post_string = substr($post_string, 0, -1);        $result = osC_Payment::sendTransactionToGateway($this->_inquiry_gateway_url, $post_string);        if (empty($result) === false) {          $osC_XML = new osC_XML($result);          $result_array = $osC_XML->toArray();          switch ($result_array['ncresponse attr']['STATUS']) {            case '':            case '0':              $transaction_return_status = '0';              break;            default:              $transaction_return_status = '1';              break;          }          $Qtransaction = $osC_Database->query('insert into :table_orders_transactions_history (orders_id, transaction_code, transaction_return_value, transaction_return_status, date_added) values (:orders_id, :transaction_code, :transaction_return_value, :transaction_return_status, now())');          $Qtransaction->bindTable(':table_orders_transactions_history', TABLE_ORDERS_TRANSACTIONS_HISTORY);          $Qtransaction->bindInt(':orders_id', $id);          $Qtransaction->bindInt(':transaction_code', 4);          $Qtransaction->bindValue(':transaction_return_value', $result);          $Qtransaction->bindInt(':transaction_return_status', $transaction_return_status);          $Qtransaction->execute();        }      }    }  }?>

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?