$user / User

The $user API variable is a type of page representing the current user, and the User class is Page type used for all users.

Click any linked item for full usage details and examples. Hookable methods are indicated with the icon. In addition to those shown below, the User class also inherits all the methods and properties of: Page, WireData and Wire.

Show $var?     Show args?       Only hookable?    

Common

NameReturnSummary 
changed(string $what)
NoneHook called when field has changed
get(string $key)
null mixedGet value 
roles PageArray Get the roles this user has.  
setEditor(WirePageEditor $editor)
NoneSet the Process module (WirePageEditor) that is editing this User

Access

NameReturnSummary 
addRole($role)
boolAdd Role to this user 
getPermissions()
PageArrayGet this user’s permissions, optionally within the context of a Page. 
$this->hasPagePermission($name)
boolDoes this user have named permission for the given Page?
hasPermission($name)
bool arrayDoes the user have the given permission? 
hasRole($role)
boolDoes this user have the given Role? 
$this->hasTemplatePermission($name, $template)
boolDoes this user have the given permission on the given template?
hasTfa()
bool string TfaDoes user have two-factor authentication (Tfa) enabled? (and what type?) 
isGuest()
boolIs this the non-logged in guest user? 
isLoggedin()
boolIs the current $user logged in and the same as this user? 
isSuperuser()
boolDoes this user have the superuser role? 
removeRole($role)
boolRemove Role from this user 
roles PageArray Get the roles this user has.  

Languages

NameReturnSummary 
language Language User language, applicable only if LanguageSupport installed.  
setLanguage($language)
selfSet language for user (quietly) 

Properties

NameReturnSummaryDefault
admin_theme string Admin theme class name (when applicable). 
email string Get or set email address for this user. 
pass string Password Set the user’s password.  

Additional methods and properties

In addition to the methods and properties above, User also inherits the methods and properties of these classes:

API reference based on ProcessWire core version 3.0.251