WP_REST_Menus_Controller::check_has_read_only_access() – Checks whether the current user has read permission for the endpoint.

You appear to be a bot. Output may be restricted

Description

Checks whether the current user has read permission for the endpoint.

This allows for any user that can edit_theme_options or edit any REST API available post type.

Usage

$bool|WP_Error = WP_REST_Menus_Controller::check_has_read_only_access( $request );

Parameters

$request
( WP_REST_Request ) required – Full details about the request.

Returns

bool|WP_Error Whether the current user has permission.

Source

File name: wordpress/wp-includes/rest-api/endpoints/class-wp-rest-menus-controller.php


Lines:

1 to 22 of 22
  protected function check_has_read_only_access( $request ) {
    if ( current_user_can( 'edit_theme_options' ) ) {
      return true;
    }

    if ( current_user_can( 'edit_posts' ) ) {
      return true;
    }

    foreach ( get_post_types( array( 'show_in_rest' => true ), 'objects' ) as $post_type ) {
      if ( current_user_can( $post_type->cap->edit_posts ) ) {
        return true;
      }
    }

    return new WP_Error(
      'rest_cannot_view',
      __( 'Sorry, you are not allowed to view menus.' ),
      array( 'status' => rest_authorization_required_code() )
    );
  }
 

 View on GitHub View on Trac