J'ai un grand nombre d'utilisateurs avec Editor Capabilities qui aident à parcourir les soumissions post. Voici ma configuration actuelle pour ce rôle:
Comme vous pouvez le constater, ils sont autorisés à edit_posts
et edit_others_posts
mais ils ne peuvent pas edit_published_posts
. Cela signifie qu'ils peuvent modifier les publications ayant le statut Brouillon et En attente.
Maintenant, je veux les limiter à only pour pouvoir éditer les publications en attente. Ils ne pourront donc pas toucher aux brouillons ( sauf si s’ils sont l’auteur du post). Malheureusement, il n’existe pas de capacité comme edit_pending_posts
... il devrait y en avoir.
Comment résoudre ce problème?
Ce n'est en réalité pas difficile. Pour ajouter une nouvelle capacité, appelez WP_Roles->add_cap()
. Vous devez le faire une seule fois, car il sera stocké dans la base de données. Nous utilisons donc un hook d’activation de plugin.
Note aux autres lecteurs: Tout le code suivant est territoire du plugin .
register_activation_hook( __FILE__, 'epp_add_cap' );
/**
* Add new capability to "editor" role.
*
* @wp-hook "activate_" . __FILE__
* @return void
*/
function epp_add_cap()
{
global $wp_roles;
if ( ! isset( $wp_roles ) )
$wp_roles = new WP_Roles;
$wp_roles->add_cap( 'editor', 'edit_pending_posts' );
}
Nous devons maintenant filtrer tous les appels pour…
current_user_can( $post_type_object->cap->edit_post, $post->ID );
… Car c'est ainsi que WordPress vérifie si un utilisateur peut modifier un message. En interne, cela sera mis en correspondance avec la capacité edit_others_posts
pour les publications d'autres auteurs.
Nous devons donc filtrer user_has_cap
et examiner notre nouvelle capacité edit_pending_posts
lorsque certains veulent utiliser la capacité edit_post
.
J'ai aussi inclus delete_post
, parce que c'est aussi une sorte de modification.
Cela semble compliqué, mais c'est très simple:
add_filter( 'user_has_cap', 'epp_filter_cap', 10, 3 );
/**
* Allow editing others pending posts only with "edit_pending_posts" capability.
* Administrators can still edit those posts.
*
* @wp-hook user_has_cap
* @param array $allcaps All the capabilities of the user
* @param array $caps [0] Required capability ('edit_others_posts')
* @param array $args [0] Requested capability
* [1] User ID
* [2] Post ID
* @return array
*/
function epp_filter_cap( $allcaps, $caps, $args )
{
// Not our capability
if ( ( 'edit_post' !== $args[0] && 'delete_post' !== $args[0] )
or empty ( $allcaps['edit_pending_posts'] )
)
return $allcaps;
$post = get_post( $args[2] );
// Let users edit their own posts
if ( (int) $args[1] === (int) $post->post_author
and in_array(
$post->post_status,
array ( 'draft', 'pending', 'auto-draft' )
)
)
{
$allcaps[ $caps[0] ] = TRUE;
}
elseif ( 'pending' !== $post->post_status )
{ // Not our post status
$allcaps[ $caps[0] ] = FALSE;
}
return $allcaps;
}