[wp-trac] [WordPress Trac] #14122: Custom "capabilities" appears broken on custom post types
WordPress Trac
wp-trac at lists.automattic.com
Wed Nov 10 13:13:43 UTC 2010
#14122: Custom "capabilities" appears broken on custom post types
----------------------------+-----------------------------------------------
Reporter: jakemgold | Owner: nacin
Type: task (blessed) | Status: assigned
Priority: normal | Milestone: 3.1
Component: Post Types | Version: 3.0
Severity: normal | Keywords: needs-patch needs-unit-tests
----------------------------+-----------------------------------------------
Comment(by nacin):
Re-post:
----
Here's a big issue with 3.0 functionality.
{{{
register_post_type( 'book', array(
'capability_type' => 'post',
'capabilities' => array( 'edit_post' => 'edit_book' ),
)
);
$user_id = 1;
$post_id = wp_insert_post( array( 'post_title' => 'book', 'post_type' =>
'book', 'post_status' => 'private', 'post_author' => 1 ) );
var_dump( map_meta_cap( 'edit_post', $user_id, $post_id ) );
$post_type_obj = get_post_type_object( 'book' );
var_dump( map_meta_cap( $post_type_obj->cap->edit_post, 1, $post_id ) );
}}}
You should get two arrays that match. They won't, though. Checking through
the post type cap will give you edit_book (no mapping), but checking
through edit_post will give you edit_private_posts based on the faulty
meta cap.
The bug everyone has been seeing is caused by a direct edit_post call in
the list table. While core shouldn't have any of these, we need to remain
compat for plugins. They should work the same.
--
Ticket URL: <http://core.trac.wordpress.org/ticket/14122#comment:44>
WordPress Trac <http://core.trac.wordpress.org/>
WordPress blogging software
More information about the wp-trac
mailing list