id === 'settings_page_activitypub' ) { $this->user_id = Users::BLOG_USER_ID; } else { $this->user_id = \get_current_user_id(); } parent::__construct( array( 'singular' => \__( 'Follower', 'activitypub' ), 'plural' => \__( 'Followers', 'activitypub' ), 'ajax' => false, ) ); } public function get_columns() { return array( 'cb' => '', 'avatar' => \__( 'Avatar', 'activitypub' ), 'post_title' => \__( 'Name', 'activitypub' ), 'username' => \__( 'Username', 'activitypub' ), 'url' => \__( 'URL', 'activitypub' ), 'published' => \__( 'Followed', 'activitypub' ), 'modified' => \__( 'Last updated', 'activitypub' ), ); } public function get_sortable_columns() { $sortable_columns = array( 'post_title' => array( 'post_title', true ), 'modified' => array( 'modified', false ), 'published' => array( 'published', false ), ); return $sortable_columns; } public function prepare_items() { $columns = $this->get_columns(); $hidden = array(); $this->process_action(); $this->_column_headers = array( $columns, $hidden, $this->get_sortable_columns() ); $page_num = $this->get_pagenum(); $per_page = 20; $args = array(); // phpcs:ignore WordPress.Security.NonceVerification.Recommended if ( isset( $_GET['orderby'] ) ) { // phpcs:ignore WordPress.Security.NonceVerification.Recommended $args['orderby'] = sanitize_text_field( wp_unslash( $_GET['orderby'] ) ); } // phpcs:ignore WordPress.Security.NonceVerification.Recommended if ( isset( $_GET['order'] ) ) { // phpcs:ignore WordPress.Security.NonceVerification.Recommended $args['order'] = sanitize_text_field( wp_unslash( $_GET['order'] ) ); } // phpcs:ignore WordPress.Security.NonceVerification.Recommended if ( isset( $_GET['s'] ) && isset( $_REQUEST['_wpnonce'] ) ) { $nonce = sanitize_text_field( wp_unslash( $_REQUEST['_wpnonce'] ) ); if ( wp_verify_nonce( $nonce, 'bulk-' . $this->_args['plural'] ) ) { // phpcs:ignore WordPress.Security.NonceVerification.Recommended $args['s'] = sanitize_text_field( wp_unslash( $_GET['s'] ) ); } } $followers_with_count = FollowerCollection::get_followers_with_count( $this->user_id, $per_page, $page_num, $args ); $followers = $followers_with_count['followers']; $counter = $followers_with_count['total']; $this->items = array(); $this->set_pagination_args( array( 'total_items' => $counter, 'total_pages' => ceil( $counter / $per_page ), 'per_page' => $per_page, ) ); foreach ( $followers as $follower ) { $item = array( 'icon' => esc_attr( $follower->get_icon_url() ), 'post_title' => esc_attr( $follower->get_name() ), 'username' => esc_attr( $follower->get_preferred_username() ), 'url' => esc_attr( $follower->get_url() ), 'identifier' => esc_attr( $follower->get_id() ), 'published' => esc_attr( $follower->get_published() ), 'modified' => esc_attr( $follower->get_updated() ), ); $this->items[] = $item; } } public function get_bulk_actions() { return array( 'delete' => __( 'Delete', 'activitypub' ), ); } public function column_default( $item, $column_name ) { if ( ! array_key_exists( $column_name, $item ) ) { return __( 'None', 'activitypub' ); } return $item[ $column_name ]; } public function column_avatar( $item ) { return sprintf( '', $item['icon'] ); } public function column_url( $item ) { return sprintf( '%s', $item['url'], $item['url'] ); } public function column_cb( $item ) { return sprintf( '', esc_attr( $item['identifier'] ) ); } public function process_action() { if ( ! isset( $_REQUEST['followers'] ) || ! isset( $_REQUEST['_wpnonce'] ) ) { return false; } $nonce = sanitize_text_field( wp_unslash( $_REQUEST['_wpnonce'] ) ); if ( ! wp_verify_nonce( $nonce, 'bulk-' . $this->_args['plural'] ) ) { return false; } if ( ! current_user_can( 'edit_user', $this->user_id ) ) { return false; } $followers = $_REQUEST['followers']; // phpcs:ignore switch ( $this->current_action() ) { case 'delete': if ( ! is_array( $followers ) ) { $followers = array( $followers ); } foreach ( $followers as $follower ) { FollowerCollection::remove_follower( $this->user_id, $follower ); } break; } } public function get_user_count() { return FollowerCollection::count_followers( $this->user_id ); } }