PageRenderTime 37ms CodeModel.GetById 1ms RepoModel.GetById 0ms app.codeStats 0ms

/wp-content/plugins/s2member/includes/classes/paypal-return-in-subscr-modify-w-level.inc.php

https://gitlab.com/Gashler/dp
PHP | 233 lines | 170 code | 31 blank | 32 comment | 62 complexity | dbff77d9fcf7c49e488d464e28130b3d MD5 | raw file
  1. <?php
  2. /**
  3. * s2Member's PayPal® Auto-Return/PDT handler (inner processing routine).
  4. *
  5. * Copyright: © 2009-2011
  6. * {@link http://www.websharks-inc.com/ WebSharks, Inc.}
  7. * (coded in the USA)
  8. *
  9. * Released under the terms of the GNU General Public License.
  10. * You should have received a copy of the GNU General Public License,
  11. * along with this software. In the main directory, see: /licensing/
  12. * If not, see: {@link http://www.gnu.org/licenses/}.
  13. *
  14. * @package s2Member\PayPal
  15. * @since 110720
  16. */
  17. if(realpath(__FILE__) === realpath($_SERVER["SCRIPT_FILENAME"]))
  18. exit("Do not access this file directly.");
  19. if(!class_exists("c_ws_plugin__s2member_paypal_return_in_subscr_modify_w_level"))
  20. {
  21. /**
  22. * s2Member's PayPal® Auto-Return/PDT handler (inner processing routine).
  23. *
  24. * @package s2Member\PayPal
  25. * @since 110720
  26. */
  27. class c_ws_plugin__s2member_paypal_return_in_subscr_modify_w_level
  28. {
  29. /**
  30. * s2Member's PayPal® Auto-Return/PDT handler (inner processing routine).
  31. *
  32. * @package s2Member\PayPal
  33. * @since 110720
  34. *
  35. * @param array $vars Required. An array of defined variables passed by {@link s2Member\PayPal\c_ws_plugin__s2member_paypal_return_in::paypal_return()}.
  36. * @return array|bool The original ``$paypal`` array passed in (extracted) from ``$vars``, or false when conditions do NOT apply.
  37. *
  38. * @todo Optimize with ``empty()`` and ``isset()``.
  39. */
  40. public static function /* Conditional phase for ``c_ws_plugin__s2member_paypal_notify_in::paypal_notify()``. */ cp($vars = array())
  41. {
  42. extract /* Extract all vars passed in from: ``c_ws_plugin__s2member_paypal_notify_in::paypal_notify()``. */($vars);
  43. if((!empty($paypal["txn_type"]) && preg_match("/^subscr_modify$/i", $paypal["txn_type"]))
  44. && (!empty($paypal["item_number"]) && preg_match($GLOBALS["WS_PLUGIN__"]["s2member"]["c"]["membership_item_number_w_level_regex"], $paypal["item_number"]))
  45. && (!empty($paypal["subscr_id"])))
  46. {
  47. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  48. do_action("ws_plugin__s2member_during_paypal_return_before_subscr_modify", get_defined_vars());
  49. unset /* Unset defined __refs, __v. */($__refs, $__v);
  50. if(!get_transient($transient_rtn = "s2m_rtn_".md5("s2member_transient_".$_paypal_s)) && set_transient($transient_rtn, time(), 31556926 * 10))
  51. {
  52. $paypal["s2member_log"][] = "s2Member `txn_type` identified as ( `subscr_modify` ), a Subscription Modification.";
  53. list($paypal["level"], $paypal["ccaps"]/*, $paypal["eotper"] */) = preg_split("/\:/", $paypal["item_number"], 2);
  54. $paypal["ip"] = (preg_match("/ip address/i", $paypal["option_name2"]) && $paypal["option_selection2"]) ? $paypal["option_selection2"] : "";
  55. $paypal["ip"] = (!$paypal["ip"] && preg_match("/^[a-z0-9]+~[0-9\.]+$/i", $paypal["invoice"])) ? preg_replace("/^[a-z0-9]+~/i", "", $paypal["invoice"]) : $paypal["ip"];
  56. $paypal["ip"] = (!$paypal["ip"] && $_SERVER["REMOTE_ADDR"]) ? $_SERVER["REMOTE_ADDR"] : $paypal["ip"];
  57. $paypal["period1"] = (preg_match("/^[1-9]/", $paypal["period1"])) ? $paypal["period1"] : /* Defaults to "0 D" (zero days). */ "0 D";
  58. $paypal["mc_amount1"] = (strlen($paypal["mc_amount1"]) && $paypal["mc_amount1"] > 0) ? $paypal["mc_amount1"] : "0.00";
  59. if /* Conversions for Lifetime & Fixed-Term sales. */(preg_match("/^web_accept$/i", $paypal["txn_type"]))
  60. {
  61. $paypal["period3"] = ($paypal["eotper"]) ? $paypal["eotper"] : /* 1 Lifetime. */ "1 L";
  62. $paypal["mc_amount3"] = /* The "Buy Now" amount is the full gross. */ $paypal["mc_gross"];
  63. }
  64. $paypal["initial_term"] = (preg_match("/^[1-9]/", $paypal["period1"])) ? $paypal["period1"] : /* Defaults to "0 D" (zero days). */ "0 D";
  65. $paypal["initial"] = (strlen($paypal["mc_amount1"]) && preg_match("/^[1-9]/", $paypal["period1"])) ? $paypal["mc_amount1"] : $paypal["mc_amount3"];
  66. $paypal["regular"] = /* This is the Regular Payment Amount that is charged to the Customer. Always required by PayPal®. */ $paypal["mc_amount3"];
  67. $paypal["regular_term"] = /* This is just set to keep a standard; this way both initial_term & regular_term are available. */ $paypal["period3"];
  68. $paypal["recurring"] = /* If non-recurring, this should be zero, otherwise Regular. */ ($paypal["recurring"]) ? $paypal["mc_amount3"] : "0";
  69. $ipn_signup_vars = $paypal; /* Create array of wouldbe IPN signup vars w/o s2member_log. */ unset($ipn_signup_vars["s2member_log"]);
  70. if(($user_id = c_ws_plugin__s2member_utils_users::get_user_id_with($paypal["subscr_id"])) && is_object($user = new WP_User($user_id)) && $user->ID)
  71. {
  72. if /* Do NOT process this routine on Administrators. */(!$user->has_cap("administrator"))
  73. {
  74. $processing = $modifying = $during = /* Yes, we ARE processing this. */ true;
  75. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  76. do_action("ws_plugin__s2member_during_paypal_return_during_before_subscr_modify", get_defined_vars());
  77. do_action("ws_plugin__s2member_during_collective_mods", $user_id, get_defined_vars(), "rtn-upgrade-downgrade", "modification", "s2member_level".$paypal["level"]);
  78. unset /* Unset defined __refs, __v. */($__refs, $__v);
  79. $fields = /* These will be needed in the routines below. */ get_user_option("s2member_custom_fields", $user_id);
  80. $user_reg_ip = /* Original IP during Registration. */ get_user_option("s2member_registration_ip", $user_id);
  81. $user_reg_ip = $paypal["ip"] = /* Now merge conditionally. */ ($user_reg_ip) ? $user_reg_ip : $paypal["ip"];
  82. if(is_multisite() && !is_user_member_of_blog($user_id) /* Must have a Role on this Blog. */)
  83. {
  84. add_existing_user_to_blog(array("user_id" => $user_id, "role" => "s2member_level".$paypal["level"]));
  85. $user = /* Now update the $user object we're using. */ new WP_User($user_id);
  86. }
  87. $current_role = c_ws_plugin__s2member_user_access::user_access_role($user);
  88. if /* Only if we need to. */($current_role !== "s2member_level".$paypal["level"])
  89. $user->set_role /* (upgrade/downgrade) */("s2member_level".$paypal["level"]);
  90. if($paypal["ccaps"] && preg_match("/^-all/", str_replace("+", "", $paypal["ccaps"])))
  91. foreach($user->allcaps as $cap => $cap_enabled)
  92. if(preg_match("/^access_s2member_ccap_/", $cap))
  93. $user->remove_cap($ccap = $cap);
  94. if($paypal["ccaps"] && preg_replace("/^-all[\r\n\t\s;,]*/", "", str_replace("+", "", $paypal["ccaps"])))
  95. foreach(preg_split("/[\r\n\t\s;,]+/", preg_replace("/^-all[\r\n\t\s;,]*/", "", str_replace("+", "", $paypal["ccaps"]))) as $ccap)
  96. if(strlen($ccap = trim(strtolower(preg_replace("/[^a-z_0-9]/i", "", $ccap)))))
  97. $user->add_cap("access_s2member_ccap_".$ccap);
  98. update_user_option($user_id, "s2member_subscr_gateway", $paypal["subscr_gateway"]);
  99. update_user_option($user_id, "s2member_subscr_id", $paypal["subscr_id"]);
  100. update_user_option($user_id, "s2member_custom", $paypal["custom"]);
  101. if(!get_user_option("s2member_registration_ip", $user_id))
  102. update_user_option($user_id, "s2member_registration_ip", $paypal["ip"]);
  103. update_user_option($user_id, "s2member_ipn_signup_vars", $ipn_signup_vars);
  104. delete_user_option($user_id, "s2member_file_download_access_log");
  105. delete_user_option($user_id, "s2member_auto_eot_time");
  106. $pr_times = get_user_option("s2member_paid_registration_times", $user_id);
  107. $pr_times["level"] = /* Preserve existing. */ (!$pr_times["level"]) ? time() : $pr_times["level"];
  108. $pr_times["level".$paypal["level"]] = (!$pr_times["level".$paypal["level"]]) ? time() : $pr_times["level".$paypal["level"]];
  109. update_user_option($user_id, "s2member_paid_registration_times", $pr_times);
  110. c_ws_plugin__s2member_user_notes::clear_user_note_lines($user_id, "/^Demoted by s2Member\:/");
  111. c_ws_plugin__s2member_user_notes::clear_user_note_lines ($user_id, "/^Paid Subscr\. ID @ time of demotion\:/");
  112. $paypal["s2member_log"][] = "s2Member Level/Capabilities updated on ( `subscr_modify` ), a Subscription Modification.";
  113. setcookie("s2member_tracking", ($s2member_tracking = c_ws_plugin__s2member_utils_encryption::encrypt($paypal["subscr_id"])), time() + 31556926, COOKIEPATH, COOKIE_DOMAIN).setcookie("s2member_tracking", $s2member_tracking, time() + 31556926, SITECOOKIEPATH, COOKIE_DOMAIN).($_COOKIE["s2member_tracking"] = $s2member_tracking);
  114. $paypal["s2member_log"][] = "Transient Tracking Cookie set on ( `subscr_modify` ), a Subscription Modification.";
  115. if($processing && ($code = $GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["modification_tracking_codes"]) && is_array($cv = preg_split("/\|/", $paypal["custom"])))
  116. {
  117. if(($code = preg_replace("/%%cv([0-9]+)%%/ei", 'trim($cv[$1])', $code)) && ($code = preg_replace("/%%subscr_id%%/i", c_ws_plugin__s2member_utils_strings::esc_ds($paypal["subscr_id"]), $code)))
  118. if(($code = preg_replace("/%%initial%%/i", c_ws_plugin__s2member_utils_strings::esc_ds($paypal["initial"]), $code)) && ($code = preg_replace("/%%regular%%/i", c_ws_plugin__s2member_utils_strings::esc_ds($paypal["regular"]), $code)) && ($code = preg_replace("/%%recurring%%/i", c_ws_plugin__s2member_utils_strings::esc_ds($paypal["recurring"]), $code)))
  119. if(($code = preg_replace("/%%initial_term%%/i", c_ws_plugin__s2member_utils_strings::esc_ds($paypal["initial_term"]), $code)) && ($code = preg_replace("/%%regular_term%%/i", c_ws_plugin__s2member_utils_strings::esc_ds($paypal["regular_term"]), $code)))
  120. if(($code = preg_replace("/%%item_number%%/i", c_ws_plugin__s2member_utils_strings::esc_ds($paypal["item_number"]), $code)) && ($code = preg_replace("/%%item_name%%/i", c_ws_plugin__s2member_utils_strings::esc_ds($paypal["item_name"]), $code)))
  121. if(($code = preg_replace("/%%first_name%%/i", c_ws_plugin__s2member_utils_strings::esc_ds($paypal["first_name"]), $code)) && ($code = preg_replace("/%%last_name%%/i", c_ws_plugin__s2member_utils_strings::esc_ds($paypal["last_name"]), $code)))
  122. if(($code = preg_replace("/%%full_name%%/i", c_ws_plugin__s2member_utils_strings::esc_ds(trim($paypal["first_name"]." ".$paypal["last_name"])), $code)))
  123. if(($code = preg_replace("/%%payer_email%%/i", c_ws_plugin__s2member_utils_strings::esc_ds($paypal["payer_email"]), $code)))
  124. {
  125. if(($code = preg_replace("/%%user_first_name%%/i", c_ws_plugin__s2member_utils_strings::esc_ds($user->first_name), $code)) && ($code = preg_replace("/%%user_last_name%%/i", c_ws_plugin__s2member_utils_strings::esc_ds($user->last_name), $code)))
  126. if(($code = preg_replace("/%%user_full_name%%/i", c_ws_plugin__s2member_utils_strings::esc_ds(trim($user->first_name." ".$user->last_name)), $code)))
  127. if(($code = preg_replace("/%%user_email%%/i", c_ws_plugin__s2member_utils_strings::esc_ds($user->user_email), $code)))
  128. if(($code = preg_replace("/%%user_login%%/i", c_ws_plugin__s2member_utils_strings::esc_ds($user->user_login), $code)))
  129. if(($code = preg_replace("/%%user_ip%%/i", c_ws_plugin__s2member_utils_strings::esc_ds($user_reg_ip), $code)))
  130. if(($code = preg_replace("/%%user_id%%/i", c_ws_plugin__s2member_utils_strings::esc_ds($user_id), $code)))
  131. {
  132. if(is_array($fields) && !empty($fields))
  133. foreach /* Custom Registration/Profile Fields. */($fields as $var => $val)
  134. if(!($code = preg_replace("/%%".preg_quote($var, "/")."%%/i", c_ws_plugin__s2member_utils_strings::esc_ds(maybe_serialize($val)), $code)))
  135. break;
  136. if(($code = trim(preg_replace("/%%(.+?)%%/i", "", $code))) /* This gets stored into a Transient Queue. */)
  137. {
  138. $paypal["s2member_log"][] = "Storing Modification Tracking Codes into a Transient Queue. These will be processed on-site.";
  139. set_transient("s2m_".md5("s2member_transient_modification_tracking_codes_".$paypal["subscr_id"]), $code, 43200);
  140. }
  141. }
  142. }
  143. }
  144. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  145. do_action("ws_plugin__s2member_during_paypal_return_during_subscr_modify", get_defined_vars());
  146. unset /* Unset defined __refs, __v. */($__refs, $__v);
  147. if(($redirection_url_after_modification = apply_filters("ws_plugin__s2member_redirection_url_after_modification", false, get_defined_vars())))
  148. {
  149. $paypal["s2member_log"][] = "Redirecting this Member to a custom URL after modification: ".$redirection_url_after_modification;
  150. wp_redirect($redirection_url_after_modification);
  151. }
  152. else // Else, use standard/default handling in this scenario. Have the Customer log in again.
  153. {
  154. $paypal["s2member_log"][] = "Redirecting Customer to the Login Page (after displaying a quick thank-you message). They need to log back in.";
  155. echo c_ws_plugin__s2member_return_templates::return_template($paypal["subscr_gateway"],
  156. '<strong>'._x("Thank you! You've been updated to:", "s2member-front", "s2member").'<br /><em>'.esc_html($paypal["item_name"]).'</em></strong>',
  157. _x("Please Log Back In (Click Here)", "s2member-front", "s2member"), wp_login_url());
  158. }
  159. }
  160. else // Else, unable to modify Subscription. The existing User ID is associated with an Administrator. Stopping here.
  161. {
  162. $paypal["s2member_log"][] = "Unable to modify Subscription. The existing User ID is associated with an Administrator. Stopping here. Otherwise, an Administrator could lose access. Please make sure that you are NOT logged in as an Administrator while testing.";
  163. $paypal["s2member_log"][] = "Redirecting Customer to the Home Page (after displaying an error message).";
  164. echo c_ws_plugin__s2member_return_templates::return_template($paypal["subscr_gateway"],
  165. _x('<strong>ERROR:</strong> Unable to modify Subscription.<br />Please contact Support for assistance.<br /><br />The existing User ID is associated with an Administrator. Stopping here. Otherwise, an Administrator could lose access. Please make sure that you are NOT logged in as an Administrator while testing.', "s2member-front", "s2member"),
  166. _x("Back To Home Page", "s2member-front", "s2member"), home_url("/"));
  167. }
  168. }
  169. else // Unable to modify Subscription. Could not get the existing User ID from the DB.
  170. {
  171. $paypal["s2member_log"][] = "Unable to modify Subscription. Could not get the existing User ID from the DB.";
  172. $paypal["s2member_log"][] = "Redirecting Customer to the Home Page (after displaying an error message).";
  173. echo c_ws_plugin__s2member_return_templates::return_template($paypal["subscr_gateway"],
  174. _x('<strong>ERROR:</strong> Unable to modify Subscription.<br />Please contact Support for assistance.<br /><br />Could not get the existing User ID from the DB.', "s2member-front", "s2member"),
  175. _x("Back To Home Page", "s2member-front", "s2member"), home_url("/"));
  176. }
  177. }
  178. else // Page Expired. Duplicate Return-Data.
  179. {
  180. $paypal["s2member_log"][] = "Page Expired. Duplicate Return-Data.";
  181. $paypal["s2member_log"][] = "s2Member `txn_type` identified as `subscr_modify`.";
  182. $paypal["s2member_log"][] = "Page Expired. Redirecting Customer to the Home Page (after displaying an error message).";
  183. echo c_ws_plugin__s2member_return_templates::return_template($paypal["subscr_gateway"],
  184. _x('<strong>Page Expired:</strong> Duplicate Return-Data.<br />Please contact Support if you need any assistance.', "s2member-front", "s2member"),
  185. _x("Back To Home Page", "s2member-front", "s2member"), home_url("/"));
  186. }
  187. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  188. do_action("ws_plugin__s2member_during_paypal_return_after_subscr_modify", get_defined_vars());
  189. unset /* Unset defined __refs, __v. */($__refs, $__v);
  190. return apply_filters("c_ws_plugin__s2member_paypal_return_in_subscr_modify_w_level", $paypal, get_defined_vars());
  191. }
  192. else return apply_filters("c_ws_plugin__s2member_paypal_return_in_subscr_modify_w_level", false, get_defined_vars());
  193. }
  194. }
  195. }
  196. ?>