Налаштування рольових дозволів ролі не дозволяють мені читати


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 () повертає null, якщо роль вже існує в базі даних. Для виробничого коду ви фактично повинні використовувати гачки активації та деактивації плагіну для цього матеріалу, а не виконувати його щоразу, як це:

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

Я знаю, і це я вже згадував у своїй відповіді. Але це все ще може бути швидким способом діагностування проблем у розвитку, так що вам не доведеться натискати деактивувати, а потім активувати кожен раз, коли ви вносите зміни в код. Потім, коли це працює, перемістіть його на гачки активації та деактивації
Майлз

1
@cybmeta Це правда. Я відредагував свою відповідь, щоб відобразити, як можна дотримуватися кращих практик.
Майлз

0

У вашому об’єкті ролі у вас є можливість 'create_shipment', де насправді слід сказати «create_shipments». Здається, у вашому коді може бути відсутність пропуску, де ви додаєте цю можливість.


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.