PageRenderTime 25ms CodeModel.GetById 12ms RepoModel.GetById 1ms app.codeStats 0ms

/wp-content/plugins/s2member/includes/classes/user-deletions.inc.php

https://gitlab.com/Gashler/dp
PHP | 225 lines | 145 code | 32 blank | 48 comment | 50 complexity | 5bb466c5a1d0b488e66f4ce9b4171513 MD5 | raw file
  1. <?php
  2. /**
  3. * User deletion routines.
  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\User_Deletions
  15. * @since 3.5
  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_user_deletions"))
  20. {
  21. /**
  22. * User deletion routines.
  23. *
  24. * @package s2Member\User_Deletions
  25. * @since 3.5
  26. */
  27. class c_ws_plugin__s2member_user_deletions
  28. {
  29. /**
  30. * Handles Multisite User removal deletions.
  31. *
  32. * @package s2Member\User_Deletions
  33. * @since 3.5
  34. *
  35. * @attaches-to ``add_action("remove_user_from_blog");``
  36. *
  37. * @param int|str $user_id Numeric WordPress® User ID.
  38. * @param int|str $blog_id Numeric WordPress® Blog ID.
  39. * @param bool $s2says Optional. Defaults to false. If true, it's definitely OK to process this deletion?
  40. * The ``$s2says`` flag can be used when/if the routine is called directly for whatever reason.
  41. * @return null
  42. */
  43. public static function handle_ms_user_deletions ($user_id = FALSE, $blog_id = FALSE, $s2says = FALSE)
  44. {
  45. static $processed = array (); // No duplicate processing.
  46. global $pagenow; // Need this to detect the current admin page.
  47. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  48. do_action ("ws_plugin__s2member_before_handle_ms_user_deletions", get_defined_vars ());
  49. unset /* Unset defined __refs, __v. */ ($__refs, $__v);
  50. if (is_multisite () && empty ($processed[$user_id])) // Safeguard this routine against duplicate processing.
  51. {
  52. if (($s2says || (is_blog_admin () && $pagenow === "users.php")) && ($processed[$user_id] = true))
  53. // Do NOT react on this globally. There are many routines that remove Users for different/minor reasons.
  54. {
  55. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  56. do_action ("ws_plugin__s2member_during_handle_ms_user_deletions_before", get_defined_vars ());
  57. unset /* Unset defined __refs, __v. */ ($__refs, $__v);
  58. c_ws_plugin__s2member_user_deletions::handle_user_deletions ($user_id); // Hand this over.
  59. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  60. do_action ("ws_plugin__s2member_during_handle_ms_user_deletions_after", get_defined_vars ());
  61. unset /* Unset defined __refs, __v. */ ($__refs, $__v);
  62. }
  63. }
  64. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  65. do_action ("ws_plugin__s2member_after_handle_ms_user_deletions", get_defined_vars ());
  66. unset /* Unset defined __refs, __v. */ ($__refs, $__v);
  67. return /* Return for uniformity. */;
  68. }
  69. /**
  70. * Handles User removals/deletions.
  71. *
  72. * @package s2Member\User_Deletions
  73. * @since 3.5
  74. *
  75. * @attaches-to ``add_action("delete_user");``
  76. * @attaches-to ``add_action("wpmu_delete_user");``
  77. *
  78. * @param int|str $user_id Numeric WordPress® User ID.
  79. * @return null
  80. */
  81. public static function handle_user_deletions ($user_id = FALSE)
  82. {
  83. static $processed = array (); // No duplicate processing.
  84. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  85. do_action ("ws_plugin__s2member_before_handle_user_deletions", get_defined_vars ());
  86. unset /* Unset defined __refs, __v. */ ($__refs, $__v);
  87. if (empty ($processed[$user_id]) && ($processed[$user_id] = true)) // Safeguard this routine against duplicate processing.
  88. {
  89. $eot_del_type = // Configure EOT/Del type (possibly through a global variable made available in other routines).
  90. (!empty ($GLOBALS["ws_plugin__s2member_eot_del_type"])) ? // Is the global available for use?
  91. $GLOBALS["ws_plugin__s2member_eot_del_type"] : "user-removal-deletion"; // Else use default.
  92. $custom = get_user_option ("s2member_custom", $user_id); // An EOT Notification is triggered, EVEN if empty.
  93. $subscr_id = get_user_option ("s2member_subscr_id", $user_id); // And also, EVEN if this is empty.
  94. $fields = get_user_option ("s2member_custom_fields", $user_id); // Used in API Notifications.
  95. $user_reg_ip = get_user_option ("s2member_registration_ip", $user_id); // In API Notifications.
  96. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  97. do_action ("ws_plugin__s2member_during_handle_user_before_deletions", get_defined_vars ());
  98. do_action ("ws_plugin__s2member_during_collective_eots", $user_id, get_defined_vars (), $eot_del_type, "removal-deletion");
  99. unset /* Unset defined __refs, __v. */ ($__refs, $__v);
  100. delete_user_option ($user_id, "s2member_custom"); // Remove User options (for this Blog).
  101. delete_user_option ($user_id, "s2member_subscr_id");
  102. delete_user_option ($user_id, "s2member_subscr_gateway");
  103. delete_user_option ($user_id, "s2member_custom_fields");
  104. delete_user_option ($user_id, "s2member_registration_ip");
  105. delete_user_option ($user_id, "s2member_ipn_signup_vars");
  106. delete_user_option ($user_id, "s2member_paid_registration_times");
  107. delete_user_option ($user_id, "s2member_sp_references");
  108. delete_user_option ($user_id, "s2member_last_status_scan");
  109. delete_user_option ($user_id, "s2member_first_payment_txn_id");
  110. delete_user_option ($user_id, "s2member_last_payment_time");
  111. delete_user_option ($user_id, "s2member_auto_eot_time");
  112. delete_user_option ($user_id, "s2member_file_download_access_arc");
  113. delete_user_option ($user_id, "s2member_file_download_access_log");
  114. delete_user_option ($user_id, "s2member_login_counter");
  115. delete_user_option ($user_id, "s2member_notes");
  116. if (is_object ($user = new WP_User ($user_id)) && $user->ID && $GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["eot_del_notification_urls"] && is_array ($cv = preg_split ("/\|/", $custom)))
  117. {
  118. foreach (preg_split ("/[\r\n\t]+/", $GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["eot_del_notification_urls"]) as $url) // Handle EOT Notifications on user deletion.
  119. if (($url = preg_replace ("/%%cv([0-9]+)%%/ei", 'urlencode(trim($cv[$1]))', $url)) && ($url = preg_replace ("/%%eot_del_type%%/i", c_ws_plugin__s2member_utils_strings::esc_ds (urlencode ($eot_del_type)), $url)) && ($url = preg_replace ("/%%subscr_id%%/i", c_ws_plugin__s2member_utils_strings::esc_ds (urlencode ($subscr_id)), $url)))
  120. if (($url = preg_replace ("/%%user_first_name%%/i", c_ws_plugin__s2member_utils_strings::esc_ds (urlencode ($user->first_name)), $url)) && ($url = preg_replace ("/%%user_last_name%%/i", c_ws_plugin__s2member_utils_strings::esc_ds (urlencode ($user->last_name)), $url)))
  121. if (($url = preg_replace ("/%%user_full_name%%/i", c_ws_plugin__s2member_utils_strings::esc_ds (urlencode (trim ($user->first_name . " " . $user->last_name))), $url)))
  122. if (($url = preg_replace ("/%%user_email%%/i", c_ws_plugin__s2member_utils_strings::esc_ds (urlencode ($user->user_email)), $url)))
  123. if (($url = preg_replace ("/%%user_login%%/i", c_ws_plugin__s2member_utils_strings::esc_ds (urlencode ($user->user_login)), $url)))
  124. if (($url = preg_replace ("/%%user_ip%%/i", c_ws_plugin__s2member_utils_strings::esc_ds (urlencode ($user_reg_ip)), $url)))
  125. if (($url = preg_replace ("/%%user_id%%/i", c_ws_plugin__s2member_utils_strings::esc_ds (urlencode ($user_id)), $url)))
  126. {
  127. if (is_array ($fields) && !empty ($fields))
  128. foreach /* Custom Registration/Profile Fields. */ ($fields as $var => $val)
  129. if (!($url = preg_replace ("/%%" . preg_quote ($var, "/") . "%%/i", c_ws_plugin__s2member_utils_strings::esc_ds (urlencode (maybe_serialize ($val))), $url)))
  130. break;
  131. if (($url = trim (preg_replace ("/%%(.+?)%%/i", "", $url))))
  132. c_ws_plugin__s2member_utils_urls::remote ($url);
  133. }
  134. }
  135. if (is_object ($user = new WP_User ($user_id)) && $user->ID && $GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["eot_del_notification_recipients"] && is_array ($cv = preg_split ("/\|/", $custom)))
  136. {
  137. $email_configs_were_on = c_ws_plugin__s2member_email_configs::email_config_status ();
  138. c_ws_plugin__s2member_email_configs::email_config_release ();
  139. $msg = $sbj = "(s2Member / API Notification Email) - EOT/Deletion";
  140. $msg .= "\n\n"; // Spacing in the message body.
  141. $msg .= "eot_del_type: %%eot_del_type%%\n";
  142. $msg .= "subscr_id: %%subscr_id%%\n";
  143. $msg .= "user_first_name: %%user_first_name%%\n";
  144. $msg .= "user_last_name: %%user_last_name%%\n";
  145. $msg .= "user_full_name: %%user_full_name%%\n";
  146. $msg .= "user_email: %%user_email%%\n";
  147. $msg .= "user_login: %%user_login%%\n";
  148. $msg .= "user_ip: %%user_ip%%\n";
  149. $msg .= "user_id: %%user_id%%\n";
  150. if (is_array ($fields) && !empty ($fields))
  151. foreach ($fields as $var => $val)
  152. $msg .= $var . ": %%" . $var . "%%\n";
  153. $msg .= "cv0: %%cv0%%\n";
  154. $msg .= "cv1: %%cv1%%\n";
  155. $msg .= "cv2: %%cv2%%\n";
  156. $msg .= "cv3: %%cv3%%\n";
  157. $msg .= "cv4: %%cv4%%\n";
  158. $msg .= "cv5: %%cv5%%\n";
  159. $msg .= "cv6: %%cv6%%\n";
  160. $msg .= "cv7: %%cv7%%\n";
  161. $msg .= "cv8: %%cv8%%\n";
  162. $msg .= "cv9: %%cv9%%";
  163. if (($msg = preg_replace ("/%%cv([0-9]+)%%/ei", 'trim($cv[$1])', $msg)) && ($msg = preg_replace ("/%%eot_del_type%%/i", c_ws_plugin__s2member_utils_strings::esc_ds ($eot_del_type), $msg)) && ($msg = preg_replace ("/%%subscr_id%%/i", c_ws_plugin__s2member_utils_strings::esc_ds ($subscr_id), $msg)))
  164. if (($msg = preg_replace ("/%%user_first_name%%/i", c_ws_plugin__s2member_utils_strings::esc_ds ($user->first_name), $msg)) && ($msg = preg_replace ("/%%user_last_name%%/i", c_ws_plugin__s2member_utils_strings::esc_ds ($user->last_name), $msg)))
  165. if (($msg = preg_replace ("/%%user_full_name%%/i", c_ws_plugin__s2member_utils_strings::esc_ds (trim ($user->first_name . " " . $user->last_name)), $msg)))
  166. if (($msg = preg_replace ("/%%user_email%%/i", c_ws_plugin__s2member_utils_strings::esc_ds ($user->user_email), $msg)))
  167. if (($msg = preg_replace ("/%%user_login%%/i", c_ws_plugin__s2member_utils_strings::esc_ds ($user->user_login), $msg)))
  168. if (($msg = preg_replace ("/%%user_ip%%/i", c_ws_plugin__s2member_utils_strings::esc_ds ($user_reg_ip), $msg)))
  169. if (($msg = preg_replace ("/%%user_id%%/i", c_ws_plugin__s2member_utils_strings::esc_ds ($user_id), $msg)))
  170. {
  171. if (is_array ($fields) && !empty ($fields))
  172. foreach /* Custom Registration/Profile Fields. */ ($fields as $var => $val)
  173. if (!($msg = preg_replace ("/%%" . preg_quote ($var, "/") . "%%/i", c_ws_plugin__s2member_utils_strings::esc_ds (maybe_serialize ($val)), $msg)))
  174. break;
  175. if ($sbj && ($msg = trim (preg_replace ("/%%(.+?)%%/i", "", $msg)))) // Still have a ``$sbj`` and a ``$msg``?
  176. foreach (c_ws_plugin__s2member_utils_strings::parse_emails ($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["eot_del_notification_recipients"]) as $recipient)
  177. wp_mail ($recipient, apply_filters ("ws_plugin__s2member_eot_del_notification_email_sbj", $sbj, get_defined_vars ()), apply_filters ("ws_plugin__s2member_eot_del_notification_email_msg", $msg, get_defined_vars ()), "Content-Type: text/plain; charset=UTF-8");
  178. }
  179. if ($email_configs_were_on) // Back on?
  180. c_ws_plugin__s2member_email_configs::email_config ();
  181. }
  182. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  183. do_action ("ws_plugin__s2member_during_handle_user_deletions", get_defined_vars ());
  184. unset /* Unset defined __refs, __v. */ ($__refs, $__v);
  185. }
  186. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  187. do_action ("ws_plugin__s2member_after_handle_user_deletions", get_defined_vars ());
  188. unset /* Unset defined __refs, __v. */ ($__refs, $__v);
  189. return /* Return for uniformity. */;
  190. }
  191. }
  192. }
  193. ?>