Los permisos de rol de tipo de publicación personalizada no me permiten leer


9

No puedo obtenerlo para que mi rol de usuario para un proveedor pueda leer el tipo de envío de envíos. Aparece en su menú, pero cuando hace clic en él, no puede ver el mensaje de error de esta página .

Funciona si yo add_cap('read_posts')pero no quiero que vean las publicaciones regulares solo el tipo de publicación de envíos.

Tengo un rol de usuario de proveedores con las siguientes capacidades.

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
        )

)

Y he configurado el tipo de publicación para envíos con lo siguiente

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

Verifique esta solución: wordpress.stackexchange.com/a/108375/38771
PS

Lo he leído varias veces ... seguí las instrucciones de todo lo que podía hacer. Aún así, no puedo acceder hasta que otorgue el permiso create_shipments.
Nicholas Koskowski

3
¿Puedes compartir tu código donde estás agregando el rol add_role()y las mayúsculas add_cap()?
Mat

1
¿Está tratando de permitir que el proveedor lea este tipo de publicación en el front-end o en el back-end?
Myles

¿Y este código está en un complemento o un tema? El complemento es mejor, pero de cualquier manera, con más información sobre su configuración, estoy seguro de que puedo proporcionarle una solución aún más completa
Myles

Respuestas:


4

Su tipo de publicación personalizado parece que está configurado correctamente. Funciona en mi instalación de prueba. Pruebe esto en lugar de cualquier código add_role y add_cap que esté usando actualmente. (Solo para fines de prueba. No lo use en el código de producción, por las razones que se detallan a continuación). Me está funcionando:

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

Es muy importante recordar que agregar funciones y capacidades de usuario en realidad ahorra datos a la base de datos. Entonces, si tenía una versión de su código antes que no funcionó, luego agregó algo que lo haría funcionar, podría no haber tenido efecto si todavía hay datos antiguos en su base de datos. add_role () devuelve nulo si el rol ya existe en la base de datos. Para el código de producción, en realidad debería usar los ganchos de activación y desactivación del complemento para estas cosas en lugar de ejecutarlo cada vez, de esta manera:

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()y remove_role()no debe ejecutarse en cada solicitud. Tenga en cuenta que una vez que se agrega un rol a la base de datos, no debe agregarlo nuevamente. Por lo general, agrega roles register_activation_hooky elimina roles en register_deactivation_hook/ register_unistall_hook; Aparte de eso, debe ejecutar remove_role()/ add_role()solo si realmente es necesario.
cybmeta

Lo sé, y lo he mencionado también en mi respuesta. Pero aún puede ser una forma rápida de diagnosticar problemas en el desarrollo para que no tenga que hacer clic en desactivar y luego activar cada vez que realice un cambio en el código. Luego, cuando esté funcionando, muévalo a los ganchos de activación y desactivación
Myles

1
@cybmeta Eso es cierto. Edité mi respuesta para reflejar cómo se pueden seguir las mejores prácticas.
Myles

0

En su objeto de rol, tiene la capacidad 'create_shipment' donde en realidad debería decir 'create_shipments'. Parece que puede faltar una 's' en su código cada vez que agrega esa capacidad.


0

Puedes probar:

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

Probar esto. 'dms_document' es el tipo de publicación personalizada.

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);
Al usar nuestro sitio, usted reconoce que ha leído y comprende nuestra Política de Cookies y Política de Privacidad.
Licensed under cc by-sa 3.0 with attribution required.