mirror of
git://develop.git.wordpress.org/
synced 2025-04-07 13:43:25 +02:00
Users: Return a WP_Error
from wp_insert_user()
if the user_url
field is too long.
The `user_url` database field only allows up to 100 characters, and if the value is longer than that, the function should return a proper error message instead of silently failing. This complements similar checks for `user_login` and `user_nicename` fields. Follow-up to [45], [1575], [32299], [34218], [34626]. Props mkox, sabernhardt, tszming, SergeyBiryukov. Fixes #44107. git-svn-id: https://develop.svn.wordpress.org/trunk@52650 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
1bf3a87e2b
commit
0fd2e294be
@ -2043,6 +2043,10 @@ function wp_insert_user( $userdata ) {
|
||||
*/
|
||||
$user_url = apply_filters( 'pre_user_url', $raw_user_url );
|
||||
|
||||
if ( mb_strlen( $user_url ) > 100 ) {
|
||||
return new WP_Error( 'user_url_too_long', __( 'User URL may not be longer than 100 characters.' ) );
|
||||
}
|
||||
|
||||
$user_registered = empty( $userdata['user_registered'] ) ? gmdate( 'Y-m-d H:i:s' ) : $userdata['user_registered'];
|
||||
|
||||
$user_activation_key = empty( $userdata['user_activation_key'] ) ? '' : $userdata['user_activation_key'];
|
||||
|
@ -1000,6 +1000,24 @@ class Tests_User extends WP_UnitTestCase {
|
||||
$this->assertSame( $expected, $user->user_nicename );
|
||||
}
|
||||
|
||||
/**
|
||||
* @ticket 44107
|
||||
*/
|
||||
public function test_wp_insert_user_should_reject_user_url_over_100_characters() {
|
||||
$user_url = str_repeat( 'a', 101 );
|
||||
$u = wp_insert_user(
|
||||
array(
|
||||
'user_login' => 'test',
|
||||
'user_email' => 'test@example.com',
|
||||
'user_pass' => 'password',
|
||||
'user_url' => $user_url,
|
||||
)
|
||||
);
|
||||
|
||||
$this->assertWPError( $u );
|
||||
$this->assertSame( 'user_url_too_long', $u->get_error_code() );
|
||||
}
|
||||
|
||||
/**
|
||||
* @ticket 28004
|
||||
*/
|
||||
|
Loading…
x
Reference in New Issue
Block a user