The Themosis framework comes with a User class that gives you shortcuts to core WordPress user functions. The User class extends the core WP_User class. So every core methods are available to your User instances as well.
The User class is not a "static" one. When using the
User
facade, you create each time a new instance. This is important to notice especially when working with user custom fields.
In order to create a new user, simply use the make()
method like so:
$user = User::make('johndoe', 'asecretpassword', '[email protected]');
This will create a new user with a username of johndoe
, a password of asecretpassword
assigned to the [email protected]
email address.
If WordPress is able to register the user or if the user already exists, it returns a User
instance. If there is an error, WordPress returns a WP_Error
instance.
Use the current()
method to retrieve the current logged in user:
$user = User::current();
If you have the User ID, you can retrieve an instance of this user like so:
$user = User::get(24);
This will return an User instance from a registered user with an ID of 24.
Check if your user instance has a specific role:
$user = User::current();
if ($user->hasRole('editor')) {
// Do something
}
You can attach a role to a selected user:
$user = User::current();
$user->setRole('editor');
$user = User::current();
if ($user->can('edit_posts')) {
// Do something
}
You can update user data by providing an array of properties. Note that the ID property is automatically fetched and inserted so you don't have to look after.
$user = User::current();
$user->update([
'user_url' => 'http://www.somewebsite.com',
'user_email' => '[email protected]'
]);
The User class provides methods to define custom user meta data. You can create user custom fields and whether or not to order them by sections.
You can define sections in order to group your user fields. You can add as many sections as you want to your users by using the addSections()
method. Pass the method a list of sections like so:
$user = User::addSections([
Section::make('section-slug', 'Section display name'),
Section::make('social', 'Social accounts')
]);
The
addSections()
method returns a User instance. Make sure to use that instance to add your user custom fields.
The above code will add two sections to the WordPress Add User
and Edit Profile
screens.
In order to define custom user meta data, use the addFields()
method and pass it an array of custom fields.
In the following example, we will add custom fields to our previously defined sections. Pass an array of custom fields to each sections defined as the array key like so:
// Grab our User instance from previous code sample
// and add fields to each section.
$user->addFields([
'section-slug' => [
Field::text('street', ['title' => 'Street address'])
],
'social' => [
Field::text('facebook', ['info' => 'Your facebook page.']),
Field::text('twitter', ['info' => 'Twitter account name.'])
]
]);
Use the Field API to define your user custom fields just like you would with metabox custom fields,...
You can add user custom fields without grouping them into sections. Directly use the addFields()
method like so:
User::addFields([
Field::text('street'),
Field::select('country', [
[
'Belgium',
'Brazil',
'Germany'
]
]),
Field::media('avatar')
]);
Calling the
addFields()
method this way means you're working on a separate user instance.
You can sanitize/validate user custom fields by using the validate()
method. Make sure to use the user instance used to define your custom fields in order to validate them:
$user = User::addFields([
Field::text('twitter'),
Field::number('age')
]);
// Validate our user instance fields...
$user->validate([
'twitter' => ['textfield', 'min:3'],
'age' => ['num']
]);
Simply define the field name as the key and specify a list of validation/sanitization rules to it.
Even if sections are defined, only use the custom field name in order to sanitize its value.
We also suggest you to always prefix your custom fields name so they don't conflict with other WordPress plugins or WordPress reserved terms.
For more information about validation rules, check the validation guide.