roles ) ); $event_id = ( 'user-edit' === $referer_check ) ? 4026 : 4025; // Note, firstname and lastname fields are purposefully spaces to avoid NULL. if ( isset( $_POST['name'] ) ) { $this->plugin->alerts->Trigger( $event_id, array( 'roles' => $current_user_roles, 'login' => $current_user->user_login, 'firstname' => ( empty( $current_user->user_firstname ) ) ? ' ' : $current_user->user_firstname, 'lastname' => ( empty( $current_user->user_lastname ) ) ? ' ' : $current_user->user_lastname, 'CurrentUserID' => $current_user->ID, 'friendly_name' => sanitize_text_field( $_POST['name'] ), 'EventType' => 'added', ) ); } // Check if all have been removed. elseif ( ! empty( $old_value ) && count( $old_value ) > 1 && empty( $_meta_value ) ) { $event_id = ( 'user-edit' === $referer_check ) ? 4028 : 4027; // Note, firstname and lastname fields are purposefully spaces to avoid NULL. $this->plugin->alerts->Trigger( $event_id , array( 'roles' => $current_user_roles, 'login' => $current_user->user_login, 'firstname' => ( empty( $current_user->user_firstname ) ) ? ' ' : $current_user->user_firstname, 'lastname' => ( empty( $current_user->user_lastname ) ) ? ' ' : $current_user->user_lastname, 'CurrentUserID' => $current_user->ID, 'EventType' => 'revoked', ) ); } // Check the item that was removed. elseif ( count( $_meta_value ) < count( $old_value ) ) { $revoked_pw = array_diff( array_map( 'serialize', $old_value ), array_map( 'serialize', $_meta_value ) ); $revoked_pw = array_values( array_map( 'unserialize', $revoked_pw ) ); $revoked_pw_name = $revoked_pw[0]['name']; $event_id = ( 'user-edit' === $referer_check ) ? 4026 : 4025; // Note, firstname and lastname fields are purposefully spaces to avoid NULL. $this->plugin->alerts->Trigger( $event_id , array( 'roles' => $current_user_roles, 'login' => $current_user->user_login, 'firstname' => ( empty( $current_user->user_firstname ) ) ? ' ' : $current_user->user_firstname, 'lastname' => ( empty( $current_user->user_lastname ) ) ? ' ' : $current_user->user_lastname, 'CurrentUserID' => $current_user->ID, 'friendly_name' => sanitize_text_field( $revoked_pw_name ), 'EventType' => 'revoked', ) ); } } } /** * Method: Support for Ultimate Member email change * alert. * * @param int $user_id - User ID. * @param WP_User $old_userdata - Old WP_User object. */ public function event_user_updated( $user_id, $old_userdata ) { // Get new user data. $new_userdata = get_userdata( $user_id ); // Alert if user password is changed. if ( $old_userdata->user_pass !== $new_userdata->user_pass ) { $event = get_current_user_id() === $user_id ? 4003 : 4004; $user_roles = implode( ', ', array_map( array( $this, 'filter_role_names' ), $new_userdata->roles ) ); $this->plugin->alerts->Trigger( $event, array( 'TargetUserID' => $user_id, 'TargetUserData' => (object) array( 'Username' => $new_userdata->user_login, 'Roles' => $user_roles, 'FirstName' => $new_userdata->user_firstname, 'LastName' => $new_userdata->user_lastname, ), 'EditUserLink' => add_query_arg( 'user_id', $user_id, admin_url( 'user-edit.php' ) ), ) ); } // Alert if user email is changed. if ( $old_userdata->user_email !== $new_userdata->user_email ) { $event = get_current_user_id() === $user_id ? 4005 : 4006; $user_roles = implode( ', ', array_map( array( $this, 'filter_role_names' ), $new_userdata->roles ) ); $this->plugin->alerts->Trigger( $event, array( 'TargetUserID' => $user_id, 'TargetUsername' => $new_userdata->user_login, 'OldEmail' => $old_userdata->user_email, 'NewEmail' => $new_userdata->user_email, 'Roles' => $user_roles, 'FirstName' => $new_userdata->user_firstname, 'LastName' => $new_userdata->user_lastname, 'EditUserLink' => add_query_arg( 'user_id', $user_id, admin_url( 'user-edit.php' ) ), ) ); } // Alert if display name is changed. if ( $old_userdata->display_name !== $new_userdata->display_name ) { $user_roles = implode( ', ', array_map( array( $this, 'filter_role_names' ), $new_userdata->roles ) ); $this->plugin->alerts->Trigger( 4020, array( 'TargetUsername' => $new_userdata->user_login, 'old_displayname' => $old_userdata->display_name, 'new_displayname' => $new_userdata->display_name, 'Roles' => $user_roles, 'FirstName' => $new_userdata->user_firstname, 'LastName' => $new_userdata->user_lastname, 'EditUserLink' => add_query_arg( 'user_id', $user_id, admin_url( 'user-edit.php' ) ), ) ); } } /** * Triggered when a user role is changed. * * @param int $user_id - User ID of the user. * @param string $new_role - New role. * @param array $old_roles - Array of old roles. */ public function event_user_role_changed( $user_id, $new_role, $old_roles ) { // Get WP_User object. $user = get_userdata( $user_id ); // Check if $user is false then return. if ( ! $user ) { return; } $old_roles = array_map( array( $this, 'filter_role_names' ), $old_roles ); $new_roles = array_map( array( $this, 'filter_role_names' ), $user->roles ); // Get roles. $old_roles = is_array( $old_roles ) ? implode( ', ', $old_roles ) : ''; $new_roles = is_array( $new_roles ) ? implode( ', ', $new_roles ) : ''; // Alert if roles are changed. if ( $old_roles !== $new_roles ) { $this->plugin->alerts->TriggerIf( 4002, array( 'TargetUserID' => $user_id, 'TargetUsername' => $user->user_login, 'OldRole' => $old_roles, 'NewRole' => $new_roles, 'FirstName' => $user->user_firstname, 'LastName' => $user->user_lastname, 'EditUserLink' => add_query_arg( 'user_id', $user_id, admin_url( 'user-edit.php' ) ), 'multisite_text' => $this->plugin->IsMultisite() ? get_current_blog_id() : false, ), array( $this, 'MustNotContainUserChanges' ) ); } } /** * Triggered when a user is deleted. * * @param int $user_id - User ID of the registered user. */ public function event_user_deleted( $user_id ) { $user = get_userdata( $user_id ); $role = is_array( $user->roles ) ? implode( ', ', $user->roles ) : $user->roles; $this->plugin->alerts->TriggerIf( 4007, array( 'TargetUserID' => $user_id, 'TargetUserData' => (object) array( 'Username' => $user->user_login, 'FirstName' => $user->user_firstname, 'LastName' => $user->user_lastname, 'Email' => $user->user_email, 'Roles' => $role ? $role : 'none', ), ), array( $this, 'MustNotContainCreateUser' ) ); } /** * Triggered when a user profile is opened. * * @param object $user - Instance of WP_User. */ public function event_open_profile( $user ) { if ( ! $user ) { return; } $current_user = wp_get_current_user(); $updated = isset( $_GET['updated'] ); // @codingStandardsIgnoreLine if ( $current_user && ( $user->ID !== $current_user->ID ) && ! $updated ) { $user_roles = implode( ', ', array_map( array( $this, 'filter_role_names' ), $user->roles ) ); $this->plugin->alerts->Trigger( 4014, array( 'UserChanger' => $current_user->user_login, 'TargetUsername' => $user->user_login, 'FirstName' => $user->user_firstname, 'LastName' => $user->user_lastname, 'Roles' => $user_roles, 'EditUserLink' => add_query_arg( 'user_id', $user->ID, admin_url( 'user-edit.php' ) ), ) ); } } /** * Triggered when a user accesses the admin area. */ public function get_super_admins() { $this->old_superadmins = $this->IsMultisite() ? get_super_admins() : null; } /** * Super Admin Enabled. * * Triggers when a user is granted super admin access. * * @since 3.4 * * @param int $user_id - ID of the user that was granted Super Admin privileges. */ public function event_super_access_granted( $user_id ) { $user = get_userdata( $user_id ); if ( $user && ! in_array( $user->user_login, $this->old_superadmins, true ) ) { $this->plugin->alerts->Trigger( 4008, array( 'TargetUserID' => $user_id, 'TargetUsername' => $user->user_login, 'Roles' => is_array( $user->roles ) ? implode( ', ', $user->roles ) : $user->roles, 'FirstName' => $user->user_firstname, 'LastName' => $user->user_lastname, 'EditUserLink' => add_query_arg( 'user_id', $user_id, admin_url( 'user-edit.php' ) ), ) ); } } /** * Super Admin Disabled. * * Triggers when a user is revoked super admin access. * * @since 3.4 * * @param int $user_id - ID of the user that was revoked Super Admin privileges. */ public function event_super_access_revoked( $user_id ) { $user = get_userdata( $user_id ); if ( $user && in_array( $user->user_login, $this->old_superadmins, true ) ) { $this->plugin->alerts->Trigger( 4009, array( 'TargetUserID' => $user_id, 'TargetUsername' => $user->user_login, 'Roles' => is_array( $user->roles ) ? implode( ', ', $user->roles ) : $user->roles, 'FirstName' => $user->user_firstname, 'LastName' => $user->user_lastname, 'EditUserLink' => add_query_arg( 'user_id', $user_id, admin_url( 'user-edit.php' ) ), ) ); } } /** * Remove BBPress Prefix from User Role. * * @since 3.4 * * @param string $user_role - User role. * @return string */ public function filter_role_names( $user_role ) { global $wp_roles; return isset( $wp_roles->role_names[ $user_role ] ) ? $wp_roles->role_names[ $user_role ] : false; } /** * Must Not Contain Create User. * * @param WSAL_AlertManager $mgr - Instance of WSAL_AlertManager. */ public function MustNotContainCreateUser( WSAL_AlertManager $mgr ) { return ! $mgr->WillTrigger( 4012 ); } /** * Must Not Contain User Changes. * * @param WSAL_AlertManager $mgr - Instance of WSAL_AlertManager. */ public function MustNotContainUserChanges( WSAL_AlertManager $mgr ) { return ! ( $mgr->WillOrHasTriggered( 4010 ) || $mgr->WillOrHasTriggered( 4011 ) || $mgr->WillOrHasTriggered( 4012 ) || $mgr->WillOrHasTriggered( 4000 ) || $mgr->WillOrHasTriggered( 4001 ) ); } }