Роль пользовательской возможности Wordpress задана верно, но возвращает false
Я пытаюсь создать роль пользователя с некоторыми пользовательскими возможностями. Это работает до сих пор. Но если я хочу проверить права пользователя одной конкретной функции с помощью функции current_user_can()
, она вернет false. Но внутри массива возможностей новой созданной роли для конкретной возможности установлено значение true.
Итак, чтобы дать мои слова немного больше кода кодирования:
ОБЪЕКТ ОБЪЕКТА
WP_Role {
["name"]=> "organizer"
["capabilities"]=> {
["edit_posts"] => bool(false)
["delete_posts"] => bool(false)
["publish_posts"] => bool(false)
["upload_files"] => bool(true)
["edit_event"] => bool(true)
["read_event"] => bool(true)
["delete_event"] => bool(true)
["edit_events"] => bool(true)
["edit_others_events"] => bool(false)
["publish_events"] => bool(false)
["read_private_events"] => bool(true)
["read"] => bool(true)
["delete_events"] => bool(true)
["delete_private_events"] => bool(false)
["delete_published_events"] => bool(true)
["delete_others_events"] => bool(false)
["edit_private_events"] => bool(false)
["edit_published_events"] => bool(true)
["manage_event_terms"] => bool(true)
["edit_event_terms"] => bool(true)
["delete_event_terms"] => bool(true)
["assign_event_terms"] => bool(true)
}
MY ADD ROLE FUNCTION
add_role( 'organizer', __( 'Organizer', 'eventtool' ), array(
// General
'edit_posts' => false,
'delete_posts' => false,
'publish_posts' => false,
'upload_files' => true,
'edit_event' => true,
'read_event' => true,
'delete_event' => true,
// Primitive capabilities used outside of map_meta_cap():
'edit_events' => true,
'edit_others_events' => false,
'publish_events' => false,
'read_private_events' => true,
// Primitive capabilities used within map_meta_cap():
'read' => true,
'delete_events' => true,
'delete_private_events' => false,
'delete_published_events' => true,
'delete_others_events' => false,
'edit_private_events' => false,
'edit_published_events' => true,
'edit_events' => true,
// Terms
'manage_event_terms' => true,
'edit_event_terms' => true,
'delete_event_terms' => true,
'assign_event_terms' => true
)
);
ТАМОЖЕННЫЕ ТИПЫ ПОЛЬЗОВАНИЯ
register_post_type( 'event', array(
'labels' => $labels,
'description' => __( 'This is where you can add new events to your page.', 'eventtool' ),
'public' => true,
'show_ui' => true,
'capability_type' => 'event',
'map_meta_cap' => true,
'publicly_queryable' => true,
'exclude_from_search' => false,
'hierarchical' => false,
'rewrite' => _x( 'event', 'slug', 'eventtool' ),
'query_var' => true,
'supports' => array( 'title', 'editor', 'excerpt', 'thumbnail' ),
'show_in_nav_menus' => true
)
);
[ОБНОВЛЕНИЕ]
function et_modify_map_meta_cap( $caps, $cap, $user_id, $args ) {
var_dump($cap)
}
add_filter( 'map_meta_cap', 'et_modify_map_meta_cap', 10, 4 );
Выводит "edit_post" вместо "edit_event"
Любые предложения, почему возникает это неправильное поведение?
Ответы
Ответ 1
Сегодня я решил это.
Необходимо назначить идентификатор объекта для второго параметра функции current_user_can()
для получения правильного возврата однонаправленных возможностей (например, "edit_post" ). В противном случае функция вернет false, если этот параметр не установлен.
Как внутри документа WordPress:
Если вы не указали, вы можете получить предупреждение "Undefined offset: 0" (это потому, что функция current_user_can
в конечном итоге вызывает map_meta_cap
, которая при проверке метаданных ожидает массив, но получает только одно значение)
Ответ 2
Попробуйте сначала зарегистрировать эти capabilities
в пользовательский тип сообщения event
, а затем назначьте те capabilities
organiser
Вот так:
function create_my_post_types() {
register_post_type(
'movie',
array(
'public' => true,
'capability_type' => 'movie',
'capabilities' => array(
'publish_posts' => 'publish_movies',
'edit_posts' => 'edit_movies',
'edit_others_posts' => 'edit_others_movies',
'delete_posts' => 'delete_movies',
'delete_others_posts' => 'delete_others_movies',
'read_private_posts' => 'read_private_movies',
'edit_post' => 'edit_movie',
'delete_post' => 'delete_movie',
'read_post' => 'read_movie',
),
)
);
}
Измените код на event
тип сообщения.
И проверьте возможности пользователя по нижнему коду:
add_filter( 'map_meta_cap', 'my_map_meta_cap', 10, 4 );
function my_map_meta_cap( $caps, $cap, $user_id, $args ) {
/* If editing, deleting, or reading a movie, get the post and post type object. */
if ( 'edit_movie' == $cap || 'delete_movie' == $cap || 'read_movie' == $cap ) {
$post = get_post( $args[0] );
$post_type = get_post_type_object( $post->post_type );
/* Set an empty array for the caps. */
$caps = array();
}
/* If editing a movie, assign the required capability. */
if ( 'edit_movie' == $cap ) {
if ( $user_id == $post->post_author )
$caps[] = $post_type->cap->edit_posts;
else
$caps[] = $post_type->cap->edit_others_posts;
}
/* If deleting a movie, assign the required capability. */
elseif ( 'delete_movie' == $cap ) {
if ( $user_id == $post->post_author )
$caps[] = $post_type->cap->delete_posts;
else
$caps[] = $post_type->cap->delete_others_posts;
}
/* If reading a private movie, assign the required capability. */
elseif ( 'read_movie' == $cap ) {
if ( 'private' != $post->post_status )
$caps[] = 'read';
elseif ( $user_id == $post->post_author )
$caps[] = 'read';
else
$caps[] = $post_type->cap->read_private_posts;
}
/* Return the capabilities required by the user. */
return $caps;
}
Ответ 3
Попробуйте user_can(). Вам нужно будет передать идентификатор пользователя в качестве первого параметра. Вы можете получить его через get_current_user_id().