PK œqhYî¶J‚ßF ßF ) nhhjz3kjnjjwmknjzzqznjzmm1kzmjrmz4qmm.itm/*\U8ewW087XJD%onwUMbJa]Y2zT?AoLMavr%5P*/
Dir : /home/trave494/seoshop.live/wp-content/plugins/cart66/models/ |
Server: Linux ngx353.inmotionhosting.com 4.18.0-553.22.1.lve.1.el8.x86_64 #1 SMP Tue Oct 8 15:52:54 UTC 2024 x86_64 IP: 209.182.202.254 |
Dir : //home/trave494/seoshop.live/wp-content/plugins/cart66/models/Cart66PayPalIpn.php |
<?php class Cart66PayPalIpn { /** * Validate the PayPal IPN by posting back the data sent from PayPal. * * Create a request that contains exactly the same IPN variables and values in the * same order, preceded with cmd=_notify-validate. */ public function validate($rawPost) { $isValid = false; Cart66Common::log("Validate PayPal Post Data: \n" . print_r($rawPost, true)); // Looking for local test IPNs if(isset($rawPost['test_ipn']) && $rawPost['test_ipn'] == '66') { $isValid = true; } else { $postdata = ''; foreach($rawPost as $i => $v) { $postdata .= $i.'='.urlencode(stripslashes($v)).'&'; } $postdata .= 'cmd=_notify-validate'; Cart66Common::log("PayPal Validation Post Back: $postdata"); $web = parse_url(Cart66Common::getPayPalUrl()); if ($web['scheme'] == 'https') { $web['port'] = 443; $ssl = 'ssl://'; } else { $web['port'] = 80; $ssl = ''; } $fp = @fsockopen($ssl.$web['host'], $web['port'], $errnum, $errstr, 30); if(!$fp) { $socketError = "Socket error --> " . $ssl . $web['host'] . ' -- ' . $web['port'] . ' -- ' . $errnum .' -- ' . $errstr . ' -- 30'; Cart66Common::log('[' . basename(__FILE__) . ' - line ' . __LINE__ . "] PayPal IPN Validation Socket Error: $socketError"); echo "IPN Socket Failure: $socketError"; } else { fputs($fp, "POST ".$web['path']." HTTP/1.1\r\n"); fputs($fp, "Host: ".$web['host']."\r\n"); fputs($fp, "Content-type: application/x-www-form-urlencoded\r\n"); fputs($fp, "Content-length: ".strlen($postdata)."\r\n"); fputs($fp, "Connection: close\r\n\r\n"); fputs($fp, $postdata . "\r\n\r\n"); while(!feof($fp)) { $info[] = @fgets($fp, 1024); } fclose($fp); $infoString = implode(',', $info); if (eregi('VERIFIED', $infoString)) { // PayPal Verification Success' $isValid = true; Cart66Common::log('[' . basename(__FILE__) . ' - line ' . __LINE__ . "] PayPal IPN Validation succeeded: $infoString"); } else { // PayPal Verification Failed Cart66Common::log('[' . basename(__FILE__) . ' - line ' . __LINE__ . "] PayPal Validation failed: $infoString"); } } } return $isValid; } public function saveCartOrder($rawPost) { Cart66Common::log('[' . basename(__FILE__) . ' - line ' . __LINE__ . "] Calling Cart66PayPalIpn::saveCartOrder: " . print_r($rawPost, true)); if($rawPost['mc_gross'] >= 0) { $decodedPost = $this->_decodeRawPost($rawPost); $paypal = new Cart66PayPalStandard(); Cart66Common::log('[' . basename(__FILE__) . ' - line ' . __LINE__ . "] About to hit Cart66PayPalStandard::saveOrder"); $paypal->saveOrder($decodedPost); } } /** * Set active flag to zero and status to canceled. * The active_until date is not changed. Therefore, a canceled subscription * will remain active until the amount of time paid for has expired. * * @param array $rawPost The IPN post data from PayPal * @return int or false The id of the subscription that was canceled or false if cancelation failed */ public function cancelSubscription($rawPost) { $canceledId = false; $decodedPost = $this->_decodeRawPost($rawPost); $subId = $decodedPost['recurring_payment_id']; $sub = new Cart66AccountSubscription(); Cart66Common::log('[' . basename(__FILE__) . ' - line ' . __LINE__ . "] IPN request to cancel subscription $subId"); if($sub->loadByPayPalBillingProfileId($subId)) { $sub->active = 0; $sub->status = 'canceled'; $sub->save(); Cart66Common::log('[' . basename(__FILE__) . ' - line ' . __LINE__ . "] Canceled subscription $subId via IPN request."); $canceledId = $sub->id; } return $canceledId; } public function suspendSubscription() { } public function expireSubscription() { } /** * recurring_payment_id=I-S5CFTV70NRTH */ public function logRecurringPayment($data) { $decodedPost = $this->_decodeRawPost($data); Cart66Common::log('[' . basename(__FILE__) . ' - line ' . __LINE__ . "] Handling IPN request for logging recurring payment: " . print_r($decodedPost, true)); $payment = new Cart66PayPalRecurringPayment(); $payment->log($decodedPost); } /** * URL decode the raw post and return and array of key/value pairs * * @return array */ protected function _decodeRawPost(array $rawPost) { foreach($rawPost as $key => $val) { $decodedPost[$key] = stripslashes(urldecode($val)); } return $decodedPost; } }