[phpBB Debug] PHP Warning: in file [ROOT]/includes/crs/crs_misc_functions.php on line 37: mime_content_type(): Empty filename or path
[phpBB Debug] PHP Warning: in file [ROOT]/includes/crs/crs_misc_functions.php on line 37: mime_content_type(): Empty filename or path
Zen Cart 源代码 paypal.php

Zen Cart 源代码 paypal.php




下载文件

文件名: paypal.php
文件类型: PHP文件
文件大小: 13.45 KiB
MD5: afddbf014c69380338d60d5c29eda36e

paypal.php - 关闭高亮
  1. <?php
  2. /**
  3.  * @package admin
  4.  * @copyright Copyright 2003-2011 Zen Cart Development Team
  5.  * @copyright Portions Copyright 2003 osCommerce
  6.  * @copyright Portions Copyright (c) 2004 DevosC.com    
  7.  * @license http://www.zen-cart.com/license/2_0.txt GNU Public License V2.0
  8.  * @version $Id: paypal.php 18799 2011-05-25 12:29:41Z wilt $
  9.  */
  10.  
  11.   require('includes/application_top.php');
  12.  
  13.   $paypal_ipn_sort_order_array = array(array('id' => '0', 'text' => TEXT_SORT_PAYPAL_ID_DESC),
  14.                              array('id' => '1', 'text' => TEXT_SORT_PAYPAL_ID),
  15.                              array('id' => '2', 'text' => TEXT_SORT_ZEN_ORDER_ID_DESC),
  16.                              array('id' => '3', 'text'=> TEXT_SORT_ZEN_ORDER_ID),
  17.                              array('id' => '4', 'text'=> TEXT_PAYMENT_AMOUNT_DESC),
  18.                              array('id' => '5', 'text'=> TEXT_PAYMENT_AMOUNT)
  19.                              );
  20.  
  21.   if (isset($_GET['paypal_ipn_sort_order'])) {
  22.     $paypal_ipn_sort_order = $_GET['paypal_ipn_sort_order'];
  23.   } else {
  24.     $paypal_ipn_sort_order = 0;
  25.   }
  26. //        $ipn_query_raw = "select p.order_id, p.paypal_ipn_id, p.txn_type, p.payment_type, p.payment_status, p.pending_reason, p.mc_currency, p.payer_status, p.mc_currency, p.date_added, p.mc_gross, p.first_name, p.last_name, p.payer_business_name, p.parent_txn_id, p.txn_id from " . TABLE_PAYPAL . " as p, " .TABLE_ORDERS . " as o  where o.orders_id = p.order_id " . $ipn_search . " order by o.orders_id DESC";
  27.  
  28.   switch ($paypal_ipn_sort_order) {
  29.     case (0):
  30.       $order_by = " order by p.paypal_ipn_id DESC";
  31.       break;
  32.     case (1):
  33.       $order_by = " order by p.paypal_ipn_id";
  34.       break;
  35.     case (2):
  36.       $order_by = " order by p.order_id DESC, p.paypal_ipn_id";
  37.       break;
  38.     case (3):
  39.       $order_by = " order by p.order_id, p.paypal_ipn_id";
  40.       break;
  41.     case (4):
  42.       $order_by = " order by p.mc_gross DESC";
  43.       break;
  44.     case (5):
  45.       $order_by = " order by p.mc_gross";
  46.       break;
  47.     default:
  48.       $order_by = " order by p.paypal_ipn_id DESC";
  49.       break;
  50.     }
  51.  
  52.   $action = (isset($_GET['action']) ? $_GET['action'] : '');
  53.   $selected_status = (isset($_GET['payment_status']) ? $_GET['payment_status'] : '');
  54.  
  55.   require(DIR_FS_CATALOG_MODULES . 'payment/paypal.php');
  56.  
  57.   $payment_statuses = array();
  58.   $payment_status_trans = $db->Execute("select payment_status_name as payment_status from " . TABLE_PAYPAL_PAYMENT_STATUS );
  59.   while (!$payment_status_trans->EOF) {
  60.     $payment_statuses[] = array('id' => $payment_status_trans->fields['payment_status'],
  61.                                 'text' => $payment_status_trans->fields['payment_status']);
  62.     $payment_status_trans->MoveNext();
  63.   }
  64.  
  65. ?>
  66. <!doctype html public "-//W3C//DTD HTML 4.01 Transitional//EN">
  67. <html <?php echo HTML_PARAMS; ?>>
  68. <head>
  69. <meta http-equiv="Content-Type" content="text/html; charset=<?php echo CHARSET; ?>">
  70. <title><?php echo TITLE; ?></title>
  71. <link rel="stylesheet" type="text/css" href="includes/stylesheet.css">
  72. <link rel="stylesheet" type="text/css" href="includes/cssjsmenuhover.css" media="all" id="hoverJS">
  73. <script language="javascript" src="includes/menu.js"></script>
  74. <script language="javascript" src="includes/general.js"></script>
  75. <script type="text/javascript">
  76.   <!--
  77.   function init()
  78.   {
  79.     cssjsmenu('navbar');
  80.     if (document.getElementById)
  81.     {
  82.       var kill = document.getElementById('hoverJS');
  83.       kill.disabled = true;
  84.     }
  85.   }
  86.   // -->
  87. </script>
  88. </head>
  89. <body marginwidth="0" marginheight="0" topmargin="0" bottommargin="0" leftmargin="0" rightmargin="0" bgcolor="#FFFFFF" onLoad="SetFocus(), init();">
  90. <!-- header //-->
  91. <?php require(DIR_WS_INCLUDES . 'header.php'); ?>
  92. <!-- header_eof //-->
  93.  
  94. <!-- body //-->
  95. <table border="0" width="100%" cellspacing="2" cellpadding="2">
  96.   <tr>
  97. <!-- body_text //-->
  98.     <td width="100%" valign="top"><table border="0" width="100%" cellspacing="0" cellpadding="2">
  99.       <tr>
  100.         <td><table border="0" width="100%" cellspacing="0" cellpadding="0">
  101.           <tr>
  102.             <td class="pageHeading"><?php echo HEADING_ADMIN_TITLE; ?></td>
  103.             <td class="pageHeading" align="right"><?php echo zen_draw_separator('pixel_trans.gif', HEADING_IMAGE_WIDTH, HEADING_IMAGE_HEIGHT); ?></td>
  104.             <td class="smallText" align="right">
  105. <?php
  106.   echo zen_draw_form('payment_status', FILENAME_PAYPAL, '', 'get') . HEADING_PAYMENT_STATUS . ' ' . zen_draw_pull_down_menu('payment_status', array_merge(array(array('id' => '', 'text' => TEXT_ALL_IPNS)), $payment_statuses), $selected_status, 'onChange="this.form.submit();"') . zen_hide_session_id() . zen_draw_hidden_field('paypal_ipn_sort_order', $_GET['paypal_ipn_sort_order']) . '</form>';
  107. ?>
  108. <?php
  109.   echo '&nbsp;&nbsp;&nbsp;' . TEXT_PAYPAL_IPN_SORT_ORDER_INFO . zen_draw_form('paypal_ipn_sort_order', FILENAME_PAYPAL, '', 'get') . '&nbsp;&nbsp;' . zen_draw_pull_down_menu('paypal_ipn_sort_order', $paypal_ipn_sort_order_array, $reset_paypal_ipn_sort_order, 'onChange="this.form.submit();"') . zen_hide_session_id() . zen_draw_hidden_field('payment_status', $_GET['payment_status']) . '</form>';
  110. ?>
  111.             </td>
  112.             <td class="pageHeading" align="right"><?php echo zen_draw_separator('pixel_trans.gif', HEADING_IMAGE_WIDTH, HEADING_IMAGE_HEIGHT); ?></td>
  113.           </tr>
  114.         </table></td>
  115.       </tr>
  116.       <tr>
  117.         <td><table border="0" width="100%" cellspacing="0" cellpadding="0">
  118.           <tr>
  119.             <td valign="top"><table border="0" width="100%" cellspacing="0" cellpadding="2">
  120.               <tr class="dataTableHeadingRow">
  121.                 <td class="dataTableHeadingContent"><?php echo TABLE_HEADING_ORDER_NUMBER; ?></td>
  122.                 <td class="dataTableHeadingContent"><?php echo TABLE_HEADING_PAYPAL_ID; ?></td>
  123.                 <td class="dataTableHeadingContent"><?php echo TABLE_HEADING_TXN_TYPE; ?></td>
  124.                 <td class="dataTableHeadingContent"><?php echo TABLE_HEADING_PAYMENT_STATUS; ?></td>
  125.                 <td class="dataTableHeadingContent" align="right"><?php echo TABLE_HEADING_PAYMENT_AMOUNT; ?></td>
  126.                 <td class="dataTableHeadingContent" align="right"><?php echo TABLE_HEADING_ACTION; ?>&nbsp;</td>
  127.               </tr>
  128. <?php
  129.   if (zen_not_null($selected_status)) {
  130.     $ipn_search = "and p.payment_status = :selectedStatus: ";
  131.     $ipn_search = $db->bindVars($ipn_search, ':selectedStatus:', $selected_status, 'string');
  132.     switch ($selected_status) {
  133.       case 'Pending':
  134.       case 'Completed':
  135.       default:
  136.         $ipn_query_raw = "select p.order_id, p.paypal_ipn_id, p.txn_type, p.payment_type, p.payment_status, p.pending_reason, p.mc_currency, p.payer_status, p.mc_currency, p.date_added, p.mc_gross, p.first_name, p.last_name, p.payer_business_name, p.parent_txn_id, p.txn_id from " . TABLE_PAYPAL . " as p, " .TABLE_ORDERS . " as o  where o.orders_id = p.order_id " . $ipn_search . $order_by;
  137.         break;
  138.     }
  139.   } else {
  140.         $ipn_query_raw = "select p.order_id, p.paypal_ipn_id, p.txn_type, p.payment_type, p.payment_status, p.pending_reason, p.mc_currency, p.payer_status, p.mc_currency, p.date_added, p.mc_gross, p.first_name, p.last_name, p.payer_business_name, p.parent_txn_id, p.txn_id from " . TABLE_PAYPAL . " as p left join " .TABLE_ORDERS . " as o on o.orders_id = p.order_id" . $order_by;
  141.   }
  142.   $ipn_split = new splitPageResults($_GET['page'], MAX_DISPLAY_SEARCH_RESULTS_PAYPAL_IPN, $ipn_query_raw, $ipn_query_numrows);
  143.   $ipn_trans = $db->Execute($ipn_query_raw);
  144.   while (!$ipn_trans->EOF) {
  145.     if ((!isset($_GET['ipnID']) || (isset($_GET['ipnID']) && ($_GET['ipnID'] == $ipn_trans->fields['paypal_ipn_id']))) && !isset($ipnInfo) ) {
  146.       $ipnInfo = new objectInfo($ipn_trans->fields);
  147.     }
  148.  
  149.     if (isset($ipnInfo) && is_object($ipnInfo) && ($ipn_trans->fields['paypal_ipn_id'] == $ipnInfo->paypal_ipn_id) ) {
  150.       echo '              <tr id="defaultSelected" class="dataTableRowSelected" onmouseover="rowOverEffect(this)" onmouseout="rowOutEffect(this)" onclick="document.location.href=\'' . zen_href_link(FILENAME_ORDERS, 'page=' . $_GET['page'] . '&ipnID=' . $ipnInfo->paypal_ipn_id . '&oID=' . $ipnInfo->order_id . '&action=edit' . '&referer=ipn' . (zen_not_null($selected_status) ? '&payment_status=' . $selected_status : '') . (zen_not_null($paypal_ipn_sort_order) ? '&paypal_ipn_sort_order=' . $paypal_ipn_sort_order : '') ) . '\'">' . "\n";
  151.     } else {
  152.       echo '              <tr class="dataTableRow" onmouseover="rowOverEffect(this)" onmouseout="rowOutEffect(this)" onclick="document.location.href=\'' . zen_href_link(FILENAME_PAYPAL, 'page=' . $_GET['page'] . '&ipnID=' . $ipn_trans->fields['paypal_ipn_id'] . (zen_not_null($selected_status) ? '&payment_status=' . $selected_status : '') . (zen_not_null($paypal_ipn_sort_order) ? '&paypal_ipn_sort_order=' . $paypal_ipn_sort_order : '') ) . '\'">' . "\n";
  153.     }
  154. ?>
  155.                 <td class="dataTableContent"> <?php echo $ipn_trans->fields['order_id']; ?> </td>
  156.                 <td class="dataTableContent"> <?php echo $ipn_trans->fields['paypal_ipn_id']; ?> </td>
  157.                 <td class="dataTableContent"> <?php echo $ipn_trans->fields['txn_type'] . '<br />' . $ipn_trans->fields['first_name'] . ' ' . $ipn_trans->fields['last_name'] . ($ipn_trans->fields['payer_business_name'] != '' ? '<br />' . $ipn_trans->fields['payer_business_name'] : ''); ?>
  158.                 <td class="dataTableContent"><?php echo $ipn_trans->fields['payment_status_name'] . ' '. $ipn_trans->fields['payment_status'] . '<br />Parent Trans ID:' . $ipn_trans->fields['parent_txn_id'] . '<br />Trans ID:' . $ipn_trans->fields['txn_id']; ?></td>
  159.                 <td class="dataTableContent" align="right"><?php echo $ipn_trans->fields['mc_currency'] . ' '.number_format($ipn_trans->fields['mc_gross'], 2); ?></td>
  160.                 <td class="dataTableContent" align="right"><?php if (isset($ipnInfo) && is_object($ipnInfo) && ($ipn_trans->fields['paypal_ipn_id'] == $ipnInfo->paypal_ipn_id) ) { echo zen_image(DIR_WS_IMAGES . 'icon_arrow_right.gif'); } else { echo '<a href="' . zen_href_link(FILENAME_PAYPAL, 'page=' . $_GET['page'] . '&ipnID=' . $ipn_trans->fields['paypal_ipn_id']) . (zen_not_null($selected_status) ? '&payment_status=' . $selected_status : '') . (zen_not_null($paypal_ipn_sort_order) ? '&paypal_ipn_sort_order=' . $paypal_ipn_sort_order : '') . '">' . zen_image(DIR_WS_IMAGES . 'icon_info.gif', IMAGE_ICON_INFO) . '</a>'; } ?>&nbsp;</td>
  161.               </tr>
  162. <?php
  163.     $ipn_trans->MoveNext();
  164.   }
  165. ?>
  166.               <tr>
  167.                 <td colspan="5"><table border="0" width="100%" cellspacing="0" cellpadding="2">
  168.                   <tr>
  169.                     <td class="smallText" valign="top"><?php echo $ipn_split->display_count($ipn_query_numrows, MAX_DISPLAY_SEARCH_RESULTS_PAYPAL_IPN, $_GET['page'], "Displaying <strong>%d</strong> to <strong>%d</strong> (of <strong>%d</strong> IPN's)"); ?></td>
  170.                     <td class="smallText" align="right"><?php echo $ipn_split->display_links($ipn_query_numrows, MAX_DISPLAY_SEARCH_RESULTS_PAYPAL_IPN, MAX_DISPLAY_PAGE_LINKS, $_GET['page'], (zen_not_null($selected_status) ? '&payment_status=' . $selected_status : '') . (zen_not_null($paypal_ipn_sort_order) ? '&paypal_ipn_sort_order=' . $paypal_ipn_sort_order : '')); ?></td>
  171.                   </tr>
  172.                 </table></td>
  173.               </tr>
  174.             </table></td>
  175. <?php
  176.   $heading = array();
  177.   $contents = array();
  178.  
  179.   switch ($action) {
  180.     case 'new':
  181.       break;
  182.     case 'edit':
  183.       break;
  184.     case 'delete':
  185.       break;
  186.     default:
  187.       if (is_object($ipnInfo)) {
  188.         $heading[] = array('text' => '<strong>' . TEXT_INFO_PAYPAL_IPN_HEADING.' #' . $ipnInfo->paypal_ipn_id . '</strong>');
  189.         $ipn = $db->Execute("select * from " . TABLE_PAYPAL_PAYMENT_STATUS_HISTORY . " where paypal_ipn_id = '" . $ipnInfo->paypal_ipn_id . "'");
  190.         $ipn_count = $ipn->RecordCount();
  191.  
  192.         $contents[] = array('align' => 'center', 'text' => '<a href="' . zen_href_link(FILENAME_ORDERS, zen_get_all_get_params(array('ipnID', 'action')) . 'oID=' . $ipnInfo->order_id .'&' . 'ipnID=' . $ipnInfo->paypal_ipn_id .'&action=edit' . '&referer=ipn') . '">' . zen_image_button('button_orders.gif', IMAGE_ORDERS) . '</a>');
  193.         $contents[] = array('text' => '<br>' . TABLE_HEADING_NUM_HISTORY_ENTRIES . ': '. $ipn_count);
  194.         $count = 1;
  195.         while (!$ipn->EOF) {
  196.           $contents[] = array('text' => '<br>' . TABLE_HEADING_ENTRY_NUM . ': '. $count);
  197.           $contents[] = array('text' =>  TABLE_HEADING_DATE_ADDED . ': '. zen_datetime_short($ipn->fields['date_added']));
  198.           $contents[] = array('text' =>  TABLE_HEADING_TRANS_ID . ': '.$ipn->fields['txn_id']);
  199.           $contents[] = array('text' =>  TABLE_HEADING_PAYMENT_STATUS . ': '.$ipn->fields['payment_status']);
  200.           $contents[] = array('text' =>  TABLE_HEADING_PENDING_REASON . ': '.$ipn->fields['pending_reason']);
  201.           $count++;
  202.           $ipn->MoveNext();
  203.         }
  204.       }
  205.       break;
  206.   }
  207.  
  208.   if ( (zen_not_null($heading)) && (zen_not_null($contents)) ) {
  209.     echo '            <td width="25%" valign="top">' . "\n";
  210.  
  211.     $box = new box;
  212.     echo $box->infoBox($heading, $contents);
  213.  
  214.     echo '            </td>' . "\n";
  215.   }
  216. ?>
  217.           </tr>
  218.         </table></td>
  219.       </tr>
  220.     </table></td>
  221. <!-- body_text_eof //-->
  222.   </tr>
  223. </table>
  224. <!-- body_eof //-->
  225.  
  226. <!-- footer //-->
  227. <?php require(DIR_WS_INCLUDES . 'footer.php'); ?>
  228. <!-- footer_eof //-->
  229. <br>
  230. </body>
  231. </html>
  232. <?php require(DIR_WS_INCLUDES . 'application_bottom.php'); ?>
  233.