-
Notifications
You must be signed in to change notification settings - Fork 4.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Allow view access of template rest endpoint to anyone with the edit_post
capability
#60317
Allow view access of template rest endpoint to anyone with the edit_post
capability
#60317
Conversation
edit_post
capability
2f032ee
to
6836921
Compare
The following accounts have interacted with this PR and/or linked issues. I will continue to update these lists as activity occurs. You can also manually ask me to refresh this list by adding the If you're merging code through a pull request on GitHub, copy and paste the following into the bottom of the merge commit message.
To understand the WordPress project's expectations around crediting contributors, please review the Contributor Attribution page in the Core Handbook. |
You need to make a more thorough check here, right now this won't account for users who have the ability not to edit posts, but other CPTs that use the block editor. See |
6836921
to
b1efbfa
Compare
@TimothyBJacobs Thanks for much for your review :) I've updated the code to essentially match the example you've provided. |
…ost capability (WordPress#60317) Co-authored-by: fabiankaegy <[email protected]> Co-authored-by: TimothyBJacobs <[email protected]>
@fabiankaegy Could you handle small-typo-change in your backport PR? |
I added a backport in WordPress/wordpress-develop#6494 (Track Ticket) |
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; | ||
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This change appears to have caused an unintended regression.
Currently, Gutenberg uses the following code to determine whether the site editor can be accessed, mainly using the command palette, and switches the link destination based on the result.
wp.data.select('core').canUser( 'read', 'templates' )
With this PR, this code now returns true
even for non-administrator users, which causes links that they are not allowed to access to be displayed in commands, etc.
See #61419
Dev Note Draft:Allow view access of the template REST API endpoint to anyone with the
|
What?
Part of #60316 as requested in #58301 (comment)
Modify the template / template part rest endpoint to allow any user role with the
edit_post
capability to view entities.Why?
In order to render the block template in the locked template preview inside the post editor we need to be able to fetch the contents of any block templates / template parts for any user role that can edit a post.
How?
Overwriting the
get_items_permissions_check
andget_item_permissions_check
methods of therest_controller_class
of thewp_template
post type to check whether the current user canedit_posts
.Testing Instructions
Try making an authenticated rest request to the template rest endpoint with any user role that has the
edit_post
capability. -> The template should get returnedTry making an unauthenticated request and still get an unauthorized error