Existe-t-il un moyen de masquer les profils utilisateur dans le serveur principal tout en permettant à leurs informations d'être accessibles dans le serveur?
Quelque chose de similaire à définir des messages ou des pages à "brouillon", mais pour les utilisateurs fonctionnerait parfaitement. Y a-t-il un moyen de faire cela?
La table de base de données pour les utilisateurs contient le user_status
sous la forme d'un entier:
$users_single_table = "CREATE TABLE $wpdb->users (
ID bigint(20) unsigned NOT NULL auto_increment,
user_login varchar(60) NOT NULL default '',
user_pass varchar(255) NOT NULL default '',
user_nicename varchar(50) NOT NULL default '',
user_email varchar(100) NOT NULL default '',
user_url varchar(100) NOT NULL default '',
user_registered datetime NOT NULL default '0000-00-00 00:00:00',
user_activation_key varchar(255) NOT NULL default '',
user_status int(11) NOT NULL default '0',
display_name varchar(250) NOT NULL default '',
PRIMARY KEY (ID),
KEY user_login_key (user_login),
KEY user_nicename (user_nicename),
KEY user_email (user_email)
) $charset_collate;\n";
La classe WP_Users
n'a pour le moment rien qui puisse modifier la propriété state, ni même conserver cette propriété.
Il y a une fonction dans wp-admin/includes/ms.php
qui peut vous montrer le chemin à suivre.
update_user_status( $user_id, 'spam', '1' );
mais ne charge que pour multisite:
/wp-admin/includes/admin.php:
82 if ( is_multisite() ) {
83 require_once(ABSPATH . 'wp-admin/includes/ms-admin-filters.php');
84: require_once(ABSPATH . 'wp-admin/includes/ms.php');
85 require_once(ABSPATH . 'wp-admin/includes/ms-deprecated.php');
86 }
Cela ressemble à ceci:
function update_user_status( $id, $pref, $value, $deprecated = null ) {
global $wpdb;
if ( null !== $deprecated )
_deprecated_argument( __FUNCTION__, '3.0.2' );
$wpdb->update( $wpdb->users, array( sanitize_key( $pref ) => $value ), array( 'ID' => $id ) );
$user = new WP_User( $id );
clean_user_cache( $user );
if ( $pref == 'spam' ) {
if ( $value == 1 ) {
/**
* Fires after the user is marked as a SPAM user.
*
* @since 3.0.0
*
* @param int $id ID of the user marked as SPAM.
*/
do_action( 'make_spam_user', $id );
} else {
/**
* Fires after the user is marked as a HAM user. Opposite of SPAM.
*
* @since 3.0.0
*
* @param int $id ID of the user marked as HAM.
*/
do_action( 'make_ham_user', $id );
}
}
return $value;
}
Vous pouvez utiliser quelque chose de similaire et créerl'action hookmake_draft_user
, probable dans votre fonction _20161214_update_user_status( $user_id, 'draft', '1' );
À l'intérieur de votre propre crochet make_draft_user
, vous pouvez définir quoi faire.
Donc, WordPress prêt à l'emploi ne fournit pas d'utilisateurs brouillons. Peut-être que ce sera un jour avec le scénario d'utilisation clair. Peut-être que le statut sera une chaîne, et pas l'int (c'est le cas pour les publications).
Définir user_status sur 2 dans la base de données semble faire l'affaire