169 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			169 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
/*
 | 
						|
 | 
						|
Copyright 2018 Murray Hayes
 | 
						|
 | 
						|
Redistribution and use in source and binary forms, with or without
 | 
						|
modification, are permitted provided that the following conditions
 | 
						|
are met:
 | 
						|
 | 
						|
1. Redistributions of source code must retain the above copyright
 | 
						|
notice, this list of conditions and the following disclaimer.
 | 
						|
 | 
						|
2. Redistributions in binary form must reproduce the above copyright
 | 
						|
notice, this list of conditions and the following disclaimer in the
 | 
						|
documentation and/or other materials provided with the distribution.
 | 
						|
 | 
						|
3. Neither the name of the copyright holder nor the names of its
 | 
						|
contributors may be used to endorse or promote products derived from
 | 
						|
this software without specific prior written permission.
 | 
						|
 | 
						|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 | 
						|
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 | 
						|
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
 | 
						|
FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
 | 
						|
COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
 | 
						|
INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
 | 
						|
BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 | 
						|
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
 | 
						|
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
 | 
						|
LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
 | 
						|
ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 | 
						|
POSSIBILITY OF SUCH DAMAGE.
 | 
						|
 | 
						|
*/
 | 
						|
 | 
						|
session_start();
 | 
						|
 | 
						|
include_once "utils.php";
 | 
						|
include_once "DOMUtils.php";
 | 
						|
include_once "consts.php";
 | 
						|
include_once "database.php";
 | 
						|
include_once "adminUtils.php";
 | 
						|
 | 
						|
$doc = returnDoc();
 | 
						|
$root = returnRoot($doc);
 | 
						|
 | 
						|
//if (!isset($_SESSION['login']) || !isset($_SESSION['MemberID']))
 | 
						|
if (!validateSession())
 | 
						|
  if (!isset($_SESSION['cookieMonster']))
 | 
						|
    generateCookieMonster();
 | 
						|
  else
 | 
						|
    generateLoginRedirect();
 | 
						|
else
 | 
						|
  if (($_SESSION['login'] === TRUE) && 
 | 
						|
      (returnAdminStatus($_SESSION['MemberID']) || 
 | 
						|
       returnDirectorStatus($_SESSION['MemberID'])))
 | 
						|
  {
 | 
						|
    $ipnDetailForm = NULL;
 | 
						|
    if ($_SERVER['REQUEST_METHOD'] == 'POST')
 | 
						|
    {
 | 
						|
      /*
 | 
						|
       *  Process form here
 | 
						|
       */
 | 
						|
      
 | 
						|
      print ("Posted: ");
 | 
						|
      print_r ($_POST);
 | 
						|
      
 | 
						|
      
 | 
						|
    }
 | 
						|
    else
 | 
						|
      if ($_SERVER['REQUEST_METHOD'] == 'GET')
 | 
						|
      {
 | 
						|
        $options = array('options' => array('min_range' => 1));
 | 
						|
        
 | 
						|
        if (isset($_GET['id']) && (filter_var($_GET['id'], FILTER_VALIDATE_INT, $options) !== FALSE))
 | 
						|
        {
 | 
						|
          $ipn = returnPendingIPN($_GET['id']);
 | 
						|
          if (!is_null($ipn))
 | 
						|
          {
 | 
						|
            $ipnDetailForm = createForm($doc, 'processIPNs.php');
 | 
						|
            $ipnDetail = createTable($doc);
 | 
						|
            $tr = createTr($doc);
 | 
						|
            $tr->appendChild(createTd($doc, 'IPN ID'));
 | 
						|
            $tr->appendChild(createTd($doc, $ipn['id']));
 | 
						|
            $ipnDetail->appendChild($tr);
 | 
						|
            $tr = createTr($doc);
 | 
						|
            $tr->appendChild(createTd($doc, 'TXN ID'));
 | 
						|
            $tr->appendChild(createTd($doc, $ipn['txn_id']));
 | 
						|
            $ipnDetail->appendChild($tr);
 | 
						|
            $tr = createTr($doc);
 | 
						|
            $tr->appendChild(createTd($doc, 'IPN Type'));
 | 
						|
            $tr->appendChild(createTd($doc, $ipn['txn_type']));
 | 
						|
            $ipnDetail->appendChild($tr);
 | 
						|
            $tr = createTr($doc);
 | 
						|
            $tr->appendChild(createTd($doc, 'IPN Payer ID'));
 | 
						|
            $tr->appendChild(createTd($doc, $ipn['payer_id']));
 | 
						|
            $ipnDetail->appendChild($tr);
 | 
						|
            $tr = createTr($doc);
 | 
						|
            $tr->appendChild(createTd($doc, 'IPN First Name'));
 | 
						|
            $tr->appendChild(createTd($doc, $ipn['first_name']));
 | 
						|
            $ipnDetail->appendChild($tr);
 | 
						|
            $tr = createTr($doc);
 | 
						|
            $tr->appendChild(createTd($doc, 'IPN Last Name'));
 | 
						|
            $tr->appendChild(createTd($doc, $ipn['last_name']));
 | 
						|
            $ipnDetail->appendChild($tr);
 | 
						|
            $tr = createTr($doc);
 | 
						|
            $tr->appendChild(createTd($doc, 'IPN Payment Date'));
 | 
						|
            $tr->appendChild(createTd($doc, $ipn['payment_date']));
 | 
						|
            $ipnDetail->appendChild($tr);
 | 
						|
            $tr = createTr($doc);
 | 
						|
            $tr->appendChild(createTd($doc, 'Date of Record'));
 | 
						|
            $tr->appendChild(createTd($doc, $ipn['incoming_timestamp']));
 | 
						|
            $ipnDetail->appendChild($tr);
 | 
						|
            $tr = createTr($doc);
 | 
						|
            $tr->appendChild(createTd($doc, 'IPN Gross'));
 | 
						|
            $tr->appendChild(createTd($doc, $ipn['mc_gross']));
 | 
						|
            $ipnDetail->appendChild($tr);
 | 
						|
            $tr = createTr($doc);
 | 
						|
            $tr->appendChild(createTd($doc, 'Select Member'));
 | 
						|
            $td = createTd($doc);
 | 
						|
            $td->appendChild(generateMemberSelector($doc, 'targetMember'));
 | 
						|
            $tr->appendChild($td);
 | 
						|
            $ipnDetail->appendChild($tr);
 | 
						|
            $ipnDetailForm->appendChild($ipnDetail);
 | 
						|
            $ipnDetailForm->appendChild(createHiddenInput($doc, 'id', $ipn['id']));
 | 
						|
            $ipnDetailForm->appendChild(createLabel($doc, 'Add To Known Paypal IDs', 'makePayerKnown'));
 | 
						|
            $ipnDetailForm->appendChild(createCheckboxInput($doc, 'makePayerKnown'));
 | 
						|
            $ipnDetailForm->appendChild(createBr($doc));
 | 
						|
            $ipnDetailForm->appendChild(createSubmitInput($doc, 'assignIPN', 'Assign IPN to Member'));
 | 
						|
          }
 | 
						|
        }
 | 
						|
      }
 | 
						|
    
 | 
						|
    processInstantPaypalNotificationQueue();
 | 
						|
    $root = $doc->appendChild($root);
 | 
						|
    $root->appendChild(generateHead($doc));
 | 
						|
    
 | 
						|
    $body = $doc->createElement('body');
 | 
						|
    $root->appendChild($body);
 | 
						|
    
 | 
						|
    $body->appendChild(generateMastHead($doc, $baseDir));
 | 
						|
    
 | 
						|
    //$body->appendChild($doc->createElement('hr'));
 | 
						|
    
 | 
						|
    $_SESSION['subNav'] = 1;
 | 
						|
    $body->appendChild(generateSelectedMenuBar($doc, 1));
 | 
						|
        
 | 
						|
    
 | 
						|
    /*
 | 
						|
     *  Insert content here.
 | 
						|
     */
 | 
						|
    
 | 
						|
    if (!is_null($ipnDetailForm))
 | 
						|
      $body->appendChild($ipnDetailForm);
 | 
						|
    $body->appendChild(generatePendingIPNTable($doc, 'processIPNs.php'));
 | 
						|
    
 | 
						|
    $body->appendChild(generateFooter($doc));
 | 
						|
    if ($prettyPretty)
 | 
						|
      $doc->formatOutput = true;
 | 
						|
    outputDoc($doc);
 | 
						|
  }
 | 
						|
  else
 | 
						|
  {
 | 
						|
    generateIndexRedirect();
 | 
						|
    //print ("redirect");
 | 
						|
  }
 | 
						|
      
 | 
						|
?>
 |