123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805 |
- <?php
- include_once('class.swpm-utils-misc.php');
- include_once('class.swpm-utils.php');
- include_once('class.swpm-utils-member.php');
- include_once('class.swpm-utils-membership-level.php');
- include_once('class.swpm-utils-template.php');
- include_once('class.swpm-init-time-tasks.php');
- include_once('class.swpm-wp-loaded-tasks.php');
- include_once('class.swpm-self-action-handler.php');
- include_once('class.swpm-comment-form-related.php');
- include_once('class.swpm-settings.php');
- include_once('class.swpm-protection.php');
- include_once('class.swpm-permission.php');
- include_once('class.swpm-auth.php');
- include_once('class.swpm-access-control.php');
- include_once('class.swpm-form.php');
- include_once('class.swpm-transfer.php');
- include_once('class.swpm-front-form.php');
- include_once('class.swpm-level-form.php');
- include_once('class.swpm-membership-levels.php');
- include_once('class.swpm-log.php');
- include_once('class.swpm-messages.php');
- include_once('class.swpm-ajax.php');
- include_once('class.swpm-registration.php');
- include_once('class.swpm-front-registration.php');
- include_once('class.swpm-admin-registration.php');
- include_once('class.swpm-membership-level.php');
- include_once('class.swpm-membership-level-custom.php');
- include_once('class.swpm-permission-collection.php');
- include_once('class.swpm-auth-permission-collection.php');
- include_once('class.swpm-transactions.php');
- include_once('shortcode-related/class.swpm-shortcodes-handler.php');
- include_once('class-swpm-member-subscriptions.php');
- class SimpleWpMembership {
- public function __construct() {
- new SwpmShortcodesHandler(); //Tackle the shortcode definitions and implementation.
- new SwpmSelfActionHandler(); //Tackle the self action hook handling.
- add_action('admin_menu', array(&$this, 'menu'));
- add_action('init', array(&$this, 'init_hook'));
- add_action('wp_loaded', array(&$this, 'handle_wp_loaded_tasks'));
- add_filter('the_content', array(&$this, 'filter_content'), 20, 1);
- add_filter('widget_text', 'do_shortcode');
- add_filter('show_admin_bar', array(&$this, 'hide_adminbar'));
- add_filter('comment_text', array(&$this, 'filter_comment'));
- add_filter('comment_form_defaults', array('SwpmCommentFormRelated', 'customize_comment_fields'));
- add_filter('wp_get_attachment_url', array(&$this, 'filter_attachment_url'), 10, 2);
- add_filter('wp_get_attachment_metadata', array(&$this, 'filter_attachment'), 10, 2);
- add_filter('attachment_fields_to_save', array(&$this, 'save_attachment_extra'), 10, 2);
- //TODO - refactor these shortcodes into the shortcodes handler class
- add_shortcode("swpm_registration_form", array(&$this, 'registration_form'));
- add_shortcode('swpm_profile_form', array(&$this, 'profile_form'));
- add_shortcode('swpm_login_form', array(&$this, 'login'));
- add_shortcode('swpm_reset_form', array(&$this, 'reset'));
- add_action('wp_head', array(&$this, 'wp_head_callback'));
- add_action('save_post', array(&$this, 'save_postdata'));
- add_action('admin_notices', array(&$this, 'do_admin_notices'));
- add_action('wp_enqueue_scripts', array(&$this, 'front_library'));
- add_action('load-toplevel_page_simple_wp_membership', array(&$this, 'admin_library'));
- add_action('load-wp-membership_page_simple_wp_membership_levels', array(&$this, 'admin_library'));
- add_action('wp_login', array(&$this, 'wp_login_hook_handler'), 10, 2);
- add_action('wp_authenticate', array(&$this, 'wp_authenticate_handler'), 1, 2);
- add_action('wp_logout', array(&$this, 'wp_logout'));
- add_action('swpm_logout', array(&$this, 'swpm_do_user_logout'));
- add_action('user_register', array(&$this, 'swpm_handle_wp_user_registration'));
- add_action('profile_update', array(&$this, 'sync_with_wp_profile'), 10, 2);
- //AJAX hooks
- add_action('wp_ajax_swpm_validate_email', 'SwpmAjax::validate_email_ajax');
- add_action('wp_ajax_nopriv_swpm_validate_email', 'SwpmAjax::validate_email_ajax');
- add_action('wp_ajax_swpm_validate_user_name', 'SwpmAjax::validate_user_name_ajax');
- add_action('wp_ajax_nopriv_swpm_validate_user_name', 'SwpmAjax::validate_user_name_ajax');
- //init is too early for settings api.
- add_action('admin_init', array(&$this, 'admin_init_hook'));
- add_action('plugins_loaded', array(&$this, "plugins_loaded"));
- add_action('password_reset', array(&$this, 'wp_password_reset_hook'), 10, 2);
- }
- public function wp_head_callback() {
- //This function is triggered by the wp_head action hook
- //Check if members only commenting is allowed then customize the form accordingly
- SwpmCommentFormRelated::customize_comment_form();
- //Other wp_head related tasks go here.
- }
- function wp_password_reset_hook($user, $pass) {
- $swpm_user = SwpmMemberUtils::get_user_by_user_name($user->user_login);
- //Check if SWPM user entry exists
- if (empty($swpm_user)) {
- SwpmLog::log_auth_debug("wp_password_reset_hook() - SWPM user not found for username: '" . $user->user_login ."'. This is OK, assuming that this user was created directly in WP Users menu (not using SWPM).", true);
- return;
- }
- $swpm_id = $swpm_user->member_id;
- if (!empty($swpm_id)) {
- $password_hash = SwpmUtils::encrypt_password($pass);
- global $wpdb;
- $wpdb->update($wpdb->prefix . "swpm_members_tbl", array('password' => $password_hash), array('member_id' => $swpm_id));
- }
- }
- public function save_attachment_extra($post, $attachment) {
- $this->save_postdata($post['ID']);
- return $post;
- }
- public function filter_attachment($content, $post_id) {
- if (is_admin()) {//No need to filter on the admin side
- return $content;
- }
- $acl = SwpmAccessControl::get_instance();
- if (has_post_thumbnail($post_id)) {
- return $content;
- }
- $post = get_post($post_id);
- if ($acl->can_i_read_post($post)) {
- return $content;
- }
- if (isset($content['file'])) {
- $content['file'] = 'restricted-icon.png';
- $content['width'] = '400';
- $content['height'] = '400';
- }
- if (isset($content['sizes'])) {
- if ($content['sizes']['thumbnail']) {
- $content['sizes']['thumbnail']['file'] = 'restricted-icon.png';
- $content['sizes']['thumbnail']['mime-type'] = 'image/png';
- }
- if ($content['sizes']['medium']) {
- $content['sizes']['medium']['file'] = 'restricted-icon.png';
- $content['sizes']['medium']['mime-type'] = 'image/png';
- }
- if (isset($content['sizes']['post-thumbnail'])) {
- $content['sizes']['post-thumbnail']['file'] = 'restricted-icon.png';
- $content['sizes']['post-thumbnail']['mime-type'] = 'image/png';
- }
- }
- return $content;
- }
- public function filter_attachment_url($content, $post_id) {
- if (is_admin()) {//No need to filter on the admin side
- return $content;
- }
- $acl = SwpmAccessControl::get_instance();
- if (has_post_thumbnail($post_id)) {
- return $content;
- }
- $post = get_post($post_id);
- if ($acl->can_i_read_post($post)) {
- return $content;
- }
- return SwpmUtils::get_restricted_image_url();
- }
- public function admin_init_hook() {
- //This hook is triggered in the wp-admin side only.
- $this->common_library(); //Load the common JS libraries and Styles
- $swpm_settings_obj = SwpmSettings::get_instance();
- //Check if the "Disable Access to WP Dashboard" option is enabled.
- $disable_wp_dashboard_for_non_admins = $swpm_settings_obj->get_value('disable-access-to-wp-dashboard');
- if ($disable_wp_dashboard_for_non_admins) {
- //This option is enabled
- if ((defined('DOING_AJAX') && DOING_AJAX)) {
- //This is an ajax request. Don't do the disable dashboard check for ajax.
- } else {
- //Not an ajax request. Do the check.
- if (!current_user_can('administrator')) {
- //This is a non-admin user. Do not show the wp dashboard.
- $message = '<p>' . SwpmUtils::_('The admin of this site does not allow users to access the wp dashboard.') . '</p>';
- $message .= '<p>' . SwpmUtils::_('Go back to the home page by ') . '<a href="' . SIMPLE_WP_MEMBERSHIP_SITE_HOME_URL . '">' . SwpmUtils::_('clicking here') . '</a>.' . '</p>';
- wp_die($message);
- }
- }
- }
- //Initialize the settings menu hooks.
- $swpm_settings_obj->init_config_hooks();
- $addon_saved = filter_input(INPUT_POST, 'swpm-addon-settings');
- if (!empty($addon_saved) && current_user_can('manage_options')) {
- check_admin_referer('swpm_addon_settings_section', 'swpm_addon_settings_section_save_settings');
- do_action('swpm_addon_settings_save');
- }
- }
- public function hide_adminbar() {
- //Never show admin toolbar if the user is not even logged in
- if (!is_user_logged_in()) {
- return false;
- }
- //Show admin toolbar to admin only feature is enabled.
- $show_to_admin = SwpmSettings::get_instance()->get_value('show-adminbar-admin-only');
- if ($show_to_admin) {
- if (current_user_can('administrator')) {
- //This is an admin user so show the tooldbar
- return true;
- } else {
- return false;
- }
- }
- //Hide admin toolbar if the hide adminbar feature is enabled
- $hide = SwpmSettings::get_instance()->get_value('hide-adminbar');
- return $hide ? FALSE : TRUE;
- }
- public function shutdown() {
- SwpmLog::writeall();
- }
- public static function swpm_login($username, $pass, $rememberme = true) {
- if (is_user_logged_in()) {
- $current_user = wp_get_current_user();
- SwpmLog::log_auth_debug("static function swpm_login(). User is logged in. WP Username: " . $current_user->user_login, true);
- if ($current_user->user_login == $username) {
- return;
- }
- }
- SwpmLog::log_auth_debug("Trying wp_signon() with username: " . $username, true);
- add_filter('wordfence_ls_require_captcha', '__return_false');//For Wordfence plugin's captcha compatibility
- $user_obj = wp_signon(array('user_login' => $username, 'user_password' => $pass, 'remember' => $rememberme), is_ssl());
- if ($user_obj instanceof WP_User) {
- wp_set_current_user($user_obj->ID, $user_obj->user_login);
- SwpmLog::log_auth_debug("Setting current WP user to: " . $user_obj->user_login, true);
- } else {
- SwpmLog::log_auth_debug("wp_signon() failed for the corresponding WP user account.", false);
- if (is_wp_error($user_obj)) {
- //SwpmLog::log_auth_debug("Error Message: ". $user_obj->get_error_message(), false);
- $force_wp_user_sync = SwpmSettings::get_instance()->get_value('force-wp-user-sync');
- if (!empty($force_wp_user_sync)) {
- //Force WP user login sync is enabled. Show error and exit out since the WP user login failed.
- $error_msg = SwpmUtils::_("Error! This site has the force WP user login feature enabled in the settings. We could not find a WP user record for the given username: ") . $username;
- $error_msg .= "<br /><br />" . SwpmUtils::_("This error is triggered when a member account doesn't have a corresponding WP user account. So the plugin fails to log the user into the WP User system.");
- $error_msg .= "<br /><br />" . SwpmUtils::_("Contact the site admin and request them to check your username in the WP Users menu to see what happened with the WP user entry of your account.");
- $error_msg .= "<br /><br />" . SwpmUtils::_("The site admin can disable the Force WP User Synchronization feature in the settings to disable this feature and this error will go away.");
- $error_msg .= "<br /><br />" . SwpmUtils::_("You can use the back button of your browser to go back to the site.");
- wp_die($error_msg);
- }
- }
- }
- $proceed_after_auth = apply_filters('swpm_login_auth_completed_filter', true);
- if (!$proceed_after_auth) {
- $auth = SwpmAuth::get_instance();
- $auth->logout();
- return;
- }
- SwpmLog::log_auth_debug("Triggering swpm_after_login hook.", true);
- do_action('swpm_after_login');
- if (!SwpmUtils::is_ajax()) {
- $redirect_url = apply_filters('swpm_after_login_redirect_url', SIMPLE_WP_MEMBERSHIP_SITE_HOME_URL);
- wp_redirect($redirect_url);
- exit(0);
- }
- }
- public function swpm_do_user_logout() {
- if (is_user_logged_in()) {
- wp_logout();
- wp_set_current_user(0);
- }
- }
- /* This function can be used to authenticate a member using currently logged in wp user. */
- public function set_current_user_handler() {
- $auth = SwpmAuth::get_instance();
- if ($auth->is_logged_in()) {
- return;
- }
- $user = wp_get_current_user();
- if (empty($user) || $user->ID === 0) {
- return false;
- }
- SwpmLog::log_auth_debug('set_current_user action. Attempting to login user ' . $user->user_login, true);
- //remove hook in order for it to not be called several times in the process
- remove_action('set_current_user', array($this, 'set_current_user_handler'));
- $auth->login_to_swpm_using_wp_user($user);
- }
- /* Used to log the user into SWPM system using the wp_login hook. Some social plugins use this hook to handle the login */
- public function wp_login_hook_handler($user_login, $user){
- SwpmLog::log_auth_debug('wp_login hook triggered. Username: ' . $user_login, true);
- $auth = SwpmAuth::get_instance();
- if ($auth->is_logged_in()) {
- //User is already logged-in. Nothing to do.
- return;
- }
- $auth->login_to_swpm_using_wp_user($user);
- }
- public function wp_authenticate_handler($username, $password) {
- $auth = SwpmAuth::get_instance();
- if (($auth->is_logged_in() && ($auth->userData->user_name == $username))) {
- SwpmLog::log_auth_debug('wp_authenticate action. User with username: ' . $username . ' is already logged in.', true);
- return;
- }
- if (!empty($username)) {
- SwpmLog::log_auth_debug('wp_authenticate action. Handling login for username: ' . $username, true);
- $auth->login($username, $password, true);
- } else {
- //empty username can mean some plugin trying to login WP user using its own methods.
- //Let's add hook for set_current_user action and let it handle the login if needed.
- SwpmLog::log_auth_debug('wp_authenticate action. Empty username provided. Adding set_current_username hook to catch potential login attempt.', true);
- add_action('set_current_user', array($this, 'set_current_user_handler'));
- }
- }
- public function login() {
- ob_start();
- $auth = SwpmAuth::get_instance();
- if ($auth->is_logged_in()) {
- //Load the template for logged-in member
- SwpmUtilsTemplate::swpm_load_template('loggedin.php', false);
- } else {
- //Load the login widget template
- SwpmUtilsTemplate::swpm_load_template('login.php', false);
- }
- return ob_get_clean();
- }
- public function wp_logout() {
- $auth = SwpmAuth::get_instance();
- if ($auth->is_logged_in()) {
- $auth->logout();
- }
- }
- public function sync_with_wp_profile($wp_user_id) {
- global $wpdb;
- $wp_user_data = get_userdata($wp_user_id);
- $query = $wpdb->prepare("SELECT * FROM " . $wpdb->prefix . "swpm_members_tbl WHERE " . ' user_name=%s', $wp_user_data->user_login);
- $profile = $wpdb->get_row($query, ARRAY_A);
- $profile = (array) $profile;
- if (empty($profile)) {
- return;
- }
- $profile['user_name'] = $wp_user_data->user_login;
- $profile['email'] = $wp_user_data->user_email;
- $profile['password'] = $wp_user_data->user_pass;
- $profile['first_name'] = $wp_user_data->user_firstname;
- $profile['last_name'] = $wp_user_data->user_lastname;
- $wpdb->update($wpdb->prefix . "swpm_members_tbl", $profile, array('member_id' => $profile['member_id']));
- }
- function swpm_handle_wp_user_registration($user_id) {
- $swpm_settings_obj = SwpmSettings::get_instance();
- $enable_auto_create_swpm_members = $swpm_settings_obj->get_value('enable-auto-create-swpm-members');
- $default_level = $swpm_settings_obj->get_value('auto-create-default-membership-level');
- $default_ac_status = $swpm_settings_obj->get_value('auto-create-default-account-status');
- if (empty($enable_auto_create_swpm_members)) {
- return;
- }
- if (empty($default_level)) {
- return;
- }
- $user_info = get_userdata($user_id);
- if (SwpmMemberUtils::get_user_by_user_name($user_info->user_login)) {
- SwpmLog::log_simple_debug("swpm_handle_wp_user_registration() - SWPM member account with this username already exists! No new account will be created for this user.", false);
- return;
- }
- if (SwpmMemberUtils::get_user_by_email($user_info->user_email)) {
- SwpmLog::log_simple_debug("swpm_handle_wp_user_registration() - SWPM member account with this email already exists! No new account will be created for this user.", false);
- return;
- }
- $fields = array();
- $fields['user_name'] = $user_info->user_login;
- $fields['password'] = $user_info->user_pass;
- $fields['email'] = $user_info->user_email;
- $fields['first_name'] = $user_info->first_name;
- $fields['last_name'] = $user_info->last_name;
- $fields['birth_place'] = $user_info->birth_place;
- $fields['membership_level'] = $default_level;
- $fields['member_since'] = SwpmUtils::get_current_date_in_wp_zone();
- $fields['account_state'] = $default_ac_status;
- $fields['subscription_starts'] = SwpmUtils::get_current_date_in_wp_zone();
- SwpmMemberUtils::create_swpm_member_entry_from_array_data($fields);
- }
- public function reset() {
- $succeeded = $this->notices();
- if ($succeeded) {
- return '';
- }
- ob_start();
- //Load the forgot password template
- SwpmUtilsTemplate::swpm_load_template('forgot_password.php', false);
- return ob_get_clean();
- }
- public function profile_form() {
- $auth = SwpmAuth::get_instance();
- $this->notices();
- if ($auth->is_logged_in()) {
- $out = apply_filters('swpm_profile_form_override', '');
- if (!empty($out)) {
- return $out;
- }
- ob_start();
- //Load the edit profile template
- SwpmUtilsTemplate::swpm_load_template('edit.php', false);
- return ob_get_clean();
- }
- return SwpmUtils::_('You are not logged in.');
- }
- /* If any message/notice was set during the execution then this function will output that message */
- public function notices() {
- $message = SwpmTransfer::get_instance()->get('status');
- $succeeded = false;
- if (empty($message)) {
- return false;
- }
- if ($message['succeeded']) {
- echo "<div id='swpm_message' class='swpm_success'>";
- $succeeded = true;
- } else {
- echo "<div id='swpm_message' class='swpm_error'>";
- }
- echo $message['message'];
- $extra = isset($message['extra']) ? $message['extra'] : array();
- if (is_string($extra)) {
- echo $extra;
- } else if (is_array($extra)) {
- echo '<ul>';
- foreach ($extra as $key => $value) {
- echo '<li>' . $value . '</li>';
- }
- echo '</ul>';
- }
- echo "</div>";
- if (isset($message['pass_reset_sent'])) {
- $succeeded = true;
- }
- return $succeeded;
- }
- /*
- * This function is hooked to WordPress's admin_notices action hook
- * It is used to show any plugin specific notices/warnings in the admin interface
- */
- public function do_admin_notices() {
- $this->notices(); //Show any execution specific notices in the admin interface.
- //Show any other general warnings/notices to the admin.
- if (SwpmMiscUtils::is_swpm_admin_page()) {
- //we are in an admin page for SWPM plugin.
- $msg = '';
- //Show notice if running in sandbox mode.
- $settings = SwpmSettings::get_instance();
- $sandbox_enabled = $settings->get_value('enable-sandbox-testing');
- if ($sandbox_enabled) {
- $msg .= '<p>' . SwpmUtils::_('You have the sandbox payment mode enabled in plugin settings. Make sure to turn off the sandbox mode when you want to do live transactions.') . '</p>';
- }
- if (!empty($msg)) {//Show warning messages if any.
- echo '<div id="message" class="error">';
- echo $msg;
- echo '</div>';
- }
- }
- }
- public function meta_box() {
- if (function_exists('add_meta_box')) {
- $post_types = get_post_types();
- foreach ($post_types as $post_type => $post_type) {
- add_meta_box('swpm_sectionid', __('Simple WP Membership Protection', 'simple-membership'), array(&$this, 'inner_custom_box'), $post_type, 'advanced');
- }
- } else {//older version doesn't have custom post type so modification isn't needed.
- add_action('dbx_post_advanced', array(&$this, 'show_old_custom_box'));
- add_action('dbx_page_advanced', array(&$this, 'show_old_custom_box'));
- }
- }
- public function show_old_custom_box() {
- echo '<div class="dbx-b-ox-wrapper">' . "\n";
- echo '<fieldset id="swpm_fieldsetid" class="dbx-box">' . "\n";
- echo '<div class="dbx-h-andle-wrapper"><h3 class="dbx-handle">' .
- __('Simple Membership Protection options', 'simple-membership') . "</h3></div>";
- echo '<div class="dbx-c-ontent-wrapper"><div class="dbx-content">';
- // output editing form
- $this->inner_custom_box();
- // end wrapper
- echo "</div></div></fieldset></div>\n";
- }
- public function inner_custom_box() {
- global $post, $wpdb;
- $id = $post->ID;
- $protection_obj = SwpmProtection::get_instance();
- $is_protected = $protection_obj->is_protected($id);
- //Nonce input
- echo '<input type="hidden" name="swpm_post_protection_box_nonce" value="' . wp_create_nonce('swpm_post_protection_box_nonce_action') . '" />';
- // The actual fields for data entry
- echo '<h4>' . __("Do you want to protect this content?", 'simple-membership') . '</h4>';
- echo '<input type="radio" ' . ((!$is_protected) ? 'checked' : "") . ' name="swpm_protect_post" value="1" /> ' . SwpmUtils::_('No, Do not protect this content.') . '<br/>';
- echo '<input type="radio" ' . (($is_protected) ? 'checked' : "") . ' name="swpm_protect_post" value="2" /> ' . SwpmUtils::_('Yes, Protect this content.') . '<br/>';
- echo $protection_obj->get_last_message();
- echo '<h4>' . __("Select the membership level that can access this content:", 'simple-membership') . "</h4>";
- $query = "SELECT * FROM " . $wpdb->prefix . "swpm_membership_tbl WHERE id !=1 ";
- $levels = $wpdb->get_results($query, ARRAY_A);
- foreach ($levels as $level) {
- echo '<input type="checkbox" ' . (SwpmPermission::get_instance($level['id'])->is_permitted($id) ? "checked='checked'" : "") .
- ' name="swpm_protection_level[' . $level['id'] . ']" value="' . $level['id'] . '" /> ' . $level['alias'] . "<br/>";
- }
- }
- public function save_postdata($post_id) {
- global $wpdb;
- $post_type = filter_input(INPUT_POST, 'post_type');
- $swpm_protect_post = filter_input(INPUT_POST, 'swpm_protect_post');
- if (wp_is_post_revision($post_id)) {
- return;
- }
- if (defined('DOING_AUTOSAVE') && DOING_AUTOSAVE) {
- return $post_id;
- }
- //Check nonce
- $swpm_post_protection_box_nonce = filter_input(INPUT_POST, 'swpm_post_protection_box_nonce');
- if (!wp_verify_nonce($swpm_post_protection_box_nonce, 'swpm_post_protection_box_nonce_action')) {
- //Nonce check failed.
- return $post_id;
- }
- if ('page' == $post_type) {
- if (!current_user_can('edit_page', $post_id)) {
- return $post_id;
- }
- } else {
- if (!current_user_can('edit_post', $post_id)) {
- return $post_id;
- }
- }
- if (empty($swpm_protect_post)) {
- return;
- }
- // OK, we're authenticated: we need to find and save the data
- $isprotected = ($swpm_protect_post == 2);
- $args = array('swpm_protection_level' => array(
- 'filter' => FILTER_VALIDATE_INT,
- 'flags' => FILTER_REQUIRE_ARRAY,
- ));
- $swpm_protection_level = filter_input_array(INPUT_POST, $args);
- $swpm_protection_level = $swpm_protection_level['swpm_protection_level'];
- if (!empty($post_type)) {
- if ($isprotected) {
- SwpmProtection::get_instance()->apply(array($post_id), $post_type);
- } else {
- SwpmProtection::get_instance()->remove(array($post_id), $post_type);
- }
- SwpmProtection::get_instance()->save();
- $query = "SELECT id FROM " . $wpdb->prefix . "swpm_membership_tbl WHERE id !=1 ";
- $level_ids = $wpdb->get_col($query);
- foreach ($level_ids as $level) {
- if (isset($swpm_protection_level[$level])) {
- SwpmPermission::get_instance($level)->apply(array($post_id), $post_type)->save();
- } else {
- SwpmPermission::get_instance($level)->remove(array($post_id), $post_type)->save();
- }
- }
- }
- $enable_protection = array();
- $enable_protection['protect'] = $swpm_protect_post;
- $enable_protection['level'] = $swpm_protection_level;
- return $enable_protection;
- }
- public function filter_comment($content) {
- if (is_admin()) {
- //Do not apply filtering for admin side viewing
- return $content;
- }
- $acl = SwpmAccessControl::get_instance();
- global $comment;
- return $acl->filter_comment($comment, $content);
- }
- public function filter_content($content) {
- if (is_preview() || is_admin()) {
- //If the user is logged-in as an admin user then do not apply filtering for admin side viewing or preview page viewing.
- if ( current_user_can('administrator') ){
- //The user is logged in as admin in this browser.
- return $content;
- }
- }
- $acl = SwpmAccessControl::get_instance();
- global $post;
- return $acl->filter_post($post, $content);
- }
- public function init_hook() {
- $init_tasks = new SwpmInitTimeTasks();
- $init_tasks->do_init_tasks();
- }
- public function handle_wp_loaded_tasks() {
- $wp_loaded_tasks = new SwpmWpLoadedTasks();
- $wp_loaded_tasks->do_wp_loaded_tasks();
- }
- public function admin_library() {
- //Only loaded on selective swpm admin menu page rendering.
- $this->common_library();
- wp_enqueue_script('password-strength-meter');
- wp_enqueue_script('swpm.password-meter', SIMPLE_WP_MEMBERSHIP_URL . '/js/swpm.password-meter.js', array('jquery'), SIMPLE_WP_MEMBERSHIP_VER);
- //jQuery UI style
- wp_register_style('swpm-jquery-ui', SIMPLE_WP_MEMBERSHIP_URL . '/css/jquery-ui.min.css', array(), SIMPLE_WP_MEMBERSHIP_VER);
- wp_enqueue_style('swpm-jquery-ui');
- wp_enqueue_script('jquery-ui-datepicker');
- $settings = array('statusChangeEmailHead' => SwpmSettings::get_instance()->get_value('account-change-email-subject'),
- 'statusChangeEmailBody' => SwpmSettings::get_instance()->get_value('account-change-email-body'));
- wp_localize_script('swpm.password-meter', 'SwpmSettings', $settings);
- }
- public function front_library() {
- $this->common_library();
- }
- private function common_library() {
- wp_enqueue_script('jquery');
- wp_enqueue_style('swpm.common', SIMPLE_WP_MEMBERSHIP_URL . '/css/swpm.common.css', array(), SIMPLE_WP_MEMBERSHIP_VER);
- //In order to not clog WP with scripts and styles we're only using with forms, let's just register those for now
- //Scripts will be queued when forms are actually displayed
- wp_register_style('validationEngine.jquery', SIMPLE_WP_MEMBERSHIP_URL . '/css/validationEngine.jquery.css', array(), SIMPLE_WP_MEMBERSHIP_VER);
- wp_register_script('jquery.validationEngine', SIMPLE_WP_MEMBERSHIP_URL . '/js/jquery.validationEngine.js', array('jquery'), SIMPLE_WP_MEMBERSHIP_VER);
- wp_register_script('jquery.validationEngine-en', SIMPLE_WP_MEMBERSHIP_URL . '/js/jquery.validationEngine-en.js', array('jquery'), SIMPLE_WP_MEMBERSHIP_VER);
- wp_register_script('swpm.validationEngine-localization', SIMPLE_WP_MEMBERSHIP_URL . '/js/swpm.validationEngine-localization.js', array('jquery'), SIMPLE_WP_MEMBERSHIP_VER);
- }
- public static function enqueue_validation_scripts($add_params = array()) {
- //Localization for jquery.validationEngine
- //This array will be merged with $.validationEngineLanguage.allRules object from jquery.validationEngine-en.js file
- $loc_data = array(
- 'ajaxUserCall' => array(
- 'url' => admin_url('admin-ajax.php'),
- 'alertTextLoad' => '* ' . SwpmUtils::_('Validating, please wait'),
- ),
- 'ajaxEmailCall' => array(
- 'url' => admin_url('admin-ajax.php'),
- 'alertTextLoad' => '* ' . SwpmUtils::_('Validating, please wait'),
- ),
- 'email' => array(
- 'alertText' => '* ' . SwpmUtils::_('Invalid email address'),
- ),
- 'required' => array(
- 'alertText' => '* ' . SwpmUtils::_('This field is required'),
- ),
- 'strongPass' => array(
- 'alertText' => '* ' . SwpmUtils::_('Password must contain at least:').'<br>'.SwpmUtils::_('- a digit').'<br>'.SwpmUtils::_('- an uppercase letter').'<br>'.SwpmUtils::_('- a lowercase letter'),
- ),
- 'SWPMUserName' => array(
- 'alertText' => '* ' . SwpmUtils::_('Invalid Username').'<br>'.SwpmUtils::_('Usernames can only contain: letters, numbers and .-_*@'),
- ),
- 'minSize' => array(
- 'alertText' => '* ' . SwpmUtils::_('Minimum '),
- 'alertText2' => SwpmUtils::_(' characters required'),
- ),
- 'noapostrophe' => array(
- 'alertText' => '* ' . SwpmUtils::_('Apostrophe character is not allowed'),
- ),
- );
- $nonce=wp_create_nonce( 'swpm-rego-form-ajax-nonce' );
- if ($add_params) {
- // Additional parameters should be added to the array, replacing existing ones
- if (isset($add_params['ajaxEmailCall'])) {
- if (isset($add_params['ajaxEmailCall']['extraData'])) {
- $add_params['ajaxEmailCall']['extraData'].='&nonce='.$nonce;
- }
- }
- $loc_data = array_replace_recursive($add_params, $loc_data);
- }
- wp_localize_script('swpm.validationEngine-localization', 'swpm_validationEngine_localization', $loc_data);
- wp_localize_script('jquery.validationEngine-en', 'swpmRegForm', array('nonce' => $nonce));
- wp_enqueue_style('validationEngine.jquery');
- wp_enqueue_script('jquery.validationEngine');
- wp_enqueue_script('jquery.validationEngine-en');
- wp_enqueue_script('swpm.validationEngine-localization');
- }
- public function registration_form($atts) {
- $succeeded = $this->notices();
- if ($succeeded) {
- return;
- }
- $is_free = SwpmSettings::get_instance()->get_value('enable-free-membership');
- $free_level = absint(SwpmSettings::get_instance()->get_value('free-membership-id'));
- $level = isset($atts['level']) ? absint($atts['level']) : ($is_free ? $free_level : null);
- return SwpmFrontRegistration::get_instance()->regigstration_ui($level);
- }
- public function menu() {
- $menu_parent_slug = 'simple_wp_membership';
- add_menu_page(__("WP Membership", 'simple-membership'), __("WP Membership", 'simple-membership'), SWPM_MANAGEMENT_PERMISSION, $menu_parent_slug, array(&$this, "admin_members_menu"), 'dashicons-id');
- add_submenu_page($menu_parent_slug, __("Members", 'simple-membership'), __('Members', 'simple-membership'), SWPM_MANAGEMENT_PERMISSION, 'simple_wp_membership', array(&$this, "admin_members_menu"));
- add_submenu_page($menu_parent_slug, __("Membership Levels", 'simple-membership'), __("Membership Levels", 'simple-membership'), SWPM_MANAGEMENT_PERMISSION, 'simple_wp_membership_levels', array(&$this, "admin_membership_levels_menu"));
- add_submenu_page($menu_parent_slug, __("Settings", 'simple-membership'), __("Settings", 'simple-membership'), SWPM_MANAGEMENT_PERMISSION, 'simple_wp_membership_settings', array(&$this, "admin_settings_menu"));
- add_submenu_page($menu_parent_slug, __("Payments", 'simple-membership'), __("Payments", 'simple-membership'), SWPM_MANAGEMENT_PERMISSION, 'simple_wp_membership_payments', array(&$this, "admin_payments_menu"));
- add_submenu_page($menu_parent_slug, __("Add-ons", 'simple-membership'), __("Add-ons", 'simple-membership'), SWPM_MANAGEMENT_PERMISSION, 'simple_wp_membership_addons', array(&$this, "admin_add_ons_menu"));
- do_action('swpm_after_main_admin_menu', $menu_parent_slug);
- $this->meta_box();
- }
- /* Render the members menu in admin dashboard */
- public function admin_members_menu() {
- include_once(SIMPLE_WP_MEMBERSHIP_PATH . 'classes/class.swpm-members.php');
- $members = new SwpmMembers();
- $members->handle_main_members_admin_menu();
- }
- /* Render the membership levels menu in admin dashboard */
- public function admin_membership_levels_menu() {
- include_once(SIMPLE_WP_MEMBERSHIP_PATH . 'classes/class.swpm-membership-levels.php');
- $levels = new SwpmMembershipLevels();
- $levels->handle_main_membership_level_admin_menu();
- }
- /* Render the settings menu in admin dashboard */
- public function admin_settings_menu() {
- $settings = SwpmSettings::get_instance();
- $settings->handle_main_settings_admin_menu();
- }
- public function admin_payments_menu() {
- include_once(SIMPLE_WP_MEMBERSHIP_PATH . 'classes/admin-includes/class.swpm-payments-admin-menu.php');
- $payments_admin = new SwpmPaymentsAdminMenu();
- $payments_admin->handle_main_payments_admin_menu();
- }
- public function admin_add_ons_menu() {
- include(SIMPLE_WP_MEMBERSHIP_PATH . 'views/admin_add_ons_page.php');
- }
- public function plugins_loaded() {
- //Runs when plugins_loaded action gets fired
- if (is_admin()) {
- //Check and run DB upgrade operation (if needed)
- if (get_option('swpm_db_version') != SIMPLE_WP_MEMBERSHIP_DB_VER) {
- include_once('class.swpm-installation.php');
- SwpmInstallation::run_safe_installer();
- }
- }
- }
- public static function activate() {
- wp_schedule_event(time(), 'daily', 'swpm_account_status_event');
- wp_schedule_event(time(), 'daily', 'swpm_delete_pending_account_event');
- include_once('class.swpm-installation.php');
- SwpmInstallation::run_safe_installer();
- }
- public static function deactivate() {
- wp_clear_scheduled_hook('swpm_account_status_event');
- wp_clear_scheduled_hook('swpm_delete_pending_account_event');
- }
- }
|