(dev/core#959) Expose contribution page in Contribution Summary report
[civicrm-core.git] / extern / ipn.php
1 <?php
2 /*
3 +--------------------------------------------------------------------+
4 | CiviCRM version 5 |
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2019 |
7 +--------------------------------------------------------------------+
8 | This file is a part of CiviCRM. |
9 | |
10 | CiviCRM is free software; you can copy, modify, and distribute it |
11 | under the terms of the GNU Affero General Public License |
12 | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
13 | |
14 | CiviCRM is distributed in the hope that it will be useful, but |
15 | WITHOUT ANY WARRANTY; without even the implied warranty of |
16 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
17 | See the GNU Affero General Public License for more details. |
18 | |
19 | You should have received a copy of the GNU Affero General Public |
20 | License and the CiviCRM Licensing Exception along |
21 | with this program; if not, contact CiviCRM LLC |
22 | at info[AT]civicrm[DOT]org. If you have questions about the |
23 | GNU Affero General Public License or the licensing of CiviCRM, |
24 | see the CiviCRM license FAQ at http://civicrm.org/licensing |
25 +--------------------------------------------------------------------+
26 */
27
28 /**
29 * @package CRM
30 * @copyright CiviCRM LLC (c) 2004-2019
31 * $Id$
32 */
33
34 if (defined('PANTHEON_ENVIRONMENT')) {
35 ini_set('session.save_handler', 'files');
36 }
37 session_start();
38
39 require_once '../civicrm.config.php';
40
41 /* Cache the real UF, override it with the SOAP environment */
42
43 $config = CRM_Core_Config::singleton();
44 $log = new CRM_Utils_SystemLogger();
45 if (empty($_GET)) {
46 $log->alert('payment_notification processor_name=PayPal', $_REQUEST);
47 $paypalIPN = new CRM_Core_Payment_PayPalProIPN($_REQUEST);
48 }
49 else {
50 $log->alert('payment_notification PayPal_Standard', $_REQUEST);
51 $paypalIPN = new CRM_Core_Payment_PayPalIPN($_REQUEST);
52 // @todo upgrade standard per Pro
53 }
54 try {
55 //CRM-18245
56 if ($config->userFramework == 'Joomla') {
57 CRM_Utils_System::loadBootStrap();
58 }
59 $paypalIPN->main();
60 }
61 catch (CRM_Core_Exception $e) {
62 CRM_Core_Error::debug_log_message($e->getMessage());
63 CRM_Core_Error::debug_var('error data', $e->getErrorData(), TRUE, TRUE);
64 CRM_Core_Error::debug_var('REQUEST', $_REQUEST, TRUE, TRUE);
65 //@todo give better info to logged in user - ie dev
66 echo "The transaction has failed. Please review the log for more detail";
67 }