Пользовательские разрешения роли типа записи не позволяют мне читать


9

Я не могу получить его, чтобы моя пользовательская роль для поставщика могла читать тип почтовых отправлений. Он отображается в их меню, но когда вы нажимаете на него, вы получаете, что вы не можете просматривать эту страницу сообщения об ошибке.

Это работает, если я, add_cap('read_posts')но я не хочу, чтобы они просматривали обычные сообщения, только по типу сообщений об отправках.

У меня есть роль поставщика поставщиков со следующими возможностями.

WP_Role Object
(
    [name] => supplier
    [capabilities] => Array
        (
            [read] => 1
            [edit_shipment] => 1
            [read_shipment] => 1
            [edit_others_shipments] => 1
            [publish_shipments] => 1
            [read_private_shipments] => 1
            [edit_shipments] => 1
            [create_shipment] => 1
            [read_shipments] => 1
        )

)

И я настроил тип сообщения для отправлений со следующим

function shipment_post_type() {
  $labels = array(
    'name'                  => _x( 'Shipments', 'Post Type General Name', 'sage' ),
    'singular_name'         => _x( 'Shipment', 'Post Type Singular Name', 'sage' ),
    'menu_name'             => __( 'Shipments', 'sage' ),
    'name_admin_bar'        => __( 'Shipments', 'sage' ),
    'archives'              => __( 'Shipment Archives', 'sage' ),
    'parent_item_colon'     => __( 'Parent shipment:', 'sage' ),
    'all_items'             => __( 'All shipments', 'sage' ),
    'add_new_item'          => __( 'Add New shipment', 'sage' ),
    'new_item'              => __( 'New shipment', 'sage' ),
    'edit_item'             => __( 'Edit shipment', 'sage' ),
    'update_item'           => __( 'Update shipment', 'sage' ),
    'view_item'             => __( 'View shipment', 'sage' ),
    'search_items'          => __( 'Search shipments', 'sage' ),
    'not_found'             => __( 'Not found', 'sage' ),
    'not_found_in_trash'    => __( 'Not found in Trash', 'sage' ),
    'featured_image'        => __( 'Featured Image', 'sage' ),
    'set_featured_image'    => __( 'Set shipment image', 'sage' ),
    'remove_featured_image' => __( 'Remove shipment image', 'sage' ),
    'use_featured_image'    => __( 'Use as shipment image', 'sage' ),
    'insert_into_item'      => __( 'Insert into shipment', 'sage' ),
    'uploaded_to_this_item' => __( 'Uploaded to this shipment', 'sage' ),
    'items_list'            => __( 'shipments list', 'sage' ),
    'items_list_navigation' => __( 'Constests list navigation', 'sage' ),
    'filter_items_list'     => __( 'Filter shipments list', 'sage' ),
  );
  $args = array(
    'label'                 => __( 'shipments', 'sage' ),
    'description'           => __( 'Manage all shipments, sweepstakes and giveaways.', 'sage' ),
    'labels'                => $labels,
    'supports'              => array( 'revisions' ),
    'taxonomies'            => array( '' ),
    'hierarchical'          => false,
    'public'                => true,
    'show_ui'               => true,
    'show_in_menu'          => true,
    'menu_position'         => 5,
    'menu_icon'             => 'dashicons-archive',
    'show_in_admin_bar'     => true,
    'show_in_nav_menus'     => false,
    'can_export'            => true,
    'has_archive'           => false,
    'exclude_from_search'   => true,
    'publicly_queryable'    => true,
    'map_meta_cap' => true,
    'capabilities' => array(
      'edit_post'          => 'edit_shipment',
      'read_post'          => 'read_shipment',
      'read_posts'         => 'read_shipments',
      'delete_post'        => 'delete_shipment',
      'delete_posts'       => 'delete_shipments',
      'edit_posts'         => 'edit_shipments',
      'edit_others_posts'  => 'edit_others_shipments',
      'publish_posts'      => 'publish_shipments',
      'read_private_posts' => 'read_private_shipments',
      'create_posts'       => 'create_shipments',
    ),
  );
  register_post_type( 'shipment', $args );

}
add_action( 'init', 'shipment_post_type', 0 );

Проверьте это решение: wordpress.stackexchange.com/a/108375/38771
PS

Я прочитал это несколько раз ... следовал инструкциям все, что я мог сделать. Тем не менее, вы не сможете получить доступ, пока я не дам разрешение create_shipments.
Николай Косковский

3
Можете ли вы поделиться своим кодом, где вы добавляете роль add_role()и заглавные буквы add_cap()?
Мат

1
Вы пытаетесь позволить поставщику прочитать этот тип поста на переднем или заднем конце?
Майлз

И этот код в плагине или теме? Плагин лучше, но в любом случае, с более подробной информацией о вашей настройке, я уверен, что смогу предоставить вам еще более комплексное решение
Myles

Ответы:


4

Ваш пользовательский тип записи выглядит так, как будто он настроен правильно. Это работает на моей тестовой установке. Попробуйте это вместо любого кода add_role и add_cap, который вы используете в данный момент. (Только для целей тестирования. Не используйте его в рабочем коде по причинам, изложенным ниже.) Это работает для меня:

function prefix_set_up_supplier_role(){
remove_role( 'supplier' );
add_role( 'supplier', 'Supplier', array(
        'read'                      => true,
        'edit_shipment'             => true,
        'read_shipment'             => true,
        'read_shipments'            => true,
        'delete_shipment'           => true,
        'delete_shipments'          => true,
        'edit_shipments'            => true,
        'edit_others_shipments'     => true,
        'publish_shipments'         => true,
        'read_private_shipments'    => true,
        'create_shipments'          => true,
    )
);
}
add_action( 'init', 'prefix_set_up_supplier_role' );

Очень важно помнить, что добавление пользовательских ролей и возможностей фактически сохраняет данные в базе данных. Поэтому, если у вас была версия вашего кода до того, как она не работала, а затем добавили что-то, что заставило бы ее работать, она могла бы не вступить в силу, если в вашей базе данных все еще есть старые данные. add_role () возвращает ноль, если роль уже существует в базе данных. Для производственного кода вы должны использовать хуки активации и деактивации плагина для этого, вместо того, чтобы запускать его каждый раз, например так:

register_activation_hook( __FILE__, 'prefix_activate' );
function prefix_activate(){
    add_role( 'supplier', 'Supplier', array(
        'read'                      => true,
        'edit_shipment'             => true,
        'read_shipment'             => true,
        'read_shipments'            => true,
        'delete_shipment'           => true,
        'delete_shipments'          => true,
        'edit_shipments'            => true,
        'edit_others_shipments'     => true,
        'publish_shipments'         => true,
        'read_private_shipments'    => true,
        'create_shipments'          => true,
    )
);
}

register_deactivation_hook( __FILE__, 'prefix_deactivate' );
function prefix_deactivate(){
    remove_role( 'supplier' );
}

2
add_role()и remove_role()не должен выполняться в каждом запросе. Обратите внимание, что как только роль добавлена ​​в базу данных, вы не сможете добавить ее снова. Обычно вы добавляете роли в register_activation_hookи удаляете роли в register_deactivation_hook/ register_unistall_hook; кроме этого, вы должны выполнить remove_role()/ add_role()только если это действительно необходимо.
cybmeta

Я знаю, и я упомянул это и в своем ответе. Но это все еще может быть быстрый способ диагностики проблем в разработке, так что вам не нужно нажимать кнопку деактивации, а затем активировать каждый раз, когда вы вносите изменения в код. Затем, когда он работает, переместите его в хуки активации и деактивации
Myles

1
@cybmeta Это правда. Я отредактировал свой ответ, чтобы отразить, как можно следовать передовым методам.
Майлз

0

В вашем объекте роли у вас есть возможность 'create_shipment', где он должен фактически сказать 'create_shipments'. Похоже, в вашем коде могут отсутствовать символы «s», где бы вы ни добавляли эту возможность.


0

Вы можете попробовать:

add_action( 'init', 'add_my_caps');
function add_my_caps() {
    global $wp_roles;

    if ( isset($wp_roles) ) {
        $wp_roles->add_cap( 'editor', 'edit_shipment' );
        $wp_roles->add_cap( 'editor', 'read_shipment' );
        $wp_roles->add_cap( 'editor', 'delete_shipment' );
        $wp_roles->add_cap( 'editor', 'publish_shipments' );
        $wp_roles->add_cap( 'editor', 'edit_shipments' );
        $wp_roles->add_cap( 'editor', 'edit_others_shipments' );
        $wp_roles->add_cap( 'editor', 'delete_shipments' );
        $wp_roles->add_cap( 'editor', 'delete_others_shipments' );
        $wp_roles->add_cap( 'editor', 'read_private_shipments' );
        ....

0

Попробуйте это. 'dms_document' - это пользовательский тип записи.

function jgd_add_role_caps() {
    // Add the roles you'd like to administer the custom post types
    $roles = array(
        'deity_user',
        'admin_user'
    );

    // Loop through each role and assign capabilities
    foreach($roles as $the_role) { 
        $role = get_role($the_role);

        $role->add_cap('read');
        $role->add_cap('read_dms_document');
        $role->add_cap('read_private_dms_documents');
        $role->add_cap('edit_dms_document');
        $role->add_cap('edit_dms_documents');
        $role->add_cap('edit_others_dms_documents');
        $role->add_cap('edit_published_dms_documents');
        $role->add_cap('publish_dms_documents');
        $role->add_cap('delete_others_dms_documents');
        $role->add_cap('delete_private_dms_documents');
        $role->add_cap('delete_dms_documents');
        $role->add_cap('delete_post_dms_documents');
        $role->add_cap('delete_published_dms_documents');
        $role->add_cap('delete_draft_dms_documents');
        $role->add_cap('delete_others_posts_dms_documents');
        $role->add_cap('delete_others_posts_dms_document');
        $role->add_cap('delete_posts_dms_documents');
        $role->add_cap('delete_posts_dms_document');
    }
}
add_action('admin_init','jgd_add_role_caps', 999);
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.