/mnt/web601/b3/14/57451114/htdocs/httpdocs/checkout_ipayment.php
<?php
/* --------------------------------------------------------------
   checkout_ipayment.php 2023-01-25
   Gambio GmbH
   http://www.gambio.de
   Copyright (c) 2023 Gambio GmbH
   Released under the GNU General Public License (Version 2)
   [http://www.gnu.org/licenses/gpl-2.0.html]
   --------------------------------------------------------------


   based on:
   (c) 2000-2001 The Exchange Project  (earlier name of osCommerce)
   (c) 2002-2003 osCommerce(ot_cod_fee.php,v 1.02 2003/02/24); www.oscommerce.com
   (C) 2001 - 2003 TheMedia, Dipl.-Ing Thomas Plänkers ; http://www.themedia.at & http://www.oscommerce.at
   (c) 2003 XT-Commerce - community made shopping http://www.xt-commerce.com ($Id: ot_cod_fee.php 1003 2005-07-10 18:58:52Z mz $)

   Released under the GNU General Public License
   ---------------------------------------------------------------------------------------*/

require_once 'includes/application_top.php';

if(isset($_GET['back_button'])) {
	xtc_redirect(GM_HTTP_SERVER.DIR_WS_CATALOG.FILENAME_CHECKOUT_CONFIRMATION);
}

if(empty($_SESSION['tmp_oID'])) {
   die('not in checkout or session expired');
}

$ipay_order = new order($_SESSION['tmp_oID']);
try {
	$ipayment = new GMIPayment($ipay_order->info['payment_method']);
}
catch(GMIPaymentCodeInvalidException $e) {
	die('payment method is not ipayment, aborting');
}

if(isset($_REQUEST['ret_status']) && isset($_REQUEST['ret_param_checksum'])) {
	// returning from payment
	$checksum_correct = $ipayment->checkReturnHash($_REQUEST);
	if($checksum_correct == true) {
		$_SESSION['ipayment_response'][$_SESSION['tmp_oID']] = $_REQUEST;
		xtc_redirect(GM_HTTP_SERVER.DIR_WS_CATALOG.'checkout_process.php');
	}
	else {
		$ipayment->log("Response handler called with incorrect hash, request follows:\n".print_r($_REQUEST));
		unset($_SESSION['tmp_oID']);
		die('violation of security parameters');
	}
}

if(isset($_REQUEST['ret_status']) && isset($_REQUEST['ret_url_checksum'])) {
	$url_checksum_correct = $ipayment->checkURLHash($_SERVER['REQUEST_URI'], $_REQUEST['ret_url_checksum']);
	if(!$url_checksum_correct == true) {
		die('violation of security parameters (G)');
	}
}

if(isset($_REQUEST['action']) && $_REQUEST['action'] == 'back') {
	// payment in prepaid mode aborted - not much we can do, go back to payment selection.
	xtc_redirect(GM_HTTP_SERVER.DIR_WS_CATALOG.FILENAME_CHECKOUT_PAYMENT);
}

// countries_list
$countries_result = xtc_db_query("SELECT countries_id, countries_name, countries_iso_code_2, countries_iso_code_3 FROM countries WHERE status = 1");
$countries_list = array();
$cid_usa = false;
$cid_canada = false;
while($countries_row = xtc_db_fetch_array($countries_result)) {
	$countries_list[] = $countries_row;
	$cid_usa = ($cid_usa == false && $countries_row['countries_iso_code_2'] == 'US') ? $countries_row['countries_id'] : $cid_usa;
	$cid_canada = ($cid_canada == false && $countries_row['countries_iso_code_2'] == 'CA') ? $countries_row['countries_id'] : $cid_canada;
}

$states_usa = array();
if($cid_usa !== false) {
	$states_usa_result = xtc_db_query("SELECT zone_code, zone_name FROM zones WHERE zone_country_id = ".(int)$cid_usa);
	while($states_usa_row = xtc_db_fetch_array($states_usa_result)) {
		$states_usa[] = $states_usa_row;
	}
}

$states_canada = array();
if($cid_canada !== false) {
	$states_canada_result = xtc_db_query("SELECT zone_code, zone_name FROM zones WHERE zone_country_id = ".(int)$cid_canada);
	while($states_canada_row = xtc_db_fetch_array($states_canada_result)) {
		$states_canada[] = $states_canada_row;
	}
}

if($_SERVER['REQUEST_METHOD'] == 'GET') {
	defined('MODULE_PAYMENT_IPAYMENT_CC_CARDS_ENABLED') or define('MODULE_PAYMENT_IPAYMENT_CC_CARDS_ENABLED', 'master,visa,amex,diners,jcb,solo,discover,maestro');
	$cards_enabled = array_map('trim', explode(',', MODULE_PAYMENT_IPAYMENT_CC_CARDS_ENABLED));
	$cards_enabled = array_map('strtolower', $cards_enabled);
	$contentView = MainFactory::create('ContentView', $_GET, $_POST);
	$contentView->set_flat_assigns(true);
    $contentView->set_content_template('checkout_payment_ipayment.html');
	$formfields = $ipayment->getFormData($_SESSION['tmp_oID'], $ipay_order);
	$contentView->set_content_data('nonsilent_message',
		'Wenn Sie nicht automatisch weitergeleitet werden, klicken Sie bitte auf den Button, um zum Zahlungsdienstleister weitergeleitet zu werden');
	if(isset($_REQUEST['ret_errormsg'])) {
		$contentView->set_content_data('silent_error', mb_convert_encoding(strip_tags($_REQUEST['ret_errormsg']), 'UTF-8', 'ISO-8859-1'));
	}

	$contentView->set_content_data('formfields',      $formfields);
	$contentView->set_content_data('cards_enabled',   $cards_enabled);
	$contentView->set_content_data('returned_fields', $_REQUEST);
	$contentView->set_content_data('countries_list',  $countries_list);
	$contentView->set_content_data('states_usa',      $states_usa);
	$contentView->set_content_data('states_canada',   $states_canada);
	$contentView->set_content_data('months',          array('01', '02', '03', '04', '05', '06', '07', '08', '09', '10', '11', '12'));
	$years = array();
	$current_year = date('y');
	for($i = 0; $i <= 20; $i++) {
		$years[] = sprintf('%02d', ($current_year + $i));
	}
	$contentView->set_content_data('years',      $years);
	$years_past = array();
	$current_year = date('y');
	for($i = 0; $i <= 10; $i++) {
		$years_past[] = sprintf('%02d', ($current_year - $i));
	}
	$contentView->set_content_data('years_past', $years_past);
	$contentView->set_content_data('action_url', $formfields['action']);
	$contentView->set_content_data('orders_id',  $_SESSION['tmp_oID']);
	$contentView->set_content_data('back_url',   GM_HTTP_SERVER.DIR_WS_CATALOG.basename(__FILE__).'?back_button=go');
	$main_content = $contentView->get_html();

	$coo_layout_control = MainFactory::create_object('LayoutContentControl');
	$coo_layout_control->set_data('GET', $_GET);
	$coo_layout_control->set_data('POST', $_POST);
	$t_category_id = 0;
	if(isset($GLOBALS['cID']))
	{
		$t_category_id = $GLOBALS['cID'];
	}
	$coo_layout_control->set_('category_id',    $t_category_id);
	$coo_layout_control->set_('coo_breadcrumb', $GLOBALS['breadcrumb']);
	$coo_layout_control->set_('coo_product',    $GLOBALS['product']);
	$coo_layout_control->set_('coo_xtc_price',  $GLOBALS['xtPrice']);
	$coo_layout_control->set_('c_path',         $GLOBALS['cPath']);
	$coo_layout_control->set_('main_content',   $main_content);
	$coo_layout_control->set_('request_type',   $GLOBALS['request_type']);
	$coo_layout_control->proceed();

	$t_redirect_url = $coo_layout_control->get_redirect_url();
	if(empty($t_redirect_url) === false)
	{
		xtc_redirect($t_redirect_url);
	}
	else
	{
		echo $coo_layout_control->get_response();
	}
}

Unexpected error occurred...

Class "main_ORIGIN" not found