Inline documentation for hooks in wp-admin/user-new.php & wp-admin/user-edit.php.
Also fixes one parameter type in wp-includes/user.php. Fixes #25726. git-svn-id: https://develop.svn.wordpress.org/trunk@26493 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
a129345361
commit
ab9d51d632
@ -74,9 +74,26 @@ function use_ssl_preference($user) {
|
|||||||
<?php
|
<?php
|
||||||
}
|
}
|
||||||
|
|
||||||
// Only allow super admins on multisite to edit every user.
|
/**
|
||||||
if ( is_multisite() && ! current_user_can( 'manage_network_users' ) && $user_id != $current_user->ID && ! apply_filters( 'enable_edit_any_user_configuration', true ) )
|
* Filter whether to allow administrators on Multisite to edit every user.
|
||||||
|
*
|
||||||
|
* Enabling the user editing form via this filter also hinges on the user holding
|
||||||
|
* the 'manage_network_users' cap, and the logged-in user not matching the user
|
||||||
|
* profile open for editing.
|
||||||
|
*
|
||||||
|
* The filter was introduced to replace the EDIT_ANY_USER constant.
|
||||||
|
*
|
||||||
|
* @since 3.0.0
|
||||||
|
*
|
||||||
|
* @param bool $allow Whether to allow editing of any user. Default true.
|
||||||
|
*/
|
||||||
|
if ( is_multisite()
|
||||||
|
&& ! current_user_can( 'manage_network_users' )
|
||||||
|
&& $user_id != $current_user->ID
|
||||||
|
&& ! apply_filters( 'enable_edit_any_user_configuration', true )
|
||||||
|
) {
|
||||||
wp_die( __( 'You do not have permission to edit this user.' ) );
|
wp_die( __( 'You do not have permission to edit this user.' ) );
|
||||||
|
}
|
||||||
|
|
||||||
// Execute confirmed email change. See send_confirmation_on_profile_email().
|
// Execute confirmed email change. See send_confirmation_on_profile_email().
|
||||||
if ( is_multisite() && IS_PROFILE_PAGE && isset( $_GET[ 'newuseremail' ] ) && $current_user->ID ) {
|
if ( is_multisite() && IS_PROFILE_PAGE && isset( $_GET[ 'newuseremail' ] ) && $current_user->ID ) {
|
||||||
@ -106,10 +123,27 @@ check_admin_referer('update-user_' . $user_id);
|
|||||||
if ( !current_user_can('edit_user', $user_id) )
|
if ( !current_user_can('edit_user', $user_id) )
|
||||||
wp_die(__('You do not have permission to edit this user.'));
|
wp_die(__('You do not have permission to edit this user.'));
|
||||||
|
|
||||||
if ( IS_PROFILE_PAGE )
|
if ( IS_PROFILE_PAGE ) {
|
||||||
do_action('personal_options_update', $user_id);
|
/**
|
||||||
else
|
* Fires before the page loads on the 'Your Profile' editing screen.
|
||||||
do_action('edit_user_profile_update', $user_id);
|
*
|
||||||
|
* The action only fires if the current user is editing their own profile.
|
||||||
|
*
|
||||||
|
* @since 2.0.0
|
||||||
|
*
|
||||||
|
* @param int $user_id The user ID.
|
||||||
|
*/
|
||||||
|
do_action( 'personal_options_update', $user_id );
|
||||||
|
} else {
|
||||||
|
/**
|
||||||
|
* Fires before the page loads on the 'Edit User' screen.
|
||||||
|
*
|
||||||
|
* @since 2.7.0
|
||||||
|
*
|
||||||
|
* @param int $user_id The user ID.
|
||||||
|
*/
|
||||||
|
do_action( 'edit_user_profile_update', $user_id );
|
||||||
|
}
|
||||||
|
|
||||||
if ( !is_multisite() ) {
|
if ( !is_multisite() ) {
|
||||||
$errors = edit_user($user_id);
|
$errors = edit_user($user_id);
|
||||||
@ -188,8 +222,14 @@ if ( ! IS_PROFILE_PAGE ) {
|
|||||||
<?php }
|
<?php }
|
||||||
} ?>
|
} ?>
|
||||||
</h2>
|
</h2>
|
||||||
|
<?php
|
||||||
<form id="your-profile" action="<?php echo esc_url( self_admin_url( IS_PROFILE_PAGE ? 'profile.php' : 'user-edit.php' ) ); ?>" method="post"<?php do_action('user_edit_form_tag'); ?>>
|
/**
|
||||||
|
* Fires inside the your-profile form tag on the user editing screen.
|
||||||
|
*
|
||||||
|
* @since 3.0.0
|
||||||
|
*/
|
||||||
|
?>
|
||||||
|
<form id="your-profile" action="<?php echo esc_url( self_admin_url( IS_PROFILE_PAGE ? 'profile.php' : 'user-edit.php' ) ); ?>" method="post"<?php do_action( 'user_edit_form_tag' ); ?>>
|
||||||
<?php wp_nonce_field('update-user_' . $user_id) ?>
|
<?php wp_nonce_field('update-user_' . $user_id) ?>
|
||||||
<?php if ( $wp_http_referer ) : ?>
|
<?php if ( $wp_http_referer ) : ?>
|
||||||
<input type="hidden" name="wp_http_referer" value="<?php echo esc_url($wp_http_referer); ?>" />
|
<input type="hidden" name="wp_http_referer" value="<?php echo esc_url($wp_http_referer); ?>" />
|
||||||
@ -211,6 +251,16 @@ if ( ! IS_PROFILE_PAGE ) {
|
|||||||
<?php if ( count($_wp_admin_css_colors) > 1 && has_action('admin_color_scheme_picker') ) : ?>
|
<?php if ( count($_wp_admin_css_colors) > 1 && has_action('admin_color_scheme_picker') ) : ?>
|
||||||
<tr>
|
<tr>
|
||||||
<th scope="row"><?php _e('Admin Color Scheme')?></th>
|
<th scope="row"><?php _e('Admin Color Scheme')?></th>
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Fires in the 'Admin Color Scheme' section of the user editing screen.
|
||||||
|
*
|
||||||
|
* The section is only enabled if a callback is hooked to the action,
|
||||||
|
* and if there is more than one defined color scheme for the admin.
|
||||||
|
*
|
||||||
|
* @since 3.0.0
|
||||||
|
*/
|
||||||
|
?>
|
||||||
<td><?php do_action( 'admin_color_scheme_picker' ); ?></td>
|
<td><?php do_action( 'admin_color_scheme_picker' ); ?></td>
|
||||||
</tr>
|
</tr>
|
||||||
<?php
|
<?php
|
||||||
@ -230,11 +280,30 @@ if ( !( IS_PROFILE_PAGE && !$user_can_edit ) ) : ?>
|
|||||||
</fieldset>
|
</fieldset>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
<?php do_action('personal_options', $profileuser); ?>
|
<?php
|
||||||
|
/**
|
||||||
|
* Fires at the end of the 'Personal Options' settings table on the user editing screen.
|
||||||
|
*
|
||||||
|
* @since 2.7.0
|
||||||
|
*
|
||||||
|
* @param WP_User $profileuser The current WP_User object.
|
||||||
|
*/
|
||||||
|
do_action( 'personal_options', $profileuser );
|
||||||
|
?>
|
||||||
</table>
|
</table>
|
||||||
<?php
|
<?php
|
||||||
if ( IS_PROFILE_PAGE )
|
if ( IS_PROFILE_PAGE ) {
|
||||||
do_action('profile_personal_options', $profileuser);
|
/**
|
||||||
|
* Fires after the 'Personal Options' settings table on the 'Your Profile' editing screen.
|
||||||
|
*
|
||||||
|
* The action only fires if the current user is editing their own profile.
|
||||||
|
*
|
||||||
|
* @since 2.0.0
|
||||||
|
*
|
||||||
|
* @param WP_User $profileuser The current WP_User object.
|
||||||
|
*/
|
||||||
|
do_action( 'profile_personal_options', $profileuser );
|
||||||
|
}
|
||||||
?>
|
?>
|
||||||
|
|
||||||
<h3><?php _e('Name') ?></h3>
|
<h3><?php _e('Name') ?></h3>
|
||||||
@ -353,7 +422,19 @@ if ( is_multisite() && is_network_admin() && ! IS_PROFILE_PAGE && current_user_c
|
|||||||
foreach ( wp_get_user_contact_methods( $profileuser ) as $name => $desc ) {
|
foreach ( wp_get_user_contact_methods( $profileuser ) as $name => $desc ) {
|
||||||
?>
|
?>
|
||||||
<tr>
|
<tr>
|
||||||
<th><label for="<?php echo $name; ?>"><?php echo apply_filters('user_'.$name.'_label', $desc); ?></label></th>
|
<?php
|
||||||
|
/**
|
||||||
|
* Filter a user contactmethod label.
|
||||||
|
*
|
||||||
|
* The dynamic portion of the filter hook, $name, refers to
|
||||||
|
* each of the keys in the contactmethods array.
|
||||||
|
*
|
||||||
|
* @since 2.9.0
|
||||||
|
*
|
||||||
|
* @param string $desc The translatable label for the contactmethod.
|
||||||
|
*/
|
||||||
|
?>
|
||||||
|
<th><label for="<?php echo $name; ?>"><?php echo apply_filters( "user_{$name}_label", $desc ); ?></label></th>
|
||||||
<td><input type="text" name="<?php echo $name; ?>" id="<?php echo $name; ?>" value="<?php echo esc_attr($profileuser->$name) ?>" class="regular-text" /></td>
|
<td><input type="text" name="<?php echo $name; ?>" id="<?php echo $name; ?>" value="<?php echo esc_attr($profileuser->$name) ?>" class="regular-text" /></td>
|
||||||
</tr>
|
</tr>
|
||||||
<?php
|
<?php
|
||||||
@ -371,7 +452,8 @@ if ( is_multisite() && is_network_admin() && ! IS_PROFILE_PAGE && current_user_c
|
|||||||
</tr>
|
</tr>
|
||||||
|
|
||||||
<?php
|
<?php
|
||||||
$show_password_fields = apply_filters('show_password_fields', true, $profileuser);
|
/** This filter is documented in wp-admin/user-new.php */
|
||||||
|
$show_password_fields = apply_filters( 'show_password_fields', true, $profileuser );
|
||||||
if ( $show_password_fields ) :
|
if ( $show_password_fields ) :
|
||||||
?>
|
?>
|
||||||
<tr id="password">
|
<tr id="password">
|
||||||
@ -396,13 +478,45 @@ if ( $show_password_fields ) :
|
|||||||
</table>
|
</table>
|
||||||
|
|
||||||
<?php
|
<?php
|
||||||
if ( IS_PROFILE_PAGE )
|
if ( IS_PROFILE_PAGE ) {
|
||||||
|
/**
|
||||||
|
* Fires after the 'About the User' settings table on the 'Your Profile' editing screen.
|
||||||
|
*
|
||||||
|
* The action only fires if the current user is editing their own profile.
|
||||||
|
*
|
||||||
|
* @since 2.0.0
|
||||||
|
*
|
||||||
|
* @param WP_User $profileuser The current WP_User object.
|
||||||
|
*/
|
||||||
do_action( 'show_user_profile', $profileuser );
|
do_action( 'show_user_profile', $profileuser );
|
||||||
else
|
} else {
|
||||||
|
/**
|
||||||
|
* Fires after the 'About the User' settings table on the 'Edit User' screen.
|
||||||
|
*
|
||||||
|
* @since 2.0.0
|
||||||
|
*
|
||||||
|
* @param WP_User $profileuser The current WP_User object.
|
||||||
|
*/
|
||||||
do_action( 'edit_user_profile', $profileuser );
|
do_action( 'edit_user_profile', $profileuser );
|
||||||
|
}
|
||||||
?>
|
?>
|
||||||
|
|
||||||
<?php if ( count( $profileuser->caps ) > count( $profileuser->roles ) && apply_filters( 'additional_capabilities_display', true, $profileuser ) ) : ?>
|
<?php
|
||||||
|
/**
|
||||||
|
* Filter whether to display additional capabilities for the user.
|
||||||
|
*
|
||||||
|
* The 'Additional Capabilities' section will only be enabled if
|
||||||
|
* the number of the user's capabilities exceeds their number of
|
||||||
|
* of roles.
|
||||||
|
*
|
||||||
|
* @since 2.8.0
|
||||||
|
*
|
||||||
|
* @param bool $enable Whether to display the capabilities. Default true.
|
||||||
|
* @param WP_User $profileuser The current WP_User object.
|
||||||
|
*/
|
||||||
|
if ( count( $profileuser->caps ) > count( $profileuser->roles )
|
||||||
|
&& apply_filters( 'additional_capabilities_display', true, $profileuser )
|
||||||
|
) : ?>
|
||||||
<h3><?php _e( 'Additional Capabilities' ); ?></h3>
|
<h3><?php _e( 'Additional Capabilities' ); ?></h3>
|
||||||
<table class="form-table">
|
<table class="form-table">
|
||||||
<tr>
|
<tr>
|
||||||
|
@ -117,11 +117,11 @@ Please click the following link to confirm the invite:
|
|||||||
$add_user_errors = $user_details[ 'errors' ];
|
$add_user_errors = $user_details[ 'errors' ];
|
||||||
} else {
|
} else {
|
||||||
/**
|
/**
|
||||||
* Filter the user_login, aka the username, before it is added to the site.
|
* Filter the user_login, also known as the username, before it is added to the site.
|
||||||
*
|
*
|
||||||
* @since 3.0.0
|
* @since 2.0.3
|
||||||
*
|
*
|
||||||
* @param string $_REQUEST['user_login'] The sanitized username.
|
* @param string $user_login The sanitized username.
|
||||||
*/
|
*/
|
||||||
$new_user_login = apply_filters( 'pre_user_login', sanitize_user( wp_unslash( $_REQUEST['user_login'] ), true ) );
|
$new_user_login = apply_filters( 'pre_user_login', sanitize_user( wp_unslash( $_REQUEST['user_login'] ), true ) );
|
||||||
if ( isset( $_POST[ 'noconfirmation' ] ) && is_super_admin() ) {
|
if ( isset( $_POST[ 'noconfirmation' ] ) && is_super_admin() ) {
|
||||||
@ -189,11 +189,11 @@ wp_enqueue_script('wp-ajax-response');
|
|||||||
wp_enqueue_script('user-profile');
|
wp_enqueue_script('user-profile');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allows you to enable user auto-complete for non-super admins in multisite.
|
* Filter whether to enable user auto-complete for non-super admins in Multisite.
|
||||||
*
|
*
|
||||||
* @since 3.4.0
|
* @since 3.4.0
|
||||||
*
|
*
|
||||||
* @param bool True or false, based on if you enable auto-complete for non-super admins. Default is false.
|
* @param bool $enable Whether to enable auto-complete for non-super admins. Default false.
|
||||||
*/
|
*/
|
||||||
if ( is_multisite() && current_user_can( 'promote_users' ) && ! wp_is_large_network( 'users' )
|
if ( is_multisite() && current_user_can( 'promote_users' ) && ! wp_is_large_network( 'users' )
|
||||||
&& ( is_super_admin() || apply_filters( 'autocomplete_users_for_site_admins', false ) )
|
&& ( is_super_admin() || apply_filters( 'autocomplete_users_for_site_admins', false ) )
|
||||||
@ -287,7 +287,7 @@ if ( is_multisite() ) {
|
|||||||
* @since 3.0.0
|
* @since 3.0.0
|
||||||
*/
|
*/
|
||||||
?>
|
?>
|
||||||
<form action="" method="post" name="adduser" id="adduser" class="validate"<?php do_action('user_new_form_tag');?>>
|
<form action="" method="post" name="adduser" id="adduser" class="validate"<?php do_action( 'user_new_form_tag' );?>>
|
||||||
<input name="action" type="hidden" value="adduser" />
|
<input name="action" type="hidden" value="adduser" />
|
||||||
<?php wp_nonce_field( 'add-user', '_wpnonce_add-user' ) ?>
|
<?php wp_nonce_field( 'add-user', '_wpnonce_add-user' ) ?>
|
||||||
|
|
||||||
@ -320,7 +320,7 @@ if ( is_multisite() ) {
|
|||||||
*
|
*
|
||||||
* @since 3.7.0
|
* @since 3.7.0
|
||||||
*
|
*
|
||||||
* @param string A contextual string specifying which type of new user form the hook follows.
|
* @param string $type A contextual string specifying which type of new user form the hook follows.
|
||||||
*/
|
*/
|
||||||
do_action( 'user_new_form', 'add-existing-user' );
|
do_action( 'user_new_form', 'add-existing-user' );
|
||||||
?>
|
?>
|
||||||
@ -334,10 +334,8 @@ if ( current_user_can( 'create_users') ) {
|
|||||||
echo '<h3 id="create-new-user">' . __( 'Add New User' ) . '</h3>';
|
echo '<h3 id="create-new-user">' . __( 'Add New User' ) . '</h3>';
|
||||||
?>
|
?>
|
||||||
<p><?php _e('Create a brand new user and add them to this site.'); ?></p>
|
<p><?php _e('Create a brand new user and add them to this site.'); ?></p>
|
||||||
<?php
|
<?php /** This action is documented in wp-admin/user-new.php */ ?>
|
||||||
/** This action is documented in wp-admin/user-new.php */
|
<form action="" method="post" name="createuser" id="createuser" class="validate"<?php do_action( 'user_new_form_tag' );?>>
|
||||||
?>
|
|
||||||
<form action="" method="post" name="createuser" id="createuser" class="validate"<?php do_action('user_new_form_tag');?>>
|
|
||||||
<input name="action" type="hidden" value="createuser" />
|
<input name="action" type="hidden" value="createuser" />
|
||||||
<?php wp_nonce_field( 'create-user', '_wpnonce_create-user' ); ?>
|
<?php wp_nonce_field( 'create-user', '_wpnonce_create-user' ); ?>
|
||||||
<?php
|
<?php
|
||||||
@ -382,7 +380,7 @@ foreach ( array( 'user_login' => 'login', 'first_name' => 'firstname', 'last_nam
|
|||||||
*
|
*
|
||||||
* @since 1.5.1
|
* @since 1.5.1
|
||||||
*
|
*
|
||||||
* @param bool True or false, based on if you want to show the password fields. Default is true.
|
* @param bool $show Whether to show the password fields. Default true.
|
||||||
*/
|
*/
|
||||||
if ( apply_filters( 'show_password_fields', true ) ) : ?>
|
if ( apply_filters( 'show_password_fields', true ) ) : ?>
|
||||||
<tr class="form-field form-required">
|
<tr class="form-field form-required">
|
||||||
|
@ -1564,7 +1564,7 @@ function wp_get_user_contact_methods( $user = null ) {
|
|||||||
* @since 2.9.0
|
* @since 2.9.0
|
||||||
*
|
*
|
||||||
* @param array $methods Array of contact methods and their labels.
|
* @param array $methods Array of contact methods and their labels.
|
||||||
* @param WP_User $user Optional. WP_User object.
|
* @param WP_User $user WP_User object.
|
||||||
*/
|
*/
|
||||||
return apply_filters( 'user_contactmethods', $methods, $user );
|
return apply_filters( 'user_contactmethods', $methods, $user );
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user