Make WordPress Core


Ignore:
Timestamp:
10/12/2023 03:02:41 PM (2 years ago)
Author:
davidbaumwald
Message:

Grouped backports to the 5.1 branch.

  • Comments: Prevent users who can not see a post from seeing comments on it.
  • Shortcodes: Restrict media shortcode ajax to certain type.
  • REST API: Ensure no-cache headers are sent when methods are overridden.
  • REST API: Limit search_columns for users without list_users.
  • Prevent unintended behavior when certain objects are unserialized.

Merges [56833], [56834], [56835], [56836], and [56838] to the 5.1 branch.
Props xknown, jorbin, joehoyle, timothyblynjacobs, peterwilsoncc, ehtis, tykoted, antpb, rmccue.

Location:
branches/5.1
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • branches/5.1

  • branches/5.1/src/wp-admin/includes/class-wp-list-table.php

    r44574 r56873  
    666666        $pending_phrase       = sprintf( _n( '%s pending comment', '%s pending comments', $pending_comments ), $pending_comments_number );
    667667
    668         // No comments at all.
     668        $post_object   = get_post( $post_id );
     669        $edit_post_cap = $post_object ? 'edit_post' : 'edit_posts';
     670        if (
     671            current_user_can( $edit_post_cap, $post_id ) ||
     672            (
     673                empty( $post_object->post_password ) &&
     674                current_user_can( 'read_post', $post_id )
     675            )
     676        ) {
     677            // The user has access to the post and thus can see comments
     678        } else {
     679            return false;
     680        }
     681
    669682        if ( ! $approved_comments && ! $pending_comments ) {
    670683            printf(
Note: See TracChangeset for help on using the changeset viewer.