PageRenderTime 29ms CodeModel.GetById 17ms RepoModel.GetById 0ms app.codeStats 0ms

/wp-content/plugins/s2member/includes/classes/list-servers.inc.php

https://gitlab.com/Gashler/dp
PHP | 391 lines | 239 code | 56 blank | 96 comment | 134 complexity | 4e2108ae7def4cafbb44836882443554 MD5 | raw file
  1. <?php
  2. /**
  3. * List Server integrations.
  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\List_Servers
  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_list_servers"))
  20. {
  21. /**
  22. * List Server integrations.
  23. *
  24. * @package s2Member\List_Servers
  25. * @since 3.5
  26. */
  27. class c_ws_plugin__s2member_list_servers
  28. {
  29. /**
  30. * Determines whether or not any List Servers have been integrated.
  31. *
  32. * @package s2Member\List_Servers
  33. * @since 3.5
  34. *
  35. * @return bool True if List Servers have been integrated, else false.
  36. */
  37. public static function list_servers_integrated ()
  38. {
  39. do_action ("ws_plugin__s2member_before_list_servers_integrated", get_defined_vars ());
  40. for /* Go through each Level; looking for a configured list. */ ($n = 0; $n <= $GLOBALS["WS_PLUGIN__"]["s2member"]["c"]["levels"]; $n++)
  41. if (!empty ($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["level" . $n . "_mailchimp_list_ids"]) || !empty ($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["level" . $n . "_aweber_list_ids"]))
  42. return apply_filters ("ws_plugin__s2member_list_servers_integrated", true, get_defined_vars ());
  43. return apply_filters ("ws_plugin__s2member_list_servers_integrated", false, get_defined_vars ());
  44. }
  45. /**
  46. * Processes List Server integrations for s2Member.
  47. *
  48. * @package s2Member\List_Servers
  49. * @since 3.5
  50. *
  51. * @param str $role A WordPress Role ID/Name, such as `subscriber`, or `s2member_level1`.
  52. * @param int|str $level A numeric s2Member Access Level number.
  53. * @param str $login Username for the User.
  54. * @param str $pass Plain Text Password for the User.
  55. * @param str $email Email Address for the User.
  56. * @param str $fname First Name for the User.
  57. * @param str $lname Last Name for the User.
  58. * @param str $ip IP Address for the User.
  59. * @param bool $opt_in Defaults to false; must be set to true. Indicates the User IS opting in.
  60. * @param bool $double_opt_in Defaults to true. If false, no email confirmation is required. Use at your own risk.
  61. * @param int|str $user_id A WordPress User ID, numeric string or integer.
  62. * @return bool True if at least one List Server is processed successfully, else false.
  63. *
  64. * @todo Integrate {@link https://labs.aweber.com/docs/php-library-walkthrough AWeber's API}.
  65. * @todo Add a separate option for mail debugging; or consolidate?
  66. * @todo Integrate AWeber® API (much like the MailChimp® API).
  67. */
  68. public static function process_list_servers ($role = FALSE, $level = FALSE, $login = FALSE, $pass = FALSE, $email = FALSE, $fname = FALSE, $lname = FALSE, $ip = FALSE, $opt_in = FALSE, $double_opt_in = TRUE, $user_id = FALSE)
  69. {
  70. global /* For Multisite support. */ $current_site, $current_blog;
  71. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  72. do_action ("ws_plugin__s2member_before_process_list_servers", get_defined_vars ());
  73. unset /* Unset defined __refs, __v. */ ($__refs, $__v);
  74. if (c_ws_plugin__s2member_list_servers::list_servers_integrated () && ($args = func_get_args ()) && $role && is_string ($role) && is_numeric ($level) && $login && is_string ($login) && is_string ($pass = (string)$pass) && $email && is_string ($email) && is_email ($email) && is_string ($fname = (string)$fname) && is_string ($lname = (string)$lname) && is_string ($ip = (string)$ip) && is_bool ($opt_in = (bool)$opt_in) && $opt_in && is_bool ($double_opt_in = (bool)$double_opt_in) && $user_id && is_numeric ($user_id) && is_object ($user = new WP_User ($user_id)) && !empty ($user->ID))
  75. {
  76. $ccaps = /* Get Custom Capabilities. */ implode (",", c_ws_plugin__s2member_user_access::user_access_ccaps ($user));
  77. $email_configs_were_on = /* s2Member Filters enabled? */ c_ws_plugin__s2member_email_configs::email_config_status ();
  78. c_ws_plugin__s2member_email_configs::email_config_release /* Release s2Member Filters before we begin this routine. */ ();
  79. if (!empty ($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["mailchimp_api_key"]) && !empty ($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["level" . $level . "_mailchimp_list_ids"]))
  80. {
  81. if /* Include the MailChimp® API Class here. */ (!class_exists ("NC_MCAPI"))
  82. include_once /* MailChimp® API (no-conflict version). */ dirname (dirname (__FILE__)) . "/externals/mailchimp/nc-mcapi.inc.php";
  83. $mcapi = /* MailChimp® API (no-conflict). */ new NC_MCAPI ($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["mailchimp_api_key"], true);
  84. foreach (preg_split ("/[\r\n\t;,]+/", $GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["level" . $level . "_mailchimp_list_ids"]) as $mailchimp_list)
  85. {
  86. $mailchimp = array ("function" => __FUNCTION__, "func_get_args" => $args, "api_method" => "listSubscribe");
  87. if /* Trim this up. NO trailing white space. */ (($mailchimp["list"] = trim ($mailchimp_list)))
  88. {
  89. if /* Also contains Interest Groups? */ (strpos ($mailchimp["list"], "::") !== false)
  90. {
  91. list ($mailchimp["list_id"], $mailchimp["interest_groups_title"], $mailchimp["interest_groups"]) = preg_split ("/\:\:/", $mailchimp["list"], 3);
  92. if /* This is a title configured by the list master. */ (($mailchimp["interest_groups_title"] = trim ($mailchimp["interest_groups_title"])))
  93. if (($mailchimp["interest_groups"] = (trim ($mailchimp["interest_groups"])) ? preg_split ("/\|/", trim ($mailchimp["interest_groups"])) : false))
  94. $mailchimp["interest_groups"] = array ("GROUPINGS" => array (array ("name" => $mailchimp["interest_groups_title"], "groups" => implode (",", $mailchimp["interest_groups"]))));
  95. if /* Need to double-check this. If empty, skip over this entry. */ (empty ($mailchimp["list_id"]))
  96. continue /* Continue to next List, if there is one. */;
  97. }
  98. else // Else, it's just a List ID.
  99. $mailchimp["list_id"] = $mailchimp["list"];
  100. $mailchimp["merge_array"] = array ("MERGE1" => $fname, "MERGE2" => $lname, "OPTIN_IP" => $ip, "OPTIN_TIME" => date ("Y-m-d H:i:s"));
  101. $mailchimp["merge_array"] = ($mailchimp["interest_groups"]) ? array_merge ($mailchimp["merge_array"], $mailchimp["interest_groups"]) : $mailchimp["merge_array"];
  102. $mailchimp["merge_array"] = apply_filters ( /* Deprecated. */"ws_plugin__s2member_mailchimp_array", $mailchimp["merge_array"], get_defined_vars ());
  103. // Filter: `ws_plugin__s2member_mailchimp_array` deprecated in v110523. Please use Filter: `ws_plugin__s2member_mailchimp_merge_array`.
  104. if ($mailchimp["api_response"] = $mcapi->{$mailchimp["api_method"]}($mailchimp["list_id"], $email, // See: `http://apidocs.mailchimp.com/` for full details.
  105. ($mailchimp["api_merge_array"] = apply_filters ("ws_plugin__s2member_mailchimp_merge_array", $mailchimp["merge_array"], get_defined_vars ())), // Configured merge array above.
  106. ($mailchimp["api_email_type"] = apply_filters ("ws_plugin__s2member_mailchimp_email_type", "html", get_defined_vars ())), // Type of email to receive (i.e. html,text,mobile).
  107. ($mailchimp["api_double_optin"] = apply_filters ("ws_plugin__s2member_mailchimp_double_optin", $double_opt_in, get_defined_vars ())), // Abuse of this may cause account suspension.
  108. ($mailchimp["api_update_existing"] = apply_filters ("ws_plugin__s2member_mailchimp_update_existing", false, get_defined_vars ())), // Existing subscribers should be updated with this?
  109. ($mailchimp["api_replace_interests"] = apply_filters ("ws_plugin__s2member_mailchimp_replace_interests", true, get_defined_vars ())), // Replace interest groups? (only if provided).
  110. ($mailchimp["api_send_welcome"] = apply_filters ("ws_plugin__s2member_mailchimp_send_welcome", false, get_defined_vars ())))) // See documentation. This is a weird option.
  111. $mailchimp["api_success"] = $success = true; // Flag indicating that we DO have a successful processing of a new List; affects the function's overall return value.
  112. $mailchimp["api_properties"] = $mcapi; // Include API instance too; as it contains some additional information after each method is processed (need this in the logs).
  113. $logt = c_ws_plugin__s2member_utilities::time_details ();
  114. $logv = c_ws_plugin__s2member_utilities::ver_details ();
  115. $logm = c_ws_plugin__s2member_utilities::mem_details ();
  116. $log4 = $_SERVER["HTTP_HOST"] . $_SERVER["REQUEST_URI"] . "\nUser-Agent: " . $_SERVER["HTTP_USER_AGENT"];
  117. $log4 = (is_multisite () && !is_main_site ()) ? ($_log4 = $current_blog->domain . $current_blog->path) . "\n" . $log4 : $log4;
  118. $log2 = (is_multisite () && !is_main_site ()) ? "mailchimp-api-4-" . trim (preg_replace ("/[^a-z0-9]/i", "-", $_log4), "-") . ".log" : "mailchimp-api.log";
  119. if ($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["gateway_debug_logs"])
  120. if (is_dir ($logs_dir = $GLOBALS["WS_PLUGIN__"]["s2member"]["c"]["logs_dir"]))
  121. if (is_writable ($logs_dir) && c_ws_plugin__s2member_utils_logs::archive_oversize_log_files ())
  122. file_put_contents ($logs_dir . "/" . $log2,
  123. "LOG ENTRY: ".$logt . "\n" . $logv . "\n" . $logm . "\n" . $log4 . "\n" .
  124. c_ws_plugin__s2member_utils_logs::conceal_private_info(var_export ($mailchimp, true)) . "\n\n",
  125. FILE_APPEND);
  126. }
  127. }
  128. }
  129. if (!empty ($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["level" . $level . "_aweber_list_ids"]))
  130. {
  131. foreach (preg_split ("/[\r\n\t\s;,]+/", $GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["level" . $level . "_aweber_list_ids"]) as $aweber_list)
  132. {
  133. $aweber = array ("function" => __FUNCTION__, "func_get_args" => $args, "wp_mail_method" => "listSubscribe");
  134. if /* Trim this up. NO trailing white space. */ (($aweber["list_id"] = trim ($aweber_list)))
  135. {
  136. $aweber["bcc"] = apply_filters ("ws_plugin__s2member_aweber_bcc", false, get_defined_vars ());
  137. $aweber["pass_inclusion"] = (apply_filters ("ws_plugin__s2member_aweber_pass_inclusion", false, get_defined_vars ()) && $pass) ? "\nPass: " . $pass : false;
  138. $buyer = ($fname || $lname) ? trim ($fname . " " . $lname) : /* Must have. AWeber's PayPal Email Parser chokes on an empty value. */ ucwords (preg_replace ("/^(.+?)@.+/", "$1", $email));
  139. if ($aweber["wp_mail_response"] = wp_mail ($aweber["list_id"] . "@aweber.com", // AWeber® List ID converts to email address @aweber.com.
  140. ($aweber["wp_mail_sbj"] = apply_filters ("ws_plugin__s2member_aweber_sbj", "s2Member Subscription Request", get_defined_vars ())), // These Filters make it possible to customize these emails.
  141. ($aweber["wp_mail_msg"] = apply_filters ("ws_plugin__s2member_aweber_msg", "s2Member Subscription Request\ns2Member w/ PayPal Email ID\nAd Tracking: s2Member-" . ((is_multisite () && !is_main_site ()) ? $current_blog->domain . $current_blog->path : $_SERVER["HTTP_HOST"]) . "\nEMail Address: " . $email . "\nBuyer: " . $buyer . "\nFull Name: " . trim ($fname . " " . $lname) . "\nFirst Name: " . $fname . "\nLast Name: " . $lname . "\nIP Address: " . $ip . "\nUser ID: " . $user_id . "\nLogin: " . $login . $aweber["pass_inclusion"] . "\nRole: " . $role . "\nLevel: " . $level . "\nCCaps: " . $ccaps . "\n - end.", get_defined_vars ())),
  142. ($aweber["wp_mail_headers"] = "From: \"" . preg_replace ('/"/', "'", $GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["reg_email_from_name"]) . "\" <" . $GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["reg_email_from_email"] . ">" . (($aweber["bcc"]) ? "\r\nBcc: " . $aweber["bcc"] : "") . "\r\nContent-Type: text/plain; charset=UTF-8")))
  143. $aweber["wp_mail_success"] = $success = true; // Flag indicating that we DO have a successful processing of a new List; affects the function's overall return value.
  144. $logt = c_ws_plugin__s2member_utilities::time_details ();
  145. $logv = c_ws_plugin__s2member_utilities::ver_details ();
  146. $logm = c_ws_plugin__s2member_utilities::mem_details ();
  147. $log4 = $_SERVER["HTTP_HOST"] . $_SERVER["REQUEST_URI"] . "\nUser-Agent: " . $_SERVER["HTTP_USER_AGENT"];
  148. $log4 = (is_multisite () && !is_main_site ()) ? ($_log4 = $current_blog->domain . $current_blog->path) . "\n" . $log4 : $log4;
  149. $log2 = (is_multisite () && !is_main_site ()) ? "aweber-api-4-" . trim (preg_replace ("/[^a-z0-9]/i", "-", $_log4), "-") . ".log" : "aweber-api.log";
  150. if ($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["gateway_debug_logs"])
  151. if (is_dir ($logs_dir = $GLOBALS["WS_PLUGIN__"]["s2member"]["c"]["logs_dir"]))
  152. if (is_writable ($logs_dir) && c_ws_plugin__s2member_utils_logs::archive_oversize_log_files ())
  153. file_put_contents ($logs_dir . "/" . $log2,
  154. "LOG ENTRY: ".$logt . "\n" . $logv . "\n" . $logm . "\n" . $log4 . "\n" .
  155. c_ws_plugin__s2member_utils_logs::conceal_private_info(var_export ($aweber, true)) . "\n\n",
  156. FILE_APPEND);
  157. }
  158. }
  159. }
  160. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  161. do_action ("ws_plugin__s2member_during_process_list_servers", get_defined_vars ());
  162. unset /* Unset defined __refs, __v. */ ($__refs, $__v);
  163. if /* Back on? */ ($email_configs_were_on)
  164. c_ws_plugin__s2member_email_configs::email_config ();
  165. }
  166. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  167. do_action ("ws_plugin__s2member_after_process_list_servers", get_defined_vars ());
  168. unset /* Unset defined __refs, __v. */ ($__refs, $__v);
  169. return apply_filters ("ws_plugin__s2member_process_list_servers", (isset ($success) && $success), get_defined_vars ());
  170. }
  171. /**
  172. * Processes List Server removals for s2Member.
  173. *
  174. * @package s2Member\List_Servers
  175. * @since 3.5
  176. *
  177. * @param str $role A WordPress Role ID/Name, such as `subscriber`, or `s2member_level1`.
  178. * @param int|str $level A numeric s2Member Access Level number.
  179. * @param str $login Username for the User.
  180. * @param str $pass Plain Text Password for the User.
  181. * @param str $email Email address for the User.
  182. * @param str $fname First Name for the User.
  183. * @param str $lname Last Name for the User.
  184. * @param str $ip IP Address for the User.
  185. * @param bool $opt_out Defaults to false; must be set to true. Indicates the User IS opting out.
  186. * @param int|str $user_id A WordPress User ID, numeric string or integer.
  187. * @return bool True if at least one List Server is processed successfully, else false.
  188. *
  189. * @todo Integrate {@link https://labs.aweber.com/docs/php-library-walkthrough AWeber's API}.
  190. * @todo Add a separate option for mail debugging; or consolidate?
  191. * @todo Integrate AWeber® API (much like the MailChimp® API).
  192. */
  193. public static function process_list_server_removals ($role = FALSE, $level = FALSE, $login = FALSE, $pass = FALSE, $email = FALSE, $fname = FALSE, $lname = FALSE, $ip = FALSE, $opt_out = FALSE, $user_id = FALSE)
  194. {
  195. global /* For Multisite support. */ $current_site, $current_blog;
  196. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  197. do_action ("ws_plugin__s2member_before_process_list_server_removals", get_defined_vars ());
  198. unset /* Unset defined __refs, __v. */ ($__refs, $__v);
  199. if (c_ws_plugin__s2member_list_servers::list_servers_integrated () && ($args = func_get_args ()) && $role && is_string ($role) && is_numeric ($level) && $login && is_string ($login) && is_string ($pass = (string)$pass) && $email && is_string ($email) && is_email ($email) && is_string ($fname = (string)$fname) && is_string ($lname = (string)$lname) && is_string ($ip = (string)$ip) && is_bool ($opt_out = (bool)$opt_out) && $opt_out && $user_id && is_numeric ($user_id) && is_object ($user = new WP_User ($user_id)) && !empty ($user->ID))
  200. {
  201. $ccaps = /* Get Custom Capabilities. */ implode (",", c_ws_plugin__s2member_user_access::user_access_ccaps ($user));
  202. $email_configs_were_on = /* s2Member Filters enabled? */ c_ws_plugin__s2member_email_configs::email_config_status ();
  203. c_ws_plugin__s2member_email_configs::email_config_release /* Release s2Member Filters before we begin this routine. */ ();
  204. if (!empty ($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["mailchimp_api_key"]) && !empty ($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["level" . $level . "_mailchimp_list_ids"]))
  205. {
  206. if /* Include the MailChimp® API Class here. */ (!class_exists ("NC_MCAPI"))
  207. include_once /* MailChimp® API (no-conflict version). */ dirname (dirname (__FILE__)) . "/externals/mailchimp/nc-mcapi.inc.php";
  208. $mcapi = /* MailChimp® API (no-conflict). */ new NC_MCAPI ($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["mailchimp_api_key"], true);
  209. foreach (preg_split ("/[\r\n\t;,]+/", $GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["level" . $level . "_mailchimp_list_ids"]) as $mailchimp_list)
  210. {
  211. $mailchimp = array ("function" => __FUNCTION__, "func_get_args" => $args, "api_removal_method" => "listUnsubscribe");
  212. if /* Trim & strip groups. */ (($mailchimp["list_id"] = trim (preg_replace ("/\:\:.*$/", "", $mailchimp_list))))
  213. {
  214. if ($mailchimp["api_removal_response"] = $mcapi->{$mailchimp["api_removal_method"]}($mailchimp["list_id"], $email, // See: `http://apidocs.mailchimp.com/`.
  215. ($mailchimp["api_removal_delete_member"] = apply_filters ("ws_plugin__s2member_mailchimp_removal_delete_member", false, get_defined_vars ())), // Completely delete?
  216. ($mailchimp["api_removal_send_goodbye"] = apply_filters ("ws_plugin__s2member_mailchimp_removal_send_goodbye", false, get_defined_vars ())), // Send goodbye letter?
  217. ($mailchimp["api_removal_send_notify"] = apply_filters ("ws_plugin__s2member_mailchimp_removal_send_notify", false, get_defined_vars ())))) // Send notification?
  218. $mailchimp["api_removal_success"] = $removal_success = true; // Flag indicating that we DO have a successful removal; affects the function's overall return value.
  219. $mailchimp["api_removal_properties"] = $mcapi; // Include API instance too; as it contains some additional information after each method is processed (need this in the logs).
  220. $logt = c_ws_plugin__s2member_utilities::time_details ();
  221. $logv = c_ws_plugin__s2member_utilities::ver_details ();
  222. $logm = c_ws_plugin__s2member_utilities::mem_details ();
  223. $log4 = $_SERVER["HTTP_HOST"] . $_SERVER["REQUEST_URI"] . "\nUser-Agent: " . $_SERVER["HTTP_USER_AGENT"];
  224. $log4 = (is_multisite () && !is_main_site ()) ? ($_log4 = $current_blog->domain . $current_blog->path) . "\n" . $log4 : $log4;
  225. $log2 = (is_multisite () && !is_main_site ()) ? "mailchimp-api-4-" . trim (preg_replace ("/[^a-z0-9]/i", "-", $_log4), "-") . ".log" : "mailchimp-api.log";
  226. if ($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["gateway_debug_logs"])
  227. if (is_dir ($logs_dir = $GLOBALS["WS_PLUGIN__"]["s2member"]["c"]["logs_dir"]))
  228. if (is_writable ($logs_dir) && c_ws_plugin__s2member_utils_logs::archive_oversize_log_files ())
  229. file_put_contents ($logs_dir . "/" . $log2,
  230. "LOG ENTRY: ".$logt . "\n" . $logv . "\n" . $logm . "\n" . $log4 . "\n" .
  231. c_ws_plugin__s2member_utils_logs::conceal_private_info(var_export ($mailchimp, true)) . "\n\n",
  232. FILE_APPEND);
  233. }
  234. }
  235. }
  236. if (!empty ($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["level" . $level . "_aweber_list_ids"]))
  237. {
  238. foreach (preg_split ("/[\r\n\t\s;,]+/", $GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["level" . $level . "_aweber_list_ids"]) as $aweber_list)
  239. {
  240. $aweber = array ("function" => __FUNCTION__, "func_get_args" => $args, "wp_mail_removal_method" => "listUnsubscribe");
  241. if /* Trim this up. NO trailing white space. */ (($aweber["list_id"] = trim ($aweber_list)))
  242. {
  243. $aweber["removal_bcc"] = apply_filters ("ws_plugin__s2member_aweber_removal_bcc", false, get_defined_vars ());
  244. c_ws_plugin__s2member_email_configs::email_config (); // Email configs MUST be ON for removal requests.
  245. // The `From:` address MUST match AWeber account. See: <http://www.aweber.com/faq/questions/62/Can+I+Unsubscribe+People+Via+Email%3F>.
  246. if ($aweber["wp_mail_removal_response"] = wp_mail ($aweber["list_id"] . "@aweber.com", // AWeber® List ID converts to email address @aweber.com.
  247. ($aweber["wp_mail_removal_sbj"] = apply_filters ("ws_plugin__s2member_aweber_removal_sbj", "REMOVE#" . $email . "#s2Member#" . $aweber["list_id"], get_defined_vars ())), // Bug fix. AWeber® does not like dots (possibly other chars) in the Ad Tracking field. Now using just: `s2Member`.
  248. ($aweber["wp_mail_removal_msg"] = "REMOVE"), ($aweber["wp_mail_removal_headers"] = "From: \"" . preg_replace ('/"/', "'", $GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["reg_email_from_name"]) . "\" <" . $GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["reg_email_from_email"] . ">" . (($aweber["removal_bcc"]) ? "\r\nBcc: " . $aweber["removal_bcc"] : "") . "\r\nContent-Type: text/plain; charset=UTF-8")))
  249. $aweber["wp_mail_removal_success"] = $removal_success = true; // Flag indicating that we DO have a successful removal; affects the function's overall return value.
  250. c_ws_plugin__s2member_email_configs::email_config_release /* Release. */ ();
  251. $logt = c_ws_plugin__s2member_utilities::time_details ();
  252. $logv = c_ws_plugin__s2member_utilities::ver_details ();
  253. $logm = c_ws_plugin__s2member_utilities::mem_details ();
  254. $log4 = $_SERVER["HTTP_HOST"] . $_SERVER["REQUEST_URI"] . "\nUser-Agent: " . $_SERVER["HTTP_USER_AGENT"];
  255. $log4 = (is_multisite () && !is_main_site ()) ? ($_log4 = $current_blog->domain . $current_blog->path) . "\n" . $log4 : $log4;
  256. $log2 = (is_multisite () && !is_main_site ()) ? "aweber-api-4-" . trim (preg_replace ("/[^a-z0-9]/i", "-", $_log4), "-") . ".log" : "aweber-api.log";
  257. if ($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["gateway_debug_logs"])
  258. if (is_dir ($logs_dir = $GLOBALS["WS_PLUGIN__"]["s2member"]["c"]["logs_dir"]))
  259. if (is_writable ($logs_dir) && c_ws_plugin__s2member_utils_logs::archive_oversize_log_files ())
  260. file_put_contents ($logs_dir . "/" . $log2,
  261. "LOG ENTRY: ".$logt . "\n" . $logv . "\n" . $logm . "\n" . $log4 . "\n" .
  262. c_ws_plugin__s2member_utils_logs::conceal_private_info(var_export ($aweber, true)) . "\n\n",
  263. FILE_APPEND);
  264. }
  265. }
  266. }
  267. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  268. do_action ("ws_plugin__s2member_during_process_list_server_removals", get_defined_vars ());
  269. unset /* Unset defined __refs, __v. */ ($__refs, $__v);
  270. if /* Back on? */ ($email_configs_were_on)
  271. c_ws_plugin__s2member_email_configs::email_config ();
  272. }
  273. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  274. do_action ("ws_plugin__s2member_after_process_list_server_removals", get_defined_vars ());
  275. unset /* Unset defined __refs, __v. */ ($__refs, $__v);
  276. return apply_filters ("ws_plugin__s2member_process_list_server_removals", (isset ($removal_success) && $removal_success), get_defined_vars ());
  277. }
  278. /**
  279. * Listens to Collective EOT/MOD Events processed internally by s2Member.
  280. *
  281. * This is only applicable when ``["custom_reg_auto_opt_outs"]`` contains related Event(s).
  282. *
  283. * @package s2Member\List_Servers
  284. * @since 3.5
  285. *
  286. * @attaches-to ``add_action("ws_plugin__s2member_during_collective_mods");``
  287. * @attaches-to ``add_action("ws_plugin__s2member_during_collective_eots");``
  288. *
  289. * @param int|str $user_id Required. A WordPress® User ID, numeric string or integer.
  290. * @param array $vars Required. An array of defined variables passed by the calling Hook.
  291. * @param str $event Required. A specific event that triggered this call from the Action Hook.
  292. * @param str $event_spec Required. A specific event specification *(a broader classification)*.
  293. * @param str $mod_new_role Required if ``$event_spec === "modification"`` (but can be empty). Role the User is being modified to.
  294. * @param str $mod_new_user Optional. If ``$event_spec === "modification"``, the new User object with current details.
  295. * @param str $mod_old_user Optional. If ``$event_spec === "modification"``, the old/previous User obj with old details.
  296. * @return null This function does not have a return value.
  297. */
  298. public static function auto_process_list_server_removals ($user_id = FALSE, $vars = FALSE, $event = FALSE, $event_spec = FALSE, $mod_new_role = FALSE, $mod_new_user = FALSE, $mod_old_user = FALSE)
  299. {
  300. global /* For Multisite support. */ $current_site, $current_blog;
  301. static $auto_processed = /* Process ONE time for each User. */ array ();
  302. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  303. do_action ("ws_plugin__s2member_before_auto_process_list_server_removals", get_defined_vars ());
  304. unset /* Unset defined __refs, __v. */ ($__refs, $__v);
  305. $custom_reg_auto_op_outs = c_ws_plugin__s2member_utils_strings::wrap_deep ($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["custom_reg_auto_opt_outs"], "/^", "$/i");
  306. if (c_ws_plugin__s2member_list_servers::list_servers_integrated () && $user_id && is_numeric ($user_id) && !in_array ($user_id, $auto_processed) && is_array ($vars) && is_string ($event = (string)$event) && is_string ($event_spec = (string)$event_spec) && (c_ws_plugin__s2member_utils_arrays::in_regex_array ($event, $custom_reg_auto_op_outs) || c_ws_plugin__s2member_utils_arrays::in_regex_array ($event_spec, $custom_reg_auto_op_outs)) && is_object ($user = $_user = new WP_User ($user_id)) && !empty ($user->ID))
  307. {
  308. $mod_new_role = ($event_spec === "modification" && $mod_new_role && is_string ($mod_new_role)) ? $mod_new_role : /* Might be empty (i.e. they now have NO Role). */ false;
  309. $mod_new_user = ($event_spec === "modification" && $mod_new_user && is_object ($mod_new_user) && !empty ($mod_new_user->ID) && $mod_new_user->ID === $_user->ID) ? $mod_new_user : false;
  310. $mod_old_user = ($event_spec === "modification" && $mod_old_user && is_object ($mod_old_user) && !empty ($mod_old_user->ID) && $mod_old_user->ID === $_user->ID) ? $mod_old_user : false;
  311. $user = ($event_spec === "modification" && $mod_old_user) ? $mod_old_user : $_user; // Now, should we switch over to the old/previous User object ``$mod_old_user`` here? Or, should we use the one pulled by this routine with the User's ID?
  312. if (($event_spec !== "modification" || ($event_spec === "modification" && /* Might be empty (i.e. they now have NO Role). */ (string)$mod_new_role !== c_ws_plugin__s2member_user_access::user_access_role ($user) && strtotime ($user->user_registered) < strtotime ("-10 seconds") && ($event !== "user-role-change" || ($event === "user-role-change" && !empty ($vars["_p"]["ws_plugin__s2member_custom_reg_auto_opt_out_transitions"]))))) && ($auto_processed[$user->ID] = true))
  313. {
  314. $removed = c_ws_plugin__s2member_list_servers::process_list_server_removals (c_ws_plugin__s2member_user_access::user_access_role ($user), c_ws_plugin__s2member_user_access::user_access_level ($user), $user->user_login, false, $user->user_email, $user->first_name, $user->last_name, false, true, $user->ID);
  315. if ($event_spec === "modification" && $mod_new_role && ($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["custom_reg_auto_opt_out_transitions"] === "2" || ($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["custom_reg_auto_opt_out_transitions"] === "1" && $removed)) /* Transitoning User/Member to different list(s)? */)
  316. {
  317. $user = ($event_spec === "modification" && $mod_new_user) ? $mod_new_user : $_user; // Now, should we switch over to a new/current User object ``$mod_new_user`` here? (which may contain newly updated details). Or, should we simply use the User object pulled by this routine with the User's ID?
  318. $transitioned = c_ws_plugin__s2member_list_servers::process_list_servers ($mod_new_role, c_ws_plugin__s2member_user_access::user_access_role_to_level ($mod_new_role), $user->user_login, false, $user->user_email, $user->first_name, $user->last_name, false, true, (($removed) ? false : true), $user->ID);
  319. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  320. do_action ("ws_plugin__s2member_during_auto_process_list_server_removal_transitions", get_defined_vars ());
  321. unset /* Unset defined __refs, __v. */ ($__refs, $__v);
  322. }
  323. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  324. do_action ("ws_plugin__s2member_during_auto_process_list_server_removals", get_defined_vars ());
  325. unset /* Unset defined __refs, __v. */ ($__refs, $__v);
  326. }
  327. }
  328. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  329. do_action ("ws_plugin__s2member_after_auto_process_list_server_removals", get_defined_vars ());
  330. unset /* Unset defined __refs, __v. */ ($__refs, $__v);
  331. return /* Return for uniformity. */;
  332. }
  333. }
  334. }
  335. ?>