Niestandardowe uprawnienia roli typu post nie pozwalają mi czytać

9

Nie mogę go uzyskać, aby moja rola użytkownika dla dostawcy mogła odczytać typ wysyłki. Wyświetla się w ich menu, ale po kliknięciu go nie możesz wyświetlić tego komunikatu o błędzie strony .

Działa, jeśli add_cap('read_posts')nie chcę, aby wyświetlały zwykłe posty tylko jako typ wysyłki.

Mam rolę użytkownika dostawcy z następującymi możliwościami.

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
        )

)

I ustawiłem typ postu dla przesyłek z następującymi

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 );
Mikołaj Koskowski
źródło
Sprawdź to rozwiązanie: wordpress.stackexchange.com/a/108375/38771
PS
Przeczytałem to wiele razy ... postępowałem zgodnie z instrukcjami, co mogłem zrobić. Nadal otrzymuj te, do których nie masz dostępu, dopóki nie udzielę zezwolenia na tworzenie_danych.
Nicholas Koskowski
3
Czy możesz udostępnić swój kod w miejscu, w którym dodajesz rolę add_role()i ograniczenia add_cap()?
Mat.
1
Czy próbujesz pozwolić dostawcy odczytać ten typ postu z przodu lub z tyłu?
Myles
A czy ten kod jest we wtyczce lub motywie? Wtyczka jest lepsza, ale w każdym razie, z większą ilością informacji o twojej konfiguracji jestem pewien, że mogę zapewnić ci jeszcze bardziej kompleksowe rozwiązanie
Myles

Odpowiedzi:

4

Twój niestandardowy typ postu wygląda na poprawnie skonfigurowany. Działa na mojej instalacji testowej. Wypróbuj to zamiast dowolnego kodu add_role i add_cap, którego obecnie używasz. (Tylko w celach testowych. Nie używaj go w kodzie produkcyjnym, z powodów wymienionych poniżej.) Działa dla mnie:

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' );

Bardzo ważne jest, aby pamiętać, że dodanie ról i możliwości użytkownika faktycznie zapisuje dane w bazie danych. Tak więc, jeśli wcześniej posiadałeś wersję swojego kodu, która nie do końca działała, a następnie dodałeś coś, co sprawiłoby, że działałaby, może nie zadziałać, jeśli w bazie danych nadal są stare dane. add_role () zwraca null, jeśli rola już istnieje w bazie danych. W przypadku kodu produkcyjnego powinieneś używać haków aktywacji i dezaktywacji wtyczek dla tych rzeczy zamiast uruchamiać je za każdym razem, tak jak to:

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' );
}
Myles
źródło
2
add_role()i remove_role()nie powinien być wykonywany przy każdym żądaniu. Pamiętaj, że po dodaniu roli do bazy danych nie można jej dodawać ponownie. Zwykle dodajesz role register_activation_hooki usuwasz role na register_deactivation_hook/ register_unistall_hook; poza tym powinieneś wykonać remove_role()/ add_role()tylko jeśli jest to naprawdę potrzebne.
cybmeta
Wiem i wspomniałem o tym również w mojej odpowiedzi. Ale nadal może to być szybki sposób diagnozowania problemów podczas programowania, dzięki czemu nie trzeba klikać opcji dezaktywuj, a następnie aktywować za każdym razem, gdy wprowadzasz zmiany w kodzie. Następnie, gdy działa, przenieś go do haków aktywacji i dezaktywacji
Myles,
1
@cybmeta To prawda. Zredagowałem swoją odpowiedź, aby odzwierciedlić sposób postępowania zgodnie z najlepszymi praktykami.
Myles
0

W swoim obiekcie roli masz zdolność „create_shipment”, w której powinna ona brzmieć „create_shipment”. Wydaje się, że w kodzie może brakować „s”, gdziekolwiek dodajesz tę możliwość.

Myles
źródło
0

Możesz spróbować:

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' );
        ....
T.Todua
źródło
0

Wypróbuj to. „dms_document” to niestandardowy typ postu.

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);
James George Dunn
źródło